-
Notifications
You must be signed in to change notification settings - Fork 32
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
Not possible to distinguish between scalars and arrays of length 1 #69
Comments
The absence of a difference is baked a long way into the IOC code, deliberately so I believe (Bob D. might be able to explain that). This isn't the only case where EPICS requires a client to know something about the PV it's connecting to. That also happens with an array of CHARs, is it a string or a series of 8-bit integers? The client has to know which it's meant to be to properly display the value. |
While I was digging around I could see that CA probably fundamentally cannot distinguish between these two types, but I do think it should be possible to do so for PVA; given that we send the data types over the wire, we should be able to say that "this is an array, but its length is 1". It's worth noting that one of the places that this decision is made at the moment is here; it's a very simply check that only looks at the length of the data and not the type of the data. This could be improved. (This gives me flashbacks of coding in APL; it is actually a bit non-trivial to have arrays of length 1, although it is possible) We can close this issue if this is truly how things should behave. But I think it is worth considering an improvement here. |
Concretely, this difference is expressed to QSRV through Of course, this still leaves cases where a "scalar" actually turns out to have zero elements. At which point things get messy...
I have had requests to allow modifications of field type mapping between PDB and PVA in places where there is no clear one-to-one relation. eg. coerce numeric to |
This seems like a useful addition. At least with CA, the Archiver Appliance can't keep archiving an array which has changed from 1 to >1 max elements after an IOC update, and vice versa, because there was a "type change". Avoiding the need to rename old data and recreate the archiver entry would be nice.
That might mean it's reasonable to add an option when archiving new PVs to treat them explicitly as arrays, especially for CA, where this problem cannot be fixed. I will try and format an issue request for that. |
While I think the |
Describe the bug
It is not possible at the moment to distinguish between the following records via PVAccess:
This ultimately manifests in the fact that fetching and processing data from a record that is a waveform of strings typically requires some additional checks, since you get something like
whereas if the array has
NELM > 1
then you instead getwhich is typically handled differently in e.g. pyepics, p4p, etc.
Note that this is not really restricted to PVXS, or even PVAccessCPP, but also ChannelAccess. In channel access I believe that due to the protocol there is no possible fix; in PVAccess, it should be fixable since an array of length 1 of type string is sent as an NTScalar, whereas an array of length > 1 is sent as an NTScalarArray; it should be possible to send an array of length one also as an NTScalarArray, which should fix this.
To Reproduce
Steps to reproduce the behavior:
Expected behavior
This is a bit murky, because I might be proposing a breaking change in how IOCs communicate over PVAccess. I think it would be more consistent to have arrays always send as NTScalarArrays instead of NTScalars if they are length 1. But there might be a good reason for the current behaviour.
Information (please complete the following):
Additional context
Add any other context about the problem here.
The text was updated successfully, but these errors were encountered: