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): fix error handling for dependency of ....



details:   https://anonhg.NetBSD.org/src/rev/385ebf8c42c9
branches:  trunk
changeset: 1016582:385ebf8c42c9
user:      rillig <rillig%NetBSD.org@localhost>
date:      Tue Nov 24 18:17:45 2020 +0000

description:
make(1): fix error handling for dependency of .END in -k mode

Fix one bug, find 4 new ones.  All these bugs have been around since
2005-05-08, when dependencies on the .BEGIN, .END and .INTERRUPT nodes
were implemented.  Before that, checking gn->made == ERROR was
appropriate, but adding the dependencies made ABORTED a new possible
error value from Compat_Make.

diffstat:

 usr.bin/make/compat.c                                |  9 ++++++---
 usr.bin/make/job.c                                   |  6 ++++--
 usr.bin/make/make.h                                  |  8 +++++++-
 usr.bin/make/unit-tests/deptgt-end-fail-indirect.exp |  5 ++++-
 4 files changed, 21 insertions(+), 7 deletions(-)

diffs (112 lines):

diff -r 5c37ee6d506e -r 385ebf8c42c9 usr.bin/make/compat.c
--- a/usr.bin/make/compat.c     Tue Nov 24 17:59:42 2020 +0000
+++ b/usr.bin/make/compat.c     Tue Nov 24 18:17:45 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: compat.c,v 1.190 2020/11/24 17:42:31 rillig Exp $      */
+/*     $NetBSD: compat.c,v 1.191 2020/11/24 18:17:45 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.190 2020/11/24 17:42:31 rillig Exp $");
+MAKE_RCSID("$NetBSD: compat.c,v 1.191 2020/11/24 18:17:45 rillig Exp $");
 
 static GNode *curTarg = NULL;
 static pid_t compatChild;
@@ -639,6 +639,8 @@
        if (gn->made == UNMADE && (gn == pgn || !(pgn->type & OP_MADE))) {
                if (!MakeUnmade(gn, pgn))
                        goto cohorts;
+
+               /* XXX: Replace with GNode_IsError(gn) */
        } else if (gn->made == ERROR) {
                /*
                 * Already had an error when making this.
@@ -689,6 +691,7 @@
                gn = Targ_FindNode(".BEGIN");
                if (gn != NULL) {
                        Compat_Make(gn, gn);
+                       /* XXX: Replace with GNode_IsError(gn) */
                        if (gn->made == ERROR) {
                                PrintOnError(gn, "\nStop.");
                                exit(1);
@@ -722,7 +725,7 @@
        if (indirectErrors == 0) {
                GNode *endNode = Targ_GetEndNode();
                Compat_Make(endNode, endNode);
-               if (gn->made == ERROR || endNode->made == ERROR) {
+               if (GNode_IsError(gn) || GNode_IsError(endNode)) {
                        PrintOnError(gn, "\nStop.");
                        exit(1);
                }
diff -r 5c37ee6d506e -r 385ebf8c42c9 usr.bin/make/job.c
--- a/usr.bin/make/job.c        Tue Nov 24 17:59:42 2020 +0000
+++ b/usr.bin/make/job.c        Tue Nov 24 18:17:45 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: job.c,v 1.328 2020/11/23 23:41:11 rillig Exp $ */
+/*     $NetBSD: job.c,v 1.329 2020/11/24 18:17:45 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -143,7 +143,7 @@
 #include "trace.h"
 
 /*     "@(#)job.c      8.2 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: job.c,v 1.328 2020/11/23 23:41:11 rillig Exp $");
+MAKE_RCSID("$NetBSD: job.c,v 1.329 2020/11/24 18:17:45 rillig Exp $");
 
 /* A shell defines how the commands are run.  All commands for a target are
  * written into a single file, which is then given to the shell to execute
@@ -1843,6 +1843,7 @@
     }
 #else
     Compat_Make(targ, targ);
+    /* XXX: Replace with GNode_IsError(gn) */
     if (targ->made == ERROR) {
        PrintOnError(targ, "\n\nStop.");
        exit(1);
@@ -2739,6 +2740,7 @@
        Var_Set(ALLSRC, fname, gn);
 
     JobRun(gn);
+    /* XXX: Replace with GNode_IsError(gn) */
     if (gn->made == ERROR) {
        PrintOnError(gn, "\n\nStop.");
        exit(1);
diff -r 5c37ee6d506e -r 385ebf8c42c9 usr.bin/make/make.h
--- a/usr.bin/make/make.h       Tue Nov 24 17:59:42 2020 +0000
+++ b/usr.bin/make/make.h       Tue Nov 24 18:17:45 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: make.h,v 1.216 2020/11/24 17:42:31 rillig Exp $        */
+/*     $NetBSD: make.h,v 1.217 2020/11/24 18:17:45 rillig Exp $        */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -701,6 +701,12 @@
     return gn->path != NULL ? gn->path : gn->name;
 }
 
+MAKE_INLINE Boolean
+GNode_IsError(const GNode *gn)
+{
+       return gn->made == ERROR || gn->made == ABORTED;
+}
+
 MAKE_INLINE const char *
 GNode_VarTarget(GNode *gn) { return Var_ValueDirect(TARGET, gn); }
 MAKE_INLINE const char *
diff -r 5c37ee6d506e -r 385ebf8c42c9 usr.bin/make/unit-tests/deptgt-end-fail-indirect.exp
--- a/usr.bin/make/unit-tests/deptgt-end-fail-indirect.exp      Tue Nov 24 17:59:42 2020 +0000
+++ b/usr.bin/make/unit-tests/deptgt-end-fail-indirect.exp      Tue Nov 24 18:17:45 2020 +0000
@@ -1,4 +1,7 @@
 : all
 false
 *** Error code 1 (continuing)
-exit status 0
+
+Stop.
+make: stopped in unit-tests
+exit status 1



Home | Main Index | Thread Index | Old Index