summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Yang <TeBoring@users.noreply.github.com>2018-03-07 14:31:25 -0800
committerGitHub <noreply@github.com>2018-03-07 14:31:25 -0800
commit681cf4279c152e60e67989b83134018c7058f874 (patch)
tree1c5176ef5236b74a099ee60b3a9dc40ef982533a
parent6edcf6a82a1d49d784302c152735e4bdba6d643e (diff)
parentdfe7d3a3749ff1cdb55d839e3dbfda46b8b2ee72 (diff)
Merge pull request #100 from TeBoring/php-change
Fix oneof encoding/decoding
-rw-r--r--upb/decode.c5
-rw-r--r--upb/encode.c8
2 files changed, 10 insertions, 3 deletions
diff --git a/upb/decode.c b/upb/decode.c
index a4da9a9..4340a90 100644
--- a/upb/decode.c
+++ b/upb/decode.c
@@ -269,7 +269,8 @@ static bool upb_decode_submsg(upb_decstate *d,
const char *limit,
const upb_msglayout_fieldinit_v1 *field,
int group_number) {
- char *submsg = *(void**)&frame->msg[field->offset];
+ char *submsg_slot = upb_decode_prepareslot(d, frame, field);
+ char *submsg = *(void**)submsg_slot;
const upb_msglayout_msginit_v1 *subm;
UPB_ASSERT(field->submsg_index != UPB_NO_SUBMSG);
@@ -281,7 +282,7 @@ static bool upb_decode_submsg(upb_decstate *d,
CHK(submsg);
submsg = upb_msg_init(
submsg, (upb_msglayout*)subm, upb_arena_alloc(upb_env_arena(d->env)));
- *(void**)&frame->msg[field->offset] = submsg;
+ *(void**)submsg_slot = submsg;
}
upb_decode_message(d, limit, group_number, submsg, subm);
diff --git a/upb/encode.c b/upb/encode.c
index f01ad0c..abcf17c 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) {
+ CHK(upb_encode_scalarfield(e, msg + f->offset, m, f, !m->is_proto2));
+ } else {
+ 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));
+ }
}
}
}
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback