⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tcatest.c

📁 Tokyo Cabinet的Tokyo Cabinet 是一个DBM的实现。这里的数据库由一系列key-value对的记录构成。key和value都可以是任意长度的字节序列,既可以是二进制也可以是字符
💻 C
📖 第 1 页 / 共 3 页
字号:
/************************************************************************************************* * The test cases of the abstract database API *                                                      Copyright (C) 2006-2009 Mikio Hirabayashi * This file is part of Tokyo Cabinet. * Tokyo Cabinet is free software; you can redistribute it and/or modify it under the terms of * the GNU Lesser General Public License as published by the Free Software Foundation; either * version 2.1 of the License or any later version.  Tokyo Cabinet is distributed in the hope * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public * License for more details. * You should have received a copy of the GNU Lesser General Public License along with Tokyo * Cabinet; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, * Boston, MA 02111-1307 USA. *************************************************************************************************/#include <tcutil.h>#include <tcadb.h>#include "myconf.h"#define RECBUFSIZ      48                // buffer for records/* global variables */const char *g_progname;                  // program nameunsigned int g_randseed;                 // random seed/* function prototypes */int main(int argc, char **argv);static void usage(void);static void iprintf(const char *format, ...);static void iputchar(int c);static void eprint(TCADB *adb, const char *func);static void sysprint(void);static int myrand(int range);static void *pdprocfunccmp(const void *vbuf, int vsiz, int *sp, void *op);static bool iterfunc(const void *kbuf, int ksiz, const void *vbuf, int vsiz, void *op);static int runwrite(int argc, char **argv);static int runread(int argc, char **argv);static int runremove(int argc, char **argv);static int runrcat(int argc, char **argv);static int runmisc(int argc, char **argv);static int runwicked(int argc, char **argv);static int runcompare(int argc, char **argv);static int procwrite(const char *name, int rnum);static int procread(const char *name);static int procremove(const char *name);static int procrcat(const char *name, int rnum);static int procmisc(const char *name, int rnum);static int procwicked(const char *name, int rnum);static int proccompare(const char *name, int tnum, int rnum);/* main routine */int main(int argc, char **argv){  g_progname = argv[0];  const char *ebuf = getenv("TCRNDSEED");  g_randseed = ebuf ? tcatoix(ebuf) : tctime() * 1000;  srand(g_randseed);  if(argc < 2) usage();  int rv = 0;  if(!strcmp(argv[1], "write")){    rv = runwrite(argc, argv);  } else if(!strcmp(argv[1], "read")){    rv = runread(argc, argv);  } else if(!strcmp(argv[1], "remove")){    rv = runremove(argc, argv);  } else if(!strcmp(argv[1], "rcat")){    rv = runrcat(argc, argv);  } else if(!strcmp(argv[1], "misc")){    rv = runmisc(argc, argv);  } else if(!strcmp(argv[1], "wicked")){    rv = runwicked(argc, argv);  } else if(!strcmp(argv[1], "compare")){    rv = runcompare(argc, argv);  } else {    usage();  }  return rv;}/* print the usage and exit */static void usage(void){  fprintf(stderr, "%s: test cases of the abstract database API of Tokyo Cabinet\n", g_progname);  fprintf(stderr, "\n");  fprintf(stderr, "usage:\n");  fprintf(stderr, "  %s write name rnum\n", g_progname);  fprintf(stderr, "  %s read name\n", g_progname);  fprintf(stderr, "  %s remove name\n", g_progname);  fprintf(stderr, "  %s rcat name rnum\n", g_progname);  fprintf(stderr, "  %s misc name rnum\n", g_progname);  fprintf(stderr, "  %s wicked name rnum\n", g_progname);  fprintf(stderr, "  %s compare name tnum rnum\n", g_progname);  fprintf(stderr, "\n");  exit(1);}/* print formatted information string and flush the buffer */static void iprintf(const char *format, ...){  va_list ap;  va_start(ap, format);  vprintf(format, ap);  fflush(stdout);  va_end(ap);}/* print a character and flush the buffer */static void iputchar(int c){  putchar(c);  fflush(stdout);}/* print error message of abstract database */static void eprint(TCADB *adb, const char *func){  const char *path = tcadbpath(adb);  fprintf(stderr, "%s: %s: %s: error\n", g_progname, path ? path : "-", func);}/* print system information */static void sysprint(void){  TCMAP *info = tcsysinfo();  if(info){    tcmapiterinit(info);    const char *kbuf;    while((kbuf = tcmapiternext2(info)) != NULL){      iprintf("sys_%s: %s\n", kbuf, tcmapiterval2(kbuf));    }    tcmapdel(info);  }}/* get a random number */static int myrand(int range){  if(range < 2) return 0;  int high = (unsigned int)rand() >> 4;  int low = range * (rand() / (RAND_MAX + 1.0));  low &= (unsigned int)INT_MAX >> 4;  return (high + low) % range;}/* duplication callback function for comparison */static void *pdprocfunccmp(const void *vbuf, int vsiz, int *sp, void *op){  switch(*(int *)op % 4){  case 1: return NULL;  case 2: return (void *)-1;  default: break;  }  *sp = vsiz;  return tcmemdup(vbuf, vsiz);}/* iterator function */static bool iterfunc(const void *kbuf, int ksiz, const void *vbuf, int vsiz, void *op){  unsigned int sum = 0;  while(--ksiz >= 0){    sum += ((char *)kbuf)[ksiz];  }  while(--vsiz >= 0){    sum += ((char *)vbuf)[vsiz];  }  return myrand(100 + (sum & 0xff)) > 0;}/* parse arguments of write command */static int runwrite(int argc, char **argv){  char *name = NULL;  char *rstr = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  int rnum = tcatoix(rstr);  if(rnum < 1) usage();  int rv = procwrite(name, rnum);  return rv;}/* parse arguments of read command */static int runread(int argc, char **argv){  char *name = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else {      usage();    }  }  if(!name) usage();  int rv = procread(name);  return rv;}/* parse arguments of remove command */static int runremove(int argc, char **argv){  char *name = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else {      usage();    }  }  if(!name) usage();  int rv = procremove(name);  return rv;}/* parse arguments of rcat command */static int runrcat(int argc, char **argv){  char *name = NULL;  char *rstr = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  int rnum = tcatoix(rstr);  if(rnum < 1) usage();  int rv = procrcat(name, rnum);  return rv;}/* parse arguments of misc command */static int runmisc(int argc, char **argv){  char *name = NULL;  char *rstr = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  int rnum = tcatoix(rstr);  if(rnum < 1) usage();  int rv = procmisc(name, rnum);  return rv;}/* parse arguments of wicked command */static int runwicked(int argc, char **argv){  char *name = NULL;  char *rstr = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  int rnum = tcatoix(rstr);  if(rnum < 1) usage();  int rv = procwicked(name, rnum);  return rv;}/* parse arguments of compare command */static int runcompare(int argc, char **argv){  char *name = NULL;  char *tstr = NULL;  char *rstr = NULL;  for(int i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!tstr){      tstr = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !tstr || !rstr) usage();  int tnum = tcatoix(tstr);  int rnum = tcatoix(rstr);  if(tnum < 1 || rnum < 1) usage();  int rv = proccompare(name, tnum, rnum);  return rv;}/* perform write command */static int procwrite(const char *name, int rnum){  iprintf("<Writing Test>\n  seed=%u  name=%s  rnum=%d\n\n", g_randseed, name, rnum);  bool err = false;  double stime = tctime();  TCADB *adb = tcadbnew();  if(!tcadbopen(adb, name)){    eprint(adb, "tcadbopen");    err = true;  }  for(int i = 1; i <= rnum; i++){    char buf[RECBUFSIZ];    int len = sprintf(buf, "%08d", i);    if(!tcadbput(adb, buf, len, buf, len)){      eprint(adb, "tcadbput");      err = true;      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb));  iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb));  sysprint();  if(!tcadbclose(adb)){    eprint(adb, "tcadbclose");    err = true;  }  tcadbdel(adb);  iprintf("time: %.3f\n", tctime() - stime);  iprintf("%s\n\n", err ? "error" : "ok");  return err ? 1 : 0;}/* perform read command */static int procread(const char *name){  iprintf("<Reading Test>\n  seed=%u  name=%s\n\n", g_randseed, name);  bool err = false;  double stime = tctime();  TCADB *adb = tcadbnew();  if(!tcadbopen(adb, name)){    eprint(adb, "tcadbopen");    err = true;  }  int rnum = tcadbrnum(adb);  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%08d", i);    int vsiz;    char *vbuf = tcadbget(adb, kbuf, ksiz, &vsiz);    if(!vbuf){      eprint(adb, "tcadbget");      err = true;      break;    }    tcfree(vbuf);    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb));  iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb));  sysprint();  if(!tcadbclose(adb)){    eprint(adb, "tcadbclose");    err = true;  }  tcadbdel(adb);  iprintf("time: %.3f\n", tctime() - stime);  iprintf("%s\n\n", err ? "error" : "ok");  return err ? 1 : 0;}/* perform remove command */static int procremove(const char *name){  iprintf("<Removing Test>\n  seed=%u  name=%s\n\n", g_randseed, name);  bool err = false;  double stime = tctime();  TCADB *adb = tcadbnew();  if(!tcadbopen(adb, name)){    eprint(adb, "tcadbopen");    err = true;  }  int rnum = tcadbrnum(adb);  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%08d", i);    if(!tcadbout(adb, kbuf, ksiz)){      eprint(adb, "tcadbout");      err = true;      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb));  iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb));  sysprint();  if(!tcadbclose(adb)){    eprint(adb, "tcadbclose");    err = true;  }  tcadbdel(adb);  iprintf("time: %.3f\n", tctime() - stime);  iprintf("%s\n\n", err ? "error" : "ok");  return err ? 1 : 0;}/* perform rcat command */static int procrcat(const char *name, int rnum){  iprintf("<Random Concatenating Test>\n  seed=%u  name=%s  rnum=%d\n\n",          g_randseed, name, rnum);  int pnum = rnum / 5 + 1;  bool err = false;  double stime = tctime();  TCADB *adb = tcadbnew();  if(!tcadbopen(adb, name)){    eprint(adb, "tcadbopen");    err = true;  }  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%d", myrand(pnum) + 1);    if(!tcadbputcat(adb, kbuf, ksiz, kbuf, ksiz)){      eprint(adb, "tcadbputcat");      err = true;      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb));  iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb));  sysprint();  if(!tcadbclose(adb)){    eprint(adb, "tcadbclose");    err = true;  }  tcadbdel(adb);  iprintf("time: %.3f\n", tctime() - stime);  iprintf("%s\n\n", err ? "error" : "ok");  return err ? 1 : 0;}/* perform misc command */static int procmisc(const char *name, int rnum){  iprintf("<Miscellaneous Test>\n  seed=%u  name=%s  rnum=%d\n\n", g_randseed, name, rnum);  bool err = false;  double stime = tctime();  TCADB *adb = tcadbnew();  if(!tcadbopen(adb, name)){    eprint(adb, "tcadbopen");    err = true;  }  iprintf("writing:\n");  for(int i = 1; i <= rnum; i++){    char buf[RECBUFSIZ];    int len = sprintf(buf, "%08d", i);    if(!tcadbputkeep(adb, buf, len, buf, len)){      eprint(adb, "tcadbputkeep");      err = true;      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("reading:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%08d", i);    int vsiz;    char *vbuf = tcadbget(adb, kbuf, ksiz, &vsiz);    if(!vbuf){      eprint(adb, "tcadbget");      err = true;      break;    } else if(vsiz != ksiz || memcmp(vbuf, kbuf, vsiz)){      eprint(adb, "(validation)");      err = true;      tcfree(vbuf);      break;    }    tcfree(vbuf);    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  if(tcadbrnum(adb) != rnum){    eprint(adb, "(validation)");    err = true;  }  iprintf("random writing:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%d", myrand(rnum) + 1);    char vbuf[RECBUFSIZ];    int vsiz = myrand(RECBUFSIZ);    memset(vbuf, '*', vsiz);    if(!tcadbput(adb, kbuf, ksiz, vbuf, vsiz)){      eprint(adb, "tcadbput");      err = true;      break;    }    int rsiz;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -