diff options
author | wens <wens@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2008-05-27 20:14:29 +0800 |
---|---|---|
committer | wens <wens@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2008-05-27 20:14:29 +0800 |
commit | 8dc05d22ea78cf3c45978e90fecfb17807fbce56 (patch) | |
tree | 40a4593b40e6e4c5d45af917f00218d366c59345 /trans | |
parent | 8367f5a18fa7291a25359390e23dc9595275f8bf (diff) | |
download | pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.tar pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.tar.gz pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.tar.bz2 pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.tar.lz pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.tar.xz pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.tar.zst pttbbs-8dc05d22ea78cf3c45978e90fecfb17807fbce56.zip |
fix up wretch converter, added support for boards
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@4327 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'trans')
-rw-r--r-- | trans/Makefile | 2 | ||||
-rw-r--r-- | trans/wretch_man.c | 124 | ||||
-rw-r--r-- | trans/wretch_trans.c | 174 |
3 files changed, 175 insertions, 125 deletions
diff --git a/trans/Makefile b/trans/Makefile index 6518509a..786fde1c 100644 --- a/trans/Makefile +++ b/trans/Makefile @@ -15,7 +15,7 @@ MBBSD_OBJS= \ # 下面這些程式, 會被 compile 並且和 $(UTIL_OBJS) 聯結 CPROG_WITH_UTIL= \ - wretch_man \ + wretch_trans \ sob_trans \ transman diff --git a/trans/wretch_man.c b/trans/wretch_man.c deleted file mode 100644 index d055980d..00000000 --- a/trans/wretch_man.c +++ /dev/null @@ -1,124 +0,0 @@ -/* $Id$ */ -/* tool to convert wretch bbs to ptt bbs */ - -#include "bbs.h" - -struct wretch_fheader_t { - time4_t chrono; - char pad[4]; - int xmode; - int xid; - char xname[32]; /* 檔案名稱 */ - char owner[80]; /* 作者 (E-mail address) */ - char nick[50]; /* 暱稱 */ - char date[9]; /* [96/12/01] */ - char title[72]; /* 主題 (TTLEN + 1) */ - char score; - char pad2[4]; -}; - -#define POST_MARKED 0x00000002 /* marked */ -#define POST_BOTTOM1 0x00002000 /* 置底文章的正本 */ - -#define GEM_RESTRICT 0x0800 /* 限制級精華區,須 manager 才能看 */ -#define GEM_RESERVED 0x1000 /* 限制級精華區,須 sysop 才能更改 */ -#define GEM_FOLDER 0x00010000 /* folder / article */ -#define GEM_BOARD 0x00020000 /* 看板精華區 */ - -static const char radix32[32] = { - '0', '1', '2', '3', '4', '5', '6', '7', - '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', - 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', - 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', -}; - -char *path; -char *board; - -int transman(char *fname, char *newpath) -{ - int fd; - char *p; - char buf[PATHLEN]; - struct wretch_fheader_t whdr; - fileheader_t fhdr; - - if (fname[0] == '.') - snprintf(buf, PATHLEN, "%s/%s", path, fname); - else - snprintf(buf, PATHLEN, "%s/%c/%s", path, fname[7], fname); - - if ((fd = open(buf, O_RDONLY, 0)) == -1) - return -1; - - while (read(fd, &whdr, sizeof(whdr)) == sizeof(whdr)) { - if (strcmp(whdr.xname, "..") == 0 || strchr(whdr.xname, '/')) - continue; - - if (!(whdr.xmode & 0xffff0000)) { - /* article */ - stampfile(newpath, &fhdr); - strlcpy(fhdr.title, "◇ ", sizeof(fhdr.title)); - - if (whdr.xname[0] == '@') - snprintf(buf, sizeof(buf), "%s/@/%s", path, whdr.xname); - else - snprintf(buf, sizeof(buf), "%s/%c/%s", path, whdr.xname[7], whdr.xname); - - copy_file(buf, newpath); - } - else if (whdr.xmode & GEM_FOLDER) { - /* folder */ - stampdir(newpath, &fhdr); - strlcpy(fhdr.title, "◆ ", sizeof(fhdr.title)); - - transman(whdr.xname, newpath); - } - - p = strrchr(newpath, '/'); - *p = '\0'; - - if (whdr.xmode & 0x0800) - fhdr.filemode |= FILE_BM; - - strncat(fhdr.title, whdr.title, sizeof(fhdr.title) - strlen(fhdr.title) - 1); - strlcpy(fhdr.owner, whdr.owner, sizeof(fhdr.title)); - - setadir(buf, newpath); - append_record(buf, &fhdr, sizeof(fhdr)); - } - - close(fd); - return 0; -} - -int main(int argc, char *argv[]) -{ - char buf[PATHLEN]; - - if (argc < 2) { - printf("%s <path> <board>\n", argv[0]); - return 0; - } - - path = argv[1]; - board = argv[2]; - - if (!dashd(path)) { - printf("%s is not directory\n", path); - return 0; - } - - setapath(buf, board); - - if (!dashd(buf)) { - printf("%s is not directory\n", buf); - return 0; - } - - attach_SHM(); - - transman(".DIR", buf); - - return 0; -} diff --git a/trans/wretch_trans.c b/trans/wretch_trans.c new file mode 100644 index 00000000..9d6ad680 --- /dev/null +++ b/trans/wretch_trans.c @@ -0,0 +1,174 @@ +/* $Id$ */ +/* tool to convert wretch bbs to ptt bbs */ + +#include "bbs.h" + +typedef struct { + time4_t chrono; + char pad[4]; + int xmode; + int xid; + char xname[32]; /* 檔案名稱 */ + char owner[80]; /* 作者 (E-mail address) */ + char nick[50]; /* 暱稱 */ + char date[9]; /* [96/12/01] */ + char title[72]; /* 主題 (TTLEN + 1) */ + char score; + char pad2[4]; +} wretch_HDR; + +#define WR_POST_MARKED 0x00000002 /* marked */ +#define WR_POST_BOTTOM1 0x00002000 /* 置底文章的正本 */ + +#define WR_GEM_RESTRICT 0x0800 /* 限制級精華區,須 manager 才能看 */ +#define WR_GEM_RESERVED 0x1000 /* 限制級精華區,須 sysop 才能更改 */ +#define WR_GEM_FOLDER 0x00010000 /* folder / article */ +#define WR_GEM_BOARD 0x00020000 /* 看板精華區 */ + +static const char radix32[32] = { + '0', '1', '2', '3', '4', '5', '6', '7', + '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', + 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', + 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', +}; + +char *path; +int trans_man = 0; + +int convert(char *fname, char *newpath) +{ + int fd; + char *p; + char buf[PATHLEN]; + wretch_HDR whdr; + fileheader_t fhdr; + + if (fname[0] == '.') + snprintf(buf, sizeof(buf), "%s/%s", path, fname); + else + snprintf(buf, sizeof(buf), "%s/%c/%s", path, fname[7], fname); + + if ((fd = open(buf, O_RDONLY, 0)) == -1) + return -1; + + while (read(fd, &whdr, sizeof(whdr)) == sizeof(whdr)) { + if (strcmp(whdr.xname, "..") == 0 || strchr(whdr.xname, '/')) + continue; + + if (!(whdr.xmode & 0xffff0000)) { + /* article */ + stampfile(newpath, &fhdr); + + if (trans_man) + strlcpy(fhdr.title, "◇ ", sizeof(fhdr.title)); + + if (whdr.xname[0] == '@') + snprintf(buf, sizeof(buf), "%s/@/%s", path, whdr.xname); + else + snprintf(buf, sizeof(buf), "%s/%c/%s", path, whdr.xname[7], whdr.xname); + + fhdr.modified = dasht(buf); + if (whdr.xmode & WR_POST_MARKED) + fhdr.filemode |= FILE_MARKED; + + copy_file(buf, newpath); + } + else if (whdr.xmode & WR_GEM_FOLDER) { + /* folder */ + stampdir(newpath, &fhdr); + + if (trans_man) + strlcpy(fhdr.title, "◆ ", sizeof(fhdr.title)); + + convert(whdr.xname, newpath); + } + else { + /* ignore */ + continue; + } + + p = strrchr(newpath, '/'); + *p = '\0'; + + if (whdr.xmode & WR_GEM_RESTRICT) + fhdr.filemode |= FILE_BM; + + strlcat(fhdr.title, whdr.title, sizeof(fhdr.title)); + strlcpy(fhdr.owner, whdr.owner, sizeof(fhdr.owner)); + if (whdr.date[0] && strlen(whdr.date) == 8) + strlcpy(fhdr.date, whdr.date + 3, sizeof(fhdr.date)); + else + strlcpy(fhdr.date, " ", sizeof(fhdr.date)); + + setadir(buf, newpath); + append_record(buf, &fhdr, sizeof(fhdr)); + } + + close(fd); + return 0; +} + +int main(int argc, char *argv[]) +{ + char buf[PATHLEN]; + char *board; + int opt; + + while ((opt = getopt(argc, argv, "m")) != -1) { + switch (opt) { + case 'm': + trans_man = 1; + break; + default: + fprintf(stderr, "%s [-m] <path> <board>\n", argv[0]); + fprintf(stderr, " -m convert man (default is board)\n"); + } + } + + if ((argc - optind + 1) < 2) { + fprintf(stderr, "%s [-m] <path> <board>\n", argv[0]); + fprintf(stderr, " -m convert man (default is board)\n"); + return 0; + } + + + path = argv[1]; + board = argv[2]; + + if (!dashd(path)) { + fprintf(stderr, "%s is not directory\n", path); + return 0; + } + + attach_SHM(); + opt = getbnum(board); + + if (opt == 0) { + fprintf(stderr, "ERR: board `%s' not found\n", board); + return 0; + } + + if (trans_man) + setapath(buf, board); + else + setbpath(buf, board); + + if (!dashd(buf)) { + fprintf(stderr, "%s is not directory\n", buf); + return 0; + } + + attach_SHM(); + + convert(".DIR", buf); + + if (trans_man) { + strlcat(buf, "/.rebuild", sizeof(buf)); + if ((opt = open(buf, O_CREAT, 0640)) > 0) + close(opt); + } + else + touchbtotal(opt); + + return 0; +} |