diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-06-04 13:43:35 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-06-04 13:43:35 +0000 |
commit | 52189363108ab96861d0b3f4b7e48ba7843b70a8 (patch) | |
tree | 77d96b4db93c01bf6318857074c19adc6f0a1a38 /clang/lib/AST/Decl.cpp | |
parent | 53c8c13bf138dc948743d88992f258cbb7887acf (diff) | |
download | bcm5719-llvm-52189363108ab96861d0b3f4b7e48ba7843b70a8.tar.gz bcm5719-llvm-52189363108ab96861d0b3f4b7e48ba7843b70a8.zip |
Fix linkage computation for local types in template functions.
Template functions (and member functions of class templates) present the same
problem as inline functions. They need to be uniqued, so we need to assign
VisibleNoLinkage linkage to types defined in them.
llvm-svn: 183222
Diffstat (limited to 'clang/lib/AST/Decl.cpp')
-rw-r--r-- | clang/lib/AST/Decl.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/clang/lib/AST/Decl.cpp b/clang/lib/AST/Decl.cpp index 80a32c5870d..a36fcf2507b 100644 --- a/clang/lib/AST/Decl.cpp +++ b/clang/lib/AST/Decl.cpp @@ -1049,8 +1049,12 @@ static LinkageInfo getLVForLocalDecl(const NamedDecl *D, return LinkageInfo::none(); const FunctionDecl *FD = getOutermostFunctionContext(D); - if (!FD || !FD->isInlined()) + if (!FD) + return LinkageInfo::none(); + + if (!FD->isInlined() && FD->getTemplateSpecializationKind() == TSK_Undeclared) return LinkageInfo::none(); + LinkageInfo LV = getLVForDecl(FD, computation); if (!isExternallyVisible(LV.getLinkage())) return LinkageInfo::none(); |