-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Changes in ProtoBuf.js 3.7
It has been requested to add oneof support to ProtoBuf.js. This feature has been introducted with Protocol Buffers 2.6.0.
As of version 3.7.0, ProtoBuf.js is capable of using the oneof syntax:
message MyOneOf {
oneof my_oneof {
uint32 id = 1;
string name = 2;
}
}
For such messages, ProtoBuf.js adds a virtual property named like the oneof to message instances (here: MyOneOf#my_oneof
), holding the name of the field that is present, or evaluates to null
if none is set. If MyOneOf#id
is set, MyOneOf#my_oneof
evaluates to "id"
.
Note: When working with oneof enclosed fields, it is highly recommended to always use Message#set(key, value[, noAssert])
when assigning values, as this guarantees that the virtual property is adjusted and a possibly previously assigned value to another enclosed field is unset. It is possible though to assign values directly to multiple oneof enclosed fields, but this will result in all of these fields being present on the wire. The decoding side, however, will most likely discard any values but the latest, which is in the case of ProtoBuf.js the latest declared and present field.
Example:
// Encoding side
var myOneOf = new MyOneOf();
myOneOf.set("id", 123);
// myOneOf.id = 123
// myOneOf.name = null
// myOneOf.my_oneof = "id"
var bb = myOneOf.encode();
// Decoding side
var myOneOf = MyOneOf.decode(bb),
which = myOneOf.my_oneof;
var my_oneof = which !== null ? myOneOf[which] : null;
// my_oneof = 123
Assigning a value to the virtual field has no effect on encoding, it's basically just a volatile marker.