aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CodeGenTypes.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/CodeGen/CodeGenTypes.cpp')
-rw-r--r--lib/CodeGen/CodeGenTypes.cpp34
1 files changed, 34 insertions, 0 deletions
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<ObjCInterfaceDecl*>(OID));
+ llvm::DenseMap<Type *, llvm::PATypeHolder>::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<llvm::OpaqueType>(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<llvm::OpaqueType>(NT) && "Didn't do layout!");
+
+ // FIXME: Remove this check when shadow structs go away.
+ if (isa<llvm::OpaqueType>(OpaqueHolder)) {
+
+ // Refine the old opaque type to its new definition.
+ cast<llvm::OpaqueType>(OpaqueHolder.get())->refineAbstractTypeTo(NT);
+ }
+}
+
+
static const llvm::Type* getTypeForFormat(const llvm::fltSemantics &format) {
if (&format == &llvm::APFloat::IEEEsingle)
return llvm::Type::FloatTy;