diff options
-rw-r--r-- | include/pttstruct.h | 4 | ||||
-rw-r--r-- | mbbsd/assess.c | 1 | ||||
-rw-r--r-- | mbbsd/chc.c | 1 | ||||
-rw-r--r-- | mbbsd/fav.c | 1 | ||||
-rw-r--r-- | mbbsd/mbbsd.c | 2 | ||||
-rw-r--r-- | mbbsd/screen.c | 6 | ||||
-rw-r--r-- | util/Makefile | 2 | ||||
-rw-r--r-- | util/angel.c | 109 | ||||
-rw-r--r-- | util/buildir.c | 7 |
9 files changed, 128 insertions, 5 deletions
diff --git a/include/pttstruct.h b/include/pttstruct.h index c32c615b..99be5a50 100644 --- a/include/pttstruct.h +++ b/include/pttstruct.h @@ -121,10 +121,10 @@ typedef struct userec_t { #define LIVERIGHT 0x200 /* true if get "liveright" already */ #define REJ_OUTTAMAIL 0x400 /* true if don't accept outside mails */ #define REJECT_OUTTAMAIL (cuser.uflag2 & REJ_OUTTAMAIL) -#define REJ_QUESTION 0x800 /* true if don't want to be angel for a while */ -#define REJECT_QUESTION (cuser.uflag2 & REJ_QUESTION) #ifdef PLAY_ANGEL +#define REJ_QUESTION 0x800 /* true if don't want to be angel for a while */ +#define REJECT_QUESTION (cuser.uflag2 & REJ_QUESTION) #define ANGEL_MASK 0x3000 #define ANGEL_R_MAEL 0x1000 /* true if reject male */ #define ANGEL_R_FEMAEL 0x2000 /* true if reject female */ diff --git a/mbbsd/assess.c b/mbbsd/assess.c index 2e8ebd36..5ceb0564 100644 --- a/mbbsd/assess.c +++ b/mbbsd/assess.c @@ -1,3 +1,4 @@ +/* $Id$ */ #include "bbs.h" #ifdef ASSESS diff --git a/mbbsd/chc.c b/mbbsd/chc.c index 4824af0f..5ab93a00 100644 --- a/mbbsd/chc.c +++ b/mbbsd/chc.c @@ -1,3 +1,4 @@ +/* $Id$ */ #include "bbs.h" #define CENTER(a, b) (((a) + (b)) >> 1) diff --git a/mbbsd/fav.c b/mbbsd/fav.c index c5bd6c0d..e4766b1a 100644 --- a/mbbsd/fav.c +++ b/mbbsd/fav.c @@ -1,3 +1,4 @@ +/* $Id$ */ #include "bbs.h" #ifdef MEM_CHECK diff --git a/mbbsd/mbbsd.c b/mbbsd/mbbsd.c index be7b32e7..402a71c6 100644 --- a/mbbsd/mbbsd.c +++ b/mbbsd/mbbsd.c @@ -778,9 +778,9 @@ setup_utmp(int mode) if (enter_uflag & CLOAK_FLAG) uinfo.invisible = YEA; +#ifdef PLAY_ANGEL if (REJECT_QUESTION) uinfo.angel = 1; -#ifdef PLAY_ANGEL uinfo.angel |= ANGEL_STATUS() << 1; #endif diff --git a/mbbsd/screen.c b/mbbsd/screen.c index 8c91434b..6ad8920b 100644 --- a/mbbsd/screen.c +++ b/mbbsd/screen.c @@ -306,6 +306,11 @@ outc(unsigned char c) if (cur_col < slp->smod) slp->smod = cur_col; } +#if 1 + ++cur_col; +#else + /* this comparison is always false (cur_col is unsigned char and scr_cols + * is 511). */ if (++cur_col >= scr_cols) { if (standing && (slp->mode & STANDOUT)) { standing = 0; @@ -315,6 +320,7 @@ outc(unsigned char c) if (cur_ln < scr_lns) cur_ln++; } +#endif } int diff --git a/util/Makefile b/util/Makefile index 1faf486e..d4d1def3 100644 --- a/util/Makefile +++ b/util/Makefile @@ -23,7 +23,7 @@ CPROG_WITH_UTIL= \ indexuser yearsold toplazyBM toplazyBBM \ reaper buildAnnounce inndBM shmctl \ outmail chkhbf checkmoney merge_dir \ - transman + transman angel # 下面這些程式, 會直接被 compile CPROG_WITHOUT_UTIL= \ diff --git a/util/angel.c b/util/angel.c new file mode 100644 index 00000000..4433aef2 --- /dev/null +++ b/util/angel.c @@ -0,0 +1,109 @@ +/* $Id$ */ +#include "bbs.h" + +#ifndef PLAY_ANGEL +int main(){ return 0; } +#else + +int total[MAX_USERS]; +int reject[4]; +int rej_question; + +int ListCmp(const void * a, const void * b){ + return *(int*)b - *(int*)a; +} + +int main(int argc, char* argv[]){ + char* mailto = "SYSOP"; + int (*list)[2]; + int i, j; + time_t t; + int count; + int nReport = 100; + userec_t user; + FILE* fp = fopen(BBSHOME "/.PASSWDS", "rb"); + int pipefd[2]; + + if(argc > 1) + mailto = argv[1]; + if(argc > 2) + nReport = atoi(argv[2]); + attach_SHM(); + + j = count = 0; + while(fread(&user, sizeof(userec_t), 1, fp) == 1){ + ++j; /* j == uid */ + if(user.myangel[0]){ + i = searchuser(user.myangel); + if(i) + ++total[i]; + } + if(user.userlevel & PERM_ANGEL){ + ++count; + ++reject[((user.uflag2 & ANGEL_MASK) >> 12)]; + ++total[j]; /* make all angel have total > 0 */ + if(user.uflag2 & REJ_QUESTION) + ++rej_question; + } + } + fclose(fp); + + if(nReport > count) + nReport = count; + + list = (int(*)[2]) malloc(count * sizeof(int[2])); + j = 0; + for(i = 0; i < MAX_USERS; ++i) + if(total[i]){ + list[j][0] = total[i] - 1; + list[j][1] = i; + ++j; + } + + qsort(list, count, sizeof(int[2]), ListCmp); + + /* Ok, let's send the result. */ + pipe(pipefd); + if((i = fork()) == -1){ + fprintf(stderr, "fork error: %s\nDidn't send the result.\n", + strerror(errno)); + return 0; + }else if(i == 0){ + /* child */ + dup2(pipefd[0], 0); + close(pipefd[0]); /* use 0 instead of pipefd[0], don't need any more */ + close(pipefd[1]); /* close write site */ + execlp("bbsmail", "bbsmail", mailto, NULL); + fprintf(stderr, "execlp error: %s\nDidn't send the result.\n", + strerror(errno)); + return 0; + } + /* parent, don't need read site */ + close(pipefd[0]); + fp = fdopen(pipefd[1], "w"); + + fprintf(fp, "Subject: 小天使統計資料\n" + "From: 站方統計\n" + "\n現在全站小天使有 %d 位\n" + "\n小主人數最多的 %d 位小天使:\n", count, nReport); + for(i = 0; i < nReport; ++i) + fprintf(fp, "%15s%3d 人\n", SHM->userid[list[i][1] - 1], list[i][0]); + fprintf(fp, "\n現在男女皆收的小天使有 %d 位\n" + "只收女生的有 %d 位 (共 %d 位收女生)\n" + "只收男生的有 %d 位 (共 %d 位收男生)\n" + "不接受新小天使的有 %d 位\n", + reject[0], reject[1], reject[1] + reject[0], + reject[2], reject[2] + reject[0], reject[3]); + fprintf(fp, "\n現在開放小主人問問題的小天使有 %d 位\n" + "不開放的有 %d 位\n", + count - rej_question, rej_question); + + time(&t); + fprintf(fp, "\n--\n\n" + " 本資料由 angel 程式產生於 %s\n", + ctime(&t)); + fclose(fp); + return 0; +} + +#endif /* defined PLAY_ANGEL */ diff --git a/util/buildir.c b/util/buildir.c index 573a0178..6b0917e7 100644 --- a/util/buildir.c +++ b/util/buildir.c @@ -1,7 +1,12 @@ /* $Id$ */ #include "bbs.h" -int dirselect(struct dirent *dir) { +#ifdef __linux__ +int dirselect(const struct dirent *dir) +#else +int dirselect(struct dirent *dir) +#endif +{ return strchr("MDSGH", dir->d_name[0]) && dir->d_name[1] == '.'; } |