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): reduce scope of variables
details: https://anonhg.NetBSD.org/src/rev/878fdeb4ae6e
branches: trunk
changeset: 1012576:878fdeb4ae6e
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Aug 02 18:23:00 2020 +0000
description:
make(1): reduce scope of variables
This groups the variables by topic and only introduces them when they
are actually needed. The compiler doesn't care, but during a debugging
session this means fewer uninitialized variables.
In VarUniq, the variable i has been split into two. All others remain
exactly as before, just with a smaller scope.
diffstat:
usr.bin/make/var.c | 178 ++++++++++++++++++++++++----------------------------
1 files changed, 81 insertions(+), 97 deletions(-)
diffs (truncated from 537 to 300 lines):
diff -r cd144cdbd763 -r 878fdeb4ae6e usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Aug 02 17:10:54 2020 +0000
+++ b/usr.bin/make/var.c Sun Aug 02 18:23:00 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.400 2020/08/02 17:10:54 rillig Exp $ */
+/* $NetBSD: var.c,v 1.401 2020/08/02 18:23:00 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.400 2020/08/02 17:10:54 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.401 2020/08/02 18:23:00 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.400 2020/08/02 17:10:54 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.401 2020/08/02 18:23:00 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -468,9 +468,6 @@
Var_Export1(const char *name, VarExportFlags flags)
{
char tmp[BUFSIZ];
- Var *v;
- char *val = NULL;
- int n;
VarExportFlags parent = flags & VAR_EXPORT_PARENT;
if (*name == '.')
@@ -490,12 +487,15 @@
return 0;
}
}
- v = VarFind(name, VAR_GLOBAL, 0);
+
+ Var *v = VarFind(name, VAR_GLOBAL, 0);
if (v == NULL)
return 0;
+
if (!parent && (v->flags & VAR_EXPORTED) && !(v->flags & VAR_REEXPORT))
return 0; /* nothing to do */
- val = Buf_GetAllZ(&v->val, NULL);
+
+ char *val = Buf_GetAllZ(&v->val, NULL);
if (!(flags & VAR_EXPORT_LITERAL) && strchr(val, '$')) {
if (parent) {
/*
@@ -513,7 +513,7 @@
*/
return 0;
}
- n = snprintf(tmp, sizeof(tmp), "${%s}", name);
+ int n = snprintf(tmp, sizeof(tmp), "${%s}", name);
if (n < (int)sizeof(tmp)) {
val = Var_Subst(tmp, VAR_GLOBAL, VARE_WANTRES);
setenv(name, val, 1);
@@ -547,15 +547,13 @@
void
Var_ExportVars(void)
{
- char tmp[BUFSIZ];
- char *val;
-
/*
* Several make's support this sort of mechanism for tracking
* recursion - but each uses a different name.
* We allow the makefiles to update MAKELEVEL and ensure
* children see a correctly incremented value.
*/
+ char tmp[BUFSIZ];
snprintf(tmp, sizeof(tmp), "%d", makelevel + 1);
setenv(MAKE_LEVEL_ENV, tmp, 1);
@@ -568,7 +566,7 @@
return;
}
- val = Var_Subst("${" MAKE_EXPORTED ":O:u}", VAR_GLOBAL, VARE_WANTRES);
+ char *val = Var_Subst("${" MAKE_EXPORTED ":O:u}", VAR_GLOBAL, VARE_WANTRES);
if (*val) {
char **av;
char *as;
@@ -591,18 +589,12 @@
void
Var_Export(char *str, int isExport)
{
- char **av;
- char *as;
- VarExportFlags flags;
- int ac;
- int i;
-
if (isExport && (!str || !str[0])) {
var_exportedVars = VAR_EXPORTED_ALL; /* use with caution! */
return;
}
- flags = 0;
+ VarExportFlags flags = 0;
if (strncmp(str, "-env", 4) == 0) {
str += 4;
} else if (strncmp(str, "-literal", 8) == 0) {
@@ -614,7 +606,11 @@
char *val = Var_Subst(str, VAR_GLOBAL, VARE_WANTRES);
if (*val) {
- av = brk_string(val, &ac, FALSE, &as);
+ char *as;
+ int ac;
+ char **av = brk_string(val, &ac, FALSE, &as);
+
+ int i;
for (i = 0; i < ac; i++) {
const char *name = av[i];
if (!name[1]) {
@@ -660,13 +656,12 @@
char tmp[BUFSIZ];
char *vlist;
char *cp;
- Boolean unexport_env;
int n;
vlist = NULL;
str += strlen("unexport");
- unexport_env = strncmp(str, "-env", 4) == 0;
+ Boolean unexport_env = strncmp(str, "-env", 4) == 0;
if (unexport_env) {
char **newenv;
@@ -748,7 +743,6 @@
Var_Set_with_flags(const char *name, const char *val, GNode *ctxt,
VarSet_Flags flags)
{
- Var *v;
char *name_freeIt = NULL;
/*
@@ -770,6 +764,7 @@
}
}
+ Var *v;
if (ctxt == VAR_GLOBAL) {
v = VarFind(name, VAR_CMD, 0);
if (v != NULL) {
@@ -895,8 +890,6 @@
void
Var_Append(const char *name, const char *val, GNode *ctxt)
{
- Var *v;
- Hash_Entry *h;
char *expanded_name = NULL;
if (strchr(name, '$') != NULL) {
@@ -913,7 +906,7 @@
name = expanded_name;
}
- v = VarFind(name, ctxt, ctxt == VAR_GLOBAL ? (FIND_CMD | FIND_ENV) : 0);
+ Var *v = VarFind(name, ctxt, ctxt == VAR_GLOBAL ? (FIND_CMD | FIND_ENV) : 0);
if (v == NULL) {
Var_Set(name, val, ctxt);
@@ -934,7 +927,7 @@
* export other variables...)
*/
v->flags &= ~VAR_FROM_ENV;
- h = Hash_CreateEntry(&ctxt->context, name, NULL);
+ Hash_Entry *h = Hash_CreateEntry(&ctxt->context, name, NULL);
Hash_SetValue(h, v);
}
}
@@ -1307,11 +1300,8 @@
static void
VarREError(int reerr, regex_t *pat, const char *str)
{
- char *errbuf;
- int errlen;
-
- errlen = regerror(reerr, pat, 0, 0);
- errbuf = bmake_malloc(errlen);
+ int errlen = regerror(reerr, pat, 0, 0);
+ char *errbuf = bmake_malloc(errlen);
regerror(reerr, pat, errbuf, errlen);
Error("%s: %s", str, errbuf);
free(errbuf);
@@ -1451,13 +1441,11 @@
int last)
{
SepBuf buf;
+ SepBuf_Init(&buf, sep);
+
char **av; /* word list */
char *as; /* word list memory */
- int ac, i;
- int start, end, step;
-
- SepBuf_Init(&buf, sep);
-
+ int ac;
if (oneBigWord) {
/* fake what brk_string() would do if there were only one word */
ac = 1;
@@ -1482,6 +1470,7 @@
/*
* We avoid scanning more of the list than we need to.
*/
+ int start, end, step;
if (first > last) {
start = MIN(ac, first) - 1;
end = MAX(0, last - 1);
@@ -1492,6 +1481,7 @@
step = 1;
}
+ int i;
for (i = start; (step < 0) == (i >= end); i += step) {
SepBuf_AddStr(&buf, av[i]);
SepBuf_Sep(&buf);
@@ -1544,12 +1534,11 @@
}
SepBuf result;
+ SepBuf_Init(&result, sep);
+
char **av; /* word list */
char *as; /* word list memory */
- int ac, i;
-
- SepBuf_Init(&result, sep);
-
+ int ac;
av = brk_string(str, &ac, FALSE, &as);
if (DEBUG(VAR)) {
@@ -1557,6 +1546,7 @@
str, ac);
}
+ int i;
for (i = 0; i < ac; i++) {
modifyWord(av[i], &result, data);
if (result.buf.count > 0)
@@ -1573,15 +1563,13 @@
static int
VarWordCompare(const void *a, const void *b)
{
- int r = strcmp(*(const char * const *)a, *(const char * const *)b);
- return r;
+ return strcmp(*(const char * const *)a, *(const char * const *)b);
}
static int
VarWordCompareReverse(const void *a, const void *b)
{
- int r = strcmp(*(const char * const *)b, *(const char * const *)a);
- return r;
+ return strcmp(*(const char * const *)b, *(const char * const *)a);
}
/*-
@@ -1601,12 +1589,11 @@
VarOrder(const char *str, const char otype)
{
Buffer buf; /* Buffer for the new string */
+ Buf_InitZ(&buf, 0);
+
char **av; /* word list */
char *as; /* word list memory */
- int ac, i;
-
- Buf_InitZ(&buf, 0);
-
+ int ac;
av = brk_string(str, &ac, FALSE, &as);
if (ac > 0) {
@@ -1624,6 +1611,8 @@
* reasonable value for mod factor is 2 (the mod 1 will produce
* 0 with probability 1).
*/
+ (void)0;
+ int i;
for (i = ac - 1; i > 0; i--) {
int rndidx = random() % (i + 1);
char *t = av[i];
@@ -1633,6 +1622,7 @@
}
}
+ int i;
for (i = 0; i < ac; i++) {
Home |
Main Index |
Thread Index |
Old Index