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 | 71adc5b587e4612e23d5ba234967b77a5f74b773 (patch) | |
tree | 27e64df0ef37c3b1bcea2d8f08ce6a28f6faeb6d /lib/Sema/SemaDecl.cpp | |
parent | a555f2be4fce6edc8ab25eef508f21ed1e2d5dae (diff) |
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.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@160364 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDecl.cpp')
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 342acf825b..4041ccf9d3 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -8880,10 +8880,6 @@ CreateNewDecl: if (Attr) ProcessDeclAttributeList(S, New, Attr); - // If there's a #pragma GCC visibility in scope, set the visibility of this - // record. - AddPushedVisibilityAttribute(New); - // If we're declaring or defining a tag in function prototype scope // in C, note that this type can only be used within the function. if (Name && S->isFunctionPrototypeScope() && !getLangOpts().CPlusPlus) @@ -8946,6 +8942,10 @@ CreateNewDecl: if (PrevDecl) mergeDeclAttributes(New, PrevDecl); + // If there's a #pragma GCC visibility in scope, set the visibility of this + // record. + AddPushedVisibilityAttribute(New); + OwnedDecl = true; return New; } |