Drastic changes to the watching-screen.

git-svn-id: svn://katsu.triplehelix.org/dgamelaunch/trunk@472 db0b04b0-f4d1-0310-9a6d-de3e77497b0e
This commit is contained in:
Pasi Kallinen 2009-10-18 01:03:27 +00:00
parent 65bc2cee98
commit 653396a7d2
1 changed files with 41 additions and 20 deletions

View File

@ -371,15 +371,23 @@ drawbanner (struct dg_banner *ban, unsigned int start_line, unsigned int howmany
void void
inprogressmenu (int gameid) inprogressmenu (int gameid)
{ {
char selectorchars[('z'-'a') + ('Z'-'A')+2];
int i, menuchoice, len = 20, offset = 0, doresizewin = 0; int i, menuchoice, len = 20, offset = 0, doresizewin = 0;
static dg_sortmode sortmode = NUM_SORTMODES; static dg_sortmode sortmode = NUM_SORTMODES;
time_t ctime; time_t ctime;
struct dg_game **games; struct dg_game **games;
char ttyrecname[130], *replacestr = NULL, gametype[10]; char ttyrecname[130], *replacestr = NULL, gametype[10];
int is_nhext[14]; int is_nhext[('z'-'a') + ('Z'-'A')+2];
sigset_t oldmask, toblock; sigset_t oldmask, toblock;
int idx = -1; int idx = -1;
int max_height = -1; int max_height = -1;
int selected = -1;
for (i = 'a'; i <= 'z'; i++) {
selectorchars[i-'a'] = i;
selectorchars[(i-'a'+1)+'z'] = (i - 'a' + 'A');
}
if (sortmode == NUM_SORTMODES) if (sortmode == NUM_SORTMODES)
sortmode = globalconfig.sortmode; sortmode = globalconfig.sortmode;
@ -392,6 +400,7 @@ inprogressmenu (int gameid)
term_resize_check(); term_resize_check();
max_height = local_LINES - 10; max_height = local_LINES - 10;
if (max_height < 2) return; if (max_height < 2) return;
if (max_height > ('z'-'a') + ('Z'-'A')) max_height = ('z'-'a') + ('Z'-'A');
if (len == 0) if (len == 0)
offset = 0; offset = 0;
@ -408,7 +417,8 @@ inprogressmenu (int gameid)
(((gameid == -1) || (myconfig[gameid]->spool)) ? " 'm' to send mail (requires login)," : "")); (((gameid == -1) || (myconfig[gameid]->spool)) ? " 'm' to send mail (requires login)," : ""));
mvaddstr (4, 1, mvaddstr (4, 1,
"'s' to toggle graphic-set stripping for DEC, IBM, and none (default)."); "'s' to toggle graphic-set stripping for DEC, IBM, and none (default).");
mvaddstr (5, 1, "The following games are in progress: (use uppercase to try to change size)"); mvaddstr (5, 1, "The following games are in progress:");
/*mvaddstr (5, 1, "The following games are in progress: (use uppercase to try to change size)");*/
/* clean old games and list good ones */ /* clean old games and list good ones */
i = 0; i = 0;
@ -418,6 +428,8 @@ inprogressmenu (int gameid)
if (i + offset >= len) if (i + offset >= len)
break; break;
if (i + offset == selected) attron(A_BOLD);
is_nhext[i] = !strcmp (games[i + offset]->ttyrec_fn + strlen (games[i + offset]->ttyrec_fn) - 6, ".nhext"); is_nhext[i] = !strcmp (games[i + offset]->ttyrec_fn + strlen (games[i + offset]->ttyrec_fn) - 6, ".nhext");
if (is_nhext[i]) if (is_nhext[i])
@ -427,18 +439,21 @@ inprogressmenu (int gameid)
games[i + offset]->ws_col, games[i + offset]->ws_row); games[i + offset]->ws_col, games[i + offset]->ws_row);
mvprintw (7 + i, 1, "%c) %-15s %-5s (%s) %s %s (%ldm %lds idle)", mvprintw (7 + i, 1, "%c) %-15s %-5s (%s) %s %s (%ldm %lds idle)",
i + 97, games[i + offset]->name, myconfig[games[i + offset]->gamenum]->shortname, gametype, selectorchars[i], games[i + offset]->name, myconfig[games[i + offset]->gamenum]->shortname, gametype,
games[i + offset]->date, games[i + offset]->time, games[i + offset]->date, games[i + offset]->time,
(time (&ctime) - games[i + offset]->idle_time) / 60, (time (&ctime) - games[i + offset]->idle_time) / 60,
(time (&ctime) - games[i + offset]->idle_time) % 60); (time (&ctime) - games[i + offset]->idle_time) % 60);
if (i + offset == selected) attroff(A_BOLD);
} }
mvprintw ((local_LINES-2), 1, "'s' and 'S' change sort mode (current: %s)", SORTMODE_NAME[sortmode]); mvprintw ((local_LINES-2), 1, "'.' changes sort mode (current: %s)", SORTMODE_NAME[sortmode]);
if (len > 0) if (len > 0)
mvprintw ((local_LINES-3), 1, "(%d-%d of %d)", offset + 1, offset + i, len); mvprintw ((local_LINES-3), 1, "(%d-%d of %d)", offset + 1, offset + i, len);
mvaddstr ((local_LINES-1), 1, mvaddstr ((local_LINES-1), 1,
"Watch which game? (any key refreshes, 'q' quits, '>'/'<' for more/less) => "); "Watch which game? (letter + enter, 'q' quits, '>'/'<' for more/less) => ");
refresh (); refresh ();
@ -481,31 +496,37 @@ inprogressmenu (int gameid)
case 'q': case 'Q': case 'q': case 'Q':
return; return;
case 's': case '.':
if (sortmode < (NUM_SORTMODES-1)) sortmode++; else sortmode = SORTMODE_NONE; if (sortmode < (NUM_SORTMODES-1)) sortmode++; else sortmode = SORTMODE_NONE;
break; break;
case 'S':
if (sortmode > SORTMODE_NONE) sortmode--; else sortmode = (NUM_SORTMODES-1);
break;
case 12: case 18: /* ^L, ^R */ case 12: case 18: /* ^L, ^R */
clear (); clear ();
break; break;
default: case '1':
doresizewin = 0; doresizewin = (doresizewin ? 1 : 0);
if (isupper (menuchoice)) break;
{
doresizewin = 1; case 13:
menuchoice = tolower (menuchoice); case 10:
case KEY_ENTER:
if (selected >= 0 && selected < len) {
idx = selected;
goto watchgame;
} }
if ((menuchoice - 'a') >= 0 && (menuchoice - 'a') < i) break;
{
if (is_nhext[menuchoice - 97]) /* Cannot watch NhExt game */
break;
idx = menuchoice - 97 + offset; default:
if (strchr(selectorchars, menuchoice)) {
int sidx = strchr(selectorchars, menuchoice) - selectorchars;
if (is_nhext[sidx]) /* Cannot watch NhExt game */
break;
idx = sidx + offset;
if (selected == idx) selected = -1;
else selected = idx;
break;
watchgame: watchgame:
/* valid choice has been made */ /* valid choice has been made */