diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2012-07-17 15:14:47 +0000 |
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2012-07-17 15:14:47 +0000 |
| commit | e3a14bb95b0d7cfb7f090da280ec2fc68e8f457d (patch) | |
| tree | 430355c004655e15ea339747b789ea99e4dee374 /clang/test/CodeGenCXX | |
| parent | 878f1445f99c71ead702d5fa88858217b9ce38ed (diff) | |
| download | bcm5719-llvm-e3a14bb95b0d7cfb7f090da280ec2fc68e8f457d.tar.gz bcm5719-llvm-e3a14bb95b0d7cfb7f090da280ec2fc68e8f457d.zip | |
Merge visibility from previous decls before looking at visibility pragma. This
is a bit fuzzy, but matches gcc behavior and existing code bases seem to
depend on it.
llvm-svn: 160364
Diffstat (limited to 'clang/test/CodeGenCXX')
| -rw-r--r-- | clang/test/CodeGenCXX/pragma-visibility.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/pragma-visibility.cpp b/clang/test/CodeGenCXX/pragma-visibility.cpp index 9b54a1813ce..11a38c1d5fb 100644 --- a/clang/test/CodeGenCXX/pragma-visibility.cpp +++ b/clang/test/CodeGenCXX/pragma-visibility.cpp @@ -52,3 +52,23 @@ namespace n __attribute((visibility("default"))) { // CHECK: define hidden void @_ZN1n1gEv #pragma GCC visibility pop } + +namespace test2 { +#pragma GCC visibility push(default) +#pragma GCC visibility push(hidden) + struct foo { // foo is hidden + }; +#pragma GCC visibility pop + struct foo; // declaration is ok, we ignore the default in the stack + template<typename T> + struct bar { // bar is default + static void f(){} + }; +#pragma GCC visibility pop + void zed() { + bar<foo>::f(); + bar<int>::f(); + } + // CHECK: define linkonce_odr hidden void @_ZN5test23barINS_3fooEE1fEv + // CHECK: define linkonce_odr void @_ZN5test23barIiE1fEv +} |

