1 //===--- DeclObjC.cpp - ObjC Declaration AST Node Implementation ----------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file implements the Objective-C related Decl classes.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "clang/AST/DeclObjC.h"
15 #include "clang/AST/ASTContext.h"
16 #include "clang/AST/ASTMutationListener.h"
17 #include "clang/AST/Attr.h"
18 #include "clang/AST/Stmt.h"
19 #include "llvm/ADT/STLExtras.h"
20 #include "llvm/ADT/SmallString.h"
21 using namespace clang;
22 
23 //===----------------------------------------------------------------------===//
24 // ObjCListBase
25 //===----------------------------------------------------------------------===//
26 
set(void * const * InList,unsigned Elts,ASTContext & Ctx)27 void ObjCListBase::set(void *const* InList, unsigned Elts, ASTContext &Ctx) {
28   List = nullptr;
29   if (Elts == 0) return;  // Setting to an empty list is a noop.
30 
31 
32   List = new (Ctx) void*[Elts];
33   NumElts = Elts;
34   memcpy(List, InList, sizeof(void*)*Elts);
35 }
36 
set(ObjCProtocolDecl * const * InList,unsigned Elts,const SourceLocation * Locs,ASTContext & Ctx)37 void ObjCProtocolList::set(ObjCProtocolDecl* const* InList, unsigned Elts,
38                            const SourceLocation *Locs, ASTContext &Ctx) {
39   if (Elts == 0)
40     return;
41 
42   Locations = new (Ctx) SourceLocation[Elts];
43   memcpy(Locations, Locs, sizeof(SourceLocation) * Elts);
44   set(InList, Elts, Ctx);
45 }
46 
47 //===----------------------------------------------------------------------===//
48 // ObjCInterfaceDecl
49 //===----------------------------------------------------------------------===//
50 
anchor()51 void ObjCContainerDecl::anchor() { }
52 
53 /// getIvarDecl - This method looks up an ivar in this ContextDecl.
54 ///
55 ObjCIvarDecl *
getIvarDecl(IdentifierInfo * Id) const56 ObjCContainerDecl::getIvarDecl(IdentifierInfo *Id) const {
57   lookup_result R = lookup(Id);
58   for (lookup_iterator Ivar = R.begin(), IvarEnd = R.end();
59        Ivar != IvarEnd; ++Ivar) {
60     if (ObjCIvarDecl *ivar = dyn_cast<ObjCIvarDecl>(*Ivar))
61       return ivar;
62   }
63   return nullptr;
64 }
65 
66 // Get the local instance/class method declared in this interface.
67 ObjCMethodDecl *
getMethod(Selector Sel,bool isInstance,bool AllowHidden) const68 ObjCContainerDecl::getMethod(Selector Sel, bool isInstance,
69                              bool AllowHidden) const {
70   // If this context is a hidden protocol definition, don't find any
71   // methods there.
72   if (const ObjCProtocolDecl *Proto = dyn_cast<ObjCProtocolDecl>(this)) {
73     if (const ObjCProtocolDecl *Def = Proto->getDefinition())
74       if (Def->isHidden() && !AllowHidden)
75         return nullptr;
76   }
77 
78   // Since instance & class methods can have the same name, the loop below
79   // ensures we get the correct method.
80   //
81   // @interface Whatever
82   // - (int) class_method;
83   // + (float) class_method;
84   // @end
85   //
86   lookup_result R = lookup(Sel);
87   for (lookup_iterator Meth = R.begin(), MethEnd = R.end();
88        Meth != MethEnd; ++Meth) {
89     ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(*Meth);
90     if (MD && MD->isInstanceMethod() == isInstance)
91       return MD;
92   }
93   return nullptr;
94 }
95 
96 /// \brief This routine returns 'true' if a user declared setter method was
97 /// found in the class, its protocols, its super classes or categories.
98 /// It also returns 'true' if one of its categories has declared a 'readwrite'
99 /// property.  This is because, user must provide a setter method for the
100 /// category's 'readwrite' property.
HasUserDeclaredSetterMethod(const ObjCPropertyDecl * Property) const101 bool ObjCContainerDecl::HasUserDeclaredSetterMethod(
102     const ObjCPropertyDecl *Property) const {
103   Selector Sel = Property->getSetterName();
104   lookup_result R = lookup(Sel);
105   for (lookup_iterator Meth = R.begin(), MethEnd = R.end();
106        Meth != MethEnd; ++Meth) {
107     ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(*Meth);
108     if (MD && MD->isInstanceMethod() && !MD->isImplicit())
109       return true;
110   }
111 
112   if (const ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(this)) {
113     // Also look into categories, including class extensions, looking
114     // for a user declared instance method.
115     for (const auto *Cat : ID->visible_categories()) {
116       if (ObjCMethodDecl *MD = Cat->getInstanceMethod(Sel))
117         if (!MD->isImplicit())
118           return true;
119       if (Cat->IsClassExtension())
120         continue;
121       // Also search through the categories looking for a 'readwrite'
122       // declaration of this property. If one found, presumably a setter will
123       // be provided (properties declared in categories will not get
124       // auto-synthesized).
125       for (const auto *P : Cat->properties())
126         if (P->getIdentifier() == Property->getIdentifier()) {
127           if (P->getPropertyAttributes() & ObjCPropertyDecl::OBJC_PR_readwrite)
128             return true;
129           break;
130         }
131     }
132 
133     // Also look into protocols, for a user declared instance method.
134     for (const auto *Proto : ID->all_referenced_protocols())
135       if (Proto->HasUserDeclaredSetterMethod(Property))
136         return true;
137 
138     // And in its super class.
139     ObjCInterfaceDecl *OSC = ID->getSuperClass();
140     while (OSC) {
141       if (OSC->HasUserDeclaredSetterMethod(Property))
142         return true;
143       OSC = OSC->getSuperClass();
144     }
145   }
146   if (const ObjCProtocolDecl *PD = dyn_cast<ObjCProtocolDecl>(this))
147     for (const auto *PI : PD->protocols())
148       if (PI->HasUserDeclaredSetterMethod(Property))
149         return true;
150   return false;
151 }
152 
153 ObjCPropertyDecl *
findPropertyDecl(const DeclContext * DC,const IdentifierInfo * propertyID)154 ObjCPropertyDecl::findPropertyDecl(const DeclContext *DC,
155                                    const IdentifierInfo *propertyID) {
156   // If this context is a hidden protocol definition, don't find any
157   // property.
158   if (const ObjCProtocolDecl *Proto = dyn_cast<ObjCProtocolDecl>(DC)) {
159     if (const ObjCProtocolDecl *Def = Proto->getDefinition())
160       if (Def->isHidden())
161         return nullptr;
162   }
163 
164   DeclContext::lookup_result R = DC->lookup(propertyID);
165   for (DeclContext::lookup_iterator I = R.begin(), E = R.end(); I != E;
166        ++I)
167     if (ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(*I))
168       return PD;
169 
170   return nullptr;
171 }
172 
173 IdentifierInfo *
getDefaultSynthIvarName(ASTContext & Ctx) const174 ObjCPropertyDecl::getDefaultSynthIvarName(ASTContext &Ctx) const {
175   SmallString<128> ivarName;
176   {
177     llvm::raw_svector_ostream os(ivarName);
178     os << '_' << getIdentifier()->getName();
179   }
180   return &Ctx.Idents.get(ivarName.str());
181 }
182 
183 /// FindPropertyDeclaration - Finds declaration of the property given its name
184 /// in 'PropertyId' and returns it. It returns 0, if not found.
FindPropertyDeclaration(const IdentifierInfo * PropertyId) const185 ObjCPropertyDecl *ObjCContainerDecl::FindPropertyDeclaration(
186     const IdentifierInfo *PropertyId) const {
187   // Don't find properties within hidden protocol definitions.
188   if (const ObjCProtocolDecl *Proto = dyn_cast<ObjCProtocolDecl>(this)) {
189     if (const ObjCProtocolDecl *Def = Proto->getDefinition())
190       if (Def->isHidden())
191         return nullptr;
192   }
193 
194   if (ObjCPropertyDecl *PD =
195         ObjCPropertyDecl::findPropertyDecl(cast<DeclContext>(this), PropertyId))
196     return PD;
197 
198   switch (getKind()) {
199     default:
200       break;
201     case Decl::ObjCProtocol: {
202       const ObjCProtocolDecl *PID = cast<ObjCProtocolDecl>(this);
203       for (const auto *I : PID->protocols())
204         if (ObjCPropertyDecl *P = I->FindPropertyDeclaration(PropertyId))
205           return P;
206       break;
207     }
208     case Decl::ObjCInterface: {
209       const ObjCInterfaceDecl *OID = cast<ObjCInterfaceDecl>(this);
210       // Look through categories (but not extensions).
211       for (const auto *Cat : OID->visible_categories()) {
212         if (!Cat->IsClassExtension())
213           if (ObjCPropertyDecl *P = Cat->FindPropertyDeclaration(PropertyId))
214             return P;
215       }
216 
217       // Look through protocols.
218       for (const auto *I : OID->all_referenced_protocols())
219         if (ObjCPropertyDecl *P = I->FindPropertyDeclaration(PropertyId))
220           return P;
221 
222       // Finally, check the super class.
223       if (const ObjCInterfaceDecl *superClass = OID->getSuperClass())
224         return superClass->FindPropertyDeclaration(PropertyId);
225       break;
226     }
227     case Decl::ObjCCategory: {
228       const ObjCCategoryDecl *OCD = cast<ObjCCategoryDecl>(this);
229       // Look through protocols.
230       if (!OCD->IsClassExtension())
231         for (const auto *I : OCD->protocols())
232           if (ObjCPropertyDecl *P = I->FindPropertyDeclaration(PropertyId))
233             return P;
234       break;
235     }
236   }
237   return nullptr;
238 }
239 
anchor()240 void ObjCInterfaceDecl::anchor() { }
241 
242 /// FindPropertyVisibleInPrimaryClass - Finds declaration of the property
243 /// with name 'PropertyId' in the primary class; including those in protocols
244 /// (direct or indirect) used by the primary class.
245 ///
246 ObjCPropertyDecl *
FindPropertyVisibleInPrimaryClass(IdentifierInfo * PropertyId) const247 ObjCInterfaceDecl::FindPropertyVisibleInPrimaryClass(
248                                             IdentifierInfo *PropertyId) const {
249   // FIXME: Should make sure no callers ever do this.
250   if (!hasDefinition())
251     return nullptr;
252 
253   if (data().ExternallyCompleted)
254     LoadExternalDefinition();
255 
256   if (ObjCPropertyDecl *PD =
257       ObjCPropertyDecl::findPropertyDecl(cast<DeclContext>(this), PropertyId))
258     return PD;
259 
260   // Look through protocols.
261   for (const auto *I : all_referenced_protocols())
262     if (ObjCPropertyDecl *P = I->FindPropertyDeclaration(PropertyId))
263       return P;
264 
265   return nullptr;
266 }
267 
collectPropertiesToImplement(PropertyMap & PM,PropertyDeclOrder & PO) const268 void ObjCInterfaceDecl::collectPropertiesToImplement(PropertyMap &PM,
269                                                      PropertyDeclOrder &PO) const {
270   for (auto *Prop : properties()) {
271     PM[Prop->getIdentifier()] = Prop;
272     PO.push_back(Prop);
273   }
274   for (const auto *PI : all_referenced_protocols())
275     PI->collectPropertiesToImplement(PM, PO);
276   // Note, the properties declared only in class extensions are still copied
277   // into the main @interface's property list, and therefore we don't
278   // explicitly, have to search class extension properties.
279 }
280 
isArcWeakrefUnavailable() const281 bool ObjCInterfaceDecl::isArcWeakrefUnavailable() const {
282   const ObjCInterfaceDecl *Class = this;
283   while (Class) {
284     if (Class->hasAttr<ArcWeakrefUnavailableAttr>())
285       return true;
286     Class = Class->getSuperClass();
287   }
288   return false;
289 }
290 
isObjCRequiresPropertyDefs() const291 const ObjCInterfaceDecl *ObjCInterfaceDecl::isObjCRequiresPropertyDefs() const {
292   const ObjCInterfaceDecl *Class = this;
293   while (Class) {
294     if (Class->hasAttr<ObjCRequiresPropertyDefsAttr>())
295       return Class;
296     Class = Class->getSuperClass();
297   }
298   return nullptr;
299 }
300 
mergeClassExtensionProtocolList(ObjCProtocolDecl * const * ExtList,unsigned ExtNum,ASTContext & C)301 void ObjCInterfaceDecl::mergeClassExtensionProtocolList(
302                               ObjCProtocolDecl *const* ExtList, unsigned ExtNum,
303                               ASTContext &C)
304 {
305   if (data().ExternallyCompleted)
306     LoadExternalDefinition();
307 
308   if (data().AllReferencedProtocols.empty() &&
309       data().ReferencedProtocols.empty()) {
310     data().AllReferencedProtocols.set(ExtList, ExtNum, C);
311     return;
312   }
313 
314   // Check for duplicate protocol in class's protocol list.
315   // This is O(n*m). But it is extremely rare and number of protocols in
316   // class or its extension are very few.
317   SmallVector<ObjCProtocolDecl*, 8> ProtocolRefs;
318   for (unsigned i = 0; i < ExtNum; i++) {
319     bool protocolExists = false;
320     ObjCProtocolDecl *ProtoInExtension = ExtList[i];
321     for (auto *Proto : all_referenced_protocols()) {
322       if (C.ProtocolCompatibleWithProtocol(ProtoInExtension, Proto)) {
323         protocolExists = true;
324         break;
325       }
326     }
327     // Do we want to warn on a protocol in extension class which
328     // already exist in the class? Probably not.
329     if (!protocolExists)
330       ProtocolRefs.push_back(ProtoInExtension);
331   }
332 
333   if (ProtocolRefs.empty())
334     return;
335 
336   // Merge ProtocolRefs into class's protocol list;
337   ProtocolRefs.append(all_referenced_protocol_begin(),
338                       all_referenced_protocol_end());
339 
340   data().AllReferencedProtocols.set(ProtocolRefs.data(), ProtocolRefs.size(),C);
341 }
342 
343 const ObjCInterfaceDecl *
findInterfaceWithDesignatedInitializers() const344 ObjCInterfaceDecl::findInterfaceWithDesignatedInitializers() const {
345   const ObjCInterfaceDecl *IFace = this;
346   while (IFace) {
347     if (IFace->hasDesignatedInitializers())
348       return IFace;
349     if (!IFace->inheritsDesignatedInitializers())
350       break;
351     IFace = IFace->getSuperClass();
352   }
353   return nullptr;
354 }
355 
isIntroducingInitializers(const ObjCInterfaceDecl * D)356 static bool isIntroducingInitializers(const ObjCInterfaceDecl *D) {
357   for (const auto *MD : D->instance_methods()) {
358     if (MD->getMethodFamily() == OMF_init && !MD->isOverriding())
359       return true;
360   }
361   for (const auto *Ext : D->visible_extensions()) {
362     for (const auto *MD : Ext->instance_methods()) {
363       if (MD->getMethodFamily() == OMF_init && !MD->isOverriding())
364         return true;
365     }
366   }
367   if (const auto *ImplD = D->getImplementation()) {
368     for (const auto *MD : ImplD->instance_methods()) {
369       if (MD->getMethodFamily() == OMF_init && !MD->isOverriding())
370         return true;
371     }
372   }
373   return false;
374 }
375 
inheritsDesignatedInitializers() const376 bool ObjCInterfaceDecl::inheritsDesignatedInitializers() const {
377   switch (data().InheritedDesignatedInitializers) {
378   case DefinitionData::IDI_Inherited:
379     return true;
380   case DefinitionData::IDI_NotInherited:
381     return false;
382   case DefinitionData::IDI_Unknown: {
383     // If the class introduced initializers we conservatively assume that we
384     // don't know if any of them is a designated initializer to avoid possible
385     // misleading warnings.
386     if (isIntroducingInitializers(this)) {
387       data().InheritedDesignatedInitializers = DefinitionData::IDI_NotInherited;
388     } else {
389       if (auto SuperD = getSuperClass()) {
390         data().InheritedDesignatedInitializers =
391           SuperD->declaresOrInheritsDesignatedInitializers() ?
392             DefinitionData::IDI_Inherited :
393             DefinitionData::IDI_NotInherited;
394       } else {
395         data().InheritedDesignatedInitializers =
396           DefinitionData::IDI_NotInherited;
397       }
398     }
399     assert(data().InheritedDesignatedInitializers
400              != DefinitionData::IDI_Unknown);
401     return data().InheritedDesignatedInitializers ==
402         DefinitionData::IDI_Inherited;
403   }
404   }
405 
406   llvm_unreachable("unexpected InheritedDesignatedInitializers value");
407 }
408 
getDesignatedInitializers(llvm::SmallVectorImpl<const ObjCMethodDecl * > & Methods) const409 void ObjCInterfaceDecl::getDesignatedInitializers(
410     llvm::SmallVectorImpl<const ObjCMethodDecl *> &Methods) const {
411   // Check for a complete definition and recover if not so.
412   if (!isThisDeclarationADefinition())
413     return;
414   if (data().ExternallyCompleted)
415     LoadExternalDefinition();
416 
417   const ObjCInterfaceDecl *IFace= findInterfaceWithDesignatedInitializers();
418   if (!IFace)
419     return;
420 
421   for (const auto *MD : IFace->instance_methods())
422     if (MD->isThisDeclarationADesignatedInitializer())
423       Methods.push_back(MD);
424   for (const auto *Ext : IFace->visible_extensions()) {
425     for (const auto *MD : Ext->instance_methods())
426       if (MD->isThisDeclarationADesignatedInitializer())
427         Methods.push_back(MD);
428   }
429 }
430 
isDesignatedInitializer(Selector Sel,const ObjCMethodDecl ** InitMethod) const431 bool ObjCInterfaceDecl::isDesignatedInitializer(Selector Sel,
432                                       const ObjCMethodDecl **InitMethod) const {
433   // Check for a complete definition and recover if not so.
434   if (!isThisDeclarationADefinition())
435     return false;
436   if (data().ExternallyCompleted)
437     LoadExternalDefinition();
438 
439   const ObjCInterfaceDecl *IFace= findInterfaceWithDesignatedInitializers();
440   if (!IFace)
441     return false;
442 
443   if (const ObjCMethodDecl *MD = IFace->getInstanceMethod(Sel)) {
444     if (MD->isThisDeclarationADesignatedInitializer()) {
445       if (InitMethod)
446         *InitMethod = MD;
447       return true;
448     }
449   }
450   for (const auto *Ext : IFace->visible_extensions()) {
451     if (const ObjCMethodDecl *MD = Ext->getInstanceMethod(Sel)) {
452       if (MD->isThisDeclarationADesignatedInitializer()) {
453         if (InitMethod)
454           *InitMethod = MD;
455         return true;
456       }
457     }
458   }
459   return false;
460 }
461 
allocateDefinitionData()462 void ObjCInterfaceDecl::allocateDefinitionData() {
463   assert(!hasDefinition() && "ObjC class already has a definition");
464   Data.setPointer(new (getASTContext()) DefinitionData());
465   Data.getPointer()->Definition = this;
466 
467   // Make the type point at the definition, now that we have one.
468   if (TypeForDecl)
469     cast<ObjCInterfaceType>(TypeForDecl)->Decl = this;
470 }
471 
startDefinition()472 void ObjCInterfaceDecl::startDefinition() {
473   allocateDefinitionData();
474 
475   // Update all of the declarations with a pointer to the definition.
476   for (auto RD : redecls()) {
477     if (RD != this)
478       RD->Data = Data;
479   }
480 }
481 
lookupInstanceVariable(IdentifierInfo * ID,ObjCInterfaceDecl * & clsDeclared)482 ObjCIvarDecl *ObjCInterfaceDecl::lookupInstanceVariable(IdentifierInfo *ID,
483                                               ObjCInterfaceDecl *&clsDeclared) {
484   // FIXME: Should make sure no callers ever do this.
485   if (!hasDefinition())
486     return nullptr;
487 
488   if (data().ExternallyCompleted)
489     LoadExternalDefinition();
490 
491   ObjCInterfaceDecl* ClassDecl = this;
492   while (ClassDecl != nullptr) {
493     if (ObjCIvarDecl *I = ClassDecl->getIvarDecl(ID)) {
494       clsDeclared = ClassDecl;
495       return I;
496     }
497 
498     for (const auto *Ext : ClassDecl->visible_extensions()) {
499       if (ObjCIvarDecl *I = Ext->getIvarDecl(ID)) {
500         clsDeclared = ClassDecl;
501         return I;
502       }
503     }
504 
505     ClassDecl = ClassDecl->getSuperClass();
506   }
507   return nullptr;
508 }
509 
510 /// lookupInheritedClass - This method returns ObjCInterfaceDecl * of the super
511 /// class whose name is passed as argument. If it is not one of the super classes
512 /// the it returns NULL.
lookupInheritedClass(const IdentifierInfo * ICName)513 ObjCInterfaceDecl *ObjCInterfaceDecl::lookupInheritedClass(
514                                         const IdentifierInfo*ICName) {
515   // FIXME: Should make sure no callers ever do this.
516   if (!hasDefinition())
517     return nullptr;
518 
519   if (data().ExternallyCompleted)
520     LoadExternalDefinition();
521 
522   ObjCInterfaceDecl* ClassDecl = this;
523   while (ClassDecl != nullptr) {
524     if (ClassDecl->getIdentifier() == ICName)
525       return ClassDecl;
526     ClassDecl = ClassDecl->getSuperClass();
527   }
528   return nullptr;
529 }
530 
531 ObjCProtocolDecl *
lookupNestedProtocol(IdentifierInfo * Name)532 ObjCInterfaceDecl::lookupNestedProtocol(IdentifierInfo *Name) {
533   for (auto *P : all_referenced_protocols())
534     if (P->lookupProtocolNamed(Name))
535       return P;
536   ObjCInterfaceDecl *SuperClass = getSuperClass();
537   return SuperClass ? SuperClass->lookupNestedProtocol(Name) : nullptr;
538 }
539 
540 /// lookupMethod - This method returns an instance/class method by looking in
541 /// the class, its categories, and its super classes (using a linear search).
542 /// When argument category "C" is specified, any implicit method found
543 /// in this category is ignored.
lookupMethod(Selector Sel,bool isInstance,bool shallowCategoryLookup,bool followSuper,const ObjCCategoryDecl * C) const544 ObjCMethodDecl *ObjCInterfaceDecl::lookupMethod(Selector Sel,
545                                                 bool isInstance,
546                                                 bool shallowCategoryLookup,
547                                                 bool followSuper,
548                                                 const ObjCCategoryDecl *C) const
549 {
550   // FIXME: Should make sure no callers ever do this.
551   if (!hasDefinition())
552     return nullptr;
553 
554   const ObjCInterfaceDecl* ClassDecl = this;
555   ObjCMethodDecl *MethodDecl = nullptr;
556 
557   if (data().ExternallyCompleted)
558     LoadExternalDefinition();
559 
560   while (ClassDecl) {
561     // 1. Look through primary class.
562     if ((MethodDecl = ClassDecl->getMethod(Sel, isInstance)))
563       return MethodDecl;
564 
565     // 2. Didn't find one yet - now look through categories.
566     for (const auto *Cat : ClassDecl->visible_categories())
567       if ((MethodDecl = Cat->getMethod(Sel, isInstance)))
568         if (C != Cat || !MethodDecl->isImplicit())
569           return MethodDecl;
570 
571     // 3. Didn't find one yet - look through primary class's protocols.
572     for (const auto *I : ClassDecl->protocols())
573       if ((MethodDecl = I->lookupMethod(Sel, isInstance)))
574         return MethodDecl;
575 
576     // 4. Didn't find one yet - now look through categories' protocols
577     if (!shallowCategoryLookup)
578       for (const auto *Cat : ClassDecl->visible_categories()) {
579         // Didn't find one yet - look through protocols.
580         const ObjCList<ObjCProtocolDecl> &Protocols =
581           Cat->getReferencedProtocols();
582         for (ObjCList<ObjCProtocolDecl>::iterator I = Protocols.begin(),
583              E = Protocols.end(); I != E; ++I)
584           if ((MethodDecl = (*I)->lookupMethod(Sel, isInstance)))
585             if (C != Cat || !MethodDecl->isImplicit())
586               return MethodDecl;
587       }
588 
589 
590     if (!followSuper)
591       return nullptr;
592 
593     // 5. Get to the super class (if any).
594     ClassDecl = ClassDecl->getSuperClass();
595   }
596   return nullptr;
597 }
598 
599 // Will search "local" class/category implementations for a method decl.
600 // If failed, then we search in class's root for an instance method.
601 // Returns 0 if no method is found.
lookupPrivateMethod(const Selector & Sel,bool Instance) const602 ObjCMethodDecl *ObjCInterfaceDecl::lookupPrivateMethod(
603                                    const Selector &Sel,
604                                    bool Instance) const {
605   // FIXME: Should make sure no callers ever do this.
606   if (!hasDefinition())
607     return nullptr;
608 
609   if (data().ExternallyCompleted)
610     LoadExternalDefinition();
611 
612   ObjCMethodDecl *Method = nullptr;
613   if (ObjCImplementationDecl *ImpDecl = getImplementation())
614     Method = Instance ? ImpDecl->getInstanceMethod(Sel)
615                       : ImpDecl->getClassMethod(Sel);
616 
617   // Look through local category implementations associated with the class.
618   if (!Method)
619     Method = getCategoryMethod(Sel, Instance);
620 
621   // Before we give up, check if the selector is an instance method.
622   // But only in the root. This matches gcc's behavior and what the
623   // runtime expects.
624   if (!Instance && !Method && !getSuperClass()) {
625     Method = lookupInstanceMethod(Sel);
626     // Look through local category implementations associated
627     // with the root class.
628     if (!Method)
629       Method = lookupPrivateMethod(Sel, true);
630   }
631 
632   if (!Method && getSuperClass())
633     return getSuperClass()->lookupPrivateMethod(Sel, Instance);
634   return Method;
635 }
636 
637 //===----------------------------------------------------------------------===//
638 // ObjCMethodDecl
639 //===----------------------------------------------------------------------===//
640 
Create(ASTContext & C,SourceLocation beginLoc,SourceLocation endLoc,Selector SelInfo,QualType T,TypeSourceInfo * ReturnTInfo,DeclContext * contextDecl,bool isInstance,bool isVariadic,bool isPropertyAccessor,bool isImplicitlyDeclared,bool isDefined,ImplementationControl impControl,bool HasRelatedResultType)641 ObjCMethodDecl *ObjCMethodDecl::Create(
642     ASTContext &C, SourceLocation beginLoc, SourceLocation endLoc,
643     Selector SelInfo, QualType T, TypeSourceInfo *ReturnTInfo,
644     DeclContext *contextDecl, bool isInstance, bool isVariadic,
645     bool isPropertyAccessor, bool isImplicitlyDeclared, bool isDefined,
646     ImplementationControl impControl, bool HasRelatedResultType) {
647   return new (C, contextDecl) ObjCMethodDecl(
648       beginLoc, endLoc, SelInfo, T, ReturnTInfo, contextDecl, isInstance,
649       isVariadic, isPropertyAccessor, isImplicitlyDeclared, isDefined,
650       impControl, HasRelatedResultType);
651 }
652 
CreateDeserialized(ASTContext & C,unsigned ID)653 ObjCMethodDecl *ObjCMethodDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
654   return new (C, ID) ObjCMethodDecl(SourceLocation(), SourceLocation(),
655                                     Selector(), QualType(), nullptr, nullptr);
656 }
657 
isThisDeclarationADesignatedInitializer() const658 bool ObjCMethodDecl::isThisDeclarationADesignatedInitializer() const {
659   return getMethodFamily() == OMF_init &&
660       hasAttr<ObjCDesignatedInitializerAttr>();
661 }
662 
isDesignatedInitializerForTheInterface(const ObjCMethodDecl ** InitMethod) const663 bool ObjCMethodDecl::isDesignatedInitializerForTheInterface(
664     const ObjCMethodDecl **InitMethod) const {
665   if (getMethodFamily() != OMF_init)
666     return false;
667   const DeclContext *DC = getDeclContext();
668   if (isa<ObjCProtocolDecl>(DC))
669     return false;
670   if (const ObjCInterfaceDecl *ID = getClassInterface())
671     return ID->isDesignatedInitializer(getSelector(), InitMethod);
672   return false;
673 }
674 
getBody() const675 Stmt *ObjCMethodDecl::getBody() const {
676   return Body.get(getASTContext().getExternalSource());
677 }
678 
setAsRedeclaration(const ObjCMethodDecl * PrevMethod)679 void ObjCMethodDecl::setAsRedeclaration(const ObjCMethodDecl *PrevMethod) {
680   assert(PrevMethod);
681   getASTContext().setObjCMethodRedeclaration(PrevMethod, this);
682   IsRedeclaration = true;
683   PrevMethod->HasRedeclaration = true;
684 }
685 
setParamsAndSelLocs(ASTContext & C,ArrayRef<ParmVarDecl * > Params,ArrayRef<SourceLocation> SelLocs)686 void ObjCMethodDecl::setParamsAndSelLocs(ASTContext &C,
687                                          ArrayRef<ParmVarDecl*> Params,
688                                          ArrayRef<SourceLocation> SelLocs) {
689   ParamsAndSelLocs = nullptr;
690   NumParams = Params.size();
691   if (Params.empty() && SelLocs.empty())
692     return;
693 
694   unsigned Size = sizeof(ParmVarDecl *) * NumParams +
695                   sizeof(SourceLocation) * SelLocs.size();
696   ParamsAndSelLocs = C.Allocate(Size);
697   std::copy(Params.begin(), Params.end(), getParams());
698   std::copy(SelLocs.begin(), SelLocs.end(), getStoredSelLocs());
699 }
700 
getSelectorLocs(SmallVectorImpl<SourceLocation> & SelLocs) const701 void ObjCMethodDecl::getSelectorLocs(
702                                SmallVectorImpl<SourceLocation> &SelLocs) const {
703   for (unsigned i = 0, e = getNumSelectorLocs(); i != e; ++i)
704     SelLocs.push_back(getSelectorLoc(i));
705 }
706 
setMethodParams(ASTContext & C,ArrayRef<ParmVarDecl * > Params,ArrayRef<SourceLocation> SelLocs)707 void ObjCMethodDecl::setMethodParams(ASTContext &C,
708                                      ArrayRef<ParmVarDecl*> Params,
709                                      ArrayRef<SourceLocation> SelLocs) {
710   assert((!SelLocs.empty() || isImplicit()) &&
711          "No selector locs for non-implicit method");
712   if (isImplicit())
713     return setParamsAndSelLocs(C, Params, llvm::None);
714 
715   SelLocsKind = hasStandardSelectorLocs(getSelector(), SelLocs, Params,
716                                         DeclEndLoc);
717   if (SelLocsKind != SelLoc_NonStandard)
718     return setParamsAndSelLocs(C, Params, llvm::None);
719 
720   setParamsAndSelLocs(C, Params, SelLocs);
721 }
722 
723 /// \brief A definition will return its interface declaration.
724 /// An interface declaration will return its definition.
725 /// Otherwise it will return itself.
getNextRedeclarationImpl()726 ObjCMethodDecl *ObjCMethodDecl::getNextRedeclarationImpl() {
727   ASTContext &Ctx = getASTContext();
728   ObjCMethodDecl *Redecl = nullptr;
729   if (HasRedeclaration)
730     Redecl = const_cast<ObjCMethodDecl*>(Ctx.getObjCMethodRedeclaration(this));
731   if (Redecl)
732     return Redecl;
733 
734   Decl *CtxD = cast<Decl>(getDeclContext());
735 
736   if (!CtxD->isInvalidDecl()) {
737     if (ObjCInterfaceDecl *IFD = dyn_cast<ObjCInterfaceDecl>(CtxD)) {
738       if (ObjCImplementationDecl *ImplD = Ctx.getObjCImplementation(IFD))
739         if (!ImplD->isInvalidDecl())
740           Redecl = ImplD->getMethod(getSelector(), isInstanceMethod());
741 
742     } else if (ObjCCategoryDecl *CD = dyn_cast<ObjCCategoryDecl>(CtxD)) {
743       if (ObjCCategoryImplDecl *ImplD = Ctx.getObjCImplementation(CD))
744         if (!ImplD->isInvalidDecl())
745           Redecl = ImplD->getMethod(getSelector(), isInstanceMethod());
746 
747     } else if (ObjCImplementationDecl *ImplD =
748                  dyn_cast<ObjCImplementationDecl>(CtxD)) {
749       if (ObjCInterfaceDecl *IFD = ImplD->getClassInterface())
750         if (!IFD->isInvalidDecl())
751           Redecl = IFD->getMethod(getSelector(), isInstanceMethod());
752 
753     } else if (ObjCCategoryImplDecl *CImplD =
754                  dyn_cast<ObjCCategoryImplDecl>(CtxD)) {
755       if (ObjCCategoryDecl *CatD = CImplD->getCategoryDecl())
756         if (!CatD->isInvalidDecl())
757           Redecl = CatD->getMethod(getSelector(), isInstanceMethod());
758     }
759   }
760 
761   if (!Redecl && isRedeclaration()) {
762     // This is the last redeclaration, go back to the first method.
763     return cast<ObjCContainerDecl>(CtxD)->getMethod(getSelector(),
764                                                     isInstanceMethod());
765   }
766 
767   return Redecl ? Redecl : this;
768 }
769 
getCanonicalDecl()770 ObjCMethodDecl *ObjCMethodDecl::getCanonicalDecl() {
771   Decl *CtxD = cast<Decl>(getDeclContext());
772 
773   if (ObjCImplementationDecl *ImplD = dyn_cast<ObjCImplementationDecl>(CtxD)) {
774     if (ObjCInterfaceDecl *IFD = ImplD->getClassInterface())
775       if (ObjCMethodDecl *MD = IFD->getMethod(getSelector(),
776                                               isInstanceMethod()))
777         return MD;
778 
779   } else if (ObjCCategoryImplDecl *CImplD =
780                dyn_cast<ObjCCategoryImplDecl>(CtxD)) {
781     if (ObjCCategoryDecl *CatD = CImplD->getCategoryDecl())
782       if (ObjCMethodDecl *MD = CatD->getMethod(getSelector(),
783                                                isInstanceMethod()))
784         return MD;
785   }
786 
787   if (isRedeclaration())
788     return cast<ObjCContainerDecl>(CtxD)->getMethod(getSelector(),
789                                                     isInstanceMethod());
790 
791   return this;
792 }
793 
getLocEnd() const794 SourceLocation ObjCMethodDecl::getLocEnd() const {
795   if (Stmt *Body = getBody())
796     return Body->getLocEnd();
797   return DeclEndLoc;
798 }
799 
getMethodFamily() const800 ObjCMethodFamily ObjCMethodDecl::getMethodFamily() const {
801   ObjCMethodFamily family = static_cast<ObjCMethodFamily>(Family);
802   if (family != static_cast<unsigned>(InvalidObjCMethodFamily))
803     return family;
804 
805   // Check for an explicit attribute.
806   if (const ObjCMethodFamilyAttr *attr = getAttr<ObjCMethodFamilyAttr>()) {
807     // The unfortunate necessity of mapping between enums here is due
808     // to the attributes framework.
809     switch (attr->getFamily()) {
810     case ObjCMethodFamilyAttr::OMF_None: family = OMF_None; break;
811     case ObjCMethodFamilyAttr::OMF_alloc: family = OMF_alloc; break;
812     case ObjCMethodFamilyAttr::OMF_copy: family = OMF_copy; break;
813     case ObjCMethodFamilyAttr::OMF_init: family = OMF_init; break;
814     case ObjCMethodFamilyAttr::OMF_mutableCopy: family = OMF_mutableCopy; break;
815     case ObjCMethodFamilyAttr::OMF_new: family = OMF_new; break;
816     }
817     Family = static_cast<unsigned>(family);
818     return family;
819   }
820 
821   family = getSelector().getMethodFamily();
822   switch (family) {
823   case OMF_None: break;
824 
825   // init only has a conventional meaning for an instance method, and
826   // it has to return an object.
827   case OMF_init:
828     if (!isInstanceMethod() || !getReturnType()->isObjCObjectPointerType())
829       family = OMF_None;
830     break;
831 
832   // alloc/copy/new have a conventional meaning for both class and
833   // instance methods, but they require an object return.
834   case OMF_alloc:
835   case OMF_copy:
836   case OMF_mutableCopy:
837   case OMF_new:
838     if (!getReturnType()->isObjCObjectPointerType())
839       family = OMF_None;
840     break;
841 
842   // These selectors have a conventional meaning only for instance methods.
843   case OMF_dealloc:
844   case OMF_finalize:
845   case OMF_retain:
846   case OMF_release:
847   case OMF_autorelease:
848   case OMF_retainCount:
849   case OMF_self:
850     if (!isInstanceMethod())
851       family = OMF_None;
852     break;
853 
854   case OMF_initialize:
855     if (isInstanceMethod() || !getReturnType()->isVoidType())
856       family = OMF_None;
857     break;
858 
859   case OMF_performSelector:
860     if (!isInstanceMethod() || !getReturnType()->isObjCIdType())
861       family = OMF_None;
862     else {
863       unsigned noParams = param_size();
864       if (noParams < 1 || noParams > 3)
865         family = OMF_None;
866       else {
867         ObjCMethodDecl::param_type_iterator it = param_type_begin();
868         QualType ArgT = (*it);
869         if (!ArgT->isObjCSelType()) {
870           family = OMF_None;
871           break;
872         }
873         while (--noParams) {
874           it++;
875           ArgT = (*it);
876           if (!ArgT->isObjCIdType()) {
877             family = OMF_None;
878             break;
879           }
880         }
881       }
882     }
883     break;
884 
885   }
886 
887   // Cache the result.
888   Family = static_cast<unsigned>(family);
889   return family;
890 }
891 
createImplicitParams(ASTContext & Context,const ObjCInterfaceDecl * OID)892 void ObjCMethodDecl::createImplicitParams(ASTContext &Context,
893                                           const ObjCInterfaceDecl *OID) {
894   QualType selfTy;
895   if (isInstanceMethod()) {
896     // There may be no interface context due to error in declaration
897     // of the interface (which has been reported). Recover gracefully.
898     if (OID) {
899       selfTy = Context.getObjCInterfaceType(OID);
900       selfTy = Context.getObjCObjectPointerType(selfTy);
901     } else {
902       selfTy = Context.getObjCIdType();
903     }
904   } else // we have a factory method.
905     selfTy = Context.getObjCClassType();
906 
907   bool selfIsPseudoStrong = false;
908   bool selfIsConsumed = false;
909 
910   if (Context.getLangOpts().ObjCAutoRefCount) {
911     if (isInstanceMethod()) {
912       selfIsConsumed = hasAttr<NSConsumesSelfAttr>();
913 
914       // 'self' is always __strong.  It's actually pseudo-strong except
915       // in init methods (or methods labeled ns_consumes_self), though.
916       Qualifiers qs;
917       qs.setObjCLifetime(Qualifiers::OCL_Strong);
918       selfTy = Context.getQualifiedType(selfTy, qs);
919 
920       // In addition, 'self' is const unless this is an init method.
921       if (getMethodFamily() != OMF_init && !selfIsConsumed) {
922         selfTy = selfTy.withConst();
923         selfIsPseudoStrong = true;
924       }
925     }
926     else {
927       assert(isClassMethod());
928       // 'self' is always const in class methods.
929       selfTy = selfTy.withConst();
930       selfIsPseudoStrong = true;
931     }
932   }
933 
934   ImplicitParamDecl *self
935     = ImplicitParamDecl::Create(Context, this, SourceLocation(),
936                                 &Context.Idents.get("self"), selfTy);
937   setSelfDecl(self);
938 
939   if (selfIsConsumed)
940     self->addAttr(NSConsumedAttr::CreateImplicit(Context));
941 
942   if (selfIsPseudoStrong)
943     self->setARCPseudoStrong(true);
944 
945   setCmdDecl(ImplicitParamDecl::Create(Context, this, SourceLocation(),
946                                        &Context.Idents.get("_cmd"),
947                                        Context.getObjCSelType()));
948 }
949 
getClassInterface()950 ObjCInterfaceDecl *ObjCMethodDecl::getClassInterface() {
951   if (ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(getDeclContext()))
952     return ID;
953   if (ObjCCategoryDecl *CD = dyn_cast<ObjCCategoryDecl>(getDeclContext()))
954     return CD->getClassInterface();
955   if (ObjCImplDecl *IMD = dyn_cast<ObjCImplDecl>(getDeclContext()))
956     return IMD->getClassInterface();
957   if (isa<ObjCProtocolDecl>(getDeclContext()))
958     return nullptr;
959   llvm_unreachable("unknown method context");
960 }
961 
getReturnTypeSourceRange() const962 SourceRange ObjCMethodDecl::getReturnTypeSourceRange() const {
963   const auto *TSI = getReturnTypeSourceInfo();
964   if (TSI)
965     return TSI->getTypeLoc().getSourceRange();
966   return SourceRange();
967 }
968 
CollectOverriddenMethodsRecurse(const ObjCContainerDecl * Container,const ObjCMethodDecl * Method,SmallVectorImpl<const ObjCMethodDecl * > & Methods,bool MovedToSuper)969 static void CollectOverriddenMethodsRecurse(const ObjCContainerDecl *Container,
970                                             const ObjCMethodDecl *Method,
971                                SmallVectorImpl<const ObjCMethodDecl *> &Methods,
972                                             bool MovedToSuper) {
973   if (!Container)
974     return;
975 
976   // In categories look for overriden methods from protocols. A method from
977   // category is not "overriden" since it is considered as the "same" method
978   // (same USR) as the one from the interface.
979   if (const ObjCCategoryDecl *
980         Category = dyn_cast<ObjCCategoryDecl>(Container)) {
981     // Check whether we have a matching method at this category but only if we
982     // are at the super class level.
983     if (MovedToSuper)
984       if (ObjCMethodDecl *
985             Overridden = Container->getMethod(Method->getSelector(),
986                                               Method->isInstanceMethod(),
987                                               /*AllowHidden=*/true))
988         if (Method != Overridden) {
989           // We found an override at this category; there is no need to look
990           // into its protocols.
991           Methods.push_back(Overridden);
992           return;
993         }
994 
995     for (const auto *P : Category->protocols())
996       CollectOverriddenMethodsRecurse(P, Method, Methods, MovedToSuper);
997     return;
998   }
999 
1000   // Check whether we have a matching method at this level.
1001   if (const ObjCMethodDecl *
1002         Overridden = Container->getMethod(Method->getSelector(),
1003                                           Method->isInstanceMethod(),
1004                                           /*AllowHidden=*/true))
1005     if (Method != Overridden) {
1006       // We found an override at this level; there is no need to look
1007       // into other protocols or categories.
1008       Methods.push_back(Overridden);
1009       return;
1010     }
1011 
1012   if (const ObjCProtocolDecl *Protocol = dyn_cast<ObjCProtocolDecl>(Container)){
1013     for (const auto *P : Protocol->protocols())
1014       CollectOverriddenMethodsRecurse(P, Method, Methods, MovedToSuper);
1015   }
1016 
1017   if (const ObjCInterfaceDecl *
1018         Interface = dyn_cast<ObjCInterfaceDecl>(Container)) {
1019     for (const auto *P : Interface->protocols())
1020       CollectOverriddenMethodsRecurse(P, Method, Methods, MovedToSuper);
1021 
1022     for (const auto *Cat : Interface->known_categories())
1023       CollectOverriddenMethodsRecurse(Cat, Method, Methods, MovedToSuper);
1024 
1025     if (const ObjCInterfaceDecl *Super = Interface->getSuperClass())
1026       return CollectOverriddenMethodsRecurse(Super, Method, Methods,
1027                                              /*MovedToSuper=*/true);
1028   }
1029 }
1030 
CollectOverriddenMethods(const ObjCContainerDecl * Container,const ObjCMethodDecl * Method,SmallVectorImpl<const ObjCMethodDecl * > & Methods)1031 static inline void CollectOverriddenMethods(const ObjCContainerDecl *Container,
1032                                             const ObjCMethodDecl *Method,
1033                              SmallVectorImpl<const ObjCMethodDecl *> &Methods) {
1034   CollectOverriddenMethodsRecurse(Container, Method, Methods,
1035                                   /*MovedToSuper=*/false);
1036 }
1037 
collectOverriddenMethodsSlow(const ObjCMethodDecl * Method,SmallVectorImpl<const ObjCMethodDecl * > & overridden)1038 static void collectOverriddenMethodsSlow(const ObjCMethodDecl *Method,
1039                           SmallVectorImpl<const ObjCMethodDecl *> &overridden) {
1040   assert(Method->isOverriding());
1041 
1042   if (const ObjCProtocolDecl *
1043         ProtD = dyn_cast<ObjCProtocolDecl>(Method->getDeclContext())) {
1044     CollectOverriddenMethods(ProtD, Method, overridden);
1045 
1046   } else if (const ObjCImplDecl *
1047                IMD = dyn_cast<ObjCImplDecl>(Method->getDeclContext())) {
1048     const ObjCInterfaceDecl *ID = IMD->getClassInterface();
1049     if (!ID)
1050       return;
1051     // Start searching for overridden methods using the method from the
1052     // interface as starting point.
1053     if (const ObjCMethodDecl *IFaceMeth = ID->getMethod(Method->getSelector(),
1054                                                     Method->isInstanceMethod(),
1055                                                     /*AllowHidden=*/true))
1056       Method = IFaceMeth;
1057     CollectOverriddenMethods(ID, Method, overridden);
1058 
1059   } else if (const ObjCCategoryDecl *
1060                CatD = dyn_cast<ObjCCategoryDecl>(Method->getDeclContext())) {
1061     const ObjCInterfaceDecl *ID = CatD->getClassInterface();
1062     if (!ID)
1063       return;
1064     // Start searching for overridden methods using the method from the
1065     // interface as starting point.
1066     if (const ObjCMethodDecl *IFaceMeth = ID->getMethod(Method->getSelector(),
1067                                                      Method->isInstanceMethod(),
1068                                                      /*AllowHidden=*/true))
1069       Method = IFaceMeth;
1070     CollectOverriddenMethods(ID, Method, overridden);
1071 
1072   } else {
1073     CollectOverriddenMethods(
1074                   dyn_cast_or_null<ObjCContainerDecl>(Method->getDeclContext()),
1075                   Method, overridden);
1076   }
1077 }
1078 
getOverriddenMethods(SmallVectorImpl<const ObjCMethodDecl * > & Overridden) const1079 void ObjCMethodDecl::getOverriddenMethods(
1080                     SmallVectorImpl<const ObjCMethodDecl *> &Overridden) const {
1081   const ObjCMethodDecl *Method = this;
1082 
1083   if (Method->isRedeclaration()) {
1084     Method = cast<ObjCContainerDecl>(Method->getDeclContext())->
1085                    getMethod(Method->getSelector(), Method->isInstanceMethod());
1086   }
1087 
1088   if (Method->isOverriding()) {
1089     collectOverriddenMethodsSlow(Method, Overridden);
1090     assert(!Overridden.empty() &&
1091            "ObjCMethodDecl's overriding bit is not as expected");
1092   }
1093 }
1094 
1095 const ObjCPropertyDecl *
findPropertyDecl(bool CheckOverrides) const1096 ObjCMethodDecl::findPropertyDecl(bool CheckOverrides) const {
1097   Selector Sel = getSelector();
1098   unsigned NumArgs = Sel.getNumArgs();
1099   if (NumArgs > 1)
1100     return nullptr;
1101 
1102   if (!isInstanceMethod())
1103     return nullptr;
1104 
1105   if (isPropertyAccessor()) {
1106     const ObjCContainerDecl *Container = cast<ObjCContainerDecl>(getParent());
1107     // If container is class extension, find its primary class.
1108     if (const ObjCCategoryDecl *CatDecl = dyn_cast<ObjCCategoryDecl>(Container))
1109       if (CatDecl->IsClassExtension())
1110         Container = CatDecl->getClassInterface();
1111 
1112     bool IsGetter = (NumArgs == 0);
1113 
1114     for (const auto *I : Container->properties()) {
1115       Selector NextSel = IsGetter ? I->getGetterName()
1116                                   : I->getSetterName();
1117       if (NextSel == Sel)
1118         return I;
1119     }
1120 
1121     llvm_unreachable("Marked as a property accessor but no property found!");
1122   }
1123 
1124   if (!CheckOverrides)
1125     return nullptr;
1126 
1127   typedef SmallVector<const ObjCMethodDecl *, 8> OverridesTy;
1128   OverridesTy Overrides;
1129   getOverriddenMethods(Overrides);
1130   for (OverridesTy::const_iterator I = Overrides.begin(), E = Overrides.end();
1131        I != E; ++I) {
1132     if (const ObjCPropertyDecl *Prop = (*I)->findPropertyDecl(false))
1133       return Prop;
1134   }
1135 
1136   return nullptr;
1137 }
1138 
1139 //===----------------------------------------------------------------------===//
1140 // ObjCInterfaceDecl
1141 //===----------------------------------------------------------------------===//
1142 
Create(const ASTContext & C,DeclContext * DC,SourceLocation atLoc,IdentifierInfo * Id,ObjCInterfaceDecl * PrevDecl,SourceLocation ClassLoc,bool isInternal)1143 ObjCInterfaceDecl *ObjCInterfaceDecl::Create(const ASTContext &C,
1144                                              DeclContext *DC,
1145                                              SourceLocation atLoc,
1146                                              IdentifierInfo *Id,
1147                                              ObjCInterfaceDecl *PrevDecl,
1148                                              SourceLocation ClassLoc,
1149                                              bool isInternal){
1150   ObjCInterfaceDecl *Result = new (C, DC)
1151       ObjCInterfaceDecl(C, DC, atLoc, Id, ClassLoc, PrevDecl, isInternal);
1152   Result->Data.setInt(!C.getLangOpts().Modules);
1153   C.getObjCInterfaceType(Result, PrevDecl);
1154   return Result;
1155 }
1156 
CreateDeserialized(const ASTContext & C,unsigned ID)1157 ObjCInterfaceDecl *ObjCInterfaceDecl::CreateDeserialized(const ASTContext &C,
1158                                                          unsigned ID) {
1159   ObjCInterfaceDecl *Result = new (C, ID) ObjCInterfaceDecl(C, nullptr,
1160                                                             SourceLocation(),
1161                                                             nullptr,
1162                                                             SourceLocation(),
1163                                                             nullptr, false);
1164   Result->Data.setInt(!C.getLangOpts().Modules);
1165   return Result;
1166 }
1167 
ObjCInterfaceDecl(const ASTContext & C,DeclContext * DC,SourceLocation AtLoc,IdentifierInfo * Id,SourceLocation CLoc,ObjCInterfaceDecl * PrevDecl,bool IsInternal)1168 ObjCInterfaceDecl::ObjCInterfaceDecl(const ASTContext &C, DeclContext *DC,
1169                                      SourceLocation AtLoc, IdentifierInfo *Id,
1170                                      SourceLocation CLoc,
1171                                      ObjCInterfaceDecl *PrevDecl,
1172                                      bool IsInternal)
1173     : ObjCContainerDecl(ObjCInterface, DC, Id, CLoc, AtLoc),
1174       redeclarable_base(C), TypeForDecl(nullptr), Data() {
1175   setPreviousDecl(PrevDecl);
1176 
1177   // Copy the 'data' pointer over.
1178   if (PrevDecl)
1179     Data = PrevDecl->Data;
1180 
1181   setImplicit(IsInternal);
1182 }
1183 
LoadExternalDefinition() const1184 void ObjCInterfaceDecl::LoadExternalDefinition() const {
1185   assert(data().ExternallyCompleted && "Class is not externally completed");
1186   data().ExternallyCompleted = false;
1187   getASTContext().getExternalSource()->CompleteType(
1188                                         const_cast<ObjCInterfaceDecl *>(this));
1189 }
1190 
setExternallyCompleted()1191 void ObjCInterfaceDecl::setExternallyCompleted() {
1192   assert(getASTContext().getExternalSource() &&
1193          "Class can't be externally completed without an external source");
1194   assert(hasDefinition() &&
1195          "Forward declarations can't be externally completed");
1196   data().ExternallyCompleted = true;
1197 }
1198 
setHasDesignatedInitializers()1199 void ObjCInterfaceDecl::setHasDesignatedInitializers() {
1200   // Check for a complete definition and recover if not so.
1201   if (!isThisDeclarationADefinition())
1202     return;
1203   data().HasDesignatedInitializers = true;
1204 }
1205 
hasDesignatedInitializers() const1206 bool ObjCInterfaceDecl::hasDesignatedInitializers() const {
1207   // Check for a complete definition and recover if not so.
1208   if (!isThisDeclarationADefinition())
1209     return false;
1210   if (data().ExternallyCompleted)
1211     LoadExternalDefinition();
1212 
1213   return data().HasDesignatedInitializers;
1214 }
1215 
1216 StringRef
getObjCRuntimeNameAsString() const1217 ObjCInterfaceDecl::getObjCRuntimeNameAsString() const {
1218   if (ObjCRuntimeNameAttr *ObjCRTName = getAttr<ObjCRuntimeNameAttr>())
1219     return ObjCRTName->getMetadataName();
1220 
1221   return getName();
1222 }
1223 
1224 StringRef
getObjCRuntimeNameAsString() const1225 ObjCImplementationDecl::getObjCRuntimeNameAsString() const {
1226   if (ObjCInterfaceDecl *ID =
1227       const_cast<ObjCImplementationDecl*>(this)->getClassInterface())
1228     return ID->getObjCRuntimeNameAsString();
1229 
1230   return getName();
1231 }
1232 
getImplementation() const1233 ObjCImplementationDecl *ObjCInterfaceDecl::getImplementation() const {
1234   if (const ObjCInterfaceDecl *Def = getDefinition()) {
1235     if (data().ExternallyCompleted)
1236       LoadExternalDefinition();
1237 
1238     return getASTContext().getObjCImplementation(
1239              const_cast<ObjCInterfaceDecl*>(Def));
1240   }
1241 
1242   // FIXME: Should make sure no callers ever do this.
1243   return nullptr;
1244 }
1245 
setImplementation(ObjCImplementationDecl * ImplD)1246 void ObjCInterfaceDecl::setImplementation(ObjCImplementationDecl *ImplD) {
1247   getASTContext().setObjCImplementation(getDefinition(), ImplD);
1248 }
1249 
1250 namespace {
1251   struct SynthesizeIvarChunk {
1252     uint64_t Size;
1253     ObjCIvarDecl *Ivar;
SynthesizeIvarChunk__anon97fe7a490111::SynthesizeIvarChunk1254     SynthesizeIvarChunk(uint64_t size, ObjCIvarDecl *ivar)
1255       : Size(size), Ivar(ivar) {}
1256   };
1257 
operator <(const SynthesizeIvarChunk & LHS,const SynthesizeIvarChunk & RHS)1258   bool operator<(const SynthesizeIvarChunk & LHS,
1259                  const SynthesizeIvarChunk &RHS) {
1260       return LHS.Size < RHS.Size;
1261   }
1262 }
1263 
1264 /// all_declared_ivar_begin - return first ivar declared in this class,
1265 /// its extensions and its implementation. Lazily build the list on first
1266 /// access.
1267 ///
1268 /// Caveat: The list returned by this method reflects the current
1269 /// state of the parser. The cache will be updated for every ivar
1270 /// added by an extension or the implementation when they are
1271 /// encountered.
1272 /// See also ObjCIvarDecl::Create().
all_declared_ivar_begin()1273 ObjCIvarDecl *ObjCInterfaceDecl::all_declared_ivar_begin() {
1274   // FIXME: Should make sure no callers ever do this.
1275   if (!hasDefinition())
1276     return nullptr;
1277 
1278   ObjCIvarDecl *curIvar = nullptr;
1279   if (!data().IvarList) {
1280     if (!ivar_empty()) {
1281       ObjCInterfaceDecl::ivar_iterator I = ivar_begin(), E = ivar_end();
1282       data().IvarList = *I; ++I;
1283       for (curIvar = data().IvarList; I != E; curIvar = *I, ++I)
1284         curIvar->setNextIvar(*I);
1285     }
1286 
1287     for (const auto *Ext : known_extensions()) {
1288       if (!Ext->ivar_empty()) {
1289         ObjCCategoryDecl::ivar_iterator
1290           I = Ext->ivar_begin(),
1291           E = Ext->ivar_end();
1292         if (!data().IvarList) {
1293           data().IvarList = *I; ++I;
1294           curIvar = data().IvarList;
1295         }
1296         for ( ;I != E; curIvar = *I, ++I)
1297           curIvar->setNextIvar(*I);
1298       }
1299     }
1300     data().IvarListMissingImplementation = true;
1301   }
1302 
1303   // cached and complete!
1304   if (!data().IvarListMissingImplementation)
1305       return data().IvarList;
1306 
1307   if (ObjCImplementationDecl *ImplDecl = getImplementation()) {
1308     data().IvarListMissingImplementation = false;
1309     if (!ImplDecl->ivar_empty()) {
1310       SmallVector<SynthesizeIvarChunk, 16> layout;
1311       for (auto *IV : ImplDecl->ivars()) {
1312         if (IV->getSynthesize() && !IV->isInvalidDecl()) {
1313           layout.push_back(SynthesizeIvarChunk(
1314                              IV->getASTContext().getTypeSize(IV->getType()), IV));
1315           continue;
1316         }
1317         if (!data().IvarList)
1318           data().IvarList = IV;
1319         else
1320           curIvar->setNextIvar(IV);
1321         curIvar = IV;
1322       }
1323 
1324       if (!layout.empty()) {
1325         // Order synthesized ivars by their size.
1326         std::stable_sort(layout.begin(), layout.end());
1327         unsigned Ix = 0, EIx = layout.size();
1328         if (!data().IvarList) {
1329           data().IvarList = layout[0].Ivar; Ix++;
1330           curIvar = data().IvarList;
1331         }
1332         for ( ; Ix != EIx; curIvar = layout[Ix].Ivar, Ix++)
1333           curIvar->setNextIvar(layout[Ix].Ivar);
1334       }
1335     }
1336   }
1337   return data().IvarList;
1338 }
1339 
1340 /// FindCategoryDeclaration - Finds category declaration in the list of
1341 /// categories for this class and returns it. Name of the category is passed
1342 /// in 'CategoryId'. If category not found, return 0;
1343 ///
1344 ObjCCategoryDecl *
FindCategoryDeclaration(IdentifierInfo * CategoryId) const1345 ObjCInterfaceDecl::FindCategoryDeclaration(IdentifierInfo *CategoryId) const {
1346   // FIXME: Should make sure no callers ever do this.
1347   if (!hasDefinition())
1348     return nullptr;
1349 
1350   if (data().ExternallyCompleted)
1351     LoadExternalDefinition();
1352 
1353   for (auto *Cat : visible_categories())
1354     if (Cat->getIdentifier() == CategoryId)
1355       return Cat;
1356 
1357   return nullptr;
1358 }
1359 
1360 ObjCMethodDecl *
getCategoryInstanceMethod(Selector Sel) const1361 ObjCInterfaceDecl::getCategoryInstanceMethod(Selector Sel) const {
1362   for (const auto *Cat : visible_categories()) {
1363     if (ObjCCategoryImplDecl *Impl = Cat->getImplementation())
1364       if (ObjCMethodDecl *MD = Impl->getInstanceMethod(Sel))
1365         return MD;
1366   }
1367 
1368   return nullptr;
1369 }
1370 
getCategoryClassMethod(Selector Sel) const1371 ObjCMethodDecl *ObjCInterfaceDecl::getCategoryClassMethod(Selector Sel) const {
1372   for (const auto *Cat : visible_categories()) {
1373     if (ObjCCategoryImplDecl *Impl = Cat->getImplementation())
1374       if (ObjCMethodDecl *MD = Impl->getClassMethod(Sel))
1375         return MD;
1376   }
1377 
1378   return nullptr;
1379 }
1380 
1381 /// ClassImplementsProtocol - Checks that 'lProto' protocol
1382 /// has been implemented in IDecl class, its super class or categories (if
1383 /// lookupCategory is true).
ClassImplementsProtocol(ObjCProtocolDecl * lProto,bool lookupCategory,bool RHSIsQualifiedID)1384 bool ObjCInterfaceDecl::ClassImplementsProtocol(ObjCProtocolDecl *lProto,
1385                                     bool lookupCategory,
1386                                     bool RHSIsQualifiedID) {
1387   if (!hasDefinition())
1388     return false;
1389 
1390   ObjCInterfaceDecl *IDecl = this;
1391   // 1st, look up the class.
1392   for (auto *PI : IDecl->protocols()){
1393     if (getASTContext().ProtocolCompatibleWithProtocol(lProto, PI))
1394       return true;
1395     // This is dubious and is added to be compatible with gcc.  In gcc, it is
1396     // also allowed assigning a protocol-qualified 'id' type to a LHS object
1397     // when protocol in qualified LHS is in list of protocols in the rhs 'id'
1398     // object. This IMO, should be a bug.
1399     // FIXME: Treat this as an extension, and flag this as an error when GCC
1400     // extensions are not enabled.
1401     if (RHSIsQualifiedID &&
1402         getASTContext().ProtocolCompatibleWithProtocol(PI, lProto))
1403       return true;
1404   }
1405 
1406   // 2nd, look up the category.
1407   if (lookupCategory)
1408     for (const auto *Cat : visible_categories()) {
1409       for (auto *PI : Cat->protocols())
1410         if (getASTContext().ProtocolCompatibleWithProtocol(lProto, PI))
1411           return true;
1412     }
1413 
1414   // 3rd, look up the super class(s)
1415   if (IDecl->getSuperClass())
1416     return
1417   IDecl->getSuperClass()->ClassImplementsProtocol(lProto, lookupCategory,
1418                                                   RHSIsQualifiedID);
1419 
1420   return false;
1421 }
1422 
1423 //===----------------------------------------------------------------------===//
1424 // ObjCIvarDecl
1425 //===----------------------------------------------------------------------===//
1426 
anchor()1427 void ObjCIvarDecl::anchor() { }
1428 
Create(ASTContext & C,ObjCContainerDecl * DC,SourceLocation StartLoc,SourceLocation IdLoc,IdentifierInfo * Id,QualType T,TypeSourceInfo * TInfo,AccessControl ac,Expr * BW,bool synthesized)1429 ObjCIvarDecl *ObjCIvarDecl::Create(ASTContext &C, ObjCContainerDecl *DC,
1430                                    SourceLocation StartLoc,
1431                                    SourceLocation IdLoc, IdentifierInfo *Id,
1432                                    QualType T, TypeSourceInfo *TInfo,
1433                                    AccessControl ac, Expr *BW,
1434                                    bool synthesized) {
1435   if (DC) {
1436     // Ivar's can only appear in interfaces, implementations (via synthesized
1437     // properties), and class extensions (via direct declaration, or synthesized
1438     // properties).
1439     //
1440     // FIXME: This should really be asserting this:
1441     //   (isa<ObjCCategoryDecl>(DC) &&
1442     //    cast<ObjCCategoryDecl>(DC)->IsClassExtension()))
1443     // but unfortunately we sometimes place ivars into non-class extension
1444     // categories on error. This breaks an AST invariant, and should not be
1445     // fixed.
1446     assert((isa<ObjCInterfaceDecl>(DC) || isa<ObjCImplementationDecl>(DC) ||
1447             isa<ObjCCategoryDecl>(DC)) &&
1448            "Invalid ivar decl context!");
1449     // Once a new ivar is created in any of class/class-extension/implementation
1450     // decl contexts, the previously built IvarList must be rebuilt.
1451     ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(DC);
1452     if (!ID) {
1453       if (ObjCImplementationDecl *IM = dyn_cast<ObjCImplementationDecl>(DC))
1454         ID = IM->getClassInterface();
1455       else
1456         ID = cast<ObjCCategoryDecl>(DC)->getClassInterface();
1457     }
1458     ID->setIvarList(nullptr);
1459   }
1460 
1461   return new (C, DC) ObjCIvarDecl(DC, StartLoc, IdLoc, Id, T, TInfo, ac, BW,
1462                                   synthesized);
1463 }
1464 
CreateDeserialized(ASTContext & C,unsigned ID)1465 ObjCIvarDecl *ObjCIvarDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
1466   return new (C, ID) ObjCIvarDecl(nullptr, SourceLocation(), SourceLocation(),
1467                                   nullptr, QualType(), nullptr,
1468                                   ObjCIvarDecl::None, nullptr, false);
1469 }
1470 
getContainingInterface() const1471 const ObjCInterfaceDecl *ObjCIvarDecl::getContainingInterface() const {
1472   const ObjCContainerDecl *DC = cast<ObjCContainerDecl>(getDeclContext());
1473 
1474   switch (DC->getKind()) {
1475   default:
1476   case ObjCCategoryImpl:
1477   case ObjCProtocol:
1478     llvm_unreachable("invalid ivar container!");
1479 
1480     // Ivars can only appear in class extension categories.
1481   case ObjCCategory: {
1482     const ObjCCategoryDecl *CD = cast<ObjCCategoryDecl>(DC);
1483     assert(CD->IsClassExtension() && "invalid container for ivar!");
1484     return CD->getClassInterface();
1485   }
1486 
1487   case ObjCImplementation:
1488     return cast<ObjCImplementationDecl>(DC)->getClassInterface();
1489 
1490   case ObjCInterface:
1491     return cast<ObjCInterfaceDecl>(DC);
1492   }
1493 }
1494 
1495 //===----------------------------------------------------------------------===//
1496 // ObjCAtDefsFieldDecl
1497 //===----------------------------------------------------------------------===//
1498 
anchor()1499 void ObjCAtDefsFieldDecl::anchor() { }
1500 
1501 ObjCAtDefsFieldDecl
Create(ASTContext & C,DeclContext * DC,SourceLocation StartLoc,SourceLocation IdLoc,IdentifierInfo * Id,QualType T,Expr * BW)1502 *ObjCAtDefsFieldDecl::Create(ASTContext &C, DeclContext *DC,
1503                              SourceLocation StartLoc,  SourceLocation IdLoc,
1504                              IdentifierInfo *Id, QualType T, Expr *BW) {
1505   return new (C, DC) ObjCAtDefsFieldDecl(DC, StartLoc, IdLoc, Id, T, BW);
1506 }
1507 
CreateDeserialized(ASTContext & C,unsigned ID)1508 ObjCAtDefsFieldDecl *ObjCAtDefsFieldDecl::CreateDeserialized(ASTContext &C,
1509                                                              unsigned ID) {
1510   return new (C, ID) ObjCAtDefsFieldDecl(nullptr, SourceLocation(),
1511                                          SourceLocation(), nullptr, QualType(),
1512                                          nullptr);
1513 }
1514 
1515 //===----------------------------------------------------------------------===//
1516 // ObjCProtocolDecl
1517 //===----------------------------------------------------------------------===//
1518 
anchor()1519 void ObjCProtocolDecl::anchor() { }
1520 
ObjCProtocolDecl(ASTContext & C,DeclContext * DC,IdentifierInfo * Id,SourceLocation nameLoc,SourceLocation atStartLoc,ObjCProtocolDecl * PrevDecl)1521 ObjCProtocolDecl::ObjCProtocolDecl(ASTContext &C, DeclContext *DC,
1522                                    IdentifierInfo *Id, SourceLocation nameLoc,
1523                                    SourceLocation atStartLoc,
1524                                    ObjCProtocolDecl *PrevDecl)
1525     : ObjCContainerDecl(ObjCProtocol, DC, Id, nameLoc, atStartLoc),
1526       redeclarable_base(C), Data() {
1527   setPreviousDecl(PrevDecl);
1528   if (PrevDecl)
1529     Data = PrevDecl->Data;
1530 }
1531 
Create(ASTContext & C,DeclContext * DC,IdentifierInfo * Id,SourceLocation nameLoc,SourceLocation atStartLoc,ObjCProtocolDecl * PrevDecl)1532 ObjCProtocolDecl *ObjCProtocolDecl::Create(ASTContext &C, DeclContext *DC,
1533                                            IdentifierInfo *Id,
1534                                            SourceLocation nameLoc,
1535                                            SourceLocation atStartLoc,
1536                                            ObjCProtocolDecl *PrevDecl) {
1537   ObjCProtocolDecl *Result =
1538       new (C, DC) ObjCProtocolDecl(C, DC, Id, nameLoc, atStartLoc, PrevDecl);
1539   Result->Data.setInt(!C.getLangOpts().Modules);
1540   return Result;
1541 }
1542 
CreateDeserialized(ASTContext & C,unsigned ID)1543 ObjCProtocolDecl *ObjCProtocolDecl::CreateDeserialized(ASTContext &C,
1544                                                        unsigned ID) {
1545   ObjCProtocolDecl *Result =
1546       new (C, ID) ObjCProtocolDecl(C, nullptr, nullptr, SourceLocation(),
1547                                    SourceLocation(), nullptr);
1548   Result->Data.setInt(!C.getLangOpts().Modules);
1549   return Result;
1550 }
1551 
lookupProtocolNamed(IdentifierInfo * Name)1552 ObjCProtocolDecl *ObjCProtocolDecl::lookupProtocolNamed(IdentifierInfo *Name) {
1553   ObjCProtocolDecl *PDecl = this;
1554 
1555   if (Name == getIdentifier())
1556     return PDecl;
1557 
1558   for (auto *I : protocols())
1559     if ((PDecl = I->lookupProtocolNamed(Name)))
1560       return PDecl;
1561 
1562   return nullptr;
1563 }
1564 
1565 // lookupMethod - Lookup a instance/class method in the protocol and protocols
1566 // it inherited.
lookupMethod(Selector Sel,bool isInstance) const1567 ObjCMethodDecl *ObjCProtocolDecl::lookupMethod(Selector Sel,
1568                                                bool isInstance) const {
1569   ObjCMethodDecl *MethodDecl = nullptr;
1570 
1571   // If there is no definition or the definition is hidden, we don't find
1572   // anything.
1573   const ObjCProtocolDecl *Def = getDefinition();
1574   if (!Def || Def->isHidden())
1575     return nullptr;
1576 
1577   if ((MethodDecl = getMethod(Sel, isInstance)))
1578     return MethodDecl;
1579 
1580   for (const auto *I : protocols())
1581     if ((MethodDecl = I->lookupMethod(Sel, isInstance)))
1582       return MethodDecl;
1583   return nullptr;
1584 }
1585 
allocateDefinitionData()1586 void ObjCProtocolDecl::allocateDefinitionData() {
1587   assert(!Data.getPointer() && "Protocol already has a definition!");
1588   Data.setPointer(new (getASTContext()) DefinitionData);
1589   Data.getPointer()->Definition = this;
1590 }
1591 
startDefinition()1592 void ObjCProtocolDecl::startDefinition() {
1593   allocateDefinitionData();
1594 
1595   // Update all of the declarations with a pointer to the definition.
1596   for (auto RD : redecls())
1597     RD->Data = this->Data;
1598 }
1599 
collectPropertiesToImplement(PropertyMap & PM,PropertyDeclOrder & PO) const1600 void ObjCProtocolDecl::collectPropertiesToImplement(PropertyMap &PM,
1601                                                     PropertyDeclOrder &PO) const {
1602 
1603   if (const ObjCProtocolDecl *PDecl = getDefinition()) {
1604     for (auto *Prop : PDecl->properties()) {
1605       // Insert into PM if not there already.
1606       PM.insert(std::make_pair(Prop->getIdentifier(), Prop));
1607       PO.push_back(Prop);
1608     }
1609     // Scan through protocol's protocols.
1610     for (const auto *PI : PDecl->protocols())
1611       PI->collectPropertiesToImplement(PM, PO);
1612   }
1613 }
1614 
1615 
collectInheritedProtocolProperties(const ObjCPropertyDecl * Property,ProtocolPropertyMap & PM) const1616 void ObjCProtocolDecl::collectInheritedProtocolProperties(
1617                                                 const ObjCPropertyDecl *Property,
1618                                                 ProtocolPropertyMap &PM) const {
1619   if (const ObjCProtocolDecl *PDecl = getDefinition()) {
1620     bool MatchFound = false;
1621     for (auto *Prop : PDecl->properties()) {
1622       if (Prop == Property)
1623         continue;
1624       if (Prop->getIdentifier() == Property->getIdentifier()) {
1625         PM[PDecl] = Prop;
1626         MatchFound = true;
1627         break;
1628       }
1629     }
1630     // Scan through protocol's protocols which did not have a matching property.
1631     if (!MatchFound)
1632       for (const auto *PI : PDecl->protocols())
1633         PI->collectInheritedProtocolProperties(Property, PM);
1634   }
1635 }
1636 
1637 StringRef
getObjCRuntimeNameAsString() const1638 ObjCProtocolDecl::getObjCRuntimeNameAsString() const {
1639   if (ObjCRuntimeNameAttr *ObjCRTName = getAttr<ObjCRuntimeNameAttr>())
1640     return ObjCRTName->getMetadataName();
1641 
1642   return getName();
1643 }
1644 
1645 //===----------------------------------------------------------------------===//
1646 // ObjCCategoryDecl
1647 //===----------------------------------------------------------------------===//
1648 
anchor()1649 void ObjCCategoryDecl::anchor() { }
1650 
Create(ASTContext & C,DeclContext * DC,SourceLocation AtLoc,SourceLocation ClassNameLoc,SourceLocation CategoryNameLoc,IdentifierInfo * Id,ObjCInterfaceDecl * IDecl,SourceLocation IvarLBraceLoc,SourceLocation IvarRBraceLoc)1651 ObjCCategoryDecl *ObjCCategoryDecl::Create(ASTContext &C, DeclContext *DC,
1652                                            SourceLocation AtLoc,
1653                                            SourceLocation ClassNameLoc,
1654                                            SourceLocation CategoryNameLoc,
1655                                            IdentifierInfo *Id,
1656                                            ObjCInterfaceDecl *IDecl,
1657                                            SourceLocation IvarLBraceLoc,
1658                                            SourceLocation IvarRBraceLoc) {
1659   ObjCCategoryDecl *CatDecl =
1660       new (C, DC) ObjCCategoryDecl(DC, AtLoc, ClassNameLoc, CategoryNameLoc, Id,
1661                                    IDecl, IvarLBraceLoc, IvarRBraceLoc);
1662   if (IDecl) {
1663     // Link this category into its class's category list.
1664     CatDecl->NextClassCategory = IDecl->getCategoryListRaw();
1665     if (IDecl->hasDefinition()) {
1666       IDecl->setCategoryListRaw(CatDecl);
1667       if (ASTMutationListener *L = C.getASTMutationListener())
1668         L->AddedObjCCategoryToInterface(CatDecl, IDecl);
1669     }
1670   }
1671 
1672   return CatDecl;
1673 }
1674 
CreateDeserialized(ASTContext & C,unsigned ID)1675 ObjCCategoryDecl *ObjCCategoryDecl::CreateDeserialized(ASTContext &C,
1676                                                        unsigned ID) {
1677   return new (C, ID) ObjCCategoryDecl(nullptr, SourceLocation(),
1678                                       SourceLocation(), SourceLocation(),
1679                                       nullptr, nullptr);
1680 }
1681 
getImplementation() const1682 ObjCCategoryImplDecl *ObjCCategoryDecl::getImplementation() const {
1683   return getASTContext().getObjCImplementation(
1684                                            const_cast<ObjCCategoryDecl*>(this));
1685 }
1686 
setImplementation(ObjCCategoryImplDecl * ImplD)1687 void ObjCCategoryDecl::setImplementation(ObjCCategoryImplDecl *ImplD) {
1688   getASTContext().setObjCImplementation(this, ImplD);
1689 }
1690 
1691 
1692 //===----------------------------------------------------------------------===//
1693 // ObjCCategoryImplDecl
1694 //===----------------------------------------------------------------------===//
1695 
anchor()1696 void ObjCCategoryImplDecl::anchor() { }
1697 
1698 ObjCCategoryImplDecl *
Create(ASTContext & C,DeclContext * DC,IdentifierInfo * Id,ObjCInterfaceDecl * ClassInterface,SourceLocation nameLoc,SourceLocation atStartLoc,SourceLocation CategoryNameLoc)1699 ObjCCategoryImplDecl::Create(ASTContext &C, DeclContext *DC,
1700                              IdentifierInfo *Id,
1701                              ObjCInterfaceDecl *ClassInterface,
1702                              SourceLocation nameLoc,
1703                              SourceLocation atStartLoc,
1704                              SourceLocation CategoryNameLoc) {
1705   if (ClassInterface && ClassInterface->hasDefinition())
1706     ClassInterface = ClassInterface->getDefinition();
1707   return new (C, DC) ObjCCategoryImplDecl(DC, Id, ClassInterface, nameLoc,
1708                                           atStartLoc, CategoryNameLoc);
1709 }
1710 
CreateDeserialized(ASTContext & C,unsigned ID)1711 ObjCCategoryImplDecl *ObjCCategoryImplDecl::CreateDeserialized(ASTContext &C,
1712                                                                unsigned ID) {
1713   return new (C, ID) ObjCCategoryImplDecl(nullptr, nullptr, nullptr,
1714                                           SourceLocation(), SourceLocation(),
1715                                           SourceLocation());
1716 }
1717 
getCategoryDecl() const1718 ObjCCategoryDecl *ObjCCategoryImplDecl::getCategoryDecl() const {
1719   // The class interface might be NULL if we are working with invalid code.
1720   if (const ObjCInterfaceDecl *ID = getClassInterface())
1721     return ID->FindCategoryDeclaration(getIdentifier());
1722   return nullptr;
1723 }
1724 
1725 
anchor()1726 void ObjCImplDecl::anchor() { }
1727 
addPropertyImplementation(ObjCPropertyImplDecl * property)1728 void ObjCImplDecl::addPropertyImplementation(ObjCPropertyImplDecl *property) {
1729   // FIXME: The context should be correct before we get here.
1730   property->setLexicalDeclContext(this);
1731   addDecl(property);
1732 }
1733 
setClassInterface(ObjCInterfaceDecl * IFace)1734 void ObjCImplDecl::setClassInterface(ObjCInterfaceDecl *IFace) {
1735   ASTContext &Ctx = getASTContext();
1736 
1737   if (ObjCImplementationDecl *ImplD
1738         = dyn_cast_or_null<ObjCImplementationDecl>(this)) {
1739     if (IFace)
1740       Ctx.setObjCImplementation(IFace, ImplD);
1741 
1742   } else if (ObjCCategoryImplDecl *ImplD =
1743              dyn_cast_or_null<ObjCCategoryImplDecl>(this)) {
1744     if (ObjCCategoryDecl *CD = IFace->FindCategoryDeclaration(getIdentifier()))
1745       Ctx.setObjCImplementation(CD, ImplD);
1746   }
1747 
1748   ClassInterface = IFace;
1749 }
1750 
1751 /// FindPropertyImplIvarDecl - This method lookup the ivar in the list of
1752 /// properties implemented in this \@implementation block and returns
1753 /// the implemented property that uses it.
1754 ///
1755 ObjCPropertyImplDecl *ObjCImplDecl::
FindPropertyImplIvarDecl(IdentifierInfo * ivarId) const1756 FindPropertyImplIvarDecl(IdentifierInfo *ivarId) const {
1757   for (auto *PID : property_impls())
1758     if (PID->getPropertyIvarDecl() &&
1759         PID->getPropertyIvarDecl()->getIdentifier() == ivarId)
1760       return PID;
1761   return nullptr;
1762 }
1763 
1764 /// FindPropertyImplDecl - This method looks up a previous ObjCPropertyImplDecl
1765 /// added to the list of those properties \@synthesized/\@dynamic in this
1766 /// category \@implementation block.
1767 ///
1768 ObjCPropertyImplDecl *ObjCImplDecl::
FindPropertyImplDecl(IdentifierInfo * Id) const1769 FindPropertyImplDecl(IdentifierInfo *Id) const {
1770   for (auto *PID : property_impls())
1771     if (PID->getPropertyDecl()->getIdentifier() == Id)
1772       return PID;
1773   return nullptr;
1774 }
1775 
operator <<(raw_ostream & OS,const ObjCCategoryImplDecl & CID)1776 raw_ostream &clang::operator<<(raw_ostream &OS,
1777                                const ObjCCategoryImplDecl &CID) {
1778   OS << CID.getName();
1779   return OS;
1780 }
1781 
1782 //===----------------------------------------------------------------------===//
1783 // ObjCImplementationDecl
1784 //===----------------------------------------------------------------------===//
1785 
anchor()1786 void ObjCImplementationDecl::anchor() { }
1787 
1788 ObjCImplementationDecl *
Create(ASTContext & C,DeclContext * DC,ObjCInterfaceDecl * ClassInterface,ObjCInterfaceDecl * SuperDecl,SourceLocation nameLoc,SourceLocation atStartLoc,SourceLocation superLoc,SourceLocation IvarLBraceLoc,SourceLocation IvarRBraceLoc)1789 ObjCImplementationDecl::Create(ASTContext &C, DeclContext *DC,
1790                                ObjCInterfaceDecl *ClassInterface,
1791                                ObjCInterfaceDecl *SuperDecl,
1792                                SourceLocation nameLoc,
1793                                SourceLocation atStartLoc,
1794                                SourceLocation superLoc,
1795                                SourceLocation IvarLBraceLoc,
1796                                SourceLocation IvarRBraceLoc) {
1797   if (ClassInterface && ClassInterface->hasDefinition())
1798     ClassInterface = ClassInterface->getDefinition();
1799   return new (C, DC) ObjCImplementationDecl(DC, ClassInterface, SuperDecl,
1800                                             nameLoc, atStartLoc, superLoc,
1801                                             IvarLBraceLoc, IvarRBraceLoc);
1802 }
1803 
1804 ObjCImplementationDecl *
CreateDeserialized(ASTContext & C,unsigned ID)1805 ObjCImplementationDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
1806   return new (C, ID) ObjCImplementationDecl(nullptr, nullptr, nullptr,
1807                                             SourceLocation(), SourceLocation());
1808 }
1809 
setIvarInitializers(ASTContext & C,CXXCtorInitializer ** initializers,unsigned numInitializers)1810 void ObjCImplementationDecl::setIvarInitializers(ASTContext &C,
1811                                              CXXCtorInitializer ** initializers,
1812                                                  unsigned numInitializers) {
1813   if (numInitializers > 0) {
1814     NumIvarInitializers = numInitializers;
1815     CXXCtorInitializer **ivarInitializers =
1816     new (C) CXXCtorInitializer*[NumIvarInitializers];
1817     memcpy(ivarInitializers, initializers,
1818            numInitializers * sizeof(CXXCtorInitializer*));
1819     IvarInitializers = ivarInitializers;
1820   }
1821 }
1822 
1823 ObjCImplementationDecl::init_const_iterator
init_begin() const1824 ObjCImplementationDecl::init_begin() const {
1825   return IvarInitializers.get(getASTContext().getExternalSource());
1826 }
1827 
operator <<(raw_ostream & OS,const ObjCImplementationDecl & ID)1828 raw_ostream &clang::operator<<(raw_ostream &OS,
1829                                const ObjCImplementationDecl &ID) {
1830   OS << ID.getName();
1831   return OS;
1832 }
1833 
1834 //===----------------------------------------------------------------------===//
1835 // ObjCCompatibleAliasDecl
1836 //===----------------------------------------------------------------------===//
1837 
anchor()1838 void ObjCCompatibleAliasDecl::anchor() { }
1839 
1840 ObjCCompatibleAliasDecl *
Create(ASTContext & C,DeclContext * DC,SourceLocation L,IdentifierInfo * Id,ObjCInterfaceDecl * AliasedClass)1841 ObjCCompatibleAliasDecl::Create(ASTContext &C, DeclContext *DC,
1842                                 SourceLocation L,
1843                                 IdentifierInfo *Id,
1844                                 ObjCInterfaceDecl* AliasedClass) {
1845   return new (C, DC) ObjCCompatibleAliasDecl(DC, L, Id, AliasedClass);
1846 }
1847 
1848 ObjCCompatibleAliasDecl *
CreateDeserialized(ASTContext & C,unsigned ID)1849 ObjCCompatibleAliasDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
1850   return new (C, ID) ObjCCompatibleAliasDecl(nullptr, SourceLocation(),
1851                                              nullptr, nullptr);
1852 }
1853 
1854 //===----------------------------------------------------------------------===//
1855 // ObjCPropertyDecl
1856 //===----------------------------------------------------------------------===//
1857 
anchor()1858 void ObjCPropertyDecl::anchor() { }
1859 
Create(ASTContext & C,DeclContext * DC,SourceLocation L,IdentifierInfo * Id,SourceLocation AtLoc,SourceLocation LParenLoc,TypeSourceInfo * T,PropertyControl propControl)1860 ObjCPropertyDecl *ObjCPropertyDecl::Create(ASTContext &C, DeclContext *DC,
1861                                            SourceLocation L,
1862                                            IdentifierInfo *Id,
1863                                            SourceLocation AtLoc,
1864                                            SourceLocation LParenLoc,
1865                                            TypeSourceInfo *T,
1866                                            PropertyControl propControl) {
1867   return new (C, DC) ObjCPropertyDecl(DC, L, Id, AtLoc, LParenLoc, T);
1868 }
1869 
CreateDeserialized(ASTContext & C,unsigned ID)1870 ObjCPropertyDecl *ObjCPropertyDecl::CreateDeserialized(ASTContext &C,
1871                                                        unsigned ID) {
1872   return new (C, ID) ObjCPropertyDecl(nullptr, SourceLocation(), nullptr,
1873                                       SourceLocation(), SourceLocation(),
1874                                       nullptr);
1875 }
1876 
1877 //===----------------------------------------------------------------------===//
1878 // ObjCPropertyImplDecl
1879 //===----------------------------------------------------------------------===//
1880 
Create(ASTContext & C,DeclContext * DC,SourceLocation atLoc,SourceLocation L,ObjCPropertyDecl * property,Kind PK,ObjCIvarDecl * ivar,SourceLocation ivarLoc)1881 ObjCPropertyImplDecl *ObjCPropertyImplDecl::Create(ASTContext &C,
1882                                                    DeclContext *DC,
1883                                                    SourceLocation atLoc,
1884                                                    SourceLocation L,
1885                                                    ObjCPropertyDecl *property,
1886                                                    Kind PK,
1887                                                    ObjCIvarDecl *ivar,
1888                                                    SourceLocation ivarLoc) {
1889   return new (C, DC) ObjCPropertyImplDecl(DC, atLoc, L, property, PK, ivar,
1890                                           ivarLoc);
1891 }
1892 
CreateDeserialized(ASTContext & C,unsigned ID)1893 ObjCPropertyImplDecl *ObjCPropertyImplDecl::CreateDeserialized(ASTContext &C,
1894                                                                unsigned ID) {
1895   return new (C, ID) ObjCPropertyImplDecl(nullptr, SourceLocation(),
1896                                           SourceLocation(), nullptr, Dynamic,
1897                                           nullptr, SourceLocation());
1898 }
1899 
getSourceRange() const1900 SourceRange ObjCPropertyImplDecl::getSourceRange() const {
1901   SourceLocation EndLoc = getLocation();
1902   if (IvarLoc.isValid())
1903     EndLoc = IvarLoc;
1904 
1905   return SourceRange(AtLoc, EndLoc);
1906 }
1907