[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / utils / not / not.cpp
blob4fcc0e89fc40231bd48c454293f2ad0a39f99ef5
1 //===- not.cpp - The 'not' testing tool -----------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 // Usage:
9 // not cmd
10 // Will return true if cmd doesn't crash and returns false.
11 // not --crash cmd
12 // Will return true if cmd crashes (e.g. for testing crash reporting).
14 #include "llvm/Support/Program.h"
15 #include "llvm/Support/WithColor.h"
16 #include "llvm/Support/raw_ostream.h"
18 #ifdef _WIN32
19 #include <windows.h>
20 #endif
22 using namespace llvm;
24 int main(int argc, const char **argv) {
25 bool ExpectCrash = false;
27 ++argv;
28 --argc;
30 if (argc > 0 && StringRef(argv[0]) == "--crash") {
31 ++argv;
32 --argc;
33 ExpectCrash = true;
35 // Crash is expected, so disable crash report and symbolization to reduce
36 // output and avoid potentially slow symbolization.
37 #ifdef _WIN32
38 SetEnvironmentVariableA("LLVM_DISABLE_CRASH_REPORT", "1");
39 SetEnvironmentVariableA("LLVM_DISABLE_SYMBOLIZATION", "1");
40 #else
41 setenv("LLVM_DISABLE_CRASH_REPORT", "1", 0);
42 setenv("LLVM_DISABLE_SYMBOLIZATION", "1", 0);
43 #endif
46 if (argc == 0)
47 return 1;
49 auto Program = sys::findProgramByName(argv[0]);
50 if (!Program) {
51 WithColor::error() << "unable to find `" << argv[0]
52 << "' in PATH: " << Program.getError().message() << "\n";
53 return 1;
56 std::vector<StringRef> Argv;
57 Argv.reserve(argc);
58 for (int i = 0; i < argc; ++i)
59 Argv.push_back(argv[i]);
60 std::string ErrMsg;
61 int Result =
62 sys::ExecuteAndWait(*Program, Argv, std::nullopt, {}, 0, 0, &ErrMsg);
63 #ifdef _WIN32
64 // Handle abort() in msvcrt -- It has exit code as 3. abort(), aka
65 // unreachable, should be recognized as a crash. However, some binaries use
66 // exit code 3 on non-crash failure paths, so only do this if we expect a
67 // crash.
68 if (ExpectCrash && Result == 3)
69 Result = -3;
70 #endif
71 if (Result < 0) {
72 WithColor::error() << ErrMsg << "\n";
73 if (ExpectCrash)
74 return 0;
75 return 1;
78 if (ExpectCrash)
79 return 1;
81 return Result == 0;