Source-Changes-HG archive

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

[src/trunk]: src/usr.bin/make make(1): extract code for dynamic variable name...



details:   https://anonhg.NetBSD.org/src/rev/f64e271f42cc
branches:  trunk
changeset: 974269:f64e271f42cc
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Jul 26 22:43:16 2020 +0000

description:
make(1): extract code for dynamic variable names out of Var_Parse

diffstat:

 usr.bin/make/var.c |  79 +++++++++++++++++++++++++++++------------------------
 1 files changed, 43 insertions(+), 36 deletions(-)

diffs (113 lines):

diff -r 5ce96cfdf2f9 -r f64e271f42cc usr.bin/make/var.c
--- a/usr.bin/make/var.c        Sun Jul 26 22:40:52 2020 +0000
+++ b/usr.bin/make/var.c        Sun Jul 26 22:43:16 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: var.c,v 1.334 2020/07/26 22:19:11 rillig Exp $ */
+/*     $NetBSD: var.c,v 1.335 2020/07/26 22:43:16 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.334 2020/07/26 22:19:11 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.335 2020/07/26 22:43:16 rillig Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)var.c      8.3 (Berkeley) 3/19/94";
 #else
-__RCSID("$NetBSD: var.c,v 1.334 2020/07/26 22:19:11 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.335 2020/07/26 22:43:16 rillig Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -3358,6 +3358,45 @@
     return var_Error;
 }
 
+static Boolean
+VarIsDynamic(GNode *ctxt, const char *varname, size_t namelen)
+{
+    if ((namelen == 1 ||
+        (namelen == 2 && (varname[1] == 'F' || varname[1] == 'D'))) &&
+       (ctxt == VAR_CMD || ctxt == VAR_GLOBAL))
+    {
+       /*
+        * If substituting a local variable in a non-local context,
+        * assume it's for dynamic source stuff. We have to handle
+        * this specially and return the longhand for the variable
+        * with the dollar sign escaped so it makes it back to the
+        * caller. Only four of the local variables are treated
+        * specially as they are the only four that will be set
+        * when dynamic sources are expanded.
+        */
+       switch (varname[0]) {
+       case '@':
+       case '%':
+       case '*':
+       case '!':
+           return TRUE;
+       }
+       return FALSE;
+    }
+
+    if (namelen > 2 && varname[0] == '.' &&
+       isupper((unsigned char) varname[1]) &&
+       (ctxt == VAR_CMD || ctxt == VAR_GLOBAL))
+    {
+       return strcmp(varname, ".TARGET") == 0 ||
+           strcmp(varname, ".ARCHIVE") == 0 ||
+           strcmp(varname, ".PREFIX") == 0 ||
+           strcmp(varname, ".MEMBER") == 0;
+    }
+
+    return FALSE;
+}
+
 /*-
  *-----------------------------------------------------------------------
  * Var_Parse --
@@ -3542,39 +3581,7 @@
        }
 
        if (v == NULL) {
-           if ((namelen == 1 ||
-                (namelen == 2 && (varname[1] == 'F' || varname[1] == 'D'))) &&
-               (ctxt == VAR_CMD || ctxt == VAR_GLOBAL))
-           {
-               /*
-                * If substituting a local variable in a non-local context,
-                * assume it's for dynamic source stuff. We have to handle
-                * this specially and return the longhand for the variable
-                * with the dollar sign escaped so it makes it back to the
-                * caller. Only four of the local variables are treated
-                * specially as they are the only four that will be set
-                * when dynamic sources are expanded.
-                */
-               switch (varname[0]) {
-               case '@':
-               case '%':
-               case '*':
-               case '!':
-                   dynamic = TRUE;
-                   break;
-               }
-           } else if (namelen > 2 && varname[0] == '.' &&
-                      isupper((unsigned char) varname[1]) &&
-                      (ctxt == VAR_CMD || ctxt == VAR_GLOBAL))
-           {
-               if ((strcmp(varname, ".TARGET") == 0) ||
-                   (strcmp(varname, ".ARCHIVE") == 0) ||
-                   (strcmp(varname, ".PREFIX") == 0) ||
-                   (strcmp(varname, ".MEMBER") == 0))
-               {
-                   dynamic = TRUE;
-               }
-           }
+           dynamic = VarIsDynamic(ctxt, varname, namelen);
 
            if (!haveModifier) {
                /*



Home | Main Index | Thread Index | Old Index