summaryrefslogtreecommitdiffstats
path: root/mbbsd
diff options
context:
space:
mode:
Diffstat (limited to 'mbbsd')
-rw-r--r--mbbsd/Makefile2
-rw-r--r--mbbsd/angel.c321
-rw-r--r--mbbsd/talk.c336
-rw-r--r--mbbsd/user.c14
4 files changed, 356 insertions, 317 deletions
diff --git a/mbbsd/Makefile b/mbbsd/Makefile
index 36d04fc2..4bfb9e6f 100644
--- a/mbbsd/Makefile
+++ b/mbbsd/Makefile
@@ -14,7 +14,7 @@ NETOBJS = mbbsd.o io.o term.o telnet.o
TALKOBJS = talk.o chat.o friend.o
UTILOBJS = stuff.o kaede.o convert.o name.o syspost.o
PAGEROBJS= more.o pmore.o
-PLUGOBJS = lovepaper.o calendar.o topsong.o gamble.o vice.o
+PLUGOBJS = lovepaper.o calendar.o topsong.o gamble.o vice.o angel.o
CHESSOBJS= chc.o chc_tab.o chess.o go.o gomo.o dark.o reversi.o
GAMEOBJS = card.o guess.o chicken.o othello.o
OBJS= admin.o assess.o edit.o menu.o xyz.o var.o \
diff --git a/mbbsd/angel.c b/mbbsd/angel.c
new file mode 100644
index 00000000..6403b99b
--- /dev/null
+++ b/mbbsd/angel.c
@@ -0,0 +1,321 @@
+/* $Id$ */
+#include "bbs.h"
+
+// PTT-BBS Angel System
+
+#ifdef PLAY_ANGEL
+
+void
+angel_toggle_pause()
+{
+ if (!HasUserPerm(PERM_ANGEL) || !currutmp)
+ return;
+ currutmp->angelpause ++;
+ currutmp->angelpause %= ANGELPAUSE_MODES;
+
+ // maintain deprecated value
+ cuser.uflag2 &= ~UF2_ANGEL_OLDMASK;
+}
+
+void
+angel_load_data()
+{
+ // TODO cache angel.msg here.
+}
+
+int
+t_changeangel(){
+ char buf[4];
+
+ /* cuser.myangel == "-" means banned for calling angel */
+ if (cuser.myangel[0] == '-' || cuser.myangel[1] == 0) return 0;
+
+ getdata(b_lines - 1, 0,
+ "更換小天使後就無法換回了喔! 是否要更換小天使? [y/N]",
+ buf, 3, LCECHO);
+ if (buf[0] == 'y' || buf[0] == 'Y') {
+ char buf[100];
+ snprintf(buf, sizeof(buf), "%s小主人 %s 換掉 %s 小天使\n",
+ ctime4(&now), cuser.userid, cuser.myangel);
+ buf[24] = ' '; // replace '\n'
+ log_file(BBSHOME "/log/changeangel.log", LOG_CREAT, buf);
+
+ cuser.myangel[0] = 0;
+ outs("小天使更新完成,下次呼叫時會選出新的小天使");
+ }
+ return XEASY;
+}
+
+int
+t_angelmsg(){
+ char msg[3][74] = { "", "", "" };
+ char nick[10] = "";
+ char buf[512];
+ int i;
+ FILE* fp;
+
+ setuserfile(buf, "angelmsg");
+ fp = fopen(buf, "r");
+ if (fp) {
+ i = 0;
+ if (fgets(msg[0], sizeof(msg[0]), fp)) {
+ chomp(msg[0]);
+ if (strncmp(msg[0], "%%[", 3) == 0) {
+ strlcpy(nick, msg[0] + 3, 7);
+ move(4, 0);
+ prints("原有暱稱:%s小天使", nick);
+ msg[0][0] = 0;
+ } else
+ i = 1;
+ } else
+ msg[0][0] = 0;
+
+ move(5, 0);
+ outs("原有留言:\n");
+ if(msg[0][0])
+ outs(msg[0]);
+ for (; i < 3; ++i) {
+ if(fgets(msg[i], sizeof(msg[0]), fp)) {
+ outs(msg[i]);
+ chomp(msg[i]);
+ } else
+ break;
+ }
+ fclose(fp);
+ }
+
+ getdata_buf(11, 0, "小天使暱稱:", nick, 7, 1);
+ do {
+ move(12, 0);
+ clrtobot();
+ outs("不在的時候要跟小主人說什麼呢?"
+ "最多三行,按[Enter]結束");
+ for (i = 0; i < 3 &&
+ getdata_buf(14 + i, 0, ":", msg[i], sizeof(msg[i]), DOECHO);
+ ++i);
+ getdata(b_lines - 2, 0, "(S)儲存 (E)重新來過 (Q)取消?[S]",
+ buf, 4, LCECHO);
+ } while (buf[0] == 'E' || buf[0] == 'e');
+ if (buf[0] == 'Q' || buf[0] == 'q')
+ return 0;
+ setuserfile(buf, "angelmsg");
+ if (msg[0][0] == 0)
+ unlink(buf);
+ else {
+ FILE* fp = fopen(buf, "w");
+ if(nick[0])
+ fprintf(fp, "%%%%[%s\n", nick);
+ for (i = 0; i < 3 && msg[i][0]; ++i) {
+ fputs(msg[i], fp);
+ fputc('\n', fp);
+ }
+ fclose(fp);
+ }
+ return 0;
+}
+
+inline int
+angel_reject_me(userinfo_t * uin){
+ int* iter = uin->reject;
+ int unum;
+ while ((unum = *iter++)) {
+ if (unum == currutmp->uid) {
+ return 1;
+ }
+ }
+ return 0;
+}
+
+
+static int
+FindAngel(void){
+ int nAngel;
+ int i, j;
+ int choose;
+ int trial = 0;
+ int mask;
+
+ if (cuser.sex < 6) /* 正常性別 */
+ mask = 1 | (2 << (cuser.sex & 1));
+ else
+ mask = 7;
+
+ do{
+ nAngel = 0;
+ j = SHM->currsorted;
+ for (i = 0; i < SHM->UTMPnumber; ++i)
+ if (SHM->uinfo[SHM->sorted[j][0][i]].userlevel & PERM_ANGEL)
+ ++nAngel;
+
+ if (nAngel == 0)
+ return 0;
+
+ choose = random() % nAngel + 1;
+ j = SHM->currsorted;
+ for (i = 0; i < SHM->UTMPnumber && choose; ++i)
+ if (SHM->uinfo[SHM->sorted[j][0][i]].userlevel & PERM_ANGEL)
+ --choose;
+
+ if (choose == 0 && SHM->uinfo[SHM->sorted[j][0][i - 1]].uid != currutmp->uid
+ && (SHM->uinfo[SHM->sorted[j][0][i - 1]].userlevel & PERM_ANGEL)
+ && !angel_reject_me(&SHM->uinfo[SHM->sorted[j][0][i - 1]]) ){
+ strlcpy(cuser.myangel, SHM->uinfo[SHM->sorted[j][0][i - 1]].userid, IDLEN + 1);
+ passwd_update(usernum, &cuser);
+ return 1;
+ }
+ }while(++trial < 5);
+ return 0;
+}
+
+static inline void
+GotoNewHand(){
+ char old_board[IDLEN + 1] = "";
+ int canRead = 1;
+
+ if (currutmp && currutmp->mode == EDITING)
+ return;
+
+ // usually crashed as 'assert(currbid == brc_currbid)'
+ if (currboard[0]) {
+ strlcpy(old_board, currboard, IDLEN + 1);
+ currboard = "";// force enter_board
+ }
+
+ if (enter_board(BN_NEWBIE) == 0)
+ canRead = 1;
+
+ if (canRead)
+ Read();
+
+ if (canRead && old_board[0])
+ enter_board(old_board);
+}
+
+
+static inline void
+NoAngelFound(const char* msg){
+ move(b_lines, 0);
+ outs(msg);
+ if (currutmp == NULL || currutmp->mode != EDITING)
+ outs(",請先在新手板上尋找答案或按 Ctrl-P 發問");
+ clrtoeol();
+ refresh();
+ sleep(1);
+ GotoNewHand();
+ return;
+}
+
+static inline void
+AngelNotOnline(){
+ char buf[PATHLEN] = "";
+ const static char* const not_online_message = "您的小天使現在不在線上";
+
+ // TODO cache angel's nick name!
+
+ if (cuser.myangel[0] != '-')
+ sethomefile(buf, cuser.myangel, "angelmsg");
+ if (cuser.myangel[0] == '-' || !dashf(buf))
+ NoAngelFound(not_online_message);
+ else {
+ time4_t mod = dasht(buf);
+ FILE* fp = fopen(buf, "r");
+ clear();
+ showtitle("小天使留言", BBSNAME);
+ move(4, 0);
+ buf[0] = 0;
+ fgets(buf, sizeof(buf), fp);
+ if (strncmp(buf, "%%[", 3) == 0) {
+ chomp(buf);
+ prints("您的%s小天使現在不在線上", buf + 3);
+ fgets(buf, sizeof(buf), fp);
+ } else
+ outs(not_online_message);
+
+ outs("\n祂留言給你:\n");
+ outs(ANSI_COLOR(1;31;44) "☉┬──────────────┤" ANSI_COLOR(37) ""
+ "小天使留言" ANSI_COLOR(31) "├──────────────┬☉" ANSI_RESET "\n");
+ outs(ANSI_COLOR(1;31) "╭┤" ANSI_COLOR(32) " 小天使 "
+ " " ANSI_COLOR(31) "├╮" ANSI_RESET "\n");
+ do {
+ chomp(buf);
+ prints(ANSI_COLOR(1;31) "│" ANSI_RESET "%-74.74s" ANSI_COLOR(1;31) "│" ANSI_RESET "\n", buf);
+ } while (fgets(buf, sizeof(buf), fp));
+
+ outs(ANSI_COLOR(1;31) "╰┬──────────────────────"
+ "─────────────┬╯" ANSI_RESET "\n");
+ outs(ANSI_COLOR(1;31;44) "☉┴─────────────────────"
+ "──────────────┴☉" ANSI_RESET "\n");
+ prints("%55s%s", "留言日期: ", Cdatelite(&mod));
+
+
+ move(b_lines - 4, 0);
+ outs("小主人使用上問題找不到小天使請到新手版(" BN_NEWBIE ")\n"
+ " 想留言給小天使請到許\願版(AngelPray)\n"
+ " 想找看板在哪的話可到(AskBoard)\n"
+ "請先在各板上尋找答案或按 Ctrl-P 發問");
+ pressanykey();
+
+ GotoNewHand();
+ }
+}
+
+static void
+TalkToAngel(){
+ static int AngelPermChecked = 0;
+ userinfo_t* uent;
+ userec_t xuser;
+
+ if (strcmp(cuser.myangel, "-") == 0){
+ AngelNotOnline();
+ return;
+ }
+
+ if (cuser.myangel[0] && !AngelPermChecked) {
+ getuser(cuser.myangel, &xuser); // XXX if user doesn't exist
+ if (!(xuser.userlevel & PERM_ANGEL))
+ cuser.myangel[0] = 0;
+ }
+ AngelPermChecked = 1;
+
+ if (cuser.myangel[0] == 0 && ! FindAngel()){
+ NoAngelFound("現在沒有小天使在線上");
+ return;
+ }
+
+ uent = search_ulist_userid(cuser.myangel);
+ if (uent == 0 || uent->angelpause || angel_reject_me(uent)){
+ AngelNotOnline();
+ return;
+ }
+
+ more("etc/angel_usage", NA);
+
+ /* 這段話或許可以在小天使回答問題時 show 出來
+ move(b_lines - 1, 0);
+ outs("現在你的id受到保密,回答你問題的小天使並不知道你是誰 \n"
+ "你可以選擇不向對方透露自己身份來保護自己 ");
+ */
+
+ my_write(uent->pid, "問小天使: ", "小天使", WATERBALL_ANGEL, uent);
+ return;
+}
+
+void
+CallAngel(){
+ static int entered = 0;
+ screen_backup_t old_screen;
+
+ if (!HasUserPerm(PERM_LOGINOK) || entered)
+ return;
+ entered = 1;
+
+ scr_dump(&old_screen);
+
+ TalkToAngel();
+
+ scr_restore(&old_screen);
+
+ entered = 0;
+}
+
+#endif // PLAY_ANGEL
diff --git a/mbbsd/talk.c b/mbbsd/talk.c
index 1a3cd5b9..013aca6b 100644
--- a/mbbsd/talk.c
+++ b/mbbsd/talk.c
@@ -224,18 +224,6 @@ set_friend_bit(const userinfo_t * me, const userinfo_t * ui)
return hit;
}
-inline int
-he_reject_me(userinfo_t * uin){
- int* iter = uin->reject;
- int unum;
- while ((unum = *iter++)) {
- if (unum == currutmp->uid) {
- return 1;
- }
- }
- return 0;
-}
-
int
reverse_friend_stat(int stat)
{
@@ -855,8 +843,9 @@ my_write(pid_t pid, const char *prompt, const char *id, int flag, userinfo_t * p
#ifdef PLAY_ANGEL
&& flag != WATERBALL_ANGEL && flag != WATERBALL_CONFIRM_ANGEL) ||
// check if user is changed of angelpause.
+ // XXX if flag == WATERBALL_ANGEL, shuold be (uin->angelpause) only.
((flag == WATERBALL_ANGEL || flag == WATERBALL_CONFIRM_ANGEL)
- && (strcasecmp(cuser.myangel, uin->userid) || uin->angelpause)
+ && (strcasecmp(cuser.myangel, uin->userid) || uin->angelpause >= ANGELPAUSE_REJALL)
#endif
)) {
bell();
@@ -904,7 +893,7 @@ my_write(pid_t pid, const char *prompt, const char *id, int flag, userinfo_t * p
!(fri_stat & HFM))))
#ifdef PLAY_ANGEL
|| ((flag == WATERBALL_ANGEL || flag == WATERBALL_CONFIRM_ANGEL)
- && he_reject_me(uin))
+ && angel_reject_me(uin))
#endif
) {
outmsg(ANSI_COLOR(1;33;41) "糟糕! 對方防水了! " ANSI_COLOR(37) "~>_<~" ANSI_RESET);
@@ -2330,18 +2319,23 @@ draw_pickup(int drawall, pickup_t * pickup, int pickup_way,
#ifdef PLAY_ANGEL
if (HasUserPerm(PERM_ANGEL) && currutmp)
{
+ // modes should match ANGELPAUSE*
+ static const char *modestr[ANGELPAUSE_MODES] = {
+ ANSI_COLOR(1;30;47) "[神諭呼叫器]" ANSI_COLOR(0;30;47)
+ " 開放 " ANSI_RESET,
+ ANSI_COLOR(1;30;47) "[神諭呼叫器]" ANSI_COLOR(0;32;47)
+ " 停收 " ANSI_RESET,
+ ANSI_COLOR(1;30;47) "[神諭呼叫器]" ANSI_COLOR(0;31;47)
+ " 關閉 " ANSI_RESET,
+ };
// reduced version
outslr(
ANSI_COLOR(34;46) " 休閒聊天 "
ANSI_COLOR(31;47) " (TAB/f)" ANSI_COLOR(30) "排序/好友 "
- ANSI_COLOR(31) "(p)" ANSI_COLOR(30) "切換呼叫器 "
- ANSI_COLOR(31) "(^P)" ANSI_COLOR(30) "切換天使狀態 ",
- 59,
- currutmp->angelpause ?
- ANSI_COLOR(1;30;47) "[神諭呼叫器]" ANSI_COLOR(0;31;47)
- " 關閉 " ANSI_RESET:
- ANSI_COLOR(1;30;47) "[神諭呼叫器]" ANSI_COLOR(0;30;47)
- " 開啟 " ANSI_RESET,
+ ANSI_COLOR(31) "(p)" ANSI_COLOR(30) "一般呼叫器 "
+ ANSI_COLOR(31) "(^P)" ANSI_COLOR(30) "神諭呼叫器 ",
+ 57,
+ modestr[currutmp->angelpause % ANGELPAUSE_MODES],
18);
} else
#endif
@@ -3011,11 +3005,15 @@ userlist(void)
#ifdef PLAY_ANGEL
case Ctrl('P'):
if (HasUserPerm(PERM_ANGEL) && currutmp) {
- currutmp->angelpause = !currutmp->angelpause;
- bell();
- vmsg(currutmp->angelpause ?
- " 停止接受小主人的問題 | X | " :
- " 開始接受小主人發問 | ● | ");
+ /*
+ static const char *msgs[ANGELPAUSE_MODES] = {
+ " 接受所有小主人發問 [●] ",
+ " 只接受已發問的小主人的問題 [△] ",
+ " 停止接受所有小主人的問題 [X] ",
+ };
+ */
+ angel_toggle_pause();
+ // vmsg(msgs[currutmp->angelpause]);
redrawall = redraw = 1;
}
break;
@@ -3395,287 +3393,3 @@ talkreply(void)
currstat = currstat0;
}
-#ifdef PLAY_ANGEL
-/* 小天使小主人處理函式 */
-int
-t_changeangel(){
- char buf[4];
-
- /* cuser.myangel == "-" means banned for calling angel */
- if (cuser.myangel[0] == '-' || cuser.myangel[1] == 0) return 0;
-
- getdata(b_lines - 1, 0,
- "更換小天使後就無法換回了喔! 是否要更換小天使? [y/N]",
- buf, 3, LCECHO);
- if (buf[0] == 'y' || buf[0] == 'Y') {
- char buf[100];
- snprintf(buf, sizeof(buf), "%s小主人 %s 換掉 %s 小天使\n",
- ctime4(&now), cuser.userid, cuser.myangel);
- buf[24] = ' '; // replace '\n'
- log_file(BBSHOME "/log/changeangel.log", LOG_CREAT, buf);
-
- cuser.myangel[0] = 0;
- outs("小天使更新完成,下次呼叫時會選出新的小天使");
- }
- return XEASY;
-}
-
-int t_angelmsg(){
- char msg[3][74] = { "", "", "" };
- char nick[10] = "";
- char buf[512];
- int i;
- FILE* fp;
-
- setuserfile(buf, "angelmsg");
- fp = fopen(buf, "r");
- if (fp) {
- i = 0;
- if (fgets(msg[0], sizeof(msg[0]), fp)) {
- chomp(msg[0]);
- if (strncmp(msg[0], "%%[", 3) == 0) {
- strlcpy(nick, msg[0] + 3, 7);
- move(4, 0);
- prints("原有暱稱:%s小天使", nick);
- msg[0][0] = 0;
- } else
- i = 1;
- } else
- msg[0][0] = 0;
-
- move(5, 0);
- outs("原有留言:\n");
- if(msg[0][0])
- outs(msg[0]);
- for (; i < 3; ++i) {
- if(fgets(msg[i], sizeof(msg[0]), fp)) {
- outs(msg[i]);
- chomp(msg[i]);
- } else
- break;
- }
- fclose(fp);
- }
-
- getdata_buf(11, 0, "小天使暱稱:", nick, 7, 1);
- do {
- move(12, 0);
- clrtobot();
- outs("不在的時候要跟小主人說什麼呢?"
- "最多三行,按[Enter]結束");
- for (i = 0; i < 3 &&
- getdata_buf(14 + i, 0, ":", msg[i], sizeof(msg[i]), DOECHO);
- ++i);
- getdata(b_lines - 2, 0, "(S)儲存 (E)重新來過 (Q)取消?[S]",
- buf, 4, LCECHO);
- } while (buf[0] == 'E' || buf[0] == 'e');
- if (buf[0] == 'Q' || buf[0] == 'q')
- return 0;
- setuserfile(buf, "angelmsg");
- if (msg[0][0] == 0)
- unlink(buf);
- else {
- FILE* fp = fopen(buf, "w");
- if(nick[0])
- fprintf(fp, "%%%%[%s\n", nick);
- for (i = 0; i < 3 && msg[i][0]; ++i) {
- fputs(msg[i], fp);
- fputc('\n', fp);
- }
- fclose(fp);
- }
- return 0;
-}
-
-static int
-FindAngel(void){
- int nAngel;
- int i, j;
- int choose;
- int trial = 0;
- int mask;
-
- if (cuser.sex < 6) /* 正常性別 */
- mask = 1 | (2 << (cuser.sex & 1));
- else
- mask = 7;
-
- do{
- nAngel = 0;
- j = SHM->currsorted;
- for (i = 0; i < SHM->UTMPnumber; ++i)
- if (SHM->uinfo[SHM->sorted[j][0][i]].userlevel & PERM_ANGEL)
- ++nAngel;
-
- if (nAngel == 0)
- return 0;
-
- choose = random() % nAngel + 1;
- j = SHM->currsorted;
- for (i = 0; i < SHM->UTMPnumber && choose; ++i)
- if (SHM->uinfo[SHM->sorted[j][0][i]].userlevel & PERM_ANGEL)
- --choose;
-
- if (choose == 0 && SHM->uinfo[SHM->sorted[j][0][i - 1]].uid != currutmp->uid
- && (SHM->uinfo[SHM->sorted[j][0][i - 1]].userlevel & PERM_ANGEL)
- && !he_reject_me(&SHM->uinfo[SHM->sorted[j][0][i - 1]]) ){
- strlcpy(cuser.myangel, SHM->uinfo[SHM->sorted[j][0][i - 1]].userid, IDLEN + 1);
- passwd_update(usernum, &cuser);
- return 1;
- }
- }while(++trial < 5);
- return 0;
-}
-
-static inline void
-GotoNewHand(){
- char old_board[IDLEN + 1] = "";
- int canRead = 1;
-
- if (currutmp && currutmp->mode == EDITING)
- return;
-
- // usually crashed as 'assert(currbid == brc_currbid)'
- if (currboard[0]) {
- strlcpy(old_board, currboard, IDLEN + 1);
- currboard = "";// force enter_board
- }
-
- if (enter_board(BN_NEWBIE) == 0)
- canRead = 1;
-
- if (canRead)
- Read();
-
- if (canRead && old_board[0])
- enter_board(old_board);
-}
-
-
-static inline void
-NoAngelFound(const char* msg){
- move(b_lines, 0);
- outs(msg);
- if (currutmp == NULL || currutmp->mode != EDITING)
- outs(",請先在新手板上尋找答案或按 Ctrl-P 發問");
- clrtoeol();
- refresh();
- sleep(1);
- GotoNewHand();
- return;
-}
-
-static inline void
-AngelNotOnline(){
- char buf[PATHLEN] = "";
- const static char* const not_online_message = "您的小天使現在不在線上";
-
- // TODO cache angel's nick name!
-
- if (cuser.myangel[0] != '-')
- sethomefile(buf, cuser.myangel, "angelmsg");
- if (cuser.myangel[0] == '-' || !dashf(buf))
- NoAngelFound(not_online_message);
- else {
- time4_t mod = dasht(buf);
- FILE* fp = fopen(buf, "r");
- clear();
- showtitle("小天使留言", BBSNAME);
- move(4, 0);
- buf[0] = 0;
- fgets(buf, sizeof(buf), fp);
- if (strncmp(buf, "%%[", 3) == 0) {
- chomp(buf);
- prints("您的%s小天使現在不在線上", buf + 3);
- fgets(buf, sizeof(buf), fp);
- } else
- outs(not_online_message);
-
- outs("\n祂留言給你:\n");
- outs(ANSI_COLOR(1;31;44) "☉┬──────────────┤" ANSI_COLOR(37) ""
- "小天使留言" ANSI_COLOR(31) "├──────────────┬☉" ANSI_RESET "\n");
- outs(ANSI_COLOR(1;31) "╭┤" ANSI_COLOR(32) " 小天使 "
- " " ANSI_COLOR(31) "├╮" ANSI_RESET "\n");
- do {
- chomp(buf);
- prints(ANSI_COLOR(1;31) "│" ANSI_RESET "%-74.74s" ANSI_COLOR(1;31) "│" ANSI_RESET "\n", buf);
- } while (fgets(buf, sizeof(buf), fp));
-
- outs(ANSI_COLOR(1;31) "╰┬──────────────────────"
- "─────────────┬╯" ANSI_RESET "\n");
- outs(ANSI_COLOR(1;31;44) "☉┴─────────────────────"
- "──────────────┴☉" ANSI_RESET "\n");
- prints("%55s%s", "留言日期: ", Cdatelite(&mod));
-
-
- move(b_lines - 4, 0);
- outs("小主人使用上問題找不到小天使請到新手版(" BN_NEWBIE ")\n"
- " 想留言給小天使請到許\願版(AngelPray)\n"
- " 想找看板在哪的話可到(AskBoard)\n"
- "請先在各板上尋找答案或按 Ctrl-P 發問");
- pressanykey();
-
- GotoNewHand();
- }
-}
-
-static void
-TalkToAngel(){
- static int AngelPermChecked = 0;
- userinfo_t* uent;
- userec_t xuser;
-
- if (strcmp(cuser.myangel, "-") == 0){
- AngelNotOnline();
- return;
- }
-
- if (cuser.myangel[0] && !AngelPermChecked) {
- getuser(cuser.myangel, &xuser); // XXX if user doesn't exist
- if (!(xuser.userlevel & PERM_ANGEL))
- cuser.myangel[0] = 0;
- }
- AngelPermChecked = 1;
-
- if (cuser.myangel[0] == 0 && ! FindAngel()){
- NoAngelFound("現在沒有小天使在線上");
- return;
- }
-
- uent = search_ulist_userid(cuser.myangel);
- if (uent == 0 || uent->angelpause || he_reject_me(uent)){
- AngelNotOnline();
- return;
- }
-
- more("etc/angel_usage", NA);
-
- /* 這段話或許可以在小天使回答問題時 show 出來
- move(b_lines - 1, 0);
- outs("現在你的id受到保密,回答你問題的小天使並不知道你是誰 \n"
- "你可以選擇不向對方透露自己身份來保護自己 ");
- */
-
- my_write(uent->pid, "問小天使: ", "小天使", WATERBALL_ANGEL, uent);
- return;
-}
-
-void
-CallAngel(){
- static int entered = 0;
- screen_backup_t old_screen;
-
- if (!HasUserPerm(PERM_LOGINOK) || entered)
- return;
- entered = 1;
-
- scr_dump(&old_screen);
-
- TalkToAngel();
-
- scr_restore(&old_screen);
-
- entered = 0;
-}
-
-#endif
diff --git a/mbbsd/user.c b/mbbsd/user.c
index 29937606..fb158ea0 100644
--- a/mbbsd/user.c
+++ b/mbbsd/user.c
@@ -429,10 +429,15 @@ void Customize(void)
#ifdef PLAY_ANGEL
if (HasUserPerm(PERM_ANGEL))
{
+ static const char *msgs[ANGELPAUSE_MODES] = {
+ "開放 (接受所有小主人發問)",
+ "停收 (只接受已回應過的小主人的問題)",
+ "關閉 (停止接受所有小主人的問題)",
+ };
prints("%c. %-40s%s\n",
'1' + iax++,
- "開放小主人詢問",
- (currutmp->angelpause ? "否" : "是"));
+ "小天使神諭呼叫器",
+ msgs[currutmp->angelpause % ANGELPAUSE_MODES]);
}
#endif // PLAY_ANGEL
}
@@ -495,9 +500,8 @@ void Customize(void)
if( HasUserPerm(PERM_ANGEL) ){
if (key == iax-1)
{
- // SwitchBeingAngel();
- currutmp->angelpause = !currutmp->angelpause;
- // dirty = 1; // pure utmp change can prevent pw dirty
+ angel_toggle_pause();
+ // dirty = 1; // pure utmp change does not need pw dirty
continue;
}
}