]> granicus.if.org Git - clang/commitdiff
Make the mangler conform even better to the grammar.
authorAnders Carlsson <andersca@mac.com>
Fri, 18 Sep 2009 19:44:50 +0000 (19:44 +0000)
committerAnders Carlsson <andersca@mac.com>
Fri, 18 Sep 2009 19:44:50 +0000 (19:44 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@82262 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/Mangle.cpp

index 61b42b905680c1161733537b4a3a4aa2d871823b..5df2a34def32c2e328e9a59b11ea752e2b2854ed 100644 (file)
@@ -262,8 +262,13 @@ static const NamedDecl *isTemplate(const NamedDecl *ND,
     }
   }
 
-  // FIXME: Check if we have a class template.
-
+  // Check if we have a class template.
+  if (const ClassTemplateSpecializationDecl *Spec =
+        dyn_cast<ClassTemplateSpecializationDecl>(ND)) {
+    TemplateArgs = &Spec->getTemplateArgs();
+    return Spec;
+  }
+    
   return 0;
 }
 
@@ -507,16 +512,7 @@ void CXXNameMangler::manglePrefix(const DeclContext *DC) {
     return;
 
   manglePrefix(DC->getParent());
-
-  if (const NamespaceDecl *Namespace = dyn_cast<NamespaceDecl>(DC))
-    mangleSourceName(Namespace->getIdentifier());
-  else if (const RecordDecl *Record = dyn_cast<RecordDecl>(DC)) {
-    if (const ClassTemplateSpecializationDecl *D =
-        dyn_cast<ClassTemplateSpecializationDecl>(Record)) {
-      mangleType(QualType(D->getTypeForDecl(), 0));
-    } else
-      mangleSourceName(Record->getIdentifier());
-  }
+  mangleUnqualifiedName(cast<NamedDecl>(DC));
   
   addSubstitution(cast<NamedDecl>(DC));
 }