summaryrefslogtreecommitdiff
path: root/upb/encode.c
diff options
context:
space:
mode:
authorBo Yang <teboring@google.com>2018-03-07 21:07:14 +0000
committerBo Yang <teboring@google.com>2018-03-07 21:07:14 +0000
commitba93474aa223bdaf7cb524c002824096a4837146 (patch)
tree007b2b9fcff24359f6db9f3983baaeca214c5bbf /upb/encode.c
parent6edcf6a82a1d49d784302c152735e4bdba6d643e (diff)
Fix oneof encoding/decoding
Diffstat (limited to 'upb/encode.c')
-rw-r--r--upb/encode.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/upb/encode.c b/upb/encode.c
index f01ad0c..67678fe 100644
--- a/upb/encode.c
+++ b/upb/encode.c
@@ -360,7 +360,13 @@ bool upb_encode_message(upb_encstate* e, const char *msg,
CHK(upb_encode_array(e, msg + f->offset, m, f));
} else {
if (upb_encode_hasscalarfield(msg, m, f)) {
- CHK(upb_encode_scalarfield(e, msg + f->offset, m, f, !m->is_proto2));
+ if (f->oneof_index != UPB_NOT_IN_ONEOF) {
+ const upb_msglayout_oneofinit_v1 *o = &m->oneofs[f->oneof_index];
+ CHK(upb_encode_scalarfield(e, msg + o->data_offset,
+ m, f, !m->is_proto2));
+ } else {
+ CHK(upb_encode_scalarfield(e, msg + f->offset, m, f, !m->is_proto2));
+ }
}
}
}
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback