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): use specialized return type for ApplyM...



details:   https://anonhg.NetBSD.org/src/rev/d8f39d326ef7
branches:  trunk
changeset: 974377:d8f39d326ef7
user:      rillig <rillig%NetBSD.org@localhost>
date:      Wed Jul 29 20:57:31 2020 +0000

description:
make(1): use specialized return type for ApplyModifier functions

This makes it immediately obvious what happens after a modifier has been
applied, instead of having to translate single-character mnemonics or
booleans to their actual intention.

This also reduces the size of the binary since there are fewer jumps.

diffstat:

 usr.bin/make/Makefile |    9 +-
 usr.bin/make/var.c    |  313 ++++++++++++++++++++++++-------------------------
 2 files changed, 161 insertions(+), 161 deletions(-)

diffs (truncated from 821 to 300 lines):

diff -r fef30d75a0a0 -r d8f39d326ef7 usr.bin/make/Makefile
--- a/usr.bin/make/Makefile     Wed Jul 29 20:33:38 2020 +0000
+++ b/usr.bin/make/Makefile     Wed Jul 29 20:57:31 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.75 2020/07/26 20:04:57 rillig Exp $
+#      $NetBSD: Makefile,v 1.76 2020/07/29 20:57:31 rillig Exp $
 #      @(#)Makefile    5.2 (Berkeley) 12/28/90
 
 PROG=  make
@@ -77,3 +77,10 @@
 
 accept: .MAKE
        cd ${.CURDIR}/unit-tests && ${.MAKE} ${.TARGET}
+
+retest:
+       ${.MAKE} -C ${.CURDIR}/unit-tests cleandir
+.if ${USE_COVERAGE} == yes
+       rm -f *.gcov *.gcda
+.endif
+       ${.MAKE} test
diff -r fef30d75a0a0 -r d8f39d326ef7 usr.bin/make/var.c
--- a/usr.bin/make/var.c        Wed Jul 29 20:33:38 2020 +0000
+++ b/usr.bin/make/var.c        Wed Jul 29 20:57:31 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: var.c,v 1.355 2020/07/29 20:33:38 rillig Exp $ */
+/*     $NetBSD: var.c,v 1.356 2020/07/29 20:57:31 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.355 2020/07/29 20:33:38 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.356 2020/07/29 20:57:31 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.355 2020/07/29 20:33:38 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.356 2020/07/29 20:57:31 rillig Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -2066,6 +2066,14 @@
 
 } ApplyModifiersState;
 
+typedef enum {
+    AMR_OK,                    /* Continue parsing */
+    AMR_UNKNOWN,               /* Not a match, try others as well */
+    AMR_BAD,                   /* Error out with message */
+    AMR_CLEANUP                        /* Error out with "missing delimiter",
+                                * if st->missing_delim is set. */
+} ApplyModifierResult;
+
 /* we now have some modifiers with long names */
 static Boolean
 ModMatch(const char *mod, const char *modname, char endc)
@@ -2084,7 +2092,7 @@
 }
 
 /* :@var@...${var}...@ */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Loop(const char *mod, ApplyModifiersState *st) {
     ModifyWord_LoopArgs args;
 
@@ -2095,14 +2103,14 @@
                                  st->ctxt, NULL, NULL, NULL);
     if (args.tvar == NULL) {
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
 
     args.str = ParseModifierPart(&st->next, delim, st->eflags & ~VARE_WANTRES,
                                 st->ctxt, NULL, NULL, NULL);
     if (args.str == NULL) {
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
 
     args.eflags = st->eflags & (VARE_UNDEFERR | VARE_WANTRES);
@@ -2114,11 +2122,11 @@
     Var_Delete(args.tvar, st->ctxt);
     free(args.tvar);
     free(args.str);
-    return TRUE;
+    return AMR_OK;
 }
 
 /* :Ddefined or :Uundefined */
-static void
+static ApplyModifierResult
 ApplyModifier_Defined(const char *mod, ApplyModifiersState *st)
 {
     Buffer buf;                        /* Buffer for patterns */
@@ -2179,15 +2187,16 @@
        st->newVal = st->val;
        Buf_Destroy(&buf, TRUE);
     }
+    return AMR_OK;
 }
 
 /* :gmtime */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Gmtime(const char *mod, ApplyModifiersState *st)
 {
     if (!ModMatchEq(mod, "gmtime", st->endc)) {
        st->next = mod + 1;
-       return FALSE;
+       return AMR_UNKNOWN;
     }
 
     time_t utc;
@@ -2200,7 +2209,7 @@
        st->next = mod + 6;
     }
     st->newVal = VarStrftime(st->val, 1, utc);
