From 9dbb79aaac8dc2a94b13ddd4c8fdc659f0167716 Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Fri, 29 Oct 2010 20:20:29 +0000 Subject: [PATCH] not is testing for a normal exit with a non-zero value. It shouldn't return success if the child process is killed with a signal. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117701 91177308-0d34-0410-b5e6-96231b3b80d8 --- utils/not/not.cpp | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/utils/not/not.cpp b/utils/not/not.cpp index dd89b8f11c0..908abe932d1 100644 --- a/utils/not/not.cpp +++ b/utils/not/not.cpp @@ -9,9 +9,19 @@ #include "llvm/System/Path.h" #include "llvm/System/Program.h" +#include "llvm/Support/raw_ostream.h" using namespace llvm; int main(int argc, const char **argv) { sys::Path Program = sys::Program::FindProgramByName(argv[1]); - return !sys::Program::ExecuteAndWait(Program, argv + 1); + + std::string ErrMsg; + int Result = sys::Program::ExecuteAndWait(Program, argv + 1, 0, 0, 0, 0, + &ErrMsg); + if (Result < 0) { + errs() << "Error: " << ErrMsg << "\n"; + return 1; + } + + return Result == 0; }