mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-11-27 15:41:46 +00:00
f39c399d9d
The exit code for -### is inconsistent. Unrecognized options lead to exit code 1, as expected. However, most others errors (including invalid option value) lead to exit code 0, differing from GCC and most utilities. This is a longstanding quirk of -###, and we didn't fix it because many driver tests need adjustment. Change -### to be similar to -fdriver-only -v and exit with code 1. This requires fixing many driver tests, but the end result gives us stronger tests. * Existing `RUN: %clang -### ...` tests usually don't use `CHECK-NOT: error:` or `--implicit-check-not=error:`. If a change introduces an error, such a change usually cannot be detected. * Many folks contributing new tests don't know `-fdriver-only -v`. To test no driver error/warning for new tests, they can use the familiar `-### -Werror` instead of `-fdriver-only -v -Werror`. An incomplete list of prerequisite test improvement: *2f79bb1046
: add -nogpulib to some AMDGPU tests *9155e517e6
: add --cuda-path= (test w/ and w/o /usr/local/cuda) *80765ede5b
: -mcpu=native may return either 0 or 1, depending on whether `--target=` specifies a native target *abae53f43f
: fix -fuse-ld=lld misuses (test w/o and w/o /usr/local/bin/ld.lld) *ab68df505e
: add -resource-dir= and -fvisibility=hidden to some -fsanitize=cfi tests *d5ca1602f6
: --rtlib=platform without --unwindlib= may fail if CLANG_DEFAULT_UNWINDLIB=unwindlib Reviewed By: jhuber6, yaxunl, dblaikie Differential Revision: https://reviews.llvm.org/D156363
32 lines
1.2 KiB
C++
32 lines
1.2 KiB
C++
// Note: %s must be preceded by --, otherwise it may be interpreted as a
|
|
// command-line option, e.g. on Mac where %s is commonly under /Users.
|
|
|
|
// RUN: %clang_cl /c /EHsc -### -- %s 2>&1 | FileCheck -check-prefix=EHsc %s
|
|
// EHsc: "-fcxx-exceptions"
|
|
// EHsc: "-fexceptions"
|
|
|
|
// RUN: %clang_cl /c /EHs-c- -### -- %s 2>&1 | FileCheck -check-prefix=EHs_c_ %s
|
|
// EHs_c_-NOT: "-fcxx-exceptions"
|
|
// EHs_c_-NOT: "-fexceptions"
|
|
|
|
// RUN: %clang_cl /c /EHs- /EHc- -### -- %s 2>&1 | FileCheck -check-prefix=EHs_EHc_ %s
|
|
// EHs_EHc_-NOT: "-fcxx-exceptions"
|
|
// EHs_EHc_-NOT: "-fexceptions"
|
|
|
|
// RUN: %clang_cl /c /EHs- /EHs -### -- %s 2>&1 | FileCheck -check-prefix=EHs_EHs %s
|
|
// EHs_EHs: "-fcxx-exceptions"
|
|
// EHs_EHs: "-fexceptions"
|
|
|
|
// RUN: %clang_cl /c /EHs- /EHsa -### -- %s 2>&1 | FileCheck -check-prefix=EHs_EHa %s
|
|
// EHs_EHa: "-fcxx-exceptions"
|
|
// EHs_EHa: "-fexceptions"
|
|
|
|
// RUN: %clang_cl /c /EHa /EHc -### -- %s 2>&1 | FileCheck -check-prefix=EHa_EHc %s
|
|
// EHa_EHc: "-fcxx-exceptions"
|
|
// EHa_EHc: "-fexceptions"
|
|
// EHa_EHc-NOT: "-fexternc-nounwind"
|
|
|
|
// RUN: not %clang_cl /c /EHinvalid -### -- %s 2>&1 | FileCheck -check-prefix=EHinvalid %s
|
|
// EHinvalid: error: invalid value 'invalid' in '/EH'
|
|
// EHinvalid-NOT: error:
|