diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-02-28 22:05:49 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-02-28 22:05:49 +0000 |
commit | a51c67424e2c4533e9f89825ad1edfb26c11d097 (patch) | |
tree | 40cb8b01966d397fcf438dc73313a259f202fb29 /clang/lib/CodeGen/Mangle.cpp | |
parent | 16e601eea1b7db28be1c2dde3a67429195dc0aaf (diff) | |
download | bcm5719-llvm-a51c67424e2c4533e9f89825ad1edfb26c11d097.tar.gz bcm5719-llvm-a51c67424e2c4533e9f89825ad1edfb26c11d097.zip |
Improve name mangling for dependently-scoped declaration references.
llvm-svn: 97422
Diffstat (limited to 'clang/lib/CodeGen/Mangle.cpp')
-rw-r--r-- | clang/lib/CodeGen/Mangle.cpp | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/Mangle.cpp b/clang/lib/CodeGen/Mangle.cpp index 55185cb92d0..fd9a1bab7f2 100644 --- a/clang/lib/CodeGen/Mangle.cpp +++ b/clang/lib/CodeGen/Mangle.cpp @@ -1369,7 +1369,18 @@ void CXXNameMangler::mangleExpression(const Expr *E) { case Expr::DependentScopeDeclRefExprClass: { const DependentScopeDeclRefExpr *DRE = cast<DependentScopeDeclRefExpr>(E); - const Type *QTy = DRE->getQualifier()->getAsType(); + NestedNameSpecifier *NNS = DRE->getQualifier(); + const Type *QTy = NNS->getAsType(); + + // When we're dealing with a nested-name-specifier that has just a + // dependent identifier in it, mangle that as a typename. FIXME: + // It isn't clear that we ever actually want to have such a + // nested-name-specifier; why not just represent it as a typename type? + if (!QTy && NNS->getAsIdentifier() && NNS->getPrefix()) { + QTy = getASTContext().getTypenameType(NNS->getPrefix(), + NNS->getAsIdentifier()) + .getTypePtr(); + } assert(QTy && "Qualifier was not type!"); // ::= sr <type> <unqualified-name> # dependent name |