summaryrefslogtreecommitdiff
path: root/upb_enum.h
diff options
context:
space:
mode:
Diffstat (limited to 'upb_enum.h')
-rw-r--r--upb_enum.h25
1 files changed, 3 insertions, 22 deletions
diff --git a/upb_enum.h b/upb_enum.h
index 2c4010b..9fea3a4 100644
--- a/upb_enum.h
+++ b/upb_enum.h
@@ -34,27 +34,8 @@ struct upb_enum_iton_entry {
/* Initializes and frees an enum, respectively. Caller retains ownership of
* ed, but it must outlive e. */
-INLINE void upb_enum_init(struct upb_enum *e,
- struct google_protobuf_EnumDescriptorProto *ed) {
- int num_values = ed->set_flags.has.value ? ed->value->len : 0;
- e->descriptor = ed;
- upb_strtable_init(&e->nametoint, num_values, sizeof(struct upb_enum_ntoi_entry));
- upb_inttable_init(&e->inttoname, num_values, sizeof(struct upb_enum_iton_entry));
-
- for(int i = 0; i < num_values; i++) {
- google_protobuf_EnumValueDescriptorProto *value = ed->value->elements[i];
- struct upb_enum_ntoi_entry ntoi_entry = {.e = {.key = *value->name},
- .value = value->number};
- struct upb_enum_iton_entry iton_entry = {.e = {.key = value->number},
- .string = value->name};
- upb_strtable_insert(&e->nametoint, &ntoi_entry.e);
- upb_inttable_insert(&e->inttoname, &iton_entry.e);
- }
-}
-
-INLINE void upb_enum_free(struct upb_enum *e) {
- upb_strtable_free(&e->nametoint);
- upb_inttable_free(&e->inttoname);
-}
+void upb_enum_init(struct upb_enum *e,
+ struct google_protobuf_EnumDescriptorProto *ed);
+void upb_enum_free(struct upb_enum *e);
#endif /* UPB_ENUM_H_ */
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback