diff options
author | Andrew Trick <atrick@apple.com> | 2011-05-21 00:56:46 +0000 |
---|---|---|
committer | Andrew Trick <atrick@apple.com> | 2011-05-21 00:56:46 +0000 |
commit | d5d0764b3b07a72cd370396332bbd382ebc876a4 (patch) | |
tree | 24eadd3c968f34cd7db69cc885027d16a0684d01 /llvm/lib/Support/Windows/Program.inc | |
parent | 1c464d496168fb54fcd88f483921aeb40e94d8af (diff) | |
download | bcm5719-llvm-d5d0764b3b07a72cd370396332bbd382ebc876a4.tar.gz bcm5719-llvm-d5d0764b3b07a72cd370396332bbd382ebc876a4.zip |
Have Program::Wait return -2 for crashed and timeouts instead of embedding
info in the error message. Per Dan's request.
llvm-svn: 131780
Diffstat (limited to 'llvm/lib/Support/Windows/Program.inc')
-rw-r--r-- | llvm/lib/Support/Windows/Program.inc | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/llvm/lib/Support/Windows/Program.inc b/llvm/lib/Support/Windows/Program.inc index b685bb8b851..e486e6ec238 100644 --- a/llvm/lib/Support/Windows/Program.inc +++ b/llvm/lib/Support/Windows/Program.inc @@ -332,8 +332,7 @@ Program::Execute(const Path& path, int Program::Wait(const Path &path, unsigned secondsToWait, - std::string* ErrMsg, - const char* /*SignalPrefix*/) { + std::string* ErrMsg) { if (Data_ == 0) { MakeErrMsg(ErrMsg, "Process not started!"); return -1; @@ -350,7 +349,8 @@ Program::Wait(const Path &path, if (WaitForSingleObject(hProcess, millisecondsToWait) == WAIT_TIMEOUT) { if (!TerminateProcess(hProcess, 1)) { MakeErrMsg(ErrMsg, "Failed to terminate timed-out program."); - return -1; + // -2 indicates a crash or timeout as opposed to failure to execute. + return -2; } WaitForSingleObject(hProcess, INFINITE); } @@ -363,7 +363,8 @@ Program::Wait(const Path &path, if (!rc) { SetLastError(err); MakeErrMsg(ErrMsg, "Failed getting status for program."); - return -1; + // -2 indicates a crash or timeout as opposed to failure to execute. + return -2; } return status; |