diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2012-01-01 18:06:40 +0000 |
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2012-01-01 18:06:40 +0000 |
| commit | 0f960a0a5ada98d0ada8562dbd7c16b22a77091a (patch) | |
| tree | a5ddb8068e856d21dfb7c91eac4165850b5b30c4 /clang | |
| parent | 47aecca51a5032470aab114d9f200b36ecb240d2 (diff) | |
| download | bcm5719-llvm-0f960a0a5ada98d0ada8562dbd7c16b22a77091a.tar.gz bcm5719-llvm-0f960a0a5ada98d0ada8562dbd7c16b22a77091a.zip | |
Consider visibility attributes in namespaces as being explicit. I.e., they
take precedence over command line options. Fixes PR10113.
llvm-svn: 147405
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/AST/Decl.cpp | 2 | ||||
| -rw-r--r-- | clang/test/CodeGenCXX/visibility.cpp | 12 |
2 files changed, 13 insertions, 1 deletions
diff --git a/clang/lib/AST/Decl.cpp b/clang/lib/AST/Decl.cpp index 842ce0f7804..b4a4eb1d13e 100644 --- a/clang/lib/AST/Decl.cpp +++ b/clang/lib/AST/Decl.cpp @@ -300,7 +300,7 @@ static LinkageInfo getLVForNamespaceScopeDecl(const NamedDecl *D, LVFlags F) { const NamespaceDecl *ND = dyn_cast<NamespaceDecl>(DC); if (!ND) continue; if (llvm::Optional<Visibility> Vis = ND->getExplicitVisibility()) { - LV.setVisibility(*Vis, false); + LV.setVisibility(*Vis, true); F.ConsiderGlobalVisibility = false; break; } diff --git a/clang/test/CodeGenCXX/visibility.cpp b/clang/test/CodeGenCXX/visibility.cpp index 0da55c63d63..ce1e8fd9d98 100644 --- a/clang/test/CodeGenCXX/visibility.cpp +++ b/clang/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<typename T> + class bar { + void zed() {} + }; + } + template class foo::bar<char>; + // CHECK: define weak_odr void @_ZN7PR101133foo3barIcE3zedEv + // CHECK-HIDDEN: define weak_odr void @_ZN7PR101133foo3barIcE3zedEv +} |

