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): split local variable into two
details: https://anonhg.NetBSD.org/src/rev/c6409c3eb9bb
branches: trunk
changeset: 974250:c6409c3eb9bb
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Jul 26 19:11:06 2020 +0000
description:
make(1): split local variable into two
Reusing a const char * parameter to store a char * and later free that
string was not a good idea. It made the pretty long code of Var_Parse
more difficult to understand.
diffstat:
usr.bin/make/var.c | 49 +++++++++++++++++++++++++------------------------
1 files changed, 25 insertions(+), 24 deletions(-)
diffs (141 lines):
diff -r c0dd39570a29 -r c6409c3eb9bb usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Jul 26 18:53:50 2020 +0000
+++ b/usr.bin/make/var.c Sun Jul 26 19:11:06 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.324 2020/07/26 18:47:02 rillig Exp $ */
+/* $NetBSD: var.c,v 1.325 2020/07/26 19:11:06 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.324 2020/07/26 18:47:02 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.325 2020/07/26 19:11:06 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.324 2020/07/26 18:47:02 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.325 2020/07/26 19:11:06 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -3452,7 +3452,7 @@
return (flags & VARE_UNDEFERR) ? var_Error : varNoError;
} else {
haveModifier = FALSE;
- tstr = &str[1];
+ tstr = str + 1;
endc = str[1];
}
} else {
@@ -3501,10 +3501,11 @@
Buf_Destroy(&buf, TRUE);
return var_Error;
}
- str = Buf_GetAll(&buf, &vlen);
+
+ char *varname = Buf_GetAll(&buf, &vlen);
/*
- * At this point, str points into newly allocated memory from
+ * At this point, varname points into newly allocated memory from
* buf, containing only the name of the variable.
*
* start and tstr point into the const string that was pointed
@@ -3514,23 +3515,23 @@
* will be '\0', ':', PRCLOSE, or BRCLOSE.
*/
- v = VarFind(str, ctxt, FIND_ENV | FIND_GLOBAL | FIND_CMD);
+ v = VarFind(varname, ctxt, FIND_ENV | FIND_GLOBAL | FIND_CMD);
/*
* Check also for bogus D and F forms of local variables since we're
* in a local context and the name is the right length.
*/
- if ((v == NULL) && (ctxt != VAR_CMD) && (ctxt != VAR_GLOBAL) &&
- (vlen == 2) && (str[1] == 'F' || str[1] == 'D') &&
- strchr("@%?*!<>", str[0]) != NULL) {
+ if (v == NULL && ctxt != VAR_CMD && ctxt != VAR_GLOBAL &&
+ vlen == 2 && (varname[1] == 'F' || varname[1] == 'D') &&
+ strchr("@%?*!<>", varname[0]) != NULL) {
/*
* Well, it's local -- go look for it.
*/
- name[0] = *str;
+ name[0] = varname[0];
name[1] = '\0';
v = VarFind(name, ctxt, 0);
if (v != NULL) {
- if (str[1] == 'D') {
+ if (varname[1] == 'D') {
extramodifiers = "H:";
} else { /* F */
extramodifiers = "T:";
@@ -3539,9 +3540,9 @@
}
if (v == NULL) {
- if (((vlen == 1) ||
- (((vlen == 2) && (str[1] == 'F' || str[1] == 'D')))) &&
- ((ctxt == VAR_CMD) || (ctxt == VAR_GLOBAL)))
+ if ((vlen == 1 ||
+ ((vlen == 2 && (varname[1] == 'F' || varname[1] == 'D')))) &&
+ (ctxt == VAR_CMD || ctxt == VAR_GLOBAL))
{
/*
* If substituting a local variable in a non-local context,
@@ -3552,7 +3553,7 @@
* specially as they are the only four that will be set
* when dynamic sources are expanded.
*/
- switch (*str) {
+ switch (varname[0]) {
case '@':
case '%':
case '*':
@@ -3560,15 +3561,15 @@
dynamic = TRUE;
break;
}
- } else if (vlen > 2 && *str == '.' &&
- isupper((unsigned char) str[1]) &&
+ } else if (vlen > 2 && varname[0] == '.' &&
+ isupper((unsigned char) varname[1]) &&
(ctxt == VAR_CMD || ctxt == VAR_GLOBAL))
{
int len = vlen - 1;
- if ((strncmp(str, ".TARGET", len) == 0) ||
- (strncmp(str, ".ARCHIVE", len) == 0) ||
- (strncmp(str, ".PREFIX", len) == 0) ||
- (strncmp(str, ".MEMBER", len) == 0))
+ if ((strncmp(varname, ".TARGET", len) == 0) ||
+ (strncmp(varname, ".ARCHIVE", len) == 0) ||
+ (strncmp(varname, ".PREFIX", len) == 0) ||
+ (strncmp(varname, ".MEMBER", len) == 0))
{
dynamic = TRUE;
}
@@ -3595,7 +3596,7 @@
* so kludge up a Var structure for the modifications
*/
v = bmake_malloc(sizeof(Var));
- v->name = UNCONST(str);
+ v->name = varname;
Buf_Init(&v->val, 1);
v->flags = VAR_JUNK;
Buf_Destroy(&buf, FALSE);
@@ -3668,7 +3669,7 @@
/*
* Perform any free'ing needed and set *freePtr to NULL so the caller
* doesn't try to free a static pointer.
- * If VAR_KEEP is also set then we want to keep str as is.
+ * If VAR_KEEP is also set then we want to keep str(?) as is.
*/
if (!(v->flags & VAR_KEEP)) {
if (*freePtr) {
Home |
Main Index |
Thread Index |
Old Index