• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===--- ExprObjC.h - Classes for representing ObjC expressions -*- C++ -*-===//
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 defines the ExprObjC interface and subclasses.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_CLANG_AST_EXPROBJC_H
15 #define LLVM_CLANG_AST_EXPROBJC_H
16 
17 #include "clang/AST/DeclObjC.h"
18 #include "clang/AST/Expr.h"
19 #include "clang/AST/SelectorLocationsKind.h"
20 #include "clang/Basic/IdentifierTable.h"
21 #include "llvm/Support/Compiler.h"
22 
23 namespace clang {
24   class IdentifierInfo;
25   class ASTContext;
26 
27 /// ObjCStringLiteral, used for Objective-C string literals
28 /// i.e. @"foo".
29 class ObjCStringLiteral : public Expr {
30   Stmt *String;
31   SourceLocation AtLoc;
32 public:
ObjCStringLiteral(StringLiteral * SL,QualType T,SourceLocation L)33   ObjCStringLiteral(StringLiteral *SL, QualType T, SourceLocation L)
34     : Expr(ObjCStringLiteralClass, T, VK_RValue, OK_Ordinary, false, false,
35            false, false),
36       String(SL), AtLoc(L) {}
ObjCStringLiteral(EmptyShell Empty)37   explicit ObjCStringLiteral(EmptyShell Empty)
38     : Expr(ObjCStringLiteralClass, Empty) {}
39 
getString()40   StringLiteral *getString() { return cast<StringLiteral>(String); }
getString()41   const StringLiteral *getString() const { return cast<StringLiteral>(String); }
setString(StringLiteral * S)42   void setString(StringLiteral *S) { String = S; }
43 
getAtLoc()44   SourceLocation getAtLoc() const { return AtLoc; }
setAtLoc(SourceLocation L)45   void setAtLoc(SourceLocation L) { AtLoc = L; }
46 
getLocStart()47   SourceLocation getLocStart() const LLVM_READONLY { return AtLoc; }
getLocEnd()48   SourceLocation getLocEnd() const LLVM_READONLY { return String->getLocEnd(); }
49 
classof(const Stmt * T)50   static bool classof(const Stmt *T) {
51     return T->getStmtClass() == ObjCStringLiteralClass;
52   }
53 
54   // Iterators
children()55   child_range children() { return child_range(&String, &String+1); }
56 };
57 
58 /// ObjCBoolLiteralExpr - Objective-C Boolean Literal.
59 ///
60 class ObjCBoolLiteralExpr : public Expr {
61   bool Value;
62   SourceLocation Loc;
63 public:
ObjCBoolLiteralExpr(bool val,QualType Ty,SourceLocation l)64   ObjCBoolLiteralExpr(bool val, QualType Ty, SourceLocation l) :
65   Expr(ObjCBoolLiteralExprClass, Ty, VK_RValue, OK_Ordinary, false, false,
66        false, false), Value(val), Loc(l) {}
67 
ObjCBoolLiteralExpr(EmptyShell Empty)68   explicit ObjCBoolLiteralExpr(EmptyShell Empty)
69   : Expr(ObjCBoolLiteralExprClass, Empty) { }
70 
getValue()71   bool getValue() const { return Value; }
setValue(bool V)72   void setValue(bool V) { Value = V; }
73 
getLocStart()74   SourceLocation getLocStart() const LLVM_READONLY { return Loc; }
getLocEnd()75   SourceLocation getLocEnd() const LLVM_READONLY { return Loc; }
76 
getLocation()77   SourceLocation getLocation() const { return Loc; }
setLocation(SourceLocation L)78   void setLocation(SourceLocation L) { Loc = L; }
79 
classof(const Stmt * T)80   static bool classof(const Stmt *T) {
81     return T->getStmtClass() == ObjCBoolLiteralExprClass;
82   }
83 
84   // Iterators
children()85   child_range children() { return child_range(); }
86 };
87 
88 /// ObjCBoxedExpr - used for generalized expression boxing.
89 /// as in: @(strdup("hello world")) or @(random())
90 /// Also used for boxing non-parenthesized numeric literals;
91 /// as in: @42 or \@true (c++/objc++) or \@__yes (c/objc).
92 class ObjCBoxedExpr : public Expr {
93   Stmt *SubExpr;
94   ObjCMethodDecl *BoxingMethod;
95   SourceRange Range;
96 public:
ObjCBoxedExpr(Expr * E,QualType T,ObjCMethodDecl * method,SourceRange R)97   ObjCBoxedExpr(Expr *E, QualType T, ObjCMethodDecl *method,
98                      SourceRange R)
99   : Expr(ObjCBoxedExprClass, T, VK_RValue, OK_Ordinary,
100          E->isTypeDependent(), E->isValueDependent(),
101          E->isInstantiationDependent(), E->containsUnexpandedParameterPack()),
102          SubExpr(E), BoxingMethod(method), Range(R) {}
ObjCBoxedExpr(EmptyShell Empty)103   explicit ObjCBoxedExpr(EmptyShell Empty)
104   : Expr(ObjCBoxedExprClass, Empty) {}
105 
getSubExpr()106   Expr *getSubExpr() { return cast<Expr>(SubExpr); }
getSubExpr()107   const Expr *getSubExpr() const { return cast<Expr>(SubExpr); }
108 
getBoxingMethod()109   ObjCMethodDecl *getBoxingMethod() const {
110     return BoxingMethod;
111   }
112 
getAtLoc()113   SourceLocation getAtLoc() const { return Range.getBegin(); }
114 
getLocStart()115   SourceLocation getLocStart() const LLVM_READONLY { return Range.getBegin(); }
getLocEnd()116   SourceLocation getLocEnd() const LLVM_READONLY { return Range.getEnd(); }
getSourceRange()117   SourceRange getSourceRange() const LLVM_READONLY {
118     return Range;
119   }
120 
classof(const Stmt * T)121   static bool classof(const Stmt *T) {
122     return T->getStmtClass() == ObjCBoxedExprClass;
123   }
124 
125   // Iterators
children()126   child_range children() { return child_range(&SubExpr, &SubExpr+1); }
127 
128   friend class ASTStmtReader;
129 };
130 
131 /// ObjCArrayLiteral - used for objective-c array containers; as in:
132 /// @[@"Hello", NSApp, [NSNumber numberWithInt:42]];
133 class ObjCArrayLiteral : public Expr {
134   unsigned NumElements;
135   SourceRange Range;
136   ObjCMethodDecl *ArrayWithObjectsMethod;
137 
138   ObjCArrayLiteral(ArrayRef<Expr *> Elements,
139                    QualType T, ObjCMethodDecl * Method,
140                    SourceRange SR);
141 
ObjCArrayLiteral(EmptyShell Empty,unsigned NumElements)142   explicit ObjCArrayLiteral(EmptyShell Empty, unsigned NumElements)
143     : Expr(ObjCArrayLiteralClass, Empty), NumElements(NumElements) {}
144 
145 public:
146   static ObjCArrayLiteral *Create(ASTContext &C,
147                                   ArrayRef<Expr *> Elements,
148                                   QualType T, ObjCMethodDecl * Method,
149                                   SourceRange SR);
150 
151   static ObjCArrayLiteral *CreateEmpty(ASTContext &C, unsigned NumElements);
152 
getLocStart()153   SourceLocation getLocStart() const LLVM_READONLY { return Range.getBegin(); }
getLocEnd()154   SourceLocation getLocEnd() const LLVM_READONLY { return Range.getEnd(); }
getSourceRange()155   SourceRange getSourceRange() const LLVM_READONLY { return Range; }
156 
classof(const Stmt * T)157   static bool classof(const Stmt *T) {
158       return T->getStmtClass() == ObjCArrayLiteralClass;
159   }
160 
161   /// \brief Retrieve elements of array of literals.
getElements()162   Expr **getElements() { return reinterpret_cast<Expr **>(this + 1); }
163 
164   /// \brief Retrieve elements of array of literals.
getElements()165   const Expr * const *getElements() const {
166     return reinterpret_cast<const Expr * const*>(this + 1);
167   }
168 
169   /// getNumElements - Return number of elements of objective-c array literal.
getNumElements()170   unsigned getNumElements() const { return NumElements; }
171 
172     /// getExpr - Return the Expr at the specified index.
getElement(unsigned Index)173   Expr *getElement(unsigned Index) {
174     assert((Index < NumElements) && "Arg access out of range!");
175     return cast<Expr>(getElements()[Index]);
176   }
getElement(unsigned Index)177   const Expr *getElement(unsigned Index) const {
178     assert((Index < NumElements) && "Arg access out of range!");
179     return cast<Expr>(getElements()[Index]);
180   }
181 
getArrayWithObjectsMethod()182   ObjCMethodDecl *getArrayWithObjectsMethod() const {
183     return ArrayWithObjectsMethod;
184   }
185 
186   // Iterators
children()187   child_range children() {
188     return child_range((Stmt **)getElements(),
189                        (Stmt **)getElements() + NumElements);
190   }
191 
192   friend class ASTStmtReader;
193 };
194 
195 /// \brief An element in an Objective-C dictionary literal.
196 ///
197 struct ObjCDictionaryElement {
198   /// \brief The key for the dictionary element.
199   Expr *Key;
200 
201   /// \brief The value of the dictionary element.
202   Expr *Value;
203 
204   /// \brief The location of the ellipsis, if this is a pack expansion.
205   SourceLocation EllipsisLoc;
206 
207   /// \brief The number of elements this pack expansion will expand to, if
208   /// this is a pack expansion and is known.
209   Optional<unsigned> NumExpansions;
210 
211   /// \brief Determines whether this dictionary element is a pack expansion.
isPackExpansionObjCDictionaryElement212   bool isPackExpansion() const { return EllipsisLoc.isValid(); }
213 };
214 } // end namespace clang
215 
216 namespace llvm {
217 template <> struct isPodLike<clang::ObjCDictionaryElement> : llvm::true_type {};
218 }
219 
220 namespace clang {
221 /// ObjCDictionaryLiteral - AST node to represent objective-c dictionary
222 /// literals; as in:  @{@"name" : NSUserName(), @"date" : [NSDate date] };
223 class ObjCDictionaryLiteral : public Expr {
224   /// \brief Key/value pair used to store the key and value of a given element.
225   ///
226   /// Objects of this type are stored directly after the expression.
227   struct KeyValuePair {
228     Expr *Key;
229     Expr *Value;
230   };
231 
232   /// \brief Data that describes an element that is a pack expansion, used if any
233   /// of the elements in the dictionary literal are pack expansions.
234   struct ExpansionData {
235     /// \brief The location of the ellipsis, if this element is a pack
236     /// expansion.
237     SourceLocation EllipsisLoc;
238 
239     /// \brief If non-zero, the number of elements that this pack
240     /// expansion will expand to (+1).
241     unsigned NumExpansionsPlusOne;
242   };
243 
244   /// \brief The number of elements in this dictionary literal.
245   unsigned NumElements : 31;
246 
247   /// \brief Determine whether this dictionary literal has any pack expansions.
248   ///
249   /// If the dictionary literal has pack expansions, then there will
250   /// be an array of pack expansion data following the array of
251   /// key/value pairs, which provide the locations of the ellipses (if
252   /// any) and number of elements in the expansion (if known). If
253   /// there are no pack expansions, we optimize away this storage.
254   unsigned HasPackExpansions : 1;
255 
256   SourceRange Range;
257   ObjCMethodDecl *DictWithObjectsMethod;
258 
259   ObjCDictionaryLiteral(ArrayRef<ObjCDictionaryElement> VK,
260                         bool HasPackExpansions,
261                         QualType T, ObjCMethodDecl *method,
262                         SourceRange SR);
263 
264   explicit ObjCDictionaryLiteral(EmptyShell Empty, unsigned NumElements,
265                                  bool HasPackExpansions)
266     : Expr(ObjCDictionaryLiteralClass, Empty), NumElements(NumElements),
267       HasPackExpansions(HasPackExpansions) {}
268 
269   KeyValuePair *getKeyValues() {
270     return reinterpret_cast<KeyValuePair *>(this + 1);
271   }
272 
273   const KeyValuePair *getKeyValues() const {
274     return reinterpret_cast<const KeyValuePair *>(this + 1);
275   }
276 
277   ExpansionData *getExpansionData() {
278     if (!HasPackExpansions)
279       return 0;
280 
281     return reinterpret_cast<ExpansionData *>(getKeyValues() + NumElements);
282   }
283 
284   const ExpansionData *getExpansionData() const {
285     if (!HasPackExpansions)
286       return 0;
287 
288     return reinterpret_cast<const ExpansionData *>(getKeyValues()+NumElements);
289   }
290 
291 public:
292   static ObjCDictionaryLiteral *Create(ASTContext &C,
293                                        ArrayRef<ObjCDictionaryElement> VK,
294                                        bool HasPackExpansions,
295                                        QualType T, ObjCMethodDecl *method,
296                                        SourceRange SR);
297 
298   static ObjCDictionaryLiteral *CreateEmpty(ASTContext &C,
299                                             unsigned NumElements,
300                                             bool HasPackExpansions);
301 
302   /// getNumElements - Return number of elements of objective-c dictionary
303   /// literal.
304   unsigned getNumElements() const { return NumElements; }
305 
306   ObjCDictionaryElement getKeyValueElement(unsigned Index) const {
307     assert((Index < NumElements) && "Arg access out of range!");
308     const KeyValuePair &KV = getKeyValues()[Index];
309     ObjCDictionaryElement Result = { KV.Key, KV.Value, SourceLocation(), None };
310     if (HasPackExpansions) {
311       const ExpansionData &Expansion = getExpansionData()[Index];
312       Result.EllipsisLoc = Expansion.EllipsisLoc;
313       if (Expansion.NumExpansionsPlusOne > 0)
314         Result.NumExpansions = Expansion.NumExpansionsPlusOne - 1;
315     }
316     return Result;
317   }
318 
319   ObjCMethodDecl *getDictWithObjectsMethod() const
320     { return DictWithObjectsMethod; }
321 
322   SourceLocation getLocStart() const LLVM_READONLY { return Range.getBegin(); }
323   SourceLocation getLocEnd() const LLVM_READONLY { return Range.getEnd(); }
324   SourceRange getSourceRange() const LLVM_READONLY { return Range; }
325 
326   static bool classof(const Stmt *T) {
327       return T->getStmtClass() == ObjCDictionaryLiteralClass;
328   }
329 
330   // Iterators
331   child_range children() {
332     // Note: we're taking advantage of the layout of the KeyValuePair struct
333     // here. If that struct changes, this code will need to change as well.
334     return child_range(reinterpret_cast<Stmt **>(this + 1),
335                        reinterpret_cast<Stmt **>(this + 1) + NumElements * 2);
336   }
337 
338   friend class ASTStmtReader;
339   friend class ASTStmtWriter;
340 };
341 
342 
343 /// ObjCEncodeExpr, used for \@encode in Objective-C.  \@encode has the same
344 /// type and behavior as StringLiteral except that the string initializer is
345 /// obtained from ASTContext with the encoding type as an argument.
346 class ObjCEncodeExpr : public Expr {
347   TypeSourceInfo *EncodedType;
348   SourceLocation AtLoc, RParenLoc;
349 public:
350   ObjCEncodeExpr(QualType T, TypeSourceInfo *EncodedType,
351                  SourceLocation at, SourceLocation rp)
352     : Expr(ObjCEncodeExprClass, T, VK_LValue, OK_Ordinary,
353            EncodedType->getType()->isDependentType(),
354            EncodedType->getType()->isDependentType(),
355            EncodedType->getType()->isInstantiationDependentType(),
356            EncodedType->getType()->containsUnexpandedParameterPack()),
357       EncodedType(EncodedType), AtLoc(at), RParenLoc(rp) {}
358 
359   explicit ObjCEncodeExpr(EmptyShell Empty) : Expr(ObjCEncodeExprClass, Empty){}
360 
361 
362   SourceLocation getAtLoc() const { return AtLoc; }
363   void setAtLoc(SourceLocation L) { AtLoc = L; }
364   SourceLocation getRParenLoc() const { return RParenLoc; }
365   void setRParenLoc(SourceLocation L) { RParenLoc = L; }
366 
367   QualType getEncodedType() const { return EncodedType->getType(); }
368 
369   TypeSourceInfo *getEncodedTypeSourceInfo() const { return EncodedType; }
370   void setEncodedTypeSourceInfo(TypeSourceInfo *EncType) {
371     EncodedType = EncType;
372   }
373 
374   SourceLocation getLocStart() const LLVM_READONLY { return AtLoc; }
375   SourceLocation getLocEnd() const LLVM_READONLY { return RParenLoc; }
376 
377   static bool classof(const Stmt *T) {
378     return T->getStmtClass() == ObjCEncodeExprClass;
379   }
380 
381   // Iterators
382   child_range children() { return child_range(); }
383 };
384 
385 /// ObjCSelectorExpr used for \@selector in Objective-C.
386 class ObjCSelectorExpr : public Expr {
387   Selector SelName;
388   SourceLocation AtLoc, RParenLoc;
389 public:
390   ObjCSelectorExpr(QualType T, Selector selInfo,
391                    SourceLocation at, SourceLocation rp)
392     : Expr(ObjCSelectorExprClass, T, VK_RValue, OK_Ordinary, false, false,
393            false, false),
394     SelName(selInfo), AtLoc(at), RParenLoc(rp){}
395   explicit ObjCSelectorExpr(EmptyShell Empty)
396    : Expr(ObjCSelectorExprClass, Empty) {}
397 
398   Selector getSelector() const { return SelName; }
399   void setSelector(Selector S) { SelName = S; }
400 
401   SourceLocation getAtLoc() const { return AtLoc; }
402   SourceLocation getRParenLoc() const { return RParenLoc; }
403   void setAtLoc(SourceLocation L) { AtLoc = L; }
404   void setRParenLoc(SourceLocation L) { RParenLoc = L; }
405 
406   SourceLocation getLocStart() const LLVM_READONLY { return AtLoc; }
407   SourceLocation getLocEnd() const LLVM_READONLY { return RParenLoc; }
408 
409   /// getNumArgs - Return the number of actual arguments to this call.
410   unsigned getNumArgs() const { return SelName.getNumArgs(); }
411 
412   static bool classof(const Stmt *T) {
413     return T->getStmtClass() == ObjCSelectorExprClass;
414   }
415 
416   // Iterators
417   child_range children() { return child_range(); }
418 };
419 
420 /// ObjCProtocolExpr used for protocol expression in Objective-C.
421 ///
422 /// This is used as: \@protocol(foo), as in:
423 /// \code
424 ///   [obj conformsToProtocol:@protocol(foo)]
425 /// \endcode
426 ///
427 /// The return type is "Protocol*".
428 class ObjCProtocolExpr : public Expr {
429   ObjCProtocolDecl *TheProtocol;
430   SourceLocation AtLoc, ProtoLoc, RParenLoc;
431 public:
432   ObjCProtocolExpr(QualType T, ObjCProtocolDecl *protocol,
433                  SourceLocation at, SourceLocation protoLoc, SourceLocation rp)
434     : Expr(ObjCProtocolExprClass, T, VK_RValue, OK_Ordinary, false, false,
435            false, false),
436       TheProtocol(protocol), AtLoc(at), ProtoLoc(protoLoc), RParenLoc(rp) {}
437   explicit ObjCProtocolExpr(EmptyShell Empty)
438     : Expr(ObjCProtocolExprClass, Empty) {}
439 
440   ObjCProtocolDecl *getProtocol() const { return TheProtocol; }
441   void setProtocol(ObjCProtocolDecl *P) { TheProtocol = P; }
442 
443   SourceLocation getProtocolIdLoc() const { return ProtoLoc; }
444   SourceLocation getAtLoc() const { return AtLoc; }
445   SourceLocation getRParenLoc() const { return RParenLoc; }
446   void setAtLoc(SourceLocation L) { AtLoc = L; }
447   void setRParenLoc(SourceLocation L) { RParenLoc = L; }
448 
449   SourceLocation getLocStart() const LLVM_READONLY { return AtLoc; }
450   SourceLocation getLocEnd() const LLVM_READONLY { return RParenLoc; }
451 
452   static bool classof(const Stmt *T) {
453     return T->getStmtClass() == ObjCProtocolExprClass;
454   }
455 
456   // Iterators
457   child_range children() { return child_range(); }
458 
459   friend class ASTStmtReader;
460   friend class ASTStmtWriter;
461 };
462 
463 /// ObjCIvarRefExpr - A reference to an ObjC instance variable.
464 class ObjCIvarRefExpr : public Expr {
465   ObjCIvarDecl *D;
466   Stmt *Base;
467   SourceLocation Loc;
468   /// OpLoc - This is the location of '.' or '->'
469   SourceLocation OpLoc;
470 
471   bool IsArrow:1;      // True if this is "X->F", false if this is "X.F".
472   bool IsFreeIvar:1;   // True if ivar reference has no base (self assumed).
473 
474 public:
475   ObjCIvarRefExpr(ObjCIvarDecl *d, QualType t,
476                   SourceLocation l, SourceLocation oploc,
477                   Expr *base,
478                   bool arrow = false, bool freeIvar = false) :
479     Expr(ObjCIvarRefExprClass, t, VK_LValue,
480          d->isBitField() ? OK_BitField : OK_Ordinary,
481          /*TypeDependent=*/false, base->isValueDependent(),
482          base->isInstantiationDependent(),
483          base->containsUnexpandedParameterPack()),
484     D(d), Base(base), Loc(l), OpLoc(oploc),
485     IsArrow(arrow), IsFreeIvar(freeIvar) {}
486 
487   explicit ObjCIvarRefExpr(EmptyShell Empty)
488     : Expr(ObjCIvarRefExprClass, Empty) {}
489 
490   ObjCIvarDecl *getDecl() { return D; }
491   const ObjCIvarDecl *getDecl() const { return D; }
492   void setDecl(ObjCIvarDecl *d) { D = d; }
493 
494   const Expr *getBase() const { return cast<Expr>(Base); }
495   Expr *getBase() { return cast<Expr>(Base); }
496   void setBase(Expr * base) { Base = base; }
497 
498   bool isArrow() const { return IsArrow; }
499   bool isFreeIvar() const { return IsFreeIvar; }
500   void setIsArrow(bool A) { IsArrow = A; }
501   void setIsFreeIvar(bool A) { IsFreeIvar = A; }
502 
503   SourceLocation getLocation() const { return Loc; }
504   void setLocation(SourceLocation L) { Loc = L; }
505 
506   SourceLocation getLocStart() const LLVM_READONLY {
507     return isFreeIvar() ? Loc : getBase()->getLocStart();
508   }
509   SourceLocation getLocEnd() const LLVM_READONLY { return Loc; }
510 
511   SourceLocation getOpLoc() const { return OpLoc; }
512   void setOpLoc(SourceLocation L) { OpLoc = L; }
513 
514   static bool classof(const Stmt *T) {
515     return T->getStmtClass() == ObjCIvarRefExprClass;
516   }
517 
518   // Iterators
519   child_range children() { return child_range(&Base, &Base+1); }
520 };
521 
522 /// ObjCPropertyRefExpr - A dot-syntax expression to access an ObjC
523 /// property.
524 class ObjCPropertyRefExpr : public Expr {
525 private:
526   /// If the bool is true, this is an implicit property reference; the
527   /// pointer is an (optional) ObjCMethodDecl and Setter may be set.
528   /// if the bool is false, this is an explicit property reference;
529   /// the pointer is an ObjCPropertyDecl and Setter is always null.
530   llvm::PointerIntPair<NamedDecl*, 1, bool> PropertyOrGetter;
531 
532   /// \brief Indicates whether the property reference will result in a message
533   /// to the getter, the setter, or both.
534   /// This applies to both implicit and explicit property references.
535   enum MethodRefFlags {
536     MethodRef_None = 0,
537     MethodRef_Getter = 0x1,
538     MethodRef_Setter = 0x2
539   };
540 
541   /// \brief Contains the Setter method pointer and MethodRefFlags bit flags.
542   llvm::PointerIntPair<ObjCMethodDecl *, 2, unsigned> SetterAndMethodRefFlags;
543 
544   // FIXME: Maybe we should store the property identifier here,
545   // because it's not rederivable from the other data when there's an
546   // implicit property with no getter (because the 'foo' -> 'setFoo:'
547   // transformation is lossy on the first character).
548 
549   SourceLocation IdLoc;
550 
551   /// \brief When the receiver in property access is 'super', this is
552   /// the location of the 'super' keyword.  When it's an interface,
553   /// this is that interface.
554   SourceLocation ReceiverLoc;
555   llvm::PointerUnion3<Stmt*, const Type*, ObjCInterfaceDecl*> Receiver;
556 
557 public:
558   ObjCPropertyRefExpr(ObjCPropertyDecl *PD, QualType t,
559                       ExprValueKind VK, ExprObjectKind OK,
560                       SourceLocation l, Expr *base)
561     : Expr(ObjCPropertyRefExprClass, t, VK, OK,
562            /*TypeDependent=*/false, base->isValueDependent(),
563            base->isInstantiationDependent(),
564            base->containsUnexpandedParameterPack()),
565       PropertyOrGetter(PD, false), SetterAndMethodRefFlags(),
566       IdLoc(l), ReceiverLoc(), Receiver(base) {
567     assert(t->isSpecificPlaceholderType(BuiltinType::PseudoObject));
568   }
569 
570   ObjCPropertyRefExpr(ObjCPropertyDecl *PD, QualType t,
571                       ExprValueKind VK, ExprObjectKind OK,
572                       SourceLocation l, SourceLocation sl, QualType st)
573     : Expr(ObjCPropertyRefExprClass, t, VK, OK,
574            /*TypeDependent=*/false, false, st->isInstantiationDependentType(),
575            st->containsUnexpandedParameterPack()),
576       PropertyOrGetter(PD, false), SetterAndMethodRefFlags(),
577       IdLoc(l), ReceiverLoc(sl), Receiver(st.getTypePtr()) {
578     assert(t->isSpecificPlaceholderType(BuiltinType::PseudoObject));
579   }
580 
581   ObjCPropertyRefExpr(ObjCMethodDecl *Getter, ObjCMethodDecl *Setter,
582                       QualType T, ExprValueKind VK, ExprObjectKind OK,
583                       SourceLocation IdLoc, Expr *Base)
584     : Expr(ObjCPropertyRefExprClass, T, VK, OK, false,
585            Base->isValueDependent(), Base->isInstantiationDependent(),
586            Base->containsUnexpandedParameterPack()),
587       PropertyOrGetter(Getter, true), SetterAndMethodRefFlags(Setter, 0),
588       IdLoc(IdLoc), ReceiverLoc(), Receiver(Base) {
589     assert(T->isSpecificPlaceholderType(BuiltinType::PseudoObject));
590   }
591 
592   ObjCPropertyRefExpr(ObjCMethodDecl *Getter, ObjCMethodDecl *Setter,
593                       QualType T, ExprValueKind VK, ExprObjectKind OK,
594                       SourceLocation IdLoc,
595                       SourceLocation SuperLoc, QualType SuperTy)
596     : Expr(ObjCPropertyRefExprClass, T, VK, OK, false, false, false, false),
597       PropertyOrGetter(Getter, true), SetterAndMethodRefFlags(Setter, 0),
598       IdLoc(IdLoc), ReceiverLoc(SuperLoc), Receiver(SuperTy.getTypePtr()) {
599     assert(T->isSpecificPlaceholderType(BuiltinType::PseudoObject));
600   }
601 
602   ObjCPropertyRefExpr(ObjCMethodDecl *Getter, ObjCMethodDecl *Setter,
603                       QualType T, ExprValueKind VK, ExprObjectKind OK,
604                       SourceLocation IdLoc,
605                       SourceLocation ReceiverLoc, ObjCInterfaceDecl *Receiver)
606     : Expr(ObjCPropertyRefExprClass, T, VK, OK, false, false, false, false),
607       PropertyOrGetter(Getter, true), SetterAndMethodRefFlags(Setter, 0),
608       IdLoc(IdLoc), ReceiverLoc(ReceiverLoc), Receiver(Receiver) {
609     assert(T->isSpecificPlaceholderType(BuiltinType::PseudoObject));
610   }
611 
612   explicit ObjCPropertyRefExpr(EmptyShell Empty)
613     : Expr(ObjCPropertyRefExprClass, Empty) {}
614 
615   bool isImplicitProperty() const { return PropertyOrGetter.getInt(); }
616   bool isExplicitProperty() const { return !PropertyOrGetter.getInt(); }
617 
618   ObjCPropertyDecl *getExplicitProperty() const {
619     assert(!isImplicitProperty());
620     return cast<ObjCPropertyDecl>(PropertyOrGetter.getPointer());
621   }
622 
623   ObjCMethodDecl *getImplicitPropertyGetter() const {
624     assert(isImplicitProperty());
625     return cast_or_null<ObjCMethodDecl>(PropertyOrGetter.getPointer());
626   }
627 
628   ObjCMethodDecl *getImplicitPropertySetter() const {
629     assert(isImplicitProperty());
630     return SetterAndMethodRefFlags.getPointer();
631   }
632 
633   Selector getGetterSelector() const {
634     if (isImplicitProperty())
635       return getImplicitPropertyGetter()->getSelector();
636     return getExplicitProperty()->getGetterName();
637   }
638 
639   Selector getSetterSelector() const {
640     if (isImplicitProperty())
641       return getImplicitPropertySetter()->getSelector();
642     return getExplicitProperty()->getSetterName();
643   }
644 
645   /// \brief True if the property reference will result in a message to the
646   /// getter.
647   /// This applies to both implicit and explicit property references.
648   bool isMessagingGetter() const {
649     return SetterAndMethodRefFlags.getInt() & MethodRef_Getter;
650   }
651 
652   /// \brief True if the property reference will result in a message to the
653   /// setter.
654   /// This applies to both implicit and explicit property references.
655   bool isMessagingSetter() const {
656     return SetterAndMethodRefFlags.getInt() & MethodRef_Setter;
657   }
658 
659   void setIsMessagingGetter(bool val = true) {
660     setMethodRefFlag(MethodRef_Getter, val);
661   }
662 
663   void setIsMessagingSetter(bool val = true) {
664     setMethodRefFlag(MethodRef_Setter, val);
665   }
666 
667   const Expr *getBase() const {
668     return cast<Expr>(Receiver.get<Stmt*>());
669   }
670   Expr *getBase() {
671     return cast<Expr>(Receiver.get<Stmt*>());
672   }
673 
674   SourceLocation getLocation() const { return IdLoc; }
675 
676   SourceLocation getReceiverLocation() const { return ReceiverLoc; }
677   QualType getSuperReceiverType() const {
678     return QualType(Receiver.get<const Type*>(), 0);
679   }
680   QualType getGetterResultType() const {
681     QualType ResultType;
682     if (isExplicitProperty()) {
683       const ObjCPropertyDecl *PDecl = getExplicitProperty();
684       if (const ObjCMethodDecl *Getter = PDecl->getGetterMethodDecl())
685         ResultType = Getter->getResultType();
686       else
687         ResultType = PDecl->getType();
688     } else {
689       const ObjCMethodDecl *Getter = getImplicitPropertyGetter();
690       if (Getter)
691         ResultType = Getter->getResultType(); // with reference!
692     }
693     return ResultType;
694   }
695 
696   QualType getSetterArgType() const {
697     QualType ArgType;
698     if (isImplicitProperty()) {
699       const ObjCMethodDecl *Setter = getImplicitPropertySetter();
700       ObjCMethodDecl::param_const_iterator P = Setter->param_begin();
701       ArgType = (*P)->getType();
702     } else {
703       if (ObjCPropertyDecl *PDecl = getExplicitProperty())
704         if (const ObjCMethodDecl *Setter = PDecl->getSetterMethodDecl()) {
705           ObjCMethodDecl::param_const_iterator P = Setter->param_begin();
706           ArgType = (*P)->getType();
707         }
708       if (ArgType.isNull())
709         ArgType = getType();
710     }
711     return ArgType;
712   }
713 
714   ObjCInterfaceDecl *getClassReceiver() const {
715     return Receiver.get<ObjCInterfaceDecl*>();
716   }
717   bool isObjectReceiver() const { return Receiver.is<Stmt*>(); }
718   bool isSuperReceiver() const { return Receiver.is<const Type*>(); }
719   bool isClassReceiver() const { return Receiver.is<ObjCInterfaceDecl*>(); }
720 
721   SourceLocation getLocStart() const LLVM_READONLY {
722     return isObjectReceiver() ? getBase()->getLocStart() :getReceiverLocation();
723   }
724   SourceLocation getLocEnd() const LLVM_READONLY { return IdLoc; }
725 
726   static bool classof(const Stmt *T) {
727     return T->getStmtClass() == ObjCPropertyRefExprClass;
728   }
729 
730   // Iterators
731   child_range children() {
732     if (Receiver.is<Stmt*>()) {
733       Stmt **begin = reinterpret_cast<Stmt**>(&Receiver); // hack!
734       return child_range(begin, begin+1);
735     }
736     return child_range();
737   }
738 
739 private:
740   friend class ASTStmtReader;
741   friend class ASTStmtWriter;
742   void setExplicitProperty(ObjCPropertyDecl *D, unsigned methRefFlags) {
743     PropertyOrGetter.setPointer(D);
744     PropertyOrGetter.setInt(false);
745     SetterAndMethodRefFlags.setPointer(0);
746     SetterAndMethodRefFlags.setInt(methRefFlags);
747   }
748   void setImplicitProperty(ObjCMethodDecl *Getter, ObjCMethodDecl *Setter,
749                            unsigned methRefFlags) {
750     PropertyOrGetter.setPointer(Getter);
751     PropertyOrGetter.setInt(true);
752     SetterAndMethodRefFlags.setPointer(Setter);
753     SetterAndMethodRefFlags.setInt(methRefFlags);
754   }
755   void setBase(Expr *Base) { Receiver = Base; }
756   void setSuperReceiver(QualType T) { Receiver = T.getTypePtr(); }
757   void setClassReceiver(ObjCInterfaceDecl *D) { Receiver = D; }
758 
759   void setLocation(SourceLocation L) { IdLoc = L; }
760   void setReceiverLocation(SourceLocation Loc) { ReceiverLoc = Loc; }
761 
762   void setMethodRefFlag(MethodRefFlags flag, bool val) {
763     unsigned f = SetterAndMethodRefFlags.getInt();
764     if (val)
765       f |= flag;
766     else
767       f &= ~flag;
768     SetterAndMethodRefFlags.setInt(f);
769   }
770 };
771 
772 /// ObjCSubscriptRefExpr - used for array and dictionary subscripting.
773 /// array[4] = array[3]; dictionary[key] = dictionary[alt_key];
774 ///
775 class ObjCSubscriptRefExpr : public Expr {
776   // Location of ']' in an indexing expression.
777   SourceLocation RBracket;
778   // array/dictionary base expression.
779   // for arrays, this is a numeric expression. For dictionaries, this is
780   // an objective-c object pointer expression.
781   enum { BASE, KEY, END_EXPR };
782   Stmt* SubExprs[END_EXPR];
783 
784   ObjCMethodDecl *GetAtIndexMethodDecl;
785 
786   // For immutable objects this is null. When ObjCSubscriptRefExpr is to read
787   // an indexed object this is null too.
788   ObjCMethodDecl *SetAtIndexMethodDecl;
789 
790 public:
791 
792   ObjCSubscriptRefExpr(Expr *base, Expr *key, QualType T,
793                        ExprValueKind VK, ExprObjectKind OK,
794                        ObjCMethodDecl *getMethod,
795                        ObjCMethodDecl *setMethod, SourceLocation RB)
796     : Expr(ObjCSubscriptRefExprClass, T, VK, OK,
797            base->isTypeDependent() || key->isTypeDependent(),
798            base->isValueDependent() || key->isValueDependent(),
799            base->isInstantiationDependent() || key->isInstantiationDependent(),
800            (base->containsUnexpandedParameterPack() ||
801             key->containsUnexpandedParameterPack())),
802       RBracket(RB),
803   GetAtIndexMethodDecl(getMethod),
804   SetAtIndexMethodDecl(setMethod)
805     {SubExprs[BASE] = base; SubExprs[KEY] = key;}
806 
807   explicit ObjCSubscriptRefExpr(EmptyShell Empty)
808     : Expr(ObjCSubscriptRefExprClass, Empty) {}
809 
810   static ObjCSubscriptRefExpr *Create(ASTContext &C,
811                                       Expr *base,
812                                       Expr *key, QualType T,
813                                       ObjCMethodDecl *getMethod,
814                                       ObjCMethodDecl *setMethod,
815                                       SourceLocation RB);
816 
817   SourceLocation getRBracket() const { return RBracket; }
818   void setRBracket(SourceLocation RB) { RBracket = RB; }
819 
820   SourceLocation getLocStart() const LLVM_READONLY {
821     return SubExprs[BASE]->getLocStart();
822   }
823   SourceLocation getLocEnd() const LLVM_READONLY { return RBracket; }
824 
825   static bool classof(const Stmt *T) {
826     return T->getStmtClass() == ObjCSubscriptRefExprClass;
827   }
828 
829   Expr *getBaseExpr() const { return cast<Expr>(SubExprs[BASE]); }
830   void setBaseExpr(Stmt *S) { SubExprs[BASE] = S; }
831 
832   Expr *getKeyExpr() const { return cast<Expr>(SubExprs[KEY]); }
833   void setKeyExpr(Stmt *S) { SubExprs[KEY] = S; }
834 
835   ObjCMethodDecl *getAtIndexMethodDecl() const {
836     return GetAtIndexMethodDecl;
837   }
838 
839   ObjCMethodDecl *setAtIndexMethodDecl() const {
840     return SetAtIndexMethodDecl;
841   }
842 
843   bool isArraySubscriptRefExpr() const {
844     return getKeyExpr()->getType()->isIntegralOrEnumerationType();
845   }
846 
847   child_range children() {
848     return child_range(SubExprs, SubExprs+END_EXPR);
849   }
850 private:
851   friend class ASTStmtReader;
852 };
853 
854 
855 /// \brief An expression that sends a message to the given Objective-C
856 /// object or class.
857 ///
858 /// The following contains two message send expressions:
859 ///
860 /// \code
861 ///   [[NSString alloc] initWithString:@"Hello"]
862 /// \endcode
863 ///
864 /// The innermost message send invokes the "alloc" class method on the
865 /// NSString class, while the outermost message send invokes the
866 /// "initWithString" instance method on the object returned from
867 /// NSString's "alloc". In all, an Objective-C message send can take
868 /// on four different (although related) forms:
869 ///
870 ///   1. Send to an object instance.
871 ///   2. Send to a class.
872 ///   3. Send to the superclass instance of the current class.
873 ///   4. Send to the superclass of the current class.
874 ///
875 /// All four kinds of message sends are modeled by the ObjCMessageExpr
876 /// class, and can be distinguished via \c getReceiverKind(). Example:
877 ///
878 class ObjCMessageExpr : public Expr {
879   /// \brief Stores either the selector that this message is sending
880   /// to (when \c HasMethod is zero) or an \c ObjCMethodDecl pointer
881   /// referring to the method that we type-checked against.
882   uintptr_t SelectorOrMethod;
883 
884   enum { NumArgsBitWidth = 16 };
885 
886   /// \brief The number of arguments in the message send, not
887   /// including the receiver.
888   unsigned NumArgs : NumArgsBitWidth;
889 
890   void setNumArgs(unsigned Num) {
891     assert((Num >> NumArgsBitWidth) == 0 && "Num of args is out of range!");
892     NumArgs = Num;
893   }
894 
895   /// \brief The kind of message send this is, which is one of the
896   /// ReceiverKind values.
897   ///
898   /// We pad this out to a byte to avoid excessive masking and shifting.
899   unsigned Kind : 8;
900 
901   /// \brief Whether we have an actual method prototype in \c
902   /// SelectorOrMethod.
903   ///
904   /// When non-zero, we have a method declaration; otherwise, we just
905   /// have a selector.
906   unsigned HasMethod : 1;
907 
908   /// \brief Whether this message send is a "delegate init call",
909   /// i.e. a call of an init method on self from within an init method.
910   unsigned IsDelegateInitCall : 1;
911 
912   /// \brief Whether this message send was implicitly generated by
913   /// the implementation rather than explicitly written by the user.
914   unsigned IsImplicit : 1;
915 
916   /// \brief Whether the locations of the selector identifiers are in a
917   /// "standard" position, a enum SelectorLocationsKind.
918   unsigned SelLocsKind : 2;
919 
920   /// \brief When the message expression is a send to 'super', this is
921   /// the location of the 'super' keyword.
922   SourceLocation SuperLoc;
923 
924   /// \brief The source locations of the open and close square
925   /// brackets ('[' and ']', respectively).
926   SourceLocation LBracLoc, RBracLoc;
927 
928   ObjCMessageExpr(EmptyShell Empty, unsigned NumArgs)
929     : Expr(ObjCMessageExprClass, Empty), SelectorOrMethod(0), Kind(0),
930       HasMethod(0), IsDelegateInitCall(0), IsImplicit(0), SelLocsKind(0) {
931     setNumArgs(NumArgs);
932   }
933 
934   ObjCMessageExpr(QualType T, ExprValueKind VK,
935                   SourceLocation LBracLoc,
936                   SourceLocation SuperLoc,
937                   bool IsInstanceSuper,
938                   QualType SuperType,
939                   Selector Sel,
940                   ArrayRef<SourceLocation> SelLocs,
941                   SelectorLocationsKind SelLocsK,
942                   ObjCMethodDecl *Method,
943                   ArrayRef<Expr *> Args,
944                   SourceLocation RBracLoc,
945                   bool isImplicit);
946   ObjCMessageExpr(QualType T, ExprValueKind VK,
947                   SourceLocation LBracLoc,
948                   TypeSourceInfo *Receiver,
949                   Selector Sel,
950                   ArrayRef<SourceLocation> SelLocs,
951                   SelectorLocationsKind SelLocsK,
952                   ObjCMethodDecl *Method,
953                   ArrayRef<Expr *> Args,
954                   SourceLocation RBracLoc,
955                   bool isImplicit);
956   ObjCMessageExpr(QualType T, ExprValueKind VK,
957                   SourceLocation LBracLoc,
958                   Expr *Receiver,
959                   Selector Sel,
960                   ArrayRef<SourceLocation> SelLocs,
961                   SelectorLocationsKind SelLocsK,
962                   ObjCMethodDecl *Method,
963                   ArrayRef<Expr *> Args,
964                   SourceLocation RBracLoc,
965                   bool isImplicit);
966 
967   void initArgsAndSelLocs(ArrayRef<Expr *> Args,
968                           ArrayRef<SourceLocation> SelLocs,
969                           SelectorLocationsKind SelLocsK);
970 
971   /// \brief Retrieve the pointer value of the message receiver.
972   void *getReceiverPointer() const {
973     return *const_cast<void **>(
974                              reinterpret_cast<const void * const*>(this + 1));
975   }
976 
977   /// \brief Set the pointer value of the message receiver.
978   void setReceiverPointer(void *Value) {
979     *reinterpret_cast<void **>(this + 1) = Value;
980   }
981 
982   SelectorLocationsKind getSelLocsKind() const {
983     return (SelectorLocationsKind)SelLocsKind;
984   }
985   bool hasStandardSelLocs() const {
986     return getSelLocsKind() != SelLoc_NonStandard;
987   }
988 
989   /// \brief Get a pointer to the stored selector identifiers locations array.
990   /// No locations will be stored if HasStandardSelLocs is true.
991   SourceLocation *getStoredSelLocs() {
992     return reinterpret_cast<SourceLocation*>(getArgs() + getNumArgs());
993   }
994   const SourceLocation *getStoredSelLocs() const {
995     return reinterpret_cast<const SourceLocation*>(getArgs() + getNumArgs());
996   }
997 
998   /// \brief Get the number of stored selector identifiers locations.
999   /// No locations will be stored if HasStandardSelLocs is true.
1000   unsigned getNumStoredSelLocs() const {
1001     if (hasStandardSelLocs())
1002       return 0;
1003     return getNumSelectorLocs();
1004   }
1005 
1006   static ObjCMessageExpr *alloc(ASTContext &C,
1007                                 ArrayRef<Expr *> Args,
1008                                 SourceLocation RBraceLoc,
1009                                 ArrayRef<SourceLocation> SelLocs,
1010                                 Selector Sel,
1011                                 SelectorLocationsKind &SelLocsK);
1012   static ObjCMessageExpr *alloc(ASTContext &C,
1013                                 unsigned NumArgs,
1014                                 unsigned NumStoredSelLocs);
1015 
1016 public:
1017   /// \brief The kind of receiver this message is sending to.
1018   enum ReceiverKind {
1019     /// \brief The receiver is a class.
1020     Class = 0,
1021     /// \brief The receiver is an object instance.
1022     Instance,
1023     /// \brief The receiver is a superclass.
1024     SuperClass,
1025     /// \brief The receiver is the instance of the superclass object.
1026     SuperInstance
1027   };
1028 
1029   /// \brief Create a message send to super.
1030   ///
1031   /// \param Context The ASTContext in which this expression will be created.
1032   ///
1033   /// \param T The result type of this message.
1034   ///
1035   /// \param VK The value kind of this message.  A message returning
1036   /// a l-value or r-value reference will be an l-value or x-value,
1037   /// respectively.
1038   ///
1039   /// \param LBracLoc The location of the open square bracket '['.
1040   ///
1041   /// \param SuperLoc The location of the "super" keyword.
1042   ///
1043   /// \param IsInstanceSuper Whether this is an instance "super"
1044   /// message (otherwise, it's a class "super" message).
1045   ///
1046   /// \param Sel The selector used to determine which method gets called.
1047   ///
1048   /// \param Method The Objective-C method against which this message
1049   /// send was type-checked. May be NULL.
1050   ///
1051   /// \param Args The message send arguments.
1052   ///
1053   /// \param RBracLoc The location of the closing square bracket ']'.
1054   static ObjCMessageExpr *Create(ASTContext &Context, QualType T,
1055                                  ExprValueKind VK,
1056                                  SourceLocation LBracLoc,
1057                                  SourceLocation SuperLoc,
1058                                  bool IsInstanceSuper,
1059                                  QualType SuperType,
1060                                  Selector Sel,
1061                                  ArrayRef<SourceLocation> SelLocs,
1062                                  ObjCMethodDecl *Method,
1063                                  ArrayRef<Expr *> Args,
1064                                  SourceLocation RBracLoc,
1065                                  bool isImplicit);
1066 
1067   /// \brief Create a class message send.
1068   ///
1069   /// \param Context The ASTContext in which this expression will be created.
1070   ///
1071   /// \param T The result type of this message.
1072   ///
1073   /// \param VK The value kind of this message.  A message returning
1074   /// a l-value or r-value reference will be an l-value or x-value,
1075   /// respectively.
1076   ///
1077   /// \param LBracLoc The location of the open square bracket '['.
1078   ///
1079   /// \param Receiver The type of the receiver, including
1080   /// source-location information.
1081   ///
1082   /// \param Sel The selector used to determine which method gets called.
1083   ///
1084   /// \param Method The Objective-C method against which this message
1085   /// send was type-checked. May be NULL.
1086   ///
1087   /// \param Args The message send arguments.
1088   ///
1089   /// \param RBracLoc The location of the closing square bracket ']'.
1090   static ObjCMessageExpr *Create(ASTContext &Context, QualType T,
1091                                  ExprValueKind VK,
1092                                  SourceLocation LBracLoc,
1093                                  TypeSourceInfo *Receiver,
1094                                  Selector Sel,
1095                                  ArrayRef<SourceLocation> SelLocs,
1096                                  ObjCMethodDecl *Method,
1097                                  ArrayRef<Expr *> Args,
1098                                  SourceLocation RBracLoc,
1099                                  bool isImplicit);
1100 
1101   /// \brief Create an instance message send.
1102   ///
1103   /// \param Context The ASTContext in which this expression will be created.
1104   ///
1105   /// \param T The result type of this message.
1106   ///
1107   /// \param VK The value kind of this message.  A message returning
1108   /// a l-value or r-value reference will be an l-value or x-value,
1109   /// respectively.
1110   ///
1111   /// \param LBracLoc The location of the open square bracket '['.
1112   ///
1113   /// \param Receiver The expression used to produce the object that
1114   /// will receive this message.
1115   ///
1116   /// \param Sel The selector used to determine which method gets called.
1117   ///
1118   /// \param Method The Objective-C method against which this message
1119   /// send was type-checked. May be NULL.
1120   ///
1121   /// \param Args The message send arguments.
1122   ///
1123   /// \param RBracLoc The location of the closing square bracket ']'.
1124   static ObjCMessageExpr *Create(ASTContext &Context, QualType T,
1125                                  ExprValueKind VK,
1126                                  SourceLocation LBracLoc,
1127                                  Expr *Receiver,
1128                                  Selector Sel,
1129                                  ArrayRef<SourceLocation> SeLocs,
1130                                  ObjCMethodDecl *Method,
1131                                  ArrayRef<Expr *> Args,
1132                                  SourceLocation RBracLoc,
1133                                  bool isImplicit);
1134 
1135   /// \brief Create an empty Objective-C message expression, to be
1136   /// filled in by subsequent calls.
1137   ///
1138   /// \param Context The context in which the message send will be created.
1139   ///
1140   /// \param NumArgs The number of message arguments, not including
1141   /// the receiver.
1142   static ObjCMessageExpr *CreateEmpty(ASTContext &Context,
1143                                       unsigned NumArgs,
1144                                       unsigned NumStoredSelLocs);
1145 
1146   /// \brief Indicates whether the message send was implicitly
1147   /// generated by the implementation. If false, it was written explicitly
1148   /// in the source code.
1149   bool isImplicit() const { return IsImplicit; }
1150 
1151   /// \brief Determine the kind of receiver that this message is being
1152   /// sent to.
1153   ReceiverKind getReceiverKind() const { return (ReceiverKind)Kind; }
1154 
1155   /// \brief Source range of the receiver.
1156   SourceRange getReceiverRange() const;
1157 
1158   /// \brief Determine whether this is an instance message to either a
1159   /// computed object or to super.
1160   bool isInstanceMessage() const {
1161     return getReceiverKind() == Instance || getReceiverKind() == SuperInstance;
1162   }
1163 
1164   /// \brief Determine whether this is an class message to either a
1165   /// specified class or to super.
1166   bool isClassMessage() const {
1167     return getReceiverKind() == Class || getReceiverKind() == SuperClass;
1168   }
1169 
1170   /// \brief Returns the object expression (receiver) for an instance message,
1171   /// or null for a message that is not an instance message.
1172   Expr *getInstanceReceiver() {
1173     if (getReceiverKind() == Instance)
1174       return static_cast<Expr *>(getReceiverPointer());
1175 
1176     return 0;
1177   }
1178   const Expr *getInstanceReceiver() const {
1179     return const_cast<ObjCMessageExpr*>(this)->getInstanceReceiver();
1180   }
1181 
1182   /// \brief Turn this message send into an instance message that
1183   /// computes the receiver object with the given expression.
1184   void setInstanceReceiver(Expr *rec) {
1185     Kind = Instance;
1186     setReceiverPointer(rec);
1187   }
1188 
1189   /// \brief Returns the type of a class message send, or NULL if the
1190   /// message is not a class message.
1191   QualType getClassReceiver() const {
1192     if (TypeSourceInfo *TSInfo = getClassReceiverTypeInfo())
1193       return TSInfo->getType();
1194 
1195     return QualType();
1196   }
1197 
1198   /// \brief Returns a type-source information of a class message
1199   /// send, or NULL if the message is not a class message.
1200   TypeSourceInfo *getClassReceiverTypeInfo() const {
1201     if (getReceiverKind() == Class)
1202       return reinterpret_cast<TypeSourceInfo *>(getReceiverPointer());
1203     return 0;
1204   }
1205 
1206   void setClassReceiver(TypeSourceInfo *TSInfo) {
1207     Kind = Class;
1208     setReceiverPointer(TSInfo);
1209   }
1210 
1211   /// \brief Retrieve the location of the 'super' keyword for a class
1212   /// or instance message to 'super', otherwise an invalid source location.
1213   SourceLocation getSuperLoc() const {
1214     if (getReceiverKind() == SuperInstance || getReceiverKind() == SuperClass)
1215       return SuperLoc;
1216 
1217     return SourceLocation();
1218   }
1219 
1220   /// \brief Retrieve the receiver type to which this message is being directed.
1221   ///
1222   /// This routine cross-cuts all of the different kinds of message
1223   /// sends to determine what the underlying (statically known) type
1224   /// of the receiver will be; use \c getReceiverKind() to determine
1225   /// whether the message is a class or an instance method, whether it
1226   /// is a send to super or not, etc.
1227   ///
1228   /// \returns The type of the receiver.
1229   QualType getReceiverType() const;
1230 
1231   /// \brief Retrieve the Objective-C interface to which this message
1232   /// is being directed, if known.
1233   ///
1234   /// This routine cross-cuts all of the different kinds of message
1235   /// sends to determine what the underlying (statically known) type
1236   /// of the receiver will be; use \c getReceiverKind() to determine
1237   /// whether the message is a class or an instance method, whether it
1238   /// is a send to super or not, etc.
1239   ///
1240   /// \returns The Objective-C interface if known, otherwise NULL.
1241   ObjCInterfaceDecl *getReceiverInterface() const;
1242 
1243   /// \brief Retrieve the type referred to by 'super'.
1244   ///
1245   /// The returned type will either be an ObjCInterfaceType (for an
1246   /// class message to super) or an ObjCObjectPointerType that refers
1247   /// to a class (for an instance message to super);
1248   QualType getSuperType() const {
1249     if (getReceiverKind() == SuperInstance || getReceiverKind() == SuperClass)
1250       return QualType::getFromOpaquePtr(getReceiverPointer());
1251 
1252     return QualType();
1253   }
1254 
1255   void setSuper(SourceLocation Loc, QualType T, bool IsInstanceSuper) {
1256     Kind = IsInstanceSuper? SuperInstance : SuperClass;
1257     SuperLoc = Loc;
1258     setReceiverPointer(T.getAsOpaquePtr());
1259   }
1260 
1261   Selector getSelector() const;
1262 
1263   void setSelector(Selector S) {
1264     HasMethod = false;
1265     SelectorOrMethod = reinterpret_cast<uintptr_t>(S.getAsOpaquePtr());
1266   }
1267 
1268   const ObjCMethodDecl *getMethodDecl() const {
1269     if (HasMethod)
1270       return reinterpret_cast<const ObjCMethodDecl *>(SelectorOrMethod);
1271 
1272     return 0;
1273   }
1274 
1275   ObjCMethodDecl *getMethodDecl() {
1276     if (HasMethod)
1277       return reinterpret_cast<ObjCMethodDecl *>(SelectorOrMethod);
1278 
1279     return 0;
1280   }
1281 
1282   void setMethodDecl(ObjCMethodDecl *MD) {
1283     HasMethod = true;
1284     SelectorOrMethod = reinterpret_cast<uintptr_t>(MD);
1285   }
1286 
1287   ObjCMethodFamily getMethodFamily() const {
1288     if (HasMethod) return getMethodDecl()->getMethodFamily();
1289     return getSelector().getMethodFamily();
1290   }
1291 
1292   /// \brief Return the number of actual arguments in this message,
1293   /// not counting the receiver.
1294   unsigned getNumArgs() const { return NumArgs; }
1295 
1296   /// \brief Retrieve the arguments to this message, not including the
1297   /// receiver.
1298   Expr **getArgs() {
1299     return reinterpret_cast<Expr **>(this + 1) + 1;
1300   }
1301   const Expr * const *getArgs() const {
1302     return reinterpret_cast<const Expr * const *>(this + 1) + 1;
1303   }
1304 
1305   /// getArg - Return the specified argument.
1306   Expr *getArg(unsigned Arg) {
1307     assert(Arg < NumArgs && "Arg access out of range!");
1308     return cast<Expr>(getArgs()[Arg]);
1309   }
1310   const Expr *getArg(unsigned Arg) const {
1311     assert(Arg < NumArgs && "Arg access out of range!");
1312     return cast<Expr>(getArgs()[Arg]);
1313   }
1314   /// setArg - Set the specified argument.
1315   void setArg(unsigned Arg, Expr *ArgExpr) {
1316     assert(Arg < NumArgs && "Arg access out of range!");
1317     getArgs()[Arg] = ArgExpr;
1318   }
1319 
1320   /// isDelegateInitCall - Answers whether this message send has been
1321   /// tagged as a "delegate init call", i.e. a call to a method in the
1322   /// -init family on self from within an -init method implementation.
1323   bool isDelegateInitCall() const { return IsDelegateInitCall; }
1324   void setDelegateInitCall(bool isDelegate) { IsDelegateInitCall = isDelegate; }
1325 
1326   SourceLocation getLeftLoc() const { return LBracLoc; }
1327   SourceLocation getRightLoc() const { return RBracLoc; }
1328 
1329   SourceLocation getSelectorStartLoc() const {
1330     if (isImplicit())
1331       return getLocStart();
1332     return getSelectorLoc(0);
1333   }
1334   SourceLocation getSelectorLoc(unsigned Index) const {
1335     assert(Index < getNumSelectorLocs() && "Index out of range!");
1336     if (hasStandardSelLocs())
1337       return getStandardSelectorLoc(Index, getSelector(),
1338                                    getSelLocsKind() == SelLoc_StandardWithSpace,
1339                                llvm::makeArrayRef(const_cast<Expr**>(getArgs()),
1340                                                   getNumArgs()),
1341                                    RBracLoc);
1342     return getStoredSelLocs()[Index];
1343   }
1344 
1345   void getSelectorLocs(SmallVectorImpl<SourceLocation> &SelLocs) const;
1346 
1347   unsigned getNumSelectorLocs() const {
1348     if (isImplicit())
1349       return 0;
1350     Selector Sel = getSelector();
1351     if (Sel.isUnarySelector())
1352       return 1;
1353     return Sel.getNumArgs();
1354   }
1355 
1356   void setSourceRange(SourceRange R) {
1357     LBracLoc = R.getBegin();
1358     RBracLoc = R.getEnd();
1359   }
1360   SourceLocation getLocStart() const LLVM_READONLY { return LBracLoc; }
1361   SourceLocation getLocEnd() const LLVM_READONLY { return RBracLoc; }
1362 
1363   static bool classof(const Stmt *T) {
1364     return T->getStmtClass() == ObjCMessageExprClass;
1365   }
1366 
1367   // Iterators
1368   child_range children();
1369 
1370   typedef ExprIterator arg_iterator;
1371   typedef ConstExprIterator const_arg_iterator;
1372 
1373   arg_iterator arg_begin() { return reinterpret_cast<Stmt **>(getArgs()); }
1374   arg_iterator arg_end()   {
1375     return reinterpret_cast<Stmt **>(getArgs() + NumArgs);
1376   }
1377   const_arg_iterator arg_begin() const {
1378     return reinterpret_cast<Stmt const * const*>(getArgs());
1379   }
1380   const_arg_iterator arg_end() const {
1381     return reinterpret_cast<Stmt const * const*>(getArgs() + NumArgs);
1382   }
1383 
1384   friend class ASTStmtReader;
1385   friend class ASTStmtWriter;
1386 };
1387 
1388 /// ObjCIsaExpr - Represent X->isa and X.isa when X is an ObjC 'id' type.
1389 /// (similar in spirit to MemberExpr).
1390 class ObjCIsaExpr : public Expr {
1391   /// Base - the expression for the base object pointer.
1392   Stmt *Base;
1393 
1394   /// IsaMemberLoc - This is the location of the 'isa'.
1395   SourceLocation IsaMemberLoc;
1396 
1397   /// OpLoc - This is the location of '.' or '->'
1398   SourceLocation OpLoc;
1399 
1400   /// IsArrow - True if this is "X->F", false if this is "X.F".
1401   bool IsArrow;
1402 public:
1403   ObjCIsaExpr(Expr *base, bool isarrow, SourceLocation l, SourceLocation oploc,
1404               QualType ty)
1405     : Expr(ObjCIsaExprClass, ty, VK_LValue, OK_Ordinary,
1406            /*TypeDependent=*/false, base->isValueDependent(),
1407            base->isInstantiationDependent(),
1408            /*ContainsUnexpandedParameterPack=*/false),
1409       Base(base), IsaMemberLoc(l), OpLoc(oploc), IsArrow(isarrow) {}
1410 
1411   /// \brief Build an empty expression.
1412   explicit ObjCIsaExpr(EmptyShell Empty) : Expr(ObjCIsaExprClass, Empty) { }
1413 
1414   void setBase(Expr *E) { Base = E; }
1415   Expr *getBase() const { return cast<Expr>(Base); }
1416 
1417   bool isArrow() const { return IsArrow; }
1418   void setArrow(bool A) { IsArrow = A; }
1419 
1420   /// getMemberLoc - Return the location of the "member", in X->F, it is the
1421   /// location of 'F'.
1422   SourceLocation getIsaMemberLoc() const { return IsaMemberLoc; }
1423   void setIsaMemberLoc(SourceLocation L) { IsaMemberLoc = L; }
1424 
1425   SourceLocation getOpLoc() const { return OpLoc; }
1426   void setOpLoc(SourceLocation L) { OpLoc = L; }
1427 
1428   SourceLocation getLocStart() const LLVM_READONLY {
1429     return getBase()->getLocStart();
1430   }
1431 
1432   SourceLocation getBaseLocEnd() const LLVM_READONLY {
1433     return getBase()->getLocEnd();
1434   }
1435 
1436   SourceLocation getLocEnd() const LLVM_READONLY { return IsaMemberLoc; }
1437 
1438   SourceLocation getExprLoc() const LLVM_READONLY { return IsaMemberLoc; }
1439 
1440   static bool classof(const Stmt *T) {
1441     return T->getStmtClass() == ObjCIsaExprClass;
1442   }
1443 
1444   // Iterators
1445   child_range children() { return child_range(&Base, &Base+1); }
1446 };
1447 
1448 
1449 /// ObjCIndirectCopyRestoreExpr - Represents the passing of a function
1450 /// argument by indirect copy-restore in ARC.  This is used to support
1451 /// passing indirect arguments with the wrong lifetime, e.g. when
1452 /// passing the address of a __strong local variable to an 'out'
1453 /// parameter.  This expression kind is only valid in an "argument"
1454 /// position to some sort of call expression.
1455 ///
1456 /// The parameter must have type 'pointer to T', and the argument must
1457 /// have type 'pointer to U', where T and U agree except possibly in
1458 /// qualification.  If the argument value is null, then a null pointer
1459 /// is passed;  otherwise it points to an object A, and:
1460 /// 1. A temporary object B of type T is initialized, either by
1461 ///    zero-initialization (used when initializing an 'out' parameter)
1462 ///    or copy-initialization (used when initializing an 'inout'
1463 ///    parameter).
1464 /// 2. The address of the temporary is passed to the function.
1465 /// 3. If the call completes normally, A is move-assigned from B.
1466 /// 4. Finally, A is destroyed immediately.
1467 ///
1468 /// Currently 'T' must be a retainable object lifetime and must be
1469 /// __autoreleasing;  this qualifier is ignored when initializing
1470 /// the value.
1471 class ObjCIndirectCopyRestoreExpr : public Expr {
1472   Stmt *Operand;
1473 
1474   // unsigned ObjCIndirectCopyRestoreBits.ShouldCopy : 1;
1475 
1476   friend class ASTReader;
1477   friend class ASTStmtReader;
1478 
1479   void setShouldCopy(bool shouldCopy) {
1480     ObjCIndirectCopyRestoreExprBits.ShouldCopy = shouldCopy;
1481   }
1482 
1483   explicit ObjCIndirectCopyRestoreExpr(EmptyShell Empty)
1484     : Expr(ObjCIndirectCopyRestoreExprClass, Empty) { }
1485 
1486 public:
1487   ObjCIndirectCopyRestoreExpr(Expr *operand, QualType type, bool shouldCopy)
1488     : Expr(ObjCIndirectCopyRestoreExprClass, type, VK_LValue, OK_Ordinary,
1489            operand->isTypeDependent(), operand->isValueDependent(),
1490            operand->isInstantiationDependent(),
1491            operand->containsUnexpandedParameterPack()),
1492       Operand(operand) {
1493     setShouldCopy(shouldCopy);
1494   }
1495 
1496   Expr *getSubExpr() { return cast<Expr>(Operand); }
1497   const Expr *getSubExpr() const { return cast<Expr>(Operand); }
1498 
1499   /// shouldCopy - True if we should do the 'copy' part of the
1500   /// copy-restore.  If false, the temporary will be zero-initialized.
1501   bool shouldCopy() const { return ObjCIndirectCopyRestoreExprBits.ShouldCopy; }
1502 
1503   child_range children() { return child_range(&Operand, &Operand+1); }
1504 
1505   // Source locations are determined by the subexpression.
1506   SourceLocation getLocStart() const LLVM_READONLY {
1507     return Operand->getLocStart();
1508   }
1509   SourceLocation getLocEnd() const LLVM_READONLY { return Operand->getLocEnd();}
1510 
1511   SourceLocation getExprLoc() const LLVM_READONLY {
1512     return getSubExpr()->getExprLoc();
1513   }
1514 
1515   static bool classof(const Stmt *s) {
1516     return s->getStmtClass() == ObjCIndirectCopyRestoreExprClass;
1517   }
1518 };
1519 
1520 /// \brief An Objective-C "bridged" cast expression, which casts between
1521 /// Objective-C pointers and C pointers, transferring ownership in the process.
1522 ///
1523 /// \code
1524 /// NSString *str = (__bridge_transfer NSString *)CFCreateString();
1525 /// \endcode
1526 class ObjCBridgedCastExpr : public ExplicitCastExpr {
1527   SourceLocation LParenLoc;
1528   SourceLocation BridgeKeywordLoc;
1529   unsigned Kind : 2;
1530 
1531   friend class ASTStmtReader;
1532   friend class ASTStmtWriter;
1533 
1534 public:
1535   ObjCBridgedCastExpr(SourceLocation LParenLoc, ObjCBridgeCastKind Kind,
1536                       CastKind CK, SourceLocation BridgeKeywordLoc,
1537                       TypeSourceInfo *TSInfo, Expr *Operand)
1538     : ExplicitCastExpr(ObjCBridgedCastExprClass, TSInfo->getType(), VK_RValue,
1539                        CK, Operand, 0, TSInfo),
1540       LParenLoc(LParenLoc), BridgeKeywordLoc(BridgeKeywordLoc), Kind(Kind) { }
1541 
1542   /// \brief Construct an empty Objective-C bridged cast.
1543   explicit ObjCBridgedCastExpr(EmptyShell Shell)
1544     : ExplicitCastExpr(ObjCBridgedCastExprClass, Shell, 0) { }
1545 
1546   SourceLocation getLParenLoc() const { return LParenLoc; }
1547 
1548   /// \brief Determine which kind of bridge is being performed via this cast.
1549   ObjCBridgeCastKind getBridgeKind() const {
1550     return static_cast<ObjCBridgeCastKind>(Kind);
1551   }
1552 
1553   /// \brief Retrieve the kind of bridge being performed as a string.
1554   StringRef getBridgeKindName() const;
1555 
1556   /// \brief The location of the bridge keyword.
1557   SourceLocation getBridgeKeywordLoc() const { return BridgeKeywordLoc; }
1558 
1559   SourceLocation getLocStart() const LLVM_READONLY { return LParenLoc; }
1560   SourceLocation getLocEnd() const LLVM_READONLY {
1561     return getSubExpr()->getLocEnd();
1562   }
1563 
1564   static bool classof(const Stmt *T) {
1565     return T->getStmtClass() == ObjCBridgedCastExprClass;
1566   }
1567 };
1568 
1569 }  // end namespace clang
1570 
1571 #endif
1572