X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=progs%2Ftput.c;h=027fab9c8fbbe9f465477443788fdeae77c8fc1b;hp=cac8d292a94b44af9291441111276b875970d302;hb=81304798ee736c467839c779c9ca5dca48db7bea;hpb=7884aa084f9440fd964f14fe31853a5f85db5104 diff --git a/progs/tput.c b/progs/tput.c index cac8d292..027fab9c 100644 --- a/progs/tput.c +++ b/progs/tput.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright 2018-2019,2020 Thomas E. Dickey * + * Copyright 2018-2020,2021 Thomas E. Dickey * * Copyright 1998-2016,2017 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * @@ -44,14 +44,10 @@ #include #include -#if !PURE_TERMINFO -#include -#include -#endif #include #include -MODULE_ID("$Id: tput.c,v 1.84 2020/10/24 18:29:38 tom Exp $") +MODULE_ID("$Id: tput.c,v 1.90 2021/04/18 17:18:19 tom Exp $") #define PUTS(s) fputs(s, stdout) @@ -62,7 +58,7 @@ static bool is_init = FALSE; static bool is_reset = FALSE; static bool is_clear = FALSE; -static void +static GCC_NORETURN void quit(int status, const char *fmt, ...) { va_list argp; @@ -75,7 +71,7 @@ quit(int status, const char *fmt, ...) ExitProgram(status); } -static void +static GCC_NORETURN void usage(void) { #define KEEP(s) s "\n" @@ -225,13 +221,14 @@ tput_cmd(int fd, TTY * saved_settings, bool opt_x, int argc, char *argv[]) long numbers[1 + NUM_PARM]; char *strings[1 + NUM_PARM]; char *p_is_s[NUM_PARM]; + TParams paramType; /* Nasty hack time. The tparm function needs to see numeric * parameters as numbers, not as pointers to their string * representations */ - for (k = 1; (k < argc) && (k < NUM_PARM); k++) { + for (k = 1; (k < argc) && (k <= NUM_PARM); k++) { char *tmp = 0; strings[k] = argv[k]; numbers[k] = strtol(argv[k], &tmp, 0); @@ -243,7 +240,21 @@ tput_cmd(int fd, TTY * saved_settings, bool opt_x, int argc, char *argv[]) strings[k] = 0; } - switch (tparm_type(name)) { + paramType = tparm_type(name); +#if NCURSES_XNAMES + /* + * If the capability is an extended one, analyze the string. + */ + if (paramType == Numbers) { + struct name_table_entry const *entry_ptr; + entry_ptr = _nc_find_type_entry(name, STRING, FALSE); + if (entry_ptr == NULL) { + paramType = Other; + } + } +#endif + + switch (paramType) { case Num_Str: s = TPARM_2(s, numbers[1], strings[2]); break;