1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-01-01 05:16:05 +01:00

23795: improve ${(Q)...} with $'..'

This commit is contained in:
Peter Stephenson 2007-08-23 22:04:25 +00:00
parent 437f67718c
commit db3ba137b3
4 changed files with 50 additions and 2 deletions

View file

@ -1,3 +1,8 @@
2007-08-23 Peter Stephenson <p.w.stephenson@ntlworld.com>
* 23795: Src/lex.c: make ${(Q)...} handle $'...' correctly,
up to the problem of long flies in short ointments.
2007-08-23 Peter Stephenson <pws@csr.com>
* unposted: Functions/Calendar/calendar_show: used subscript

View file

@ -27,5 +27,5 @@
# This must also serve as a shell script, so do not add spaces around the
# `=' signs.
VERSION=4.3.4-dev-0
VERSION_DATE='April 19, 2006'
VERSION=4.3.4-dev-1
VERSION_DATE='August 1, 2007'

View file

@ -1556,6 +1556,7 @@ mod_export int
parse_subst_string(char *s)
{
int c, l = strlen(s), err, olen, lexstop_ret;
char *ptr;
if (!*s || !strcmp(s, nulstring))
return 0;
@ -1593,6 +1594,43 @@ parse_subst_string(char *s)
return 1;
}
#endif
/* Check for $'...' quoting. This needs special handling. */
for (ptr = s; *ptr; )
{
if (*ptr == String && ptr[1] == Snull)
{
char *t;
int len, tlen, diff;
t = getkeystring(ptr + 2, &len, GETKEYS_DOLLARS_QUOTE, NULL);
len += 2;
tlen = strlen(t);
diff = len - tlen;
/*
* Yuk.
* parse_subst_string() currently handles strings in-place.
* That's not so easy to fix without knowing whether
* additional memory should come off the heap or
* otherwise. So we cheat by copying the unquoted string
* into place, unless it's too long. That's not the
* normal case, but I'm worried there are are pathological
* cases with converting metafied multibyte strings.
* If someone can prove there aren't I will be very happy.
*/
if (diff < 0) {
DPUTS(1, "$'...' subst too long: fix get_parse_string()");
return 1;
}
memcpy(ptr, t, tlen);
ptr += tlen;
if (diff > 0) {
char *dptr = ptr;
char *sptr = ptr + diff;
while ((*dptr++ = *sptr++))
;
}
} else
ptr++;
}
return 0;
}

View file

@ -320,6 +320,11 @@
0:${(Q)...}
>and now even the pubs are shut.
foo="X$'\x41'$'\x42'Y"
print -r ${(Q)foo}
0:${(Q)...} with handling of $'...'
>XABY
psvar=(dog)
setopt promptsubst
foo='It shouldn'\''t $(happen) to a %1v.'