summaryrefslogtreecommitdiff
path: root/benchmarks/parsestream.upb_table.c
diff options
context:
space:
mode:
authorJoshua Haberman <jhaberman@gmail.com>2011-08-17 08:15:57 -0700
committerJoshua Haberman <jhaberman@gmail.com>2011-08-17 08:15:57 -0700
commitfa82e4fbf065bb474b0f87023f66edffb8a5b850 (patch)
treee515ba7d9a431a05b08468619b8289d7bc9b1527 /benchmarks/parsestream.upb_table.c
parent51d4e295a4d8e55facf0e95502cde75d488fd511 (diff)
Benchmark JIT vs no JIT without forcing a whole-project recompile.
Diffstat (limited to 'benchmarks/parsestream.upb_table.c')
-rw-r--r--benchmarks/parsestream.upb_table.c86
1 files changed, 0 insertions, 86 deletions
diff --git a/benchmarks/parsestream.upb_table.c b/benchmarks/parsestream.upb_table.c
deleted file mode 100644
index a4022b1..0000000
--- a/benchmarks/parsestream.upb_table.c
+++ /dev/null
@@ -1,86 +0,0 @@
-
-#include "main.c"
-
-#include <stdlib.h>
-#include "upb/bytestream.h"
-#include "upb/def.h"
-#include "upb/pb/decoder.h"
-#include "upb/pb/glue.h"
-
-static char *input_str;
-static size_t input_len;
-static upb_msgdef *def;
-static upb_decoder decoder;
-static upb_stringsrc stringsrc;
-
-static upb_sflow_t startsubmsg(void *_m, upb_value fval) {
- (void)_m;
- (void)fval;
- return UPB_CONTINUE_WITH(NULL);
-}
-
-static upb_flow_t value(void *closure, upb_value fval, upb_value val) {
- (void)closure;
- (void)fval;
- (void)val;
- return UPB_CONTINUE;
-}
-
-static bool initialize()
-{
- // Initialize upb state, decode descriptor.
- upb_status status = UPB_STATUS_INIT;
- upb_symtab *s = upb_symtab_new();
- upb_read_descriptorfile(s, MESSAGE_DESCRIPTOR_FILE, &status);
- if(!upb_ok(&status)) {
- upb_status_print(&status, stderr);
- return false;
- }
-
- def = upb_dyncast_msgdef(upb_symtab_lookup(s, MESSAGE_NAME));
- if(!def) {
- fprintf(stderr, "Error finding symbol '%s'.\n", MESSAGE_NAME);
- return false;
- }
- upb_symtab_unref(s);
-
- // Read the message data itself.
- input_str = upb_readfile(MESSAGE_FILE, &input_len);
- if(input_str == NULL) {
- fprintf(stderr, "Error reading " MESSAGE_FILE "\n");
- return false;
- }
-
- upb_handlers *handlers = upb_handlers_new();
- // Cause all messages to be read, but do nothing when they are.
- upb_handlerset hset = {NULL, NULL, value, startsubmsg, NULL, NULL, NULL};
- upb_handlers_reghandlerset(handlers, def, &hset);
- upb_decoder_initforhandlers(&decoder, handlers);
- upb_handlers_unref(handlers);
- upb_stringsrc_init(&stringsrc);
- return true;
-}
-
-static void cleanup()
-{
- free(input_str);
- upb_def_unref(UPB_UPCAST(def));
- upb_decoder_uninit(&decoder);
- upb_stringsrc_uninit(&stringsrc);
-}
-
-static size_t run(int i)
-{
- (void)i;
- upb_status status = UPB_STATUS_INIT;
- upb_stringsrc_reset(&stringsrc, input_str, input_len);
- upb_decoder_reset(&decoder, upb_stringsrc_bytesrc(&stringsrc), 0, UINT64_MAX, NULL);
- upb_decoder_decode(&decoder, &status);
- if(!upb_ok(&status)) goto err;
- return input_len;
-
-err:
- fprintf(stderr, "Decode error: ");
- upb_status_print(&status, stderr);
- return 0;
-}
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback