Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
[PATCH] Restrict named directories to scalar parameters.
- X-seq: zsh-workers 54759
- From: Philippe Altherr <philippe.altherr@xxxxxxxxx>
- To: Zsh hackers list <zsh-workers@xxxxxxx>
- Subject: [PATCH] Restrict named directories to scalar parameters.
- Date: Fri, 12 Jun 2026 21:41:01 +0200
- Arc-authentication-results: i=1; mx.google.com; arc=none
- Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20240605; h=to:subject:message-id:date:from:mime-version:dkim-signature; bh=3AwpWW7E20x3b4kQezk2WoTmbiVE5a+5lOEufcYYrbY=; fh=BgAYDYpL6Ne/A5nWEMVJiHiBtrz8Imz3uf26RDwgQX4=; b=Hqe4sgkG60uediIGzr/Ker2yay8iKQt3okKpqO/dyLNcAW1OhaetfkodxQoHnCj4Cr n8CFkYBVq8zoT9ebX3uloLtuAmiWJ7/TRLAZ48oUxtaE1CWvPUDQWgqQds2KvWPGMaXI f91usKsXsuxcPnlOLgo7DHoWIXIAwV0zeAX5WXvTJI91zLtwct1kWdJk1TmoU8Z9hbwE oKp4jJFdSeymNfQsq1mrpPgBh1BXKG7jz7rHqIRQhrjl9rUL6KPJY+Jqfr3sl5GzWFcf cp/9bnEb2mtXn6XsYhh4HHfSOkAhYDtc5twTrCbe5Sg2BWcO0ywcdr3gYYnUGJ5TC88T UOSg==; darn=zsh.org
- Arc-seal: i=1; a=rsa-sha256; t=1781293273; cv=none; d=google.com; s=arc-20240605; b=GTh2Pv/+ReLB5yQwsRhwrWuUD86spC4LSHewGJMgURuqgA2ZEVRHI8lSSAAMMdTy3e NK0xIra4ADBYRjYVEP/pcyYiZCL6fouzwXLM3lWdRfh0xkonZx5a/wYV515rhjMKLH83 AzasaHSFu/lZqr9VARKcDER2weO5hWqqc0JWzO2lDoeFfoMiyUQnuXJp+8eakNKSqV94 agN1YtKc8H6D+br70MbDWGTCYzceUU+KKN3kEYxx5eNMxYy1/FRqsyMfYCXfs8V9DYLL Ahe3F58eSrk0pMj1x6FRY/RzgMUzUHTHZXQKw3T0PgwcAVsvxCA6J4RA/XWagPd9EGmk 7cKg==
- Archived-at: <https://zsh.org/workers/54759>
- List-id: <zsh-workers.zsh.org>
diff --git a/Src/params.c b/Src/params.c
index e5bbe9cb9..8df594837 100644
--- a/Src/params.c
+++ b/Src/params.c
@@ -3975,7 +3975,7 @@ floatsetfn(Param pm, double x)
pm->u.dval = x;
}
-/* Function to get value of a scalar (string) parameter */
+/* Function to get value of a scalar (string) or nameref parameter */
/**/
mod_export char *
@@ -3984,7 +3984,7 @@ strgetfn(Param pm)
return pm->u.str ? pm->u.str : (char *) hcalloc(1);
}
-/* Function to set value of a scalar (string) parameter */
+/* Function to set value of a scalar (string) or nameref parameter */
/**/
mod_export void
@@ -3995,6 +3995,7 @@ strsetfn(Param pm, char *x)
pm->u.str = x;
}
if (!(pm->node.flags & PM_HASHELEM) && !pm->level &&
+ (PM_TYPE(pm->node.flags) == PM_SCALAR) &&
((pm->node.flags & PM_NAMEDDIR) || isset(AUTONAMEDIRS))) {
pm->node.flags |= PM_NAMEDDIR;
adduserdir(pm->node.nam, x, 0, 0);
diff --git a/Test/K01nameref.ztst b/Test/K01nameref.ztst
index 6cfe6d1d0..54fe8565a 100644
--- a/Test/K01nameref.ztst
+++ b/Test/K01nameref.ztst
@@ -1573,6 +1573,37 @@ F:previously this could create an infinite recursion and crash
'
0:regression - converting a string into a named reference
>typeset PS1=zz
+*?*
+
+# Testing named directories requires to run in interactive mode
+
+ $ZTST_testdir/../Src/zsh -fis <<<$'
+ typeset v1=/1 v2
+ typeset -n r1=v1 r2
+ { echo "~v1:" ~v1 } 2>&1
+ { echo "~r1:" ~r1 } 2>&1
+ echo "nameddirs=( ${(kv)nameddirs} )"
+ r1=/A
+ echo "nameddirs=( ${(kv)nameddirs} )"
+ hash -d v2=/2 r2=/R
+ echo "nameddirs=( ${(kv)nameddirs} )"
+ setopt autonamedirs
+ v2=V2
+ echo "nameddirs=( ${(kv)nameddirs} )"
+ r2=v2
+ echo "nameddirs=( ${(kv)nameddirs} )"
+ r2=/B
+ echo "nameddirs=( ${(kv)nameddirs} )"
+ '
+0:Only string parameters are promoted to named directories
+>~v1: /1
+>zsh: no such user or named directory: r1
+>nameddirs=( v1 /1 )
+>nameddirs=( v1 /A )
+>nameddirs=( v1 /A v2 /2 r2 /R )
+>nameddirs=( v1 /A r2 /R )
+>nameddirs=( v1 /A r2 /R )
+>nameddirs=( v1 /A v2 /B r2 /R )
*?*
unset var1 var2
Messages sorted by:
Reverse Date,
Date,
Thread,
Author