#include #include "google_messages.pb.h" #include "test_util.h" #include "upb_context.h" #include "upb_msg.h" int main () { struct upb_context c; upb_context_init(&c); struct upb_string fds; if(!upb_strreadfile("benchmark/google_messages.proto.pb", &fds)) { fprintf(stderr, "Couldn't read google_speed.proto.bin.\n"); return 1; } if(!upb_context_parsefds(&c, &fds)) { fprintf(stderr, "Error parsing or resolving proto.\n"); return 1; } upb_strfree(fds); char class_name[] = "benchmarks.SpeedMessage2"; struct upb_string proto_name; proto_name.ptr = class_name; proto_name.byte_len = sizeof(class_name)-1; struct upb_symtab_entry *e = upb_context_lookup(&c, &proto_name); if(!e || e->type != UPB_SYM_MESSAGE) { fprintf(stderr, "Error finding symbol '" UPB_STRFMT "'.\n", UPB_STRARG(proto_name)); return 1; } struct upb_msg *m = e->ref.msg; struct upb_msg_parse_state s; void *data = upb_msgdata_new(m); upb_msg_parse_init(&s, data, m, false, true); size_t read; struct upb_string str; if(!upb_strreadfile("benchmark/google_message2.dat", &str)) { fprintf(stderr, "Error reading google_message2.dat\n"); return 1; } size_t total = 0; clock_t before = clock(); for(int i = 0; i < 2000; i++) { upb_msg_parse_reset(&s, data, m, false, false); upb_status_t status = upb_msg_parse(&s, str.ptr, str.byte_len, &read); if(status != UPB_STATUS_OK && read != str.byte_len) { fprintf(stderr, "Error. :( error=%d, read=%lu\n", status, read); return 1; } total += str.byte_len; } double elapsed = ((double)clock() - before) / CLOCKS_PER_SEC; fprintf(stderr, "upb parsed %sB, ", eng(total, 3, false)); fprintf(stderr, "%sB/s\n", eng(total/elapsed, 3, false)); total = 0; before = clock(); for(int i = 0; i < 2000; i++) { upb_msg_parse_reset(&s, data, m, false, true); upb_status_t status = upb_msg_parse(&s, str.ptr, str.byte_len, &read); if(status != UPB_STATUS_OK && read != str.byte_len) { fprintf(stderr, "Error. :( error=%d, read=%lu\n", status, read); return 1; } total += str.byte_len; } elapsed = ((double)clock() - before) / CLOCKS_PER_SEC; fprintf(stderr, "upb(byref) parsed %sB, ", eng(total, 3, false)); fprintf(stderr, "%sB/s\n", eng(total/elapsed, 3, false)); upb_msg_parse_free(&s); upb_msgdata_free(data, m, true); upb_context_free(&c); benchmarks::SpeedMessage2 msg; std::string stlstr(str.ptr, str.byte_len); upb_strfree(str); total = 0; before = clock(); for(int i = 0; i < 2000; i++) { if(!msg.ParseFromString(stlstr)) { fprintf(stderr, "Error parsing with proto2.\n"); return 1; } total += str.byte_len; } elapsed = ((double)clock() - before) / CLOCKS_PER_SEC; fprintf(stderr, "proto2 parsed %sB, ", eng(total, 3, false)); fprintf(stderr, "%sB/s\n", eng(total/elapsed, 3, false)); }