-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add WaveForm
and Enum
dataypes
#85
Comments
I think |
Can we just do |
Okay, I'll move it to that PR.
I'll make it so that an enum type which exceeds the epics limit for options comes out as a |
WaveForm
Will be either a
Sequence[T]
whereT
isfloat
,int
, orstr
, or a numpy array with adtype
. This will not be an arg to the dataclass (not optional).There will be a
length
on the datatype set to some sane default, since this is required by the EPICS and tango backends.Enum
Will take a python
enum.Enum
type. When putting to the attribute you put the enum member not a string/int value itself. We will check on initialisation that all the values are either string or int.We should keep allowed values for checking on
Attribute.set
, but I don't think that the current system of making andmbb
record if it's a string with allowed values is as nice as having a dedicatedEnum
datatype that can be altered to whatever control system's enum definition.Changes which will be required across datatypes.
DataType
will now be given two additional attributes:cast(T)
: For casting to a datatype which can be sent over the control system. It will also do some validation (i.e checking that anInt
value doesn't exceed the maximum defined in theDataType
).@property\intitial_value()
: We can't rely onAttr._datatype.dtype()
for an initial value anymore since the structured numpy array's has to be initialised with shape (length in our case) anddtype=
. For enums this is true too. Therefore, we will useDataType.initial_value
for the default initial value on attributes. This can be defaulted toself.dtype()
in theAttribute
base class.The text was updated successfully, but these errors were encountered: