Home | History | Annotate | Download | only in Sema
      1 //===--- SemaExprObjC.cpp - Semantic Analysis for ObjC Expressions --------===//
      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 semantic analysis for Objective-C expressions.
     11 //
     12 //===----------------------------------------------------------------------===//
     13 
     14 #include "clang/Sema/SemaInternal.h"
     15 #include "clang/AST/ASTContext.h"
     16 #include "clang/AST/DeclObjC.h"
     17 #include "clang/AST/ExprObjC.h"
     18 #include "clang/AST/StmtVisitor.h"
     19 #include "clang/AST/TypeLoc.h"
     20 #include "clang/Analysis/DomainSpecific/CocoaConventions.h"
     21 #include "clang/Edit/Commit.h"
     22 #include "clang/Edit/Rewriters.h"
     23 #include "clang/Lex/Preprocessor.h"
     24 #include "clang/Sema/Initialization.h"
     25 #include "clang/Sema/Lookup.h"
     26 #include "clang/Sema/Scope.h"
     27 #include "clang/Sema/ScopeInfo.h"
     28 #include "llvm/ADT/SmallString.h"
     29 
     30 using namespace clang;
     31 using namespace sema;
     32 using llvm::makeArrayRef;
     33 
     34 ExprResult Sema::ParseObjCStringLiteral(SourceLocation *AtLocs,
     35                                         Expr **strings,
     36                                         unsigned NumStrings) {
     37   StringLiteral **Strings = reinterpret_cast<StringLiteral**>(strings);
     38 
     39   // Most ObjC strings are formed out of a single piece.  However, we *can*
     40   // have strings formed out of multiple @ strings with multiple pptokens in
     41   // each one, e.g. @"foo" "bar" @"baz" "qux"   which need to be turned into one
     42   // StringLiteral for ObjCStringLiteral to hold onto.
     43   StringLiteral *S = Strings[0];
     44 
     45   // If we have a multi-part string, merge it all together.
     46   if (NumStrings != 1) {
     47     // Concatenate objc strings.
     48     SmallString<128> StrBuf;
     49     SmallVector<SourceLocation, 8> StrLocs;
     50 
     51     for (unsigned i = 0; i != NumStrings; ++i) {
     52       S = Strings[i];
     53 
     54       // ObjC strings can't be wide or UTF.
     55       if (!S->isAscii()) {
     56         Diag(S->getLocStart(), diag::err_cfstring_literal_not_string_constant)
     57           << S->getSourceRange();
     58         return true;
     59       }
     60 
     61       // Append the string.
     62       StrBuf += S->getString();
     63 
     64       // Get the locations of the string tokens.
     65       StrLocs.append(S->tokloc_begin(), S->tokloc_end());
     66     }
     67 
     68     // Create the aggregate string with the appropriate content and location
     69     // information.
     70     const ConstantArrayType *CAT = Context.getAsConstantArrayType(S->getType());
     71     assert(CAT && "String literal not of constant array type!");
     72     QualType StrTy = Context.getConstantArrayType(
     73         CAT->getElementType(), llvm::APInt(32, StrBuf.size() + 1),
     74         CAT->getSizeModifier(), CAT->getIndexTypeCVRQualifiers());
     75     S = StringLiteral::Create(Context, StrBuf, StringLiteral::Ascii,
     76                               /*Pascal=*/false, StrTy, &StrLocs[0],
     77                               StrLocs.size());
     78   }
     79 
     80   return BuildObjCStringLiteral(AtLocs[0], S);
     81 }
     82 
     83 ExprResult Sema::BuildObjCStringLiteral(SourceLocation AtLoc, StringLiteral *S){
     84   // Verify that this composite string is acceptable for ObjC strings.
     85   if (CheckObjCString(S))
     86     return true;
     87 
     88   // Initialize the constant string interface lazily. This assumes
     89   // the NSString interface is seen in this translation unit. Note: We
     90   // don't use NSConstantString, since the runtime team considers this
     91   // interface private (even though it appears in the header files).
     92   QualType Ty = Context.getObjCConstantStringInterface();
     93   if (!Ty.isNull()) {
     94     Ty = Context.getObjCObjectPointerType(Ty);
     95   } else if (getLangOpts().NoConstantCFStrings) {
     96     IdentifierInfo *NSIdent=nullptr;
     97     std::string StringClass(getLangOpts().ObjCConstantStringClass);
     98 
     99     if (StringClass.empty())
    100       NSIdent = &Context.Idents.get("NSConstantString");
    101     else
    102       NSIdent = &Context.Idents.get(StringClass);
    103 
    104     NamedDecl *IF = LookupSingleName(TUScope, NSIdent, AtLoc,
    105                                      LookupOrdinaryName);
    106     if (ObjCInterfaceDecl *StrIF = dyn_cast_or_null<ObjCInterfaceDecl>(IF)) {
    107       Context.setObjCConstantStringInterface(StrIF);
    108       Ty = Context.getObjCConstantStringInterface();
    109       Ty = Context.getObjCObjectPointerType(Ty);
    110     } else {
    111       // If there is no NSConstantString interface defined then treat this
    112       // as error and recover from it.
    113       Diag(S->getLocStart(), diag::err_no_nsconstant_string_class) << NSIdent
    114         << S->getSourceRange();
    115       Ty = Context.getObjCIdType();
    116     }
    117   } else {
    118     IdentifierInfo *NSIdent = NSAPIObj->getNSClassId(NSAPI::ClassId_NSString);
    119     NamedDecl *IF = LookupSingleName(TUScope, NSIdent, AtLoc,
    120                                      LookupOrdinaryName);
    121     if (ObjCInterfaceDecl *StrIF = dyn_cast_or_null<ObjCInterfaceDecl>(IF)) {
    122       Context.setObjCConstantStringInterface(StrIF);
    123       Ty = Context.getObjCConstantStringInterface();
    124       Ty = Context.getObjCObjectPointerType(Ty);
    125     } else {
    126       // If there is no NSString interface defined, implicitly declare
    127       // a @class NSString; and use that instead. This is to make sure
    128       // type of an NSString literal is represented correctly, instead of
    129       // being an 'id' type.
    130       Ty = Context.getObjCNSStringType();
    131       if (Ty.isNull()) {
    132         ObjCInterfaceDecl *NSStringIDecl =
    133           ObjCInterfaceDecl::Create (Context,
    134                                      Context.getTranslationUnitDecl(),
    135                                      SourceLocation(), NSIdent,
    136                                      nullptr, SourceLocation());
    137         Ty = Context.getObjCInterfaceType(NSStringIDecl);
    138         Context.setObjCNSStringType(Ty);
    139       }
    140       Ty = Context.getObjCObjectPointerType(Ty);
    141     }
    142   }
    143 
    144   return new (Context) ObjCStringLiteral(S, Ty, AtLoc);
    145 }
    146 
    147 /// \brief Emits an error if the given method does not exist, or if the return
    148 /// type is not an Objective-C object.
    149 static bool validateBoxingMethod(Sema &S, SourceLocation Loc,
    150                                  const ObjCInterfaceDecl *Class,
    151                                  Selector Sel, const ObjCMethodDecl *Method) {
    152   if (!Method) {
    153     // FIXME: Is there a better way to avoid quotes than using getName()?
    154     S.Diag(Loc, diag::err_undeclared_boxing_method) << Sel << Class->getName();
    155     return false;
    156   }
    157 
    158   // Make sure the return type is reasonable.
    159   QualType ReturnType = Method->getReturnType();
    160   if (!ReturnType->isObjCObjectPointerType()) {
    161     S.Diag(Loc, diag::err_objc_literal_method_sig)
    162       << Sel;
    163     S.Diag(Method->getLocation(), diag::note_objc_literal_method_return)
    164       << ReturnType;
    165     return false;
    166   }
    167 
    168   return true;
    169 }
    170 
    171 /// \brief Retrieve the NSNumber factory method that should be used to create
    172 /// an Objective-C literal for the given type.
    173 static ObjCMethodDecl *getNSNumberFactoryMethod(Sema &S, SourceLocation Loc,
    174                                                 QualType NumberType,
    175                                                 bool isLiteral = false,
    176                                                 SourceRange R = SourceRange()) {
    177   Optional<NSAPI::NSNumberLiteralMethodKind> Kind =
    178       S.NSAPIObj->getNSNumberFactoryMethodKind(NumberType);
    179 
    180   if (!Kind) {
    181     if (isLiteral) {
    182       S.Diag(Loc, diag::err_invalid_nsnumber_type)
    183         << NumberType << R;
    184     }
    185     return nullptr;
    186   }
    187 
    188   // If we already looked up this method, we're done.
    189   if (S.NSNumberLiteralMethods[*Kind])
    190     return S.NSNumberLiteralMethods[*Kind];
    191 
    192   Selector Sel = S.NSAPIObj->getNSNumberLiteralSelector(*Kind,
    193                                                         /*Instance=*/false);
    194 
    195   ASTContext &CX = S.Context;
    196 
    197   // Look up the NSNumber class, if we haven't done so already. It's cached
    198   // in the Sema instance.
    199   if (!S.NSNumberDecl) {
    200     IdentifierInfo *NSNumberId =
    201       S.NSAPIObj->getNSClassId(NSAPI::ClassId_NSNumber);
    202     NamedDecl *IF = S.LookupSingleName(S.TUScope, NSNumberId,
    203                                        Loc, Sema::LookupOrdinaryName);
    204     S.NSNumberDecl = dyn_cast_or_null<ObjCInterfaceDecl>(IF);
    205     if (!S.NSNumberDecl) {
    206       if (S.getLangOpts().DebuggerObjCLiteral) {
    207         // Create a stub definition of NSNumber.
    208         S.NSNumberDecl = ObjCInterfaceDecl::Create(CX,
    209                                                    CX.getTranslationUnitDecl(),
    210                                                    SourceLocation(), NSNumberId,
    211                                                    nullptr, SourceLocation());
    212       } else {
    213         // Otherwise, require a declaration of NSNumber.
    214         S.Diag(Loc, diag::err_undeclared_nsnumber);
    215         return nullptr;
    216       }
    217     } else if (!S.NSNumberDecl->hasDefinition()) {
    218       S.Diag(Loc, diag::err_undeclared_nsnumber);
    219       return nullptr;
    220     }
    221 
    222     // generate the pointer to NSNumber type.
    223     QualType NSNumberObject = CX.getObjCInterfaceType(S.NSNumberDecl);
    224     S.NSNumberPointer = CX.getObjCObjectPointerType(NSNumberObject);
    225   }
    226 
    227   // Look for the appropriate method within NSNumber.
    228   ObjCMethodDecl *Method = S.NSNumberDecl->lookupClassMethod(Sel);
    229   if (!Method && S.getLangOpts().DebuggerObjCLiteral) {
    230     // create a stub definition this NSNumber factory method.
    231     TypeSourceInfo *ReturnTInfo = nullptr;
    232     Method =
    233         ObjCMethodDecl::Create(CX, SourceLocation(), SourceLocation(), Sel,
    234                                S.NSNumberPointer, ReturnTInfo, S.NSNumberDecl,
    235                                /*isInstance=*/false, /*isVariadic=*/false,
    236                                /*isPropertyAccessor=*/false,
    237                                /*isImplicitlyDeclared=*/true,
    238                                /*isDefined=*/false, ObjCMethodDecl::Required,
    239                                /*HasRelatedResultType=*/false);
    240     ParmVarDecl *value = ParmVarDecl::Create(S.Context, Method,
    241                                              SourceLocation(), SourceLocation(),
    242                                              &CX.Idents.get("value"),
    243                                              NumberType, /*TInfo=*/nullptr,
    244                                              SC_None, nullptr);
    245     Method->setMethodParams(S.Context, value, None);
    246   }
    247 
    248   if (!validateBoxingMethod(S, Loc, S.NSNumberDecl, Sel, Method))
    249     return nullptr;
    250 
    251   // Note: if the parameter type is out-of-line, we'll catch it later in the
    252   // implicit conversion.
    253 
    254   S.NSNumberLiteralMethods[*Kind] = Method;
    255   return Method;
    256 }
    257 
    258 /// BuildObjCNumericLiteral - builds an ObjCBoxedExpr AST node for the
    259 /// numeric literal expression. Type of the expression will be "NSNumber *".
    260 ExprResult Sema::BuildObjCNumericLiteral(SourceLocation AtLoc, Expr *Number) {
    261   // Determine the type of the literal.
    262   QualType NumberType = Number->getType();
    263   if (CharacterLiteral *Char = dyn_cast<CharacterLiteral>(Number)) {
    264     // In C, character literals have type 'int'. That's not the type we want
    265     // to use to determine the Objective-c literal kind.
    266     switch (Char->getKind()) {
    267     case CharacterLiteral::Ascii:
    268       NumberType = Context.CharTy;
    269       break;
    270 
    271     case CharacterLiteral::Wide:
    272       NumberType = Context.getWideCharType();
    273       break;
    274 
    275     case CharacterLiteral::UTF16:
    276       NumberType = Context.Char16Ty;
    277       break;
    278 
    279     case CharacterLiteral::UTF32:
    280       NumberType = Context.Char32Ty;
    281       break;
    282     }
    283   }
    284 
    285   // Look for the appropriate method within NSNumber.
    286   // Construct the literal.
    287   SourceRange NR(Number->getSourceRange());
    288   ObjCMethodDecl *Method = getNSNumberFactoryMethod(*this, AtLoc, NumberType,
    289                                                     true, NR);
    290   if (!Method)
    291     return ExprError();
    292 
    293   // Convert the number to the type that the parameter expects.
    294   ParmVarDecl *ParamDecl = Method->parameters()[0];
    295   InitializedEntity Entity = InitializedEntity::InitializeParameter(Context,
    296                                                                     ParamDecl);
    297   ExprResult ConvertedNumber = PerformCopyInitialization(Entity,
    298                                                          SourceLocation(),
    299                                                          Number);
    300   if (ConvertedNumber.isInvalid())
    301     return ExprError();
    302   Number = ConvertedNumber.get();
    303 
    304   // Use the effective source range of the literal, including the leading '@'.
    305   return MaybeBindToTemporary(
    306            new (Context) ObjCBoxedExpr(Number, NSNumberPointer, Method,
    307                                        SourceRange(AtLoc, NR.getEnd())));
    308 }
    309 
    310 ExprResult Sema::ActOnObjCBoolLiteral(SourceLocation AtLoc,
    311                                       SourceLocation ValueLoc,
    312                                       bool Value) {
    313   ExprResult Inner;
    314   if (getLangOpts().CPlusPlus) {
    315     Inner = ActOnCXXBoolLiteral(ValueLoc, Value? tok::kw_true : tok::kw_false);
    316   } else {
    317     // C doesn't actually have a way to represent literal values of type
    318     // _Bool. So, we'll use 0/1 and implicit cast to _Bool.
    319     Inner = ActOnIntegerConstant(ValueLoc, Value? 1 : 0);
    320     Inner = ImpCastExprToType(Inner.get(), Context.BoolTy,
    321                               CK_IntegralToBoolean);
    322   }
    323 
    324   return BuildObjCNumericLiteral(AtLoc, Inner.get());
    325 }
    326 
    327 /// \brief Check that the given expression is a valid element of an Objective-C
    328 /// collection literal.
    329 static ExprResult CheckObjCCollectionLiteralElement(Sema &S, Expr *Element,
    330                                                     QualType T,
    331                                                     bool ArrayLiteral = false) {
    332   // If the expression is type-dependent, there's nothing for us to do.
    333   if (Element->isTypeDependent())
    334     return Element;
    335 
    336   ExprResult Result = S.CheckPlaceholderExpr(Element);
    337   if (Result.isInvalid())
    338     return ExprError();
    339   Element = Result.get();
    340 
    341   // In C++, check for an implicit conversion to an Objective-C object pointer
    342   // type.
    343   if (S.getLangOpts().CPlusPlus && Element->getType()->isRecordType()) {
    344     InitializedEntity Entity
    345       = InitializedEntity::InitializeParameter(S.Context, T,
    346                                                /*Consumed=*/false);
    347     InitializationKind Kind
    348       = InitializationKind::CreateCopy(Element->getLocStart(),
    349                                        SourceLocation());
    350     InitializationSequence Seq(S, Entity, Kind, Element);
    351     if (!Seq.Failed())
    352       return Seq.Perform(S, Entity, Kind, Element);
    353   }
    354 
    355   Expr *OrigElement = Element;
    356 
    357   // Perform lvalue-to-rvalue conversion.
    358   Result = S.DefaultLvalueConversion(Element);
    359   if (Result.isInvalid())
    360     return ExprError();
    361   Element = Result.get();
    362 
    363   // Make sure that we have an Objective-C pointer type or block.
    364   if (!Element->getType()->isObjCObjectPointerType() &&
    365       !Element->getType()->isBlockPointerType()) {
    366     bool Recovered = false;
    367 
    368     // If this is potentially an Objective-C numeric literal, add the '@'.
    369     if (isa<IntegerLiteral>(OrigElement) ||
    370         isa<CharacterLiteral>(OrigElement) ||
    371         isa<FloatingLiteral>(OrigElement) ||
    372         isa<ObjCBoolLiteralExpr>(OrigElement) ||
    373         isa<CXXBoolLiteralExpr>(OrigElement)) {
    374       if (S.NSAPIObj->getNSNumberFactoryMethodKind(OrigElement->getType())) {
    375         int Which = isa<CharacterLiteral>(OrigElement) ? 1
    376                   : (isa<CXXBoolLiteralExpr>(OrigElement) ||
    377                      isa<ObjCBoolLiteralExpr>(OrigElement)) ? 2
    378                   : 3;
    379 
    380         S.Diag(OrigElement->getLocStart(), diag::err_box_literal_collection)
    381           << Which << OrigElement->getSourceRange()
    382           << FixItHint::CreateInsertion(OrigElement->getLocStart(), "@");
    383 
    384         Result = S.BuildObjCNumericLiteral(OrigElement->getLocStart(),
    385                                            OrigElement);
    386         if (Result.isInvalid())
    387           return ExprError();
    388 
    389         Element = Result.get();
    390         Recovered = true;
    391       }
    392     }
    393     // If this is potentially an Objective-C string literal, add the '@'.
    394     else if (StringLiteral *String = dyn_cast<StringLiteral>(OrigElement)) {
    395       if (String->isAscii()) {
    396         S.Diag(OrigElement->getLocStart(), diag::err_box_literal_collection)
    397           << 0 << OrigElement->getSourceRange()
    398           << FixItHint::CreateInsertion(OrigElement->getLocStart(), "@");
    399 
    400         Result = S.BuildObjCStringLiteral(OrigElement->getLocStart(), String);
    401         if (Result.isInvalid())
    402           return ExprError();
    403 
    404         Element = Result.get();
    405         Recovered = true;
    406       }
    407     }
    408 
    409     if (!Recovered) {
    410       S.Diag(Element->getLocStart(), diag::err_invalid_collection_element)
    411         << Element->getType();
    412       return ExprError();
    413     }
    414   }
    415   if (ArrayLiteral)
    416     if (ObjCStringLiteral *getString =
    417           dyn_cast<ObjCStringLiteral>(OrigElement)) {
    418       if (StringLiteral *SL = getString->getString()) {
    419         unsigned numConcat = SL->getNumConcatenated();
    420         if (numConcat > 1) {
    421           // Only warn if the concatenated string doesn't come from a macro.
    422           bool hasMacro = false;
    423           for (unsigned i = 0; i < numConcat ; ++i)
    424             if (SL->getStrTokenLoc(i).isMacroID()) {
    425               hasMacro = true;
    426               break;
    427             }
    428           if (!hasMacro)
    429             S.Diag(Element->getLocStart(),
    430                    diag::warn_concatenated_nsarray_literal)
    431               << Element->getType();
    432         }
    433       }
    434     }
    435 
    436   // Make sure that the element has the type that the container factory
    437   // function expects.
    438   return S.PerformCopyInitialization(
    439            InitializedEntity::InitializeParameter(S.Context, T,
    440                                                   /*Consumed=*/false),
    441            Element->getLocStart(), Element);
    442 }
    443 
    444 ExprResult Sema::BuildObjCBoxedExpr(SourceRange SR, Expr *ValueExpr) {
    445   if (ValueExpr->isTypeDependent()) {
    446     ObjCBoxedExpr *BoxedExpr =
    447       new (Context) ObjCBoxedExpr(ValueExpr, Context.DependentTy, nullptr, SR);
    448     return BoxedExpr;
    449   }
    450   ObjCMethodDecl *BoxingMethod = nullptr;
    451   QualType BoxedType;
    452   // Convert the expression to an RValue, so we can check for pointer types...
    453   ExprResult RValue = DefaultFunctionArrayLvalueConversion(ValueExpr);
    454   if (RValue.isInvalid()) {
    455     return ExprError();
    456   }
    457   ValueExpr = RValue.get();
    458   QualType ValueType(ValueExpr->getType());
    459   if (const PointerType *PT = ValueType->getAs<PointerType>()) {
    460     QualType PointeeType = PT->getPointeeType();
    461     if (Context.hasSameUnqualifiedType(PointeeType, Context.CharTy)) {
    462 
    463       if (!NSStringDecl) {
    464         IdentifierInfo *NSStringId =
    465           NSAPIObj->getNSClassId(NSAPI::ClassId_NSString);
    466         NamedDecl *Decl = LookupSingleName(TUScope, NSStringId,
    467                                            SR.getBegin(), LookupOrdinaryName);
    468         NSStringDecl = dyn_cast_or_null<ObjCInterfaceDecl>(Decl);
    469         if (!NSStringDecl) {
    470           if (getLangOpts().DebuggerObjCLiteral) {
    471             // Support boxed expressions in the debugger w/o NSString declaration.
    472             DeclContext *TU = Context.getTranslationUnitDecl();
    473             NSStringDecl = ObjCInterfaceDecl::Create(Context, TU,
    474                                                      SourceLocation(),
    475                                                      NSStringId,
    476                                                      nullptr, SourceLocation());
    477           } else {
    478             Diag(SR.getBegin(), diag::err_undeclared_nsstring);
    479             return ExprError();
    480           }
    481         } else if (!NSStringDecl->hasDefinition()) {
    482           Diag(SR.getBegin(), diag::err_undeclared_nsstring);
    483           return ExprError();
    484         }
    485         assert(NSStringDecl && "NSStringDecl should not be NULL");
    486         QualType NSStringObject = Context.getObjCInterfaceType(NSStringDecl);
    487         NSStringPointer = Context.getObjCObjectPointerType(NSStringObject);
    488       }
    489 
    490       if (!StringWithUTF8StringMethod) {
    491         IdentifierInfo *II = &Context.Idents.get("stringWithUTF8String");
    492         Selector stringWithUTF8String = Context.Selectors.getUnarySelector(II);
    493 
    494         // Look for the appropriate method within NSString.
    495         BoxingMethod = NSStringDecl->lookupClassMethod(stringWithUTF8String);
    496         if (!BoxingMethod && getLangOpts().DebuggerObjCLiteral) {
    497           // Debugger needs to work even if NSString hasn't been defined.
    498           TypeSourceInfo *ReturnTInfo = nullptr;
    499           ObjCMethodDecl *M = ObjCMethodDecl::Create(
    500               Context, SourceLocation(), SourceLocation(), stringWithUTF8String,
    501               NSStringPointer, ReturnTInfo, NSStringDecl,
    502               /*isInstance=*/false, /*isVariadic=*/false,
    503               /*isPropertyAccessor=*/false,
    504               /*isImplicitlyDeclared=*/true,
    505               /*isDefined=*/false, ObjCMethodDecl::Required,
    506               /*HasRelatedResultType=*/false);
    507           QualType ConstCharType = Context.CharTy.withConst();
    508           ParmVarDecl *value =
    509             ParmVarDecl::Create(Context, M,
    510                                 SourceLocation(), SourceLocation(),
    511                                 &Context.Idents.get("value"),
    512                                 Context.getPointerType(ConstCharType),
    513                                 /*TInfo=*/nullptr,
    514                                 SC_None, nullptr);
    515           M->setMethodParams(Context, value, None);
    516           BoxingMethod = M;
    517         }
    518 
    519         if (!validateBoxingMethod(*this, SR.getBegin(), NSStringDecl,
    520                                   stringWithUTF8String, BoxingMethod))
    521            return ExprError();
    522 
    523         StringWithUTF8StringMethod = BoxingMethod;
    524       }
    525 
    526       BoxingMethod = StringWithUTF8StringMethod;
    527       BoxedType = NSStringPointer;
    528     }
    529   } else if (ValueType->isBuiltinType()) {
    530     // The other types we support are numeric, char and BOOL/bool. We could also
    531     // provide limited support for structure types, such as NSRange, NSRect, and
    532     // NSSize. See NSValue (NSValueGeometryExtensions) in <Foundation/NSGeometry.h>
    533     // for more details.
    534 
    535     // Check for a top-level character literal.
    536     if (const CharacterLiteral *Char =
    537         dyn_cast<CharacterLiteral>(ValueExpr->IgnoreParens())) {
    538       // In C, character literals have type 'int'. That's not the type we want
    539       // to use to determine the Objective-c literal kind.
    540       switch (Char->getKind()) {
    541       case CharacterLiteral::Ascii:
    542         ValueType = Context.CharTy;
    543         break;
    544 
    545       case CharacterLiteral::Wide:
    546         ValueType = Context.getWideCharType();
    547         break;
    548 
    549       case CharacterLiteral::UTF16:
    550         ValueType = Context.Char16Ty;
    551         break;
    552 
    553       case CharacterLiteral::UTF32:
    554         ValueType = Context.Char32Ty;
    555         break;
    556       }
    557     }
    558     CheckForIntOverflow(ValueExpr);
    559     // FIXME:  Do I need to do anything special with BoolTy expressions?
    560 
    561     // Look for the appropriate method within NSNumber.
    562     BoxingMethod = getNSNumberFactoryMethod(*this, SR.getBegin(), ValueType);
    563     BoxedType = NSNumberPointer;
    564 
    565   } else if (const EnumType *ET = ValueType->getAs<EnumType>()) {
    566     if (!ET->getDecl()->isComplete()) {
    567       Diag(SR.getBegin(), diag::err_objc_incomplete_boxed_expression_type)
    568         << ValueType << ValueExpr->getSourceRange();
    569       return ExprError();
    570     }
    571 
    572     BoxingMethod = getNSNumberFactoryMethod(*this, SR.getBegin(),
    573                                             ET->getDecl()->getIntegerType());
    574     BoxedType = NSNumberPointer;
    575   }
    576 
    577   if (!BoxingMethod) {
    578     Diag(SR.getBegin(), diag::err_objc_illegal_boxed_expression_type)
    579       << ValueType << ValueExpr->getSourceRange();
    580     return ExprError();
    581   }
    582 
    583   // Convert the expression to the type that the parameter requires.
    584   ParmVarDecl *ParamDecl = BoxingMethod->parameters()[0];
    585   InitializedEntity Entity = InitializedEntity::InitializeParameter(Context,
    586                                                                     ParamDecl);
    587   ExprResult ConvertedValueExpr = PerformCopyInitialization(Entity,
    588                                                             SourceLocation(),
    589                                                             ValueExpr);
    590   if (ConvertedValueExpr.isInvalid())
    591     return ExprError();
    592   ValueExpr = ConvertedValueExpr.get();
    593 
    594   ObjCBoxedExpr *BoxedExpr =
    595     new (Context) ObjCBoxedExpr(ValueExpr, BoxedType,
    596                                       BoxingMethod, SR);
    597   return MaybeBindToTemporary(BoxedExpr);
    598 }
    599 
    600 /// Build an ObjC subscript pseudo-object expression, given that
    601 /// that's supported by the runtime.
    602 ExprResult Sema::BuildObjCSubscriptExpression(SourceLocation RB, Expr *BaseExpr,
    603                                         Expr *IndexExpr,
    604                                         ObjCMethodDecl *getterMethod,
    605                                         ObjCMethodDecl *setterMethod) {
    606   assert(!LangOpts.isSubscriptPointerArithmetic());
    607 
    608   // We can't get dependent types here; our callers should have
    609   // filtered them out.
    610   assert((!BaseExpr->isTypeDependent() && !IndexExpr->isTypeDependent()) &&
    611          "base or index cannot have dependent type here");
    612 
    613   // Filter out placeholders in the index.  In theory, overloads could
    614   // be preserved here, although that might not actually work correctly.
    615   ExprResult Result = CheckPlaceholderExpr(IndexExpr);
    616   if (Result.isInvalid())
    617     return ExprError();
    618   IndexExpr = Result.get();
    619 
    620   // Perform lvalue-to-rvalue conversion on the base.
    621   Result = DefaultLvalueConversion(BaseExpr);
    622   if (Result.isInvalid())
    623     return ExprError();
    624   BaseExpr = Result.get();
    625 
    626   // Build the pseudo-object expression.
    627   return ObjCSubscriptRefExpr::Create(Context, BaseExpr, IndexExpr,
    628                                       Context.PseudoObjectTy, getterMethod,
    629                                       setterMethod, RB);
    630 }
    631 
    632 ExprResult Sema::BuildObjCArrayLiteral(SourceRange SR, MultiExprArg Elements) {
    633   // Look up the NSArray class, if we haven't done so already.
    634   if (!NSArrayDecl) {
    635     NamedDecl *IF = LookupSingleName(TUScope,
    636                                  NSAPIObj->getNSClassId(NSAPI::ClassId_NSArray),
    637                                  SR.getBegin(),
    638                                  LookupOrdinaryName);
    639     NSArrayDecl = dyn_cast_or_null<ObjCInterfaceDecl>(IF);
    640     if (!NSArrayDecl && getLangOpts().DebuggerObjCLiteral)
    641       NSArrayDecl =  ObjCInterfaceDecl::Create (Context,
    642                             Context.getTranslationUnitDecl(),
    643                             SourceLocation(),
    644                             NSAPIObj->getNSClassId(NSAPI::ClassId_NSArray),
    645                             nullptr, SourceLocation());
    646 
    647     if (!NSArrayDecl) {
    648       Diag(SR.getBegin(), diag::err_undeclared_nsarray);
    649       return ExprError();
    650     }
    651   }
    652 
    653   // Find the arrayWithObjects:count: method, if we haven't done so already.
    654   QualType IdT = Context.getObjCIdType();
    655   if (!ArrayWithObjectsMethod) {
    656     Selector
    657       Sel = NSAPIObj->getNSArraySelector(NSAPI::NSArr_arrayWithObjectsCount);
    658     ObjCMethodDecl *Method = NSArrayDecl->lookupClassMethod(Sel);
    659     if (!Method && getLangOpts().DebuggerObjCLiteral) {
    660       TypeSourceInfo *ReturnTInfo = nullptr;
    661       Method = ObjCMethodDecl::Create(
    662           Context, SourceLocation(), SourceLocation(), Sel, IdT, ReturnTInfo,
    663           Context.getTranslationUnitDecl(), false /*Instance*/,
    664           false /*isVariadic*/,
    665           /*isPropertyAccessor=*/false,
    666           /*isImplicitlyDeclared=*/true, /*isDefined=*/false,
    667           ObjCMethodDecl::Required, false);
    668       SmallVector<ParmVarDecl *, 2> Params;
    669       ParmVarDecl *objects = ParmVarDecl::Create(Context, Method,
    670                                                  SourceLocation(),
    671                                                  SourceLocation(),
    672                                                  &Context.Idents.get("objects"),
    673                                                  Context.getPointerType(IdT),
    674                                                  /*TInfo=*/nullptr,
    675                                                  SC_None, nullptr);
    676       Params.push_back(objects);
    677       ParmVarDecl *cnt = ParmVarDecl::Create(Context, Method,
    678                                              SourceLocation(),
    679                                              SourceLocation(),
    680                                              &Context.Idents.get("cnt"),
    681                                              Context.UnsignedLongTy,
    682                                              /*TInfo=*/nullptr, SC_None,
    683                                              nullptr);
    684       Params.push_back(cnt);
    685       Method->setMethodParams(Context, Params, None);
    686     }
    687 
    688     if (!validateBoxingMethod(*this, SR.getBegin(), NSArrayDecl, Sel, Method))
    689       return ExprError();
    690 
    691     // Dig out the type that all elements should be converted to.
    692     QualType T = Method->parameters()[0]->getType();
    693     const PointerType *PtrT = T->getAs<PointerType>();
    694     if (!PtrT ||
    695         !Context.hasSameUnqualifiedType(PtrT->getPointeeType(), IdT)) {
    696       Diag(SR.getBegin(), diag::err_objc_literal_method_sig)
    697         << Sel;
    698       Diag(Method->parameters()[0]->getLocation(),
    699            diag::note_objc_literal_method_param)
    700         << 0 << T
    701         << Context.getPointerType(IdT.withConst());
    702       return ExprError();
    703     }
    704 
    705     // Check that the 'count' parameter is integral.
    706     if (!Method->parameters()[1]->getType()->isIntegerType()) {
    707       Diag(SR.getBegin(), diag::err_objc_literal_method_sig)
    708         << Sel;
    709       Diag(Method->parameters()[1]->getLocation(),
    710            diag::note_objc_literal_method_param)
    711         << 1
    712         << Method->parameters()[1]->getType()
    713         << "integral";
    714       return ExprError();
    715     }
    716 
    717     // We've found a good +arrayWithObjects:count: method. Save it!
    718     ArrayWithObjectsMethod = Method;
    719   }
    720 
    721   QualType ObjectsType = ArrayWithObjectsMethod->parameters()[0]->getType();
    722   QualType RequiredType = ObjectsType->castAs<PointerType>()->getPointeeType();
    723 
    724   // Check that each of the elements provided is valid in a collection literal,
    725   // performing conversions as necessary.
    726   Expr **ElementsBuffer = Elements.data();
    727   for (unsigned I = 0, N = Elements.size(); I != N; ++I) {
    728     ExprResult Converted = CheckObjCCollectionLiteralElement(*this,
    729                                                              ElementsBuffer[I],
    730                                                              RequiredType, true);
    731     if (Converted.isInvalid())
    732       return ExprError();
    733 
    734     ElementsBuffer[I] = Converted.get();
    735   }
    736 
    737   QualType Ty
    738     = Context.getObjCObjectPointerType(
    739                                     Context.getObjCInterfaceType(NSArrayDecl));
    740 
    741   return MaybeBindToTemporary(
    742            ObjCArrayLiteral::Create(Context, Elements, Ty,
    743                                     ArrayWithObjectsMethod, SR));
    744 }
    745 
    746 ExprResult Sema::BuildObjCDictionaryLiteral(SourceRange SR,
    747                                             ObjCDictionaryElement *Elements,
    748                                             unsigned NumElements) {
    749   // Look up the NSDictionary class, if we haven't done so already.
    750   if (!NSDictionaryDecl) {
    751     NamedDecl *IF = LookupSingleName(TUScope,
    752                             NSAPIObj->getNSClassId(NSAPI::ClassId_NSDictionary),
    753                             SR.getBegin(), LookupOrdinaryName);
    754     NSDictionaryDecl = dyn_cast_or_null<ObjCInterfaceDecl>(IF);
    755     if (!NSDictionaryDecl && getLangOpts().DebuggerObjCLiteral)
    756       NSDictionaryDecl =  ObjCInterfaceDecl::Create (Context,
    757                             Context.getTranslationUnitDecl(),
    758                             SourceLocation(),
    759                             NSAPIObj->getNSClassId(NSAPI::ClassId_NSDictionary),
    760                             nullptr, SourceLocation());
    761 
    762     if (!NSDictionaryDecl) {
    763       Diag(SR.getBegin(), diag::err_undeclared_nsdictionary);
    764       return ExprError();
    765     }
    766   }
    767 
    768   // Find the dictionaryWithObjects:forKeys:count: method, if we haven't done
    769   // so already.
    770   QualType IdT = Context.getObjCIdType();
    771   if (!DictionaryWithObjectsMethod) {
    772     Selector Sel = NSAPIObj->getNSDictionarySelector(
    773                                NSAPI::NSDict_dictionaryWithObjectsForKeysCount);
    774     ObjCMethodDecl *Method = NSDictionaryDecl->lookupClassMethod(Sel);
    775     if (!Method && getLangOpts().DebuggerObjCLiteral) {
    776       Method = ObjCMethodDecl::Create(Context,
    777                            SourceLocation(), SourceLocation(), Sel,
    778                            IdT,
    779                            nullptr /*TypeSourceInfo */,
    780                            Context.getTranslationUnitDecl(),
    781                            false /*Instance*/, false/*isVariadic*/,
    782                            /*isPropertyAccessor=*/false,
    783                            /*isImplicitlyDeclared=*/true, /*isDefined=*/false,
    784                            ObjCMethodDecl::Required,
    785                            false);
    786       SmallVector<ParmVarDecl *, 3> Params;
    787       ParmVarDecl *objects = ParmVarDecl::Create(Context, Method,
    788                                                  SourceLocation(),
    789                                                  SourceLocation(),
    790                                                  &Context.Idents.get("objects"),
    791                                                  Context.getPointerType(IdT),
    792                                                  /*TInfo=*/nullptr, SC_None,
    793                                                  nullptr);
    794       Params.push_back(objects);
    795       ParmVarDecl *keys = ParmVarDecl::Create(Context, Method,
    796                                               SourceLocation(),
    797                                               SourceLocation(),
    798                                               &Context.Idents.get("keys"),
    799                                               Context.getPointerType(IdT),
    800                                               /*TInfo=*/nullptr, SC_None,
    801                                               nullptr);
    802       Params.push_back(keys);
    803       ParmVarDecl *cnt = ParmVarDecl::Create(Context, Method,
    804                                              SourceLocation(),
    805                                              SourceLocation(),
    806                                              &Context.Idents.get("cnt"),
    807                                              Context.UnsignedLongTy,
    808                                              /*TInfo=*/nullptr, SC_None,
    809                                              nullptr);
    810       Params.push_back(cnt);
    811       Method->setMethodParams(Context, Params, None);
    812     }
    813 
    814     if (!validateBoxingMethod(*this, SR.getBegin(), NSDictionaryDecl, Sel,
    815                               Method))
    816        return ExprError();
    817 
    818     // Dig out the type that all values should be converted to.
    819     QualType ValueT = Method->parameters()[0]->getType();
    820     const PointerType *PtrValue = ValueT->getAs<PointerType>();
    821     if (!PtrValue ||
    822         !Context.hasSameUnqualifiedType(PtrValue->getPointeeType(), IdT)) {
    823       Diag(SR.getBegin(), diag::err_objc_literal_method_sig)
    824         << Sel;
    825       Diag(Method->parameters()[0]->getLocation(),
    826            diag::note_objc_literal_method_param)
    827         << 0 << ValueT
    828         << Context.getPointerType(IdT.withConst());
    829       return ExprError();
    830     }
    831 
    832     // Dig out the type that all keys should be converted to.
    833     QualType KeyT = Method->parameters()[1]->getType();
    834     const PointerType *PtrKey = KeyT->getAs<PointerType>();
    835     if (!PtrKey ||
    836         !Context.hasSameUnqualifiedType(PtrKey->getPointeeType(),
    837                                         IdT)) {
    838       bool err = true;
    839       if (PtrKey) {
    840         if (QIDNSCopying.isNull()) {
    841           // key argument of selector is id<NSCopying>?
    842           if (ObjCProtocolDecl *NSCopyingPDecl =
    843               LookupProtocol(&Context.Idents.get("NSCopying"), SR.getBegin())) {
    844             ObjCProtocolDecl *PQ[] = {NSCopyingPDecl};
    845             QIDNSCopying =
    846               Context.getObjCObjectType(Context.ObjCBuiltinIdTy,
    847                                         (ObjCProtocolDecl**) PQ,1);
    848             QIDNSCopying = Context.getObjCObjectPointerType(QIDNSCopying);
    849           }
    850         }
    851         if (!QIDNSCopying.isNull())
    852           err = !Context.hasSameUnqualifiedType(PtrKey->getPointeeType(),
    853                                                 QIDNSCopying);
    854       }
    855 
    856       if (err) {
    857         Diag(SR.getBegin(), diag::err_objc_literal_method_sig)
    858           << Sel;
    859         Diag(Method->parameters()[1]->getLocation(),
    860              diag::note_objc_literal_method_param)
    861           << 1 << KeyT
    862           << Context.getPointerType(IdT.withConst());
    863         return ExprError();
    864       }
    865     }
    866 
    867     // Check that the 'count' parameter is integral.
    868     QualType CountType = Method->parameters()[2]->getType();
    869     if (!CountType->isIntegerType()) {
    870       Diag(SR.getBegin(), diag::err_objc_literal_method_sig)
    871         << Sel;
    872       Diag(Method->parameters()[2]->getLocation(),
    873            diag::note_objc_literal_method_param)
    874         << 2 << CountType
    875         << "integral";
    876       return ExprError();
    877     }
    878 
    879     // We've found a good +dictionaryWithObjects:keys:count: method; save it!
    880     DictionaryWithObjectsMethod = Method;
    881   }
    882 
    883   QualType ValuesT = DictionaryWithObjectsMethod->parameters()[0]->getType();
    884   QualType ValueT = ValuesT->castAs<PointerType>()->getPointeeType();
    885   QualType KeysT = DictionaryWithObjectsMethod->parameters()[1]->getType();
    886   QualType KeyT = KeysT->castAs<PointerType>()->getPointeeType();
    887 
    888   // Check that each of the keys and values provided is valid in a collection
    889   // literal, performing conversions as necessary.
    890   bool HasPackExpansions = false;
    891   for (unsigned I = 0, N = NumElements; I != N; ++I) {
    892     // Check the key.
    893     ExprResult Key = CheckObjCCollectionLiteralElement(*this, Elements[I].Key,
    894                                                        KeyT);
    895     if (Key.isInvalid())
    896       return ExprError();
    897 
    898     // Check the value.
    899     ExprResult Value
    900       = CheckObjCCollectionLiteralElement(*this, Elements[I].Value, ValueT);
    901     if (Value.isInvalid())
    902       return ExprError();
    903 
    904     Elements[I].Key = Key.get();
    905     Elements[I].Value = Value.get();
    906 
    907     if (Elements[I].EllipsisLoc.isInvalid())
    908       continue;
    909 
    910     if (!Elements[I].Key->containsUnexpandedParameterPack() &&
    911         !Elements[I].Value->containsUnexpandedParameterPack()) {
    912       Diag(Elements[I].EllipsisLoc,
    913            diag::err_pack_expansion_without_parameter_packs)
    914         << SourceRange(Elements[I].Key->getLocStart(),
    915                        Elements[I].Value->getLocEnd());
    916       return ExprError();
    917     }
    918 
    919     HasPackExpansions = true;
    920   }
    921 
    922 
    923   QualType Ty
    924     = Context.getObjCObjectPointerType(
    925                                 Context.getObjCInterfaceType(NSDictionaryDecl));
    926   return MaybeBindToTemporary(ObjCDictionaryLiteral::Create(
    927       Context, makeArrayRef(Elements, NumElements), HasPackExpansions, Ty,
    928       DictionaryWithObjectsMethod, SR));
    929 }
    930 
    931 ExprResult Sema::BuildObjCEncodeExpression(SourceLocation AtLoc,
    932                                       TypeSourceInfo *EncodedTypeInfo,
    933                                       SourceLocation RParenLoc) {
    934   QualType EncodedType = EncodedTypeInfo->getType();
    935   QualType StrTy;
    936   if (EncodedType->isDependentType())
    937     StrTy = Context.DependentTy;
    938   else {
    939     if (!EncodedType->getAsArrayTypeUnsafe() && //// Incomplete array is handled.
    940         !EncodedType->isVoidType()) // void is handled too.
    941       if (RequireCompleteType(AtLoc, EncodedType,
    942                               diag::err_incomplete_type_objc_at_encode,
    943                               EncodedTypeInfo->getTypeLoc()))
    944         return ExprError();
    945 
    946     std::string Str;
    947     Context.getObjCEncodingForType(EncodedType, Str);
    948 
    949     // The type of @encode is the same as the type of the corresponding string,
    950     // which is an array type.
    951     StrTy = Context.CharTy;
    952     // A C++ string literal has a const-qualified element type (C++ 2.13.4p1).
    953     if (getLangOpts().CPlusPlus || getLangOpts().ConstStrings)
    954       StrTy.addConst();
    955     StrTy = Context.getConstantArrayType(StrTy, llvm::APInt(32, Str.size()+1),
    956                                          ArrayType::Normal, 0);
    957   }
    958 
    959   return new (Context) ObjCEncodeExpr(StrTy, EncodedTypeInfo, AtLoc, RParenLoc);
    960 }
    961 
    962 ExprResult Sema::ParseObjCEncodeExpression(SourceLocation AtLoc,
    963                                            SourceLocation EncodeLoc,
    964                                            SourceLocation LParenLoc,
    965                                            ParsedType ty,
    966                                            SourceLocation RParenLoc) {
    967   // FIXME: Preserve type source info ?
    968   TypeSourceInfo *TInfo;
    969   QualType EncodedType = GetTypeFromParser(ty, &TInfo);
    970   if (!TInfo)
    971     TInfo = Context.getTrivialTypeSourceInfo(EncodedType,
    972                                              PP.getLocForEndOfToken(LParenLoc));
    973 
    974   return BuildObjCEncodeExpression(AtLoc, TInfo, RParenLoc);
    975 }
    976 
    977 static bool HelperToDiagnoseMismatchedMethodsInGlobalPool(Sema &S,
    978                                                SourceLocation AtLoc,
    979                                                SourceLocation LParenLoc,
    980                                                SourceLocation RParenLoc,
    981                                                ObjCMethodDecl *Method,
    982                                                ObjCMethodList &MethList) {
    983   ObjCMethodList *M = &MethList;
    984   bool Warned = false;
    985   for (M = M->getNext(); M; M=M->getNext()) {
    986     ObjCMethodDecl *MatchingMethodDecl = M->Method;
    987     if (MatchingMethodDecl == Method ||
    988         isa<ObjCImplDecl>(MatchingMethodDecl->getDeclContext()) ||
    989         MatchingMethodDecl->getSelector() != Method->getSelector())
    990       continue;
    991     if (!S.MatchTwoMethodDeclarations(Method,
    992                                       MatchingMethodDecl, Sema::MMS_loose)) {
    993       if (!Warned) {
    994         Warned = true;
    995         S.Diag(AtLoc, diag::warning_multiple_selectors)
    996           << Method->getSelector() << FixItHint::CreateInsertion(LParenLoc, "(")
    997           << FixItHint::CreateInsertion(RParenLoc, ")");
    998         S.Diag(Method->getLocation(), diag::note_method_declared_at)
    999           << Method->getDeclName();
   1000       }
   1001       S.Diag(MatchingMethodDecl->getLocation(), diag::note_method_declared_at)
   1002         << MatchingMethodDecl->getDeclName();
   1003     }
   1004   }
   1005   return Warned;
   1006 }
   1007 
   1008 static void DiagnoseMismatchedSelectors(Sema &S, SourceLocation AtLoc,
   1009                                         ObjCMethodDecl *Method,
   1010                                         SourceLocation LParenLoc,
   1011                                         SourceLocation RParenLoc,
   1012                                         bool WarnMultipleSelectors) {
   1013   if (!WarnMultipleSelectors ||
   1014       S.Diags.isIgnored(diag::warning_multiple_selectors, SourceLocation()))
   1015     return;
   1016   bool Warned = false;
   1017   for (Sema::GlobalMethodPool::iterator b = S.MethodPool.begin(),
   1018        e = S.MethodPool.end(); b != e; b++) {
   1019     // first, instance methods
   1020     ObjCMethodList &InstMethList = b->second.first;
   1021     if (HelperToDiagnoseMismatchedMethodsInGlobalPool(S, AtLoc, LParenLoc, RParenLoc,
   1022                                                       Method, InstMethList))
   1023       Warned = true;
   1024 
   1025     // second, class methods
   1026     ObjCMethodList &ClsMethList = b->second.second;
   1027     if (HelperToDiagnoseMismatchedMethodsInGlobalPool(S, AtLoc, LParenLoc, RParenLoc,
   1028                                                       Method, ClsMethList) || Warned)
   1029       return;
   1030   }
   1031 }
   1032 
   1033 ExprResult Sema::ParseObjCSelectorExpression(Selector Sel,
   1034                                              SourceLocation AtLoc,
   1035                                              SourceLocation SelLoc,
   1036                                              SourceLocation LParenLoc,
   1037                                              SourceLocation RParenLoc,
   1038                                              bool WarnMultipleSelectors) {
   1039   ObjCMethodDecl *Method = LookupInstanceMethodInGlobalPool(Sel,
   1040                              SourceRange(LParenLoc, RParenLoc), false, false);
   1041   if (!Method)
   1042     Method = LookupFactoryMethodInGlobalPool(Sel,
   1043                                           SourceRange(LParenLoc, RParenLoc));
   1044   if (!Method) {
   1045     if (const ObjCMethodDecl *OM = SelectorsForTypoCorrection(Sel)) {
   1046       Selector MatchedSel = OM->getSelector();
   1047       SourceRange SelectorRange(LParenLoc.getLocWithOffset(1),
   1048                                 RParenLoc.getLocWithOffset(-1));
   1049       Diag(SelLoc, diag::warn_undeclared_selector_with_typo)
   1050         << Sel << MatchedSel
   1051         << FixItHint::CreateReplacement(SelectorRange, MatchedSel.getAsString());
   1052 
   1053     } else
   1054         Diag(SelLoc, diag::warn_undeclared_selector) << Sel;
   1055   } else
   1056     DiagnoseMismatchedSelectors(*this, AtLoc, Method, LParenLoc, RParenLoc,
   1057                                 WarnMultipleSelectors);
   1058 
   1059   if (Method &&
   1060       Method->getImplementationControl() != ObjCMethodDecl::Optional &&
   1061       !getSourceManager().isInSystemHeader(Method->getLocation())) {
   1062     llvm::DenseMap<Selector, SourceLocation>::iterator Pos
   1063       = ReferencedSelectors.find(Sel);
   1064     if (Pos == ReferencedSelectors.end())
   1065       ReferencedSelectors.insert(std::make_pair(Sel, AtLoc));
   1066   }
   1067 
   1068   // In ARC, forbid the user from using @selector for
   1069   // retain/release/autorelease/dealloc/retainCount.
   1070   if (getLangOpts().ObjCAutoRefCount) {
   1071     switch (Sel.getMethodFamily()) {
   1072     case OMF_retain:
   1073     case OMF_release:
   1074     case OMF_autorelease:
   1075     case OMF_retainCount:
   1076     case OMF_dealloc:
   1077       Diag(AtLoc, diag::err_arc_illegal_selector) <<
   1078         Sel << SourceRange(LParenLoc, RParenLoc);
   1079       break;
   1080 
   1081     case OMF_None:
   1082     case OMF_alloc:
   1083     case OMF_copy:
   1084     case OMF_finalize:
   1085     case OMF_init:
   1086     case OMF_mutableCopy:
   1087     case OMF_new:
   1088     case OMF_self:
   1089     case OMF_performSelector:
   1090       break;
   1091     }
   1092   }
   1093   QualType Ty = Context.getObjCSelType();
   1094   return new (Context) ObjCSelectorExpr(Ty, Sel, AtLoc, RParenLoc);
   1095 }
   1096 
   1097 ExprResult Sema::ParseObjCProtocolExpression(IdentifierInfo *ProtocolId,
   1098                                              SourceLocation AtLoc,
   1099                                              SourceLocation ProtoLoc,
   1100                                              SourceLocation LParenLoc,
   1101                                              SourceLocation ProtoIdLoc,
   1102                                              SourceLocation RParenLoc) {
   1103   ObjCProtocolDecl* PDecl = LookupProtocol(ProtocolId, ProtoIdLoc);
   1104   if (!PDecl) {
   1105     Diag(ProtoLoc, diag::err_undeclared_protocol) << ProtocolId;
   1106     return true;
   1107   }
   1108 
   1109   QualType Ty = Context.getObjCProtoType();
   1110   if (Ty.isNull())
   1111     return true;
   1112   Ty = Context.getObjCObjectPointerType(Ty);
   1113   return new (Context) ObjCProtocolExpr(Ty, PDecl, AtLoc, ProtoIdLoc, RParenLoc);
   1114 }
   1115 
   1116 /// Try to capture an implicit reference to 'self'.
   1117 ObjCMethodDecl *Sema::tryCaptureObjCSelf(SourceLocation Loc) {
   1118   DeclContext *DC = getFunctionLevelDeclContext();
   1119 
   1120   // If we're not in an ObjC method, error out.  Note that, unlike the
   1121   // C++ case, we don't require an instance method --- class methods
   1122   // still have a 'self', and we really do still need to capture it!
   1123   ObjCMethodDecl *method = dyn_cast<ObjCMethodDecl>(DC);
   1124   if (!method)
   1125     return nullptr;
   1126 
   1127   tryCaptureVariable(method->getSelfDecl(), Loc);
   1128 
   1129   return method;
   1130 }
   1131 
   1132 static QualType stripObjCInstanceType(ASTContext &Context, QualType T) {
   1133   if (T == Context.getObjCInstanceType())
   1134     return Context.getObjCIdType();
   1135 
   1136   return T;
   1137 }
   1138 
   1139 QualType Sema::getMessageSendResultType(QualType ReceiverType,
   1140                                         ObjCMethodDecl *Method,
   1141                                     bool isClassMessage, bool isSuperMessage) {
   1142   assert(Method && "Must have a method");
   1143   if (!Method->hasRelatedResultType())
   1144     return Method->getSendResultType();
   1145 
   1146   // If a method has a related return type:
   1147   //   - if the method found is an instance method, but the message send
   1148   //     was a class message send, T is the declared return type of the method
   1149   //     found
   1150   if (Method->isInstanceMethod() && isClassMessage)
   1151     return stripObjCInstanceType(Context, Method->getSendResultType());
   1152 
   1153   //   - if the receiver is super, T is a pointer to the class of the
   1154   //     enclosing method definition
   1155   if (isSuperMessage) {
   1156     if (ObjCMethodDecl *CurMethod = getCurMethodDecl())
   1157       if (ObjCInterfaceDecl *Class = CurMethod->getClassInterface())
   1158         return Context.getObjCObjectPointerType(
   1159                                         Context.getObjCInterfaceType(Class));
   1160   }
   1161 
   1162   //   - if the receiver is the name of a class U, T is a pointer to U
   1163   if (ReceiverType->getAs<ObjCInterfaceType>() ||
   1164       ReceiverType->isObjCQualifiedInterfaceType())
   1165     return Context.getObjCObjectPointerType(ReceiverType);
   1166   //   - if the receiver is of type Class or qualified Class type,
   1167   //     T is the declared return type of the method.
   1168   if (ReceiverType->isObjCClassType() ||
   1169       ReceiverType->isObjCQualifiedClassType())
   1170     return stripObjCInstanceType(Context, Method->getSendResultType());
   1171 
   1172   //   - if the receiver is id, qualified id, Class, or qualified Class, T
   1173   //     is the receiver type, otherwise
   1174   //   - T is the type of the receiver expression.
   1175   return ReceiverType;
   1176 }
   1177 
   1178 /// Look for an ObjC method whose result type exactly matches the given type.
   1179 static const ObjCMethodDecl *
   1180 findExplicitInstancetypeDeclarer(const ObjCMethodDecl *MD,
   1181                                  QualType instancetype) {
   1182   if (MD->getReturnType() == instancetype)
   1183     return MD;
   1184 
   1185   // For these purposes, a method in an @implementation overrides a
   1186   // declaration in the @interface.
   1187   if (const ObjCImplDecl *impl =
   1188         dyn_cast<ObjCImplDecl>(MD->getDeclContext())) {
   1189     const ObjCContainerDecl *iface;
   1190     if (const ObjCCategoryImplDecl *catImpl =
   1191           dyn_cast<ObjCCategoryImplDecl>(impl)) {
   1192       iface = catImpl->getCategoryDecl();
   1193     } else {
   1194       iface = impl->getClassInterface();
   1195     }
   1196 
   1197     const ObjCMethodDecl *ifaceMD =
   1198       iface->getMethod(MD->getSelector(), MD->isInstanceMethod());
   1199     if (ifaceMD) return findExplicitInstancetypeDeclarer(ifaceMD, instancetype);
   1200   }
   1201 
   1202   SmallVector<const ObjCMethodDecl *, 4> overrides;
   1203   MD->getOverriddenMethods(overrides);
   1204   for (unsigned i = 0, e = overrides.size(); i != e; ++i) {
   1205     if (const ObjCMethodDecl *result =
   1206           findExplicitInstancetypeDeclarer(overrides[i], instancetype))
   1207       return result;
   1208   }
   1209 
   1210   return nullptr;
   1211 }
   1212 
   1213 void Sema::EmitRelatedResultTypeNoteForReturn(QualType destType) {
   1214   // Only complain if we're in an ObjC method and the required return
   1215   // type doesn't match the method's declared return type.
   1216   ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(CurContext);
   1217   if (!MD || !MD->hasRelatedResultType() ||
   1218       Context.hasSameUnqualifiedType(destType, MD->getReturnType()))
   1219     return;
   1220 
   1221   // Look for a method overridden by this method which explicitly uses
   1222   // 'instancetype'.
   1223   if (const ObjCMethodDecl *overridden =
   1224         findExplicitInstancetypeDeclarer(MD, Context.getObjCInstanceType())) {
   1225     SourceLocation loc;
   1226     SourceRange range;
   1227     if (TypeSourceInfo *TSI = overridden->getReturnTypeSourceInfo()) {
   1228       range = TSI->getTypeLoc().getSourceRange();
   1229       loc = range.getBegin();
   1230     }
   1231     if (loc.isInvalid())
   1232       loc = overridden->getLocation();
   1233     Diag(loc, diag::note_related_result_type_explicit)
   1234       << /*current method*/ 1 << range;
   1235     return;
   1236   }
   1237 
   1238   // Otherwise, if we have an interesting method family, note that.
   1239   // This should always trigger if the above didn't.
   1240   if (ObjCMethodFamily family = MD->getMethodFamily())
   1241     Diag(MD->getLocation(), diag::note_related_result_type_family)
   1242       << /*current method*/ 1
   1243       << family;
   1244 }
   1245 
   1246 void Sema::EmitRelatedResultTypeNote(const Expr *E) {
   1247   E = E->IgnoreParenImpCasts();
   1248   const ObjCMessageExpr *MsgSend = dyn_cast<ObjCMessageExpr>(E);
   1249   if (!MsgSend)
   1250     return;
   1251 
   1252   const ObjCMethodDecl *Method = MsgSend->getMethodDecl();
   1253   if (!Method)
   1254     return;
   1255 
   1256   if (!Method->hasRelatedResultType())
   1257     return;
   1258 
   1259   if (Context.hasSameUnqualifiedType(
   1260           Method->getReturnType().getNonReferenceType(), MsgSend->getType()))
   1261     return;
   1262 
   1263   if (!Context.hasSameUnqualifiedType(Method->getReturnType(),
   1264                                       Context.getObjCInstanceType()))
   1265     return;
   1266 
   1267   Diag(Method->getLocation(), diag::note_related_result_type_inferred)
   1268     << Method->isInstanceMethod() << Method->getSelector()
   1269     << MsgSend->getType();
   1270 }
   1271 
   1272 bool Sema::CheckMessageArgumentTypes(QualType ReceiverType,
   1273                                      MultiExprArg Args,
   1274                                      Selector Sel,
   1275                                      ArrayRef<SourceLocation> SelectorLocs,
   1276                                      ObjCMethodDecl *Method,
   1277                                      bool isClassMessage, bool isSuperMessage,
   1278                                      SourceLocation lbrac, SourceLocation rbrac,
   1279                                      QualType &ReturnType, ExprValueKind &VK) {
   1280   SourceLocation SelLoc;
   1281   if (!SelectorLocs.empty() && SelectorLocs.front().isValid())
   1282     SelLoc = SelectorLocs.front();
   1283   else
   1284     SelLoc = lbrac;
   1285 
   1286   if (!Method) {
   1287     // Apply default argument promotion as for (C99 6.5.2.2p6).
   1288     for (unsigned i = 0, e = Args.size(); i != e; i++) {
   1289       if (Args[i]->isTypeDependent())
   1290         continue;
   1291 
   1292       ExprResult result;
   1293       if (getLangOpts().DebuggerSupport) {
   1294         QualType paramTy; // ignored
   1295         result = checkUnknownAnyArg(SelLoc, Args[i], paramTy);
   1296       } else {
   1297         result = DefaultArgumentPromotion(Args[i]);
   1298       }
   1299       if (result.isInvalid())
   1300         return true;
   1301       Args[i] = result.get();
   1302     }
   1303 
   1304     unsigned DiagID;
   1305     if (getLangOpts().ObjCAutoRefCount)
   1306       DiagID = diag::err_arc_method_not_found;
   1307     else
   1308       DiagID = isClassMessage ? diag::warn_class_method_not_found
   1309                               : diag::warn_inst_method_not_found;
   1310     if (!getLangOpts().DebuggerSupport) {
   1311       const ObjCMethodDecl *OMD = SelectorsForTypoCorrection(Sel, ReceiverType);
   1312       if (OMD && !OMD->isInvalidDecl()) {
   1313         if (getLangOpts().ObjCAutoRefCount)
   1314           DiagID = diag::error_method_not_found_with_typo;
   1315         else
   1316           DiagID = isClassMessage ? diag::warn_class_method_not_found_with_typo
   1317                                   : diag::warn_instance_method_not_found_with_typo;
   1318         Selector MatchedSel = OMD->getSelector();
   1319         SourceRange SelectorRange(SelectorLocs.front(), SelectorLocs.back());
   1320         Diag(SelLoc, DiagID)
   1321           << Sel<< isClassMessage << MatchedSel
   1322           << FixItHint::CreateReplacement(SelectorRange, MatchedSel.getAsString());
   1323       }
   1324       else
   1325         Diag(SelLoc, DiagID)
   1326           << Sel << isClassMessage << SourceRange(SelectorLocs.front(),
   1327                                                 SelectorLocs.back());
   1328       // Find the class to which we are sending this message.
   1329       if (ReceiverType->isObjCObjectPointerType()) {
   1330         if (ObjCInterfaceDecl *Class =
   1331               ReceiverType->getAs<ObjCObjectPointerType>()->getInterfaceDecl())
   1332           Diag(Class->getLocation(), diag::note_receiver_class_declared);
   1333       }
   1334     }
   1335 
   1336     // In debuggers, we want to use __unknown_anytype for these
   1337     // results so that clients can cast them.
   1338     if (getLangOpts().DebuggerSupport) {
   1339       ReturnType = Context.UnknownAnyTy;
   1340     } else {
   1341       ReturnType = Context.getObjCIdType();
   1342     }
   1343     VK = VK_RValue;
   1344     return false;
   1345   }
   1346 
   1347   ReturnType = getMessageSendResultType(ReceiverType, Method, isClassMessage,
   1348                                         isSuperMessage);
   1349   VK = Expr::getValueKindForType(Method->getReturnType());
   1350 
   1351   unsigned NumNamedArgs = Sel.getNumArgs();
   1352   // Method might have more arguments than selector indicates. This is due
   1353   // to addition of c-style arguments in method.
   1354   if (Method->param_size() > Sel.getNumArgs())
   1355     NumNamedArgs = Method->param_size();
   1356   // FIXME. This need be cleaned up.
   1357   if (Args.size() < NumNamedArgs) {
   1358     Diag(SelLoc, diag::err_typecheck_call_too_few_args)
   1359       << 2 << NumNamedArgs << static_cast<unsigned>(Args.size());
   1360     return false;
   1361   }
   1362 
   1363   bool IsError = false;
   1364   for (unsigned i = 0; i < NumNamedArgs; i++) {
   1365     // We can't do any type-checking on a type-dependent argument.
   1366     if (Args[i]->isTypeDependent())
   1367       continue;
   1368 
   1369     Expr *argExpr = Args[i];
   1370 
   1371     ParmVarDecl *param = Method->parameters()[i];
   1372     assert(argExpr && "CheckMessageArgumentTypes(): missing expression");
   1373 
   1374     // Strip the unbridged-cast placeholder expression off unless it's
   1375     // a consumed argument.
   1376     if (argExpr->hasPlaceholderType(BuiltinType::ARCUnbridgedCast) &&
   1377         !param->hasAttr<CFConsumedAttr>())
   1378       argExpr = stripARCUnbridgedCast(argExpr);
   1379 
   1380     // If the parameter is __unknown_anytype, infer its type
   1381     // from the argument.
   1382     if (param->getType() == Context.UnknownAnyTy) {
   1383       QualType paramType;
   1384       ExprResult argE = checkUnknownAnyArg(SelLoc, argExpr, paramType);
   1385       if (argE.isInvalid()) {
   1386         IsError = true;
   1387       } else {
   1388         Args[i] = argE.get();
   1389 
   1390         // Update the parameter type in-place.
   1391         param->setType(paramType);
   1392       }
   1393       continue;
   1394     }
   1395 
   1396     if (RequireCompleteType(argExpr->getSourceRange().getBegin(),
   1397                             param->getType(),
   1398                             diag::err_call_incomplete_argument, argExpr))
   1399       return true;
   1400 
   1401     InitializedEntity Entity = InitializedEntity::InitializeParameter(Context,
   1402                                                                       param);
   1403     ExprResult ArgE = PerformCopyInitialization(Entity, SelLoc, argExpr);
   1404     if (ArgE.isInvalid())
   1405       IsError = true;
   1406     else
   1407       Args[i] = ArgE.getAs<Expr>();
   1408   }
   1409 
   1410   // Promote additional arguments to variadic methods.
   1411   if (Method->isVariadic()) {
   1412     for (unsigned i = NumNamedArgs, e = Args.size(); i < e; ++i) {
   1413       if (Args[i]->isTypeDependent())
   1414         continue;
   1415 
   1416       ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], VariadicMethod,
   1417                                                         nullptr);
   1418       IsError |= Arg.isInvalid();
   1419       Args[i] = Arg.get();
   1420     }
   1421   } else {
   1422     // Check for extra arguments to non-variadic methods.
   1423     if (Args.size() != NumNamedArgs) {
   1424       Diag(Args[NumNamedArgs]->getLocStart(),
   1425            diag::err_typecheck_call_too_many_args)
   1426         << 2 /*method*/ << NumNamedArgs << static_cast<unsigned>(Args.size())
   1427         << Method->getSourceRange()
   1428         << SourceRange(Args[NumNamedArgs]->getLocStart(),
   1429                        Args.back()->getLocEnd());
   1430     }
   1431   }
   1432 
   1433   DiagnoseSentinelCalls(Method, SelLoc, Args);
   1434 
   1435   // Do additional checkings on method.
   1436   IsError |= CheckObjCMethodCall(
   1437       Method, SelLoc, makeArrayRef<const Expr *>(Args.data(), Args.size()));
   1438 
   1439   return IsError;
   1440 }
   1441 
   1442 bool Sema::isSelfExpr(Expr *RExpr) {
   1443   // 'self' is objc 'self' in an objc method only.
   1444   ObjCMethodDecl *Method =
   1445       dyn_cast_or_null<ObjCMethodDecl>(CurContext->getNonClosureAncestor());
   1446   return isSelfExpr(RExpr, Method);
   1447 }
   1448 
   1449 bool Sema::isSelfExpr(Expr *receiver, const ObjCMethodDecl *method) {
   1450   if (!method) return false;
   1451 
   1452   receiver = receiver->IgnoreParenLValueCasts();
   1453   if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(receiver))
   1454     if (DRE->getDecl() == method->getSelfDecl())
   1455       return true;
   1456   return false;
   1457 }
   1458 
   1459 /// LookupMethodInType - Look up a method in an ObjCObjectType.
   1460 ObjCMethodDecl *Sema::LookupMethodInObjectType(Selector sel, QualType type,
   1461                                                bool isInstance) {
   1462   const ObjCObjectType *objType = type->castAs<ObjCObjectType>();
   1463   if (ObjCInterfaceDecl *iface = objType->getInterface()) {
   1464     // Look it up in the main interface (and categories, etc.)
   1465     if (ObjCMethodDecl *method = iface->lookupMethod(sel, isInstance))
   1466       return method;
   1467 
   1468     // Okay, look for "private" methods declared in any
   1469     // @implementations we've seen.
   1470     if (ObjCMethodDecl *method = iface->lookupPrivateMethod(sel, isInstance))
   1471       return method;
   1472   }
   1473 
   1474   // Check qualifiers.
   1475   for (const auto *I : objType->quals())
   1476     if (ObjCMethodDecl *method = I->lookupMethod(sel, isInstance))
   1477       return method;
   1478 
   1479   return nullptr;
   1480 }
   1481 
   1482 /// LookupMethodInQualifiedType - Lookups up a method in protocol qualifier
   1483 /// list of a qualified objective pointer type.
   1484 ObjCMethodDecl *Sema::LookupMethodInQualifiedType(Selector Sel,
   1485                                               const ObjCObjectPointerType *OPT,
   1486                                               bool Instance)
   1487 {
   1488   ObjCMethodDecl *MD = nullptr;
   1489   for (const auto *PROTO : OPT->quals()) {
   1490     if ((MD = PROTO->lookupMethod(Sel, Instance))) {
   1491       return MD;
   1492     }
   1493   }
   1494   return nullptr;
   1495 }
   1496 
   1497 static void DiagnoseARCUseOfWeakReceiver(Sema &S, Expr *Receiver) {
   1498   if (!Receiver)
   1499     return;
   1500 
   1501   if (OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(Receiver))
   1502     Receiver = OVE->getSourceExpr();
   1503 
   1504   Expr *RExpr = Receiver->IgnoreParenImpCasts();
   1505   SourceLocation Loc = RExpr->getLocStart();
   1506   QualType T = RExpr->getType();
   1507   const ObjCPropertyDecl *PDecl = nullptr;
   1508   const ObjCMethodDecl *GDecl = nullptr;
   1509   if (PseudoObjectExpr *POE = dyn_cast<PseudoObjectExpr>(RExpr)) {
   1510     RExpr = POE->getSyntacticForm();
   1511     if (ObjCPropertyRefExpr *PRE = dyn_cast<ObjCPropertyRefExpr>(RExpr)) {
   1512       if (PRE->isImplicitProperty()) {
   1513         GDecl = PRE->getImplicitPropertyGetter();
   1514         if (GDecl) {
   1515           T = GDecl->getReturnType();
   1516         }
   1517       }
   1518       else {
   1519         PDecl = PRE->getExplicitProperty();
   1520         if (PDecl) {
   1521           T = PDecl->getType();
   1522         }
   1523       }
   1524     }
   1525   }
   1526   else if (ObjCMessageExpr *ME = dyn_cast<ObjCMessageExpr>(RExpr)) {
   1527     // See if receiver is a method which envokes a synthesized getter
   1528     // backing a 'weak' property.
   1529     ObjCMethodDecl *Method = ME->getMethodDecl();
   1530     if (Method && Method->getSelector().getNumArgs() == 0) {
   1531       PDecl = Method->findPropertyDecl();
   1532       if (PDecl)
   1533         T = PDecl->getType();
   1534     }
   1535   }
   1536 
   1537   if (T.getObjCLifetime() != Qualifiers::OCL_Weak) {
   1538     if (!PDecl)
   1539       return;
   1540     if (!(PDecl->getPropertyAttributes() & ObjCPropertyDecl::OBJC_PR_weak))
   1541       return;
   1542   }
   1543 
   1544   S.Diag(Loc, diag::warn_receiver_is_weak)
   1545     << ((!PDecl && !GDecl) ? 0 : (PDecl ? 1 : 2));
   1546 
   1547   if (PDecl)
   1548     S.Diag(PDecl->getLocation(), diag::note_property_declare);
   1549   else if (GDecl)
   1550     S.Diag(GDecl->getLocation(), diag::note_method_declared_at) << GDecl;
   1551 
   1552   S.Diag(Loc, diag::note_arc_assign_to_strong);
   1553 }
   1554 
   1555 /// HandleExprPropertyRefExpr - Handle foo.bar where foo is a pointer to an
   1556 /// objective C interface.  This is a property reference expression.
   1557 ExprResult Sema::
   1558 HandleExprPropertyRefExpr(const ObjCObjectPointerType *OPT,
   1559                           Expr *BaseExpr, SourceLocation OpLoc,
   1560                           DeclarationName MemberName,
   1561                           SourceLocation MemberLoc,
   1562                           SourceLocation SuperLoc, QualType SuperType,
   1563                           bool Super) {
   1564   const ObjCInterfaceType *IFaceT = OPT->getInterfaceType();
   1565   ObjCInterfaceDecl *IFace = IFaceT->getDecl();
   1566 
   1567   if (!MemberName.isIdentifier()) {
   1568     Diag(MemberLoc, diag::err_invalid_property_name)
   1569       << MemberName << QualType(OPT, 0);
   1570     return ExprError();
   1571   }
   1572 
   1573   IdentifierInfo *Member = MemberName.getAsIdentifierInfo();
   1574 
   1575   SourceRange BaseRange = Super? SourceRange(SuperLoc)
   1576                                : BaseExpr->getSourceRange();
   1577   if (RequireCompleteType(MemberLoc, OPT->getPointeeType(),
   1578                           diag::err_property_not_found_forward_class,
   1579                           MemberName, BaseRange))
   1580     return ExprError();
   1581 
   1582   // Search for a declared property first.
   1583   if (ObjCPropertyDecl *PD = IFace->FindPropertyDeclaration(Member)) {
   1584     // Check whether we can reference this property.
   1585     if (DiagnoseUseOfDecl(PD, MemberLoc))
   1586       return ExprError();
   1587     if (Super)
   1588       return new (Context)
   1589           ObjCPropertyRefExpr(PD, Context.PseudoObjectTy, VK_LValue,
   1590                               OK_ObjCProperty, MemberLoc, SuperLoc, SuperType);
   1591     else
   1592       return new (Context)
   1593           ObjCPropertyRefExpr(PD, Context.PseudoObjectTy, VK_LValue,
   1594                               OK_ObjCProperty, MemberLoc, BaseExpr);
   1595   }
   1596   // Check protocols on qualified interfaces.
   1597   for (const auto *I : OPT->quals())
   1598     if (ObjCPropertyDecl *PD = I->FindPropertyDeclaration(Member)) {
   1599       // Check whether we can reference this property.
   1600       if (DiagnoseUseOfDecl(PD, MemberLoc))
   1601         return ExprError();
   1602 
   1603       if (Super)
   1604         return new (Context) ObjCPropertyRefExpr(
   1605             PD, Context.PseudoObjectTy, VK_LValue, OK_ObjCProperty, MemberLoc,
   1606             SuperLoc, SuperType);
   1607       else
   1608         return new (Context)
   1609             ObjCPropertyRefExpr(PD, Context.PseudoObjectTy, VK_LValue,
   1610                                 OK_ObjCProperty, MemberLoc, BaseExpr);
   1611     }
   1612   // If that failed, look for an "implicit" property by seeing if the nullary
   1613   // selector is implemented.
   1614 
   1615   // FIXME: The logic for looking up nullary and unary selectors should be
   1616   // shared with the code in ActOnInstanceMessage.
   1617 
   1618   Selector Sel = PP.getSelectorTable().getNullarySelector(Member);
   1619   ObjCMethodDecl *Getter = IFace->lookupInstanceMethod(Sel);
   1620 
   1621   // May be founf in property's qualified list.
   1622   if (!Getter)
   1623     Getter = LookupMethodInQualifiedType(Sel, OPT, true);
   1624 
   1625   // If this reference is in an @implementation, check for 'private' methods.
   1626   if (!Getter)
   1627     Getter = IFace->lookupPrivateMethod(Sel);
   1628 
   1629   if (Getter) {
   1630     // Check if we can reference this property.
   1631     if (DiagnoseUseOfDecl(Getter, MemberLoc))
   1632       return ExprError();
   1633   }
   1634   // If we found a getter then this may be a valid dot-reference, we
   1635   // will look for the matching setter, in case it is needed.
   1636   Selector SetterSel =
   1637     SelectorTable::constructSetterSelector(PP.getIdentifierTable(),
   1638                                            PP.getSelectorTable(), Member);
   1639   ObjCMethodDecl *Setter = IFace->lookupInstanceMethod(SetterSel);
   1640 
   1641   // May be founf in property's qualified list.
   1642   if (!Setter)
   1643     Setter = LookupMethodInQualifiedType(SetterSel, OPT, true);
   1644 
   1645   if (!Setter) {
   1646     // If this reference is in an @implementation, also check for 'private'
   1647     // methods.
   1648     Setter = IFace->lookupPrivateMethod(SetterSel);
   1649   }
   1650 
   1651   if (Setter && DiagnoseUseOfDecl(Setter, MemberLoc))
   1652     return ExprError();
   1653 
   1654   if (Getter || Setter) {
   1655     if (Super)
   1656       return new (Context)
   1657           ObjCPropertyRefExpr(Getter, Setter, Context.PseudoObjectTy, VK_LValue,
   1658                               OK_ObjCProperty, MemberLoc, SuperLoc, SuperType);
   1659     else
   1660       return new (Context)
   1661           ObjCPropertyRefExpr(Getter, Setter, Context.PseudoObjectTy, VK_LValue,
   1662                               OK_ObjCProperty, MemberLoc, BaseExpr);
   1663 
   1664   }
   1665 
   1666   // Attempt to correct for typos in property names.
   1667   DeclFilterCCC<ObjCPropertyDecl> Validator;
   1668   if (TypoCorrection Corrected = CorrectTypo(
   1669           DeclarationNameInfo(MemberName, MemberLoc), LookupOrdinaryName,
   1670           nullptr, nullptr, Validator, CTK_ErrorRecovery, IFace, false, OPT)) {
   1671     diagnoseTypo(Corrected, PDiag(diag::err_property_not_found_suggest)
   1672                               << MemberName << QualType(OPT, 0));
   1673     DeclarationName TypoResult = Corrected.getCorrection();
   1674     return HandleExprPropertyRefExpr(OPT, BaseExpr, OpLoc,
   1675                                      TypoResult, MemberLoc,
   1676                                      SuperLoc, SuperType, Super);
   1677   }
   1678   ObjCInterfaceDecl *ClassDeclared;
   1679   if (ObjCIvarDecl *Ivar =
   1680       IFace->lookupInstanceVariable(Member, ClassDeclared)) {
   1681     QualType T = Ivar->getType();
   1682     if (const ObjCObjectPointerType * OBJPT =
   1683         T->getAsObjCInterfacePointerType()) {
   1684       if (RequireCompleteType(MemberLoc, OBJPT->getPointeeType(),
   1685                               diag::err_property_not_as_forward_class,
   1686                               MemberName, BaseExpr))
   1687         return ExprError();
   1688     }
   1689     Diag(MemberLoc,
   1690          diag::err_ivar_access_using_property_syntax_suggest)
   1691     << MemberName << QualType(OPT, 0) << Ivar->getDeclName()
   1692     << FixItHint::CreateReplacement(OpLoc, "->");
   1693     return ExprError();
   1694   }
   1695 
   1696   Diag(MemberLoc, diag::err_property_not_found)
   1697     << MemberName << QualType(OPT, 0);
   1698   if (Setter)
   1699     Diag(Setter->getLocation(), diag::note_getter_unavailable)
   1700           << MemberName << BaseExpr->getSourceRange();
   1701   return ExprError();
   1702 }
   1703 
   1704 
   1705 
   1706 ExprResult Sema::
   1707 ActOnClassPropertyRefExpr(IdentifierInfo &receiverName,
   1708                           IdentifierInfo &propertyName,
   1709                           SourceLocation receiverNameLoc,
   1710                           SourceLocation propertyNameLoc) {
   1711 
   1712   IdentifierInfo *receiverNamePtr = &receiverName;
   1713   ObjCInterfaceDecl *IFace = getObjCInterfaceDecl(receiverNamePtr,
   1714                                                   receiverNameLoc);
   1715 
   1716   bool IsSuper = false;
   1717   if (!IFace) {
   1718     // If the "receiver" is 'super' in a method, handle it as an expression-like
   1719     // property reference.
   1720     if (receiverNamePtr->isStr("super")) {
   1721       IsSuper = true;
   1722 
   1723       if (ObjCMethodDecl *CurMethod = tryCaptureObjCSelf(receiverNameLoc)) {
   1724         if (CurMethod->isInstanceMethod()) {
   1725           ObjCInterfaceDecl *Super =
   1726             CurMethod->getClassInterface()->getSuperClass();
   1727           if (!Super) {
   1728             // The current class does not have a superclass.
   1729             Diag(receiverNameLoc, diag::error_root_class_cannot_use_super)
   1730             << CurMethod->getClassInterface()->getIdentifier();
   1731             return ExprError();
   1732           }
   1733           QualType T = Context.getObjCInterfaceType(Super);
   1734           T = Context.getObjCObjectPointerType(T);
   1735 
   1736           return HandleExprPropertyRefExpr(T->getAsObjCInterfacePointerType(),
   1737                                            /*BaseExpr*/nullptr,
   1738                                            SourceLocation()/*OpLoc*/,
   1739                                            &propertyName,
   1740                                            propertyNameLoc,
   1741                                            receiverNameLoc, T, true);
   1742         }
   1743 
   1744         // Otherwise, if this is a class method, try dispatching to our
   1745         // superclass.
   1746         IFace = CurMethod->getClassInterface()->getSuperClass();
   1747       }
   1748     }
   1749 
   1750     if (!IFace) {
   1751       Diag(receiverNameLoc, diag::err_expected_either) << tok::identifier
   1752                                                        << tok::l_paren;
   1753       return ExprError();
   1754     }
   1755   }
   1756 
   1757   // Search for a declared property first.
   1758   Selector Sel = PP.getSelectorTable().getNullarySelector(&propertyName);
   1759   ObjCMethodDecl *Getter = IFace->lookupClassMethod(Sel);
   1760 
   1761   // If this reference is in an @implementation, check for 'private' methods.
   1762   if (!Getter)
   1763     Getter = IFace->lookupPrivateClassMethod(Sel);
   1764 
   1765   if (Getter) {
   1766     // FIXME: refactor/share with ActOnMemberReference().
   1767     // Check if we can reference this property.
   1768     if (DiagnoseUseOfDecl(Getter, propertyNameLoc))
   1769       return ExprError();
   1770   }
   1771 
   1772   // Look for the matching setter, in case it is needed.
   1773   Selector SetterSel =
   1774     SelectorTable::constructSetterSelector(PP.getIdentifierTable(),
   1775                                            PP.getSelectorTable(),
   1776                                            &propertyName);
   1777 
   1778   ObjCMethodDecl *Setter = IFace->lookupClassMethod(SetterSel);
   1779   if (!Setter) {
   1780     // If this reference is in an @implementation, also check for 'private'
   1781     // methods.
   1782     Setter = IFace->lookupPrivateClassMethod(SetterSel);
   1783   }
   1784   // Look through local category implementations associated with the class.
   1785   if (!Setter)
   1786     Setter = IFace->getCategoryClassMethod(SetterSel);
   1787 
   1788   if (Setter && DiagnoseUseOfDecl(Setter, propertyNameLoc))
   1789     return ExprError();
   1790 
   1791   if (Getter || Setter) {
   1792     if (IsSuper)
   1793       return new (Context)
   1794           ObjCPropertyRefExpr(Getter, Setter, Context.PseudoObjectTy, VK_LValue,
   1795                               OK_ObjCProperty, propertyNameLoc, receiverNameLoc,
   1796                               Context.getObjCInterfaceType(IFace));
   1797 
   1798     return new (Context) ObjCPropertyRefExpr(
   1799         Getter, Setter, Context.PseudoObjectTy, VK_LValue, OK_ObjCProperty,
   1800         propertyNameLoc, receiverNameLoc, IFace);
   1801   }
   1802   return ExprError(Diag(propertyNameLoc, diag::err_property_not_found)
   1803                      << &propertyName << Context.getObjCInterfaceType(IFace));
   1804 }
   1805 
   1806 namespace {
   1807 
   1808 class ObjCInterfaceOrSuperCCC : public CorrectionCandidateCallback {
   1809  public:
   1810   ObjCInterfaceOrSuperCCC(ObjCMethodDecl *Method) {
   1811     // Determine whether "super" is acceptable in the current context.
   1812     if (Method && Method->getClassInterface())
   1813       WantObjCSuper = Method->getClassInterface()->getSuperClass();
   1814   }
   1815 
   1816   bool ValidateCandidate(const TypoCorrection &candidate) override {
   1817     return candidate.getCorrectionDeclAs<ObjCInterfaceDecl>() ||
   1818         candidate.isKeyword("super");
   1819   }
   1820 };
   1821 
   1822 }
   1823 
   1824 Sema::ObjCMessageKind Sema::getObjCMessageKind(Scope *S,
   1825                                                IdentifierInfo *Name,
   1826                                                SourceLocation NameLoc,
   1827                                                bool IsSuper,
   1828                                                bool HasTrailingDot,
   1829                                                ParsedType &ReceiverType) {
   1830   ReceiverType = ParsedType();
   1831 
   1832   // If the identifier is "super" and there is no trailing dot, we're
   1833   // messaging super. If the identifier is "super" and there is a
   1834   // trailing dot, it's an instance message.
   1835   if (IsSuper && S->isInObjcMethodScope())
   1836     return HasTrailingDot? ObjCInstanceMessage : ObjCSuperMessage;
   1837 
   1838   LookupResult Result(*this, Name, NameLoc, LookupOrdinaryName);
   1839   LookupName(Result, S);
   1840 
   1841   switch (Result.getResultKind()) {
   1842   case LookupResult::NotFound:
   1843     // Normal name lookup didn't find anything. If we're in an
   1844     // Objective-C method, look for ivars. If we find one, we're done!
   1845     // FIXME: This is a hack. Ivar lookup should be part of normal
   1846     // lookup.
   1847     if (ObjCMethodDecl *Method = getCurMethodDecl()) {
   1848       if (!Method->getClassInterface()) {
   1849         // Fall back: let the parser try to parse it as an instance message.
   1850         return ObjCInstanceMessage;
   1851       }
   1852 
   1853       ObjCInterfaceDecl *ClassDeclared;
   1854       if (Method->getClassInterface()->lookupInstanceVariable(Name,
   1855                                                               ClassDeclared))
   1856         return ObjCInstanceMessage;
   1857     }
   1858 
   1859     // Break out; we'll perform typo correction below.
   1860     break;
   1861 
   1862   case LookupResult::NotFoundInCurrentInstantiation:
   1863   case LookupResult::FoundOverloaded:
   1864   case LookupResult::FoundUnresolvedValue:
   1865   case LookupResult::Ambiguous:
   1866     Result.suppressDiagnostics();
   1867     return ObjCInstanceMessage;
   1868 
   1869   case LookupResult::Found: {
   1870     // If the identifier is a class or not, and there is a trailing dot,
   1871     // it's an instance message.
   1872     if (HasTrailingDot)
   1873       return ObjCInstanceMessage;
   1874     // We found something. If it's a type, then we have a class
   1875     // message. Otherwise, it's an instance message.
   1876     NamedDecl *ND = Result.getFoundDecl();
   1877     QualType T;
   1878     if (ObjCInterfaceDecl *Class = dyn_cast<ObjCInterfaceDecl>(ND))
   1879       T = Context.getObjCInterfaceType(Class);
   1880     else if (TypeDecl *Type = dyn_cast<TypeDecl>(ND)) {
   1881       T = Context.getTypeDeclType(Type);
   1882       DiagnoseUseOfDecl(Type, NameLoc);
   1883     }
   1884     else
   1885       return ObjCInstanceMessage;
   1886 
   1887     //  We have a class message, and T is the type we're
   1888     //  messaging. Build source-location information for it.
   1889     TypeSourceInfo *TSInfo = Context.getTrivialTypeSourceInfo(T, NameLoc);
   1890     ReceiverType = CreateParsedType(T, TSInfo);
   1891     return ObjCClassMessage;
   1892   }
   1893   }
   1894 
   1895   ObjCInterfaceOrSuperCCC Validator(getCurMethodDecl());
   1896   if (TypoCorrection Corrected =
   1897           CorrectTypo(Result.getLookupNameInfo(), Result.getLookupKind(), S,
   1898                       nullptr, Validator, CTK_ErrorRecovery, nullptr, false,
   1899                       nullptr, false)) {
   1900     if (Corrected.isKeyword()) {
   1901       // If we've found the keyword "super" (the only keyword that would be
   1902       // returned by CorrectTypo), this is a send to super.
   1903       diagnoseTypo(Corrected,
   1904                    PDiag(diag::err_unknown_receiver_suggest) << Name);
   1905       return ObjCSuperMessage;
   1906     } else if (ObjCInterfaceDecl *Class =
   1907                    Corrected.getCorrectionDeclAs<ObjCInterfaceDecl>()) {
   1908       // If we found a declaration, correct when it refers to an Objective-C
   1909       // class.
   1910       diagnoseTypo(Corrected,
   1911                    PDiag(diag::err_unknown_receiver_suggest) << Name);
   1912       QualType T = Context.getObjCInterfaceType(Class);
   1913       TypeSourceInfo *TSInfo = Context.getTrivialTypeSourceInfo(T, NameLoc);
   1914       ReceiverType = CreateParsedType(T, TSInfo);
   1915       return ObjCClassMessage;
   1916     }
   1917   }
   1918 
   1919   // Fall back: let the parser try to parse it as an instance message.
   1920   return ObjCInstanceMessage;
   1921 }
   1922 
   1923 ExprResult Sema::ActOnSuperMessage(Scope *S,
   1924                                    SourceLocation SuperLoc,
   1925                                    Selector Sel,
   1926                                    SourceLocation LBracLoc,
   1927                                    ArrayRef<SourceLocation> SelectorLocs,
   1928                                    SourceLocation RBracLoc,
   1929                                    MultiExprArg Args) {
   1930   // Determine whether we are inside a method or not.
   1931   ObjCMethodDecl *Method = tryCaptureObjCSelf(SuperLoc);
   1932   if (!Method) {
   1933     Diag(SuperLoc, diag::err_invalid_receiver_to_message_super);
   1934     return ExprError();
   1935   }
   1936 
   1937   ObjCInterfaceDecl *Class = Method->getClassInterface();
   1938   if (!Class) {
   1939     Diag(SuperLoc, diag::error_no_super_class_message)
   1940       << Method->getDeclName();
   1941     return ExprError();
   1942   }
   1943 
   1944   ObjCInterfaceDecl *Super = Class->getSuperClass();
   1945   if (!Super) {
   1946     // The current class does not have a superclass.
   1947     Diag(SuperLoc, diag::error_root_class_cannot_use_super)
   1948       << Class->getIdentifier();
   1949     return ExprError();
   1950   }
   1951 
   1952   // We are in a method whose class has a superclass, so 'super'
   1953   // is acting as a keyword.
   1954   if (Method->getSelector() == Sel)
   1955     getCurFunction()->ObjCShouldCallSuper = false;
   1956 
   1957   if (Method->isInstanceMethod()) {
   1958     // Since we are in an instance method, this is an instance
   1959     // message to the superclass instance.
   1960     QualType SuperTy = Context.getObjCInterfaceType(Super);
   1961     SuperTy = Context.getObjCObjectPointerType(SuperTy);
   1962     return BuildInstanceMessage(nullptr, SuperTy, SuperLoc,
   1963                                 Sel, /*Method=*/nullptr,
   1964                                 LBracLoc, SelectorLocs, RBracLoc, Args);
   1965   }
   1966 
   1967   // Since we are in a class method, this is a class message to
   1968   // the superclass.
   1969   return BuildClassMessage(/*ReceiverTypeInfo=*/nullptr,
   1970                            Context.getObjCInterfaceType(Super),
   1971                            SuperLoc, Sel, /*Method=*/nullptr,
   1972                            LBracLoc, SelectorLocs, RBracLoc, Args);
   1973 }
   1974 
   1975 
   1976 ExprResult Sema::BuildClassMessageImplicit(QualType ReceiverType,
   1977                                            bool isSuperReceiver,
   1978                                            SourceLocation Loc,
   1979                                            Selector Sel,
   1980                                            ObjCMethodDecl *Method,
   1981                                            MultiExprArg Args) {
   1982   TypeSourceInfo *receiverTypeInfo = nullptr;
   1983   if (!ReceiverType.isNull())
   1984     receiverTypeInfo = Context.getTrivialTypeSourceInfo(ReceiverType);
   1985 
   1986   return BuildClassMessage(receiverTypeInfo, ReceiverType,
   1987                           /*SuperLoc=*/isSuperReceiver ? Loc : SourceLocation(),
   1988                            Sel, Method, Loc, Loc, Loc, Args,
   1989                            /*isImplicit=*/true);
   1990 
   1991 }
   1992 
   1993 static void applyCocoaAPICheck(Sema &S, const ObjCMessageExpr *Msg,
   1994                                unsigned DiagID,
   1995                                bool (*refactor)(const ObjCMessageExpr *,
   1996                                               const NSAPI &, edit::Commit &)) {
   1997   SourceLocation MsgLoc = Msg->getExprLoc();
   1998   if (S.Diags.isIgnored(DiagID, MsgLoc))
   1999     return;
   2000 
   2001   SourceManager &SM = S.SourceMgr;
   2002   edit::Commit ECommit(SM, S.LangOpts);
   2003   if (refactor(Msg,*S.NSAPIObj, ECommit)) {
   2004     DiagnosticBuilder Builder = S.Diag(MsgLoc, DiagID)
   2005                         << Msg->getSelector() << Msg->getSourceRange();
   2006     // FIXME: Don't emit diagnostic at all if fixits are non-commitable.
   2007     if (!ECommit.isCommitable())
   2008       return;
   2009     for (edit::Commit::edit_iterator
   2010            I = ECommit.edit_begin(), E = ECommit.edit_end(); I != E; ++I) {
   2011       const edit::Commit::Edit &Edit = *I;
   2012       switch (Edit.Kind) {
   2013       case edit::Commit::Act_Insert:
   2014         Builder.AddFixItHint(FixItHint::CreateInsertion(Edit.OrigLoc,
   2015                                                         Edit.Text,
   2016                                                         Edit.BeforePrev));
   2017         break;
   2018       case edit::Commit::Act_InsertFromRange:
   2019         Builder.AddFixItHint(
   2020             FixItHint::CreateInsertionFromRange(Edit.OrigLoc,
   2021                                                 Edit.getInsertFromRange(SM),
   2022                                                 Edit.BeforePrev));
   2023         break;
   2024       case edit::Commit::Act_Remove:
   2025         Builder.AddFixItHint(FixItHint::CreateRemoval(Edit.getFileRange(SM)));
   2026         break;
   2027       }
   2028     }
   2029   }
   2030 }
   2031 
   2032 static void checkCocoaAPI(Sema &S, const ObjCMessageExpr *Msg) {
   2033   applyCocoaAPICheck(S, Msg, diag::warn_objc_redundant_literal_use,
   2034                      edit::rewriteObjCRedundantCallWithLiteral);
   2035 }
   2036 
   2037 /// \brief Build an Objective-C class message expression.
   2038 ///
   2039 /// This routine takes care of both normal class messages and
   2040 /// class messages to the superclass.
   2041 ///
   2042 /// \param ReceiverTypeInfo Type source information that describes the
   2043 /// receiver of this message. This may be NULL, in which case we are
   2044 /// sending to the superclass and \p SuperLoc must be a valid source
   2045 /// location.
   2046 
   2047 /// \param ReceiverType The type of the object receiving the
   2048 /// message. When \p ReceiverTypeInfo is non-NULL, this is the same
   2049 /// type as that refers to. For a superclass send, this is the type of
   2050 /// the superclass.
   2051 ///
   2052 /// \param SuperLoc The location of the "super" keyword in a
   2053 /// superclass message.
   2054 ///
   2055 /// \param Sel The selector to which the message is being sent.
   2056 ///
   2057 /// \param Method The method that this class message is invoking, if
   2058 /// already known.
   2059 ///
   2060 /// \param LBracLoc The location of the opening square bracket ']'.
   2061 ///
   2062 /// \param RBracLoc The location of the closing square bracket ']'.
   2063 ///
   2064 /// \param ArgsIn The message arguments.
   2065 ExprResult Sema::BuildClassMessage(TypeSourceInfo *ReceiverTypeInfo,
   2066                                    QualType ReceiverType,
   2067                                    SourceLocation SuperLoc,
   2068                                    Selector Sel,
   2069                                    ObjCMethodDecl *Method,
   2070                                    SourceLocation LBracLoc,
   2071                                    ArrayRef<SourceLocation> SelectorLocs,
   2072                                    SourceLocation RBracLoc,
   2073                                    MultiExprArg ArgsIn,
   2074                                    bool isImplicit) {
   2075   SourceLocation Loc = SuperLoc.isValid()? SuperLoc
   2076     : ReceiverTypeInfo->getTypeLoc().getSourceRange().getBegin();
   2077   if (LBracLoc.isInvalid()) {
   2078     Diag(Loc, diag::err_missing_open_square_message_send)
   2079       << FixItHint::CreateInsertion(Loc, "[");
   2080     LBracLoc = Loc;
   2081   }
   2082   SourceLocation SelLoc;
   2083   if (!SelectorLocs.empty() && SelectorLocs.front().isValid())
   2084     SelLoc = SelectorLocs.front();
   2085   else
   2086     SelLoc = Loc;
   2087 
   2088   if (ReceiverType->isDependentType()) {
   2089     // If the receiver type is dependent, we can't type-check anything
   2090     // at this point. Build a dependent expression.
   2091     unsigned NumArgs = ArgsIn.size();
   2092     Expr **Args = ArgsIn.data();
   2093     assert(SuperLoc.isInvalid() && "Message to super with dependent type");
   2094     return ObjCMessageExpr::Create(
   2095         Context, ReceiverType, VK_RValue, LBracLoc, ReceiverTypeInfo, Sel,
   2096         SelectorLocs, /*Method=*/nullptr, makeArrayRef(Args, NumArgs), RBracLoc,
   2097         isImplicit);
   2098   }
   2099 
   2100   // Find the class to which we are sending this message.
   2101   ObjCInterfaceDecl *Class = nullptr;
   2102   const ObjCObjectType *ClassType = ReceiverType->getAs<ObjCObjectType>();
   2103   if (!ClassType || !(Class = ClassType->getInterface())) {
   2104     Diag(Loc, diag::err_invalid_receiver_class_message)
   2105       << ReceiverType;
   2106     return ExprError();
   2107   }
   2108   assert(Class && "We don't know which class we're messaging?");
   2109   // objc++ diagnoses during typename annotation.
   2110   if (!getLangOpts().CPlusPlus)
   2111     (void)DiagnoseUseOfDecl(Class, SelLoc);
   2112   // Find the method we are messaging.
   2113   if (!Method) {
   2114     SourceRange TypeRange
   2115       = SuperLoc.isValid()? SourceRange(SuperLoc)
   2116                           : ReceiverTypeInfo->getTypeLoc().getSourceRange();
   2117     if (RequireCompleteType(Loc, Context.getObjCInterfaceType(Class),
   2118                             (getLangOpts().ObjCAutoRefCount
   2119                                ? diag::err_arc_receiver_forward_class
   2120                                : diag::warn_receiver_forward_class),
   2121                             TypeRange)) {
   2122       // A forward class used in messaging is treated as a 'Class'
   2123       Method = LookupFactoryMethodInGlobalPool(Sel,
   2124                                                SourceRange(LBracLoc, RBracLoc));
   2125       if (Method && !getLangOpts().ObjCAutoRefCount)
   2126         Diag(Method->getLocation(), diag::note_method_sent_forward_class)
   2127           << Method->getDeclName();
   2128     }
   2129     if (!Method)
   2130       Method = Class->lookupClassMethod(Sel);
   2131 
   2132     // If we have an implementation in scope, check "private" methods.
   2133     if (!Method)
   2134       Method = Class->lookupPrivateClassMethod(Sel);
   2135 
   2136     if (Method && DiagnoseUseOfDecl(Method, SelLoc))
   2137       return ExprError();
   2138   }
   2139 
   2140   // Check the argument types and determine the result type.
   2141   QualType ReturnType;
   2142   ExprValueKind VK = VK_RValue;
   2143 
   2144   unsigned NumArgs = ArgsIn.size();
   2145   Expr **Args = ArgsIn.data();
   2146   if (CheckMessageArgumentTypes(ReceiverType, MultiExprArg(Args, NumArgs),
   2147                                 Sel, SelectorLocs,
   2148                                 Method, true,
   2149                                 SuperLoc.isValid(), LBracLoc, RBracLoc,
   2150                                 ReturnType, VK))
   2151     return ExprError();
   2152 
   2153   if (Method && !Method->getReturnType()->isVoidType() &&
   2154       RequireCompleteType(LBracLoc, Method->getReturnType(),
   2155                           diag::err_illegal_message_expr_incomplete_type))
   2156     return ExprError();
   2157 
   2158   // Construct the appropriate ObjCMessageExpr.
   2159   ObjCMessageExpr *Result;
   2160   if (SuperLoc.isValid())
   2161     Result = ObjCMessageExpr::Create(Context, ReturnType, VK, LBracLoc,
   2162                                      SuperLoc, /*IsInstanceSuper=*/false,
   2163                                      ReceiverType, Sel, SelectorLocs,
   2164                                      Method, makeArrayRef(Args, NumArgs),
   2165                                      RBracLoc, isImplicit);
   2166   else {
   2167     Result = ObjCMessageExpr::Create(Context, ReturnType, VK, LBracLoc,
   2168                                      ReceiverTypeInfo, Sel, SelectorLocs,
   2169                                      Method, makeArrayRef(Args, NumArgs),
   2170                                      RBracLoc, isImplicit);
   2171     if (!isImplicit)
   2172       checkCocoaAPI(*this, Result);
   2173   }
   2174   return MaybeBindToTemporary(Result);
   2175 }
   2176 
   2177 // ActOnClassMessage - used for both unary and keyword messages.
   2178 // ArgExprs is optional - if it is present, the number of expressions
   2179 // is obtained from Sel.getNumArgs().
   2180 ExprResult Sema::ActOnClassMessage(Scope *S,
   2181                                    ParsedType Receiver,
   2182                                    Selector Sel,
   2183                                    SourceLocation LBracLoc,
   2184                                    ArrayRef<SourceLocation> SelectorLocs,
   2185                                    SourceLocation RBracLoc,
   2186                                    MultiExprArg Args) {
   2187   TypeSourceInfo *ReceiverTypeInfo;
   2188   QualType ReceiverType = GetTypeFromParser(Receiver, &ReceiverTypeInfo);
   2189   if (ReceiverType.isNull())
   2190     return ExprError();
   2191 
   2192 
   2193   if (!ReceiverTypeInfo)
   2194     ReceiverTypeInfo = Context.getTrivialTypeSourceInfo(ReceiverType, LBracLoc);
   2195 
   2196   return BuildClassMessage(ReceiverTypeInfo, ReceiverType,
   2197                            /*SuperLoc=*/SourceLocation(), Sel,
   2198                            /*Method=*/nullptr, LBracLoc, SelectorLocs, RBracLoc,
   2199                            Args);
   2200 }
   2201 
   2202 ExprResult Sema::BuildInstanceMessageImplicit(Expr *Receiver,
   2203                                               QualType ReceiverType,
   2204                                               SourceLocation Loc,
   2205                                               Selector Sel,
   2206                                               ObjCMethodDecl *Method,
   2207                                               MultiExprArg Args) {
   2208   return BuildInstanceMessage(Receiver, ReceiverType,
   2209                               /*SuperLoc=*/!Receiver ? Loc : SourceLocation(),
   2210                               Sel, Method, Loc, Loc, Loc, Args,
   2211                               /*isImplicit=*/true);
   2212 }
   2213 
   2214 /// \brief Build an Objective-C instance message expression.
   2215 ///
   2216 /// This routine takes care of both normal instance messages and
   2217 /// instance messages to the superclass instance.
   2218 ///
   2219 /// \param Receiver The expression that computes the object that will
   2220 /// receive this message. This may be empty, in which case we are
   2221 /// sending to the superclass instance and \p SuperLoc must be a valid
   2222 /// source location.
   2223 ///
   2224 /// \param ReceiverType The (static) type of the object receiving the
   2225 /// message. When a \p Receiver expression is provided, this is the
   2226 /// same type as that expression. For a superclass instance send, this
   2227 /// is a pointer to the type of the superclass.
   2228 ///
   2229 /// \param SuperLoc The location of the "super" keyword in a
   2230 /// superclass instance message.
   2231 ///
   2232 /// \param Sel The selector to which the message is being sent.
   2233 ///
   2234 /// \param Method The method that this instance message is invoking, if
   2235 /// already known.
   2236 ///
   2237 /// \param LBracLoc The location of the opening square bracket ']'.
   2238 ///
   2239 /// \param RBracLoc The location of the closing square bracket ']'.
   2240 ///
   2241 /// \param ArgsIn The message arguments.
   2242 ExprResult Sema::BuildInstanceMessage(Expr *Receiver,
   2243                                       QualType ReceiverType,
   2244                                       SourceLocation SuperLoc,
   2245                                       Selector Sel,
   2246                                       ObjCMethodDecl *Method,
   2247                                       SourceLocation LBracLoc,
   2248                                       ArrayRef<SourceLocation> SelectorLocs,
   2249                                       SourceLocation RBracLoc,
   2250                                       MultiExprArg ArgsIn,
   2251                                       bool isImplicit) {
   2252   // The location of the receiver.
   2253   SourceLocation Loc = SuperLoc.isValid()? SuperLoc : Receiver->getLocStart();
   2254   SourceRange RecRange =
   2255       SuperLoc.isValid()? SuperLoc : Receiver->getSourceRange();
   2256   SourceLocation SelLoc;
   2257   if (!SelectorLocs.empty() && SelectorLocs.front().isValid())
   2258     SelLoc = SelectorLocs.front();
   2259   else
   2260     SelLoc = Loc;
   2261 
   2262   if (LBracLoc.isInvalid()) {
   2263     Diag(Loc, diag::err_missing_open_square_message_send)
   2264       << FixItHint::CreateInsertion(Loc, "[");
   2265     LBracLoc = Loc;
   2266   }
   2267 
   2268   // If we have a receiver expression, perform appropriate promotions
   2269   // and determine receiver type.
   2270   if (Receiver) {
   2271     if (Receiver->hasPlaceholderType()) {
   2272       ExprResult Result;
   2273       if (Receiver->getType() == Context.UnknownAnyTy)
   2274         Result = forceUnknownAnyToType(Receiver, Context.getObjCIdType());
   2275       else
   2276         Result = CheckPlaceholderExpr(Receiver);
   2277       if (Result.isInvalid()) return ExprError();
   2278       Receiver = Result.get();
   2279     }
   2280 
   2281     if (Receiver->isTypeDependent()) {
   2282       // If the receiver is type-dependent, we can't type-check anything
   2283       // at this point. Build a dependent expression.
   2284       unsigned NumArgs = ArgsIn.size();
   2285       Expr **Args = ArgsIn.data();
   2286       assert(SuperLoc.isInvalid() && "Message to super with dependent type");
   2287       return ObjCMessageExpr::Create(
   2288           Context, Context.DependentTy, VK_RValue, LBracLoc, Receiver, Sel,
   2289           SelectorLocs, /*Method=*/nullptr, makeArrayRef(Args, NumArgs),
   2290           RBracLoc, isImplicit);
   2291     }
   2292 
   2293     // If necessary, apply function/array conversion to the receiver.
   2294     // C99 6.7.5.3p[7,8].
   2295     ExprResult Result = DefaultFunctionArrayLvalueConversion(Receiver);
   2296     if (Result.isInvalid())
   2297       return ExprError();
   2298     Receiver = Result.get();
   2299     ReceiverType = Receiver->getType();
   2300 
   2301     // If the receiver is an ObjC pointer, a block pointer, or an
   2302     // __attribute__((NSObject)) pointer, we don't need to do any
   2303     // special conversion in order to look up a receiver.
   2304     if (ReceiverType->isObjCRetainableType()) {
   2305       // do nothing
   2306     } else if (!getLangOpts().ObjCAutoRefCount &&
   2307                !Context.getObjCIdType().isNull() &&
   2308                (ReceiverType->isPointerType() ||
   2309                 ReceiverType->isIntegerType())) {
   2310       // Implicitly convert integers and pointers to 'id' but emit a warning.
   2311       // But not in ARC.
   2312       Diag(Loc, diag::warn_bad_receiver_type)
   2313         << ReceiverType
   2314         << Receiver->getSourceRange();
   2315       if (ReceiverType->isPointerType()) {
   2316         Receiver = ImpCastExprToType(Receiver, Context.getObjCIdType(),
   2317                                      CK_CPointerToObjCPointerCast).get();
   2318       } else {
   2319         // TODO: specialized warning on null receivers?
   2320         bool IsNull = Receiver->isNullPointerConstant(Context,
   2321                                               Expr::NPC_ValueDependentIsNull);
   2322         CastKind Kind = IsNull ? CK_NullToPointer : CK_IntegralToPointer;
   2323         Receiver = ImpCastExprToType(Receiver, Context.getObjCIdType(),
   2324                                      Kind).get();
   2325       }
   2326       ReceiverType = Receiver->getType();
   2327     } else if (getLangOpts().CPlusPlus) {
   2328       // The receiver must be a complete type.
   2329       if (RequireCompleteType(Loc, Receiver->getType(),
   2330                               diag::err_incomplete_receiver_type))
   2331         return ExprError();
   2332 
   2333       ExprResult result = PerformContextuallyConvertToObjCPointer(Receiver);
   2334       if (result.isUsable()) {
   2335         Receiver = result.get();
   2336         ReceiverType = Receiver->getType();
   2337       }
   2338     }
   2339   }
   2340 
   2341   // There's a somewhat weird interaction here where we assume that we
   2342   // won't actually have a method unless we also don't need to do some
   2343   // of the more detailed type-checking on the receiver.
   2344 
   2345   if (!Method) {
   2346     // Handle messages to id.
   2347     bool receiverIsId = ReceiverType->isObjCIdType();
   2348     if (receiverIsId || ReceiverType->isBlockPointerType() ||
   2349         (Receiver && Context.isObjCNSObjectType(Receiver->getType()))) {
   2350       Method = LookupInstanceMethodInGlobalPool(Sel,
   2351                                                 SourceRange(LBracLoc, RBracLoc),
   2352                                                 receiverIsId);
   2353       if (!Method)
   2354         Method = LookupFactoryMethodInGlobalPool(Sel,
   2355                                                  SourceRange(LBracLoc,RBracLoc),
   2356                                                  receiverIsId);
   2357     } else if (ReceiverType->isObjCClassType() ||
   2358                ReceiverType->isObjCQualifiedClassType()) {
   2359       // Handle messages to Class.
   2360       // We allow sending a message to a qualified Class ("Class<foo>"), which
   2361       // is ok as long as one of the protocols implements the selector (if not, warn).
   2362       if (const ObjCObjectPointerType *QClassTy
   2363             = ReceiverType->getAsObjCQualifiedClassType()) {
   2364         // Search protocols for class methods.
   2365         Method = LookupMethodInQualifiedType(Sel, QClassTy, false);
   2366         if (!Method) {
   2367           Method = LookupMethodInQualifiedType(Sel, QClassTy, true);
   2368           // warn if instance method found for a Class message.
   2369           if (Method) {
   2370             Diag(SelLoc, diag::warn_instance_method_on_class_found)
   2371               << Method->getSelector() << Sel;
   2372             Diag(Method->getLocation(), diag::note_method_declared_at)
   2373               << Method->getDeclName();
   2374           }
   2375         }
   2376       } else {
   2377         if (ObjCMethodDecl *CurMeth = getCurMethodDecl()) {
   2378           if (ObjCInterfaceDecl *ClassDecl = CurMeth->getClassInterface()) {
   2379             // First check the public methods in the class interface.
   2380             Method = ClassDecl->lookupClassMethod(Sel);
   2381 
   2382             if (!Method)
   2383               Method = ClassDecl->lookupPrivateClassMethod(Sel);
   2384           }
   2385           if (Method && DiagnoseUseOfDecl(Method, SelLoc))
   2386             return ExprError();
   2387         }
   2388         if (!Method) {
   2389           // If not messaging 'self', look for any factory method named 'Sel'.
   2390           if (!Receiver || !isSelfExpr(Receiver)) {
   2391             Method = LookupFactoryMethodInGlobalPool(Sel,
   2392                                                 SourceRange(LBracLoc, RBracLoc),
   2393                                                      true);
   2394             if (!Method) {
   2395               // If no class (factory) method was found, check if an _instance_
   2396               // method of the same name exists in the root class only.
   2397               Method = LookupInstanceMethodInGlobalPool(Sel,
   2398                                                SourceRange(LBracLoc, RBracLoc),
   2399                                                         true);
   2400               if (Method)
   2401                   if (const ObjCInterfaceDecl *ID =
   2402                       dyn_cast<ObjCInterfaceDecl>(Method->getDeclContext())) {
   2403                     if (ID->getSuperClass())
   2404                       Diag(SelLoc, diag::warn_root_inst_method_not_found)
   2405                       << Sel << SourceRange(LBracLoc, RBracLoc);
   2406                   }
   2407             }
   2408           }
   2409         }
   2410       }
   2411     } else {
   2412       ObjCInterfaceDecl *ClassDecl = nullptr;
   2413 
   2414       // We allow sending a message to a qualified ID ("id<foo>"), which is ok as
   2415       // long as one of the protocols implements the selector (if not, warn).
   2416       // And as long as message is not deprecated/unavailable (warn if it is).
   2417       if (const ObjCObjectPointerType *QIdTy
   2418                                    = ReceiverType->getAsObjCQualifiedIdType()) {
   2419         // Search protocols for instance methods.
   2420         Method = LookupMethodInQualifiedType(Sel, QIdTy, true);
   2421         if (!Method)
   2422           Method = LookupMethodInQualifiedType(Sel, QIdTy, false);
   2423         if (Method && DiagnoseUseOfDecl(Method, SelLoc))
   2424           return ExprError();
   2425       } else if (const ObjCObjectPointerType *OCIType
   2426                    = ReceiverType->getAsObjCInterfacePointerType()) {
   2427         // We allow sending a message to a pointer to an interface (an object).
   2428         ClassDecl = OCIType->getInterfaceDecl();
   2429 
   2430         // Try to complete the type. Under ARC, this is a hard error from which
   2431         // we don't try to recover.
   2432         const ObjCInterfaceDecl *forwardClass = nullptr;
   2433         if (RequireCompleteType(Loc, OCIType->getPointeeType(),
   2434               getLangOpts().ObjCAutoRefCount
   2435                 ? diag::err_arc_receiver_forward_instance
   2436                 : diag::warn_receiver_forward_instance,
   2437                                 Receiver? Receiver->getSourceRange()
   2438                                         : SourceRange(SuperLoc))) {
   2439           if (getLangOpts().ObjCAutoRefCount)
   2440             return ExprError();
   2441 
   2442           forwardClass = OCIType->getInterfaceDecl();
   2443           Diag(Receiver ? Receiver->getLocStart()
   2444                         : SuperLoc, diag::note_receiver_is_id);
   2445           Method = nullptr;
   2446         } else {
   2447           Method = ClassDecl->lookupInstanceMethod(Sel);
   2448         }
   2449 
   2450         if (!Method)
   2451           // Search protocol qualifiers.
   2452           Method = LookupMethodInQualifiedType(Sel, OCIType, true);
   2453 
   2454         if (!Method) {
   2455           // If we have implementations in scope, check "private" methods.
   2456           Method = ClassDecl->lookupPrivateMethod(Sel);
   2457 
   2458           if (!Method && getLangOpts().ObjCAutoRefCount) {
   2459             Diag(SelLoc, diag::err_arc_may_not_respond)
   2460               << OCIType->getPointeeType() << Sel << RecRange
   2461               << SourceRange(SelectorLocs.front(), SelectorLocs.back());
   2462             return ExprError();
   2463           }
   2464 
   2465           if (!Method && (!Receiver || !isSelfExpr(Receiver))) {
   2466             // If we still haven't found a method, look in the global pool. This
   2467             // behavior isn't very desirable, however we need it for GCC
   2468             // compatibility. FIXME: should we deviate??
   2469             if (OCIType->qual_empty()) {
   2470               Method = LookupInstanceMethodInGlobalPool(Sel,
   2471                                               SourceRange(LBracLoc, RBracLoc));
   2472               if (Method && !forwardClass)
   2473                 Diag(SelLoc, diag::warn_maynot_respond)
   2474                   << OCIType->getInterfaceDecl()->getIdentifier()
   2475                   << Sel << RecRange;
   2476             }
   2477           }
   2478         }
   2479         if (Method && DiagnoseUseOfDecl(Method, SelLoc, forwardClass))
   2480           return ExprError();
   2481       } else {
   2482         // Reject other random receiver types (e.g. structs).
   2483         Diag(Loc, diag::err_bad_receiver_type)
   2484           << ReceiverType << Receiver->getSourceRange();
   2485         return ExprError();
   2486       }
   2487     }
   2488   }
   2489 
   2490   FunctionScopeInfo *DIFunctionScopeInfo =
   2491     (Method && Method->getMethodFamily() == OMF_init)
   2492       ? getEnclosingFunction() : nullptr;
   2493 
   2494   if (DIFunctionScopeInfo &&
   2495       DIFunctionScopeInfo->ObjCIsDesignatedInit &&
   2496       (SuperLoc.isValid() || isSelfExpr(Receiver))) {
   2497     bool isDesignatedInitChain = false;
   2498     if (SuperLoc.isValid()) {
   2499       if (const ObjCObjectPointerType *
   2500             OCIType = ReceiverType->getAsObjCInterfacePointerType()) {
   2501         if (const ObjCInterfaceDecl *ID = OCIType->getInterfaceDecl()) {
   2502           // Either we know this is a designated initializer or we
   2503           // conservatively assume it because we don't know for sure.
   2504           if (!ID->declaresOrInheritsDesignatedInitializers() ||
   2505               ID->isDesignatedInitializer(Sel)) {
   2506             isDesignatedInitChain = true;
   2507             DIFunctionScopeInfo->ObjCWarnForNoDesignatedInitChain = false;
   2508           }
   2509         }
   2510       }
   2511     }
   2512     if (!isDesignatedInitChain) {
   2513       const ObjCMethodDecl *InitMethod = nullptr;
   2514       bool isDesignated =
   2515         getCurMethodDecl()->isDesignatedInitializerForTheInterface(&InitMethod);
   2516       assert(isDesignated && InitMethod);
   2517       (void)isDesignated;
   2518       Diag(SelLoc, SuperLoc.isValid() ?
   2519              diag::warn_objc_designated_init_non_designated_init_call :
   2520              diag::warn_objc_designated_init_non_super_designated_init_call);
   2521       Diag(InitMethod->getLocation(),
   2522            diag::note_objc_designated_init_marked_here);
   2523     }
   2524   }
   2525 
   2526   if (DIFunctionScopeInfo &&
   2527       DIFunctionScopeInfo->ObjCIsSecondaryInit &&
   2528       (SuperLoc.isValid() || isSelfExpr(Receiver))) {
   2529     if (SuperLoc.isValid()) {
   2530       Diag(SelLoc, diag::warn_objc_secondary_init_super_init_call);
   2531     } else {
   2532       DIFunctionScopeInfo->ObjCWarnForNoInitDelegation = false;
   2533     }
   2534   }
   2535 
   2536   // Check the message arguments.
   2537   unsigned NumArgs = ArgsIn.size();
   2538   Expr **Args = ArgsIn.data();
   2539   QualType ReturnType;
   2540   ExprValueKind VK = VK_RValue;
   2541   bool ClassMessage = (ReceiverType->isObjCClassType() ||
   2542                        ReceiverType->isObjCQualifiedClassType());
   2543   if (CheckMessageArgumentTypes(ReceiverType, MultiExprArg(Args, NumArgs),
   2544                                 Sel, SelectorLocs, Method,
   2545                                 ClassMessage, SuperLoc.isValid(),
   2546                                 LBracLoc, RBracLoc, ReturnType, VK))
   2547     return ExprError();
   2548 
   2549   if (Method && !Method->getReturnType()->isVoidType() &&
   2550       RequireCompleteType(LBracLoc, Method->getReturnType(),
   2551                           diag::err_illegal_message_expr_incomplete_type))
   2552     return ExprError();
   2553 
   2554   // In ARC, forbid the user from sending messages to
   2555   // retain/release/autorelease/dealloc/retainCount explicitly.
   2556   if (getLangOpts().ObjCAutoRefCount) {
   2557     ObjCMethodFamily family =
   2558       (Method ? Method->getMethodFamily() : Sel.getMethodFamily());
   2559     switch (family) {
   2560     case OMF_init:
   2561       if (Method)
   2562         checkInitMethod(Method, ReceiverType);
   2563 
   2564     case OMF_None:
   2565     case OMF_alloc:
   2566     case OMF_copy:
   2567     case OMF_finalize:
   2568     case OMF_mutableCopy:
   2569     case OMF_new:
   2570     case OMF_self:
   2571       break;
   2572 
   2573     case OMF_dealloc:
   2574     case OMF_retain:
   2575     case OMF_release:
   2576     case OMF_autorelease:
   2577     case OMF_retainCount:
   2578       Diag(SelLoc, diag::err_arc_illegal_explicit_message)
   2579         << Sel << RecRange;
   2580       break;
   2581 
   2582     case OMF_performSelector:
   2583       if (Method && NumArgs >= 1) {
   2584         if (ObjCSelectorExpr *SelExp = dyn_cast<ObjCSelectorExpr>(Args[0])) {
   2585           Selector ArgSel = SelExp->getSelector();
   2586           ObjCMethodDecl *SelMethod =
   2587             LookupInstanceMethodInGlobalPool(ArgSel,
   2588                                              SelExp->getSourceRange());
   2589           if (!SelMethod)
   2590             SelMethod =
   2591               LookupFactoryMethodInGlobalPool(ArgSel,
   2592                                               SelExp->getSourceRange());
   2593           if (SelMethod) {
   2594             ObjCMethodFamily SelFamily = SelMethod->getMethodFamily();
   2595             switch (SelFamily) {
   2596               case OMF_alloc:
   2597               case OMF_copy:
   2598               case OMF_mutableCopy:
   2599               case OMF_new:
   2600               case OMF_self:
   2601               case OMF_init:
   2602                 // Issue error, unless ns_returns_not_retained.
   2603                 if (!SelMethod->hasAttr<NSReturnsNotRetainedAttr>()) {
   2604                   // selector names a +1 method
   2605                   Diag(SelLoc,
   2606                        diag::err_arc_perform_selector_retains);
   2607                   Diag(SelMethod->getLocation(), diag::note_method_declared_at)
   2608                     << SelMethod->getDeclName();
   2609                 }
   2610                 break;
   2611               default:
   2612                 // +0 call. OK. unless ns_returns_retained.
   2613                 if (SelMethod->hasAttr<NSReturnsRetainedAttr>()) {
   2614                   // selector names a +1 method
   2615                   Diag(SelLoc,
   2616                        diag::err_arc_perform_selector_retains);
   2617                   Diag(SelMethod->getLocation(), diag::note_method_declared_at)
   2618                     << SelMethod->getDeclName();
   2619                 }
   2620                 break;
   2621             }
   2622           }
   2623         } else {
   2624           // error (may leak).
   2625           Diag(SelLoc, diag::warn_arc_perform_selector_leaks);
   2626           Diag(Args[0]->getExprLoc(), diag::note_used_here);
   2627         }
   2628       }
   2629       break;
   2630     }
   2631   }
   2632 
   2633   // Construct the appropriate ObjCMessageExpr instance.
   2634   ObjCMessageExpr *Result;
   2635   if (SuperLoc.isValid())
   2636     Result = ObjCMessageExpr::Create(Context, ReturnType, VK, LBracLoc,
   2637                                      SuperLoc,  /*IsInstanceSuper=*/true,
   2638                                      ReceiverType, Sel, SelectorLocs, Method,
   2639                                      makeArrayRef(Args, NumArgs), RBracLoc,
   2640                                      isImplicit);
   2641   else {
   2642     Result = ObjCMessageExpr::Create(Context, ReturnType, VK, LBracLoc,
   2643                                      Receiver, Sel, SelectorLocs, Method,
   2644                                      makeArrayRef(Args, NumArgs), RBracLoc,
   2645                                      isImplicit);
   2646     if (!isImplicit)
   2647       checkCocoaAPI(*this, Result);
   2648   }
   2649 
   2650   if (getLangOpts().ObjCAutoRefCount) {
   2651     // Do not warn about IBOutlet weak property receivers being set to null
   2652     // as this cannot asynchronously happen.
   2653     bool WarnWeakReceiver = true;
   2654     if (isImplicit && Method)
   2655       if (const ObjCPropertyDecl *PropertyDecl = Method->findPropertyDecl())
   2656         WarnWeakReceiver = !PropertyDecl->hasAttr<IBOutletAttr>();
   2657     if (WarnWeakReceiver)
   2658       DiagnoseARCUseOfWeakReceiver(*this, Receiver);
   2659 
   2660     // In ARC, annotate delegate init calls.
   2661     if (Result->getMethodFamily() == OMF_init &&
   2662         (SuperLoc.isValid() || isSelfExpr(Receiver))) {
   2663       // Only consider init calls *directly* in init implementations,
   2664       // not within blocks.
   2665       ObjCMethodDecl *method = dyn_cast<ObjCMethodDecl>(CurContext);
   2666       if (method && method->getMethodFamily() == OMF_init) {
   2667         // The implicit assignment to self means we also don't want to
   2668         // consume the result.
   2669         Result->setDelegateInitCall(true);
   2670         return Result;
   2671       }
   2672     }
   2673 
   2674     // In ARC, check for message sends which are likely to introduce
   2675     // retain cycles.
   2676     checkRetainCycles(Result);
   2677 
   2678     if (!isImplicit && Method) {
   2679       if (const ObjCPropertyDecl *Prop = Method->findPropertyDecl()) {
   2680         bool IsWeak =
   2681           Prop->getPropertyAttributes() & ObjCPropertyDecl::OBJC_PR_weak;
   2682         if (!IsWeak && Sel.isUnarySelector())
   2683           IsWeak = ReturnType.getObjCLifetime() & Qualifiers::OCL_Weak;
   2684         if (IsWeak &&
   2685             !Diags.isIgnored(diag::warn_arc_repeated_use_of_weak, LBracLoc))
   2686           getCurFunction()->recordUseOfWeak(Result, Prop);
   2687       }
   2688     }
   2689   }
   2690 
   2691   return MaybeBindToTemporary(Result);
   2692 }
   2693 
   2694 static void RemoveSelectorFromWarningCache(Sema &S, Expr* Arg) {
   2695   if (ObjCSelectorExpr *OSE =
   2696       dyn_cast<ObjCSelectorExpr>(Arg->IgnoreParenCasts())) {
   2697     Selector Sel = OSE->getSelector();
   2698     SourceLocation Loc = OSE->getAtLoc();
   2699     llvm::DenseMap<Selector, SourceLocation>::iterator Pos
   2700     = S.ReferencedSelectors.find(Sel);
   2701     if (Pos != S.ReferencedSelectors.end() && Pos->second == Loc)
   2702       S.ReferencedSelectors.erase(Pos);
   2703   }
   2704 }
   2705 
   2706 // ActOnInstanceMessage - used for both unary and keyword messages.
   2707 // ArgExprs is optional - if it is present, the number of expressions
   2708 // is obtained from Sel.getNumArgs().
   2709 ExprResult Sema::ActOnInstanceMessage(Scope *S,
   2710                                       Expr *Receiver,
   2711                                       Selector Sel,
   2712                                       SourceLocation LBracLoc,
   2713                                       ArrayRef<SourceLocation> SelectorLocs,
   2714                                       SourceLocation RBracLoc,
   2715                                       MultiExprArg Args) {
   2716   if (!Receiver)
   2717     return ExprError();
   2718 
   2719   // A ParenListExpr can show up while doing error recovery with invalid code.
   2720   if (isa<ParenListExpr>(Receiver)) {
   2721     ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Receiver);
   2722     if (Result.isInvalid()) return ExprError();
   2723     Receiver = Result.get();
   2724   }
   2725 
   2726   if (RespondsToSelectorSel.isNull()) {
   2727     IdentifierInfo *SelectorId = &Context.Idents.get("respondsToSelector");
   2728     RespondsToSelectorSel = Context.Selectors.getUnarySelector(SelectorId);
   2729   }
   2730   if (Sel == RespondsToSelectorSel)
   2731     RemoveSelectorFromWarningCache(*this, Args[0]);
   2732 
   2733   return BuildInstanceMessage(Receiver, Receiver->getType(),
   2734                               /*SuperLoc=*/SourceLocation(), Sel,
   2735                               /*Method=*/nullptr, LBracLoc, SelectorLocs,
   2736                               RBracLoc, Args);
   2737 }
   2738 
   2739 enum ARCConversionTypeClass {
   2740   /// int, void, struct A
   2741   ACTC_none,
   2742 
   2743   /// id, void (^)()
   2744   ACTC_retainable,
   2745 
   2746   /// id*, id***, void (^*)(),
   2747   ACTC_indirectRetainable,
   2748 
   2749   /// void* might be a normal C type, or it might a CF type.
   2750   ACTC_voidPtr,
   2751 
   2752   /// struct A*
   2753   ACTC_coreFoundation
   2754 };
   2755 static bool isAnyRetainable(ARCConversionTypeClass ACTC) {
   2756   return (ACTC == ACTC_retainable ||
   2757           ACTC == ACTC_coreFoundation ||
   2758           ACTC == ACTC_voidPtr);
   2759 }
   2760 static bool isAnyCLike(ARCConversionTypeClass ACTC) {
   2761   return ACTC == ACTC_none ||
   2762          ACTC == ACTC_voidPtr ||
   2763          ACTC == ACTC_coreFoundation;
   2764 }
   2765 
   2766 static ARCConversionTypeClass classifyTypeForARCConversion(QualType type) {
   2767   bool isIndirect = false;
   2768 
   2769   // Ignore an outermost reference type.
   2770   if (const ReferenceType *ref = type->getAs<ReferenceType>()) {
   2771     type = ref->getPointeeType();
   2772     isIndirect = true;
   2773   }
   2774 
   2775   // Drill through pointers and arrays recursively.
   2776   while (true) {
   2777     if (const PointerType *ptr = type->getAs<PointerType>()) {
   2778       type = ptr->getPointeeType();
   2779 
   2780       // The first level of pointer may be the innermost pointer on a CF type.
   2781       if (!isIndirect) {
   2782         if (type->isVoidType()) return ACTC_voidPtr;
   2783         if (type->isRecordType()) return ACTC_coreFoundation;
   2784       }
   2785     } else if (const ArrayType *array = type->getAsArrayTypeUnsafe()) {
   2786       type = QualType(array->getElementType()->getBaseElementTypeUnsafe(), 0);
   2787     } else {
   2788       break;
   2789     }
   2790     isIndirect = true;
   2791   }
   2792 
   2793   if (isIndirect) {
   2794     if (type->isObjCARCBridgableType())
   2795       return ACTC_indirectRetainable;
   2796     return ACTC_none;
   2797   }
   2798 
   2799   if (type->isObjCARCBridgableType())
   2800     return ACTC_retainable;
   2801 
   2802   return ACTC_none;
   2803 }
   2804 
   2805 namespace {
   2806   /// A result from the cast checker.
   2807   enum ACCResult {
   2808     /// Cannot be casted.
   2809     ACC_invalid,
   2810 
   2811     /// Can be safely retained or not retained.
   2812     ACC_bottom,
   2813 
   2814     /// Can be casted at +0.
   2815     ACC_plusZero,
   2816 
   2817     /// Can be casted at +1.
   2818     ACC_plusOne
   2819   };
   2820   ACCResult merge(ACCResult left, ACCResult right) {
   2821     if (left == right) return left;
   2822     if (left == ACC_bottom) return right;
   2823     if (right == ACC_bottom) return left;
   2824     return ACC_invalid;
   2825   }
   2826 
   2827   /// A checker which white-lists certain expressions whose conversion
   2828   /// to or from retainable type would otherwise be forbidden in ARC.
   2829   class ARCCastChecker : public StmtVisitor<ARCCastChecker, ACCResult> {
   2830     typedef StmtVisitor<ARCCastChecker, ACCResult> super;
   2831 
   2832     ASTContext &Context;
   2833     ARCConversionTypeClass SourceClass;
   2834     ARCConversionTypeClass TargetClass;
   2835     bool Diagnose;
   2836 
   2837     static bool isCFType(QualType type) {
   2838       // Someday this can use ns_bridged.  For now, it has to do this.
   2839       return type->isCARCBridgableType();
   2840     }
   2841 
   2842   public:
   2843     ARCCastChecker(ASTContext &Context, ARCConversionTypeClass source,
   2844                    ARCConversionTypeClass target, bool diagnose)
   2845       : Context(Context), SourceClass(source), TargetClass(target),
   2846         Diagnose(diagnose) {}
   2847 
   2848     using super::Visit;
   2849     ACCResult Visit(Expr *e) {
   2850       return super::Visit(e->IgnoreParens());
   2851     }
   2852 
   2853     ACCResult VisitStmt(Stmt *s) {
   2854       return ACC_invalid;
   2855     }
   2856 
   2857     /// Null pointer constants can be casted however you please.
   2858     ACCResult VisitExpr(Expr *e) {
   2859       if (e->isNullPointerConstant(Context, Expr::NPC_ValueDependentIsNotNull))
   2860         return ACC_bottom;
   2861       return ACC_invalid;
   2862     }
   2863 
   2864     /// Objective-C string literals can be safely casted.
   2865     ACCResult VisitObjCStringLiteral(ObjCStringLiteral *e) {
   2866       // If we're casting to any retainable type, go ahead.  Global
   2867       // strings are immune to retains, so this is bottom.
   2868       if (isAnyRetainable(TargetClass)) return ACC_bottom;
   2869 
   2870       return ACC_invalid;
   2871     }
   2872 
   2873     /// Look through certain implicit and explicit casts.
   2874     ACCResult VisitCastExpr(CastExpr *e) {
   2875       switch (e->getCastKind()) {
   2876         case CK_NullToPointer:
   2877           return ACC_bottom;
   2878 
   2879         case CK_NoOp:
   2880         case CK_LValueToRValue:
   2881         case CK_BitCast:
   2882         case CK_CPointerToObjCPointerCast:
   2883         case CK_BlockPointerToObjCPointerCast:
   2884         case CK_AnyPointerToBlockPointerCast:
   2885           return Visit(e->getSubExpr());
   2886 
   2887         default:
   2888           return ACC_invalid;
   2889       }
   2890     }
   2891 
   2892     /// Look through unary extension.
   2893     ACCResult VisitUnaryExtension(UnaryOperator *e) {
   2894       return Visit(e->getSubExpr());
   2895     }
   2896 
   2897     /// Ignore the LHS of a comma operator.
   2898     ACCResult VisitBinComma(BinaryOperator *e) {
   2899       return Visit(e->getRHS());
   2900     }
   2901 
   2902     /// Conditional operators are okay if both sides are okay.
   2903     ACCResult VisitConditionalOperator(ConditionalOperator *e) {
   2904       ACCResult left = Visit(e->getTrueExpr());
   2905       if (left == ACC_invalid) return ACC_invalid;
   2906       return merge(left, Visit(e->getFalseExpr()));
   2907     }
   2908 
   2909     /// Look through pseudo-objects.
   2910     ACCResult VisitPseudoObjectExpr(PseudoObjectExpr *e) {
   2911       // If we're getting here, we should always have a result.
   2912       return Visit(e->getResultExpr());
   2913     }
   2914 
   2915     /// Statement expressions are okay if their result expression is okay.
   2916     ACCResult VisitStmtExpr(StmtExpr *e) {
   2917       return Visit(e->getSubStmt()->body_back());
   2918     }
   2919 
   2920     /// Some declaration references are okay.
   2921     ACCResult VisitDeclRefExpr(DeclRefExpr *e) {
   2922       // References to global constants from system headers are okay.
   2923       // These are things like 'kCFStringTransformToLatin'.  They are
   2924       // can also be assumed to be immune to retains.
   2925       VarDecl *var = dyn_cast<VarDecl>(e->getDecl());
   2926       if (isAnyRetainable(TargetClass) &&
   2927           isAnyRetainable(SourceClass) &&
   2928           var &&
   2929           var->getStorageClass() == SC_Extern &&
   2930           var->getType().isConstQualified() &&
   2931           Context.getSourceManager().isInSystemHeader(var->getLocation())) {
   2932         return ACC_bottom;
   2933       }
   2934 
   2935       // Nothing else.
   2936       return ACC_invalid;
   2937     }
   2938 
   2939     /// Some calls are okay.
   2940     ACCResult VisitCallExpr(CallExpr *e) {
   2941       if (FunctionDecl *fn = e->getDirectCallee())
   2942         if (ACCResult result = checkCallToFunction(fn))
   2943           return result;
   2944 
   2945       return super::VisitCallExpr(e);
   2946     }
   2947 
   2948     ACCResult checkCallToFunction(FunctionDecl *fn) {
   2949       // Require a CF*Ref return type.
   2950       if (!isCFType(fn->getReturnType()))
   2951         return ACC_invalid;
   2952 
   2953       if (!isAnyRetainable(TargetClass))
   2954         return ACC_invalid;
   2955 
   2956       // Honor an explicit 'not retained' attribute.
   2957       if (fn->hasAttr<CFReturnsNotRetainedAttr>())
   2958         return ACC_plusZero;
   2959 
   2960       // Honor an explicit 'retained' attribute, except that for
   2961       // now we're not going to permit implicit handling of +1 results,
   2962       // because it's a bit frightening.
   2963       if (fn->hasAttr<CFReturnsRetainedAttr>())
   2964         return Diagnose ? ACC_plusOne
   2965                         : ACC_invalid; // ACC_plusOne if we start accepting this
   2966 
   2967       // Recognize this specific builtin function, which is used by CFSTR.
   2968       unsigned builtinID = fn->getBuiltinID();
   2969       if (builtinID == Builtin::BI__builtin___CFStringMakeConstantString)
   2970         return ACC_bottom;
   2971 
   2972       // Otherwise, don't do anything implicit with an unaudited function.
   2973       if (!fn->hasAttr<CFAuditedTransferAttr>())
   2974         return ACC_invalid;
   2975 
   2976       // Otherwise, it's +0 unless it follows the create convention.
   2977       if (ento::coreFoundation::followsCreateRule(fn))
   2978         return Diagnose ? ACC_plusOne
   2979                         : ACC_invalid; // ACC_plusOne if we start accepting this
   2980 
   2981       return ACC_plusZero;
   2982     }
   2983 
   2984     ACCResult VisitObjCMessageExpr(ObjCMessageExpr *e) {
   2985       return checkCallToMethod(e->getMethodDecl());
   2986     }
   2987 
   2988     ACCResult VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *e) {
   2989       ObjCMethodDecl *method;
   2990       if (e->isExplicitProperty())
   2991         method = e->getExplicitProperty()->getGetterMethodDecl();
   2992       else
   2993         method = e->getImplicitPropertyGetter();
   2994       return checkCallToMethod(method);
   2995     }
   2996 
   2997     ACCResult checkCallToMethod(ObjCMethodDecl *method) {
   2998       if (!method) return ACC_invalid;
   2999 
   3000       // Check for message sends to functions returning CF types.  We
   3001       // just obey the Cocoa conventions with these, even though the
   3002       // return type is CF.
   3003       if (!isAnyRetainable(TargetClass) || !isCFType(method->getReturnType()))
   3004         return ACC_invalid;
   3005 
   3006       // If the method is explicitly marked not-retained, it's +0.
   3007       if (method->hasAttr<CFReturnsNotRetainedAttr>())
   3008         return ACC_plusZero;
   3009 
   3010       // If the method is explicitly marked as returning retained, or its
   3011       // selector follows a +1 Cocoa convention, treat it as +1.
   3012       if (method->hasAttr<CFReturnsRetainedAttr>())
   3013         return ACC_plusOne;
   3014 
   3015       switch (method->getSelector().getMethodFamily()) {
   3016       case OMF_alloc:
   3017       case OMF_copy:
   3018       case OMF_mutableCopy:
   3019       case OMF_new:
   3020         return ACC_plusOne;
   3021 
   3022       default:
   3023         // Otherwise, treat it as +0.
   3024         return ACC_plusZero;
   3025       }
   3026     }
   3027   };
   3028 }
   3029 
   3030 bool Sema::isKnownName(StringRef name) {
   3031   if (name.empty())
   3032     return false;
   3033   LookupResult R(*this, &Context.Idents.get(name), SourceLocation(),
   3034                  Sema::LookupOrdinaryName);
   3035   return LookupName(R, TUScope, false);
   3036 }
   3037 
   3038 static void addFixitForObjCARCConversion(Sema &S,
   3039                                          DiagnosticBuilder &DiagB,
   3040                                          Sema::CheckedConversionKind CCK,
   3041                                          SourceLocation afterLParen,
   3042                                          QualType castType,
   3043                                          Expr *castExpr,
   3044                                          Expr *realCast,
   3045                                          const char *bridgeKeyword,
   3046                                          const char *CFBridgeName) {
   3047   // We handle C-style and implicit casts here.
   3048   switch (CCK) {
   3049   case Sema::CCK_ImplicitConversion:
   3050   case Sema::CCK_CStyleCast:
   3051   case Sema::CCK_OtherCast:
   3052     break;
   3053   case Sema::CCK_FunctionalCast:
   3054     return;
   3055   }
   3056 
   3057   if (CFBridgeName) {
   3058     if (CCK == Sema::CCK_OtherCast) {
   3059       if (const CXXNamedCastExpr *NCE = dyn_cast<CXXNamedCastExpr>(realCast)) {
   3060         SourceRange range(NCE->getOperatorLoc(),
   3061                           NCE->getAngleBrackets().getEnd());
   3062         SmallString<32> BridgeCall;
   3063 
   3064         SourceManager &SM = S.getSourceManager();
   3065         char PrevChar = *SM.getCharacterData(range.getBegin().getLocWithOffset(-1));
   3066         if (Lexer::isIdentifierBodyChar(PrevChar, S.getLangOpts()))
   3067           BridgeCall += ' ';
   3068 
   3069         BridgeCall += CFBridgeName;
   3070         DiagB.AddFixItHint(FixItHint::CreateReplacement(range, BridgeCall));
   3071       }
   3072       return;
   3073     }
   3074     Expr *castedE = castExpr;
   3075     if (CStyleCastExpr *CCE = dyn_cast<CStyleCastExpr>(castedE))
   3076       castedE = CCE->getSubExpr();
   3077     castedE = castedE->IgnoreImpCasts();
   3078     SourceRange range = castedE->getSourceRange();
   3079 
   3080     SmallString<32> BridgeCall;
   3081 
   3082     SourceManager &SM = S.getSourceManager();
   3083     char PrevChar = *SM.getCharacterData(range.getBegin().getLocWithOffset(-1));
   3084     if (Lexer::isIdentifierBodyChar(PrevChar, S.getLangOpts()))
   3085       BridgeCall += ' ';
   3086 
   3087     BridgeCall += CFBridgeName;
   3088 
   3089     if (isa<ParenExpr>(castedE)) {
   3090       DiagB.AddFixItHint(FixItHint::CreateInsertion(range.getBegin(),
   3091                          BridgeCall));
   3092     } else {
   3093       BridgeCall += '(';
   3094       DiagB.AddFixItHint(FixItHint::CreateInsertion(range.getBegin(),
   3095                                                     BridgeCall));
   3096       DiagB.AddFixItHint(FixItHint::CreateInsertion(
   3097                                        S.PP.getLocForEndOfToken(range.getEnd()),
   3098                                        ")"));
   3099     }
   3100     return;
   3101   }
   3102 
   3103   if (CCK == Sema::CCK_CStyleCast) {
   3104     DiagB.AddFixItHint(FixItHint::CreateInsertion(afterLParen, bridgeKeyword));
   3105   } else if (CCK == Sema::CCK_OtherCast) {
   3106     if (const CXXNamedCastExpr *NCE = dyn_cast<CXXNamedCastExpr>(realCast)) {
   3107       std::string castCode = "(";
   3108       castCode += bridgeKeyword;
   3109       castCode += castType.getAsString();
   3110       castCode += ")";
   3111       SourceRange Range(NCE->getOperatorLoc(),
   3112                         NCE->getAngleBrackets().getEnd());
   3113       DiagB.AddFixItHint(FixItHint::CreateReplacement(Range, castCode));
   3114     }
   3115   } else {
   3116     std::string castCode = "(";
   3117     castCode += bridgeKeyword;
   3118     castCode += castType.getAsString();
   3119     castCode += ")";
   3120     Expr *castedE = castExpr->IgnoreImpCasts();
   3121     SourceRange range = castedE->getSourceRange();
   3122     if (isa<ParenExpr>(castedE)) {
   3123       DiagB.AddFixItHint(FixItHint::CreateInsertion(range.getBegin(),
   3124                          castCode));
   3125     } else {
   3126       castCode += "(";
   3127       DiagB.AddFixItHint(FixItHint::CreateInsertion(range.getBegin(),
   3128                                                     castCode));
   3129       DiagB.AddFixItHint(FixItHint::CreateInsertion(
   3130                                        S.PP.getLocForEndOfToken(range.getEnd()),
   3131                                        ")"));
   3132     }
   3133   }
   3134 }
   3135 
   3136 template <typename T>
   3137 static inline T *getObjCBridgeAttr(const TypedefType *TD) {
   3138   TypedefNameDecl *TDNDecl = TD->getDecl();
   3139   QualType QT = TDNDecl->getUnderlyingType();
   3140   if (QT->isPointerType()) {
   3141     QT = QT->getPointeeType();
   3142     if (const RecordType *RT = QT->getAs<RecordType>())
   3143       if (RecordDecl *RD = RT->getDecl()->getMostRecentDecl())
   3144         return RD->getAttr<T>();
   3145   }
   3146   return nullptr;
   3147 }
   3148 
   3149 static ObjCBridgeRelatedAttr *ObjCBridgeRelatedAttrFromType(QualType T,
   3150                                                             TypedefNameDecl *&TDNDecl) {
   3151   while (const TypedefType *TD = dyn_cast<TypedefType>(T.getTypePtr())) {
   3152     TDNDecl = TD->getDecl();
   3153     if (ObjCBridgeRelatedAttr *ObjCBAttr =
   3154         getObjCBridgeAttr<ObjCBridgeRelatedAttr>(TD))
   3155       return ObjCBAttr;
   3156     T = TDNDecl->getUnderlyingType();
   3157   }
   3158   return nullptr;
   3159 }
   3160 
   3161 static void
   3162 diagnoseObjCARCConversion(Sema &S, SourceRange castRange,
   3163                           QualType castType, ARCConversionTypeClass castACTC,
   3164                           Expr *castExpr, Expr *realCast,
   3165                           ARCConversionTypeClass exprACTC,
   3166                           Sema::CheckedConversionKind CCK) {
   3167   SourceLocation loc =
   3168     (castRange.isValid() ? castRange.getBegin() : castExpr->getExprLoc());
   3169 
   3170   if (S.makeUnavailableInSystemHeader(loc,
   3171                 "converts between Objective-C and C pointers in -fobjc-arc"))
   3172     return;
   3173 
   3174   QualType castExprType = castExpr->getType();
   3175   TypedefNameDecl *TDNDecl = nullptr;
   3176   if ((castACTC == ACTC_coreFoundation &&  exprACTC == ACTC_retainable &&
   3177        ObjCBridgeRelatedAttrFromType(castType, TDNDecl)) ||
   3178       (exprACTC == ACTC_coreFoundation && castACTC == ACTC_retainable &&
   3179        ObjCBridgeRelatedAttrFromType(castExprType, TDNDecl)))
   3180     return;
   3181 
   3182   unsigned srcKind = 0;
   3183   switch (exprACTC) {
   3184   case ACTC_none:
   3185   case ACTC_coreFoundation:
   3186   case ACTC_voidPtr:
   3187     srcKind = (castExprType->isPointerType() ? 1 : 0);
   3188     break;
   3189   case ACTC_retainable:
   3190     srcKind = (castExprType->isBlockPointerType() ? 2 : 3);
   3191     break;
   3192   case ACTC_indirectRetainable:
   3193     srcKind = 4;
   3194     break;
   3195   }
   3196 
   3197   // Check whether this could be fixed with a bridge cast.
   3198   SourceLocation afterLParen = S.PP.getLocForEndOfToken(castRange.getBegin());
   3199   SourceLocation noteLoc = afterLParen.isValid() ? afterLParen : loc;
   3200 
   3201   // Bridge from an ARC type to a CF type.
   3202   if (castACTC == ACTC_retainable && isAnyRetainable(exprACTC)) {
   3203 
   3204     S.Diag(loc, diag::err_arc_cast_requires_bridge)
   3205       << unsigned(CCK == Sema::CCK_ImplicitConversion) // cast|implicit
   3206       << 2 // of C pointer type
   3207       << castExprType
   3208       << unsigned(castType->isBlockPointerType()) // to ObjC|block type
   3209       << castType
   3210       << castRange
   3211       << castExpr->getSourceRange();
   3212     bool br = S.isKnownName("CFBridgingRelease");
   3213     ACCResult CreateRule =
   3214       ARCCastChecker(S.Context, exprACTC, castACTC, true).Visit(castExpr);
   3215     assert(CreateRule != ACC_bottom && "This cast should already be accepted.");
   3216     if (CreateRule != ACC_plusOne)
   3217     {
   3218       DiagnosticBuilder DiagB =
   3219         (CCK != Sema::CCK_OtherCast) ? S.Diag(noteLoc, diag::note_arc_bridge)
   3220                               : S.Diag(noteLoc, diag::note_arc_cstyle_bridge);
   3221 
   3222       addFixitForObjCARCConversion(S, DiagB, CCK, afterLParen,
   3223                                    castType, castExpr, realCast, "__bridge ",
   3224                                    nullptr);
   3225     }
   3226     if (CreateRule != ACC_plusZero)
   3227     {
   3228       DiagnosticBuilder DiagB =
   3229         (CCK == Sema::CCK_OtherCast && !br) ?
   3230           S.Diag(noteLoc, diag::note_arc_cstyle_bridge_transfer) << castExprType :
   3231           S.Diag(br ? castExpr->getExprLoc() : noteLoc,
   3232                  diag::note_arc_bridge_transfer)
   3233             << castExprType << br;
   3234 
   3235       addFixitForObjCARCConversion(S, DiagB, CCK, afterLParen,
   3236                                    castType, castExpr, realCast, "__bridge_transfer ",
   3237                                    br ? "CFBridgingRelease" : nullptr);
   3238     }
   3239 
   3240     return;
   3241   }
   3242 
   3243   // Bridge from a CF type to an ARC type.
   3244   if (exprACTC == ACTC_retainable && isAnyRetainable(castACTC)) {
   3245     bool br = S.isKnownName("CFBridgingRetain");
   3246     S.Diag(loc, diag::err_arc_cast_requires_bridge)
   3247       << unsigned(CCK == Sema::CCK_ImplicitConversion) // cast|implicit
   3248       << unsigned(castExprType->isBlockPointerType()) // of ObjC|block type
   3249       << castExprType
   3250       << 2 // to C pointer type
   3251       << castType
   3252       << castRange
   3253       << castExpr->getSourceRange();
   3254     ACCResult CreateRule =
   3255       ARCCastChecker(S.Context, exprACTC, castACTC, true).Visit(castExpr);
   3256     assert(CreateRule != ACC_bottom && "This cast should already be accepted.");
   3257     if (CreateRule != ACC_plusOne)
   3258     {
   3259       DiagnosticBuilder DiagB =
   3260       (CCK != Sema::CCK_OtherCast) ? S.Diag(noteLoc, diag::note_arc_bridge)
   3261                                : S.Diag(noteLoc, diag::note_arc_cstyle_bridge);
   3262       addFixitForObjCARCConversion(S, DiagB, CCK, afterLParen,
   3263                                    castType, castExpr, realCast, "__bridge ",
   3264                                    nullptr);
   3265     }
   3266     if (CreateRule != ACC_plusZero)
   3267     {
   3268       DiagnosticBuilder DiagB =
   3269         (CCK == Sema::CCK_OtherCast && !br) ?
   3270           S.Diag(noteLoc, diag::note_arc_cstyle_bridge_retained) << castType :
   3271           S.Diag(br ? castExpr->getExprLoc() : noteLoc,
   3272                  diag::note_arc_bridge_retained)
   3273             << castType << br;
   3274 
   3275       addFixitForObjCARCConversion(S, DiagB, CCK, afterLParen,
   3276                                    castType, castExpr, realCast, "__bridge_retained ",
   3277                                    br ? "CFBridgingRetain" : nullptr);
   3278     }
   3279 
   3280     return;
   3281   }
   3282 
   3283   S.Diag(loc, diag::err_arc_mismatched_cast)
   3284     << (CCK != Sema::CCK_ImplicitConversion)
   3285     << srcKind << castExprType << castType
   3286     << castRange << castExpr->getSourceRange();
   3287 }
   3288 
   3289 template <typename TB>
   3290 static bool CheckObjCBridgeNSCast(Sema &S, QualType castType, Expr *castExpr,
   3291                                   bool &HadTheAttribute, bool warn) {
   3292   QualType T = castExpr->getType();
   3293   HadTheAttribute = false;
   3294   while (const TypedefType *TD = dyn_cast<TypedefType>(T.getTypePtr())) {
   3295     TypedefNameDecl *TDNDecl = TD->getDecl();
   3296     if (TB *ObjCBAttr = getObjCBridgeAttr<TB>(TD)) {
   3297       if (IdentifierInfo *Parm = ObjCBAttr->getBridgedType()) {
   3298         HadTheAttribute = true;
   3299         NamedDecl *Target = nullptr;
   3300         // Check for an existing type with this name.
   3301         LookupResult R(S, DeclarationName(Parm), SourceLocation(),
   3302                        Sema::LookupOrdinaryName);
   3303         if (S.LookupName(R, S.TUScope)) {
   3304           Target = R.getFoundDecl();
   3305           if (Target && isa<ObjCInterfaceDecl>(Target)) {
   3306             ObjCInterfaceDecl *ExprClass = cast<ObjCInterfaceDecl>(Target);
   3307             if (const ObjCObjectPointerType *InterfacePointerType =
   3308                   castType->getAsObjCInterfacePointerType()) {
   3309               ObjCInterfaceDecl *CastClass
   3310                 = InterfacePointerType->getObjectType()->getInterface();
   3311               if ((CastClass == ExprClass) ||
   3312                   (CastClass && ExprClass->isSuperClassOf(CastClass)))
   3313                 return true;
   3314               if (warn)
   3315                 S.Diag(castExpr->getLocStart(), diag::warn_objc_invalid_bridge)
   3316                   << T << Target->getName() << castType->getPointeeType();
   3317               return false;
   3318             } else if (castType->isObjCIdType() ||
   3319                        (S.Context.ObjCObjectAdoptsQTypeProtocols(
   3320                           castType, ExprClass)))
   3321               // ok to cast to 'id'.
   3322               // casting to id<p-list> is ok if bridge type adopts all of
   3323               // p-list protocols.
   3324               return true;
   3325             else {
   3326               if (warn) {
   3327                 S.Diag(castExpr->getLocStart(), diag::warn_objc_invalid_bridge)
   3328                   << T << Target->getName() << castType;
   3329                 S.Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3330                 S.Diag(Target->getLocStart(), diag::note_declared_at);
   3331               }
   3332               return false;
   3333            }
   3334           }
   3335         }
   3336         S.Diag(castExpr->getLocStart(), diag::err_objc_cf_bridged_not_interface)
   3337           << castExpr->getType() << Parm;
   3338         S.Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3339         if (Target)
   3340           S.Diag(Target->getLocStart(), diag::note_declared_at);
   3341         return true;
   3342       }
   3343       return false;
   3344     }
   3345     T = TDNDecl->getUnderlyingType();
   3346   }
   3347   return true;
   3348 }
   3349 
   3350 template <typename TB>
   3351 static bool CheckObjCBridgeCFCast(Sema &S, QualType castType, Expr *castExpr,
   3352                                   bool &HadTheAttribute, bool warn) {
   3353   QualType T = castType;
   3354   HadTheAttribute = false;
   3355   while (const TypedefType *TD = dyn_cast<TypedefType>(T.getTypePtr())) {
   3356     TypedefNameDecl *TDNDecl = TD->getDecl();
   3357     if (TB *ObjCBAttr = getObjCBridgeAttr<TB>(TD)) {
   3358       if (IdentifierInfo *Parm = ObjCBAttr->getBridgedType()) {
   3359         HadTheAttribute = true;
   3360         NamedDecl *Target = nullptr;
   3361         // Check for an existing type with this name.
   3362         LookupResult R(S, DeclarationName(Parm), SourceLocation(),
   3363                        Sema::LookupOrdinaryName);
   3364         if (S.LookupName(R, S.TUScope)) {
   3365           Target = R.getFoundDecl();
   3366           if (Target && isa<ObjCInterfaceDecl>(Target)) {
   3367             ObjCInterfaceDecl *CastClass = cast<ObjCInterfaceDecl>(Target);
   3368             if (const ObjCObjectPointerType *InterfacePointerType =
   3369                   castExpr->getType()->getAsObjCInterfacePointerType()) {
   3370               ObjCInterfaceDecl *ExprClass
   3371                 = InterfacePointerType->getObjectType()->getInterface();
   3372               if ((CastClass == ExprClass) ||
   3373                   (ExprClass && CastClass->isSuperClassOf(ExprClass)))
   3374                 return true;
   3375               if (warn) {
   3376                 S.Diag(castExpr->getLocStart(), diag::warn_objc_invalid_bridge_to_cf)
   3377                   << castExpr->getType()->getPointeeType() << T;
   3378                 S.Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3379               }
   3380               return false;
   3381             } else if (castExpr->getType()->isObjCIdType() ||
   3382                        (S.Context.QIdProtocolsAdoptObjCObjectProtocols(
   3383                           castExpr->getType(), CastClass)))
   3384               // ok to cast an 'id' expression to a CFtype.
   3385               // ok to cast an 'id<plist>' expression to CFtype provided plist
   3386               // adopts all of CFtype's ObjetiveC's class plist.
   3387               return true;
   3388             else {
   3389               if (warn) {
   3390                 S.Diag(castExpr->getLocStart(), diag::warn_objc_invalid_bridge_to_cf)
   3391                   << castExpr->getType() << castType;
   3392                 S.Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3393                 S.Diag(Target->getLocStart(), diag::note_declared_at);
   3394               }
   3395               return false;
   3396             }
   3397           }
   3398         }
   3399         S.Diag(castExpr->getLocStart(), diag::err_objc_ns_bridged_invalid_cfobject)
   3400         << castExpr->getType() << castType;
   3401         S.Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3402         if (Target)
   3403           S.Diag(Target->getLocStart(), diag::note_declared_at);
   3404         return true;
   3405       }
   3406       return false;
   3407     }
   3408     T = TDNDecl->getUnderlyingType();
   3409   }
   3410   return true;
   3411 }
   3412 
   3413 void Sema::CheckTollFreeBridgeCast(QualType castType, Expr *castExpr) {
   3414   if (!getLangOpts().ObjC1)
   3415     return;
   3416   // warn in presence of __bridge casting to or from a toll free bridge cast.
   3417   ARCConversionTypeClass exprACTC = classifyTypeForARCConversion(castExpr->getType());
   3418   ARCConversionTypeClass castACTC = classifyTypeForARCConversion(castType);
   3419   if (castACTC == ACTC_retainable && exprACTC == ACTC_coreFoundation) {
   3420     bool HasObjCBridgeAttr;
   3421     bool ObjCBridgeAttrWillNotWarn =
   3422       CheckObjCBridgeNSCast<ObjCBridgeAttr>(*this, castType, castExpr, HasObjCBridgeAttr,
   3423                                             false);
   3424     if (ObjCBridgeAttrWillNotWarn && HasObjCBridgeAttr)
   3425       return;
   3426     bool HasObjCBridgeMutableAttr;
   3427     bool ObjCBridgeMutableAttrWillNotWarn =
   3428       CheckObjCBridgeNSCast<ObjCBridgeMutableAttr>(*this, castType, castExpr,
   3429                                                    HasObjCBridgeMutableAttr, false);
   3430     if (ObjCBridgeMutableAttrWillNotWarn && HasObjCBridgeMutableAttr)
   3431       return;
   3432 
   3433     if (HasObjCBridgeAttr)
   3434       CheckObjCBridgeNSCast<ObjCBridgeAttr>(*this, castType, castExpr, HasObjCBridgeAttr,
   3435                                             true);
   3436     else if (HasObjCBridgeMutableAttr)
   3437       CheckObjCBridgeNSCast<ObjCBridgeMutableAttr>(*this, castType, castExpr,
   3438                                                    HasObjCBridgeMutableAttr, true);
   3439   }
   3440   else if (castACTC == ACTC_coreFoundation && exprACTC == ACTC_retainable) {
   3441     bool HasObjCBridgeAttr;
   3442     bool ObjCBridgeAttrWillNotWarn =
   3443       CheckObjCBridgeCFCast<ObjCBridgeAttr>(*this, castType, castExpr, HasObjCBridgeAttr,
   3444                                             false);
   3445     if (ObjCBridgeAttrWillNotWarn && HasObjCBridgeAttr)
   3446       return;
   3447     bool HasObjCBridgeMutableAttr;
   3448     bool ObjCBridgeMutableAttrWillNotWarn =
   3449       CheckObjCBridgeCFCast<ObjCBridgeMutableAttr>(*this, castType, castExpr,
   3450                                                    HasObjCBridgeMutableAttr, false);
   3451     if (ObjCBridgeMutableAttrWillNotWarn && HasObjCBridgeMutableAttr)
   3452       return;
   3453 
   3454     if (HasObjCBridgeAttr)
   3455       CheckObjCBridgeCFCast<ObjCBridgeAttr>(*this, castType, castExpr, HasObjCBridgeAttr,
   3456                                             true);
   3457     else if (HasObjCBridgeMutableAttr)
   3458       CheckObjCBridgeCFCast<ObjCBridgeMutableAttr>(*this, castType, castExpr,
   3459                                                    HasObjCBridgeMutableAttr, true);
   3460   }
   3461 }
   3462 
   3463 void Sema::CheckObjCBridgeRelatedCast(QualType castType, Expr *castExpr) {
   3464   QualType SrcType = castExpr->getType();
   3465   if (ObjCPropertyRefExpr *PRE = dyn_cast<ObjCPropertyRefExpr>(castExpr)) {
   3466     if (PRE->isExplicitProperty()) {
   3467       if (ObjCPropertyDecl *PDecl = PRE->getExplicitProperty())
   3468         SrcType = PDecl->getType();
   3469     }
   3470     else if (PRE->isImplicitProperty()) {
   3471       if (ObjCMethodDecl *Getter = PRE->getImplicitPropertyGetter())
   3472         SrcType = Getter->getReturnType();
   3473 
   3474     }
   3475   }
   3476 
   3477   ARCConversionTypeClass srcExprACTC = classifyTypeForARCConversion(SrcType);
   3478   ARCConversionTypeClass castExprACTC = classifyTypeForARCConversion(castType);
   3479   if (srcExprACTC != ACTC_retainable || castExprACTC != ACTC_coreFoundation)
   3480     return;
   3481   CheckObjCBridgeRelatedConversions(castExpr->getLocStart(),
   3482                                     castType, SrcType, castExpr);
   3483   return;
   3484 }
   3485 
   3486 bool Sema::CheckTollFreeBridgeStaticCast(QualType castType, Expr *castExpr,
   3487                                          CastKind &Kind) {
   3488   if (!getLangOpts().ObjC1)
   3489     return false;
   3490   ARCConversionTypeClass exprACTC =
   3491     classifyTypeForARCConversion(castExpr->getType());
   3492   ARCConversionTypeClass castACTC = classifyTypeForARCConversion(castType);
   3493   if ((castACTC == ACTC_retainable && exprACTC == ACTC_coreFoundation) ||
   3494       (castACTC == ACTC_coreFoundation && exprACTC == ACTC_retainable)) {
   3495     CheckTollFreeBridgeCast(castType, castExpr);
   3496     Kind = (castACTC == ACTC_coreFoundation) ? CK_BitCast
   3497                                              : CK_CPointerToObjCPointerCast;
   3498     return true;
   3499   }
   3500   return false;
   3501 }
   3502 
   3503 bool Sema::checkObjCBridgeRelatedComponents(SourceLocation Loc,
   3504                                             QualType DestType, QualType SrcType,
   3505                                             ObjCInterfaceDecl *&RelatedClass,
   3506                                             ObjCMethodDecl *&ClassMethod,
   3507                                             ObjCMethodDecl *&InstanceMethod,
   3508                                             TypedefNameDecl *&TDNDecl,
   3509                                             bool CfToNs) {
   3510   QualType T = CfToNs ? SrcType : DestType;
   3511   ObjCBridgeRelatedAttr *ObjCBAttr = ObjCBridgeRelatedAttrFromType(T, TDNDecl);
   3512   if (!ObjCBAttr)
   3513     return false;
   3514 
   3515   IdentifierInfo *RCId = ObjCBAttr->getRelatedClass();
   3516   IdentifierInfo *CMId = ObjCBAttr->getClassMethod();
   3517   IdentifierInfo *IMId = ObjCBAttr->getInstanceMethod();
   3518   if (!RCId)
   3519     return false;
   3520   NamedDecl *Target = nullptr;
   3521   // Check for an existing type with this name.
   3522   LookupResult R(*this, DeclarationName(RCId), SourceLocation(),
   3523                  Sema::LookupOrdinaryName);
   3524   if (!LookupName(R, TUScope)) {
   3525     Diag(Loc, diag::err_objc_bridged_related_invalid_class) << RCId
   3526           << SrcType << DestType;
   3527     Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3528     return false;
   3529   }
   3530   Target = R.getFoundDecl();
   3531   if (Target && isa<ObjCInterfaceDecl>(Target))
   3532     RelatedClass = cast<ObjCInterfaceDecl>(Target);
   3533   else {
   3534     Diag(Loc, diag::err_objc_bridged_related_invalid_class_name) << RCId
   3535           << SrcType << DestType;
   3536     Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3537     if (Target)
   3538       Diag(Target->getLocStart(), diag::note_declared_at);
   3539     return false;
   3540   }
   3541 
   3542   // Check for an existing class method with the given selector name.
   3543   if (CfToNs && CMId) {
   3544     Selector Sel = Context.Selectors.getUnarySelector(CMId);
   3545     ClassMethod = RelatedClass->lookupMethod(Sel, false);
   3546     if (!ClassMethod) {
   3547       Diag(Loc, diag::err_objc_bridged_related_known_method)
   3548             << SrcType << DestType << Sel << false;
   3549       Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3550       return false;
   3551     }
   3552   }
   3553 
   3554   // Check for an existing instance method with the given selector name.
   3555   if (!CfToNs && IMId) {
   3556     Selector Sel = Context.Selectors.getNullarySelector(IMId);
   3557     InstanceMethod = RelatedClass->lookupMethod(Sel, true);
   3558     if (!InstanceMethod) {
   3559       Diag(Loc, diag::err_objc_bridged_related_known_method)
   3560             << SrcType << DestType << Sel << true;
   3561       Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3562       return false;
   3563     }
   3564   }
   3565   return true;
   3566 }
   3567 
   3568 bool
   3569 Sema::CheckObjCBridgeRelatedConversions(SourceLocation Loc,
   3570                                         QualType DestType, QualType SrcType,
   3571                                         Expr *&SrcExpr) {
   3572   ARCConversionTypeClass rhsExprACTC = classifyTypeForARCConversion(SrcType);
   3573   ARCConversionTypeClass lhsExprACTC = classifyTypeForARCConversion(DestType);
   3574   bool CfToNs = (rhsExprACTC == ACTC_coreFoundation && lhsExprACTC == ACTC_retainable);
   3575   bool NsToCf = (rhsExprACTC == ACTC_retainable && lhsExprACTC == ACTC_coreFoundation);
   3576   if (!CfToNs && !NsToCf)
   3577     return false;
   3578 
   3579   ObjCInterfaceDecl *RelatedClass;
   3580   ObjCMethodDecl *ClassMethod = nullptr;
   3581   ObjCMethodDecl *InstanceMethod = nullptr;
   3582   TypedefNameDecl *TDNDecl = nullptr;
   3583   if (!checkObjCBridgeRelatedComponents(Loc, DestType, SrcType, RelatedClass,
   3584                                         ClassMethod, InstanceMethod, TDNDecl, CfToNs))
   3585     return false;
   3586 
   3587   if (CfToNs) {
   3588     // Implicit conversion from CF to ObjC object is needed.
   3589     if (ClassMethod) {
   3590       std::string ExpressionString = "[";
   3591       ExpressionString += RelatedClass->getNameAsString();
   3592       ExpressionString += " ";
   3593       ExpressionString += ClassMethod->getSelector().getAsString();
   3594       SourceLocation SrcExprEndLoc = PP.getLocForEndOfToken(SrcExpr->getLocEnd());
   3595       // Provide a fixit: [RelatedClass ClassMethod SrcExpr]
   3596       Diag(Loc, diag::err_objc_bridged_related_known_method)
   3597         << SrcType << DestType << ClassMethod->getSelector() << false
   3598         << FixItHint::CreateInsertion(SrcExpr->getLocStart(), ExpressionString)
   3599         << FixItHint::CreateInsertion(SrcExprEndLoc, "]");
   3600       Diag(RelatedClass->getLocStart(), diag::note_declared_at);
   3601       Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3602 
   3603       QualType receiverType =
   3604         Context.getObjCInterfaceType(RelatedClass);
   3605       // Argument.
   3606       Expr *args[] = { SrcExpr };
   3607       ExprResult msg = BuildClassMessageImplicit(receiverType, false,
   3608                                       ClassMethod->getLocation(),
   3609                                       ClassMethod->getSelector(), ClassMethod,
   3610                                       MultiExprArg(args, 1));
   3611       SrcExpr = msg.get();
   3612       return true;
   3613     }
   3614   }
   3615   else {
   3616     // Implicit conversion from ObjC type to CF object is needed.
   3617     if (InstanceMethod) {
   3618       std::string ExpressionString;
   3619       SourceLocation SrcExprEndLoc = PP.getLocForEndOfToken(SrcExpr->getLocEnd());
   3620       if (InstanceMethod->isPropertyAccessor())
   3621         if (const ObjCPropertyDecl *PDecl = InstanceMethod->findPropertyDecl()) {
   3622           // fixit: ObjectExpr.propertyname when it is  aproperty accessor.
   3623           ExpressionString = ".";
   3624           ExpressionString += PDecl->getNameAsString();
   3625           Diag(Loc, diag::err_objc_bridged_related_known_method)
   3626           << SrcType << DestType << InstanceMethod->getSelector() << true
   3627           << FixItHint::CreateInsertion(SrcExprEndLoc, ExpressionString);
   3628         }
   3629       if (ExpressionString.empty()) {
   3630         // Provide a fixit: [ObjectExpr InstanceMethod]
   3631         ExpressionString = " ";
   3632         ExpressionString += InstanceMethod->getSelector().getAsString();
   3633         ExpressionString += "]";
   3634 
   3635         Diag(Loc, diag::err_objc_bridged_related_known_method)
   3636         << SrcType << DestType << InstanceMethod->getSelector() << true
   3637         << FixItHint::CreateInsertion(SrcExpr->getLocStart(), "[")
   3638         << FixItHint::CreateInsertion(SrcExprEndLoc, ExpressionString);
   3639       }
   3640       Diag(RelatedClass->getLocStart(), diag::note_declared_at);
   3641       Diag(TDNDecl->getLocStart(), diag::note_declared_at);
   3642 
   3643       ExprResult msg =
   3644         BuildInstanceMessageImplicit(SrcExpr, SrcType,
   3645                                      InstanceMethod->getLocation(),
   3646                                      InstanceMethod->getSelector(),
   3647                                      InstanceMethod, None);
   3648       SrcExpr = msg.get();
   3649       return true;
   3650     }
   3651   }
   3652   return false;
   3653 }
   3654 
   3655 Sema::ARCConversionResult
   3656 Sema::CheckObjCARCConversion(SourceRange castRange, QualType castType,
   3657                              Expr *&castExpr, CheckedConversionKind CCK,
   3658                              bool DiagnoseCFAudited,
   3659                              BinaryOperatorKind Opc) {
   3660   QualType castExprType = castExpr->getType();
   3661 
   3662   // For the purposes of the classification, we assume reference types
   3663   // will bind to temporaries.
   3664   QualType effCastType = castType;
   3665   if (const ReferenceType *ref = castType->getAs<ReferenceType>())
   3666     effCastType = ref->getPointeeType();
   3667 
   3668   ARCConversionTypeClass exprACTC = classifyTypeForARCConversion(castExprType);
   3669   ARCConversionTypeClass castACTC = classifyTypeForARCConversion(effCastType);
   3670   if (exprACTC == castACTC) {
   3671     // check for viablity and report error if casting an rvalue to a
   3672     // life-time qualifier.
   3673     if ((castACTC == ACTC_retainable) &&
   3674         (CCK == CCK_CStyleCast || CCK == CCK_OtherCast) &&
   3675         (castType != castExprType)) {
   3676       const Type *DT = castType.getTypePtr();
   3677       QualType QDT = castType;
   3678       // We desugar some types but not others. We ignore those
   3679       // that cannot happen in a cast; i.e. auto, and those which
   3680       // should not be de-sugared; i.e typedef.
   3681       if (const ParenType *PT = dyn_cast<ParenType>(DT))
   3682         QDT = PT->desugar();
   3683       else if (const TypeOfType *TP = dyn_cast<TypeOfType>(DT))
   3684         QDT = TP->desugar();
   3685       else if (const AttributedType *AT = dyn_cast<AttributedType>(DT))
   3686         QDT = AT->desugar();
   3687       if (QDT != castType &&
   3688           QDT.getObjCLifetime() !=  Qualifiers::OCL_None) {
   3689         SourceLocation loc =
   3690           (castRange.isValid() ? castRange.getBegin()
   3691                               : castExpr->getExprLoc());
   3692         Diag(loc, diag::err_arc_nolifetime_behavior);
   3693       }
   3694     }
   3695     return ACR_okay;
   3696   }
   3697 
   3698   if (isAnyCLike(exprACTC) && isAnyCLike(castACTC)) return ACR_okay;
   3699 
   3700   // Allow all of these types to be cast to integer types (but not
   3701   // vice-versa).
   3702   if (castACTC == ACTC_none && castType->isIntegralType(Context))
   3703     return ACR_okay;
   3704 
   3705   // Allow casts between pointers to lifetime types (e.g., __strong id*)
   3706   // and pointers to void (e.g., cv void *). Casting from void* to lifetime*
   3707   // must be explicit.
   3708   if (exprACTC == ACTC_indirectRetainable && castACTC == ACTC_voidPtr)
   3709     return ACR_okay;
   3710   if (castACTC == ACTC_indirectRetainable && exprACTC == ACTC_voidPtr &&
   3711       CCK != CCK_ImplicitConversion)
   3712     return ACR_okay;
   3713 
   3714   switch (ARCCastChecker(Context, exprACTC, castACTC, false).Visit(castExpr)) {
   3715   // For invalid casts, fall through.
   3716   case ACC_invalid:
   3717     break;
   3718 
   3719   // Do nothing for both bottom and +0.
   3720   case ACC_bottom:
   3721   case ACC_plusZero:
   3722     return ACR_okay;
   3723 
   3724   // If the result is +1, consume it here.
   3725   case ACC_plusOne:
   3726     castExpr = ImplicitCastExpr::Create(Context, castExpr->getType(),
   3727                                         CK_ARCConsumeObject, castExpr,
   3728                                         nullptr, VK_RValue);
   3729     ExprNeedsCleanups = true;
   3730     return ACR_okay;
   3731   }
   3732 
   3733   // If this is a non-implicit cast from id or block type to a
   3734   // CoreFoundation type, delay complaining in case the cast is used
   3735   // in an acceptable context.
   3736   if (exprACTC == ACTC_retainable && isAnyRetainable(castACTC) &&
   3737       CCK != CCK_ImplicitConversion)
   3738     return ACR_unbridged;
   3739 
   3740   // Do not issue bridge cast" diagnostic when implicit casting a cstring
   3741   // to 'NSString *'. Let caller issue a normal mismatched diagnostic with
   3742   // suitable fix-it.
   3743   if (castACTC == ACTC_retainable && exprACTC == ACTC_none &&
   3744       ConversionToObjCStringLiteralCheck(castType, castExpr))
   3745     return ACR_okay;
   3746 
   3747   // Do not issue "bridge cast" diagnostic when implicit casting
   3748   // a retainable object to a CF type parameter belonging to an audited
   3749   // CF API function. Let caller issue a normal type mismatched diagnostic
   3750   // instead.
   3751   if (!DiagnoseCFAudited || exprACTC != ACTC_retainable ||
   3752       castACTC != ACTC_coreFoundation)
   3753     if (!(exprACTC == ACTC_voidPtr && castACTC == ACTC_retainable &&
   3754           (Opc == BO_NE || Opc == BO_EQ)))
   3755       diagnoseObjCARCConversion(*this, castRange, castType, castACTC,
   3756                                 castExpr, castExpr, exprACTC, CCK);
   3757   return ACR_okay;
   3758 }
   3759 
   3760 /// Given that we saw an expression with the ARCUnbridgedCastTy
   3761 /// placeholder type, complain bitterly.
   3762 void Sema::diagnoseARCUnbridgedCast(Expr *e) {
   3763   // We expect the spurious ImplicitCastExpr to already have been stripped.
   3764   assert(!e->hasPlaceholderType(BuiltinType::ARCUnbridgedCast));
   3765   CastExpr *realCast = cast<CastExpr>(e->IgnoreParens());
   3766 
   3767   SourceRange castRange;
   3768   QualType castType;
   3769   CheckedConversionKind CCK;
   3770 
   3771   if (CStyleCastExpr *cast = dyn_cast<CStyleCastExpr>(realCast)) {
   3772     castRange = SourceRange(cast->getLParenLoc(), cast->getRParenLoc());
   3773     castType = cast->getTypeAsWritten();
   3774     CCK = CCK_CStyleCast;
   3775   } else if (ExplicitCastExpr *cast = dyn_cast<ExplicitCastExpr>(realCast)) {
   3776     castRange = cast->getTypeInfoAsWritten()->getTypeLoc().getSourceRange();
   3777     castType = cast->getTypeAsWritten();
   3778     CCK = CCK_OtherCast;
   3779   } else {
   3780     castType = cast->getType();
   3781     CCK = CCK_ImplicitConversion;
   3782   }
   3783 
   3784   ARCConversionTypeClass castACTC =
   3785     classifyTypeForARCConversion(castType.getNonReferenceType());
   3786 
   3787   Expr *castExpr = realCast->getSubExpr();
   3788   assert(classifyTypeForARCConversion(castExpr->getType()) == ACTC_retainable);
   3789 
   3790   diagnoseObjCARCConversion(*this, castRange, castType, castACTC,
   3791                             castExpr, realCast, ACTC_retainable, CCK);
   3792 }
   3793 
   3794 /// stripARCUnbridgedCast - Given an expression of ARCUnbridgedCast
   3795 /// type, remove the placeholder cast.
   3796 Expr *Sema::stripARCUnbridgedCast(Expr *e) {
   3797   assert(e->hasPlaceholderType(BuiltinType::ARCUnbridgedCast));
   3798 
   3799   if (ParenExpr *pe = dyn_cast<ParenExpr>(e)) {
   3800     Expr *sub = stripARCUnbridgedCast(pe->getSubExpr());
   3801     return new (Context) ParenExpr(pe->getLParen(), pe->getRParen(), sub);
   3802   } else if (UnaryOperator *uo = dyn_cast<UnaryOperator>(e)) {
   3803     assert(uo->getOpcode() == UO_Extension);
   3804     Expr *sub = stripARCUnbridgedCast(uo->getSubExpr());
   3805     return new (Context) UnaryOperator(sub, UO_Extension, sub->getType(),
   3806                                    sub->getValueKind(), sub->getObjectKind(),
   3807                                        uo->getOperatorLoc());
   3808   } else if (GenericSelectionExpr *gse = dyn_cast<GenericSelectionExpr>(e)) {
   3809     assert(!gse->isResultDependent());
   3810 
   3811     unsigned n = gse->getNumAssocs();
   3812     SmallVector<Expr*, 4> subExprs(n);
   3813     SmallVector<TypeSourceInfo*, 4> subTypes(n);
   3814     for (unsigned i = 0; i != n; ++i) {
   3815       subTypes[i] = gse->getAssocTypeSourceInfo(i);
   3816       Expr *sub = gse->getAssocExpr(i);
   3817       if (i == gse->getResultIndex())
   3818         sub = stripARCUnbridgedCast(sub);
   3819       subExprs[i] = sub;
   3820     }
   3821 
   3822     return new (Context) GenericSelectionExpr(Context, gse->getGenericLoc(),
   3823                                               gse->getControllingExpr(),
   3824                                               subTypes, subExprs,
   3825                                               gse->getDefaultLoc(),
   3826                                               gse->getRParenLoc(),
   3827                                        gse->containsUnexpandedParameterPack(),
   3828                                               gse->getResultIndex());
   3829   } else {
   3830     assert(isa<ImplicitCastExpr>(e) && "bad form of unbridged cast!");
   3831     return cast<ImplicitCastExpr>(e)->getSubExpr();
   3832   }
   3833 }
   3834 
   3835 bool Sema::CheckObjCARCUnavailableWeakConversion(QualType castType,
   3836                                                  QualType exprType) {
   3837   QualType canCastType =
   3838     Context.getCanonicalType(castType).getUnqualifiedType();
   3839   QualType canExprType =
   3840     Context.getCanonicalType(exprType).getUnqualifiedType();
   3841   if (isa<ObjCObjectPointerType>(canCastType) &&
   3842       castType.getObjCLifetime() == Qualifiers::OCL_Weak &&
   3843       canExprType->isObjCObjectPointerType()) {
   3844     if (const ObjCObjectPointerType *ObjT =
   3845         canExprType->getAs<ObjCObjectPointerType>())
   3846       if (const ObjCInterfaceDecl *ObjI = ObjT->getInterfaceDecl())
   3847         return !ObjI->isArcWeakrefUnavailable();
   3848   }
   3849   return true;
   3850 }
   3851 
   3852 /// Look for an ObjCReclaimReturnedObject cast and destroy it.
   3853 static Expr *maybeUndoReclaimObject(Expr *e) {
   3854   // For now, we just undo operands that are *immediately* reclaim
   3855   // expressions, which prevents the vast majority of potential
   3856   // problems here.  To catch them all, we'd need to rebuild arbitrary
   3857   // value-propagating subexpressions --- we can't reliably rebuild
   3858   // in-place because of expression sharing.
   3859   if (ImplicitCastExpr *ice = dyn_cast<ImplicitCastExpr>(e))
   3860     if (ice->getCastKind() == CK_ARCReclaimReturnedObject)
   3861       return ice->getSubExpr();
   3862 
   3863   return e;
   3864 }
   3865 
   3866 ExprResult Sema::BuildObjCBridgedCast(SourceLocation LParenLoc,
   3867                                       ObjCBridgeCastKind Kind,
   3868                                       SourceLocation BridgeKeywordLoc,
   3869                                       TypeSourceInfo *TSInfo,
   3870                                       Expr *SubExpr) {
   3871   ExprResult SubResult = UsualUnaryConversions(SubExpr);
   3872   if (SubResult.isInvalid()) return ExprError();
   3873   SubExpr = SubResult.get();
   3874 
   3875   QualType T = TSInfo->getType();
   3876   QualType FromType = SubExpr->getType();
   3877 
   3878   CastKind CK;
   3879 
   3880   bool MustConsume = false;
   3881   if (T->isDependentType() || SubExpr->isTypeDependent()) {
   3882     // Okay: we'll build a dependent expression type.
   3883     CK = CK_Dependent;
   3884   } else if (T->isObjCARCBridgableType() && FromType->isCARCBridgableType()) {
   3885     // Casting CF -> id
   3886     CK = (T->isBlockPointerType() ? CK_AnyPointerToBlockPointerCast
   3887                                   : CK_CPointerToObjCPointerCast);
   3888     switch (Kind) {
   3889     case OBC_Bridge:
   3890       break;
   3891 
   3892     case OBC_BridgeRetained: {
   3893       bool br = isKnownName("CFBridgingRelease");
   3894       Diag(BridgeKeywordLoc, diag::err_arc_bridge_cast_wrong_kind)
   3895         << 2
   3896         << FromType
   3897         << (T->isBlockPointerType()? 1 : 0)
   3898         << T
   3899         << SubExpr->getSourceRange()
   3900         << Kind;
   3901       Diag(BridgeKeywordLoc, diag::note_arc_bridge)
   3902         << FixItHint::CreateReplacement(BridgeKeywordLoc, "__bridge");
   3903       Diag(BridgeKeywordLoc, diag::note_arc_bridge_transfer)
   3904         << FromType << br
   3905         << FixItHint::CreateReplacement(BridgeKeywordLoc,
   3906                                         br ? "CFBridgingRelease "
   3907                                            : "__bridge_transfer ");
   3908 
   3909       Kind = OBC_Bridge;
   3910       break;
   3911     }
   3912 
   3913     case OBC_BridgeTransfer:
   3914       // We must consume the Objective-C object produced by the cast.
   3915       MustConsume = true;
   3916       break;
   3917     }
   3918   } else if (T->isCARCBridgableType() && FromType->isObjCARCBridgableType()) {
   3919     // Okay: id -> CF
   3920     CK = CK_BitCast;
   3921     switch (Kind) {
   3922     case OBC_Bridge:
   3923       // Reclaiming a value that's going to be __bridge-casted to CF
   3924       // is very dangerous, so we don't do it.
   3925       SubExpr = maybeUndoReclaimObject(SubExpr);
   3926       break;
   3927 
   3928     case OBC_BridgeRetained:
   3929       // Produce the object before casting it.
   3930       SubExpr = ImplicitCastExpr::Create(Context, FromType,
   3931                                          CK_ARCProduceObject,
   3932                                          SubExpr, nullptr, VK_RValue);
   3933       break;
   3934 
   3935     case OBC_BridgeTransfer: {
   3936       bool br = isKnownName("CFBridgingRetain");
   3937       Diag(BridgeKeywordLoc, diag::err_arc_bridge_cast_wrong_kind)
   3938         << (FromType->isBlockPointerType()? 1 : 0)
   3939         << FromType
   3940         << 2
   3941         << T
   3942         << SubExpr->getSourceRange()
   3943         << Kind;
   3944 
   3945       Diag(BridgeKeywordLoc, diag::note_arc_bridge)
   3946         << FixItHint::CreateReplacement(BridgeKeywordLoc, "__bridge ");
   3947       Diag(BridgeKeywordLoc, diag::note_arc_bridge_retained)
   3948         << T << br
   3949         << FixItHint::CreateReplacement(BridgeKeywordLoc,
   3950                           br ? "CFBridgingRetain " : "__bridge_retained");
   3951 
   3952       Kind = OBC_Bridge;
   3953       break;
   3954     }
   3955     }
   3956   } else {
   3957     Diag(LParenLoc, diag::err_arc_bridge_cast_incompatible)
   3958       << FromType << T << Kind
   3959       << SubExpr->getSourceRange()
   3960       << TSInfo->getTypeLoc().getSourceRange();
   3961     return ExprError();
   3962   }
   3963 
   3964   Expr *Result = new (Context) ObjCBridgedCastExpr(LParenLoc, Kind, CK,
   3965                                                    BridgeKeywordLoc,
   3966                                                    TSInfo, SubExpr);
   3967 
   3968   if (MustConsume) {
   3969     ExprNeedsCleanups = true;
   3970     Result = ImplicitCastExpr::Create(Context, T, CK_ARCConsumeObject, Result,
   3971                                       nullptr, VK_RValue);
   3972   }
   3973 
   3974   return Result;
   3975 }
   3976 
   3977 ExprResult Sema::ActOnObjCBridgedCast(Scope *S,
   3978                                       SourceLocation LParenLoc,
   3979                                       ObjCBridgeCastKind Kind,
   3980                                       SourceLocation BridgeKeywordLoc,
   3981                                       ParsedType Type,
   3982                                       SourceLocation RParenLoc,
   3983                                       Expr *SubExpr) {
   3984   TypeSourceInfo *TSInfo = nullptr;
   3985   QualType T = GetTypeFromParser(Type, &TSInfo);
   3986   if (Kind == OBC_Bridge)
   3987     CheckTollFreeBridgeCast(T, SubExpr);
   3988   if (!TSInfo)
   3989     TSInfo = Context.getTrivialTypeSourceInfo(T, LParenLoc);
   3990   return BuildObjCBridgedCast(LParenLoc, Kind, BridgeKeywordLoc, TSInfo,
   3991                               SubExpr);
   3992 }
   3993