summaryrefslogtreecommitdiff
path: root/upb/encode.c
diff options
context:
space:
mode:
authorJoshua Haberman <jhaberman@gmail.com>2018-09-06 12:57:16 -0700
committerJoshua Haberman <jhaberman@gmail.com>2018-09-06 12:57:16 -0700
commitf7713ebc391d247617b0dff788a76e5c3383ae94 (patch)
tree3542a54abd18ed5d1eef586ac331b1d66f7c612e /upb/encode.c
parent694d51f4d6cb8adf4a2f7975e5bb899327875de7 (diff)
Changed C API to use inline functions and computed offsets.
Diffstat (limited to 'upb/encode.c')
-rw-r--r--upb/encode.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/upb/encode.c b/upb/encode.c
index d38676d..034a90d 100644
--- a/upb/encode.c
+++ b/upb/encode.c
@@ -340,6 +340,15 @@ bool upb_encode_hasscalarfield(const char *msg, const upb_msglayout *m,
}
}
+static size_t get_field_offset2(const upb_msglayout *m,
+ const upb_msglayout_field *field) {
+ if (field->oneof_index == UPB_NOT_IN_ONEOF) {
+ return field->offset;
+ } else {
+ return m->oneofs[field->oneof_index].data_offset;
+ }
+}
+
bool upb_encode_message(upb_encstate *e, const char *msg,
const upb_msglayout *m, size_t *size) {
int i;
@@ -351,13 +360,14 @@ bool upb_encode_message(upb_encstate *e, const char *msg,
for (i = m->field_count - 1; i >= 0; i--) {
const upb_msglayout_field *f = &m->fields[i];
+ size_t offset = get_field_offset2(m, f);
if (f->label == UPB_LABEL_REPEATED) {
- CHK(upb_encode_array(e, msg + f->offset, m, f));
+ CHK(upb_encode_array(e, msg + offset, m, f));
} else {
if (upb_encode_hasscalarfield(msg, m, f)) {
if (f->oneof_index == UPB_NOT_IN_ONEOF) {
- CHK(upb_encode_scalarfield(e, msg + f->offset, m, f, !m->is_proto2));
+ CHK(upb_encode_scalarfield(e, msg + offset, m, f, !m->is_proto2));
} else {
const upb_msglayout_oneof *o = &m->oneofs[f->oneof_index];
CHK(upb_encode_scalarfield(e, msg + o->data_offset,
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback