diff options
-rw-r--r-- | include/proto.h | 8 | ||||
-rw-r--r-- | mbbsd/assess.c | 33 | ||||
-rw-r--r-- | mbbsd/bbs.c | 14 | ||||
-rw-r--r-- | mbbsd/talk.c | 21 |
4 files changed, 49 insertions, 27 deletions
diff --git a/include/proto.h b/include/proto.h index 1ca98489..3cc3ed4c 100644 --- a/include/proto.h +++ b/include/proto.h @@ -35,10 +35,10 @@ void initsetproctitle(int argc, char **argv, char **envp); void setproctitle(const char* format, ...) GCC_CHECK_FORMAT(1,2); /* assess */ -void inc_goodpost(int uid); -void inc_badpost(int uid); -void inc_goodsale(int uid); -void inc_badsale(int uid); +void inc_goodpost(int uid, int num); +void inc_badpost(int uid, int num); +void inc_goodsale(int uid, int num); +void inc_badsale(int uid, int num); void set_assess(int uid, unsigned char num, int type); /* bbcall */ diff --git a/mbbsd/assess.c b/mbbsd/assess.c index cc5e84b1..02498263 100644 --- a/mbbsd/assess.c +++ b/mbbsd/assess.c @@ -1,36 +1,47 @@ #include "bbs.h" -inline static void inc(unsigned char *num) + +inline static void inc(unsigned char *num, int n) +{ + if (SALE_MAXVALUE - *num >= n) + (*num) += n; + else + (*num) = SALE_MAXVALUE; +} + +inline static void dec(unsigned char *num, int n) { - if (*num < SALE_MAXVALUE) - (*num)++; + if (*num < n) + (*num) -= n; + else + (*num) = 0; } -void inc_goodpost(int uid) +void inc_goodpost(int uid, int num) { passwd_query(uid, &xuser); - inc(&xuser.goodpost); + inc(&xuser.goodpost, num); passwd_update(uid, &xuser); } -void inc_badpost(int uid) +void inc_badpost(int uid, int num) { passwd_query(uid, &xuser); - inc(&xuser.badpost); + inc(&xuser.badpost, num); passwd_update(uid, &xuser); } -void inc_goodsale(int uid) +void inc_goodsale(int uid, int num) { passwd_query(uid, &xuser); - inc(&xuser.goodsale); + inc(&xuser.goodsale, num); passwd_update(uid, &xuser); } -void inc_badsale(int uid) +void inc_badsale(int uid, int num) { passwd_query(uid, &xuser); - inc(&xuser.badsale); + inc(&xuser.badsale, num); passwd_update(uid, &xuser); } diff --git a/mbbsd/bbs.c b/mbbsd/bbs.c index 3ed870ed..eb4c627d 100644 --- a/mbbsd/bbs.c +++ b/mbbsd/bbs.c @@ -1417,10 +1417,10 @@ do_bid(int ent, fileheader_t * fhdr, boardheader_t *bp, char *direct, struct t if ('1' <= tmp && tmp <= '3'){ switch(tmp){ case 1: - inc_goodsale(currutmp->uid); + inc_goodsale(currutmp->uid, 1); break; case 2: - inc_badpost(currutmp->uid); + inc_badpost(currutmp->uid, 1); break; } bidinfo.flag |= SALE_COMMENTED; @@ -1581,7 +1581,7 @@ recommend(int ent, fileheader_t * fhdr, char *direct) do_add_recommend(direct, fhdr, ent, buf); /* 每 10 次推文 加一次 goodpost */ if ((fhdr->filemode & FILE_MARKED) && fhdr->recommend % 10 == 0) - inc_goodpost(searchuser(fhdr->owner)); + inc_goodpost(searchuser(fhdr->owner), 1); lastrecommend = now; return FULLUPDATE; } @@ -1601,6 +1601,12 @@ mark_post(int ent, fileheader_t * fhdr, char *direct) return DONOTHING; fhdr->filemode ^= FILE_MARKED; + + if (fhdr->filemode) + inc_goodpost(searchuser(fhdr->owner), fhdr->recommend); + else + inc_badpost(searchuser(fhdr->owner), fhdr->recommend); + substitute_record(direct, fhdr, sizeof(*fhdr), ent); substitute_check(fhdr); touchdircache(currbid); @@ -1726,7 +1732,7 @@ del_post(int ent, fileheader_t * fhdr, char *direct) delete_file(genbuf, sizeof(fileheader_t), num, cmpfilename); } if (not_owned) - inc_badpost(searchuser(fhdr->owner)); + inc_badpost(searchuser(fhdr->owner), 1); cancelpost(fhdr, not_owned); setbtotal(currbid); diff --git a/mbbsd/talk.c b/mbbsd/talk.c index d53e1618..b1a3d712 100644 --- a/mbbsd/talk.c +++ b/mbbsd/talk.c @@ -346,20 +346,24 @@ my_query(char *uident) setutmpmode(TQUERY); currutmp->destuid = tuid; + if ((uentp = (userinfo_t *) search_ulist(tuid))) + fri_stat = friend_stat(currutmp, uentp); + j = muser.money; for (i = 0; i < 10 && j > 10; i++) j /= 10; - prints("《ID暱稱》%s(%s)%*s《經濟狀況》%s\n", + prints("《ID暱稱》%s(%s)%*s《經濟狀況》%s", muser.userid, muser.username, 26 - strlen(muser.userid) - strlen(muser.username), "", money[i]); + if ((uentp && ((fri_stat & HFM) || strcmp(muser.userid,cuser.userid) == 0) && !uentp->invisible)) + prints(" (%d)", muser.money); + prints("\n"); prints("《上站次數》%d次", muser.numlogins); move(2, 40); prints("《文章篇數》%d篇\n", muser.numposts); - if ((uentp = (userinfo_t *) search_ulist(tuid))) - fri_stat = friend_stat(currutmp, uentp); prints("\033[1;33m《目前動態》%-28.28s\033[m", (uentp && isvisible_stat(currutmp, uentp, fri_stat)) ? modestring(uentp, 0) : "不在站上"); @@ -370,14 +374,15 @@ my_query(char *uident) prints("《上次上站》%-28.28s《上次故鄉》%s\n", Cdate(&muser.lastlogin), (muser.lasthost[0] ? muser.lasthost : "(不詳)")); - if ((uentp && ((fri_stat & HFM) || strcmp(muser.userid,cuser.userid) == 0) && !uentp->invisible)) - prints("《 性 別 》%-28.28s《私有財產》%d 銀兩\n", - sex[muser.sex % 8], - muser.money); + prints("《文章評比》 優 %-3d 劣 %-3d 《競標評比》 優 %-3d 劣 %-3d\n", + muser.goodpost, muser.badpost, + muser.goodsale, muser.badsale); prints("《五子棋戰績》%3d 勝 %3d 敗 %3d 和 " - "《象棋戰績》%3d 勝 %3d 敗 %3d 和", + "《象棋戰績》%3d 勝 %3d 敗 %3d 和\n", muser.five_win, muser.five_lose, muser.five_tie, muser.chc_win, muser.chc_lose, muser.chc_tie); + if ((uentp && ((fri_stat & HFM) || strcmp(muser.userid,cuser.userid) == 0) && !uentp->invisible)) + prints("《 性 別 》%-28.28s\n", sex[muser.sex % 8]); showplans(uident); pressanykey(); return FULLUPDATE; |