From: Christopher Lamb Date: Sat, 1 Dec 2007 09:08:41 +0000 (+0000) Subject: When generating the CodeGen type name of a struct, union, enum use the typedef X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=0f8db7021ef6a9f16f2571ecf68cc3f3eda4eae5;p=clang When generating the CodeGen type name of a struct, union, enum use the typedef name if a tag type name is not available for the type. This matches how llvm-gcc chooses CodeGen type names. This means that "typedef struct {...} foo" now results in a CodeGen name of "struct.foo" rather than "struct." git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@44489 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/CodeGen/CodeGenTypes.cpp b/CodeGen/CodeGenTypes.cpp index e953d59f1d..7b8a73c100 100644 --- a/CodeGen/CodeGenTypes.cpp +++ b/CodeGen/CodeGenTypes.cpp @@ -310,7 +310,14 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) { std::string TypeName(TD->getKindName()); TypeName += '.'; - TypeName += TD->getName(); + + // Name the codegen type after the typedef name + // if there is no tag type name available + if (TD->getName() == "" && T->getTypeClass() == Type::TypeName) { + const TypedefType *TdT = cast(T); + TypeName += TdT->getDecl()->getName(); + } else + TypeName += TD->getName(); TheModule.addTypeName(TypeName, ResultType); return ResultType;