forked from OSchip/llvm-project
Add a --crash option to not.
Now the two possible uses of not are * not cmd Will return true if cmd doesn't crash and returns false. * not --crash cmd Will return true if cmd crashes. It will be used/tested in a followup commit for the clang crash recovery testing. llvm-svn: 185678
This commit is contained in:
parent
c2a990bc00
commit
91487584c9
|
@ -13,14 +13,33 @@
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
int main(int argc, const char **argv) {
|
int main(int argc, const char **argv) {
|
||||||
std::string Program = sys::FindProgramByName(argv[1]);
|
bool ExpectCrash = false;
|
||||||
|
|
||||||
|
++argv;
|
||||||
|
--argc;
|
||||||
|
|
||||||
|
if (argc > 0 && StringRef(argv[0]) == "--crash") {
|
||||||
|
++argv;
|
||||||
|
--argc;
|
||||||
|
ExpectCrash = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argc == 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
std::string Program = sys::FindProgramByName(argv[0]);
|
||||||
|
|
||||||
std::string ErrMsg;
|
std::string ErrMsg;
|
||||||
int Result = sys::ExecuteAndWait(Program, argv + 1, 0, 0, 0, 0, &ErrMsg);
|
int Result = sys::ExecuteAndWait(Program, argv, 0, 0, 0, 0, &ErrMsg);
|
||||||
if (Result < 0) {
|
if (Result < 0) {
|
||||||
errs() << "Error: " << ErrMsg << "\n";
|
errs() << "Error: " << ErrMsg << "\n";
|
||||||
|
if (ExpectCrash)
|
||||||
|
return 0;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ExpectCrash)
|
||||||
|
return 1;
|
||||||
|
|
||||||
return Result == 0;
|
return Result == 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue