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/Unix | |
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/Unix')
-rw-r--r-- | llvm/lib/Support/Unix/Program.inc | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/llvm/lib/Support/Unix/Program.inc b/llvm/lib/Support/Unix/Program.inc index 86f3aa9eaca..346baf1744d 100644 --- a/llvm/lib/Support/Unix/Program.inc +++ b/llvm/lib/Support/Unix/Program.inc @@ -298,8 +298,7 @@ Program::Execute(const Path &path, const char **args, const char **envp, int Program::Wait(const sys::Path &path, unsigned secondsToWait, - std::string* ErrMsg, - const char* SignalPrefix) + std::string* ErrMsg) { #ifdef HAVE_SYS_WAIT_H struct sigaction Act, Old; @@ -339,7 +338,7 @@ Program::Wait(const sys::Path &path, else MakeErrMsg(ErrMsg, "Child timed out", 0); - return -1; // Timeout detected + return -2; // Timeout detected } else if (errno != EINTR) { MakeErrMsg(ErrMsg, "Error waiting for child process"); return -1; @@ -377,15 +376,15 @@ Program::Wait(const sys::Path &path, } } else if (WIFSIGNALED(status)) { if (ErrMsg) { - if (SignalPrefix) - *ErrMsg = SignalPrefix; - *ErrMsg += strsignal(WTERMSIG(status)); + *ErrMsg = strsignal(WTERMSIG(status)); #ifdef WCOREDUMP if (WCOREDUMP(status)) *ErrMsg += " (core dumped)"; #endif } - return -1; + // Return a special value to indicate that the process received an unhandled + // signal during execution as opposed to failing to execute. + return -2; } return result; #else |