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): hide some more implementation details ...
details: https://anonhg.NetBSD.org/src/rev/0c947e49e752
branches: trunk
changeset: 955603:0c947e49e752
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Oct 04 21:08:37 2020 +0000
description:
make(1): hide some more implementation details from Parse_DoVar
diffstat:
usr.bin/make/parse.c | 33 ++++++++++++++++-----------------
1 files changed, 16 insertions(+), 17 deletions(-)
diffs (88 lines):
diff -r 318b85282bb3 -r 0c947e49e752 usr.bin/make/parse.c
--- a/usr.bin/make/parse.c Sun Oct 04 20:57:26 2020 +0000
+++ b/usr.bin/make/parse.c Sun Oct 04 21:08:37 2020 +0000
@@ -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 @@
}
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 @@
* 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 @@
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 @@
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);
}
Home |
Main Index |
Thread Index |
Old Index