diff options
author | Anders Carlsson <andersca@mac.com> | 2009-09-18 19:00:18 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-09-18 19:00:18 +0000 |
commit | 2744a063f1d9c475d76c2276f0b4f0998dfc5d09 (patch) | |
tree | 47366dbd835e8d908aafee86ec20b649e76a7e0c /lib/CodeGen/Mangle.cpp | |
parent | aa73ab1bd037419852eb4d4fb3ddf8fe2a2a4e5b (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.cpp | 38 |
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); |