From 285d0dba947b7c9960eaa88e8c4fced0398d4319 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 1 Apr 2009 02:36:43 +0000 Subject: [PATCH] fix the two xfails I added with a previous patch by making ObjC interface types get completed when their definition is seen if previously laid out by the code generator. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@68177 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CodeGenModule.cpp | 7 ++-- lib/CodeGen/CodeGenTypes.cpp | 34 +++++++++++++++++++ lib/CodeGen/CodeGenTypes.h | 2 ++ test/CodeGenObjC/class-type.m | 1 - .../CodeGenObjC/forward-class-impl-metadata.m | 1 - 5 files changed, 41 insertions(+), 4 deletions(-) diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp index 59876516aa..101b2e58b7 100644 --- a/lib/CodeGen/CodeGenModule.cpp +++ b/lib/CodeGen/CodeGenModule.cpp @@ -1242,9 +1242,13 @@ void CodeGenModule::EmitTopLevelDecl(Decl *D) { case Decl::ObjCClass: case Decl::ObjCForwardProtocol: case Decl::ObjCCategory: + break; case Decl::ObjCInterface: + // If we already laid out this interface due to an @class, and if we + // codegen'd a reference it, update the 'opaque' type to be a real type now. + Types.UpdateCompletedType(cast(D)); break; - + case Decl::ObjCProtocol: Runtime->GenerateProtocol(cast(D)); break; @@ -1252,7 +1256,6 @@ void CodeGenModule::EmitTopLevelDecl(Decl *D) { case Decl::ObjCCategoryImpl: // Categories have properties but don't support synthesize so we // can ignore them here. - Runtime->GenerateCategory(cast(D)); break; diff --git a/lib/CodeGen/CodeGenTypes.cpp b/lib/CodeGen/CodeGenTypes.cpp index ff4b80f3b4..e13a4bc65d 100644 --- a/lib/CodeGen/CodeGenTypes.cpp +++ b/lib/CodeGen/CodeGenTypes.cpp @@ -197,6 +197,40 @@ void CodeGenTypes::UpdateCompletedType(const TagDecl *TD) { } } +void CodeGenTypes::UpdateCompletedType(const ObjCInterfaceDecl *OID) { + // Check to see if we have already laid this type out, if not, just return. + QualType OIDTy = + Context.getObjCInterfaceType(const_cast(OID)); + llvm::DenseMap::iterator TCI = + TypeCache.find(OIDTy.getTypePtr()); + if (TCI == TypeCache.end()) return; + + // Remember the opaque LLVM type for this interface. + llvm::PATypeHolder OpaqueHolder = TCI->second; + assert(isa(OpaqueHolder.get()) && + "Updating compilation of an already non-opaque type?"); + + // Remove it from TagDeclTypes so that it will be regenerated. + TypeCache.erase(TCI); + + // Update the "shadow" struct that is laid out. + // FIXME: REMOVE THIS. + const RecordDecl *RD = Context.addRecordToClass(OID); + UpdateCompletedType(RD); + + // Generate the new type. + const llvm::Type *NT = ConvertType(OIDTy); + assert(!isa(NT) && "Didn't do layout!"); + + // FIXME: Remove this check when shadow structs go away. + if (isa(OpaqueHolder)) { + + // Refine the old opaque type to its new definition. + cast(OpaqueHolder.get())->refineAbstractTypeTo(NT); + } +} + + static const llvm::Type* getTypeForFormat(const llvm::fltSemantics &format) { if (&format == &llvm::APFloat::IEEEsingle) return llvm::Type::FloatTy; diff --git a/lib/CodeGen/CodeGenTypes.h b/lib/CodeGen/CodeGenTypes.h index b408ff66a6..813ff8b2a2 100644 --- a/lib/CodeGen/CodeGenTypes.h +++ b/lib/CodeGen/CodeGenTypes.h @@ -161,6 +161,8 @@ public: /// UpdateCompletedType - When we find the full definition for a TagDecl, /// replace the 'opaque' type we previously made for it if applicable. void UpdateCompletedType(const TagDecl *TD); + /// Likewise for an ObjC Interface. + void UpdateCompletedType(const ObjCInterfaceDecl *OID); /// getFunctionInfo - Get the CGFunctionInfo for this function signature. const CGFunctionInfo &getFunctionInfo(QualType RetTy, diff --git a/test/CodeGenObjC/class-type.m b/test/CodeGenObjC/class-type.m index 456a6370b3..c8a1c18b9c 100644 --- a/test/CodeGenObjC/class-type.m +++ b/test/CodeGenObjC/class-type.m @@ -1,5 +1,4 @@ // RUN: clang-cc -triple x86_64-unknown-unknown -emit-llvm -o %t %s -// XFAIL: * @interface I0 { struct { int a; } a; diff --git a/test/CodeGenObjC/forward-class-impl-metadata.m b/test/CodeGenObjC/forward-class-impl-metadata.m index 3f8a5a4bc2..b3976d6458 100644 --- a/test/CodeGenObjC/forward-class-impl-metadata.m +++ b/test/CodeGenObjC/forward-class-impl-metadata.m @@ -1,5 +1,4 @@ // RUN: clang-cc -triple x86_64-unknown-unknown -emit-llvm -o %t %s -// XFAIL: * @interface BASE { @private -- 2.50.1