X-Git-Url: http://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=test%2Fsavescreen.c;h=9ace6a701fe99cee6e47e2f56260c361592a480d;hp=3bdf87108567fca3f617b9115fc960dad1464a6d;hb=2560bc3dae7f4919060c02c91a593566c908091c;hpb=87f20fc6e737084b06b6343c8c7206404daec4a2 diff --git a/test/savescreen.c b/test/savescreen.c index 3bdf8710..9ace6a70 100644 --- a/test/savescreen.c +++ b/test/savescreen.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 2007-2011,2015 Free Software Foundation, Inc. * + * Copyright (c) 2007-2015,2017 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * @@ -26,13 +26,14 @@ * authorization. * ****************************************************************************/ /* - * $Id: savescreen.c,v 1.23 2015/03/21 21:35:00 tom Exp $ + * $Id: savescreen.c,v 1.32 2017/04/15 17:33:50 tom Exp $ * * Demonstrate save/restore functions from the curses library. * Thomas Dickey - 2007/7/14 */ #include +#include #if HAVE_SCR_DUMP @@ -50,9 +51,28 @@ # endif #endif +#if defined(__hpux) +#define MyMarker 'X' +#else +#define MyMarker ACS_DIAMOND +#endif + static bool use_init = FALSE; static bool keep_dumps = FALSE; +#if USE_WIDEC_SUPPORT +/* In HPUX curses, cchar_t is opaque; other implementations are not */ +static wchar_t +BaseChar(cchar_t data) +{ + wchar_t my_wchar[sizeof(cchar_t)]; + attr_t my_attr; + short my_pair; + getcchar(&data, my_wchar, &my_attr, &my_pair, NULL); + return my_wchar[0]; +} +#endif + static int fexists(const char *name) { @@ -148,24 +168,6 @@ get_command(int which, int last) return ch; } -static void -show_help(const char **help) -{ - WINDOW *mywin = newwin(LINES, COLS, 0, 0); - int n; - - box(mywin, 0, 0); - wmove(mywin, 1, 1); - for (n = 0; help[n] != 0; ++n) { - wmove(mywin, 1 + n, 2); - wprintw(mywin, "%.*s", COLS - 4, help[n]); - } - wgetch(mywin); - delwin(mywin); - touchwin(stdscr); - refresh(); -} - static void editor_help(void) { @@ -183,8 +185,9 @@ editor_help(void) " a toggle between '#' and graphic symbol for drawing", " c change color drawn by line to next in palette", " h,j,k,l or arrows to move around the screen, drawing", + 0 }; - show_help(msgs); + popup_msg(stdscr, msgs); } static void @@ -199,8 +202,9 @@ replay_help(void) " q quit", " load the next screen", " load the previous screen", + 0 }; - show_help(msgs); + popup_msg(stdscr, msgs); } static void @@ -211,9 +215,10 @@ usage(void) "Usage: savescreen [-r] files", "", "Options:", - " -i use scr_init/scr_restore rather than scr_set", - " -k keep the restored dump-files rather than removing them", - " -r replay the screen-dump files" + " -f file fill/initialize screen using text from this file", + " -i use scr_init/scr_restore rather than scr_set", + " -k keep the restored dump-files rather than removing them", + " -r replay the screen-dump files" }; unsigned n; for (n = 0; n < SIZEOF(msg); ++n) { @@ -231,11 +236,19 @@ main(int argc, char *argv[]) bool replaying = FALSE; bool done = FALSE; char **files; + char *fill_by = 0; +#if USE_WIDEC_SUPPORT + cchar_t mycc; + int myxx; +#endif setlocale(LC_ALL, ""); - while ((ch = getopt(argc, argv, "ikr")) != -1) { + while ((ch = getopt(argc, argv, "f:ikr")) != -1) { switch (ch) { + case 'f': + fill_by = optarg; + break; case 'i': use_init = TRUE; break; @@ -281,6 +294,31 @@ main(int argc, char *argv[]) } } + if (fill_by != 0) { + FILE *fp = fopen(fill_by, "r"); + if (fp != 0) { + bool filled = FALSE; + move(1, 0); + while ((ch = fgetc(fp)) != EOF) { + if (addch(UChar(ch)) == ERR) { + filled = TRUE; + break; + } + } + fclose(fp); + if (!filled) { + while (addch(' ') != ERR) { + ; + } + } + move(0, 0); + } else { + endwin(); + fprintf(stderr, "Cannot open \"%s\"\n", fill_by); + ExitProgram(EXIT_FAILURE); + } + } + if (replaying) { /* @@ -324,7 +362,7 @@ main(int argc, char *argv[]) if (++which > last) which = 0; break; - case '?': + case HELP_KEY_1: replay_help(); break; default: @@ -385,7 +423,17 @@ main(int argc, char *argv[]) for (cx = 0; cx < COLS; ++cx) { wmove(curscr, cy, cx); wmove(stdscr, cy, cx); +#if USE_WIDEC_SUPPORT + if (win_wch(curscr, &mycc) != ERR) { + myxx = wcwidth(BaseChar(mycc)); + if (myxx > 0) { + wadd_wchnstr(stdscr, &mycc, 1); + cx += (myxx - 1); + } + } +#else waddch(stdscr, winch(curscr)); +#endif } } } @@ -419,7 +467,7 @@ main(int argc, char *argv[]) case 'c': color = (color + 1) % COLORS; break; - case '?': + case HELP_KEY_1: editor_help(); break; default: @@ -427,10 +475,10 @@ main(int argc, char *argv[]) continue; } if (!done) { - attr_t attr = (A_REVERSE | COLOR_PAIR(color * COLORS)); - chtype ch2 = (altchars ? ACS_DIAMOND : '#'); + attr_t attr = (A_REVERSE | (attr_t) COLOR_PAIR(color * COLORS)); + chtype ch2 = (altchars ? MyMarker : '#'); move(y, x); - addch(ch2 | attr); + AddCh(ch2 | attr); move(y, x); } }