X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=test%2Fchgat.c;h=a5bcbea27d6149bf1a6e6a5ff09c45500860a63e;hp=aee178e16947fbfc4888f10c04c559ed8c53f211;hb=3e91848cbe3dad23fdb60962fa9b678592591c34;hpb=3a0d9d27e0cf115ff9dcc6163c251bccaa62bd7d diff --git a/test/chgat.c b/test/chgat.c index aee178e1..a5bcbea2 100644 --- a/test/chgat.c +++ b/test/chgat.c @@ -1,5 +1,6 @@ /**************************************************************************** - * Copyright (c) 2006-2008,2009 Free Software Foundation, Inc. * + * Copyright 2019,2020 Thomas E. Dickey * + * Copyright 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 +27,13 @@ * authorization. * ****************************************************************************/ /* - * $Id: chgat.c,v 1.10 2009/10/24 21:32:57 tom Exp $ + * $Id: chgat.c,v 1.19 2020/02/02 23:34:34 tom Exp $ * * test-driver for chgat/wchgat/mvchgat/mvwchgat */ #include +#include #if HAVE_CHGAT @@ -45,10 +47,10 @@ #endif typedef struct { - unsigned c; - unsigned v; + size_t c; + size_t v; short pair; - unsigned attr; + attr_t attr; int count; int ch; const char *c_msg; @@ -60,7 +62,7 @@ typedef struct { } STATUS; static const char * -color_params(unsigned state, short *pair) +color_params(size_t state, short *pair) { /* *INDENT-OFF* */ static struct { @@ -74,12 +76,13 @@ color_params(unsigned state, short *pair) }; /* *INDENT-ON* */ - static bool first = TRUE; const char *result = 0; if (has_colors()) { + static bool first = TRUE; + if (first) { - unsigned n; + size_t n; start_color(); for (n = 0; n < SIZEOF(table); ++n) { @@ -95,18 +98,18 @@ color_params(unsigned state, short *pair) } static const char * -video_params(unsigned state, unsigned *attr) +video_params(size_t state, attr_t *attr) { /* *INDENT-OFF* */ static struct { - unsigned attr; + attr_t attr; const char *msg; } table[] = { - { A_NORMAL, "normal" }, - { A_BOLD, "bold" }, - { A_REVERSE, "reverse" }, - { A_UNDERLINE, "underline" }, - { A_BLINK, "blink" }, + { WA_NORMAL, "normal" }, + { WA_BOLD, "bold" }, + { WA_REVERSE, "reverse" }, + { WA_UNDERLINE, "underline" }, + { WA_BLINK, "blink" }, }; /* *INDENT-ON* */ @@ -176,6 +179,8 @@ do_subwindow(WINDOW *win, STATUS * sp, void func(WINDOW *)) delwin(win1); touchwin(win); } else { + if (win1 != 0) + delwin(win1); beep(); } } @@ -198,7 +203,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." @@ -212,19 +217,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 @@ -278,8 +274,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)) {