-    return TRUE;
+    return AMR_OK;
 }
 
 /* :localtime */
@@ -2209,7 +2218,7 @@
 {
     if (!ModMatchEq(mod, "localtime", st->endc)) {
        st->next = mod + 1;
-       return FALSE;
+       return AMR_UNKNOWN;
     }
 
     time_t utc;
@@ -2222,25 +2231,25 @@
        st->next = mod + 9;
     }
     st->newVal = VarStrftime(st->val, 0, utc);
-    return TRUE;
+    return AMR_OK;
 }
 
 /* :hash */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Hash(const char *mod, ApplyModifiersState *st)
 {
     if (!ModMatch(mod, "hash", st->endc)) {
        st->next = mod + 1;
-       return FALSE;
+       return AMR_UNKNOWN;
     }
 
     st->newVal = VarHash(st->val);
     st->next = mod + 4;
-    return TRUE;
+    return AMR_OK;
 }
 
 /* :P */
-static void
+static ApplyModifierResult
 ApplyModifier_Path(const char *mod, ApplyModifiersState *st)
 {
     if (st->v->flags & VAR_JUNK)
@@ -2256,10 +2265,11 @@
     if (!st->newVal)
        st->newVal = bmake_strdup(st->v->name);
     st->next = mod + 1;
+    return AMR_OK;
 }
 
 /* :!cmd! */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Exclam(const char *mod, ApplyModifiersState *st)
 {
     st->next = mod + 1;
@@ -2268,7 +2278,7 @@
                                  NULL, NULL, NULL);
     if (cmd == NULL) {
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
 
     const char *emsg = NULL;
@@ -2279,20 +2289,20 @@
     free(cmd);
 
     if (emsg)
-       Error(emsg, st->val);
+       Error(emsg, st->val);   /* XXX: why still return AMR_OK? */
 
     if (st->v->flags & VAR_JUNK)
        st->v->flags |= VAR_KEEP;
-    return TRUE;
+    return AMR_OK;
 }
 
 /* :range */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Range(const char *mod, ApplyModifiersState *st)
 {
     if (!ModMatchEq(mod, "range", st->endc)) {
        st->next = mod + 1;
-       return FALSE;
+       return AMR_UNKNOWN;
     }
 
     int n;
@@ -2305,11 +2315,11 @@
        st->next = mod + 5;
     }
     st->newVal = VarRange(st->val, n);
-    return TRUE;
+    return AMR_OK;
 }
 
 /* :Mpattern or :Npattern */
-static void
+static ApplyModifierResult
 ApplyModifier_Match(const char *mod, ApplyModifiersState *st)
 {
     Boolean copy = FALSE;      /* pattern should be, or has been, copied */
@@ -2381,10 +2391,11 @@
     st->newVal = ModifyWords(st->ctxt, st->sep, st->oneBigWord, st->val,
                             callback, pattern);
     free(pattern);
+    return AMR_OK;
 }
 
 /* :S,from,to, */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Subst(const char * const mod, ApplyModifiersState *st)
 {
     ModifyWord_SubstArgs args;
@@ -2407,7 +2418,7 @@
                                  &args.lhsLen, &args.pflags, NULL);
     if (lhs == NULL) {
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
     args.lhs = lhs;
 
@@ -2415,7 +2426,7 @@
                                  &args.rhsLen, NULL, &args);
     if (rhs == NULL) {
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
     args.rhs = rhs;
 
@@ -2444,13 +2455,13 @@
 
     free(lhs);
     free(rhs);
-    return TRUE;
+    return AMR_OK;
 }
 
 #ifndef NO_REGEX
 
 /* :C,from,to, */
-static Boolean
+static ApplyModifierResult
 ApplyModifier_Regex(const char *mod, ApplyModifiersState *st)
 {
     ModifyWord_SubstRegexArgs args;
@@ -2465,7 +2476,7 @@
                                 NULL, NULL, NULL);
     if (re == NULL) {
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
 
     args.replace = ParseModifierPart(&st->next, delim, st->eflags, st->ctxt,
@@ -2473,7 +2484,7 @@
     if (args.replace == NULL) {
        free(re);
        st->missing_delim = delim;
-       return FALSE;
+       return AMR_CLEANUP;
     }
 
     for (;; st->next++) {
@@ -2496,7 +2507,7 @@
     if (error) {
        VarREError(error, &args.re, "RE substitution error");
        free(args.replace);
-       return FALSE;



Home | Main Index | Thread Index | Old Index