diff options
-rw-r--r-- | include/proto.h | 2 | ||||
-rw-r--r-- | mbbsd/mbbsd.c | 2 | ||||
-rw-r--r-- | mbbsd/menu.c | 54 |
3 files changed, 37 insertions, 21 deletions
diff --git a/include/proto.h b/include/proto.h index 981a7ba4..f3579619 100644 --- a/include/proto.h +++ b/include/proto.h @@ -379,7 +379,7 @@ int query_file_money(const fileheader_t *pfh); /* menu */ void showtitle(const char *title, const char *mid); void movie(int i); -void domenu(int cmdmode, const char *cmdtitle, int cmd, const commands_t cmdtable[]); +int main_menu(void); int admin(void); int Mail(void); int Talk(void); diff --git a/mbbsd/mbbsd.c b/mbbsd/mbbsd.c index f9cd01c4..adc2dedf 100644 --- a/mbbsd/mbbsd.c +++ b/mbbsd/mbbsd.c @@ -1152,7 +1152,7 @@ start_client(void) Signal(SIGALRM, SIG_IGN); - domenu(MMENU, "主功\能表", (currutmp->mailalert ? 'M' : 'C'), cmdlist); + main_menu(); } /* 取得 remote user name 以判定身份 */ diff --git a/mbbsd/menu.c b/mbbsd/menu.c index a613de8d..a802713d 100644 --- a/mbbsd/menu.c +++ b/mbbsd/menu.c @@ -9,7 +9,6 @@ extern char *boardprefix; extern struct utmpfile_t *utmpshm; extern char board_hidden_status; - static const char *title_tail_msgs[] = { "看板", "文摘", @@ -214,18 +213,30 @@ show_menu(const commands_t * p) return n - 1; } -void + +static enum { + M_ADMIN = 0, M_AMUSE, M_CHC, M_JCEE, M_MAIL, M_MMENU, M_NMENU, + M_PMENU, M_PSALE, M_SREG, M_TMENU, M_UMENU, M_XMENU, +}; + +static const int mode_map[] = { + ADMIN, AMUSE, CHC, JCEE, MAIL, MMENU, NMENU, + PMENU, PSALE, SREG, TMENU, UMENU, XMENU, +}; + +static void domenu(int cmdmode, const char *cmdtitle, int cmd, const commands_t cmdtable[]) { int lastcmdptr; int n, pos, total, i; int err; - // XXX do we really need this ? - static char cmd0[MODE_MAX]; + static char cursor_position[sizeof(mode_map) / sizeof(mode_map[0])] = { 0 }; + + cmdmode = mode_map[cmdmode]; - if (cmd0[cmdmode]) - cmd = cmd0[cmdmode]; + if (cursor_position[cmdmode]) + cmd = cursor_position[cmdmode]; setutmpmode(cmdmode); @@ -314,7 +325,7 @@ domenu(int cmdmode, const char *cmdtitle, int cmd, const commands_t cmdtable[]) cmd = cmdtable[lastcmdptr].desc[0]; else cmd = cmdtable[lastcmdptr].desc[1]; - cmd0[cmdmode] = cmdtable[lastcmdptr].desc[0]; + cursor_position[cmdmode] = cmdtable[lastcmdptr].desc[0]; } if (cmd >= 'a' && cmd <= 'z') cmd &= ~0x20; @@ -535,8 +546,13 @@ static const commands_t moneylist[] = { {NULL, 0, NULL} }; +int main_menu(void) { + domenu(M_MMENU, "主功\能表", (currutmp->mailalert ? 'M' : 'C'), cmdlist); + return 0; +} + static int p_money() { - domenu(PSALE, "Ptt量販店", '0', moneylist); + domenu(M_PSALE, "Ptt量販店", '0', moneylist); return 0; }; @@ -551,7 +567,7 @@ const static commands_t jceelist[] = { }; static int m_jcee() { - domenu(JCEE, "Ptt查榜系統", '0', jceelist); + domenu(M_JCEE, "Ptt查榜系統", '0', jceelist); return 0; } #endif @@ -594,7 +610,7 @@ static const commands_t chesslist[] = { }; static int chessroom() { - domenu(CHC, "Ptt棋院", '1', chesslist); + domenu(M_CHC, "Ptt棋院", '1', chesslist); return 0; } @@ -615,7 +631,7 @@ static const commands_t plist[] = { }; static int playground() { - domenu(AMUSE, "Ptt遊樂場",'1',plist); + domenu(M_AMUSE, "Ptt遊樂場",'1',plist); return 0; } @@ -628,7 +644,7 @@ static const commands_t slist[] = { }; static int forsearch() { - domenu(SREG, "Ptt搜尋器", '1', slist); + domenu(M_SREG, "Ptt搜尋器", '1', slist); return 0; } @@ -637,49 +653,49 @@ static int forsearch() { int admin(void) { - domenu(ADMIN, "系統維護", 'X', adminlist); + domenu(M_ADMIN, "系統維護", 'X', adminlist); return 0; } int Mail(void) { - domenu(MAIL, "電子郵件", 'R', maillist); + domenu(M_MAIL, "電子郵件", 'R', maillist); return 0; } int Talk(void) { - domenu(TMENU, "聊天說話", 'U', talklist); + domenu(M_TMENU, "聊天說話", 'U', talklist); return 0; } int User(void) { - domenu(UMENU, "個人設定", 'I', userlist); + domenu(M_UMENU, "個人設定", 'I', userlist); return 0; } int Xyz(void) { - domenu(XMENU, "工具程式", 'M', xyzlist); + domenu(M_XMENU, "工具程式", 'M', xyzlist); return 0; } int Play_Play(void) { - domenu(PMENU, "網路遊樂場", 'A', playlist); + domenu(M_PMENU, "網路遊樂場", 'A', playlist); return 0; } int Name_Menu(void) { - domenu(NMENU, "白色恐怖", 'O', namelist); + domenu(M_NMENU, "白色恐怖", 'O', namelist); return 0; } |