diff options
Diffstat (limited to 'util')
-rw-r--r-- | util/Makefile | 2 | ||||
-rw-r--r-- | util/merge_dir.c | 50 |
2 files changed, 51 insertions, 1 deletions
diff --git a/util/Makefile b/util/Makefile index 0dc3f0f6..99461ffe 100644 --- a/util/Makefile +++ b/util/Makefile @@ -22,7 +22,7 @@ CPROG_WITH_UTIL= \ openvice parse_news openticket topusr \ indexuser yearsold toplazyBM toplazyBBM \ reaper buildAnnounce inndBM shmctl \ - outmail chkhbf checkmoney + outmail chkhbf checkmoney merge_dir # 下面這些程式, 會直接被 compile CPROG_WITHOUT_UTIL= \ diff --git a/util/merge_dir.c b/util/merge_dir.c new file mode 100644 index 00000000..8df9239b --- /dev/null +++ b/util/merge_dir.c @@ -0,0 +1,50 @@ +/* $Id: merge_board.c 1096 2003-08-15 06:13:29Z victor $ */ +#include <stdio.h> +#include <stdlib.h> +#include <ctype.h> +#include <string.h> +#include <sys/types.h> +#include "config.h" +#include "pttstruct.h" + +void usage() { + fprintf(stderr, "Usage:\n\n" + "merge_dir <dir1> <dir2> \n"); +} +int +dir_cmp(fileheader_t *a, fileheader_t *b) +{ + if(!a->filename[0] || !b->filename[0]) return 0; + return (strcasecmp(a->filename+1, b->filename+1)); +} + + +fileheader_t *fh; + +int main(int argc, char **argv) { + int pn, sn, i; + + if(argc < 2) { + usage(); + return 1; + } + + pn=get_num_records(argv[1], sizeof(fileheader_t)); + sn=get_num_records(argv[2], sizeof(fileheader_t)); + if(sn <=0 || pn<=0) + { + usage(); + return 1; + } + fh = (fileheader_t *)malloc( (pn+sn)*sizeof(fileheader_t)); + get_records(argv[1], fh, sizeof(fileheader_t), 1, pn); + get_records(argv[2], fh+pn, sizeof(fileheader_t), 1, sn); + qsort(fh, pn+sn, sizeof(boardheader_t), dir_cmp); + + for(i=0; i<pn+sn; i++) + { + printf("%s %s %s\n",fh[i].date, fh[i].title, fh[i].filename); + } + + return 0; +} |