-
Notifications
You must be signed in to change notification settings - Fork 120
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
Discussion: OPC-UA structures are not optional #199
Comments
What do you find most annoying about the nullable properties? When sending an IServiceRequest, the library looks for null RequestHeader and fills in a default one. Are there other fields that could be auto-filled? see
|
Most annoying is that the type system does not reflect some guaranties we have with OPC UA. I know, giving a "request" as an example, was not optimal. I just looked for an example where a
we have to suppress an nullable warning. We know that a after recieving a structure, the structure cannot be var response = new HistoryReadResponse();
var header = response.ResponseHeader.Timestamp; // ouch, ResponseHeader is null So if we want to reduce the warnings on accessing structures, we have to make the C# types to be non-null after construction. One way would be my example above. We could make my proposable more backward compatible by still allowing setting the property, i.e., public class HistoryReadRequest : IServiceRequest
{
public RequestHeader RequestHeader { get; set; } = new RequestHeader();
public HistoryReadDetails? HistoryReadDetails { get; set; }
// ... Then we do not have to mark it by a question mark and use it as a non-nullable. |
Some users may set the TimeoutHint in the SecureChannel. These settings are used when the RequestHeader is null.
Should we get rid of these settings above, and use constants in the RequestHeader constructor?
|
I'm not sure if we are talking about the same things. What I'm talking about are the nullability warning that you are getting with latest version of C#/dotnet. It don't think that UaClient library is doing something wrong. In fact it's doing right, but the compile cannot and does not recognize this. Let me give you the following example: Both examples |
Recently, I'm playing around with C#'s nullable references. And it is a little bit annoying because there are many references that the compiler identifies as possible nullable, but in reallity are never
null
. I first thought it is some kind of weakness of the C# type system, but if you look at a different angle on it, the nature of OPC UA structure could help us. OPC UA structures are not optional, i.e., they cannot be null, similar to C# structures. We cannot use C# structures because of the lack of inheritance support. But we can make the instances non-optional. Let's take an look on an example:While we always know it is non-null when read from stream (I know a request is not read from stream...); after a casual creation with
new
it is null.We could change that! So that all structures are preinitialized before (note: I'm not talking about ExtensionObject). Like:
ExtensionObject
s and arrays, which both could be null, would stay as they are. But ordenary structures would become non-nullable! The above examples probably does not work for JSON or XML encoding. Maybe we'd need to add a second method for encoding likeDecode(IDecoder decoder, string fieldname)
.Anyway, this is just to start a discussion, because a change would cause a code break for nearly everyone, we should only do this after a careful consideration.
The text was updated successfully, but these errors were encountered: