X-Git-Url: http://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=test%2Ftest_vidputs.c;h=355f100989bd3a9d288277d40b3dc4a2aa88dd91;hp=7c7ade3018c008395476c321a0dcc81fd3b54c9c;hb=HEAD;hpb=0dc2639645b2cc67271247405709161df24a771f diff --git a/test/test_vidputs.c b/test/test_vidputs.c index 7c7ade30..31dc9da4 100644 --- a/test/test_vidputs.c +++ b/test/test_vidputs.c @@ -1,5 +1,6 @@ /**************************************************************************** - * Copyright (c) 2013,2014 Free Software Foundation, Inc. * + * Copyright 2020-2021,2022 Thomas E. Dickey * + * Copyright 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 +27,7 @@ * authorization. * ****************************************************************************/ /* - * $Id: test_vidputs.c,v 1.5 2014/07/19 23:09:58 tom Exp $ + * $Id: test_vidputs.c,v 1.15 2022/12/10 23:23:27 tom Exp $ * * Demonstrate the vidputs and vidattr functions. * Thomas Dickey - 2013/01/12 @@ -37,15 +38,13 @@ #if HAVE_SETUPTERM && HAVE_VIDPUTS -#define valid(s) ((s != 0) && s != (char *)-1) - static FILE *my_fp; static bool p_opt = FALSE; static TPUTS_PROTO(outc, c) { - int rc = c; + int rc; rc = putc(c, my_fp); TPUTS_RETURN(rc); @@ -54,7 +53,7 @@ TPUTS_PROTO(outc, c) static bool outs(const char *s) { - if (valid(s)) { + if (VALID_STRING(s)) { tputs(s, 1, outc); return TRUE; } @@ -64,10 +63,12 @@ outs(const 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 @@ -93,54 +94,70 @@ test_vidputs(void) } static void -usage(void) +usage(int ok) { static const char *tbl[] = { "Usage: test_vidputs [options]" ,"" + ,USAGE_COMMON ,"Options:" - ," -e use stderr (default stdout)" - ," -p use vidputs (default vidattr)" + ," -e use stderr (default stdout)" + ," -n do not initialize terminal" + ," -p use vidputs (default vidattr)" }; unsigned n; for (n = 0; n < SIZEOF(tbl); ++n) fprintf(stderr, "%s\n", tbl[n]); - ExitProgram(EXIT_FAILURE); + ExitProgram(ok ? EXIT_SUCCESS : EXIT_FAILURE); } +/* *INDENT-OFF* */ +VERSION_COMMON() +/* *INDENT-ON* */ int -main(int argc GCC_UNUSED, char *argv[]GCC_UNUSED) +main(int argc, char *argv[]) { int ch; + bool no_init = FALSE; my_fp = stdout; - while ((ch = getopt(argc, argv, "ep")) != -1) { + while ((ch = getopt(argc, argv, OPTS_COMMON "enp")) != -1) { switch (ch) { case 'e': my_fp = stderr; break; + case 'n': + no_init = TRUE; + break; case 'p': p_opt = TRUE; break; + case OPTS_VERSION: + show_version(argv); + ExitProgram(EXIT_SUCCESS); default: - usage(); - break; + usage(ch == OPTS_USAGE); + /* NOTREACHED */ } } if (optind < argc) - usage(); + usage(FALSE); - 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, - char *argv[]GCC_UNUSED) +main(void) { fprintf(stderr, "This program requires terminfo\n"); exit(EXIT_FAILURE);