X-Git-Url: http://ncurses.scripts.mit.edu/?a=blobdiff_plain;f=test%2Fchgat.c;h=1a605fdd569723f748a3d52fcdfa3134e84bc6ec;hb=5e1e572b71ae31a6071daa24e2460a68a6f1003c;hp=ee51297de5f006f4c6b1809c98c062bb12e094d9;hpb=4ae6d1c18d0dec956b814865893812655ec3a22c;p=ncurses.git diff --git a/test/chgat.c b/test/chgat.c index ee51297d..1a605fdd 100644 --- a/test/chgat.c +++ b/test/chgat.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 2006-2007,2008 Free Software Foundation, Inc. * + * Copyright (c) 2006-2012,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,12 +26,13 @@ * authorization. * ****************************************************************************/ /* - * $Id: chgat.c,v 1.8 2008/02/09 23:19:13 tom Exp $ + * $Id: chgat.c,v 1.15 2017/04/16 00:47:55 tom Exp $ * * test-driver for chgat/wchgat/mvchgat/mvwchgat */ #include +#include #if HAVE_CHGAT @@ -47,7 +48,7 @@ typedef struct { unsigned c; unsigned v; - int pair; + short pair; unsigned attr; int count; int ch; @@ -60,12 +61,12 @@ typedef struct { } STATUS; static const char * -color_params(unsigned state, int *pair) +color_params(unsigned state, short *pair) { /* *INDENT-OFF* */ static struct { - int pair; - int fg, bg; + short pair; + short fg, bg; const char *msg; } table[] = { { 0, COLOR_DEFAULT, COLOR_DEFAULT, "default" }, @@ -124,10 +125,17 @@ static void fill_window(WINDOW *win) { int y, x; + int y0 = -1, x0 = -1; getyx(win, y, x); wmove(win, 0, 0); while (waddstr(win, "0123456789 abcdefghijklmnopqrstuvwxyz ") != ERR) { + int y1, x1; + getyx(win, y1, x1); + if (y1 == y0 && x1 == x0) + break; + x0 = x1; + y0 = y1; } wmove(win, y, x); } @@ -169,6 +177,8 @@ do_subwindow(WINDOW *win, STATUS * sp, void func(WINDOW *)) delwin(win1); touchwin(win); } else { + if (win1 != 0) + delwin(win1); beep(); } } @@ -191,7 +201,7 @@ init_status(WINDOW *win, STATUS * sp) static void show_help(WINDOW *win) { - static const char *table[] = + static const char *msgs[] = { "Basic commands:" ,"Use h/j/k/l or arrow keys to move the cursor." @@ -205,19 +215,10 @@ show_help(WINDOW *win) ,"= resets count to zero." ,"- negates count." ,"? shows this help-window" - ,"" - ,"" + ,0 }; - int y_max, x_max; - int row; - - getmaxyx(win, y_max, x_max); - for (row = 0; row < (int) SIZEOF(table) && row < y_max; ++row) { - mvwprintw(win, row, 0, "%.*s", x_max, table[row]); - } - while (wgetch(win) != 'q') - beep(); + popup_msg(win, msgs); } static void @@ -271,8 +272,8 @@ update_status(WINDOW *win, STATUS * sp) sp->count = -(sp->count); show_status(win, sp); break; - case '?': - do_subwindow(win, sp, show_help); + case HELP_KEY_1: + show_help(win); break; default: if (isdigit(sp->ch)) {