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): trust that Var_Subst never returns NULL
details: https://anonhg.NetBSD.org/src/rev/cc915a6fbc4b
branches: trunk
changeset: 1013511:cc915a6fbc4b
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Aug 29 13:16:54 2020 +0000
description:
make(1): trust that Var_Subst never returns NULL
It really never does, and it doesn't even report errors. It just
returns the content of the buffer, up to the first parse error.
diffstat:
usr.bin/make/main.c | 19 +++++++------------
usr.bin/make/make.c | 8 ++++----
usr.bin/make/meta.c | 16 ++++++----------
usr.bin/make/suff.c | 9 +++++----
usr.bin/make/var.c | 23 ++++++++++-------------
5 files changed, 32 insertions(+), 43 deletions(-)
diffs (247 lines):
diff -r 7359a126f536 -r cc915a6fbc4b usr.bin/make/main.c
--- a/usr.bin/make/main.c Sat Aug 29 13:04:30 2020 +0000
+++ b/usr.bin/make/main.c Sat Aug 29 13:16:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: main.c,v 1.328 2020/08/29 13:04:30 rillig Exp $ */
+/* $NetBSD: main.c,v 1.329 2020/08/29 13:16:54 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,7 +69,7 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: main.c,v 1.328 2020/08/29 13:04:30 rillig Exp $";
+static char rcsid[] = "$NetBSD: main.c,v 1.329 2020/08/29 13:16:54 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
@@ -81,7 +81,7 @@
#if 0
static char sccsid[] = "@(#)main.c 8.3 (Berkeley) 3/19/94";
#else
-__RCSID("$NetBSD: main.c,v 1.328 2020/08/29 13:04:30 rillig Exp $");
+__RCSID("$NetBSD: main.c,v 1.329 2020/08/29 13:16:54 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -1349,13 +1349,11 @@
Fatal("%s: cannot open %s.", progname,
(char *)Lst_Datum(ln));
} else {
- p1 = Var_Subst("${" MAKEFILE_PREFERENCE "}",
- VAR_CMD, VARE_WANTRES);
- if (p1) {
+ p1 = Var_Subst("${" MAKEFILE_PREFERENCE "}",
+ VAR_CMD, VARE_WANTRES);
(void)str2Lst_Append(makefiles, p1, NULL);
(void)Lst_Find(makefiles, ReadMakefileSucceeded, NULL);
free(p1);
- }
}
/* In particular suppress .depend for '-r -V .OBJDIR -f /dev/null' */
@@ -2044,11 +2042,8 @@
}
expr = "${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'\n@}";
cp = Var_Subst(expr, VAR_GLOBAL, VARE_WANTRES);
- if (cp) {
- if (*cp)
- printf("%s", cp);
- free(cp);
- }
+ printf("%s", cp);
+ free(cp);
fflush(stdout);
/*
diff -r 7359a126f536 -r cc915a6fbc4b usr.bin/make/make.c
--- a/usr.bin/make/make.c Sat Aug 29 13:04:30 2020 +0000
+++ b/usr.bin/make/make.c Sat Aug 29 13:16:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: make.c,v 1.129 2020/08/28 04:48:57 rillig Exp $ */
+/* $NetBSD: make.c,v 1.130 2020/08/29 13:16:54 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: make.c,v 1.129 2020/08/28 04:48:57 rillig Exp $";
+static char rcsid[] = "$NetBSD: make.c,v 1.130 2020/08/29 13:16:54 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
#if 0
static char sccsid[] = "@(#)make.c 8.1 (Berkeley) 6/6/93";
#else
-__RCSID("$NetBSD: make.c,v 1.129 2020/08/28 04:48:57 rillig Exp $");
+__RCSID("$NetBSD: make.c,v 1.130 2020/08/29 13:16:54 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -500,7 +500,7 @@
free(gn->name);
}
gn->name = Var_Subst(gn->uname, pgn, VARE_WANTRES);
- if (gn->name && gn->uname && strcmp(gn->name, gn->uname) != 0) {
+ if (gn->uname && strcmp(gn->name, gn->uname) != 0) {
/* See if we have a target for this node. */
GNode *tgn = Targ_FindNode(gn->name, TARG_NOCREATE);
if (tgn != NULL)
diff -r 7359a126f536 -r cc915a6fbc4b usr.bin/make/meta.c
--- a/usr.bin/make/meta.c Sat Aug 29 13:04:30 2020 +0000
+++ b/usr.bin/make/meta.c Sat Aug 29 13:16:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: meta.c,v 1.110 2020/08/29 10:41:12 rillig Exp $ */
+/* $NetBSD: meta.c,v 1.111 2020/08/29 13:16:54 rillig Exp $ */
/*
* Implement 'meta' mode.
@@ -368,13 +368,13 @@
{
meta_file_t *mfp = mfpp;
char *cmd = cmdp;
- char *cp = NULL;
+ char *cmd_freeIt = NULL;
if (strchr(cmd, '$')) {
- cmd = cp = Var_Subst(cmd, mfp->gn, VARE_WANTRES);
+ cmd = cmd_freeIt = Var_Subst(cmd, mfp->gn, VARE_WANTRES);
}
fprintf(mfp->fp, "CMD %s\n", cmd);
- free(cp);
+ free(cmd_freeIt);
return 0;
}
@@ -628,9 +628,7 @@
metaBailiwick = Lst_Init();
metaBailiwickStr = Var_Subst("${.MAKE.META.BAILIWICK:O:u:tA}",
VAR_GLOBAL, VARE_WANTRES);
- if (metaBailiwickStr) {
- str2Lst_Append(metaBailiwick, metaBailiwickStr, NULL);
- }
+ str2Lst_Append(metaBailiwick, metaBailiwickStr, NULL);
/*
* We ignore any paths that start with ${.MAKE.META.IGNORE_PATHS}
*/
@@ -639,9 +637,7 @@
"/dev /etc /proc /tmp /var/run /var/tmp ${TMPDIR}", VAR_GLOBAL);
metaIgnorePathsStr = Var_Subst("${" MAKE_META_IGNORE_PATHS ":O:u:tA}",
VAR_GLOBAL, VARE_WANTRES);
- if (metaIgnorePathsStr) {
- str2Lst_Append(metaIgnorePaths, metaIgnorePathsStr, NULL);
- }
+ str2Lst_Append(metaIgnorePaths, metaIgnorePathsStr, NULL);
/*
* We ignore any paths that match ${.MAKE.META.IGNORE_PATTERNS}
diff -r 7359a126f536 -r cc915a6fbc4b usr.bin/make/suff.c
--- a/usr.bin/make/suff.c Sat Aug 29 13:04:30 2020 +0000
+++ b/usr.bin/make/suff.c Sat Aug 29 13:16:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: suff.c,v 1.134 2020/08/29 12:01:46 rillig Exp $ */
+/* $NetBSD: suff.c,v 1.135 2020/08/29 13:16:54 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: suff.c,v 1.134 2020/08/29 12:01:46 rillig Exp $";
+static char rcsid[] = "$NetBSD: suff.c,v 1.135 2020/08/29 13:16:54 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
#if 0
static char sccsid[] = "@(#)suff.c 8.4 (Berkeley) 3/21/94";
#else
-__RCSID("$NetBSD: suff.c,v 1.134 2020/08/29 12:01:46 rillig Exp $");
+__RCSID("$NetBSD: suff.c,v 1.135 2020/08/29 13:16:54 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -1281,7 +1281,7 @@
}
cp = Var_Subst(cgn->name, pgn, VARE_UNDEFERR|VARE_WANTRES);
- if (cp != NULL) {
+ {
Lst members = Lst_Init();
if (cgn->type & OP_ARCHV) {
@@ -1384,6 +1384,7 @@
*/
free(cp);
}
+
if (DEBUG(SUFF)) {
fprintf(debug_file, "\n");
}
diff -r 7359a126f536 -r cc915a6fbc4b usr.bin/make/var.c
--- a/usr.bin/make/var.c Sat Aug 29 13:04:30 2020 +0000
+++ b/usr.bin/make/var.c Sat Aug 29 13:16:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.476 2020/08/29 12:48:17 rillig Exp $ */
+/* $NetBSD: var.c,v 1.477 2020/08/29 13:16:54 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.476 2020/08/29 12:48:17 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.477 2020/08/29 13:16:54 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.476 2020/08/29 12:48:17 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.477 2020/08/29 13:16:54 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -721,7 +721,7 @@
VAR_GLOBAL, VARE_WANTRES);
}
- if (TRUE) {
+ {
Var *v;
char **av;
char *as;
@@ -1464,14 +1464,12 @@
VAR_DEBUG("ModifyWord_Loop: in \"%s\", replace \"%s\" with \"%s\" "
"to \"%s\"\n",
- word, args->tvar, args->str, s ? s : "(null)");
-
- if (s != NULL && s[0] != '\0') {
- if (s[0] == '\n' || (buf->buf.count > 0 &&
- buf->buf.buffer[buf->buf.count - 1] == '\n'))
- buf->needSep = FALSE;
- SepBuf_AddStr(buf, s);
- }
+ word, args->tvar, args->str, s);
+
+ if (s[0] == '\n' || (buf->buf.count > 0 &&
+ buf->buf.buffer[buf->buf.count - 1] == '\n'))
+ buf->needSep = FALSE;
+ SepBuf_AddStr(buf, s);
free(s);
}
@@ -3615,7 +3613,6 @@
if (strchr(nstr, '$') != NULL && (eflags & VARE_WANTRES) != 0) {
nstr = Var_Subst(nstr, ctxt, eflags);
*freePtr = nstr;
- assert(nstr != NULL);
}
v->flags &= ~(unsigned)VAR_IN_USE;
Home |
Main Index |
Thread Index |
Old Index