main(int argc,char **argv) { read_argv_1(argc,argv); pack_init(); DTBOneTable_FST(); }
static void test_pack_std(void **state) { int ret = 0; pack_t pack; pack_init(pack); assert_int_equal(pack.len, 0); /* Push/delete without reservation. */ assert_int_not_equal(pack_obj_push(&pack, U8(""), 1), 0); assert_int_not_equal(pack_obj_del(&pack, U8(""), 1), 0); /* Reserve capacity and fill. */ assert_true(pack_reserve(pack, 10, 10 * 2) >= 0); for (unsigned i = 0; i < 10; ++i) { ret = pack_obj_push(&pack, U8("de"), 2); assert_true(ret >= 0); } /* Iterate */ uint8_t *it = pack_head(pack); assert_non_null(it); unsigned count = 0; while (it != pack_tail(pack)) { assert_int_equal(pack_obj_len(it), 2); assert_true(memcmp(pack_obj_val(it), "de", 2) == 0); it = pack_obj_next(it); count += 1; } /* Find */ it = pack_obj_find(&pack, U8("de"), 2); assert_non_null(it); it = pack_obj_find(&pack, U8("ed"), 2); assert_null(it); /* Delete */ assert_int_not_equal(pack_obj_del(&pack, U8("be"), 2), 0); assert_int_equal(pack_obj_del(&pack, U8("de"), 2), 0); assert_int_equal(pack.len, 9*(2+2)); /* 9 objects, length=2 */ pack_clear(pack); }
int main(int argc, char **argv) { char *fn; FILE *f; packer_t pk; uint64_t x; size_t string_length; uint8_t *string; fn = argv[1]; f = fopen(fn, "rb"); if(!f) abort(); if(!pack_init(&pk, 1024, f, file_resplenish, malloc, free)) abort(); while(pack_read_uint64(&pk, &x)) { if(!pack_read_string(&pk, &string, &string_length)) { break; } else { printf("0x%08lx : %s\n", x, string); free(string); } } return 0; }