Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/bin/sh DTRT when dynamically generated variables return "uns...



details:   https://anonhg.NetBSD.org/src/rev/149b33b711ca
branches:  trunk
changeset: 996831:149b33b711ca
user:      kre <kre%NetBSD.org@localhost>
date:      Sat Feb 09 09:38:11 2019 +0000

description:
DTRT when dynamically generated variables return "unset" instead of
a value.   There are none which do that at the minute, so this is a NFCI
change, which is just making the code correct even though nothing
currently triggers any bugs.

diffstat:

 bin/sh/var.c |  53 ++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 36 insertions(+), 17 deletions(-)

diffs (110 lines):

diff -r b96af4116374 -r 149b33b711ca bin/sh/var.c
--- a/bin/sh/var.c      Sat Feb 09 09:34:43 2019 +0000
+++ b/bin/sh/var.c      Sat Feb 09 09:38:11 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: var.c,v 1.76 2019/02/09 03:35:55 kre Exp $     */
+/*     $NetBSD: var.c,v 1.77 2019/02/09 09:38:11 kre Exp $     */
 
 /*-
  * Copyright (c) 1991, 1993
@@ -37,7 +37,7 @@
 #if 0
 static char sccsid[] = "@(#)var.c      8.3 (Berkeley) 5/4/95";
 #else
-__RCSID("$NetBSD: var.c,v 1.76 2019/02/09 03:35:55 kre Exp $");
+__RCSID("$NetBSD: var.c,v 1.77 2019/02/09 09:38:11 kre Exp $");
 #endif
 #endif /* not lint */
 
@@ -562,13 +562,19 @@
 lookupvar(const char *name)
 {
        struct var *v;
+       char *p;
 
        v = find_var(name, NULL, NULL);
        if (v == NULL || v->flags & VUNSET)
                return NULL;
-       if (v->rfunc && (v->flags & VFUNCREF) != 0)
-               return (*v->rfunc)(v) + v->name_len + 1;
-       return v->text + v->name_len + 1;
+       if (v->rfunc && (v->flags & VFUNCREF) != 0) {
+               p = (*v->rfunc)(v);
+               if (p == NULL)
+                       return NULL;
+       } else
+               p = v->text;
+
+       return p + v->name_len + 1;
 }
 
 
@@ -584,6 +590,7 @@
 {
        struct strlist *sp;
        struct var *v;
+       char *p;
 
        for (sp = cmdenviron ; sp ; sp = sp->next) {
                if (strequal(sp->text, name))
@@ -594,9 +601,15 @@
 
        if (v == NULL || v->flags & VUNSET || (!doall && !(v->flags & VEXPORT)))
                return NULL;
-       if (v->rfunc && (v->flags & VFUNCREF) != 0)
-               return (*v->rfunc)(v) + v->name_len + 1;
-       return v->text + v->name_len + 1;
+
+       if (v->rfunc && (v->flags & VFUNCREF) != 0) {
+               p = (*v->rfunc)(v);
+               if (p == NULL)
+                       return NULL;
+       } else
+               p = v->text;
+
+       return p + v->name_len + 1;
 }
 
 
@@ -626,9 +639,11 @@
        for (vpp = vartab ; vpp < vartab + VTABSIZE ; vpp++) {
                for (vp = *vpp ; vp ; vp = vp->next)
                        if ((vp->flags & (VEXPORT|VUNSET)) == VEXPORT) {
-                               if (vp->rfunc && (vp->flags & VFUNCREF))
-                                       *ep++ = (*vp->rfunc)(vp);
-                               else
+                               if (vp->rfunc && (vp->flags & VFUNCREF)) {
+                                       *ep = (*vp->rfunc)(vp);
+                                       if (*ep != NULL)
+                                               ep++;
+                               } else
                                        *ep++ = vp->text;
                                VTRACE(DBG_VARS, ("environment: %s\n", ep[-1]));
                        }
@@ -763,16 +778,20 @@
 {
        const char *p;
 
+       p = vp->text;
+       if (vp->rfunc && (vp->flags & VFUNCREF) != 0) {
+               p = (*vp->rfunc)(vp);
+               if (p == NULL) {
+                       if (!(show_value & 2))
+                               return;
+                       p = vp->text;
+                       show_value = 0;
+               }
+       }
        if (cmd)
                out1fmt("%s ", cmd);
        if (xtra)
                out1fmt("%s ", xtra);
-       p = vp->text;
-       if (vp->rfunc && (vp->flags & VFUNCREF) != 0) {
-               p = (*vp->rfunc)(vp);
-               if (p == NULL)
-                       p = vp->text;
-       }
        for ( ; *p != '=' ; p++)
                out1c(*p);
        if (!(vp->flags & VUNSET) && show_value) {



Home | Main Index | Thread Index | Old Index