Add create methods for ObjCIvarDecl and ObjCInterfaceDecl

llvm-svn: 48408
This commit is contained in:
Chris Lattner 2008-03-16 01:15:50 +00:00
parent 011b0f5c5a
commit 96c501ef7e
5 changed files with 38 additions and 13 deletions

View File

@ -224,7 +224,7 @@ class ObjCInterfaceDecl : public TypeDecl {
SourceLocation EndLoc; // marks the '>', '}', or identifier. SourceLocation EndLoc; // marks the '>', '}', or identifier.
SourceLocation AtEndLoc; // marks the end of the entire interface. SourceLocation AtEndLoc; // marks the end of the entire interface.
public:
ObjCInterfaceDecl(SourceLocation atLoc, unsigned numRefProtos, ObjCInterfaceDecl(SourceLocation atLoc, unsigned numRefProtos,
IdentifierInfo *Id, bool FD = false, IdentifierInfo *Id, bool FD = false,
bool isInternal = false) bool isInternal = false)
@ -237,6 +237,12 @@ public:
ForwardDecl(FD), InternalInterface(isInternal) { ForwardDecl(FD), InternalInterface(isInternal) {
AllocIntfRefProtocols(numRefProtos); AllocIntfRefProtocols(numRefProtos);
} }
public:
static ObjCInterfaceDecl *Create(ASTContext &C, SourceLocation atLoc,
unsigned numRefProtos, IdentifierInfo *Id,
bool ForwardDecl = false,
bool isInternal = false);
// This is necessary when converting a forward declaration to a definition. // This is necessary when converting a forward declaration to a definition.
void AllocIntfRefProtocols(unsigned numRefProtos) { void AllocIntfRefProtocols(unsigned numRefProtos) {
@ -303,20 +309,20 @@ public:
// Get the local instance method declared in this interface. // Get the local instance method declared in this interface.
ObjCMethodDecl *getInstanceMethod(Selector &Sel) { ObjCMethodDecl *getInstanceMethod(Selector &Sel) {
for (instmeth_iterator I = instmeth_begin(), E = instmeth_end(); for (instmeth_iterator I = instmeth_begin(), E = instmeth_end();
I != E; ++I) { I != E; ++I) {
if ((*I)->getSelector() == Sel) if ((*I)->getSelector() == Sel)
return *I; return *I;
} }
return 0; return 0;
} }
// Get the local class method declared in this interface. // Get the local class method declared in this interface.
ObjCMethodDecl *getClassMethod(Selector &Sel) { ObjCMethodDecl *getClassMethod(Selector &Sel) {
for (classmeth_iterator I = classmeth_begin(), E = classmeth_end(); for (classmeth_iterator I = classmeth_begin(), E = classmeth_end();
I != E; ++I) { I != E; ++I) {
if ((*I)->getSelector() == Sel) if ((*I)->getSelector() == Sel)
return *I; return *I;
} }
return 0; return 0;
} }
// Lookup a method. First, we search locally. If a method isn't // Lookup a method. First, we search locally. If a method isn't
// found, we search referenced protocols and class categories. // found, we search referenced protocols and class categories.
@ -365,9 +371,11 @@ public:
/// } /// }
/// ///
class ObjCIvarDecl : public FieldDecl { class ObjCIvarDecl : public FieldDecl {
public:
ObjCIvarDecl(SourceLocation L, IdentifierInfo *Id, QualType T) ObjCIvarDecl(SourceLocation L, IdentifierInfo *Id, QualType T)
: FieldDecl(ObjCIvar, L, Id, T) {} : FieldDecl(ObjCIvar, L, Id, T) {}
public:
static ObjCIvarDecl *Create(ASTContext &C, SourceLocation L,
IdentifierInfo *Id, QualType T);
enum AccessControl { enum AccessControl {
None, Private, Protected, Public, Package None, Private, Protected, Public, Package

View File

@ -30,7 +30,21 @@ ObjCMethodDecl *ObjCMethodDecl::Create(ASTContext &C, SourceLocation beginLoc,
return new (Mem) ObjCMethodDecl(beginLoc, endLoc, SelInfo, T, contextDecl, return new (Mem) ObjCMethodDecl(beginLoc, endLoc, SelInfo, T, contextDecl,
M, isInstance, M, isInstance,
isVariadic, impControl); isVariadic, impControl);
}
ObjCInterfaceDecl *ObjCInterfaceDecl::Create(ASTContext &C,SourceLocation atLoc,
unsigned numRefProtos,
IdentifierInfo *Id,
bool ForwardDecl, bool isInternal){
void *Mem = C.getAllocator().Allocate<ObjCInterfaceDecl>();
return new (Mem) ObjCInterfaceDecl(atLoc, numRefProtos, Id, ForwardDecl,
isInternal);
}
ObjCIvarDecl *ObjCIvarDecl::Create(ASTContext &C, SourceLocation L,
IdentifierInfo *Id, QualType T) {
void *Mem = C.getAllocator().Allocate<ObjCIvarDecl>();
return new (Mem) ObjCIvarDecl(L, Id, T);
} }

View File

@ -108,8 +108,9 @@ Sema::Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer)
Context.setObjCClassType(ClassTypedef); Context.setObjCClassType(ClassTypedef);
// Synthesize "@class Protocol; // Synthesize "@class Protocol;
ObjCInterfaceDecl *ProtocolDecl = new ObjCInterfaceDecl(SourceLocation(), 0, ObjCInterfaceDecl *ProtocolDecl =
&Context.Idents.get("Protocol"), true); ObjCInterfaceDecl::Create(Context, SourceLocation(), 0,
&Context.Idents.get("Protocol"), true);
Context.setObjCProtoType(Context.getObjCInterfaceType(ProtocolDecl)); Context.setObjCProtoType(Context.getObjCInterfaceType(ProtocolDecl));
// Synthesize "typedef struct objc_object { Class isa; } *id;" // Synthesize "typedef struct objc_object { Class isa; } *id;"

View File

@ -1340,7 +1340,7 @@ Sema::DeclTy *Sema::ActOnField(Scope *S, DeclTy *TagDecl,
// properties can appear within a protocol. // properties can appear within a protocol.
// See corresponding FIXME in DeclObjC.h:ObjCPropertyDecl. // See corresponding FIXME in DeclObjC.h:ObjCPropertyDecl.
isa<ObjCProtocolDecl>(static_cast<Decl *>(TagDecl))) isa<ObjCProtocolDecl>(static_cast<Decl *>(TagDecl)))
NewFD = new ObjCIvarDecl(Loc, II, T); NewFD = ObjCIvarDecl::Create(Context, Loc, II, T);
else else
assert(0 && "Sema::ActOnField(): Unknown TagDecl"); assert(0 && "Sema::ActOnField(): Unknown TagDecl");

View File

@ -98,7 +98,8 @@ Sema::DeclTy *Sema::ActOnStartClassInterface(
} }
} }
else { else {
IDecl = new ObjCInterfaceDecl(AtInterfaceLoc, NumProtocols, ClassName); IDecl = ObjCInterfaceDecl::Create(Context, AtInterfaceLoc, NumProtocols,
ClassName);
// Chain & install the interface decl into the identifier. // Chain & install the interface decl into the identifier.
IDecl->setNext(ClassName->getFETokenInfo<ScopedDecl>()); IDecl->setNext(ClassName->getFETokenInfo<ScopedDecl>());
@ -382,8 +383,8 @@ Sema::DeclTy *Sema::ActOnStartClassImplementation(
if (!IDecl) { if (!IDecl) {
// Legacy case of @implementation with no corresponding @interface. // Legacy case of @implementation with no corresponding @interface.
// Build, chain & install the interface decl into the identifier. // Build, chain & install the interface decl into the identifier.
IDecl = new ObjCInterfaceDecl(AtClassImplLoc, 0, ClassName, IDecl = ObjCInterfaceDecl::Create(Context, AtClassImplLoc, 0, ClassName,
false, true); false, true);
IDecl->setNext(ClassName->getFETokenInfo<ScopedDecl>()); IDecl->setNext(ClassName->getFETokenInfo<ScopedDecl>());
ClassName->setFETokenInfo(IDecl); ClassName->setFETokenInfo(IDecl);
IDecl->setSuperClass(SDecl); IDecl->setSuperClass(SDecl);
@ -589,7 +590,8 @@ Sema::ActOnForwardClassDeclaration(SourceLocation AtClassLoc,
} }
ObjCInterfaceDecl *IDecl = dyn_cast_or_null<ObjCInterfaceDecl>(PrevDecl); ObjCInterfaceDecl *IDecl = dyn_cast_or_null<ObjCInterfaceDecl>(PrevDecl);
if (!IDecl) { // Not already seen? Make a forward decl. if (!IDecl) { // Not already seen? Make a forward decl.
IDecl = new ObjCInterfaceDecl(AtClassLoc, 0, IdentList[i], true); IDecl = ObjCInterfaceDecl::Create(Context, AtClassLoc, 0, IdentList[i],
true);
// Chain & install the interface decl into the identifier. // Chain & install the interface decl into the identifier.
IDecl->setNext(IdentList[i]->getFETokenInfo<ScopedDecl>()); IDecl->setNext(IdentList[i]->getFETokenInfo<ScopedDecl>());
IdentList[i]->setFETokenInfo(IDecl); IdentList[i]->setFETokenInfo(IDecl);