diff options
author | Joshua Haberman <joshua@reverberate.org> | 2009-12-05 10:32:53 -0800 |
---|---|---|
committer | Joshua Haberman <joshua@reverberate.org> | 2009-12-05 10:32:53 -0800 |
commit | 18291eedc3cb6bf4386698620ad9d02ad367126a (patch) | |
tree | 4096201b5a9e8c57605f145be8927e757cb23385 /benchmarks/parsetostruct.upb_table.c | |
parent | a95ab58e79c50b0927eae2b834d3de20a8effc36 (diff) |
Make defs refcounted, rename upb_context->upbsymtab.
There is currently a memory leak when type definitions
form cycles. This will need to be dealt with.
Diffstat (limited to 'benchmarks/parsetostruct.upb_table.c')
-rw-r--r-- | benchmarks/parsetostruct.upb_table.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/benchmarks/parsetostruct.upb_table.c b/benchmarks/parsetostruct.upb_table.c index 0a170de..045aedb 100644 --- a/benchmarks/parsetostruct.upb_table.c +++ b/benchmarks/parsetostruct.upb_table.c @@ -1,11 +1,11 @@ #include "main.c" -#include "upb_context.h" -#include "upb_msg.h" +#include "upb_def.h" #include "upb_mm.h" +#include "upb_msg.h" -static struct upb_context *c; +static struct upb_symtab *s; static struct upb_string *str; static struct upb_msgdef *def; static struct upb_msg *msgs[NUM_MESSAGES]; @@ -15,14 +15,14 @@ static bool initialize() { // Initialize upb state, parse descriptor. struct upb_status status = UPB_STATUS_INIT; - c = upb_context_new(); + s = upb_symtab_new(); struct upb_string *fds = upb_strreadfile(MESSAGE_DESCRIPTOR_FILE); if(!fds) { fprintf(stderr, "Couldn't read " MESSAGE_DESCRIPTOR_FILE ": %s.\n", status.msg); return false; } - upb_context_parsefds(c, fds, &status); + upb_symtab_add_desc(s, fds, &status); if(!upb_ok(&status)) { fprintf(stderr, "Error importing " MESSAGE_DESCRIPTOR_FILE ": %s.\n", status.msg); @@ -31,7 +31,7 @@ static bool initialize() upb_string_unref(fds); struct upb_string *proto_name = upb_strdupc(MESSAGE_NAME); - def = upb_downcast_msgdef(upb_context_lookup(c, proto_name)); + def = upb_downcast_msgdef(upb_symtab_lookup(s, proto_name)); if(!def) { fprintf(stderr, "Error finding symbol '" UPB_STRFMT "'.\n", UPB_STRARG(proto_name)); @@ -57,7 +57,7 @@ static void cleanup() for(int i = 0; i < NUM_MESSAGES; i++) upb_msg_unref(msgs[i]); upb_string_unref(str); - upb_context_unref(c); + upb_symtab_unref(s); upb_msgparser_free(mp); } |