diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2012-04-22 15:31:59 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2012-04-22 15:31:59 +0000 |
commit | bbc5cbc4108429c9f39a6972d069f58920d7bd99 (patch) | |
tree | 87da132d89ca6819b9dee276ef6cd5fa5c737efd /clang/test/CodeGenCXX/visibility.cpp | |
parent | 6c6cdec3de64b096dba68923117e1236710e97df (diff) | |
download | bcm5719-llvm-bbc5cbc4108429c9f39a6972d069f58920d7bd99.tar.gz bcm5719-llvm-bbc5cbc4108429c9f39a6972d069f58920d7bd99.zip |
An attribute in a explicit template installation should take precedence over
the tempale arguments in deciding the visibility.
This agrees with gcc 4.7.
Found by trying to build chrome with component=shared_library with 155314
reverted.
llvm-svn: 155316
Diffstat (limited to 'clang/test/CodeGenCXX/visibility.cpp')
-rw-r--r-- | clang/test/CodeGenCXX/visibility.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/visibility.cpp b/clang/test/CodeGenCXX/visibility.cpp index f309f3fc349..4199abbc486 100644 --- a/clang/test/CodeGenCXX/visibility.cpp +++ b/clang/test/CodeGenCXX/visibility.cpp @@ -660,3 +660,16 @@ namespace test32 { // CHECK: define void @_ZN6test321A1B3bazEv // CHECK-HIDDEN: define void @_ZN6test321A1B3bazEv } + +namespace test33 { + template<typename T> + class foo { + void bar() {} + int a; + }; + struct __attribute__((visibility("hidden"))) zed { + }; + template class __attribute__((visibility("default"))) foo<zed>; + // CHECK: define weak_odr void @_ZN6test333fooINS_3zedEE3barEv + // CHECK-HIDDEN: define weak_odr void @_ZN6test333fooINS_3zedEE3barEv +} |