summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2010-11-24 21:05:09 +0000
committerAnders Carlsson <andersca@mac.com>2010-11-24 21:05:09 +0000
commit0c75b49dc18e1be685d9725ccb0e25ce3120542f (patch)
treefe6758341ebe023a4ccbf095bd1aab0a8faa6085 /clang/lib/CodeGen
parent0e4dfebe6300d06aff9f60a1be8c0120a2b2e11c (diff)
downloadbcm5719-llvm-0c75b49dc18e1be685d9725ccb0e25ce3120542f.tar.gz
bcm5719-llvm-0c75b49dc18e1be685d9725ccb0e25ce3120542f.zip
Fix a (probably very old) regression where we weren't using the typedef name for anonymous tag types.
llvm-svn: 120113
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r--clang/lib/CodeGen/CodeGenTypes.cpp11
1 files changed, 5 insertions, 6 deletions
diff --git a/clang/lib/CodeGen/CodeGenTypes.cpp b/clang/lib/CodeGen/CodeGenTypes.cpp
index fdfdd9895b8..dde1322e3c2 100644
--- a/clang/lib/CodeGen/CodeGenTypes.cpp
+++ b/clang/lib/CodeGen/CodeGenTypes.cpp
@@ -384,16 +384,15 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) {
OS << TD->getQualifiedNameAsString();
else
TD->printName(OS);
- } else if (const TypedefType *TdT = dyn_cast<TypedefType>(T)) {
+ } else if (const TypedefDecl *TDD = TD->getTypedefForAnonDecl()) {
// FIXME: We should not have to check for a null decl context here.
// Right now we do it because the implicit Obj-C decls don't have one.
- if (TdT->getDecl()->getDeclContext())
- OS << TdT->getDecl()->getQualifiedNameAsString();
+ if (TDD->getDeclContext())
+ OS << TDD->getQualifiedNameAsString();
else
- TdT->getDecl()->printName(OS);
- } else {
+ TDD->printName(OS);
+ } else
OS << "anon";
- }
TheModule.addTypeName(OS.str(), Res);
return Res;
OpenPOWER on IntegriCloud