X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=test%2Ftest_vidputs.c;h=3cf004768bba443311acfde5e7a441d7fdbabff8;hp=c32f50b7812c9b13eb92f3b3319d144642b978ce;hb=d66080c21038ad4feb2e41a0c4e517d5b4a03ab2;hpb=a1e63be290fce9e589bc57c9f753be09e8ac0cc7 diff --git a/test/test_vidputs.c b/test/test_vidputs.c index c32f50b7..3cf00476 100644 --- a/test/test_vidputs.c +++ b/test/test_vidputs.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 2013 Free Software Foundation, Inc. * + * Copyright (c) 2013-2014,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,7 +26,7 @@ * authorization. * ****************************************************************************/ /* - * $Id: test_vidputs.c,v 1.3 2013/01/13 00:58:54 tom Exp $ + * $Id: test_vidputs.c,v 1.9 2017/10/11 08:17:07 tom Exp $ * * Demonstrate the vidputs and vidattr functions. * Thomas Dickey - 2013/01/12 @@ -35,9 +35,7 @@ #define USE_TINFO #include -#if HAVE_SETUPTERM - -#define valid(s) ((s != 0) && s != (char *)-1) +#if HAVE_SETUPTERM && HAVE_VIDPUTS static FILE *my_fp; static bool p_opt = FALSE; @@ -52,9 +50,9 @@ TPUTS_PROTO(outc, c) } static bool -outs(char *s) +outs(const char *s) { - if (valid(s)) { + if (VALID_STRING(s)) { tputs(s, 1, outc); return TRUE; } @@ -64,10 +62,12 @@ outs(char *s) static void cleanup(void) { - outs(exit_attribute_mode); - if (!outs(orig_colors)) - outs(orig_pair); - outs(cursor_normal); + if (cur_term != 0) { + outs(exit_attribute_mode); + if (!outs(orig_colors)) + outs(orig_pair); + outs(cursor_normal); + } } static void @@ -101,6 +101,7 @@ usage(void) ,"" ,"Options:" ," -e use stderr (default stdout)" + ," -n do not initialize terminal" ," -p use vidputs (default vidattr)" }; unsigned n; @@ -113,14 +114,18 @@ int main(int argc GCC_UNUSED, char *argv[]GCC_UNUSED) { int ch; + bool no_init = FALSE; my_fp = stdout; - while ((ch = getopt(argc, argv, "ep")) != -1) { + while ((ch = getopt(argc, argv, "enp")) != -1) { switch (ch) { case 'e': my_fp = stderr; break; + case 'n': + no_init = TRUE; + break; case 'p': p_opt = TRUE; break; @@ -132,11 +137,16 @@ main(int argc GCC_UNUSED, char *argv[]GCC_UNUSED) if (optind < argc) usage(); - setupterm((char *) 0, 1, (int *) 0); + if (no_init) { + START_TRACE(); + } else { + setupterm((char *) 0, fileno(my_fp), (int *) 0); + } test_vidputs(); cleanup(); ExitProgram(EXIT_SUCCESS); } + #else int main(int argc GCC_UNUSED,