From 0e3dc386e92f4b0b49922c5eb43252bcd3ffca88 Mon Sep 17 00:00:00 2001 From: Michal Gorny Date: Sun, 22 Sep 2019 20:55:01 +0000 Subject: [PATCH] [clang] [Basic] Enable __has_feature(leak_sanitizer) Add a 'leak_sanitizer' feature akin to existing '*_sanitizer' features to let programmers switch code paths accounting for leak sanitizers being enabled. Differential Revision: https://reviews.llvm.org/D67719 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@372527 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/clang/Basic/Features.def | 2 ++ test/Lexer/has_feature_leak_sanitizer.cpp | 11 +++++++++++ 2 files changed, 13 insertions(+) create mode 100644 test/Lexer/has_feature_leak_sanitizer.cpp diff --git a/include/clang/Basic/Features.def b/include/clang/Basic/Features.def index 57132f5c0f..28eb694ba9 100644 --- a/include/clang/Basic/Features.def +++ b/include/clang/Basic/Features.def @@ -39,6 +39,8 @@ FEATURE(address_sanitizer, LangOpts.Sanitize.hasOneOf(SanitizerKind::Address | SanitizerKind::KernelAddress)) +FEATURE(leak_sanitizer, + LangOpts.Sanitize.has(SanitizerKind::Leak)) FEATURE(hwaddress_sanitizer, LangOpts.Sanitize.hasOneOf(SanitizerKind::HWAddress | SanitizerKind::KernelHWAddress)) diff --git a/test/Lexer/has_feature_leak_sanitizer.cpp b/test/Lexer/has_feature_leak_sanitizer.cpp new file mode 100644 index 0000000000..00ca96f4ba --- /dev/null +++ b/test/Lexer/has_feature_leak_sanitizer.cpp @@ -0,0 +1,11 @@ +// RUN: %clang_cc1 -E -fsanitize=leak %s -o - | FileCheck --check-prefix=CHECK-LSAN %s +// RUN: %clang_cc1 -E %s -o - | FileCheck --check-prefix=CHECK-NO-LSAN %s + +#if __has_feature(leak_sanitizer) +int LeakSanitizerEnabled(); +#else +int LeakSanitizerDisabled(); +#endif + +// CHECK-LSAN: LeakSanitizerEnabled +// CHECK-NO-LSAN: LeakSanitizerDisabled -- 2.40.0