Show the watching-menu sorting by hilighting the title.

git-svn-id: svn://katsu.triplehelix.org/dgamelaunch/trunk@483 db0b04b0-f4d1-0310-9a6d-de3e77497b0e
This commit is contained in:
Pasi Kallinen 2009-10-18 10:31:45 +00:00
parent dde7cc68b4
commit 284a2201e3
2 changed files with 24 additions and 19 deletions

5
TODO
View File

@ -1,11 +1,6 @@
-update virus to the newest version. -update virus to the newest version.
-inprogress-dir config option prepends the dgl-root dir, other
config dirs do not. unify.
-allow changing the name where the ttyrecs are saved, like -allow changing the name where the ttyrecs are saved, like
ttyrec_fn = "%rttyrec/%n/%g/%p.ttyrec" ttyrec_fn = "%rttyrec/%n/%g/%p.ttyrec"
-allow typing / in watching screen to search for a user
("/foo<enter>" would start watching user foo's game, or
report that that player is not playing.
-maybe save more stuff in the db, if we're using the sqlite -maybe save more stuff in the db, if we're using the sqlite
(last login timestamp, watch-menu sort-type, etc) (last login timestamp, watch-menu sort-type, etc)
-Allow using a ttyrec (or similar screen capture) as the menu -Allow using a ttyrec (or similar screen capture) as the menu

View File

@ -384,9 +384,13 @@ inprogressmenu (int gameid)
int selected = -1; int selected = -1;
int abs_max_height; int abs_max_height;
int top_banner_hei = 4; int top_banner_hei = 5;
int btm_banner_hei = 3;
int btm; int btm;
int title_attr = A_STANDOUT;
int selected_attr = A_BOLD;
if (sortmode == NUM_SORTMODES) if (sortmode == NUM_SORTMODES)
sortmode = globalconfig.sortmode; sortmode = globalconfig.sortmode;
@ -404,7 +408,7 @@ inprogressmenu (int gameid)
while (1) while (1)
{ {
term_resize_check(); term_resize_check();
max_height = local_LINES - 8; max_height = local_LINES - (top_banner_hei + btm_banner_hei) - 1;
if (max_height < 2) { if (max_height < 2) {
free(is_nhext); free(is_nhext);
free_populated_games(games, len); free_populated_games(games, len);
@ -425,25 +429,31 @@ inprogressmenu (int gameid)
erase (); erase ();
drawbanner (&banner, 1, 1); drawbanner (&banner, 1, 1);
/*
mvprintw (3, 1,
"During playback, hit 'q' to return here,%s",
(((gameid == -1) || (myconfig[gameid]->spool)) ? " 'm' to send mail (requires login)," : ""));
mvaddstr (4, 1,
"'s' to toggle graphic-set stripping for DEC, IBM, and none (default).");
*/
mvaddstr (3, 1, "The following games are in progress:"); mvaddstr (3, 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;
mvprintw(top_banner_hei,1 ," ");
if (sortmode == SORTMODE_USERNAME) attron(title_attr);
mvprintw(top_banner_hei,4 , "Username");
if (sortmode == SORTMODE_USERNAME) attroff(title_attr);
mvprintw(top_banner_hei,21, "Game");
mvprintw(top_banner_hei,29, "Size");
mvprintw(top_banner_hei,37, "Start date & time");
if (sortmode == SORTMODE_IDLETIME) attron(title_attr);
mvprintw(top_banner_hei,58, "Idle time");
if (sortmode == SORTMODE_IDLETIME) attroff(title_attr);
/* mvprintw(top_banner_hei,1," Username Game Size Start date & time Idle time");*/
for (i = 0; i < max_height; i++) for (i = 0; i < max_height; i++)
{ {
if (i + offset >= len) if (i + offset >= len)
break; break;
if (i + offset == selected) attron(A_BOLD); if (i + offset == selected) attron(selected_attr);
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");
@ -453,17 +463,17 @@ inprogressmenu (int gameid)
snprintf (gametype, sizeof gametype, "%3dx%3d", snprintf (gametype, sizeof gametype, "%3dx%3d",
games[i + offset]->ws_col, games[i + offset]->ws_row); games[i + offset]->ws_col, games[i + offset]->ws_row);
mvprintw (top_banner_hei + 1 + i, 1, "%c) %-15s %-5s (%s) %s %s (%ldm %lds idle)", mvprintw (top_banner_hei + 1 + i, 1, "%c) %-15s %-5s %s %s %s %ldm %lds",
selectorchars[i], 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); if (i + offset == selected) attroff(selected_attr);
} }
btm = local_LINES-3-top_banner_hei; btm = local_LINES-btm_banner_hei-top_banner_hei;
if (btm > i) btm = i+1; if (btm > i) btm = i+1;
if (len > 0) { if (len > 0) {
if (max_height+offset < len) if (max_height+offset < len)