DeclObjC.cpp revision 900fc6388e803868a34b9483510c345e9b49d7eb
11e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//===--- DeclObjC.cpp - ObjC Declaration AST Node Implementation ----------===//
21e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//
31e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//                     The LLVM Compiler Infrastructure
41e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//
51e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner// This file is distributed under the University of Illinois Open Source
61e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner// License. See LICENSE.TXT for details.
71e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//
81e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//===----------------------------------------------------------------------===//
91e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//
101e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner// This file implements the Objective-C related Decl classes.
111e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//
121e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner//===----------------------------------------------------------------------===//
131e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
141e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner#include "clang/AST/DeclObjC.h"
151e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner#include "clang/AST/ASTContext.h"
16e91593ef084479340582b2ba177b44be50a717b7Daniel Dunbar#include "clang/AST/Stmt.h"
170de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff#include "llvm/ADT/STLExtras.h"
181e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattnerusing namespace clang;
191e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
206c4ae5de0c356777446f823b573821fb95560d91Chris Lattner//===----------------------------------------------------------------------===//
2111e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner// ObjCListBase
2211e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner//===----------------------------------------------------------------------===//
2311e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner
2438af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattnervoid ObjCListBase::Destroy(ASTContext &Ctx) {
254ee413ba81c8030c195a9166847928054ed01ca4Chris Lattner  Ctx.Deallocate(List);
2611e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner  NumElts = 0;
2711e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner  List = 0;
2811e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner}
2911e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner
3038af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattnervoid ObjCListBase::set(void *const* InList, unsigned Elts, ASTContext &Ctx) {
3111e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner  assert(List == 0 && "Elements already set!");
3211e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner  if (Elts == 0) return;  // Setting to an empty list is a noop.
331eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
341eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
354ee413ba81c8030c195a9166847928054ed01ca4Chris Lattner  List = new (Ctx) void*[Elts];
3611e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner  NumElts = Elts;
3711e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner  memcpy(List, InList, sizeof(void*)*Elts);
3811e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner}
3911e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner
4018df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregorvoid ObjCProtocolList::set(ObjCProtocolDecl* const* InList, unsigned Elts,
4118df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor                           const SourceLocation *Locs, ASTContext &Ctx) {
4218df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  if (Elts == 0)
4318df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor    return;
4418df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor
4518df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  Locations = new (Ctx) SourceLocation[Elts];
4618df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  memcpy(Locations, Locs, sizeof(SourceLocation) * Elts);
4718df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  set(InList, Elts, Ctx);
4818df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor}
4918df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor
5018df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregorvoid ObjCProtocolList::Destroy(ASTContext &Ctx) {
5118df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  Ctx.Deallocate(Locations);
5218df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  Locations = 0;
5318df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  ObjCList<ObjCProtocolDecl>::Destroy(Ctx);
5418df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor}
5511e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner
5611e1e1af2641affb378080a4f3d1a30da1cad082Chris Lattner//===----------------------------------------------------------------------===//
57ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCInterfaceDecl
58ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
59ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
60496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian/// getIvarDecl - This method looks up an ivar in this ContextDecl.
61496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian///
62496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz JahanianObjCIvarDecl *
6317945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios KyrtzidisObjCContainerDecl::getIvarDecl(IdentifierInfo *Id) const {
64496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian  lookup_const_iterator Ivar, IvarEnd;
6517945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis  for (llvm::tie(Ivar, IvarEnd) = lookup(Id); Ivar != IvarEnd; ++Ivar) {
66496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian    if (ObjCIvarDecl *ivar = dyn_cast<ObjCIvarDecl>(*Ivar))
67496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian      return ivar;
68496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian  }
69496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian  return 0;
70496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian}
71496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian
72467c0b165072689ef87fe8d9cd47a5b63485bcdcArgyrios Kyrtzidis// Get the local instance/class method declared in this interface.
736ab3524f72a6e64aa04973fa9433b5559abb3525Douglas GregorObjCMethodDecl *
74467c0b165072689ef87fe8d9cd47a5b63485bcdcArgyrios KyrtzidisObjCContainerDecl::getMethod(Selector Sel, bool isInstance) const {
750de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  // Since instance & class methods can have the same name, the loop below
760de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  // ensures we get the correct method.
770de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  //
780de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  // @interface Whatever
790de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  // - (int) class_method;
800de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  // + (float) class_method;
810de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  // @end
820de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  //
830de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  lookup_const_iterator Meth, MethEnd;
8417945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis  for (llvm::tie(Meth, MethEnd) = lookup(Sel); Meth != MethEnd; ++Meth) {
850de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff    ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(*Meth);
86467c0b165072689ef87fe8d9cd47a5b63485bcdcArgyrios Kyrtzidis    if (MD && MD->isInstanceMethod() == isInstance)
870de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff      return MD;
880de21fd85d79bccd32f04256f5b3328ab5ed7c95Steve Naroff  }
89ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return 0;
90ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
91ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
929f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted KremenekObjCPropertyDecl *
93de09d0c9694f01a99870a8825266d44a29ebb325Ted KremenekObjCPropertyDecl::findPropertyDecl(const DeclContext *DC,
949f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek                                   IdentifierInfo *propertyID) {
959f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek
96de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek  DeclContext::lookup_const_iterator I, E;
979f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek  llvm::tie(I, E) = DC->lookup(propertyID);
989f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek  for ( ; I != E; ++I)
999f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek    if (ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(*I))
1009f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek      return PD;
1019f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek
1029f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek  return 0;
1039f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek}
1049f550ff05d496e6b9480e5619a21d9da0c9e27c1Ted Kremenek
105ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// FindPropertyDeclaration - Finds declaration of the property given its name
106ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// in 'PropertyId' and returns it. It returns 0, if not found.
107ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCPropertyDecl *
10817945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios KyrtzidisObjCContainerDecl::FindPropertyDeclaration(IdentifierInfo *PropertyId) const {
1091eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
110de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek  if (ObjCPropertyDecl *PD =
111de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek        ObjCPropertyDecl::findPropertyDecl(cast<DeclContext>(this), PropertyId))
112de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek    return PD;
113de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek
114de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek  switch (getKind()) {
115de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek    default:
116de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      break;
117de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek    case Decl::ObjCProtocol: {
118de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      const ObjCProtocolDecl *PID = cast<ObjCProtocolDecl>(this);
119de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      for (ObjCProtocolDecl::protocol_iterator I = PID->protocol_begin(),
120de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek           E = PID->protocol_end(); I != E; ++I)
121de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek        if (ObjCPropertyDecl *P = (*I)->FindPropertyDeclaration(PropertyId))
12225760611365be23556b32332f8a66ae21ea93ecfFariborz Jahanian          return P;
123de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      break;
124ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    }
125de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek    case Decl::ObjCInterface: {
126de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      const ObjCInterfaceDecl *OID = cast<ObjCInterfaceDecl>(this);
127de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      // Look through categories.
128de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      for (ObjCCategoryDecl *Cat = OID->getCategoryList();
129de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek           Cat; Cat = Cat->getNextClassCategory())
130de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek        if (!Cat->IsClassExtension())
131de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek          if (ObjCPropertyDecl *P = Cat->FindPropertyDeclaration(PropertyId))
132de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek            return P;
133de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek
134de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      // Look through protocols.
135de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      for (ObjCInterfaceDecl::protocol_iterator
136de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek            I = OID->protocol_begin(), E = OID->protocol_end(); I != E; ++I)
137de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek        if (ObjCPropertyDecl *P = (*I)->FindPropertyDeclaration(PropertyId))
138de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek          return P;
139de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek
140de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      // Finally, check the super class.
141de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      if (const ObjCInterfaceDecl *superClass = OID->getSuperClass())
142de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek        return superClass->FindPropertyDeclaration(PropertyId);
143de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      break;
144ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    }
145de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek    case Decl::ObjCCategory: {
146de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      const ObjCCategoryDecl *OCD = cast<ObjCCategoryDecl>(this);
147de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      // Look through protocols.
148de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      if (!OCD->IsClassExtension())
149de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek        for (ObjCCategoryDecl::protocol_iterator
150de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek              I = OCD->protocol_begin(), E = OCD->protocol_end(); I != E; ++I)
15125760611365be23556b32332f8a66ae21ea93ecfFariborz Jahanian        if (ObjCPropertyDecl *P = (*I)->FindPropertyDeclaration(PropertyId))
15225760611365be23556b32332f8a66ae21ea93ecfFariborz Jahanian          return P;
153de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek
154de09d0c9694f01a99870a8825266d44a29ebb325Ted Kremenek      break;
155ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    }
156ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  }
157ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return 0;
158ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
159ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
160a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian/// FindPropertyVisibleInPrimaryClass - Finds declaration of the property
161a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian/// with name 'PropertyId' in the primary class; including those in protocols
16237cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek/// (direct or indirect) used by the primary class.
163a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian///
164a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz JahanianObjCPropertyDecl *
16537cafb077ad5b170acae77e566638603011ef4c0Ted KremenekObjCInterfaceDecl::FindPropertyVisibleInPrimaryClass(
166a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian                                            IdentifierInfo *PropertyId) const {
16737cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek  if (ObjCPropertyDecl *PD =
16837cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek      ObjCPropertyDecl::findPropertyDecl(cast<DeclContext>(this), PropertyId))
16937cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek    return PD;
17037cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek
171a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian  // Look through protocols.
17237cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek  for (ObjCInterfaceDecl::protocol_iterator
17337cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek        I = protocol_begin(), E = protocol_end(); I != E; ++I)
174a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian    if (ObjCPropertyDecl *P = (*I)->FindPropertyDeclaration(PropertyId))
175a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian      return P;
17637cafb077ad5b170acae77e566638603011ef4c0Ted Kremenek
177a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian  return 0;
178a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian}
179a6f14e1a7ee3a9343a838297c73ca87fddb9ed4aFariborz Jahanian
180339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanianvoid ObjCInterfaceDecl::mergeClassExtensionProtocolList(
181339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian                              ObjCProtocolDecl *const* ExtList, unsigned ExtNum,
18218df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor                              const SourceLocation *Locs,
183339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian                              ASTContext &C)
184339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian{
185339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  if (ReferencedProtocols.empty()) {
18618df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor    ReferencedProtocols.set(ExtList, ExtNum, Locs, C);
187339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    return;
188339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  }
189339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  // Check for duplicate protocol in class's protocol list.
190339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  // This is (O)2. But it is extremely rare and number of protocols in
191339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  // class or its extension are very few.
192339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  llvm::SmallVector<ObjCProtocolDecl*, 8> ProtocolRefs;
19318df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  llvm::SmallVector<SourceLocation, 8> ProtocolLocs;
194339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  for (unsigned i = 0; i < ExtNum; i++) {
195339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    bool protocolExists = false;
196339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    ObjCProtocolDecl *ProtoInExtension = ExtList[i];
197339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    for (protocol_iterator p = protocol_begin(), e = protocol_end();
198339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian         p != e; p++) {
199339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian      ObjCProtocolDecl *Proto = (*p);
200339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian      if (C.ProtocolCompatibleWithProtocol(ProtoInExtension, Proto)) {
201339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian        protocolExists = true;
202339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian        break;
203339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian      }
204339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    }
205339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    // Do we want to warn on a protocol in extension class which
206339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    // already exist in the class? Probably not.
20718df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor    if (!protocolExists) {
208339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian      ProtocolRefs.push_back(ProtoInExtension);
20918df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor      ProtocolLocs.push_back(Locs[i]);
21018df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor    }
211339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  }
212339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  if (ProtocolRefs.empty())
213339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    return;
214b106fc635b1523952332131785b700453a936e49Fariborz Jahanian  // Merge ProtocolRefs into class's protocol list;
21518df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  protocol_loc_iterator pl = protocol_loc_begin();
216339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  for (protocol_iterator p = protocol_begin(), e = protocol_end();
21718df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor       p != e; ++p, ++pl) {
218339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian    ProtocolRefs.push_back(*p);
21918df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor    ProtocolLocs.push_back(*pl);
22018df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  }
221339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  ReferencedProtocols.Destroy(C);
222339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian  unsigned NumProtoRefs = ProtocolRefs.size();
22318df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  setProtocolList(ProtocolRefs.data(), NumProtoRefs, ProtocolLocs.data(), C);
224339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian}
225339798eae1eb61c50ca68766ed028c0a16d0a284Fariborz Jahanian
2260e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian/// getClassExtension - Find class extension of the given class.
2270e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian// FIXME. can speed it up, if need be.
2280e5ad255729ee86b8ed57e659029008984517cdeFariborz JahanianObjCCategoryDecl* ObjCInterfaceDecl::getClassExtension() const {
2290e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian  const ObjCInterfaceDecl* ClassDecl = this;
2300e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian  for (ObjCCategoryDecl *CDecl = ClassDecl->getCategoryList(); CDecl;
2310e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian       CDecl = CDecl->getNextClassCategory())
2320e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian    if (CDecl->IsClassExtension())
2330e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian      return CDecl;
2340e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian  return 0;
2350e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian}
2360e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian
23717945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios KyrtzidisObjCIvarDecl *ObjCInterfaceDecl::lookupInstanceVariable(IdentifierInfo *ID,
23817945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis                                              ObjCInterfaceDecl *&clsDeclared) {
239ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  ObjCInterfaceDecl* ClassDecl = this;
240ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  while (ClassDecl != NULL) {
24117945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis    if (ObjCIvarDecl *I = ClassDecl->getIvarDecl(ID)) {
242496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian      clsDeclared = ClassDecl;
243496b5a894c5ec5425de53909f5aac3fb4771a2ecFariborz Jahanian      return I;
244ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    }
2450e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian    if (const ObjCCategoryDecl *CDecl = ClassDecl->getClassExtension())
2460e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian      if (ObjCIvarDecl *I = CDecl->getIvarDecl(ID)) {
2470e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian        clsDeclared = ClassDecl;
2480e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian        return I;
2490e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian      }
2500e5ad255729ee86b8ed57e659029008984517cdeFariborz Jahanian
251ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    ClassDecl = ClassDecl->getSuperClass();
252ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  }
253ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return NULL;
254ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
255ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
256cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian/// lookupInheritedClass - This method returns ObjCInterfaceDecl * of the super
257cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian/// class whose name is passed as argument. If it is not one of the super classes
258cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian/// the it returns NULL.
259cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz JahanianObjCInterfaceDecl *ObjCInterfaceDecl::lookupInheritedClass(
260cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian                                        const IdentifierInfo*ICName) {
261cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian  ObjCInterfaceDecl* ClassDecl = this;
262cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian  while (ClassDecl != NULL) {
263cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian    if (ClassDecl->getIdentifier() == ICName)
264cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian      return ClassDecl;
265cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian    ClassDecl = ClassDecl->getSuperClass();
266cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian  }
267cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian  return NULL;
268cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian}
269cd1876207f5564beba74e4b2524b664bdba0ba9fFariborz Jahanian
270aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis/// lookupMethod - This method returns an instance/class method by looking in
271ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// the class, its categories, and its super classes (using a linear search).
272aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios KyrtzidisObjCMethodDecl *ObjCInterfaceDecl::lookupMethod(Selector Sel,
273aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis                                                bool isInstance) const {
274aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis  const ObjCInterfaceDecl* ClassDecl = this;
275ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  ObjCMethodDecl *MethodDecl = 0;
2761eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
277ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  while (ClassDecl != NULL) {
278aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis    if ((MethodDecl = ClassDecl->getMethod(Sel, isInstance)))
279ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      return MethodDecl;
2801eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
281ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    // Didn't find one yet - look through protocols.
282ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    const ObjCList<ObjCProtocolDecl> &Protocols =
283ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      ClassDecl->getReferencedProtocols();
284ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    for (ObjCList<ObjCProtocolDecl>::iterator I = Protocols.begin(),
285ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner         E = Protocols.end(); I != E; ++I)
286aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis      if ((MethodDecl = (*I)->lookupMethod(Sel, isInstance)))
287ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner        return MethodDecl;
2881eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
289ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    // Didn't find one yet - now look through categories.
290ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    ObjCCategoryDecl *CatDecl = ClassDecl->getCategoryList();
291ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    while (CatDecl) {
292aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis      if ((MethodDecl = CatDecl->getMethod(Sel, isInstance)))
293ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner        return MethodDecl;
2941eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
295b558422a49dbf97d560e493fb1573d44f0abe221Steve Naroff      // Didn't find one yet - look through protocols.
296b558422a49dbf97d560e493fb1573d44f0abe221Steve Naroff      const ObjCList<ObjCProtocolDecl> &Protocols =
297b558422a49dbf97d560e493fb1573d44f0abe221Steve Naroff        CatDecl->getReferencedProtocols();
298b558422a49dbf97d560e493fb1573d44f0abe221Steve Naroff      for (ObjCList<ObjCProtocolDecl>::iterator I = Protocols.begin(),
299b558422a49dbf97d560e493fb1573d44f0abe221Steve Naroff           E = Protocols.end(); I != E; ++I)
300aa5420c1e36ab8e0e4bb87239d8b73a3a8ce75dbArgyrios Kyrtzidis        if ((MethodDecl = (*I)->lookupMethod(Sel, isInstance)))
301b558422a49dbf97d560e493fb1573d44f0abe221Steve Naroff          return MethodDecl;
302ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      CatDecl = CatDecl->getNextClassCategory();
303ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    }
304ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    ClassDecl = ClassDecl->getSuperClass();
305ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  }
306ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return NULL;
307ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
308ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
309d789d3d985e28c9404e62157af46dcb7331920e0Steve NaroffObjCMethodDecl *ObjCInterfaceDecl::lookupPrivateInstanceMethod(
310d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff                                   const Selector &Sel) {
311d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff  ObjCMethodDecl *Method = 0;
312d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff  if (ObjCImplementationDecl *ImpDecl = getImplementation())
313d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff    Method = ImpDecl->getInstanceMethod(Sel);
314d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff
315d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff  if (!Method && getSuperClass())
316d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff    return getSuperClass()->lookupPrivateInstanceMethod(Sel);
317d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff  return Method;
318d789d3d985e28c9404e62157af46dcb7331920e0Steve Naroff}
319ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
320ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
321ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCMethodDecl
3226c4ae5de0c356777446f823b573821fb95560d91Chris Lattner//===----------------------------------------------------------------------===//
3236c4ae5de0c356777446f823b573821fb95560d91Chris Lattner
3240ed844b04ea4387caa4e1cf3dc375d269657536bChris LattnerObjCMethodDecl *ObjCMethodDecl::Create(ASTContext &C,
3251eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                       SourceLocation beginLoc,
3266c4ae5de0c356777446f823b573821fb95560d91Chris Lattner                                       SourceLocation endLoc,
3276c4ae5de0c356777446f823b573821fb95560d91Chris Lattner                                       Selector SelInfo, QualType T,
3284bc1cb6aa635a5bf8fae99bf69c56c724c1e786cDouglas Gregor                                       TypeSourceInfo *ResultTInfo,
3290701bbb228dfd87e1fe82a0a4b7b9facfecb43daSteve Naroff                                       DeclContext *contextDecl,
330f6414927e67e27d9324d8d179c5f7ea620443924Daniel Dunbar                                       bool isInstance,
3316c4ae5de0c356777446f823b573821fb95560d91Chris Lattner                                       bool isVariadic,
3324607034e621aa77378ec75249d1e9eaf5de49b6aFariborz Jahanian                                       bool isSynthesized,
3337732cc9c0fdc97a2f8cce4e5933d8103213d1aefFariborz Jahanian                                       ImplementationControl impControl,
3347732cc9c0fdc97a2f8cce4e5933d8103213d1aefFariborz Jahanian                                       unsigned numSelectorArgs) {
3353e9704981d7691fdd44913bf1786e8d760d8a627Steve Naroff  return new (C) ObjCMethodDecl(beginLoc, endLoc,
3364bc1cb6aa635a5bf8fae99bf69c56c724c1e786cDouglas Gregor                                SelInfo, T, ResultTInfo, contextDecl,
3374bc1cb6aa635a5bf8fae99bf69c56c724c1e786cDouglas Gregor                                isInstance,
3387732cc9c0fdc97a2f8cce4e5933d8103213d1aefFariborz Jahanian                                isVariadic, isSynthesized, impControl,
3397732cc9c0fdc97a2f8cce4e5933d8103213d1aefFariborz Jahanian                                numSelectorArgs);
3400e77ba0bf769e2e5a4a93c079f241b02aeb3ef93Chris Lattner}
3410e77ba0bf769e2e5a4a93c079f241b02aeb3ef93Chris Lattner
34238af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattnervoid ObjCMethodDecl::Destroy(ASTContext &C) {
3438a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek  if (Body) Body->Destroy(C);
3448a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek  if (SelfDecl) SelfDecl->Destroy(C);
3451eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
3468a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek  for (param_iterator I=param_begin(), E=param_end(); I!=E; ++I)
3478a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek    if (*I) (*I)->Destroy(C);
348411280e5b25ba7dcd7c8a82a5c23880fe7632a3cChris Lattner
34938af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner  ParamInfo.Destroy(C);
350411280e5b25ba7dcd7c8a82a5c23880fe7632a3cChris Lattner
3518a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek  Decl::Destroy(C);
3528a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek}
3538a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek
35457ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis/// \brief A definition will return its interface declaration.
35557ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis/// An interface declaration will return its definition.
35657ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis/// Otherwise it will return itself.
35757ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios KyrtzidisObjCMethodDecl *ObjCMethodDecl::getNextRedeclaration() {
35857ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  ASTContext &Ctx = getASTContext();
35957ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  ObjCMethodDecl *Redecl = 0;
36057ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  Decl *CtxD = cast<Decl>(getDeclContext());
36157ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis
36257ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  if (ObjCInterfaceDecl *IFD = dyn_cast<ObjCInterfaceDecl>(CtxD)) {
36357ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis    if (ObjCImplementationDecl *ImplD = Ctx.getObjCImplementation(IFD))
36457ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis      Redecl = ImplD->getMethod(getSelector(), isInstanceMethod());
36557ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis
36657ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  } else if (ObjCCategoryDecl *CD = dyn_cast<ObjCCategoryDecl>(CtxD)) {
36757ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis    if (ObjCCategoryImplDecl *ImplD = Ctx.getObjCImplementation(CD))
36857ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis      Redecl = ImplD->getMethod(getSelector(), isInstanceMethod());
36957ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis
3704292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis  } else if (ObjCImplementationDecl *ImplD =
3714292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis               dyn_cast<ObjCImplementationDecl>(CtxD)) {
37257ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis    if (ObjCInterfaceDecl *IFD = ImplD->getClassInterface())
37357ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis      Redecl = IFD->getMethod(getSelector(), isInstanceMethod());
3744292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis
3754292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis  } else if (ObjCCategoryImplDecl *CImplD =
3764292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis               dyn_cast<ObjCCategoryImplDecl>(CtxD)) {
3770d69b8cc8e90a9364771837cb42d7031b4cbb984Steve Naroff    if (ObjCCategoryDecl *CatD = CImplD->getCategoryDecl())
3784292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis      Redecl = CatD->getMethod(getSelector(), isInstanceMethod());
37957ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  }
38057ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis
38157ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis  return Redecl ? Redecl : this;
38257ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis}
38357ea6bee79cc60ba20c7886b453f40f380dce1b1Argyrios Kyrtzidis
384e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios KyrtzidisObjCMethodDecl *ObjCMethodDecl::getCanonicalDecl() {
385e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis  Decl *CtxD = cast<Decl>(getDeclContext());
386e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis
387e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis  if (ObjCImplementationDecl *ImplD = dyn_cast<ObjCImplementationDecl>(CtxD)) {
388e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis    if (ObjCInterfaceDecl *IFD = ImplD->getClassInterface())
389e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis      if (ObjCMethodDecl *MD = IFD->getMethod(getSelector(),
390e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis                                              isInstanceMethod()))
391e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis        return MD;
392e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis
393e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis  } else if (ObjCCategoryImplDecl *CImplD =
394e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis               dyn_cast<ObjCCategoryImplDecl>(CtxD)) {
3950d69b8cc8e90a9364771837cb42d7031b4cbb984Steve Naroff    if (ObjCCategoryDecl *CatD = CImplD->getCategoryDecl())
396e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis      if (ObjCMethodDecl *MD = CatD->getMethod(getSelector(),
397e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis                                               isInstanceMethod()))
398e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis        return MD;
399e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis  }
400e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis
401e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis  return this;
402e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis}
403e7f9d301a10b4b3223e91d9be4362b44cba0a212Argyrios Kyrtzidis
4041eb4433ac451dc16f4133a88af2d002ac26c58efMike Stumpvoid ObjCMethodDecl::createImplicitParams(ASTContext &Context,
405ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                          const ObjCInterfaceDecl *OID) {
406ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  QualType selfTy;
407ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  if (isInstanceMethod()) {
408ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    // There may be no interface context due to error in declaration
409ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    // of the interface (which has been reported). Recover gracefully.
410ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    if (OID) {
4113b3a45858c6b2a45114e91902c3bf3c4b7f5f302Daniel Dunbar      selfTy = Context.getObjCInterfaceType(OID);
41214108da7f7fc059772711e4ffee1322a27b152a7Steve Naroff      selfTy = Context.getObjCObjectPointerType(selfTy);
413ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    } else {
414ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      selfTy = Context.getObjCIdType();
415ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    }
416ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  } else // we have a factory method.
417ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    selfTy = Context.getObjCClassType();
418ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
4191eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  setSelfDecl(ImplicitParamDecl::Create(Context, this, SourceLocation(),
42053c9d8a4b8f0a76cb9dd2fdd8c433ccf110f2eecSteve Naroff                                        &Context.Idents.get("self"), selfTy));
421ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
4221eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  setCmdDecl(ImplicitParamDecl::Create(Context, this, SourceLocation(),
4231eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                       &Context.Idents.get("_cmd"),
42453c9d8a4b8f0a76cb9dd2fdd8c433ccf110f2eecSteve Naroff                                       Context.getObjCSelType()));
425ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
426ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
427ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCInterfaceDecl *ObjCMethodDecl::getClassInterface() {
428ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  if (ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(getDeclContext()))
429ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    return ID;
430ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  if (ObjCCategoryDecl *CD = dyn_cast<ObjCCategoryDecl>(getDeclContext()))
431ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    return CD->getClassInterface();
432a8530375168f578e9039837c58054d55655c981bArgyrios Kyrtzidis  if (ObjCImplDecl *IMD = dyn_cast<ObjCImplDecl>(getDeclContext()))
433ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    return IMD->getClassInterface();
434a8530375168f578e9039837c58054d55655c981bArgyrios Kyrtzidis
435a8530375168f578e9039837c58054d55655c981bArgyrios Kyrtzidis  assert(!isa<ObjCProtocolDecl>(getDeclContext()) && "It's a protocol method");
436ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  assert(false && "unknown method context");
437ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return 0;
438ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
439ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
440ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
441ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCInterfaceDecl
442ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
4430b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner
4440ed844b04ea4387caa4e1cf3dc375d269657536bChris LattnerObjCInterfaceDecl *ObjCInterfaceDecl::Create(ASTContext &C,
445d04341000d35c8808a72838b057eed7bf13b7661Douglas Gregor                                             DeclContext *DC,
4460ed844b04ea4387caa4e1cf3dc375d269657536bChris Lattner                                             SourceLocation atLoc,
4471eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                             IdentifierInfo *Id,
448d6a07aaf62b40cdfbd96f6b874d02b06fc22d015Steve Naroff                                             SourceLocation ClassLoc,
4490e77ba0bf769e2e5a4a93c079f241b02aeb3ef93Chris Lattner                                             bool ForwardDecl, bool isInternal){
4503e9704981d7691fdd44913bf1786e8d760d8a627Steve Naroff  return new (C) ObjCInterfaceDecl(DC, atLoc, Id, ClassLoc, ForwardDecl,
4510e77ba0bf769e2e5a4a93c079f241b02aeb3ef93Chris Lattner                                     isInternal);
4520e77ba0bf769e2e5a4a93c079f241b02aeb3ef93Chris Lattner}
4536c4ae5de0c356777446f823b573821fb95560d91Chris Lattner
4540b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris LattnerObjCInterfaceDecl::
4550b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris LattnerObjCInterfaceDecl(DeclContext *DC, SourceLocation atLoc, IdentifierInfo *Id,
4560b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner                  SourceLocation CLoc, bool FD, bool isInternal)
4570b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner  : ObjCContainerDecl(ObjCInterface, DC, atLoc, Id),
458e881483a3bc22ffad62367501aa09ad8508fe363Chris Lattner    TypeForDecl(0), SuperClass(0),
4590b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner    CategoryList(0), ForwardDecl(FD), InternalInterface(isInternal),
4600b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner    ClassLoc(CLoc) {
461e4f039e01e797a38bc97bf22aff9832ecd18ff5fSteve Naroff}
462e4f039e01e797a38bc97bf22aff9832ecd18ff5fSteve Naroff
4631eb4433ac451dc16f4133a88af2d002ac26c58efMike Stumpvoid ObjCInterfaceDecl::Destroy(ASTContext &C) {
464d13d30258647e20c55a3910e4969f4a47bb2802cChris Lattner  for (ivar_iterator I = ivar_begin(), E = ivar_end(); I != E; ++I)
4658a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek    if (*I) (*I)->Destroy(C);
4661eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
4670b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner  // FIXME: CategoryList?
4681eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
4691a726d7cbf62ab13949743e9ef8c0670dd862e46Ted Kremenek  // FIXME: Because there is no clear ownership
4701a726d7cbf62ab13949743e9ef8c0670dd862e46Ted Kremenek  //  role between ObjCInterfaceDecls and the ObjCPropertyDecls that they
4711a726d7cbf62ab13949743e9ef8c0670dd862e46Ted Kremenek  //  reference, we destroy ObjCPropertyDecls in ~TranslationUnit.
4728a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek  Decl::Destroy(C);
4738a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek}
4748a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek
4758a1d722f13df383600f36d77f842957c8adb5f1bArgyrios KyrtzidisObjCImplementationDecl *ObjCInterfaceDecl::getImplementation() const {
4768a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  return getASTContext().getObjCImplementation(
4778a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis                                          const_cast<ObjCInterfaceDecl*>(this));
4788a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis}
4798a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
4808a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidisvoid ObjCInterfaceDecl::setImplementation(ObjCImplementationDecl *ImplD) {
4818a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  getASTContext().setObjCImplementation(this, ImplD);
4828a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis}
4838a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
4848a779314870760848e61da2c428a78971fe3f1c3Ted Kremenek
485ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// FindCategoryDeclaration - Finds category declaration in the list of
486ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// categories for this class and returns it. Name of the category is passed
487ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// in 'CategoryId'. If category not found, return 0;
488ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner///
489ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCCategoryDecl *
490ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCInterfaceDecl::FindCategoryDeclaration(IdentifierInfo *CategoryId) const {
491ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  for (ObjCCategoryDecl *Category = getCategoryList();
492ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner       Category; Category = Category->getNextClassCategory())
493ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    if (Category->getIdentifier() == CategoryId)
494ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      return Category;
495ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return 0;
496ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
497ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
4981cb35dd4840d21cec58648361180d5688446a9caArgyrios KyrtzidisObjCMethodDecl *
4991cb35dd4840d21cec58648361180d5688446a9caArgyrios KyrtzidisObjCInterfaceDecl::getCategoryInstanceMethod(Selector Sel) const {
5001cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis  for (ObjCCategoryDecl *Category = getCategoryList();
5011cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis       Category; Category = Category->getNextClassCategory())
5021cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis    if (ObjCCategoryImplDecl *Impl = Category->getImplementation())
5031cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis      if (ObjCMethodDecl *MD = Impl->getInstanceMethod(Sel))
5041cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis        return MD;
5051cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis  return 0;
5061cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis}
5071cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis
5081cb35dd4840d21cec58648361180d5688446a9caArgyrios KyrtzidisObjCMethodDecl *ObjCInterfaceDecl::getCategoryClassMethod(Selector Sel) const {
5091cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis  for (ObjCCategoryDecl *Category = getCategoryList();
5101cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis       Category; Category = Category->getNextClassCategory())
5111cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis    if (ObjCCategoryImplDecl *Impl = Category->getImplementation())
5121cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis      if (ObjCMethodDecl *MD = Impl->getClassMethod(Sel))
5131cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis        return MD;
5141cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis  return 0;
5151cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis}
5161cb35dd4840d21cec58648361180d5688446a9caArgyrios Kyrtzidis
5170fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian/// ClassImplementsProtocol - Checks that 'lProto' protocol
5180fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian/// has been implemented in IDecl class, its super class or categories (if
5190fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian/// lookupCategory is true).
5200fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanianbool ObjCInterfaceDecl::ClassImplementsProtocol(ObjCProtocolDecl *lProto,
5210fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian                                    bool lookupCategory,
5220fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian                                    bool RHSIsQualifiedID) {
5230fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  ObjCInterfaceDecl *IDecl = this;
5240fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  // 1st, look up the class.
5250fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  const ObjCList<ObjCProtocolDecl> &Protocols =
5260fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  IDecl->getReferencedProtocols();
5271eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
5280fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  for (ObjCList<ObjCProtocolDecl>::iterator PI = Protocols.begin(),
5290fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian       E = Protocols.end(); PI != E; ++PI) {
5300fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    if (getASTContext().ProtocolCompatibleWithProtocol(lProto, *PI))
5310fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian      return true;
5320fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    // This is dubious and is added to be compatible with gcc.  In gcc, it is
5330fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    // also allowed assigning a protocol-qualified 'id' type to a LHS object
5340fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    // when protocol in qualified LHS is in list of protocols in the rhs 'id'
5350fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    // object. This IMO, should be a bug.
5360fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    // FIXME: Treat this as an extension, and flag this as an error when GCC
5370fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    // extensions are not enabled.
5381eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    if (RHSIsQualifiedID &&
5390fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian        getASTContext().ProtocolCompatibleWithProtocol(*PI, lProto))
5400fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian      return true;
5410fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  }
5421eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
5430fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  // 2nd, look up the category.
5440fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  if (lookupCategory)
5450fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    for (ObjCCategoryDecl *CDecl = IDecl->getCategoryList(); CDecl;
5460fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian         CDecl = CDecl->getNextClassCategory()) {
5470fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian      for (ObjCCategoryDecl::protocol_iterator PI = CDecl->protocol_begin(),
5480fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian           E = CDecl->protocol_end(); PI != E; ++PI)
5490fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian        if (getASTContext().ProtocolCompatibleWithProtocol(lProto, *PI))
5500fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian          return true;
5510fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    }
5521eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
5530fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  // 3rd, look up the super class(s)
5540fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  if (IDecl->getSuperClass())
5550fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian    return
5560fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  IDecl->getSuperClass()->ClassImplementsProtocol(lProto, lookupCategory,
5570fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian                                                  RHSIsQualifiedID);
5581eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
5590fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian  return false;
5600fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian}
5610fd8904c5f71a11d29f67716c3ebdf7ad1c855fbFariborz Jahanian
562ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
563ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCIvarDecl
564ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
565ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
566a06549226f45d5b72169a3d054415616dd1014a2Daniel DunbarObjCIvarDecl *ObjCIvarDecl::Create(ASTContext &C, ObjCContainerDecl *DC,
5670c00aac5d618f39afc406c5b2e07642930af1d56Argyrios Kyrtzidis                                   SourceLocation L, IdentifierInfo *Id,
568a93c934af4fbf97cbe8e649d82e68ccacfe57c95John McCall                                   QualType T, TypeSourceInfo *TInfo,
569a1d5662d96465f0fddf8819d245da4d19b892effArgyrios Kyrtzidis                                   AccessControl ac, Expr *BW) {
570a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar  if (DC) {
571a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // Ivar's can only appear in interfaces, implementations (via synthesized
572a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // properties), and class extensions (via direct declaration, or synthesized
573a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // properties).
574a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    //
575a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // FIXME: This should really be asserting this:
576a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    //   (isa<ObjCCategoryDecl>(DC) &&
577a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    //    cast<ObjCCategoryDecl>(DC)->IsClassExtension()))
578a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // but unfortunately we sometimes place ivars into non-class extension
579a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // categories on error. This breaks an AST invariant, and should not be
580a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    // fixed.
581a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar    assert((isa<ObjCInterfaceDecl>(DC) || isa<ObjCImplementationDecl>(DC) ||
582a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar            isa<ObjCCategoryDecl>(DC)) &&
583a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar           "Invalid ivar decl context!");
584a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar  }
585a06549226f45d5b72169a3d054415616dd1014a2Daniel Dunbar
586a93c934af4fbf97cbe8e649d82e68ccacfe57c95John McCall  return new (C) ObjCIvarDecl(DC, L, Id, T, TInfo, ac, BW);
5876c4ae5de0c356777446f823b573821fb95560d91Chris Lattner}
5886c4ae5de0c356777446f823b573821fb95560d91Chris Lattner
58927a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbarconst ObjCInterfaceDecl *ObjCIvarDecl::getContainingInterface() const {
59027a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  const ObjCContainerDecl *DC = cast<ObjCContainerDecl>(getDeclContext());
59127a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar
59227a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  switch (DC->getKind()) {
59327a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  default:
59427a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  case ObjCCategoryImpl:
59527a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  case ObjCProtocol:
59627a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    assert(0 && "invalid ivar container!");
59727a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    return 0;
59827a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar
59927a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    // Ivars can only appear in class extension categories.
60027a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  case ObjCCategory: {
60127a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    const ObjCCategoryDecl *CD = cast<ObjCCategoryDecl>(DC);
60227a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    assert(CD->IsClassExtension() && "invalid container for ivar!");
60327a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    return CD->getClassInterface();
60427a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  }
60527a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar
60627a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  case ObjCImplementation:
60727a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    return cast<ObjCImplementationDecl>(DC)->getClassInterface();
60801e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek
60927a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  case ObjCInterface:
61027a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar    return cast<ObjCInterfaceDecl>(DC);
61127a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar  }
61227a961a6adab85cfcf7e48485bbec9237719ae96Daniel Dunbar}
613ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
614ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
615ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCAtDefsFieldDecl
616ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
617ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
61801e6779faca1e3a3164c697d6e2dfee0881a6981Ted KremenekObjCAtDefsFieldDecl
61944b4321feab46299d3f5cfd404680884752a0fcfDouglas Gregor*ObjCAtDefsFieldDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation L,
62001e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek                             IdentifierInfo *Id, QualType T, Expr *BW) {
6213e9704981d7691fdd44913bf1786e8d760d8a627Steve Naroff  return new (C) ObjCAtDefsFieldDecl(DC, L, Id, T, BW);
62201e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek}
62301e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek
62401e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenekvoid ObjCAtDefsFieldDecl::Destroy(ASTContext& C) {
62501e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek  this->~ObjCAtDefsFieldDecl();
6261eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  C.Deallocate((void *)this);
62701e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek}
62801e6779faca1e3a3164c697d6e2dfee0881a6981Ted Kremenek
629ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
630ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCProtocolDecl
631ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
632ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
633d04341000d35c8808a72838b057eed7bf13b7661Douglas GregorObjCProtocolDecl *ObjCProtocolDecl::Create(ASTContext &C, DeclContext *DC,
6341eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                           SourceLocation L,
635c858105d41602a2dadb2efbc1af80a7b791ebac3Chris Lattner                                           IdentifierInfo *Id) {
6363e9704981d7691fdd44913bf1786e8d760d8a627Steve Naroff  return new (C) ObjCProtocolDecl(DC, L, Id);
637cca59d77c4b84fd2da268018dbaf9431a621e75bChris Lattner}
638cca59d77c4b84fd2da268018dbaf9431a621e75bChris Lattner
639411280e5b25ba7dcd7c8a82a5c23880fe7632a3cChris Lattnervoid ObjCProtocolDecl::Destroy(ASTContext &C) {
64038af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner  ReferencedProtocols.Destroy(C);
641411280e5b25ba7dcd7c8a82a5c23880fe7632a3cChris Lattner  ObjCContainerDecl::Destroy(C);
6421c8a413c1e00636c77666ddf1e3b0311f3fa8c81Ted Kremenek}
6431c8a413c1e00636c77666ddf1e3b0311f3fa8c81Ted Kremenek
64491b0b0cf6b537cbcbca0038c7032f87161a41d31Steve NaroffObjCProtocolDecl *ObjCProtocolDecl::lookupProtocolNamed(IdentifierInfo *Name) {
64591b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff  ObjCProtocolDecl *PDecl = this;
64691b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff
64791b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff  if (Name == getIdentifier())
64891b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff    return PDecl;
64991b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff
65091b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff  for (protocol_iterator I = protocol_begin(), E = protocol_end(); I != E; ++I)
65191b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff    if ((PDecl = (*I)->lookupProtocolNamed(Name)))
65291b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff      return PDecl;
6531eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
65491b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff  return NULL;
65591b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff}
65691b0b0cf6b537cbcbca0038c7032f87161a41d31Steve Naroff
657094e2bb6730d63e0f6919e4839522a43b7644181Argyrios Kyrtzidis// lookupMethod - Lookup a instance/class method in the protocol and protocols
658ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// it inherited.
659094e2bb6730d63e0f6919e4839522a43b7644181Argyrios KyrtzidisObjCMethodDecl *ObjCProtocolDecl::lookupMethod(Selector Sel,
660094e2bb6730d63e0f6919e4839522a43b7644181Argyrios Kyrtzidis                                               bool isInstance) const {
661ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  ObjCMethodDecl *MethodDecl = NULL;
6621eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
663094e2bb6730d63e0f6919e4839522a43b7644181Argyrios Kyrtzidis  if ((MethodDecl = getMethod(Sel, isInstance)))
664ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    return MethodDecl;
6651eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
666ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  for (protocol_iterator I = protocol_begin(), E = protocol_end(); I != E; ++I)
667094e2bb6730d63e0f6919e4839522a43b7644181Argyrios Kyrtzidis    if ((MethodDecl = (*I)->lookupMethod(Sel, isInstance)))
668ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      return MethodDecl;
669ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return NULL;
670ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
671411280e5b25ba7dcd7c8a82a5c23880fe7632a3cChris Lattner
672ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
673ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCClassDecl
674ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
675411280e5b25ba7dcd7c8a82a5c23880fe7632a3cChris Lattner
6761eb4433ac451dc16f4133a88af2d002ac26c58efMike StumpObjCClassDecl::ObjCClassDecl(DeclContext *DC, SourceLocation L,
677321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek                             ObjCInterfaceDecl *const *Elts,
678321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek                             const SourceLocation *Locs,
679321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek                             unsigned nElts,
68038af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner                             ASTContext &C)
68138af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner  : Decl(ObjCClass, DC, L) {
682321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  setClassList(C, Elts, Locs, nElts);
68338af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner}
68438af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner
685321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenekvoid ObjCClassDecl::setClassList(ASTContext &C, ObjCInterfaceDecl*const*List,
686321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek                                 const SourceLocation *Locs, unsigned Num) {
687321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  ForwardDecls = (ObjCClassRef*) C.Allocate(sizeof(ObjCClassRef)*Num,
688321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek                                            llvm::alignof<ObjCClassRef>());
689321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  for (unsigned i = 0; i < Num; ++i)
690321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek    new (&ForwardDecls[i]) ObjCClassRef(List[i], Locs[i]);
691321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek
692321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  NumDecls = Num;
693321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek}
69438af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner
695d04341000d35c8808a72838b057eed7bf13b7661Douglas GregorObjCClassDecl *ObjCClassDecl::Create(ASTContext &C, DeclContext *DC,
6960ed844b04ea4387caa4e1cf3dc375d269657536bChris Lattner                                     SourceLocation L,
69767956052ea5fb0cd7f443de96a11f9a0176dc681Chris Lattner                                     ObjCInterfaceDecl *const *Elts,
698321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek                                     const SourceLocation *Locs,
69967956052ea5fb0cd7f443de96a11f9a0176dc681Chris Lattner                                     unsigned nElts) {
700321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  return new (C) ObjCClassDecl(DC, L, Elts, Locs, nElts, C);
70161f9d41036e30ff80130f99b31c0626e3ef057ccChris Lattner}
70261f9d41036e30ff80130f99b31c0626e3ef057ccChris Lattner
7030b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattnervoid ObjCClassDecl::Destroy(ASTContext &C) {
704321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  // ObjCInterfaceDecls registered with a DeclContext will get destroyed
705321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  // when the DeclContext is destroyed.  For those created only by a forward
706321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  // declaration, the first @class that created the ObjCInterfaceDecl gets
707321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  // to destroy it.
708321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  // FIXME: Note that this ownership role is very brittle; a better
709321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  // polict is surely need in the future.
710321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  for (iterator I = begin(), E = end(); I !=E ; ++I) {
711321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek    ObjCInterfaceDecl *ID = I->getInterface();
712321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek    if (ID->isForwardDecl() && ID->getLocStart() == getLocStart())
713321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek      ID->Destroy(C);
714321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  }
715321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek
716321c22f1c4271c3d9a3d4d3fc18847f948ab595bTed Kremenek  C.Deallocate(ForwardDecls);
717400d95fb7bb9fac609f8613862b84f3a2a7d510fTed Kremenek  Decl::Destroy(C);
718400d95fb7bb9fac609f8613862b84f3a2a7d510fTed Kremenek}
719400d95fb7bb9fac609f8613862b84f3a2a7d510fTed Kremenek
7202dbdd622d02d1bfbe1e5bcf421b07b74c7a748f1Ted KremenekSourceRange ObjCClassDecl::getSourceRange() const {
7212dbdd622d02d1bfbe1e5bcf421b07b74c7a748f1Ted Kremenek  // FIXME: We should include the semicolon
7222dbdd622d02d1bfbe1e5bcf421b07b74c7a748f1Ted Kremenek  assert(NumDecls);
7232dbdd622d02d1bfbe1e5bcf421b07b74c7a748f1Ted Kremenek  return SourceRange(getLocation(), ForwardDecls[NumDecls-1].getLocation());
7242dbdd622d02d1bfbe1e5bcf421b07b74c7a748f1Ted Kremenek}
7252dbdd622d02d1bfbe1e5bcf421b07b74c7a748f1Ted Kremenek
726ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
727ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCForwardProtocolDecl
728ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
729ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
73038af2deb27cdfa1a95bde96e30dab15dce53fcefChris LattnerObjCForwardProtocolDecl::
73138af2deb27cdfa1a95bde96e30dab15dce53fcefChris LattnerObjCForwardProtocolDecl(DeclContext *DC, SourceLocation L,
73238af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner                        ObjCProtocolDecl *const *Elts, unsigned nElts,
73318df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor                        const SourceLocation *Locs, ASTContext &C)
7341eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump: Decl(ObjCForwardProtocol, DC, L) {
73518df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  ReferencedProtocols.set(Elts, nElts, Locs, C);
73638af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner}
73738af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner
73838af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner
73961f9d41036e30ff80130f99b31c0626e3ef057ccChris LattnerObjCForwardProtocolDecl *
740d04341000d35c8808a72838b057eed7bf13b7661Douglas GregorObjCForwardProtocolDecl::Create(ASTContext &C, DeclContext *DC,
7411eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                SourceLocation L,
74207fa7749da805969f2ed467a4eb5b405a4ff9a23Chris Lattner                                ObjCProtocolDecl *const *Elts,
74318df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor                                unsigned NumElts,
74418df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor                                const SourceLocation *Locs) {
74518df52bbb5d28ca082064d31ae7558dbdae52377Douglas Gregor  return new (C) ObjCForwardProtocolDecl(DC, L, Elts, NumElts, Locs, C);
7460b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner}
7470b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattner
7480b7ebb3dba0df0a6cbf221e5edbc6a4b8848478cChris Lattnervoid ObjCForwardProtocolDecl::Destroy(ASTContext &C) {
74938af2deb27cdfa1a95bde96e30dab15dce53fcefChris Lattner  ReferencedProtocols.Destroy(C);
75007fa7749da805969f2ed467a4eb5b405a4ff9a23Chris Lattner  Decl::Destroy(C);
75105ac3ef08f9d06e0a4439073c9edabf7f912f946Ted Kremenek}
75205ac3ef08f9d06e0a4439073c9edabf7f912f946Ted Kremenek
753ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
754ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCCategoryDecl
755ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
756ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
757d04341000d35c8808a72838b057eed7bf13b7661Douglas GregorObjCCategoryDecl *ObjCCategoryDecl::Create(ASTContext &C, DeclContext *DC,
7583db211b617c5073aa70eb25d37ed44ae0dca17c4Douglas Gregor                                           SourceLocation AtLoc,
7593db211b617c5073aa70eb25d37ed44ae0dca17c4Douglas Gregor                                           SourceLocation ClassNameLoc,
7603db211b617c5073aa70eb25d37ed44ae0dca17c4Douglas Gregor                                           SourceLocation CategoryNameLoc,
76161f9d41036e30ff80130f99b31c0626e3ef057ccChris Lattner                                           IdentifierInfo *Id) {
7623db211b617c5073aa70eb25d37ed44ae0dca17c4Douglas Gregor  return new (C) ObjCCategoryDecl(DC, AtLoc, ClassNameLoc, CategoryNameLoc, Id);
76361f9d41036e30ff80130f99b31c0626e3ef057ccChris Lattner}
76461f9d41036e30ff80130f99b31c0626e3ef057ccChris Lattner
7658a1d722f13df383600f36d77f842957c8adb5f1bArgyrios KyrtzidisObjCCategoryImplDecl *ObjCCategoryDecl::getImplementation() const {
7668a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  return getASTContext().getObjCImplementation(
7678a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis                                           const_cast<ObjCCategoryDecl*>(this));
7688a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis}
7698a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
7708a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidisvoid ObjCCategoryDecl::setImplementation(ObjCCategoryImplDecl *ImplD) {
7718a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  getASTContext().setObjCImplementation(this, ImplD);
7728a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis}
7738a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
7748a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
775ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
776ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCCategoryImplDecl
777ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
778ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner
77975c9cae5f85c72cbb1649e93849e16ede3f07522Chris LattnerObjCCategoryImplDecl *
780d04341000d35c8808a72838b057eed7bf13b7661Douglas GregorObjCCategoryImplDecl::Create(ASTContext &C, DeclContext *DC,
7810ed844b04ea4387caa4e1cf3dc375d269657536bChris Lattner                             SourceLocation L,IdentifierInfo *Id,
78275c9cae5f85c72cbb1649e93849e16ede3f07522Chris Lattner                             ObjCInterfaceDecl *ClassInterface) {
7833e9704981d7691fdd44913bf1786e8d760d8a627Steve Naroff  return new (C) ObjCCategoryImplDecl(DC, L, Id, ClassInterface);
78475c9cae5f85c72cbb1649e93849e16ede3f07522Chris Lattner}
78575c9cae5f85c72cbb1649e93849e16ede3f07522Chris Lattner
7860d69b8cc8e90a9364771837cb42d7031b4cbb984Steve NaroffObjCCategoryDecl *ObjCCategoryImplDecl::getCategoryDecl() const {
787ebfa339321f8a4df9d5011e591a615d5765107d5Ted Kremenek  // The class interface might be NULL if we are working with invalid code.
788ebfa339321f8a4df9d5011e591a615d5765107d5Ted Kremenek  if (const ObjCInterfaceDecl *ID = getClassInterface())
789ebfa339321f8a4df9d5011e591a615d5765107d5Ted Kremenek    return ID->FindCategoryDeclaration(getIdentifier());
790ebfa339321f8a4df9d5011e591a615d5765107d5Ted Kremenek  return 0;
7914292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis}
7924292073a858f72769fa405b48390620c8932f8aeArgyrios Kyrtzidis
793f8d17a59167d9c2026506ed8813ea434d93b662aChris Lattner
79417945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidisvoid ObjCImplDecl::addPropertyImplementation(ObjCPropertyImplDecl *property) {
7952c2d43c557beca1b4ba4bd743f33978aecb46a97Douglas Gregor  // FIXME: The context should be correct before we get here.
796653f1b1bf293a9bd96fd4dd6372e779cc7af1597Douglas Gregor  property->setLexicalDeclContext(this);
79717945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis  addDecl(property);
798653f1b1bf293a9bd96fd4dd6372e779cc7af1597Douglas Gregor}
799653f1b1bf293a9bd96fd4dd6372e779cc7af1597Douglas Gregor
8008a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidisvoid ObjCImplDecl::setClassInterface(ObjCInterfaceDecl *IFace) {
8018a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  ASTContext &Ctx = getASTContext();
8028a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
8038a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  if (ObjCImplementationDecl *ImplD
80498f2cca4b2731b5d43da7c1582dd443ecead658dDuncan Sands        = dyn_cast_or_null<ObjCImplementationDecl>(this)) {
8058a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis    if (IFace)
8068a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis      Ctx.setObjCImplementation(IFace, ImplD);
8078a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
80898f2cca4b2731b5d43da7c1582dd443ecead658dDuncan Sands  } else if (ObjCCategoryImplDecl *ImplD =
8098a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis             dyn_cast_or_null<ObjCCategoryImplDecl>(this)) {
8108a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis    if (ObjCCategoryDecl *CD = IFace->FindCategoryDeclaration(getIdentifier()))
8118a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis      Ctx.setObjCImplementation(CD, ImplD);
8128a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  }
8138a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
8148a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis  ClassInterface = IFace;
8158a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis}
8168a1d722f13df383600f36d77f842957c8adb5f1bArgyrios Kyrtzidis
817ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// FindPropertyImplIvarDecl - This method lookup the ivar in the list of
818ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// properties implemented in this category @implementation block and returns
819ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// the implemented property that uses it.
820aaa63a761c6671a08e3f4f463435b72739fa194bFariborz Jahanian///
8213aa1861bd8b5121e53379b1a00f9d6ad8dead4f6Chris LattnerObjCPropertyImplDecl *ObjCImplDecl::
82217945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios KyrtzidisFindPropertyImplIvarDecl(IdentifierInfo *ivarId) const {
82317945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis  for (propimpl_iterator i = propimpl_begin(), e = propimpl_end(); i != e; ++i){
824ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    ObjCPropertyImplDecl *PID = *i;
825ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    if (PID->getPropertyIvarDecl() &&
826ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner        PID->getPropertyIvarDecl()->getIdentifier() == ivarId)
827ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      return PID;
828ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  }
8290701bbb228dfd87e1fe82a0a4b7b9facfecb43daSteve Naroff  return 0;
8300701bbb228dfd87e1fe82a0a4b7b9facfecb43daSteve Naroff}
8310701bbb228dfd87e1fe82a0a4b7b9facfecb43daSteve Naroff
832ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// FindPropertyImplDecl - This method looks up a previous ObjCPropertyImplDecl
833ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// added to the list of those properties @synthesized/@dynamic in this
834ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner/// category @implementation block.
835559c0c4bbecc017aab0716d546c4fefbcc194687Fariborz Jahanian///
8363aa1861bd8b5121e53379b1a00f9d6ad8dead4f6Chris LattnerObjCPropertyImplDecl *ObjCImplDecl::
83717945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios KyrtzidisFindPropertyImplDecl(IdentifierInfo *Id) const {
83817945a0f64fe03ff6ec0c2146005a87636e3ac12Argyrios Kyrtzidis  for (propimpl_iterator i = propimpl_begin(), e = propimpl_end(); i != e; ++i){
839ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    ObjCPropertyImplDecl *PID = *i;
840ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner    if (PID->getPropertyDecl()->getIdentifier() == Id)
841ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner      return PID;
842f034e9cc4dad81d8fe6eb88a84da55b2909a9cddFariborz Jahanian  }
843559c0c4bbecc017aab0716d546c4fefbcc194687Fariborz Jahanian  return 0;
844559c0c4bbecc017aab0716d546c4fefbcc194687Fariborz Jahanian}
845559c0c4bbecc017aab0716d546c4fefbcc194687Fariborz Jahanian
846900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramerllvm::raw_ostream &clang::operator<<(llvm::raw_ostream &OS,
847900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer                                     const ObjCCategoryImplDecl *CID) {
848900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer  OS << CID->getName();
849900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer  return OS;
850900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer}
851900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer
852ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
853ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCImplementationDecl
854ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
8551e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
856ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCImplementationDecl *
8571eb4433ac451dc16f4133a88af2d002ac26c58efMike StumpObjCImplementationDecl::Create(ASTContext &C, DeclContext *DC,
858ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                               SourceLocation L,
859ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                               ObjCInterfaceDecl *ClassInterface,
860ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                               ObjCInterfaceDecl *SuperDecl) {
861ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return new (C) ObjCImplementationDecl(DC, L, ClassInterface, SuperDecl);
862ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner}
8631e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
864900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramerllvm::raw_ostream &clang::operator<<(llvm::raw_ostream &OS,
865900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer                                     const ObjCImplementationDecl *ID) {
866900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer  OS << ID->getName();
867900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer  return OS;
868900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer}
869900fc6388e803868a34b9483510c345e9b49d7ebBenjamin Kramer
870ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
871ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCCompatibleAliasDecl
872ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
8731e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
874ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCCompatibleAliasDecl *
875ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCCompatibleAliasDecl::Create(ASTContext &C, DeclContext *DC,
876ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                SourceLocation L,
8771eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                IdentifierInfo *Id,
878ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                ObjCInterfaceDecl* AliasedClass) {
879ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner  return new (C) ObjCCompatibleAliasDecl(DC, L, Id, AliasedClass);
8801e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner}
8811e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
882ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
883ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCPropertyDecl
884ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
8851e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
886ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris LattnerObjCPropertyDecl *ObjCPropertyDecl::Create(ASTContext &C, DeclContext *DC,
887ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                           SourceLocation L,
888ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                           IdentifierInfo *Id,
889d0502407c1b41b2ace326f355d7b7a6876246223Fariborz Jahanian                                           SourceLocation AtLoc,
890ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                           QualType T,
891ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner                                           PropertyControl propControl) {
892d0502407c1b41b2ace326f355d7b7a6876246223Fariborz Jahanian  return new (C) ObjCPropertyDecl(DC, L, Id, AtLoc, T);
8931e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner}
8941e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
8951e03a561f4bd96910cb31a8af53a6ad321a12b51Chris Lattner
896ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
897ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner// ObjCPropertyImplDecl
898ab35163a5b80bf1bd49f0eebb708970f2b0e04e9Chris Lattner//===----------------------------------------------------------------------===//
899f4af5154571e0c5eadb19df10e65464766ef6683Chris Lattner
900628b96f34e93b643b6e15e75eabb8d96079a7e27Fariborz JahanianObjCPropertyImplDecl *ObjCPropertyImplDecl::Create(ASTContext &C,
901d04341000d35c8808a72838b057eed7bf13b7661Douglas Gregor                                                   DeclContext *DC,
902628b96f34e93b643b6e15e75eabb8d96079a7e27Fariborz Jahanian                                                   SourceLocation atLoc,
903628b96f34e93b643b6e15e75eabb8d96079a7e27Fariborz Jahanian                                                   SourceLocation L,
904628b96f34e93b643b6e15e75eabb8d96079a7e27Fariborz Jahanian                                                   ObjCPropertyDecl *property,
9059f0afd4e79601d9982072ff9318e6f9a982c770eDaniel Dunbar                                                   Kind PK,
906628b96f34e93b643b6e15e75eabb8d96079a7e27Fariborz Jahanian                                                   ObjCIvarDecl *ivar) {
9073e9704981d7691fdd44913bf1786e8d760d8a627Steve Naroff  return new (C) ObjCPropertyImplDecl(DC, atLoc, L, property, PK, ivar);
908628b96f34e93b643b6e15e75eabb8d96079a7e27Fariborz Jahanian}
909f4af5154571e0c5eadb19df10e65464766ef6683Chris Lattner
9100ed844b04ea4387caa4e1cf3dc375d269657536bChris Lattner
911