summaryrefslogtreecommitdiff
path: root/Src/subst.c
diff options
context:
space:
mode:
authorBart Schaefer <barts@users.sourceforge.net>2012-02-20 17:50:39 +0000
committerBart Schaefer <barts@users.sourceforge.net>2012-02-20 17:50:39 +0000
commit15138d4fb7a40a1276722924b0482f53c83468f3 (patch)
treec313e526de9f0cd381b9b0158c942376520457fe /Src/subst.c
parent5f25bb8223d090d13af5869893fa35e5b8c44182 (diff)
downloadzsh-15138d4fb7a40a1276722924b0482f53c83468f3.tar.gz
zsh-15138d4fb7a40a1276722924b0482f53c83468f3.zip
30242: use PREFORK_SINGLE for ${...=...} in POSIX emulation
Diffstat (limited to 'Src/subst.c')
-rw-r--r--Src/subst.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/Src/subst.c b/Src/subst.c
index 894f9cd2f..b9229861b 100644
--- a/Src/subst.c
+++ b/Src/subst.c
@@ -2693,7 +2693,12 @@ paramsubst(LinkList l, LinkNode n, char **str, int qt, int pf_flags)
*idend = '\0';
val = dupstring(s);
if (spsep || !arrasg) {
- multsub(&val, PREFORK_NOSHWORDSPLIT, NULL, &isarr, NULL);
+ /* POSIX requires PREFORK_SINGLE semantics here, but
+ * traditional zsh used PREFORK_NOSHWORDSPLIT. Base
+ * behavior on caller choice of PREFORK_SHWORDSPLIT. */
+ multsub(&val,
+ spbreak ? PREFORK_SINGLE : PREFORK_NOSHWORDSPLIT,
+ NULL, &isarr, NULL);
} else {
if (spbreak)
split_flags = PREFORK_SPLIT|PREFORK_SHWORDSPLIT;