diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2012-05-01 20:58:29 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2012-05-01 20:58:29 +0000 |
commit | 4e31b4d6cf25029aa280d691e9023359c0ef4204 (patch) | |
tree | b5ecad0df08e400dc2695aa08d22a9f4c5ee479d /lib/Sema/SemaDeclAttr.cpp | |
parent | 294fe20bfae74de9203bb9809bf12d4ae711b3db (diff) |
Extend the error about incompatible visibility attributes in different
decls to work on function templates specializations.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@155943 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDeclAttr.cpp')
-rw-r--r-- | lib/Sema/SemaDeclAttr.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/lib/Sema/SemaDeclAttr.cpp b/lib/Sema/SemaDeclAttr.cpp index 47e393c18d..c8af3a430a 100644 --- a/lib/Sema/SemaDeclAttr.cpp +++ b/lib/Sema/SemaDeclAttr.cpp @@ -1752,7 +1752,13 @@ static void handleVisibilityAttr(Sema &S, Decl *D, const AttributeList &Attr) { return; } - VisibilityAttr *PrevAttr = D->getCanonicalDecl()->getAttr<VisibilityAttr>(); + Decl *PrevDecl; + if (isa<FunctionDecl>(D)) + PrevDecl = D->getMostRecentDecl()->getPreviousDecl(); + else + PrevDecl = D->getCanonicalDecl(); + + VisibilityAttr *PrevAttr = PrevDecl ? PrevDecl->getAttr<VisibilityAttr>() : 0; if (PrevAttr) { VisibilityAttr::VisibilityType PrevVisibility = PrevAttr->getVisibility(); if (PrevVisibility != type) { |