summaryrefslogtreecommitdiff
path: root/job.c
diff options
context:
space:
mode:
authorRoland McGrath <roland@redhat.com>1994-04-21 02:00:20 +0000
committerRoland McGrath <roland@redhat.com>1994-04-21 02:00:20 +0000
commitbca4e882ba29f3f8c24d671b7142b3885e7ebde6 (patch)
tree01176c0e6886642d3bfda46183a717e34aa132f8 /job.c
parenteb088188289bfffeb3ef8dbaf6da6a76fe698c0a (diff)
downloadgunmake-bca4e882ba29f3f8c24d671b7142b3885e7ebde6.tar.gz
(reap_children): Die with 2 for error.
(start_job_command): Set update_status to 2 for error. Set it to 1 when we would run a command and question_flag is set.
Diffstat (limited to 'job.c')
-rw-r--r--job.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/job.c b/job.c
index 882deb1..cdc2612 100644
--- a/job.c
+++ b/job.c
@@ -1,5 +1,5 @@
/* Job execution and handling for GNU Make.
-Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993 Free Software Foundation, Inc.
+Copyright (C) 1988, 89, 90, 91, 92, 93, 94 Free Software Foundation, Inc.
This file is part of GNU Make.
GNU Make is free software; you can redistribute it and/or modify
@@ -441,7 +441,7 @@ reap_children (block, err)
/* If the job failed, and the -k flag was not given, die,
unless we are already in the process of dying. */
if (!err && child_failed && !keep_going_flag)
- die (1);
+ die (2);
}
/* Only block for one child. */
@@ -513,9 +513,15 @@ start_job_command (child)
++p;
}
- /* If -q was given, just say that updating `failed'. */
+ /* If -q was given, just say that updating `failed'. The exit status of
+ 1 tells the user that -q is saying `something to do'; the exit status
+ for a random error is 2. */
if (question_flag && !(flags & COMMANDS_RECURSE))
- goto error;
+ {
+ child->file->update_status = 1;
+ child->file->command_state = cs_finished;
+ return;
+ }
/* There may be some preceding whitespace left if there
was nothing but a backslash on the first line. */
@@ -673,8 +679,8 @@ start_job_command (child)
return;
- error:;
- child->file->update_status = 1;
+ error:
+ child->file->update_status = 2;
child->file->command_state = cs_finished;
}