summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/Mangle.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-01-13 16:39:34 +0000
committerDouglas Gregor <dgregor@apple.com>2011-01-13 16:39:34 +0000
commitd81c7c1659747d8a0c9a687c4d15bbbf33f87dc4 (patch)
treed7930b9afb199d12ff422a0011876b9a02dcadd6 /clang/lib/CodeGen/Mangle.cpp
parentb7c43b8c59678c388a42a90993f72f0bd3aebd64 (diff)
downloadbcm5719-llvm-d81c7c1659747d8a0c9a687c4d15bbbf33f87dc4.tar.gz
bcm5719-llvm-d81c7c1659747d8a0c9a687c4d15bbbf33f87dc4.zip
Add tests for name mangling of variadic templates.
llvm-svn: 123378
Diffstat (limited to 'clang/lib/CodeGen/Mangle.cpp')
-rw-r--r--clang/lib/CodeGen/Mangle.cpp11
1 files changed, 6 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/Mangle.cpp b/clang/lib/CodeGen/Mangle.cpp
index ff0e9223c81..0dfa0520aff 100644
--- a/clang/lib/CodeGen/Mangle.cpp
+++ b/clang/lib/CodeGen/Mangle.cpp
@@ -1476,7 +1476,7 @@ void CXXNameMangler::mangleType(const DependentSizedExtVectorType *T) {
}
void CXXNameMangler::mangleType(const PackExpansionType *T) {
- // FIXME: We may need to push this mangling into the callers
+ // <type> ::= Dp <type> # pack expansion (C++0x)
Out << "sp";
mangleType(T->getPattern());
}
@@ -1626,6 +1626,7 @@ void CXXNameMangler::mangleExpression(const Expr *E, unsigned Arity) {
// ::= sr <type> <unqualified-name> # dependent name
// ::= sr <type> <unqualified-name> <template-args> # dependent template-id
// ::= sZ <template-param> # size of a parameter pack
+ // ::= sZ <function-param> # size of a function parameter pack
// ::= <expr-primary>
// <expr-primary> ::= L <type> <value number> E # integer literal
// ::= L <type <value float> E # floating literal
@@ -2050,7 +2051,6 @@ void CXXNameMangler::mangleExpression(const Expr *E, unsigned Arity) {
break;
case Expr::SizeOfPackExprClass: {
- // FIXME: Variadic templates missing mangling for function parameter packs?
Out << "sZ";
const NamedDecl *Pack = cast<SizeOfPackExpr>(E)->getPack();
if (const TemplateTypeParmDecl *TTP = dyn_cast<TemplateTypeParmDecl>(Pack))
@@ -2062,7 +2062,8 @@ void CXXNameMangler::mangleExpression(const Expr *E, unsigned Arity) {
= dyn_cast<TemplateTemplateParmDecl>(Pack))
mangleTemplateParameter(TempTP->getIndex());
else {
- // FIXME: This case isn't handled by the Itanium C++ ABI
+ // Note: proposed by Mike Herrick on 11/30/10
+ // <expression> ::= sZ <function-param> # size of function parameter pack
Diagnostic &Diags = Context.getDiags();
unsigned DiagID = Diags.getCustomDiagID(Diagnostic::Error,
"cannot mangle sizeof...(function parameter pack)");
@@ -2156,7 +2157,7 @@ void CXXNameMangler::mangleTemplateArg(const NamedDecl *P,
// <template-arg> ::= <type> # type or template
// ::= X <expression> E # expression
// ::= <expr-primary> # simple expressions
- // ::= I <template-arg>* E # argument pack
+ // ::= J <template-arg>* E # argument pack
// ::= sp <expression> # pack expansion of (C++0x)
switch (A.getKind()) {
case TemplateArgument::Null:
@@ -2170,7 +2171,7 @@ void CXXNameMangler::mangleTemplateArg(const NamedDecl *P,
mangleType(A.getAsTemplate());
break;
case TemplateArgument::TemplateExpansion:
- // This is mangled as Dp <type>.
+ // <type> ::= Dp <type> # pack expansion (C++0x)
Out << "Dp";
mangleType(A.getAsTemplateOrTemplatePattern());
break;
OpenPOWER on IntegriCloud