summaryrefslogtreecommitdiffstats
path: root/generator
diff options
context:
space:
mode:
authorBenjamin Kamath <ben.kamath@synapse.com>2015-11-04 16:42:25 -0800
committerBenjamin Kamath <ben.kamath@synapse.com>2015-11-10 22:35:46 -0800
commit9a8cc59703b227ff418cc55b4dc24f63eda64b62 (patch)
tree46fc92a7ef1021610386802a2616d05caad84e91 /generator
parent6c136580a091a30e94aaebd66dd978117d999ad0 (diff)
Add option to allow for anonymous unions
Diffstat (limited to 'generator')
-rwxr-xr-xgenerator/nanopb_generator.py19
-rw-r--r--generator/proto/nanopb.proto3
2 files changed, 19 insertions, 3 deletions
diff --git a/generator/nanopb_generator.py b/generator/nanopb_generator.py
index 2dad4ec1..a21257b5 100755
--- a/generator/nanopb_generator.py
+++ b/generator/nanopb_generator.py
@@ -463,7 +463,10 @@ class Field:
'''
if self.rules == 'ONEOF':
- result = ' PB_ONEOF_FIELD(%s, ' % self.union_name
+ if self.anonymous:
+ result = ' PB_ANONYMOUS_ONEOF_FIELD(%s, ' % self.union_name
+ else:
+ result = ' PB_ONEOF_FIELD(%s, ' % self.union_name
else:
result = ' PB_FIELD('
@@ -497,7 +500,10 @@ class Field:
if self.rules == 'REPEATED' and self.allocation == 'STATIC':
check.append('pb_membersize(%s, %s[0])' % (self.struct_name, self.name))
elif self.rules == 'ONEOF':
- check.append('pb_membersize(%s, %s.%s)' % (self.struct_name, self.union_name, self.name))
+ if self.anonymous:
+ check.append('pb_membersize(%s, %s)' % (self.struct_name, self.name))
+ else:
+ check.append('pb_membersize(%s, %s.%s)' % (self.struct_name, self.union_name, self.name))
else:
check.append('pb_membersize(%s, %s)' % (self.struct_name, self.name))
@@ -653,6 +659,7 @@ class OneOf(Field):
self.allocation = 'ONEOF'
self.default = None
self.rules = 'ONEOF'
+ self.anonymous = False
def add_field(self, field):
if field.allocation == 'CALLBACK':
@@ -661,6 +668,7 @@ class OneOf(Field):
field.union_name = self.name
field.rules = 'ONEOF'
+ field.anonymous = self.anonymous
self.fields.append(field)
self.fields.sort(key = lambda f: f.tag)
@@ -674,7 +682,10 @@ class OneOf(Field):
result += ' union {\n'
for f in self.fields:
result += ' ' + str(f).replace('\n', '\n ') + '\n'
- result += ' } ' + self.name + ';'
+ if self.anonymous:
+ result += ' };'
+ else:
+ result += ' } ' + self.name + ';'
return result
def types(self):
@@ -742,6 +753,8 @@ class Message:
pass # No union and skip fields also
else:
oneof = OneOf(self.name, f)
+ if oneof_options.anonymous_oneof:
+ oneof.anonymous = True
self.oneofs[i] = oneof
self.fields.append(oneof)
diff --git a/generator/proto/nanopb.proto b/generator/proto/nanopb.proto
index b8671bbd..9b2f0fbc 100644
--- a/generator/proto/nanopb.proto
+++ b/generator/proto/nanopb.proto
@@ -62,6 +62,9 @@ message NanoPBOptions {
// integer type tag for a message
optional uint32 msgid = 9;
+
+ // decode oneof as anonymous union
+ optional bool anonymous_oneof = 11 [default = false];
}
// Extensions to protoc 'Descriptor' type in order to define options