Module Name:    src
Committed By:   rillig
Date:           Sun Oct  4 21:08:37 UTC 2020

Modified Files:
        src/usr.bin/make: parse.c

Log Message:
make(1): hide some more implementation details from Parse_DoVar


To generate a diff of this commit:
cvs rdiff -u -r1.359 -r1.360 src/usr.bin/make/parse.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/usr.bin/make/parse.c
diff -u src/usr.bin/make/parse.c:1.359 src/usr.bin/make/parse.c:1.360
--- src/usr.bin/make/parse.c:1.359	Sun Oct  4 20:57:26 2020
+++ src/usr.bin/make/parse.c	Sun Oct  4 21:08:37 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: parse.c,v 1.359 2020/10/04 20:57:26 rillig Exp $	*/
+/*	$NetBSD: parse.c,v 1.360 2020/10/04 21:08:37 rillig Exp $	*/
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -131,7 +131,7 @@
 #include "pathnames.h"
 
 /*	"@(#)parse.c	8.3 (Berkeley) 3/19/94"	*/
-MAKE_RCSID("$NetBSD: parse.c,v 1.359 2020/10/04 20:57:26 rillig Exp $");
+MAKE_RCSID("$NetBSD: parse.c,v 1.360 2020/10/04 21:08:37 rillig Exp $");
 
 /* types and constants */
 
@@ -1807,10 +1807,10 @@ VarCheckSyntax(VarAssignOp type, const c
 }
 
 static Boolean
-VarAssign_Eval(VarAssign *var,
-	  const char *const uvalue, const char **out_avalue, char **out_evalue,
-	  GNode *ctxt)
+VarAssign_Eval(VarAssign *var, GNode *ctxt,
+	       const char **out_avalue, void **out_avalue_freeIt)
 {
+    const char *uvalue = var->value;
     const char *name = var->varname;
     const VarAssignOp type = var->op;
     const char *avalue = uvalue;
@@ -1857,7 +1857,8 @@ VarAssign_Eval(VarAssign *var,
 	     * expansion on the whole thing. The resulting string will need
 	     * freeing when we're done.
 	     */
-	    (void)Var_Subst(uvalue, VAR_CMD, VARE_UNDEFERR|VARE_WANTRES, &evalue);
+	    (void)Var_Subst(uvalue, VAR_CMD, VARE_UNDEFERR|VARE_WANTRES,
+			    &evalue);
 	    /* TODO: handle errors */
 	    avalue = evalue;
 	}
@@ -1869,15 +1870,17 @@ VarAssign_Eval(VarAssign *var,
 	if (error)
 	    Parse_Error(PARSE_WARNING, error, avalue);
     } else {
-	if (type == VAR_DEFAULT && Var_Exists(var->varname, ctxt))
+	if (type == VAR_DEFAULT && Var_Exists(var->varname, ctxt)) {
+	    *out_avalue_freeIt = NULL;
 	    return FALSE;
+	}
 
 	/* Normal assignment -- just do it. */
 	Var_Set(name, uvalue, ctxt);
     }
 
     *out_avalue = avalue;
-    *out_evalue = evalue;
+    *out_avalue_freeIt = evalue;
     return TRUE;
 }
 
@@ -1917,20 +1920,16 @@ VarAssignSpecial(const char *name, const
 void
 Parse_DoVar(VarAssign *var, GNode *ctxt)
 {
-    const char *uvalue;		/* unexpanded value */
-    const char *avalue;		/* actual value */
-    char *evalue = NULL;	/* expanded value */
+    const char *avalue;		/* actual value (maybe expanded) */
+    void *avalue_freeIt;
 
     ParseVarassignOp(var);
 
-    uvalue = var->value;
-    avalue = uvalue;
-
-    VarCheckSyntax(var->op, uvalue, ctxt);
-    if (VarAssign_Eval(var, uvalue, &avalue, &evalue, ctxt))
+    VarCheckSyntax(var->op, var->value, ctxt);
+    if (VarAssign_Eval(var, ctxt, &avalue, &avalue_freeIt))
 	VarAssignSpecial(var->varname, avalue);
 
-    free(evalue);
+    free(avalue_freeIt);
     free(var->varname);
 }
 

Reply via email to