1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2024-12-28 16:15:02 +01:00

19258: arg support for echoti.

This commit is contained in:
Clint Adams 2003-11-19 17:06:48 +00:00
parent a9cb4b0fa7
commit 184fd22fd4
3 changed files with 61 additions and 5 deletions

View file

@ -1,3 +1,8 @@
2003-11-19 Clint Adams <clint@zsh.org>
* 19258: Doc/Zsh/mod_terminfo.yo, Src/Modules/terminfo.c:
arg support for echoti.
2003-11-14 Clint Adams <clint@zsh.org>
* unposted: config.guess, config.sub:

23
Doc/Zsh/mod_terminfo.yo Normal file
View file

@ -0,0 +1,23 @@
COMMENT(!MOD!zsh/terminfo
Interface to the terminfo database.
!MOD!)
The tt(zsh/terminfo) module makes available one builtin command:
startitem()
findex(echoti)
cindex(terminfo value, printing)
item(tt(echoti) var(cap) [ var(arg) ])(
Output the terminfo value corresponding to the capability
var(cap), instantiated with var(arg) if applicable.
)
enditem()
The tt(zsh/terminfo) module makes available one parameter:
startitem()
vindex(terminfo)
item(tt(terminfo))(
An associative array that maps terminfo capability names to
their values.
)
enditem()

View file

@ -51,6 +51,12 @@ static char terminfo_nam[] = "terminfo";
# include <term.h>
# endif
/* If ERR isn't defined, we probably have bigger problems,
* but try this anyway. */
# ifndef ERR
# define ERR (-1)
# endif
static Param terminfo_pm;
/* echoti: output a terminfo capability */
@ -59,8 +65,8 @@ static Param terminfo_pm;
static int
bin_echoti(char *name, char **argv, char *ops, int func)
{
char *s, *t;
int num;
char *s, *t, *u;
int num, argct;
s = *argv++;
/* This depends on the termcap stuff in init.c */
@ -92,9 +98,28 @@ bin_echoti(char *name, char **argv, char *ops, int func)
zwarnnam(name, "no such terminfo capability: %s", s, 0);
return 1;
}
tputs(t, 1, putchar);
/* count the number of arguments required */
for (argct = 0, u = t; *u; u++)
if (*u == '%') {
if (u++, (*u == 'd' || *u == '2' || *u == '3' || *u == '.' ||
*u == '+'))
argct++;
}
/* check that the number of arguments provided is correct */
if (arrlen(argv) != argct) {
zwarnnam(name, (arrlen(argv) < argct) ? "not enough arguments" :
"too many arguments", NULL, 0);
return 1;
}
/* output string, through the proper termcap functions */
if (!argct)
tputs(t, 1, putraw);
else {
num = (argv[1]) ? atoi(argv[1]) : atoi(*argv);
tputs(tparm(t, atoi(*argv)), num, putraw);
}
return 0;
}
/**/
@ -351,7 +376,10 @@ boot_(Module m)
{
#ifdef HAVE_TIGETSTR
# ifdef HAVE_SETUPTERM
setupterm((char *)0, 1, (int *)0);
int errret;
if (setupterm((char *)0, 1, &errret) == ERR)
return 1;
# endif
if (!createtihash())