forked from OSchip/llvm-project
Add create methods for ObjCIvarDecl and ObjCInterfaceDecl
llvm-svn: 48408
This commit is contained in:
parent
011b0f5c5a
commit
96c501ef7e
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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;"
|
||||||
|
|
|
@ -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");
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue