diff options
author | piaip <piaip@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2009-06-04 03:28:57 +0800 |
---|---|---|
committer | piaip <piaip@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2009-06-04 03:28:57 +0800 |
commit | d7fe5b258c13cabd339cc4bda3aea25df93f31ea (patch) | |
tree | d501f262c5c70548cf7189558ab3da016fa56a1a | |
parent | 6eadc41a587bb1f362470e42d6b615e1567a6343 (diff) | |
download | pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.tar pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.tar.gz pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.tar.bz2 pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.tar.lz pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.tar.xz pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.tar.zst pttbbs-d7fe5b258c13cabd339cc4bda3aea25df93f31ea.zip |
add 'where am I' in announce system (thanks to sangl@ptt[PttSuggestion])
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@4492 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
-rw-r--r-- | include/pttstruct.h | 9 | ||||
-rw-r--r-- | mbbsd/announce.c | 54 |
2 files changed, 53 insertions, 10 deletions
diff --git a/include/pttstruct.h b/include/pttstruct.h index ea6cf302..33f4febc 100644 --- a/include/pttstruct.h +++ b/include/pttstruct.h @@ -423,12 +423,13 @@ typedef struct { } screen_backup_t; // menu_t ���O gmenu_t (deprecated), ��ذϱM�� menu -typedef struct { +typedef struct menu_t { + int num, page, now, level, bid; int header_size; - fileheader_t *header; + fileheader_t *header; + const char *path; + struct menu_t *next; char mtitle[STRLEN]; - const char *path; - int num, page, now, level, bid; } menu_t; /* Used to pass commands to the readmenu. diff --git a/mbbsd/announce.c b/mbbsd/announce.c index 0176d553..97762e13 100644 --- a/mbbsd/announce.c +++ b/mbbsd/announce.c @@ -325,6 +325,7 @@ a_showhelp(int level) "[^B][PgUp] �W�����\n" "[^F][PgDn][Spc] �U�����\n" "[##] ����ӿﶵ\n" + "[^W] �ڦb����\n" "[F][U] �N�峹�H�^ Internet �l�c/" "�N�峹 uuencode ��H�^�l�c\n"); if (level >= MANAGER) { @@ -1015,13 +1016,15 @@ isvisible_man(const menu_t * me) } return 1; } + int -a_menu(const char *maintitle, const char *path, +a_menu_rec(const char *maintitle, const char *path, int lastlevel, int lastbid, - char *trans_buffer) + char *trans_buffer, + menu_t *root, menu_t *parent) { static char Fexit; // �ΨӸ��X recursion - menu_t me; + menu_t me = {0}; char fname[PATHLEN]; int ch, returnvalue = FULLUPDATE; @@ -1035,7 +1038,13 @@ a_menu(const char *maintitle, const char *path, if(trans_buffer) trans_buffer[0] = '\0'; - memset(&me, 0, sizeof(me)); + if (parent) + { + parent->next = &me; + } else { + root = &me; + } + Fexit = 0; me.header_size = p_lines; me.header = (fileheader_t *) calloc(me.header_size, FHSZ); @@ -1148,6 +1157,28 @@ a_menu(const char *maintitle, const char *path, me.page = 9999; break; + case Ctrl('W'): + // XXX look up current location (utilize path and .DIR lookup) + move(1, 0); clrtobot(); outs("�ڦb���H\n"); + { + menu_t *p; + int lvl = 0, num = 0; + + for (p = root; p != NULL && lvl < t_lines - 3; p = p->next, lvl++) + { + prints("%*s", lvl, ""); + if (num) + prints("%d. ", num); + prints("%s\n", p->mtitle); + + // print in next round.. + num = p->now +1; + } + } + vmsg(NULL); + me.page = 9999; + break; + case 'e': case 'E': snprintf(fname, sizeof(fname), @@ -1275,8 +1306,9 @@ a_menu(const char *maintitle, const char *path, break; } } else if (dashd(fname)) { - a_menu(me.header[me.now - me.page].title, fname, - me.level, me.bid, trans_buffer); + a_menu_rec(me.header[me.now - me.page].title, fname, + me.level, me.bid, trans_buffer, root, &me); + me.next = NULL; /* Ptt �j�O���Xrecursive */ if (Fexit) { free(me.header); @@ -1408,6 +1440,16 @@ a_menu(const char *maintitle, const char *path, } int +a_menu(const char *maintitle, const char *path, + int lastlevel, int lastbid, + char *trans_buffer) +{ + return a_menu_rec(maintitle, path, + lastlevel, lastbid, trans_buffer, + NULL, NULL); +} + +int Announce(void) { setutmpmode(ANNOUNCE); |