summaryrefslogtreecommitdiffstats
path: root/mbbsd/talk.c
diff options
context:
space:
mode:
authorpiaip <piaip@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2008-04-02 14:41:31 +0800
committerpiaip <piaip@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2008-04-02 14:41:31 +0800
commit702edad799fc813d84a29673de87d7e58854ed39 (patch)
tree4c5792a97bb89ea4161c6a693ac6b7c29df64f50 /mbbsd/talk.c
parentc9def28ad0172a5066e63bef771cfd1c325a9e40 (diff)
downloadpttbbs-702edad799fc813d84a29673de87d7e58854ed39.tar
pttbbs-702edad799fc813d84a29673de87d7e58854ed39.tar.gz
pttbbs-702edad799fc813d84a29673de87d7e58854ed39.tar.bz2
pttbbs-702edad799fc813d84a29673de87d7e58854ed39.tar.lz
pttbbs-702edad799fc813d84a29673de87d7e58854ed39.tar.xz
pttbbs-702edad799fc813d84a29673de87d7e58854ed39.tar.zst
pttbbs-702edad799fc813d84a29673de87d7e58854ed39.zip
- angel system: extend pager modes to 3 types (accept, reject new, reject all)
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@4064 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'mbbsd/talk.c')
-rw-r--r--mbbsd/talk.c336
1 files changed, 25 insertions, 311 deletions
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