summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/DeclBase.cpp
diff options
context:
space:
mode:
authorDuncan P. N. Exon Smith <dexonsmith@apple.com>2016-02-26 19:27:00 +0000
committerDuncan P. N. Exon Smith <dexonsmith@apple.com>2016-02-26 19:27:00 +0000
commitec599a906b7388f6ebdd3d00d6904473b69ec288 (patch)
tree6eac50103586441591f2527e034c4f4fd958ed53 /clang/lib/AST/DeclBase.cpp
parent2993854bb464c08f060e1f704f4c0b6dbc9ccda8 (diff)
downloadbcm5719-llvm-ec599a906b7388f6ebdd3d00d6904473b69ec288.tar.gz
bcm5719-llvm-ec599a906b7388f6ebdd3d00d6904473b69ec288.zip
SemaCXX: Support templates in availability attributes
If the availability context is `FunctionTemplateDecl`, we should look through it to the `FunctionDecl`. This prevents a diagnostic in the following case: class C __attribute__((unavailable)); template <class T> void foo(C&) __attribute__((unavailable)); This adds tests for availability in templates in many other cases, but that was the only case that failed before this patch. I added a feature `__has_feature(attribute_availability_in_templates)` so users can test for this. rdar://problem/24561029 llvm-svn: 262050
Diffstat (limited to 'clang/lib/AST/DeclBase.cpp')
-rw-r--r--clang/lib/AST/DeclBase.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/clang/lib/AST/DeclBase.cpp b/clang/lib/AST/DeclBase.cpp
index 58c3cc3369f..d41d25f7a44 100644
--- a/clang/lib/AST/DeclBase.cpp
+++ b/clang/lib/AST/DeclBase.cpp
@@ -467,6 +467,9 @@ static AvailabilityResult CheckAvailability(ASTContext &Context,
}
AvailabilityResult Decl::getAvailability(std::string *Message) const {
+ if (auto *FTD = dyn_cast<FunctionTemplateDecl>(this))
+ return FTD->getTemplatedDecl()->getAvailability(Message);
+
AvailabilityResult Result = AR_Available;
std::string ResultMessage;
OpenPOWER on IntegriCloud