diff options
author | John McCall <rjmccall@apple.com> | 2010-05-15 11:32:37 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-05-15 11:32:37 +0000 |
commit | 8b07ec253d4042f824dccec711e17fb6d92bed5e (patch) | |
tree | a8983adf6d01605181cab33ce1beef16e0804609 /clang/lib/CodeGen/CGObjC.cpp | |
parent | 75142e6bfc4c61856ef2ede261be82efe27ab403 (diff) | |
download | bcm5719-llvm-8b07ec253d4042f824dccec711e17fb6d92bed5e.tar.gz bcm5719-llvm-8b07ec253d4042f824dccec711e17fb6d92bed5e.zip |
Substantially alter the design of the Objective C type AST by introducing
ObjCObjectType, which is basically just a pair of
one of {primitive-id, primitive-Class, user-defined @class}
with
a list of protocols.
An ObjCObjectPointerType is therefore just a pointer which always points to
one of these types (possibly sugared). ObjCInterfaceType is now just a kind
of ObjCObjectType which happens to not carry any protocols.
Alter a rather large number of use sites to use ObjCObjectType instead of
ObjCInterfaceType. Store an ObjCInterfaceType as a pointer on the decl rather
than hashing them in a FoldingSet. Remove some number of methods that are no
longer used, at least after this patch.
By simplifying ObjCObjectPointerType, we are now able to easily remove and apply
pointers to Objective-C types, which is crucial for a certain kind of ObjC++
metaprogramming common in WebKit.
llvm-svn: 103870
Diffstat (limited to 'clang/lib/CodeGen/CGObjC.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGObjC.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGObjC.cpp b/clang/lib/CodeGen/CGObjC.cpp index df0263ee129..ce048405afe 100644 --- a/clang/lib/CodeGen/CGObjC.cpp +++ b/clang/lib/CodeGen/CGObjC.cpp @@ -66,8 +66,8 @@ RValue CodeGenFunction::EmitObjCMessageExpr(const ObjCMessageExpr *E) { case ObjCMessageExpr::Class: { const ObjCInterfaceType *IFace = E->getClassReceiver()->getAs<ObjCInterfaceType>(); - OID = IFace->getDecl(); assert(IFace && "Invalid Objective-C class message send"); + OID = IFace->getDecl(); Receiver = Runtime.GetClass(Builder, OID); isClassMessage = true; break; |