X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=test%2Fdemo_new_pair.c;h=a4cbb5370dcbec8ba03fc7db13ba56dced2873c8;hp=aef725a0d5e5f1deb8f6660c109650ea32614e9c;hb=19e522ff96ce25dbb06b42c6e7c7680ecb12a277;hpb=90d42867e1296bc79021006a92032c76e59068b6 diff --git a/test/demo_new_pair.c b/test/demo_new_pair.c index aef725a0..a4cbb537 100644 --- a/test/demo_new_pair.c +++ b/test/demo_new_pair.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 2017 Free Software Foundation, Inc. * + * Copyright (c) 2017,2018 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,16 +26,21 @@ * authorization. * ****************************************************************************/ /* - * $Id: demo_new_pair.c,v 1.10 2017/03/10 09:47:15 tom Exp $ + * $Id: demo_new_pair.c,v 1.19 2018/05/12 14:30:04 tom Exp $ * * Demonstrate the alloc_pair() function. */ #include #include +#include #if HAVE_ALLOC_PAIR && USE_WIDEC_SUPPORT +#include +#include +#include + #define MAX_BITS 8 /* all but A_ALTCHARSET */ #define MAX_ATTR ((1<= 0) { + output = fdopen(ch, "w"); + } else { + fprintf(stderr, "cannot open terminal for output\n"); + ExitProgram(EXIT_FAILURE); + } + if (newterm(NULL, output, stdin) == 0) { + fprintf(stderr, "Cannot initialize terminal\n"); + fclose(output); + ExitProgram(EXIT_FAILURE); + } (void) cbreak(); /* read chars without wait for \n */ (void) noecho(); /* don't echo input */ update_modes(); @@ -259,8 +258,8 @@ main(int argc, char *argv[]) int my_pair; switch (getch()) { - case '?': - show_help(help); + case HELP_KEY_1: + popup_msg(stdscr, help); break; case 'p': /* step-by-page */ @@ -324,7 +323,9 @@ main(int argc, char *argv[]) break; wch[0] = use_wide ? 0xff03 : '#'; wch[1] = 0; - setcchar(&temp, wch, my_attrs, (short) my_pair, NULL); + setcchar(&temp, wch, my_attrs, + (short) my_pair, + (use_init ? NULL : (void *) &my_pair)); /* * At the end of a page, move the cursor to the home position. */ @@ -335,7 +336,8 @@ main(int argc, char *argv[]) total_cells += 1 + (use_wide ? 1 : 0); ++current; } - endwin(); + exit_curses(); + fclose(output); printf("%.1f cells/second\n", (double) (total_cells) / (double) (now() - start));