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

📄 rltest.c

📁 harvest是一个下载html网页得机器人
💻 C
字号:
/************************************************************************************************* * Test cases of Relic *                                                      Copyright (C) 2000-2003 Mikio Hirabayashi * This file is part of QDBM, Quick Database Manager. * QDBM 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.  QDBM 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 QDBM; if * not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA * 02111-1307 USA. *************************************************************************************************/#include <relic.h>#include <stdlib.h>#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <stdio.h>#include <string.h>#include <stdarg.h>#undef TRUE#define TRUE           1                 /* boolean true */#undef FALSE#define FALSE          0                 /* boolean false */#define RECBUFSIZ      32                /* buffer for records *//* for RISC OS */#if defined(__riscos__) || defined(__riscos)#include <unixlib/local.h>int __riscosify_control = __RISCOSIFY_NO_PROCESS;#endif/* global variables */const char *progname;                    /* program name *//* function prototypes */int main(int argc, char **argv);void usage(void);int runwrite(int argc, char **argv);int runread(int argc, char **argv);int printfflush(const char *format, ...);void pmyerror(const char *name, const char *msg);int dowrite(char *name, int rnum);int doread(char *name, int rnum);/* main routine */int main(int argc, char **argv){  int rv;  progname = argv[0];  if(argc < 2) usage();  rv = 0;  if(!strcmp(argv[1], "write")){    rv = runwrite(argc, argv);  } else if(!strcmp(argv[1], "read")){    rv = runread(argc, argv);  } else {    usage();  }  return rv;}/* print the usage and exit */void usage(void){  fprintf(stderr, "%s: test cases for Relic\n", progname);  fprintf(stderr, "\n");  fprintf(stderr, "usage:\n");  fprintf(stderr, "  %s write name rnum\n", progname);  fprintf(stderr, "  %s read name rnum\n", progname);  exit(1);}/* parse arguments of write command */int runwrite(int argc, char **argv){  char *name, *rstr;  int i, rnum, rv;  name = NULL;  rstr = NULL;  rnum = 0;  for(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();  rnum = atoi(rstr);  if(rnum < 1) usage();  rv = dowrite(name, rnum);  return rv;}/* parse arguments of read command */int runread(int argc, char **argv){  char *name, *rstr;  int i, rnum, rv;  name = NULL;  rstr = NULL;  rnum = 0;  for(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();  rnum = atoi(rstr);  if(rnum < 1) usage();  rv = doread(name, rnum);  return rv;}/* print formatted string and flush the buffer */int printfflush(const char *format, ...){  va_list ap;  int rv;  va_start(ap, format);  rv = vprintf(format, ap);  if(fflush(stdout) == EOF) rv = -1;  va_end(ap);  return rv;}/* print an error message */void pmyerror(const char *name, const char *msg){  fprintf(stderr, "%s: %s: %s\n", progname, name, msg);}/* perform write command */int dowrite(char *name, int rnum){  DBM *db;  datum key, content;  int i, err, len;  char buf[RECBUFSIZ];  printfflush("<Writing Test>\n  name=%s  rnum=%d\n\n", name, rnum);  /* open a database */  if(!(db = dbm_open(name, O_RDWR | O_CREAT | O_TRUNC, 00644))){    pmyerror(name, "dbm_open failed");    return 1;  }  err = FALSE;  /* loop for each record */  for(i = 1; i <= rnum; i++){    len = sprintf(buf, "%08d", i);    key.dptr = buf;    key.dsize = len;    content.dptr = buf;    content.dsize = len;    /* store a record */    if(dbm_store(db, key, content, DBM_REPLACE) < 0){      pmyerror(name, "dbm_store failed");      err = TRUE;      break;    }    /* print progression */    if(rnum > 250 && i % (rnum / 250) == 0){      putchar('.');      fflush(stdout);      if(i == rnum || i % (rnum / 10) == 0){        printfflush(" (%08d)\n", i);      }    }  }  /* close the database */  dbm_close(db);  if(!err) printfflush("ok\n\n");  return err ? 1 : 0;}/* perform read command */int doread(char *name, int rnum){  DBM *db;  datum key, content;  int i, err, len;  char buf[RECBUFSIZ];  printfflush("<Reading Test>\n  name=%s  rnum=%d\n\n", name, rnum);  /* open a database */  if(!(db = dbm_open(name, O_RDONLY, 00644))){    pmyerror(name, "dbm_open failed");    return 1;  }  err = FALSE;  /* loop for each record */  for(i = 1; i <= rnum; i++){    /* retrieve a record */    len = sprintf(buf, "%08d", i);    key.dptr = buf;    key.dsize = len;    content = dbm_fetch(db, key);    if(!content.dptr){      pmyerror(name, "dbm_fetch failed");      err = TRUE;      break;    }    /* print progression */    if(rnum > 250 && i % (rnum / 250) == 0){      putchar('.');      fflush(stdout);      if(i == rnum || i % (rnum / 10) == 0){        printfflush(" (%08d)\n", i);      }    }  }  /* close the database */  dbm_close(db);  if(!err) printfflush("ok\n\n");  return err ? 1 : 0;}/* END OF FILE */

⌨️ 快捷键说明

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