diff options
author | Aaron Ballman <aaron@aaronballman.com> | 2019-11-25 17:32:07 -0500 |
---|---|---|
committer | Aaron Ballman <aaron@aaronballman.com> | 2019-11-25 17:35:12 -0500 |
commit | d930ed1acc0ea49d4b3aae7e95b4c6d9cd310578 (patch) | |
tree | 947d5557d14981c7e0a1bedea59cd88afab7b6df | |
parent | 214683f3b2d6f421c346debf41d545de18cc0caa (diff) | |
download | bcm5719-llvm-d930ed1acc0ea49d4b3aae7e95b4c6d9cd310578.tar.gz bcm5719-llvm-d930ed1acc0ea49d4b3aae7e95b4c6d9cd310578.zip |
Disallow use of __has_c_attribute in C++ mode.
__has_cpp_attribute is not available in C mode, and __has_c_attribute
should not be available in C++ mode. This also adds a test to
demonstrate that we properly handle scoped attribute tokens even in C
mode.
-rw-r--r-- | clang/lib/Lex/PPMacroExpansion.cpp | 6 | ||||
-rw-r--r-- | clang/test/Preprocessor/has_c_attribute.c | 6 | ||||
-rw-r--r-- | clang/test/Preprocessor/has_c_attribute.cpp | 8 |
3 files changed, 19 insertions, 1 deletions
diff --git a/clang/lib/Lex/PPMacroExpansion.cpp b/clang/lib/Lex/PPMacroExpansion.cpp index e6e00b1c170..a69c4dbb3a2 100644 --- a/clang/lib/Lex/PPMacroExpansion.cpp +++ b/clang/lib/Lex/PPMacroExpansion.cpp @@ -370,7 +370,11 @@ void Preprocessor::RegisterBuiltinMacros() { Ident__has_extension = RegisterBuiltinMacro(*this, "__has_extension"); Ident__has_builtin = RegisterBuiltinMacro(*this, "__has_builtin"); Ident__has_attribute = RegisterBuiltinMacro(*this, "__has_attribute"); - Ident__has_c_attribute = RegisterBuiltinMacro(*this, "__has_c_attribute"); + if (!LangOpts.CPlusPlus) + Ident__has_c_attribute = RegisterBuiltinMacro(*this, "__has_c_attribute"); + else + Ident__has_c_attribute = nullptr; + Ident__has_declspec = RegisterBuiltinMacro(*this, "__has_declspec_attribute"); Ident__has_include = RegisterBuiltinMacro(*this, "__has_include"); Ident__has_include_next = RegisterBuiltinMacro(*this, "__has_include_next"); diff --git a/clang/test/Preprocessor/has_c_attribute.c b/clang/test/Preprocessor/has_c_attribute.c index 843a67a2646..f8b0b364faa 100644 --- a/clang/test/Preprocessor/has_c_attribute.c +++ b/clang/test/Preprocessor/has_c_attribute.c @@ -1,4 +1,5 @@ // RUN: %clang_cc1 -fdouble-square-bracket-attributes -std=c11 -E %s -o - | FileCheck %s +// RUN: %clang_cc1 -std=c2x -E %s -o - | FileCheck %s // CHECK: has_fallthrough #if __has_c_attribute(fallthrough) @@ -14,3 +15,8 @@ #if __has_c_attribute(__nodiscard__) int has_nodiscard_underscore(); #endif + +// CHECK: has_clang_annotate +#if __has_c_attribute(clang::annotate) + int has_clang_annotate(); +#endif diff --git a/clang/test/Preprocessor/has_c_attribute.cpp b/clang/test/Preprocessor/has_c_attribute.cpp new file mode 100644 index 00000000000..0bde7306717 --- /dev/null +++ b/clang/test/Preprocessor/has_c_attribute.cpp @@ -0,0 +1,8 @@ +// RUN: %clang_cc1 -std=c++11 %s -verify + +#if __has_c_attribute(fallthrough) // expected-error {{function-like macro '__has_c_attribute' is not defined}} +#endif + +#if __has_c_attribute(gnu::transparent_union) // expected-error {{function-like macro '__has_c_attribute' is not defined}} +#endif + |