X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=test%2Ftest_sgr.c;h=aeb833cf9e10c902eb628f7fe29116c3a3aa0c57;hp=aa7a649ba778415b1beedadb3dd401b866f102cf;hb=3e91848cbe3dad23fdb60962fa9b678592591c34;hpb=603f0cb25b7acc8f04f4b18d2a2fe6f90039829a diff --git a/test/test_sgr.c b/test/test_sgr.c index aa7a649b..aeb833cf 100644 --- a/test/test_sgr.c +++ b/test/test_sgr.c @@ -1,5 +1,6 @@ /**************************************************************************** - * Copyright (c) 2015,2016 Free Software Foundation, Inc. * + * Copyright 2019,2020 Thomas E. Dickey * + * Copyright 2015-2016,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 * @@ -29,7 +30,7 @@ /* * Author: Thomas E. Dickey * - * $Id: test_sgr.c,v 1.7 2016/06/11 23:15:03 tom Exp $ + * $Id: test_sgr.c,v 1.15 2020/02/02 23:34:34 tom Exp $ * * A simple demo of the sgr/sgr0 terminal capabilities. */ @@ -49,6 +50,7 @@ failed(const char *msg) #if HAVE_TIGETSTR +static bool no_init = FALSE; static bool q_opt = FALSE; static char *d_opt; @@ -61,8 +63,9 @@ static long total_values; static char * make_dbitem(char *p, char *q) { - char *result = malloc(strlen(e_opt) + 2 + (size_t) (p - q)); - sprintf(result, "%s=%.*s", e_opt, (int) (p - q), q); + size_t need = strlen(e_opt) + 2 + (size_t) (p - q); + char *result = malloc(need); + _nc_SPRINTF(result, _nc_SLIMIT(need) "%s=%.*s", e_opt, (int) (p - q), q); return result; } @@ -117,7 +120,7 @@ next_dbitem(void) return result; } -#ifdef NO_LEAKS +#if NO_LEAKS static void free_dblist(void) { @@ -145,7 +148,7 @@ dumpit(unsigned bits, unsigned ignore, const char *sgr, const char *sgr0) static char params[] = "SURBDBIPA"; unsigned n; - printf("%4d ", bits); + printf("%4u ", bits); bits &= ~ignore; for (n = 0; n < MAXPAR; ++n) { putchar((int) ((bits & (unsigned) (1 << n)) ? params[n] : '-')); @@ -180,15 +183,23 @@ brute_force(const char *name) char *my_bold; char *my_revs; char *my_smso; + char *my_name = strdup(name); if (db_list) { putenv(next_dbitem()); } + if (!q_opt) - printf("Terminal type \"%s\"\n", name); - setupterm((NCURSES_CONST char *) name, 1, (int *) 0); + printf("Terminal type \"%s\"\n", my_name); + + if (no_init) { + START_TRACE(); + } else { + setupterm((NCURSES_CONST char *) my_name, 1, (int *) 0); + } + if (!q_opt) { - if (strcmp(name, ttytype)) + if (strcmp(my_name, ttytype)) printf("... actual \"%s\"\n", ttytype); } @@ -285,7 +296,11 @@ brute_force(const char *name) } } } + for (count = 0; count < MAXSGR; ++count) { + free(values[count]); + } } + free(my_name); del_curterm(cur_term); } @@ -301,6 +316,7 @@ usage(void) "Options:", " -d LIST colon-separated list of databases to use", " -e NAME environment variable to set with -d option", + " -n do not initialize terminal, to test error-checking", " -q quiet (prints only counts)", }; unsigned n; @@ -316,7 +332,7 @@ main(int argc, char *argv[]) int n; char *name; - while ((n = getopt(argc, argv, "d:e:q")) != -1) { + while ((n = getopt(argc, argv, "d:e:nq")) != -1) { switch (n) { case 'd': d_opt = optarg; @@ -324,6 +340,9 @@ main(int argc, char *argv[]) case 'e': e_opt = optarg; break; + case 'n': + no_init = TRUE; + break; case 'q': q_opt = TRUE; break; @@ -348,7 +367,7 @@ main(int argc, char *argv[]) printf("%ld distinct values\n", total_values); -#ifdef NO_LEAKS +#if NO_LEAKS free_dblist(); #endif