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): refactor Compat_Run to show the error ...
details:   https://anonhg.NetBSD.org/src/rev/91b575036946
branches:  trunk
changeset: 946730:91b575036946
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Dec 06 23:02:56 2020 +0000
description:
make(1): refactor Compat_Run to show the error condition more clearly
This refactoring allows to gradually change the conditions for the
"Stop." error message, to demonstrate which cases are affected by each
tiny change.
diffstat:
 usr.bin/make/compat.c |  34 +++++++++++++++++++++-------------
 1 files changed, 21 insertions(+), 13 deletions(-)
diffs (76 lines):
diff -r 4101629c2f92 -r 91b575036946 usr.bin/make/compat.c
--- a/usr.bin/make/compat.c     Sun Dec 06 22:49:40 2020 +0000
+++ b/usr.bin/make/compat.c     Sun Dec 06 23:02:56 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: compat.c,v 1.197 2020/12/06 22:49:40 rillig Exp $      */
+/*     $NetBSD: compat.c,v 1.198 2020/12/06 23:02:56 rillig Exp $      */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -96,7 +96,7 @@
 #include "pathnames.h"
 
 /*     "@(#)compat.c   8.2 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: compat.c,v 1.197 2020/12/06 22:49:40 rillig Exp $");
+MAKE_RCSID("$NetBSD: compat.c,v 1.198 2020/12/06 23:02:56 rillig Exp $");
 
 static GNode *curTarg = NULL;
 static pid_t compatChild;
@@ -664,8 +664,9 @@
 Compat_Run(GNodeList *targs)
 {
        GNode *gn = NULL;       /* Current root target */
-       int indirectErrors;     /* Number of targets not remade due to errors */
-       Boolean seenError;
+       Boolean mainError;
+       Boolean mainDepError;
+       Boolean endError;
 
        if (!shellName)
                Shell_Init();
@@ -705,7 +706,7 @@
         */
        Make_ExpandUse(targs);
 
-       indirectErrors = 0;
+       mainDepError = FALSE;
        while (!Lst_IsEmpty(targs)) {
                gn = Lst_Dequeue(targs);
                Compat_Make(gn, gn);
@@ -715,21 +716,28 @@
                } else if (gn->made == ABORTED) {
                        printf("`%s' not remade because of errors.\n",
                               gn->name);
-                       indirectErrors++;
+                       mainDepError = TRUE;
                }
        }
 
        /*
+        * XXX: what about multiple main targets if the first few fail but
+        * the last one succeeds?  This should not count as overall success.
+        */
+       mainError = GNode_IsError(gn);
+
+       /*
         * If the user has defined a .END target, run its commands.
         */
-       seenError = indirectErrors > 0;
-       if (!seenError) {
+       if (!mainDepError) {
                GNode *endNode = Targ_GetEndNode();
                Compat_Make(endNode, endNode);
-               seenError = GNode_IsError(gn) || GNode_IsError(endNode);
-               if (seenError) {
-                       PrintOnError(gn, "\nStop.");
-                       exit(1);
-               }
+               endError = GNode_IsError(endNode);
+       } else
+               endError = FALSE;
+
+       if (!mainDepError && (mainError || endError)) {
+               PrintOnError(gn, "\nStop.");
+               exit(1);
        }
 }
Home |
Main Index |
Thread Index |
Old Index