diff options
-rw-r--r-- | src/build.cc | 18 | ||||
-rw-r--r-- | src/build.h | 4 | ||||
-rw-r--r-- | src/build_test.cc | 5 |
3 files changed, 19 insertions, 8 deletions
diff --git a/src/build.cc b/src/build.cc index d02027d..8ffbc7c 100644 --- a/src/build.cc +++ b/src/build.cc @@ -165,7 +165,7 @@ struct RealCommandRunner : public CommandRunner { virtual ~RealCommandRunner() {} virtual bool CanRunMore(); virtual bool StartCommand(Edge* edge); - virtual void WaitForCommands(); + virtual bool WaitForCommands(); virtual Edge* NextFinishedCommand(bool* success); SubprocessSet subprocs_; @@ -188,10 +188,14 @@ bool RealCommandRunner::StartCommand(Edge* edge) { return true; } -void RealCommandRunner::WaitForCommands() { - while (subprocs_.finished_.empty() && !subprocs_.running_.empty()) { +bool RealCommandRunner::WaitForCommands() { + if (subprocs_.running_.empty()) + return false; + + while (subprocs_.finished_.empty()) { subprocs_.DoWork(); } + return true; } Edge* RealCommandRunner::NextFinishedCommand(bool* success) { @@ -225,7 +229,8 @@ struct DryRunCommandRunner : public CommandRunner { finished_.push(edge); return true; } - virtual void WaitForCommands() { + virtual bool WaitForCommands() { + return true; } virtual Edge* NextFinishedCommand(bool* success) { if (finished_.empty()) @@ -300,7 +305,10 @@ bool Builder::Build(string* err) { } FinishEdge(edge); } else { - command_runner_->WaitForCommands(); + if (!command_runner_->WaitForCommands()) { + *err = "stuck [this is a bug]"; + return false; + } } } diff --git a/src/build.h b/src/build.h index f4b8d0c..843e907 100644 --- a/src/build.h +++ b/src/build.h @@ -53,7 +53,9 @@ struct CommandRunner { virtual ~CommandRunner() {} virtual bool CanRunMore() = 0; virtual bool StartCommand(Edge* edge) = 0; - virtual void WaitForCommands() = 0; + // Wait for commands to make progress; return false if there is no + // progress to be made. + virtual bool WaitForCommands() = 0; virtual Edge* NextFinishedCommand(bool* success) = 0; }; diff --git a/src/build_test.cc b/src/build_test.cc index b2c4d76..a430801 100644 --- a/src/build_test.cc +++ b/src/build_test.cc @@ -178,7 +178,7 @@ struct BuildTest : public StateTestWithBuiltinRules, // CommandRunner impl virtual bool CanRunMore(); virtual bool StartCommand(Edge* edge); - virtual void WaitForCommands(); + virtual bool WaitForCommands(); virtual Edge* NextFinishedCommand(bool* success); // DiskInterface @@ -251,7 +251,8 @@ bool BuildTest::StartCommand(Edge* edge) { return false; } -void BuildTest::WaitForCommands() { +bool BuildTest::WaitForCommands() { + return true; } Edge* BuildTest::NextFinishedCommand(bool* success) { |