summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--util/Makefile2
-rw-r--r--util/kenben.c44
-rw-r--r--util/merge_passwd.c100
3 files changed, 1 insertions, 145 deletions
diff --git a/util/Makefile b/util/Makefile
index 33f3726b..f768c106 100644
--- a/util/Makefile
+++ b/util/Makefile
@@ -34,7 +34,7 @@ CPROG_WITHOUT_UTIL= \
uhash_loader showboard \
countalldice bbsrf initbbs \
userlist merge_passwd \
- merge_board bbsmail gamble_fix
+ merge_board bbsmail
# 下面這些程式會被 install
PROGS= ${CPROG_WITH_UTIL} ${CPROG_WITHOUT_UTIL} \
diff --git a/util/kenben.c b/util/kenben.c
deleted file mode 100644
index 67b1e9bd..00000000
--- a/util/kenben.c
+++ /dev/null
@@ -1,44 +0,0 @@
-#include <stdio.h>
-
-
-void main()
-{
- FILE * fin, * fout;
- char line[255], line2[255];
- int i;
- char genbuf[255], tok[20];
- fin = fopen("M.1006277896.A","r");
- while(!feof(fin))
- {
- fgets(line,255,fin);
- line[12] = '\0';
-
- sprintf(genbuf, "cd "BBSHOME"/boards/%c/%s;grep "
- "超過一個月無廣告以外的本站文章發表。"
- " *.A > "BBSHOME"/pttbbs/util/kenken.txt", line[0], line);
- system(genbuf);
-
- fout = fopen("kenken.txt","r");
- while(!feof(fout))
- {
- line2[0] = '\0';
- fgets(line2,255,fout);
- if(strlen(line2) <= 10) break;
- sscanf(line2,"%s:",tok);
- for(i = 0; i < 20;i++)
- {
- if(tok[i] == ':')
- {
- tok[i] = '\0';
- break;
- }
- }
- sprintf(genbuf, "cd "BBSHOME"/boards/%c/%s;rm %s", line[0], line, tok);
-// printf("%s \n", genbuf);
- system(genbuf);
- }
- }
-
- fclose(fin);
-
-}
diff --git a/util/merge_passwd.c b/util/merge_passwd.c
deleted file mode 100644
index 7221e384..00000000
--- a/util/merge_passwd.c
+++ /dev/null
@@ -1,100 +0,0 @@
-/* $Id$ */
-#include "bbs.h"
-
-typedef struct hash_t {
- char *userid;
- struct hash_t *next;
-} hash_t;
-
-FILE *fout;
-hash_t *hash_tbl[65536];
-int counter;
-
-void usage() {
- fprintf(stderr, "Usage:\n\n"
- "merge_passwd <output file> [input file1] [input file2] ...\n");
-}
-
-unsigned int string_hash(unsigned char *s) {
- unsigned int v=0;
-
- while(*s) {
- v = (v << 8) | (v >> 24);
- v ^= toupper(*s++); /* note this is case insensitive */
- }
- return (v * 2654435769U) >> (32 - 16);
-}
-
-int is_exist(char *userid) {
- int i;
- hash_t *n;
-
- i = string_hash(userid);
- for(n = hash_tbl[i]; n != NULL; n = n->next)
- if(strcasecmp(userid, n->userid) == 0)
- return 1;
- return 0;
-}
-
-void add_hash(char *userid) {
- int i;
- hash_t *n;
-
- i = string_hash(userid);
-
- n = malloc(sizeof(*n));
- n->userid = strdup(userid);
- n->next = hash_tbl[i];
- hash_tbl[i] = n;
-}
-
-void merge_user(userec_t *u) {
- if(!is_exist(u->userid)) {
- fwrite(u, sizeof(*u), 1, fout);
- add_hash(u->userid);
- ++counter;
- }
-}
-
-void merge_file(char *fname) {
- FILE *fin;
- userec_t u;
-
- if((fin = fopen(fname, "r")) == NULL) {
- perror(fname);
- return;
- }
-
- counter = 0;
- while(fread(&u, sizeof(u), 1, fin) == 1)
- if(u.userid[0])
- merge_user(&u);
-
- printf("merge from %s: %d users\n", fname, counter);
-
- fclose(fin);
-}
-
-int main(int argc, char **argv) {
- int i;
-
- if(argc < 2) {
- usage();
- return 1;
- }
-
- bzero(hash_tbl, sizeof(hash_tbl));
-
- if((fout = fopen(argv[1], "w")) == NULL) {
- perror(argv[1]);
- return 2;
- }
-
- for(i = 2; i < argc; ++i)
- merge_file(argv[i]);
-
- fclose(fout);
- printf("Done\n");
-
- return 0;
-}