mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-09-08 12:01:21 +02:00
12859: dynamically-allocate buffer in ztat(), ztrdupstring()
This commit is contained in:
parent
430e294795
commit
2a625db39d
3 changed files with 32 additions and 8 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
2000-09-22 Clint Adams <schizo@debian.org>
|
||||||
|
|
||||||
|
* 12859: Src/string.c, Src/Zle/compresult.c:
|
||||||
|
dynamically allocate buffer in ztat, remove
|
||||||
|
duplication loop to ztrdupstrip().
|
||||||
|
|
||||||
2000-09-20 Bart Schaefer <schaefer@zsh.org>
|
2000-09-20 Bart Schaefer <schaefer@zsh.org>
|
||||||
|
|
||||||
* 12851, 12852: Completion/Commands/_expand_word,
|
* 12851, 12852: Completion/Commands/_expand_word,
|
||||||
|
|
|
@ -731,19 +731,17 @@ do_ambiguous(void)
|
||||||
mod_export int
|
mod_export int
|
||||||
ztat(char *nam, struct stat *buf, int ls)
|
ztat(char *nam, struct stat *buf, int ls)
|
||||||
{
|
{
|
||||||
char b[PATH_MAX], *p;
|
int e;
|
||||||
|
char *b;
|
||||||
|
|
||||||
if (!(ls ? lstat(nam, buf) : stat(nam, buf)))
|
if (!(ls ? lstat(nam, buf) : stat(nam, buf)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
for (p = b; p < b + sizeof(b) - 1 && *nam; nam++)
|
b = ztrdupstrip(nam, '\\');
|
||||||
if (*nam == '\\' && nam[1])
|
|
||||||
*p++ = *++nam;
|
|
||||||
else
|
|
||||||
*p++ = *nam;
|
|
||||||
*p = '\0';
|
|
||||||
|
|
||||||
return ls ? lstat(b, buf) : stat(b, buf);
|
e = ls ? lstat(b, buf) : stat(b, buf);
|
||||||
|
zsfree(b);
|
||||||
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Insert a single match in the command line. */
|
/* Insert a single match in the command line. */
|
||||||
|
|
20
Src/string.c
20
Src/string.c
|
@ -133,3 +133,23 @@ appstr(char *base, char const *append)
|
||||||
{
|
{
|
||||||
return strcat(realloc(base, strlen(base) + strlen(append) + 1), append);
|
return strcat(realloc(base, strlen(base) + strlen(append) + 1), append);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Duplicate a string, stripping delimiters. */
|
||||||
|
|
||||||
|
/**/
|
||||||
|
mod_export char *
|
||||||
|
ztrdupstrip(const char *nam, char delim)
|
||||||
|
{
|
||||||
|
char *p, *buf;
|
||||||
|
|
||||||
|
buf = zalloc(strlen(nam));
|
||||||
|
|
||||||
|
for (p = buf; *nam; nam++)
|
||||||
|
if (*nam == delim && nam[1])
|
||||||
|
*p++ = *++nam;
|
||||||
|
else
|
||||||
|
*p++ = *nam;
|
||||||
|
*p = '\0';
|
||||||
|
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue