diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-03-26 12:16:15 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-03-26 12:16:15 +0000 |
commit | dceb53180ae145915673913a9398ba4a00b05584 (patch) | |
tree | 80e2b267f91670fae13185d0d6cb668768762ca5 | |
parent | 4421d2b341d041df44013769f23c306308bbab83 (diff) |
Add a __has_feature check for the 'availability' attribute
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@128337 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Lex/PPMacroExpansion.cpp | 1 | ||||
-rw-r--r-- | test/Parser/attr-availability.c | 5 |
2 files changed, 6 insertions, 0 deletions
diff --git a/lib/Lex/PPMacroExpansion.cpp b/lib/Lex/PPMacroExpansion.cpp index e1fc0ba88f..71f332769e 100644 --- a/lib/Lex/PPMacroExpansion.cpp +++ b/lib/Lex/PPMacroExpansion.cpp @@ -530,6 +530,7 @@ static bool HasFeature(const Preprocessor &PP, const IdentifierInfo *II) { return llvm::StringSwitch<bool>(II->getName()) .Case("attribute_analyzer_noreturn", true) + .Case("attribute_availability", true) .Case("attribute_cf_returns_not_retained", true) .Case("attribute_cf_returns_retained", true) .Case("attribute_deprecated_with_message", true) diff --git a/test/Parser/attr-availability.c b/test/Parser/attr-availability.c index 63bb5271e5..269f90847d 100644 --- a/test/Parser/attr-availability.c +++ b/test/Parser/attr-availability.c @@ -1,4 +1,9 @@ // RUN: %clang_cc1 -fsyntax-only -verify %s + +#if !__has_feature(attribute_availability) +# error 'availability' attribute is not available +#endif + void f0() __attribute__((availability(macosx,introduced=10.2,deprecated=10.4,obsoleted=10.6))); void f1() __attribute__((availability(macosx,deprecated=10.4,introduced=10.2,obsoleted=10.6))); |