about summary refs log tree commit diff
path: root/Src/params.c
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2001-06-15 13:07:50 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2001-06-15 13:07:50 +0000
commit3f6a9e4522205efb2e404d81ae44ad45df44d79b (patch)
tree2d440db6a38d8137bc04c6d64ee4159257a63f63 /Src/params.c
parent12e1cf567d239495cf238f44456ab19daab327c8 (diff)
downloadzsh-3f6a9e4522205efb2e404d81ae44ad45df44d79b.tar.gz
zsh-3f6a9e4522205efb2e404d81ae44ad45df44d79b.tar.xz
zsh-3f6a9e4522205efb2e404d81ae44ad45df44d79b.zip
fix setting of individual positional parameters after 14915
Diffstat (limited to 'Src/params.c')
-rw-r--r--Src/params.c21
1 files changed, 15 insertions, 6 deletions
diff --git a/Src/params.c b/Src/params.c
index 7eec34bf4..f96824165 100644
--- a/Src/params.c
+++ b/Src/params.c
@@ -108,13 +108,12 @@ mod_export int termflags;
  
 /* Nodes for special parameters for parameter hash table */
 
-static
 #ifdef HAVE_UNION_INIT
 # define BR(X) {X}
-struct param
+typedef struct param initparam;
 #else
 # define BR(X) X
-struct iparam {
+typedef struct iparam {
     struct hashnode *next;
     char *nam;			/* hash data                             */
     int flags;			/* PM_* flags (defined in zsh.h)         */
@@ -127,9 +126,10 @@ struct iparam {
     char *ename;		/* name of corresponding environment var */
     Param old;			/* old struct for use with local         */
     int level;			/* if (old != NULL), level of localness  */
-}
+} initparam;
 #endif
-special_params[] ={
+
+static initparam special_params[] ={
 #define SFN(X) BR(((void (*)_((Param, char *)))(X)))
 #define GFN(X) BR(((char *(*)_((Param)))(X)))
 #define IPDEF1(A,B,C,D) {NULL,A,PM_INTEGER|PM_SPECIAL|D,BR(NULL),SFN(C),GFN(B),stdunsetfn,10,NULL,NULL,NULL,0}
@@ -248,6 +248,15 @@ IPDEF10("pipestatus", pipestatgetfn, pipestatsetfn),
 
 {NULL, NULL}
 };
+
+/*
+ * Special way of referring to the positional parameters.  Unlike $*
+ * and $@, this is not readonly.  This parameter is not directly
+ * visible in user space.
+ */
+initparam argvparam_pm = IPDEF9F("", &pparams, NULL, \
+				 PM_ARRAY|PM_SPECIAL|PM_DONTIMPORT);
+
 #undef BR
 
 #define IS_UNSET_VALUE(V) \
@@ -502,7 +511,7 @@ createparamtable(void)
 	while ((++ip)->nam)
 	    paramtab->addnode(paramtab, ztrdup(ip->nam), ip);
 
-    argvparam = (Param) paramtab->getnode(paramtab, "*");
+    argvparam = (Param) &argvparam_pm;
 
     noerrs = 2;