You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The method calls minSizeInBits, minSizeInBytes, maxSizeInBits, and maxSizeInBytes can be applied to some expressions.
But it is not very explicit what kinds of expressions these can be. From the description below the table, it it seems it is applicable to typedef- and type-introduced types. But what else?
The P4C has a test where it applies these methods to values, probably yielding the size of the type that the value has. Is this intended to be permitted?
The P4C accepts application of these methods to headers.
In P4C, it is not possible apply them to bit<N>, i.e. both bit<4>.minSizeInBits() and (bit<4>).minSizeInBits() fails (with different errors).
Also in P4C, it is not possible to apply them to generic type parameters bit<4> test<T>() { return T.minSizeInBits(); } does not work. And this does not work also for generic values.
Frankly, I find this syntax a bit clunky, but given its existence, I think this should be cleaned up. I find it weird, that it can be applied to some concrete types (like headers), while not to others (like bit<4>). Also, I wonder if it should be permitted to use it for generic types (although I don't see a use case right now). Obviously such value would not be local compile time know. It can be only know after the function is inlined and the types are know. But at the very least, we should make the constraints much more explicit in the specification.
The text was updated successfully, but these errors were encountered:
The primary reason for introducing these methods was for applying them to variables with a header type, so if the spec is not explicit that this should be supported, that sounds like a good change to make to the spec.
Any other values or types it can apply to are simply bonuses, in my opinion.
The specifications says
But it is not very explicit what kinds of expressions these can be. From the description below the table, it it seems it is applicable to
typedef
- andtype
-introduced types. But what else?bit<N>
, i.e. bothbit<4>.minSizeInBits()
and(bit<4>).minSizeInBits()
fails (with different errors).bit<4> test<T>() { return T.minSizeInBits(); }
does not work. And this does not work also for generic values.Frankly, I find this syntax a bit clunky, but given its existence, I think this should be cleaned up. I find it weird, that it can be applied to some concrete types (like headers), while not to others (like
bit<4>
). Also, I wonder if it should be permitted to use it for generic types (although I don't see a use case right now). Obviously such value would not be local compile time know. It can be only know after the function is inlined and the types are know. But at the very least, we should make the constraints much more explicit in the specification.The text was updated successfully, but these errors were encountered: