summaryrefslogtreecommitdiff
path: root/benchmarks
diff options
context:
space:
mode:
authorJoshua Haberman <joshua@reverberate.org>2010-07-24 18:18:09 -0700
committerJoshua Haberman <joshua@reverberate.org>2010-07-24 18:18:09 -0700
commit2a617bf12c8e1f7f689e3767bf7e4582d76c4f39 (patch)
tree2b4a9af39d25cc7aabf755c2527560d2c675d1d7 /benchmarks
parent372c8f0487a666c3fb36edc18accba0fba9a2680 (diff)
Optimizations and bugfix to benchmark.
Diffstat (limited to 'benchmarks')
-rw-r--r--benchmarks/parsestream.upb_table.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/benchmarks/parsestream.upb_table.c b/benchmarks/parsestream.upb_table.c
index 1e18119..16979b0 100644
--- a/benchmarks/parsestream.upb_table.c
+++ b/benchmarks/parsestream.upb_table.c
@@ -85,15 +85,14 @@ static size_t run(int i)
upb_decoder_reset(decoder, upb_stringsrc_bytesrc(stringsrc));
upb_src *src = upb_decoder_src(decoder);
upb_fielddef *f;
- upb_string *str = NULL;
int depth = 0;
while(1) {
- while((f = upb_src_getdef(src)) != NULL) {
+ while(!upb_src_eof(src) && (f = upb_src_getdef(src)) != NULL) {
if(upb_issubmsg(f)) {
upb_src_startmsg(src);
++depth;
} else if(upb_isstring(f)) {
- tmp_str = upb_string_tryrecycle(str);
+ tmp_str = upb_string_tryrecycle(tmp_str);
upb_src_getstr(src, tmp_str);
} else {
// Primitive type.
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback