about summary refs log tree commit diff
path: root/Src
diff options
context:
space:
mode:
authorMikael Magnusson <mikachu@gmail.com>2015-08-31 14:52:59 +0200
committerMikael Magnusson <mikachu@gmail.com>2015-09-01 23:20:05 +0200
commit8e3ca08f13f198caa7cd7dc2bb37863238bea4f2 (patch)
tree9d61db4475d8a74c18d25a849ffa7de03b85892a /Src
parentcbe00216fe2b61a4d00cd6bd8189063efc5e132a (diff)
downloadzsh-8e3ca08f13f198caa7cd7dc2bb37863238bea4f2.tar.gz
zsh-8e3ca08f13f198caa7cd7dc2bb37863238bea4f2.tar.xz
zsh-8e3ca08f13f198caa7cd7dc2bb37863238bea4f2.zip
36347: Fix appending empty array to associations
Diffstat (limited to 'Src')
-rw-r--r--Src/params.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/Src/params.c b/Src/params.c
index 00f43e47d..de151a4cd 100644
--- a/Src/params.c
+++ b/Src/params.c
@@ -3312,9 +3312,12 @@ arrhashsetfn(Param pm, char **val, int augment)
 	zerr("bad set of key/value pairs for associative array");
 	return;
     }
-    if (alen)
-    	if (!(augment && (ht = paramtab = pm->gsu.h->getfn(pm))))
-	    ht = paramtab = newparamtable(17, pm->node.nam);
+    if (augment) {
+	ht = paramtab = pm->gsu.h->getfn(pm);
+    }
+    if (alen && (!augment || !paramtab)) {
+	ht = paramtab = newparamtable(17, pm->node.nam);
+    }
     while (*aptr) {
 	/* The parameter name is ztrdup'd... */
 	v->pm = createparam(*aptr, PM_SCALAR|PM_UNSET);