X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;ds=sidebyside;f=lib%2Fdb-test.c;h=9a6f3bb6264e19620970226474d15ab85d7bb083;hb=dc63fe59d2bb4c3eb8be67790a55069c8c0a46a9;hp=4ba3afd5cc2ab2dd0134fc121604788367781620;hpb=abe1abe4f943ae9157588556d486a6863262226a;p=libucw.git diff --git a/lib/db-test.c b/lib/db-test.c index 4ba3afd5..9a6f3bb6 100644 --- a/lib/db-test.c +++ b/lib/db-test.c @@ -1,18 +1,21 @@ /* - * Sherlock Library -- Database Manager -- Tests and Benchmarks + * UCW Library -- Database Manager -- Tests and Benchmarks * - * (c) 1999 Martin Mares + * (c) 1999 Martin Mares + * + * This software may be freely distributed and used according to the terms + * of the GNU Lesser General Public License. */ #if 1 -#include "db.c" +#include "lib/db.c" #define NAME "SDBM" #else -#include "db-emul.c" +#include "lib/db-emul.c" #define NAME "GDBM" #endif -#include +#include #include #include #include @@ -45,6 +48,7 @@ Options:\n\ -kU Use keys with URL distribution\n\ -n Number of distinct keys\n\ -d[-] Use specified value size (see -k-)\n\ +-t Perform the tests on an existing database file\n\ -v Be verbose\n\ -s Turn on synchronous mode\n\ -S Turn on supersynchronous mode\n\ @@ -257,11 +261,13 @@ int main(int argc, char **argv) byte kb[2048], vb[2048], vb2[2048]; uns ks, vs, vs2, perc, cnt; char *ch; + int dont_delete = 0; + timestamp_t timer; - initlog("dbtest"); + log_init("dbtest"); setvbuf(stdout, NULL, _IONBF, 0); setvbuf(stderr, NULL, _IONBF, 0); - while ((c = getopt(argc, argv, "c:p:k:n:d:vsSF")) >= 0) + while ((c = getopt(argc, argv, "c:p:k:n:d:vsStF")) >= 0) switch (c) { case 'c': @@ -294,6 +300,9 @@ int main(int argc, char **argv) case 'F': opts.flags |= SDBM_FAST; break; + case 't': + dont_delete = 1; + break; default: help(); } @@ -316,7 +325,8 @@ int main(int argc, char **argv) verb("OPEN(%s, key=%d, val=%d, cache=%d, pgorder=%d)\n", opts.name, opts.key_size, opts.val_size, opts.cache_size, opts.page_order); - unlink(opts.name); + if (!dont_delete) + unlink(opts.name); d = sdbm_open(&opts); if (!d) die("open failed: %m"); @@ -324,7 +334,7 @@ int main(int argc, char **argv) while (optind < argc) { char *o = argv[optind++]; - init_timer(); + init_timer(&timer); switch (*o) { case 'c': @@ -360,7 +370,7 @@ int main(int argc, char **argv) ch = o; perc = 100; } - cnt = atol(o); + cnt = atol(ch); if (!cnt) { cnt = num_keys; @@ -450,7 +460,7 @@ int main(int argc, char **argv) help(); } sdbm_sync(d); - printf("%d ms\n", get_timer()); + printf("%d ms\n", get_timer(&timer)); } verb("CLOSE\n");