]> granicus.if.org Git - clang/commitdiff
PR10120: Make CodeGenModule::getVTableLinkage use NamedDecl::getLinkage to determine...
authorEli Friedman <eli.friedman@gmail.com>
Fri, 10 Jun 2011 21:53:06 +0000 (21:53 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Fri, 10 Jun 2011 21:53:06 +0000 (21:53 +0000)
While I'm here, zap the other user of isInAnonymousNamespace outside of Decl.cpp.

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

lib/AST/RecordLayoutBuilder.cpp
lib/CodeGen/CodeGenModule.cpp
test/CodeGenCXX/internal-linkage.cpp

index 3c397a2059ba28427230232b1c0481b9843d7e1a..de0b1d0ed9dbde3995ab29fbea0e3a6f2936fa3f 100644 (file)
@@ -1757,10 +1757,10 @@ RecordLayoutBuilder::ComputeKeyFunction(const CXXRecordDecl *RD) {
   if (!RD->isPolymorphic())
     return 0;
 
-  // A class inside an anonymous namespace doesn't have a key function.  (Or
+  // A class that is not externally visible doesn't have a key function. (Or
   // at least, there's no point to assigning a key function to such a class;
   // this doesn't affect the ABI.)
-  if (RD->isInAnonymousNamespace())
+  if (RD->getLinkage() != ExternalLinkage)
     return 0;
 
   // Template instantiations don't have key functions,see Itanium C++ ABI 5.2.6.
index bea70ea38f314beefc5830bb7d5de27be40e7ba2..7a1a968259f3e06ab740f83962cd6cd3975fd660 100644 (file)
@@ -1125,7 +1125,7 @@ void CodeGenModule::EmitVTable(CXXRecordDecl *Class, bool DefinitionRequired) {
 
 llvm::GlobalVariable::LinkageTypes 
 CodeGenModule::getVTableLinkage(const CXXRecordDecl *RD) {
-  if (RD->isInAnonymousNamespace() || !RD->hasLinkage())
+  if (RD->getLinkage() != ExternalLinkage)
     return llvm::GlobalVariable::InternalLinkage;
 
   if (const CXXMethodDecl *KeyFunction
index 39bce8545ff5d89a87bdff94d7ac7ea0ff4826e8..56cb81030922c496d5adf9204d82459107b54f07 100644 (file)
@@ -54,3 +54,11 @@ char const * *test4()
     // CHECK: @extern_nonconst_xyzzy = global
     return &extern_nonconst_xyzzy;
 }
+
+// PR10120
+template <typename T> class klass {
+    virtual void f();
+};
+namespace { struct S; }
+void foo () { klass<S> x; }
+// CHECK: @_ZTV5klassIN12_GLOBAL__N_11SEE = internal unnamed_addr constant