aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/Mangle.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-09-18 19:00:18 +0000
committerAnders Carlsson <andersca@mac.com>2009-09-18 19:00:18 +0000
commit2744a063f1d9c475d76c2276f0b4f0998dfc5d09 (patch)
tree47366dbd835e8d908aafee86ec20b649e76a7e0c /lib/CodeGen/Mangle.cpp
parentaa73ab1bd037419852eb4d4fb3ddf8fe2a2a4e5b (diff)
More mangler mangling.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@82250 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/Mangle.cpp')
-rw-r--r--lib/CodeGen/Mangle.cpp38
1 files changed, 26 insertions, 12 deletions
diff --git a/lib/CodeGen/Mangle.cpp b/lib/CodeGen/Mangle.cpp
index 685bb6d594..61b42b9056 100644
--- a/lib/CodeGen/Mangle.cpp
+++ b/lib/CodeGen/Mangle.cpp
@@ -252,6 +252,21 @@ static bool isStdNamespace(const DeclContext *DC) {
return NS->getOriginalNamespace()->getIdentifier()->isStr("std");
}
+static const NamedDecl *isTemplate(const NamedDecl *ND,
+ const TemplateArgumentList *&TemplateArgs) {
+ // Check if we have a function template.
+ if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND)){
+ if (FD->getPrimaryTemplate()) {
+ TemplateArgs = FD->getTemplateSpecializationArgs();
+ return FD;
+ }
+ }
+
+ // FIXME: Check if we have a class template.
+
+ return 0;
+}
+
void CXXNameMangler::mangleName(const NamedDecl *ND) {
// <name> ::= <nested-name>
// ::= <unscoped-name>
@@ -266,16 +281,14 @@ void CXXNameMangler::mangleName(const NamedDecl *ND) {
}
if (DC->isTranslationUnit() || isStdNamespace(DC)) {
- // Check if we have a function template.
- if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND)){
- if (FD->getPrimaryTemplate()) {
- mangleUnscopedTemplateName(FD);
- mangleTemplateArgumentList(*FD->getTemplateSpecializationArgs());
- return;
- }
+ // Check if we have a template.
+ const TemplateArgumentList *TemplateArgs = 0;
+ if (const NamedDecl *TD = isTemplate(ND, TemplateArgs)) {
+ mangleUnscopedTemplateName(TD);
+ mangleTemplateArgumentList(*TemplateArgs);
+ return;
}
- // FIXME: Check if we have a class template.
mangleUnscopedName(ND);
return;
}
@@ -446,10 +459,11 @@ void CXXNameMangler::mangleNestedName(const NamedDecl *ND) {
if (const CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(ND))
mangleCVQualifiers(Method->getTypeQualifiers());
- const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND);
- if (FD && FD->getPrimaryTemplate()) {
- mangleTemplatePrefix(FD);
- mangleTemplateArgumentList(*FD->getTemplateSpecializationArgs());
+ // Check if we have a template.
+ const TemplateArgumentList *TemplateArgs = 0;
+ if (const NamedDecl *TD = isTemplate(ND, TemplateArgs)) {
+ mangleTemplatePrefix(TD);
+ mangleTemplateArgumentList(*TemplateArgs);
} else {
manglePrefix(ND->getDeclContext());
mangleUnqualifiedName(ND);