summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mbbsd/Makefile2
-rw-r--r--mbbsd/bbs.c2
-rw-r--r--mbbsd/mail.c53
-rw-r--r--mbbsd/talk.c64
4 files changed, 85 insertions, 36 deletions
diff --git a/mbbsd/Makefile b/mbbsd/Makefile
index 2e5637ab..3be108ad 100644
--- a/mbbsd/Makefile
+++ b/mbbsd/Makefile
@@ -21,7 +21,7 @@ OBJS= admin.o announce.o args.o assess.o bbs.o board.o cache.o cal.o card.o\
OBJS+= random.o time.o
DIETCC= diet -Os
.endif
-#CFLAGS+=-g
+CFLAGS+=-std=c99
# reduce .bss align overhead
.if !defined(DEBUG)
diff --git a/mbbsd/bbs.c b/mbbsd/bbs.c
index dad56f0a..fac9c21a 100644
--- a/mbbsd/bbs.c
+++ b/mbbsd/bbs.c
@@ -1173,6 +1173,8 @@ edit_post(int ent, fileheader_t * fhdr, const char *direct)
fp = fopen(fpath, "at");
src = fopen(genbuf, "rt");
+ FILE *xp = NULL;
+
if(!fp)
{
vmsg("抱歉,檔案已損毀。");
diff --git a/mbbsd/mail.c b/mbbsd/mail.c
index c9e2011e..7acc84fe 100644
--- a/mbbsd/mail.c
+++ b/mbbsd/mail.c
@@ -893,28 +893,40 @@ m_new(void)
static void
mailtitle(void)
{
- char buf[256];
+ char buf[STRLEN];
+ int msglen = 0;
showtitle("郵件選單", BBSName);
prints("[←]離開[↑↓]選擇[→]閱\讀信件 [R]回信 [x]轉達 "
- "[y]群組回信 [O]站外信:%s [h]求助\n" ANSI_COLOR(7) ""
- " 編號 %s 作 者 信 件 標 題 "
- ANSI_COLOR(32) "",
+ "[y]群組回信 [O]站外信:%s [h]求助\n"
+ ANSI_COLOR(7) " 編號 %s 作 者 信 件 標 題"
+ "",
REJECT_OUTTAMAIL ? ANSI_COLOR(31) "關" ANSI_RESET : "開",
(showmail_mode == SHOWMAIL_SUM) ? "大 小":"日 期");
+
+ /* 43 columns in length, used later. */
buf[0] = 0;
- if (mailsumlimit) {
- snprintf(buf, sizeof(buf),
- "(容量:%d/%dk %d/%d篇)", mailsum, mailsumlimit,
+
+ if (mailsumlimit)
+ {
+ /* warning: snprintf returns length "if not limited".
+ * however if this case, they should be the same. */
+
+ msglen = snprintf(buf, sizeof(buf),
+ ANSI_COLOR(32)
+ " (容量:%d/%dk %d/%d篇) ",
+ mailsum, mailsumlimit,
mailkeep, mailmaxkeep);
+ msglen -= strlen(ANSI_COLOR(32));
}
- prints("%-29s" ANSI_RESET, buf);
+ outslr("", 44, buf, msglen);
+ outs(ANSI_RESET);
}
static void
maildoent(int num, fileheader_t * ent)
{
- char *title, *mark, color, type = "+ Mm"[(ent->filemode & 3)];
+ char *title, *mark, *color = NULL, type = "+ Mm"[(ent->filemode & 3)];
char datepart[6];
if (TagNum && !Tagger(atoi(ent->filename + 2), 0, TAG_NIN))
@@ -922,10 +934,10 @@ maildoent(int num, fileheader_t * ent)
title = subject(mark = ent->title);
if (title == mark) {
- color = '1';
+ color = ANSI_COLOR(1;31);
mark = "◇";
} else {
- color = '3';
+ color = ANSI_COLOR(1;33);
mark = "R:";
}
@@ -966,13 +978,18 @@ maildoent(int num, fileheader_t * ent)
break;
}
- if (strncmp(currtitle, title, TTLEN))
- prints("%6d %c %-6s%-15.14s%s %.46s\n", num, type,
- datepart, ent->owner, mark, title);
- else
- prints("%6d %c %-6s%-15.14s" ANSI_COLOR(1;3%c)
- "%s %.46s" ANSI_COLOR(0) "\n", num, type,
- datepart, ent->owner, color, mark, title);
+ /* print out */
+ if (strncmp(currtitle, title, TTLEN) != 0)
+ {
+ /* is title. */
+ color = "";
+ }
+
+ prints("%6d %c %-6s%-15.14s%s %s%-*.*s%s\n",
+ num, type, datepart, ent->owner, mark, color,
+ t_columns - 34, t_columns - 34,
+ title,
+ *color ? ANSI_RESET : "");
}
diff --git a/mbbsd/talk.c b/mbbsd/talk.c
index 3cdf126f..316739a2 100644
--- a/mbbsd/talk.c
+++ b/mbbsd/talk.c
@@ -122,8 +122,8 @@ modestring(const userinfo_t * uentp, int simple)
)
if (uentp->msgcount < 10) {
const char *cnum[10] =
- {"", "一", "兩", "三", "四", "五", "六", "七",
- "八", "九"};
+ {"", "一", "兩", "三", "四", "五",
+ "六", "七", "八", "九"};
snprintf(modestr, sizeof(modestr),
"中%s顆水球", cnum[(int)(uentp->msgcount)]);
} else
@@ -2035,38 +2035,63 @@ draw_pickup(int drawall, pickup_t * pickup, int pickup_way,
userinfo_t *uentp;
int i, ch, state, friend;
char mind[5];
+
#ifdef SHOW_IDLE_TIME
char idlestr[32];
int idletime;
#endif
+ /* wide screen support */
+ int wNick = 17, wMode = 12; //13; , one byte give number for ptt always > 10000 online.
+
+ if (t_columns > 80)
+ {
+ int d = t_columns - 80;
+
+ /* rule: try to give extra space to both nick and mode,
+ * because nick is smaller, try nick first then mode. */
+ if (d >= sizeof(cuser.nickname) - wNick)
+ {
+ d -= (sizeof(cuser.nickname) - wNick);
+ wNick = sizeof(cuser.nickname);
+ wMode += d;
+ } else {
+ wNick += d;
+ }
+ }
+
if (drawall) {
showtitle((cuser.uflag & FRIEND_FLAG) ? "好友列表" : "休閒聊天",
BBSName);
prints("\n"
- ANSI_COLOR(7) " %s P%c代號 %-17s%-17s%-13s%-10s" ANSI_RESET "\n",
+ ANSI_COLOR(7) " %s P%c代號 %-*s%-17s%-*s%10s"
+ ANSI_RESET "\n",
show_uid ? "UID " : "編號",
- (HasUserPerm(PERM_SEECLOAK) || HasUserPerm(PERM_SYSOP)) ? 'C' : ' ',
- "暱稱",
+ (HasUserPerm(PERM_SEECLOAK) || HasUserPerm(PERM_SYSOP)) ?
+ 'C' : ' ',
+ wNick, "暱稱",
MODE_STRING[show_mode],
- show_board ? "Board" : "動態",
- show_pid ? " PID" : "心情 發呆"
+ wMode, show_board ? "Board" : "動態",
+ show_pid ? " PID" : "心情 "
+#ifdef SHOW_IDLE_TIME
+ "發呆"
+#else
+ " "
+#endif
);
move(b_lines, 0);
outslr(
ANSI_COLOR(34;46) " 休閒聊天 "
ANSI_COLOR(31;47) " (TAB/f)" ANSI_COLOR(30) "排序/好友 "
- ANSI_COLOR(31) "(t)" ANSI_COLOR(30) "聊天 "
- ANSI_COLOR(31) "(a/d/o)" ANSI_COLOR(30) "交友 "
- ANSI_COLOR(31) "(q)" ANSI_COLOR(30) "查詢 "
- ANSI_COLOR(31) "(w)" ANSI_COLOR(30) "水球 "
- ANSI_COLOR(31) "(m)" ANSI_COLOR(30) "寄信 ",
- 80-8,
+ ANSI_COLOR(31) "(a/o)" ANSI_COLOR(30) "交友 "
+ ANSI_COLOR(31) "(q/w)" ANSI_COLOR(30) "查詢/丟水球 "
+ ANSI_COLOR(31) "(t/m)" ANSI_COLOR(30) "聊天/寫信 ",
+ 80-10,
ANSI_COLOR(31) "(h)" ANSI_COLOR(30) "說明 " ANSI_RESET,
8);
}
move(1, 0);
- prints(" 排序:[%s] 上站人數:%-4d "
+ prints(" 排序:[%s] 上站人數:%-4d "
ANSI_COLOR(1;32) "我的朋友:%-3d "
ANSI_COLOR(33) "與我為友:%-3d "
ANSI_COLOR(36) "板友:%-4d "
@@ -2074,6 +2099,7 @@ draw_pickup(int drawall, pickup_t * pickup, int pickup_way,
ANSI_RESET "\n",
msg_pickup_way[pickup_way], SHM->UTMPnumber,
myfriend, friendme, currutmp->brc_id ? bfriend : 0, badfriend);
+
for (i = 0, ch = page * nPickups + 1; i < nPickups; ++i, ++ch) {
move(i + 3, 0);
outc('a');
@@ -2118,7 +2144,11 @@ draw_pickup(int drawall, pickup_t * pickup, int pickup_way,
else
memcpy(mind, uentp->mind, 4);
mind[4] = 0;
- prints("%6d %c%c%s%-13s%-17.16s" ANSI_RESET "%-17.16s%-13.13s"
+
+ /* TODO
+ * will this be faster if we use pure outc/outs?
+ */
+ prints("%7d %c%c%s%-13s%-*.*s " ANSI_RESET "%-16.16s %-*.*s"
ANSI_COLOR(33) "%-4.4s" ANSI_RESET "%s\n",
/* list number or uid */
@@ -2137,18 +2167,18 @@ draw_pickup(int drawall, pickup_t * pickup, int pickup_way,
fcolor[state], uentp->userid,
/* nickname */
- uentp->nickname,
+ wNick-1, wNick-1, uentp->nickname,
/* from */
descript(show_mode, uentp,
uentp->pager & !(friend & HRM)),
/* board or mode */
+ wMode, wMode,
#if defined(SHOWBOARD) && defined(DEBUG)
show_board ? (uentp->brc_id == 0 ? "" :
getbcache(uentp->brc_id)->brdname) :
#endif
- /* %-13.13s */
modestring(uentp, 0),
/* memo */