From af2ae90d25c362365f8fd82c15e57d22b692cddf Mon Sep 17 00:00:00 2001 From: Bart Schaefer Date: Fri, 16 Feb 2001 17:16:13 +0000 Subject: Fix "${=foo=$@}". --- ChangeLog | 6 +++++- Src/subst.c | 8 ++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 65348f35c..fc64a84d0 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,9 +1,13 @@ +2001-02-16 Bart Schaefer + + * 13495: Follow-up to 13492 to un-break "${(A)=foo=$@}". + 2001-02-16 Sven Wischnowsky * 13494: Completion/Core/compinit: make `compdef foo=bar' use the service defined for `bar' if there is any -2001-02-16 Bart Schaefer +2001-02-16 Bart Schaefer * 13492: Src/subst.c: Partial fix for ${1+"$@"} expanding to an array (still doesn't handle shwordsplit properly); fix so diff --git a/Src/subst.c b/Src/subst.c index da848779a..27ed6af07 100644 --- a/Src/subst.c +++ b/Src/subst.c @@ -1015,7 +1015,7 @@ paramsubst(LinkList l, LinkNode n, char **str, int qt, int ssub) spbreak = 0; s++; } else - spbreak = 1; + spbreak = 2; } else if ((c == '#' || c == Pound) && (iident(cc = s[1]) || cc == '*' || cc == Star || cc == '@' @@ -1414,8 +1414,6 @@ paramsubst(LinkList l, LinkNode n, char **str, int qt, int ssub) if (spsep || spbreak) { aval = sepsplit(val, spsep, 0, 1); isarr = 2; - sep = spsep = NULL; - spbreak = 0; l = arrlen(aval); if (l && !*(aval[l-1])) l--; @@ -1456,10 +1454,12 @@ paramsubst(LinkList l, LinkNode n, char **str, int qt, int ssub) if (isarr) { if (nojoin) isarr = -1; - if (qt && !getlen && isarr > 0) { + if (qt && !getlen && isarr > 0 && !spsep && spbreak < 2) { val = sepjoin(aval, sep, 1); isarr = 0; } + sep = spsep = NULL; + spbreak = 0; } } break; -- cgit 1.4.1