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): replace freeIt with FStr in EvalUndefined



details:   https://anonhg.NetBSD.org/src/rev/45f82568502a
branches:  trunk
changeset: 1017266:45f82568502a
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Dec 20 10:59:21 2020 +0000

description:
make(1): replace freeIt with FStr in EvalUndefined

Previously, the parameter out_freeIt was not guaranteed to be
initialized in every case, at least when looking only at EvalUndefined.
This contradicted the variable name.

Replace the two parameters with a single FStr to ensure that these
variables are always initialized together.

diffstat:

 usr.bin/make/var.c |  31 ++++++++++++++++---------------
 1 files changed, 16 insertions(+), 15 deletions(-)

diffs (102 lines):

diff -r ca78839609ea -r 45f82568502a usr.bin/make/var.c
--- a/usr.bin/make/var.c        Sun Dec 20 10:34:33 2020 +0000
+++ b/usr.bin/make/var.c        Sun Dec 20 10:59:21 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: var.c,v 1.739 2020/12/20 00:57:29 rillig Exp $ */
+/*     $NetBSD: var.c,v 1.740 2020/12/20 10:59:21 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -131,7 +131,7 @@
 #include "metachar.h"
 
 /*     "@(#)var.c      8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: var.c,v 1.739 2020/12/20 00:57:29 rillig Exp $");
+MAKE_RCSID("$NetBSD: var.c,v 1.740 2020/12/20 10:59:21 rillig Exp $");
 
 /* A string that may need to be freed after use. */
 typedef struct FStr {
@@ -3846,13 +3846,11 @@
 static VarParseResult
 EvalUndefined(Boolean dynamic, const char *start, const char *p, char *varname,
              VarEvalFlags eflags,
-             const char **out_val, void **out_freeIt)
+             FStr *out_val)
 {
        if (dynamic) {
-               char *pstr = bmake_strsedup(start, p);
+               *out_val = FStr_InitOwn(bmake_strsedup(start, p));
                free(varname);
-               *out_val = pstr;
-               *out_freeIt = pstr;
                return VPR_OK;
        }
 
@@ -3860,18 +3858,18 @@
                Parse_Error(PARSE_FATAL,
                    "Variable \"%s\" is undefined", varname);
                free(varname);
-               *out_val = var_Error;
+               *out_val = FStr_InitRefer(var_Error);
                return VPR_UNDEF_MSG;
        }
 
        if (eflags & VARE_UNDEFERR) {
                free(varname);
-               *out_val = var_Error;
+               *out_val = FStr_InitRefer(var_Error);
                return VPR_UNDEF_SILENT;
        }
 
        free(varname);
-       *out_val = varUndefined;
+       *out_val = FStr_InitRefer(varUndefined);
        return VPR_OK;
 }
 
@@ -3888,8 +3886,7 @@
 
        const char **out_FALSE_pp,
        VarParseResult *out_FALSE_res,
-       const char **out_FALSE_val,
-       void **out_FALSE_freeIt,
+       FStr *out_FALSE_val,
 
        char *out_TRUE_endc,
        const char **out_TRUE_p,
@@ -3920,7 +3917,7 @@
                Parse_Error(PARSE_FATAL, "Unclosed variable \"%s\"", varname);
                free(varname);
                *out_FALSE_pp = p;
-               *out_FALSE_val = var_Error;
+               *out_FALSE_val = FStr_InitRefer(var_Error);
                *out_FALSE_res = VPR_PARSE_MSG;
                return FALSE;
        }
@@ -3947,7 +3944,7 @@
                        p++;    /* skip endc */
                        *out_FALSE_pp = p;
                        *out_FALSE_res = EvalUndefined(dynamic, start, p,
-                           varname, eflags, out_FALSE_val, out_FALSE_freeIt);
+                           varname, eflags, out_FALSE_val);
                        return FALSE;
                }
 
@@ -4079,11 +4076,15 @@
                p++;
        } else {
                VarParseResult res;
+               FStr fval;
                if (!ParseVarnameLong(p, startc, ctxt, eflags,
-                   pp, &res, out_val, out_val_freeIt,
+                   pp, &res, &fval,
                    &endc, &p, &v, &haveModifier, &extramodifiers,
-                   &dynamic, &exprFlags))
+                   &dynamic, &exprFlags)) {
+                       *out_val = fval.str;
+                       *out_val_freeIt = fval.freeIt;
                        return res;
+               }
        }
 
        if (v->flags & VAR_IN_USE)



Home | Main Index | Thread Index | Old Index