From: Rafael Espindola Date: Sun, 1 Jan 2012 18:06:40 +0000 (+0000) Subject: Consider visibility attributes in namespaces as being explicit. I.e., they X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=71cb8a2e10c3f75ca50e2b4f205cbd4cec40ad5e;p=clang Consider visibility attributes in namespaces as being explicit. I.e., they take precedence over command line options. Fixes PR10113. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@147405 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/Decl.cpp b/lib/AST/Decl.cpp index 842ce0f780..b4a4eb1d13 100644 --- a/lib/AST/Decl.cpp +++ b/lib/AST/Decl.cpp @@ -300,7 +300,7 @@ static LinkageInfo getLVForNamespaceScopeDecl(const NamedDecl *D, LVFlags F) { const NamespaceDecl *ND = dyn_cast(DC); if (!ND) continue; if (llvm::Optional Vis = ND->getExplicitVisibility()) { - LV.setVisibility(*Vis, false); + LV.setVisibility(*Vis, true); F.ConsiderGlobalVisibility = false; break; } diff --git a/test/CodeGenCXX/visibility.cpp b/test/CodeGenCXX/visibility.cpp index 0da55c63d6..ce1e8fd9d9 100644 --- a/test/CodeGenCXX/visibility.cpp +++ b/test/CodeGenCXX/visibility.cpp @@ -454,3 +454,15 @@ namespace test22 { // CHECK-HIDDEN: declare void @_ZN6test221BINS_2A2EE3fooEv() // CHECK-HIDDEN: define linkonce_odr hidden void @_ZN6test221BINS_2A2EE3barEv() } + +namespace PR10113 { + namespace foo __attribute__ ((__visibility__ ("default"))) { + template + class bar { + void zed() {} + }; + } + template class foo::bar; + // CHECK: define weak_odr void @_ZN7PR101133foo3barIcE3zedEv + // CHECK-HIDDEN: define weak_odr void @_ZN7PR101133foo3barIcE3zedEv +}