#include #include #include #include #include #include #include #include #include "../negentropy_wrapper.h" #define MAX_FRAME_SIZE 153600 void printHexBuffer(buffer buf){ for (uint64_t i = 0; i < buf.len; ++i) { printf("%0hhx", buf.data[i]); } printf("\n"); } void rec_callback(buffer* have_ids, uint64_t have_ids_len, buffer* need_ids, uint64_t need_ids_len, buffer* output){ printf("needIds count:%llu , haveIds count: %llu \n",need_ids_len, have_ids_len); for (int i=0; i < need_ids_len ; i++) { printf("need ID at %d :", i); printHexBuffer(need_ids[i]); } for (int j=0; j < have_ids_len ; j++) { printf("need ID at %d :", j); printHexBuffer(have_ids[j]); } } int main(){ void* st1 = storage_new("",""); if(st1 == NULL){ perror("failed to create storage"); } void* st2 = storage_new("",""); if(st2 == NULL){ perror("failed to create storage"); } unsigned char m1[] = {0x6a, 0xdf, 0xaa, 0xe0, 0x31, 0xeb, 0x61, 0xa8, \ 0x3c, 0xff, 0x9c, 0xfd, 0xd2, 0xae, 0xf6, 0xed, \ 0x63, 0xda, 0xcf, 0xaa, 0x96, 0xd0, 0x51, 0x26, \ 0x7e, 0xf1, 0x0c, 0x8b, 0x61, 0xae, 0x35, 0xe9};//"61dfaae031eb61a83cff9cfdd2aef6ed63dacfaa96d051267ef10c8b61ae35e9"; buffer b1 ; b1.len = 32; b1.data = m1; unsigned char m2[] = {0x28 ,0x79 ,0x8d ,0x29 ,0x5c ,0x30 ,0xc7 ,0xe6 \ ,0xd9 ,0xa4 ,0xa9 ,0x6c ,0xdd ,0xa7 ,0xe0 ,0x20 \ ,0xf7 ,0xaa ,0x71 ,0x68 ,0xcc ,0xe0 ,0x63 ,0x30 \ ,0x2e ,0xd1 ,0x9b ,0x85 ,0x63 ,0x32 ,0x95 ,0x9e}; //28798d295c30c7e6d9a4a96cdda7e020f7aa7168cce063302ed19b856332959e buffer b2 ; b2.len = 32; b2.data = m2; bool ret = storage_insert(st1,time(NULL),&b1); if (ret){ printf("inserted hash successfully in st1\n"); } ret = storage_insert(st2,time(NULL),&b2); if (ret){ printf("inserted hash successfully in st2\n"); } ret = storage_insert(st2,time(NULL),&b1); if (ret){ printf("inserted hash successfully in st2\n"); } buffer b4 ; b4.len = 0; b4.data = (unsigned char*)malloc(37*sizeof(unsigned char)); printf("storage size of st2 is %d \n",storage_size(st2)); void* subrange = subrange_new(st2, 0 , UINT64_MAX); if (subrange == NULL){ perror("failed to init subrange"); return -1; } printf("subrange init successful with size %d \n ", subrange_size(subrange) ); void* subrange1 = subrange_new(st1, 0 , UINT64_MAX); if (subrange == NULL){ perror("failed to init subrange"); return -1; } printf("subrange init successful with size %d \n ", subrange_size(subrange1) ); void* ngn_inst1 = negentropy_new(subrange1, MAX_FRAME_SIZE); if(ngn_inst1 == NULL){ perror("failed to create negentropy instance"); return -1; } void* ngn_inst2 = negentropy_new(subrange, MAX_FRAME_SIZE); if(ngn_inst2 == NULL){ perror("failed to create negentropy instance"); return -1; } result res; int ret1 = negentropy_subrange_initiate(ngn_inst1, &res); if(ret1 < 0){ perror("failed to initiate negentropy instance"); return -1; } printf("initiated negentropy successfully with output of len %llu \n", res.output.len); b4.len = res.output.len; memcpy(b4.data, res.output.data, res.output.len); free_result(&res); buffer b3 ; b3.len = 0; b3.data = (unsigned char*)malloc(69*sizeof(unsigned char)); ret1 = reconcile_subrange(ngn_inst2, &b4, &res); if(ret1 < 0){ perror("error from reconcile"); } if (res.output.len == 0){ perror("nothing to reconcile"); } printf("reconcile returned with output of len %llu \n", res.output.len); b3.len = res.output.len; memcpy(b3.data, res.output.data, res.output.len); free_result(&res); //outSize = reconcile_with_ids(ngn_inst1, &b3, &rec_callback); result res1; reconcile_with_ids_subrange_no_cbk(ngn_inst1, &b3, &res1); printf("needIds count:%llu , haveIds count: %llu \n",res1.need_ids_len, res1.have_ids_len); for (int i=0; i < res1.need_ids_len ; i++) { printf("need ID at %d :", i); printHexBuffer(res1.need_ids[i]); } for (int j=0; j < res1.have_ids_len ; j++) { printf("need ID at %d :", j); printHexBuffer(res1.have_ids[j]); } free(b3.data); free(b4.data); free_result(&res1); ret = storage_insert(st1, time(NULL), &b2); if (ret){ printf("inserted hash successfully in st1\n"); } printf("\n storage size after adding 1 more elem is %d, subrange size is %d \n", storage_size(st1), subrange_size(subrange1)); subrange_delete(subrange); subrange_delete(subrange1); printf("storage after subrange deletion, st1 size: %d, st2 size: %d.", storage_size(st1), storage_size(st2)); }