summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/Mangle.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-02-28 22:05:49 +0000
committerDouglas Gregor <dgregor@apple.com>2010-02-28 22:05:49 +0000
commita51c67424e2c4533e9f89825ad1edfb26c11d097 (patch)
tree40cb8b01966d397fcf438dc73313a259f202fb29 /clang/lib/CodeGen/Mangle.cpp
parent16e601eea1b7db28be1c2dde3a67429195dc0aaf (diff)
downloadbcm5719-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.cpp13
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
OpenPOWER on IntegriCloud