]> granicus.if.org Git - clang/commitdiff
Move computation of __private_extern__ visibilty to
authorFariborz Jahanian <fjahanian@apple.com>
Thu, 16 Jun 2011 20:14:50 +0000 (20:14 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Thu, 16 Jun 2011 20:14:50 +0000 (20:14 +0000)
getLVForNamespaceScopeDecl(). // rdar://9609649

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@133182 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/Decl.cpp
lib/CodeGen/CodeGenModule.cpp

index 8661e7405fb359c95b95b6b79c47a7d449484c91..c2abe1a5a90d5a9c322daa47439e06701275f570 100644 (file)
@@ -231,6 +231,14 @@ static LinkageInfo getLVForNamespaceScopeDecl(const NamedDecl *D, LVFlags F) {
       if (!FoundExtern)
         return LinkageInfo::internal();
     }
+    if (Var->getStorageClass() == SC_None) {
+      const VarDecl *PrevVar = Var->getPreviousDeclaration();
+      for (; PrevVar; PrevVar = PrevVar->getPreviousDeclaration())
+        if (PrevVar->getStorageClass() == SC_PrivateExtern)
+          break;
+        if (PrevVar)
+          return PrevVar->getLinkageAndVisibility();
+    }
   } else if (isa<FunctionDecl>(D) || isa<FunctionTemplateDecl>(D)) {
     // C++ [temp]p4:
     //   A non-member function template can have internal linkage; any
index c15ef9b0890151630e01439274697cef19ebf24c..78c57b4e3f2a738f5e52d7ca3fbf748620304a4d 100644 (file)
@@ -206,17 +206,8 @@ void CodeGenModule::setGlobalVisibility(llvm::GlobalValue *GV,
 
   // Set visibility for definitions.
   NamedDecl::LinkageInfo LV = D->getLinkageAndVisibility();
-  if (LV.visibilityExplicit() || !GV->hasAvailableExternallyLinkage()) {
-    Visibility Vis = LV.visibility();
-    if (Vis == DefaultVisibility)
-      if (const VarDecl *VD = dyn_cast<VarDecl>(D))
-        if (const VarDecl *Old = VD->getPreviousDeclaration()) {
-          Visibility OldVis = Old->getLinkageAndVisibility().visibility();
-          if (OldVis == HiddenVisibility)
-            Vis = HiddenVisibility;
-        }
-    GV->setVisibility(GetLLVMVisibility(Vis));
-  }
+  if (LV.visibilityExplicit() || !GV->hasAvailableExternallyLinkage())
+    GV->setVisibility(GetLLVMVisibility(LV.visibility()));
 }
 
 /// Set the symbol visibility of type information (vtable and RTTI)