1 //===--- SemaOverload.cpp - C++ Overloading -------------------------------===// 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 provides Sema routines for C++ overloading. 11 // 12 //===----------------------------------------------------------------------===// 13 14 #include "clang/Sema/Overload.h" 15 #include "clang/AST/ASTContext.h" 16 #include "clang/AST/CXXInheritance.h" 17 #include "clang/AST/DeclObjC.h" 18 #include "clang/AST/Expr.h" 19 #include "clang/AST/ExprCXX.h" 20 #include "clang/AST/ExprObjC.h" 21 #include "clang/AST/TypeOrdering.h" 22 #include "clang/Basic/Diagnostic.h" 23 #include "clang/Basic/DiagnosticOptions.h" 24 #include "clang/Basic/PartialDiagnostic.h" 25 #include "clang/Basic/TargetInfo.h" 26 #include "clang/Sema/Initialization.h" 27 #include "clang/Sema/Lookup.h" 28 #include "clang/Sema/SemaInternal.h" 29 #include "clang/Sema/Template.h" 30 #include "clang/Sema/TemplateDeduction.h" 31 #include "llvm/ADT/DenseSet.h" 32 #include "llvm/ADT/Optional.h" 33 #include "llvm/ADT/STLExtras.h" 34 #include "llvm/ADT/SmallPtrSet.h" 35 #include "llvm/ADT/SmallString.h" 36 #include <algorithm> 37 #include <cstdlib> 38 39 using namespace clang; 40 using namespace sema; 41 42 static bool functionHasPassObjectSizeParams(const FunctionDecl *FD) { 43 return llvm::any_of(FD->parameters(), [](const ParmVarDecl *P) { 44 return P->hasAttr<PassObjectSizeAttr>(); 45 }); 46 } 47 48 /// A convenience routine for creating a decayed reference to a function. 49 static ExprResult 50 CreateFunctionRefExpr(Sema &S, FunctionDecl *Fn, NamedDecl *FoundDecl, 51 const Expr *Base, bool HadMultipleCandidates, 52 SourceLocation Loc = SourceLocation(), 53 const DeclarationNameLoc &LocInfo = DeclarationNameLoc()){ 54 if (S.DiagnoseUseOfDecl(FoundDecl, Loc)) 55 return ExprError(); 56 // If FoundDecl is different from Fn (such as if one is a template 57 // and the other a specialization), make sure DiagnoseUseOfDecl is 58 // called on both. 59 // FIXME: This would be more comprehensively addressed by modifying 60 // DiagnoseUseOfDecl to accept both the FoundDecl and the decl 61 // being used. 62 if (FoundDecl != Fn && S.DiagnoseUseOfDecl(Fn, Loc)) 63 return ExprError(); 64 if (auto *FPT = Fn->getType()->getAs<FunctionProtoType>()) 65 S.ResolveExceptionSpec(Loc, FPT); 66 DeclRefExpr *DRE = new (S.Context) DeclRefExpr(Fn, false, Fn->getType(), 67 VK_LValue, Loc, LocInfo); 68 if (HadMultipleCandidates) 69 DRE->setHadMultipleCandidates(true); 70 71 S.MarkDeclRefReferenced(DRE, Base); 72 return S.ImpCastExprToType(DRE, S.Context.getPointerType(DRE->getType()), 73 CK_FunctionToPointerDecay); 74 } 75 76 static bool IsStandardConversion(Sema &S, Expr* From, QualType ToType, 77 bool InOverloadResolution, 78 StandardConversionSequence &SCS, 79 bool CStyle, 80 bool AllowObjCWritebackConversion); 81 82 static bool IsTransparentUnionStandardConversion(Sema &S, Expr* From, 83 QualType &ToType, 84 bool InOverloadResolution, 85 StandardConversionSequence &SCS, 86 bool CStyle); 87 static OverloadingResult 88 IsUserDefinedConversion(Sema &S, Expr *From, QualType ToType, 89 UserDefinedConversionSequence& User, 90 OverloadCandidateSet& Conversions, 91 bool AllowExplicit, 92 bool AllowObjCConversionOnExplicit); 93 94 95 static ImplicitConversionSequence::CompareKind 96 CompareStandardConversionSequences(Sema &S, SourceLocation Loc, 97 const StandardConversionSequence& SCS1, 98 const StandardConversionSequence& SCS2); 99 100 static ImplicitConversionSequence::CompareKind 101 CompareQualificationConversions(Sema &S, 102 const StandardConversionSequence& SCS1, 103 const StandardConversionSequence& SCS2); 104 105 static ImplicitConversionSequence::CompareKind 106 CompareDerivedToBaseConversions(Sema &S, SourceLocation Loc, 107 const StandardConversionSequence& SCS1, 108 const StandardConversionSequence& SCS2); 109 110 /// GetConversionRank - Retrieve the implicit conversion rank 111 /// corresponding to the given implicit conversion kind. 112 ImplicitConversionRank clang::GetConversionRank(ImplicitConversionKind Kind) { 113 static const ImplicitConversionRank 114 Rank[(int)ICK_Num_Conversion_Kinds] = { 115 ICR_Exact_Match, 116 ICR_Exact_Match, 117 ICR_Exact_Match, 118 ICR_Exact_Match, 119 ICR_Exact_Match, 120 ICR_Exact_Match, 121 ICR_Promotion, 122 ICR_Promotion, 123 ICR_Promotion, 124 ICR_Conversion, 125 ICR_Conversion, 126 ICR_Conversion, 127 ICR_Conversion, 128 ICR_Conversion, 129 ICR_Conversion, 130 ICR_Conversion, 131 ICR_Conversion, 132 ICR_Conversion, 133 ICR_Conversion, 134 ICR_OCL_Scalar_Widening, 135 ICR_Complex_Real_Conversion, 136 ICR_Conversion, 137 ICR_Conversion, 138 ICR_Writeback_Conversion, 139 ICR_Exact_Match, // NOTE(gbiv): This may not be completely right -- 140 // it was omitted by the patch that added 141 // ICK_Zero_Event_Conversion 142 ICR_C_Conversion, 143 ICR_C_Conversion_Extension 144 }; 145 return Rank[(int)Kind]; 146 } 147 148 /// GetImplicitConversionName - Return the name of this kind of 149 /// implicit conversion. 150 static const char* GetImplicitConversionName(ImplicitConversionKind Kind) { 151 static const char* const Name[(int)ICK_Num_Conversion_Kinds] = { 152 "No conversion", 153 "Lvalue-to-rvalue", 154 "Array-to-pointer", 155 "Function-to-pointer", 156 "Function pointer conversion", 157 "Qualification", 158 "Integral promotion", 159 "Floating point promotion", 160 "Complex promotion", 161 "Integral conversion", 162 "Floating conversion", 163 "Complex conversion", 164 "Floating-integral conversion", 165 "Pointer conversion", 166 "Pointer-to-member conversion", 167 "Boolean conversion", 168 "Compatible-types conversion", 169 "Derived-to-base conversion", 170 "Vector conversion", 171 "Vector splat", 172 "Complex-real conversion", 173 "Block Pointer conversion", 174 "Transparent Union Conversion", 175 "Writeback conversion", 176 "OpenCL Zero Event Conversion", 177 "C specific type conversion", 178 "Incompatible pointer conversion" 179 }; 180 return Name[Kind]; 181 } 182 183 /// StandardConversionSequence - Set the standard conversion 184 /// sequence to the identity conversion. 185 void StandardConversionSequence::setAsIdentityConversion() { 186 First = ICK_Identity; 187 Second = ICK_Identity; 188 Third = ICK_Identity; 189 DeprecatedStringLiteralToCharPtr = false; 190 QualificationIncludesObjCLifetime = false; 191 ReferenceBinding = false; 192 DirectBinding = false; 193 IsLvalueReference = true; 194 BindsToFunctionLvalue = false; 195 BindsToRvalue = false; 196 BindsImplicitObjectArgumentWithoutRefQualifier = false; 197 ObjCLifetimeConversionBinding = false; 198 CopyConstructor = nullptr; 199 } 200 201 /// getRank - Retrieve the rank of this standard conversion sequence 202 /// (C++ 13.3.3.1.1p3). The rank is the largest rank of each of the 203 /// implicit conversions. 204 ImplicitConversionRank StandardConversionSequence::getRank() const { 205 ImplicitConversionRank Rank = ICR_Exact_Match; 206 if (GetConversionRank(First) > Rank) 207 Rank = GetConversionRank(First); 208 if (GetConversionRank(Second) > Rank) 209 Rank = GetConversionRank(Second); 210 if (GetConversionRank(Third) > Rank) 211 Rank = GetConversionRank(Third); 212 return Rank; 213 } 214 215 /// isPointerConversionToBool - Determines whether this conversion is 216 /// a conversion of a pointer or pointer-to-member to bool. This is 217 /// used as part of the ranking of standard conversion sequences 218 /// (C++ 13.3.3.2p4). 219 bool StandardConversionSequence::isPointerConversionToBool() const { 220 // Note that FromType has not necessarily been transformed by the 221 // array-to-pointer or function-to-pointer implicit conversions, so 222 // check for their presence as well as checking whether FromType is 223 // a pointer. 224 if (getToType(1)->isBooleanType() && 225 (getFromType()->isPointerType() || 226 getFromType()->isObjCObjectPointerType() || 227 getFromType()->isBlockPointerType() || 228 getFromType()->isNullPtrType() || 229 First == ICK_Array_To_Pointer || First == ICK_Function_To_Pointer)) 230 return true; 231 232 return false; 233 } 234 235 /// isPointerConversionToVoidPointer - Determines whether this 236 /// conversion is a conversion of a pointer to a void pointer. This is 237 /// used as part of the ranking of standard conversion sequences (C++ 238 /// 13.3.3.2p4). 239 bool 240 StandardConversionSequence:: 241 isPointerConversionToVoidPointer(ASTContext& Context) const { 242 QualType FromType = getFromType(); 243 QualType ToType = getToType(1); 244 245 // Note that FromType has not necessarily been transformed by the 246 // array-to-pointer implicit conversion, so check for its presence 247 // and redo the conversion to get a pointer. 248 if (First == ICK_Array_To_Pointer) 249 FromType = Context.getArrayDecayedType(FromType); 250 251 if (Second == ICK_Pointer_Conversion && FromType->isAnyPointerType()) 252 if (const PointerType* ToPtrType = ToType->getAs<PointerType>()) 253 return ToPtrType->getPointeeType()->isVoidType(); 254 255 return false; 256 } 257 258 /// Skip any implicit casts which could be either part of a narrowing conversion 259 /// or after one in an implicit conversion. 260 static const Expr *IgnoreNarrowingConversion(const Expr *Converted) { 261 while (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(Converted)) { 262 switch (ICE->getCastKind()) { 263 case CK_NoOp: 264 case CK_IntegralCast: 265 case CK_IntegralToBoolean: 266 case CK_IntegralToFloating: 267 case CK_BooleanToSignedIntegral: 268 case CK_FloatingToIntegral: 269 case CK_FloatingToBoolean: 270 case CK_FloatingCast: 271 Converted = ICE->getSubExpr(); 272 continue; 273 274 default: 275 return Converted; 276 } 277 } 278 279 return Converted; 280 } 281 282 /// Check if this standard conversion sequence represents a narrowing 283 /// conversion, according to C++11 [dcl.init.list]p7. 284 /// 285 /// \param Ctx The AST context. 286 /// \param Converted The result of applying this standard conversion sequence. 287 /// \param ConstantValue If this is an NK_Constant_Narrowing conversion, the 288 /// value of the expression prior to the narrowing conversion. 289 /// \param ConstantType If this is an NK_Constant_Narrowing conversion, the 290 /// type of the expression prior to the narrowing conversion. 291 NarrowingKind 292 StandardConversionSequence::getNarrowingKind(ASTContext &Ctx, 293 const Expr *Converted, 294 APValue &ConstantValue, 295 QualType &ConstantType) const { 296 assert(Ctx.getLangOpts().CPlusPlus && "narrowing check outside C++"); 297 298 // C++11 [dcl.init.list]p7: 299 // A narrowing conversion is an implicit conversion ... 300 QualType FromType = getToType(0); 301 QualType ToType = getToType(1); 302 303 // A conversion to an enumeration type is narrowing if the conversion to 304 // the underlying type is narrowing. This only arises for expressions of 305 // the form 'Enum{init}'. 306 if (auto *ET = ToType->getAs<EnumType>()) 307 ToType = ET->getDecl()->getIntegerType(); 308 309 switch (Second) { 310 // 'bool' is an integral type; dispatch to the right place to handle it. 311 case ICK_Boolean_Conversion: 312 if (FromType->isRealFloatingType()) 313 goto FloatingIntegralConversion; 314 if (FromType->isIntegralOrUnscopedEnumerationType()) 315 goto IntegralConversion; 316 // Boolean conversions can be from pointers and pointers to members 317 // [conv.bool], and those aren't considered narrowing conversions. 318 return NK_Not_Narrowing; 319 320 // -- from a floating-point type to an integer type, or 321 // 322 // -- from an integer type or unscoped enumeration type to a floating-point 323 // type, except where the source is a constant expression and the actual 324 // value after conversion will fit into the target type and will produce 325 // the original value when converted back to the original type, or 326 case ICK_Floating_Integral: 327 FloatingIntegralConversion: 328 if (FromType->isRealFloatingType() && ToType->isIntegralType(Ctx)) { 329 return NK_Type_Narrowing; 330 } else if (FromType->isIntegralType(Ctx) && ToType->isRealFloatingType()) { 331 llvm::APSInt IntConstantValue; 332 const Expr *Initializer = IgnoreNarrowingConversion(Converted); 333 assert(Initializer && "Unknown conversion expression"); 334 335 // If it's value-dependent, we can't tell whether it's narrowing. 336 if (Initializer->isValueDependent()) 337 return NK_Dependent_Narrowing; 338 339 if (Initializer->isIntegerConstantExpr(IntConstantValue, Ctx)) { 340 // Convert the integer to the floating type. 341 llvm::APFloat Result(Ctx.getFloatTypeSemantics(ToType)); 342 Result.convertFromAPInt(IntConstantValue, IntConstantValue.isSigned(), 343 llvm::APFloat::rmNearestTiesToEven); 344 // And back. 345 llvm::APSInt ConvertedValue = IntConstantValue; 346 bool ignored; 347 Result.convertToInteger(ConvertedValue, 348 llvm::APFloat::rmTowardZero, &ignored); 349 // If the resulting value is different, this was a narrowing conversion. 350 if (IntConstantValue != ConvertedValue) { 351 ConstantValue = APValue(IntConstantValue); 352 ConstantType = Initializer->getType(); 353 return NK_Constant_Narrowing; 354 } 355 } else { 356 // Variables are always narrowings. 357 return NK_Variable_Narrowing; 358 } 359 } 360 return NK_Not_Narrowing; 361 362 // -- from long double to double or float, or from double to float, except 363 // where the source is a constant expression and the actual value after 364 // conversion is within the range of values that can be represented (even 365 // if it cannot be represented exactly), or 366 case ICK_Floating_Conversion: 367 if (FromType->isRealFloatingType() && ToType->isRealFloatingType() && 368 Ctx.getFloatingTypeOrder(FromType, ToType) == 1) { 369 // FromType is larger than ToType. 370 const Expr *Initializer = IgnoreNarrowingConversion(Converted); 371 372 // If it's value-dependent, we can't tell whether it's narrowing. 373 if (Initializer->isValueDependent()) 374 return NK_Dependent_Narrowing; 375 376 if (Initializer->isCXX11ConstantExpr(Ctx, &ConstantValue)) { 377 // Constant! 378 assert(ConstantValue.isFloat()); 379 llvm::APFloat FloatVal = ConstantValue.getFloat(); 380 // Convert the source value into the target type. 381 bool ignored; 382 llvm::APFloat::opStatus ConvertStatus = FloatVal.convert( 383 Ctx.getFloatTypeSemantics(ToType), 384 llvm::APFloat::rmNearestTiesToEven, &ignored); 385 // If there was no overflow, the source value is within the range of 386 // values that can be represented. 387 if (ConvertStatus & llvm::APFloat::opOverflow) { 388 ConstantType = Initializer->getType(); 389 return NK_Constant_Narrowing; 390 } 391 } else { 392 return NK_Variable_Narrowing; 393 } 394 } 395 return NK_Not_Narrowing; 396 397 // -- from an integer type or unscoped enumeration type to an integer type 398 // that cannot represent all the values of the original type, except where 399 // the source is a constant expression and the actual value after 400 // conversion will fit into the target type and will produce the original 401 // value when converted back to the original type. 402 case ICK_Integral_Conversion: 403 IntegralConversion: { 404 assert(FromType->isIntegralOrUnscopedEnumerationType()); 405 assert(ToType->isIntegralOrUnscopedEnumerationType()); 406 const bool FromSigned = FromType->isSignedIntegerOrEnumerationType(); 407 const unsigned FromWidth = Ctx.getIntWidth(FromType); 408 const bool ToSigned = ToType->isSignedIntegerOrEnumerationType(); 409 const unsigned ToWidth = Ctx.getIntWidth(ToType); 410 411 if (FromWidth > ToWidth || 412 (FromWidth == ToWidth && FromSigned != ToSigned) || 413 (FromSigned && !ToSigned)) { 414 // Not all values of FromType can be represented in ToType. 415 llvm::APSInt InitializerValue; 416 const Expr *Initializer = IgnoreNarrowingConversion(Converted); 417 418 // If it's value-dependent, we can't tell whether it's narrowing. 419 if (Initializer->isValueDependent()) 420 return NK_Dependent_Narrowing; 421 422 if (!Initializer->isIntegerConstantExpr(InitializerValue, Ctx)) { 423 // Such conversions on variables are always narrowing. 424 return NK_Variable_Narrowing; 425 } 426 bool Narrowing = false; 427 if (FromWidth < ToWidth) { 428 // Negative -> unsigned is narrowing. Otherwise, more bits is never 429 // narrowing. 430 if (InitializerValue.isSigned() && InitializerValue.isNegative()) 431 Narrowing = true; 432 } else { 433 // Add a bit to the InitializerValue so we don't have to worry about 434 // signed vs. unsigned comparisons. 435 InitializerValue = InitializerValue.extend( 436 InitializerValue.getBitWidth() + 1); 437 // Convert the initializer to and from the target width and signed-ness. 438 llvm::APSInt ConvertedValue = InitializerValue; 439 ConvertedValue = ConvertedValue.trunc(ToWidth); 440 ConvertedValue.setIsSigned(ToSigned); 441 ConvertedValue = ConvertedValue.extend(InitializerValue.getBitWidth()); 442 ConvertedValue.setIsSigned(InitializerValue.isSigned()); 443 // If the result is different, this was a narrowing conversion. 444 if (ConvertedValue != InitializerValue) 445 Narrowing = true; 446 } 447 if (Narrowing) { 448 ConstantType = Initializer->getType(); 449 ConstantValue = APValue(InitializerValue); 450 return NK_Constant_Narrowing; 451 } 452 } 453 return NK_Not_Narrowing; 454 } 455 456 default: 457 // Other kinds of conversions are not narrowings. 458 return NK_Not_Narrowing; 459 } 460 } 461 462 /// dump - Print this standard conversion sequence to standard 463 /// error. Useful for debugging overloading issues. 464 LLVM_DUMP_METHOD void StandardConversionSequence::dump() const { 465 raw_ostream &OS = llvm::errs(); 466 bool PrintedSomething = false; 467 if (First != ICK_Identity) { 468 OS << GetImplicitConversionName(First); 469 PrintedSomething = true; 470 } 471 472 if (Second != ICK_Identity) { 473 if (PrintedSomething) { 474 OS << " -> "; 475 } 476 OS << GetImplicitConversionName(Second); 477 478 if (CopyConstructor) { 479 OS << " (by copy constructor)"; 480 } else if (DirectBinding) { 481 OS << " (direct reference binding)"; 482 } else if (ReferenceBinding) { 483 OS << " (reference binding)"; 484 } 485 PrintedSomething = true; 486 } 487 488 if (Third != ICK_Identity) { 489 if (PrintedSomething) { 490 OS << " -> "; 491 } 492 OS << GetImplicitConversionName(Third); 493 PrintedSomething = true; 494 } 495 496 if (!PrintedSomething) { 497 OS << "No conversions required"; 498 } 499 } 500 501 /// dump - Print this user-defined conversion sequence to standard 502 /// error. Useful for debugging overloading issues. 503 void UserDefinedConversionSequence::dump() const { 504 raw_ostream &OS = llvm::errs(); 505 if (Before.First || Before.Second || Before.Third) { 506 Before.dump(); 507 OS << " -> "; 508 } 509 if (ConversionFunction) 510 OS << '\'' << *ConversionFunction << '\''; 511 else 512 OS << "aggregate initialization"; 513 if (After.First || After.Second || After.Third) { 514 OS << " -> "; 515 After.dump(); 516 } 517 } 518 519 /// dump - Print this implicit conversion sequence to standard 520 /// error. Useful for debugging overloading issues. 521 void ImplicitConversionSequence::dump() const { 522 raw_ostream &OS = llvm::errs(); 523 if (isStdInitializerListElement()) 524 OS << "Worst std::initializer_list element conversion: "; 525 switch (ConversionKind) { 526 case StandardConversion: 527 OS << "Standard conversion: "; 528 Standard.dump(); 529 break; 530 case UserDefinedConversion: 531 OS << "User-defined conversion: "; 532 UserDefined.dump(); 533 break; 534 case EllipsisConversion: 535 OS << "Ellipsis conversion"; 536 break; 537 case AmbiguousConversion: 538 OS << "Ambiguous conversion"; 539 break; 540 case BadConversion: 541 OS << "Bad conversion"; 542 break; 543 } 544 545 OS << "\n"; 546 } 547 548 void AmbiguousConversionSequence::construct() { 549 new (&conversions()) ConversionSet(); 550 } 551 552 void AmbiguousConversionSequence::destruct() { 553 conversions().~ConversionSet(); 554 } 555 556 void 557 AmbiguousConversionSequence::copyFrom(const AmbiguousConversionSequence &O) { 558 FromTypePtr = O.FromTypePtr; 559 ToTypePtr = O.ToTypePtr; 560 new (&conversions()) ConversionSet(O.conversions()); 561 } 562 563 namespace { 564 // Structure used by DeductionFailureInfo to store 565 // template argument information. 566 struct DFIArguments { 567 TemplateArgument FirstArg; 568 TemplateArgument SecondArg; 569 }; 570 // Structure used by DeductionFailureInfo to store 571 // template parameter and template argument information. 572 struct DFIParamWithArguments : DFIArguments { 573 TemplateParameter Param; 574 }; 575 // Structure used by DeductionFailureInfo to store template argument 576 // information and the index of the problematic call argument. 577 struct DFIDeducedMismatchArgs : DFIArguments { 578 TemplateArgumentList *TemplateArgs; 579 unsigned CallArgIndex; 580 }; 581 } 582 583 /// \brief Convert from Sema's representation of template deduction information 584 /// to the form used in overload-candidate information. 585 DeductionFailureInfo 586 clang::MakeDeductionFailureInfo(ASTContext &Context, 587 Sema::TemplateDeductionResult TDK, 588 TemplateDeductionInfo &Info) { 589 DeductionFailureInfo Result; 590 Result.Result = static_cast<unsigned>(TDK); 591 Result.HasDiagnostic = false; 592 switch (TDK) { 593 case Sema::TDK_Invalid: 594 case Sema::TDK_InstantiationDepth: 595 case Sema::TDK_TooManyArguments: 596 case Sema::TDK_TooFewArguments: 597 case Sema::TDK_MiscellaneousDeductionFailure: 598 case Sema::TDK_CUDATargetMismatch: 599 Result.Data = nullptr; 600 break; 601 602 case Sema::TDK_Incomplete: 603 case Sema::TDK_InvalidExplicitArguments: 604 Result.Data = Info.Param.getOpaqueValue(); 605 break; 606 607 case Sema::TDK_DeducedMismatch: 608 case Sema::TDK_DeducedMismatchNested: { 609 // FIXME: Should allocate from normal heap so that we can free this later. 610 auto *Saved = new (Context) DFIDeducedMismatchArgs; 611 Saved->FirstArg = Info.FirstArg; 612 Saved->SecondArg = Info.SecondArg; 613 Saved->TemplateArgs = Info.take(); 614 Saved->CallArgIndex = Info.CallArgIndex; 615 Result.Data = Saved; 616 break; 617 } 618 619 case Sema::TDK_NonDeducedMismatch: { 620 // FIXME: Should allocate from normal heap so that we can free this later. 621 DFIArguments *Saved = new (Context) DFIArguments; 622 Saved->FirstArg = Info.FirstArg; 623 Saved->SecondArg = Info.SecondArg; 624 Result.Data = Saved; 625 break; 626 } 627 628 case Sema::TDK_Inconsistent: 629 case Sema::TDK_Underqualified: { 630 // FIXME: Should allocate from normal heap so that we can free this later. 631 DFIParamWithArguments *Saved = new (Context) DFIParamWithArguments; 632 Saved->Param = Info.Param; 633 Saved->FirstArg = Info.FirstArg; 634 Saved->SecondArg = Info.SecondArg; 635 Result.Data = Saved; 636 break; 637 } 638 639 case Sema::TDK_SubstitutionFailure: 640 Result.Data = Info.take(); 641 if (Info.hasSFINAEDiagnostic()) { 642 PartialDiagnosticAt *Diag = new (Result.Diagnostic) PartialDiagnosticAt( 643 SourceLocation(), PartialDiagnostic::NullDiagnostic()); 644 Info.takeSFINAEDiagnostic(*Diag); 645 Result.HasDiagnostic = true; 646 } 647 break; 648 649 case Sema::TDK_Success: 650 case Sema::TDK_NonDependentConversionFailure: 651 llvm_unreachable("not a deduction failure"); 652 } 653 654 return Result; 655 } 656 657 void DeductionFailureInfo::Destroy() { 658 switch (static_cast<Sema::TemplateDeductionResult>(Result)) { 659 case Sema::TDK_Success: 660 case Sema::TDK_Invalid: 661 case Sema::TDK_InstantiationDepth: 662 case Sema::TDK_Incomplete: 663 case Sema::TDK_TooManyArguments: 664 case Sema::TDK_TooFewArguments: 665 case Sema::TDK_InvalidExplicitArguments: 666 case Sema::TDK_CUDATargetMismatch: 667 case Sema::TDK_NonDependentConversionFailure: 668 break; 669 670 case Sema::TDK_Inconsistent: 671 case Sema::TDK_Underqualified: 672 case Sema::TDK_DeducedMismatch: 673 case Sema::TDK_DeducedMismatchNested: 674 case Sema::TDK_NonDeducedMismatch: 675 // FIXME: Destroy the data? 676 Data = nullptr; 677 break; 678 679 case Sema::TDK_SubstitutionFailure: 680 // FIXME: Destroy the template argument list? 681 Data = nullptr; 682 if (PartialDiagnosticAt *Diag = getSFINAEDiagnostic()) { 683 Diag->~PartialDiagnosticAt(); 684 HasDiagnostic = false; 685 } 686 break; 687 688 // Unhandled 689 case Sema::TDK_MiscellaneousDeductionFailure: 690 break; 691 } 692 } 693 694 PartialDiagnosticAt *DeductionFailureInfo::getSFINAEDiagnostic() { 695 if (HasDiagnostic) 696 return static_cast<PartialDiagnosticAt*>(static_cast<void*>(Diagnostic)); 697 return nullptr; 698 } 699 700 TemplateParameter DeductionFailureInfo::getTemplateParameter() { 701 switch (static_cast<Sema::TemplateDeductionResult>(Result)) { 702 case Sema::TDK_Success: 703 case Sema::TDK_Invalid: 704 case Sema::TDK_InstantiationDepth: 705 case Sema::TDK_TooManyArguments: 706 case Sema::TDK_TooFewArguments: 707 case Sema::TDK_SubstitutionFailure: 708 case Sema::TDK_DeducedMismatch: 709 case Sema::TDK_DeducedMismatchNested: 710 case Sema::TDK_NonDeducedMismatch: 711 case Sema::TDK_CUDATargetMismatch: 712 case Sema::TDK_NonDependentConversionFailure: 713 return TemplateParameter(); 714 715 case Sema::TDK_Incomplete: 716 case Sema::TDK_InvalidExplicitArguments: 717 return TemplateParameter::getFromOpaqueValue(Data); 718 719 case Sema::TDK_Inconsistent: 720 case Sema::TDK_Underqualified: 721 return static_cast<DFIParamWithArguments*>(Data)->Param; 722 723 // Unhandled 724 case Sema::TDK_MiscellaneousDeductionFailure: 725 break; 726 } 727 728 return TemplateParameter(); 729 } 730 731 TemplateArgumentList *DeductionFailureInfo::getTemplateArgumentList() { 732 switch (static_cast<Sema::TemplateDeductionResult>(Result)) { 733 case Sema::TDK_Success: 734 case Sema::TDK_Invalid: 735 case Sema::TDK_InstantiationDepth: 736 case Sema::TDK_TooManyArguments: 737 case Sema::TDK_TooFewArguments: 738 case Sema::TDK_Incomplete: 739 case Sema::TDK_InvalidExplicitArguments: 740 case Sema::TDK_Inconsistent: 741 case Sema::TDK_Underqualified: 742 case Sema::TDK_NonDeducedMismatch: 743 case Sema::TDK_CUDATargetMismatch: 744 case Sema::TDK_NonDependentConversionFailure: 745 return nullptr; 746 747 case Sema::TDK_DeducedMismatch: 748 case Sema::TDK_DeducedMismatchNested: 749 return static_cast<DFIDeducedMismatchArgs*>(Data)->TemplateArgs; 750 751 case Sema::TDK_SubstitutionFailure: 752 return static_cast<TemplateArgumentList*>(Data); 753 754 // Unhandled 755 case Sema::TDK_MiscellaneousDeductionFailure: 756 break; 757 } 758 759 return nullptr; 760 } 761 762 const TemplateArgument *DeductionFailureInfo::getFirstArg() { 763 switch (static_cast<Sema::TemplateDeductionResult>(Result)) { 764 case Sema::TDK_Success: 765 case Sema::TDK_Invalid: 766 case Sema::TDK_InstantiationDepth: 767 case Sema::TDK_Incomplete: 768 case Sema::TDK_TooManyArguments: 769 case Sema::TDK_TooFewArguments: 770 case Sema::TDK_InvalidExplicitArguments: 771 case Sema::TDK_SubstitutionFailure: 772 case Sema::TDK_CUDATargetMismatch: 773 case Sema::TDK_NonDependentConversionFailure: 774 return nullptr; 775 776 case Sema::TDK_Inconsistent: 777 case Sema::TDK_Underqualified: 778 case Sema::TDK_DeducedMismatch: 779 case Sema::TDK_DeducedMismatchNested: 780 case Sema::TDK_NonDeducedMismatch: 781 return &static_cast<DFIArguments*>(Data)->FirstArg; 782 783 // Unhandled 784 case Sema::TDK_MiscellaneousDeductionFailure: 785 break; 786 } 787 788 return nullptr; 789 } 790 791 const TemplateArgument *DeductionFailureInfo::getSecondArg() { 792 switch (static_cast<Sema::TemplateDeductionResult>(Result)) { 793 case Sema::TDK_Success: 794 case Sema::TDK_Invalid: 795 case Sema::TDK_InstantiationDepth: 796 case Sema::TDK_Incomplete: 797 case Sema::TDK_TooManyArguments: 798 case Sema::TDK_TooFewArguments: 799 case Sema::TDK_InvalidExplicitArguments: 800 case Sema::TDK_SubstitutionFailure: 801 case Sema::TDK_CUDATargetMismatch: 802 case Sema::TDK_NonDependentConversionFailure: 803 return nullptr; 804 805 case Sema::TDK_Inconsistent: 806 case Sema::TDK_Underqualified: 807 case Sema::TDK_DeducedMismatch: 808 case Sema::TDK_DeducedMismatchNested: 809 case Sema::TDK_NonDeducedMismatch: 810 return &static_cast<DFIArguments*>(Data)->SecondArg; 811 812 // Unhandled 813 case Sema::TDK_MiscellaneousDeductionFailure: 814 break; 815 } 816 817 return nullptr; 818 } 819 820 llvm::Optional<unsigned> DeductionFailureInfo::getCallArgIndex() { 821 switch (static_cast<Sema::TemplateDeductionResult>(Result)) { 822 case Sema::TDK_DeducedMismatch: 823 case Sema::TDK_DeducedMismatchNested: 824 return static_cast<DFIDeducedMismatchArgs*>(Data)->CallArgIndex; 825 826 default: 827 return llvm::None; 828 } 829 } 830 831 void OverloadCandidateSet::destroyCandidates() { 832 for (iterator i = begin(), e = end(); i != e; ++i) { 833 for (auto &C : i->Conversions) 834 C.~ImplicitConversionSequence(); 835 if (!i->Viable && i->FailureKind == ovl_fail_bad_deduction) 836 i->DeductionFailure.Destroy(); 837 } 838 } 839 840 void OverloadCandidateSet::clear(CandidateSetKind CSK) { 841 destroyCandidates(); 842 SlabAllocator.Reset(); 843 NumInlineBytesUsed = 0; 844 Candidates.clear(); 845 Functions.clear(); 846 Kind = CSK; 847 } 848 849 namespace { 850 class UnbridgedCastsSet { 851 struct Entry { 852 Expr **Addr; 853 Expr *Saved; 854 }; 855 SmallVector<Entry, 2> Entries; 856 857 public: 858 void save(Sema &S, Expr *&E) { 859 assert(E->hasPlaceholderType(BuiltinType::ARCUnbridgedCast)); 860 Entry entry = { &E, E }; 861 Entries.push_back(entry); 862 E = S.stripARCUnbridgedCast(E); 863 } 864 865 void restore() { 866 for (SmallVectorImpl<Entry>::iterator 867 i = Entries.begin(), e = Entries.end(); i != e; ++i) 868 *i->Addr = i->Saved; 869 } 870 }; 871 } 872 873 /// checkPlaceholderForOverload - Do any interesting placeholder-like 874 /// preprocessing on the given expression. 875 /// 876 /// \param unbridgedCasts a collection to which to add unbridged casts; 877 /// without this, they will be immediately diagnosed as errors 878 /// 879 /// Return true on unrecoverable error. 880 static bool 881 checkPlaceholderForOverload(Sema &S, Expr *&E, 882 UnbridgedCastsSet *unbridgedCasts = nullptr) { 883 if (const BuiltinType *placeholder = E->getType()->getAsPlaceholderType()) { 884 // We can't handle overloaded expressions here because overload 885 // resolution might reasonably tweak them. 886 if (placeholder->getKind() == BuiltinType::Overload) return false; 887 888 // If the context potentially accepts unbridged ARC casts, strip 889 // the unbridged cast and add it to the collection for later restoration. 890 if (placeholder->getKind() == BuiltinType::ARCUnbridgedCast && 891 unbridgedCasts) { 892 unbridgedCasts->save(S, E); 893 return false; 894 } 895 896 // Go ahead and check everything else. 897 ExprResult result = S.CheckPlaceholderExpr(E); 898 if (result.isInvalid()) 899 return true; 900 901 E = result.get(); 902 return false; 903 } 904 905 // Nothing to do. 906 return false; 907 } 908 909 /// checkArgPlaceholdersForOverload - Check a set of call operands for 910 /// placeholders. 911 static bool checkArgPlaceholdersForOverload(Sema &S, 912 MultiExprArg Args, 913 UnbridgedCastsSet &unbridged) { 914 for (unsigned i = 0, e = Args.size(); i != e; ++i) 915 if (checkPlaceholderForOverload(S, Args[i], &unbridged)) 916 return true; 917 918 return false; 919 } 920 921 /// Determine whether the given New declaration is an overload of the 922 /// declarations in Old. This routine returns Ovl_Match or Ovl_NonFunction if 923 /// New and Old cannot be overloaded, e.g., if New has the same signature as 924 /// some function in Old (C++ 1.3.10) or if the Old declarations aren't 925 /// functions (or function templates) at all. When it does return Ovl_Match or 926 /// Ovl_NonFunction, MatchedDecl will point to the decl that New cannot be 927 /// overloaded with. This decl may be a UsingShadowDecl on top of the underlying 928 /// declaration. 929 /// 930 /// Example: Given the following input: 931 /// 932 /// void f(int, float); // #1 933 /// void f(int, int); // #2 934 /// int f(int, int); // #3 935 /// 936 /// When we process #1, there is no previous declaration of "f", so IsOverload 937 /// will not be used. 938 /// 939 /// When we process #2, Old contains only the FunctionDecl for #1. By comparing 940 /// the parameter types, we see that #1 and #2 are overloaded (since they have 941 /// different signatures), so this routine returns Ovl_Overload; MatchedDecl is 942 /// unchanged. 943 /// 944 /// When we process #3, Old is an overload set containing #1 and #2. We compare 945 /// the signatures of #3 to #1 (they're overloaded, so we do nothing) and then 946 /// #3 to #2. Since the signatures of #3 and #2 are identical (return types of 947 /// functions are not part of the signature), IsOverload returns Ovl_Match and 948 /// MatchedDecl will be set to point to the FunctionDecl for #2. 949 /// 950 /// 'NewIsUsingShadowDecl' indicates that 'New' is being introduced into a class 951 /// by a using declaration. The rules for whether to hide shadow declarations 952 /// ignore some properties which otherwise figure into a function template's 953 /// signature. 954 Sema::OverloadKind 955 Sema::CheckOverload(Scope *S, FunctionDecl *New, const LookupResult &Old, 956 NamedDecl *&Match, bool NewIsUsingDecl) { 957 for (LookupResult::iterator I = Old.begin(), E = Old.end(); 958 I != E; ++I) { 959 NamedDecl *OldD = *I; 960 961 bool OldIsUsingDecl = false; 962 if (isa<UsingShadowDecl>(OldD)) { 963 OldIsUsingDecl = true; 964 965 // We can always introduce two using declarations into the same 966 // context, even if they have identical signatures. 967 if (NewIsUsingDecl) continue; 968 969 OldD = cast<UsingShadowDecl>(OldD)->getTargetDecl(); 970 } 971 972 // A using-declaration does not conflict with another declaration 973 // if one of them is hidden. 974 if ((OldIsUsingDecl || NewIsUsingDecl) && !isVisible(*I)) 975 continue; 976 977 // If either declaration was introduced by a using declaration, 978 // we'll need to use slightly different rules for matching. 979 // Essentially, these rules are the normal rules, except that 980 // function templates hide function templates with different 981 // return types or template parameter lists. 982 bool UseMemberUsingDeclRules = 983 (OldIsUsingDecl || NewIsUsingDecl) && CurContext->isRecord() && 984 !New->getFriendObjectKind(); 985 986 if (FunctionDecl *OldF = OldD->getAsFunction()) { 987 if (!IsOverload(New, OldF, UseMemberUsingDeclRules)) { 988 if (UseMemberUsingDeclRules && OldIsUsingDecl) { 989 HideUsingShadowDecl(S, cast<UsingShadowDecl>(*I)); 990 continue; 991 } 992 993 if (!isa<FunctionTemplateDecl>(OldD) && 994 !shouldLinkPossiblyHiddenDecl(*I, New)) 995 continue; 996 997 Match = *I; 998 return Ovl_Match; 999 } 1000 } else if (isa<UsingDecl>(OldD) || isa<UsingPackDecl>(OldD)) { 1001 // We can overload with these, which can show up when doing 1002 // redeclaration checks for UsingDecls. 1003 assert(Old.getLookupKind() == LookupUsingDeclName); 1004 } else if (isa<TagDecl>(OldD)) { 1005 // We can always overload with tags by hiding them. 1006 } else if (auto *UUD = dyn_cast<UnresolvedUsingValueDecl>(OldD)) { 1007 // Optimistically assume that an unresolved using decl will 1008 // overload; if it doesn't, we'll have to diagnose during 1009 // template instantiation. 1010 // 1011 // Exception: if the scope is dependent and this is not a class 1012 // member, the using declaration can only introduce an enumerator. 1013 if (UUD->getQualifier()->isDependent() && !UUD->isCXXClassMember()) { 1014 Match = *I; 1015 return Ovl_NonFunction; 1016 } 1017 } else { 1018 // (C++ 13p1): 1019 // Only function declarations can be overloaded; object and type 1020 // declarations cannot be overloaded. 1021 Match = *I; 1022 return Ovl_NonFunction; 1023 } 1024 } 1025 1026 return Ovl_Overload; 1027 } 1028 1029 bool Sema::IsOverload(FunctionDecl *New, FunctionDecl *Old, 1030 bool UseMemberUsingDeclRules, bool ConsiderCudaAttrs) { 1031 // C++ [basic.start.main]p2: This function shall not be overloaded. 1032 if (New->isMain()) 1033 return false; 1034 1035 // MSVCRT user defined entry points cannot be overloaded. 1036 if (New->isMSVCRTEntryPoint()) 1037 return false; 1038 1039 FunctionTemplateDecl *OldTemplate = Old->getDescribedFunctionTemplate(); 1040 FunctionTemplateDecl *NewTemplate = New->getDescribedFunctionTemplate(); 1041 1042 // C++ [temp.fct]p2: 1043 // A function template can be overloaded with other function templates 1044 // and with normal (non-template) functions. 1045 if ((OldTemplate == nullptr) != (NewTemplate == nullptr)) 1046 return true; 1047 1048 // Is the function New an overload of the function Old? 1049 QualType OldQType = Context.getCanonicalType(Old->getType()); 1050 QualType NewQType = Context.getCanonicalType(New->getType()); 1051 1052 // Compare the signatures (C++ 1.3.10) of the two functions to 1053 // determine whether they are overloads. If we find any mismatch 1054 // in the signature, they are overloads. 1055 1056 // If either of these functions is a K&R-style function (no 1057 // prototype), then we consider them to have matching signatures. 1058 if (isa<FunctionNoProtoType>(OldQType.getTypePtr()) || 1059 isa<FunctionNoProtoType>(NewQType.getTypePtr())) 1060 return false; 1061 1062 const FunctionProtoType *OldType = cast<FunctionProtoType>(OldQType); 1063 const FunctionProtoType *NewType = cast<FunctionProtoType>(NewQType); 1064 1065 // The signature of a function includes the types of its 1066 // parameters (C++ 1.3.10), which includes the presence or absence 1067 // of the ellipsis; see C++ DR 357). 1068 if (OldQType != NewQType && 1069 (OldType->getNumParams() != NewType->getNumParams() || 1070 OldType->isVariadic() != NewType->isVariadic() || 1071 !FunctionParamTypesAreEqual(OldType, NewType))) 1072 return true; 1073 1074 // C++ [temp.over.link]p4: 1075 // The signature of a function template consists of its function 1076 // signature, its return type and its template parameter list. The names 1077 // of the template parameters are significant only for establishing the 1078 // relationship between the template parameters and the rest of the 1079 // signature. 1080 // 1081 // We check the return type and template parameter lists for function 1082 // templates first; the remaining checks follow. 1083 // 1084 // However, we don't consider either of these when deciding whether 1085 // a member introduced by a shadow declaration is hidden. 1086 if (!UseMemberUsingDeclRules && NewTemplate && 1087 (!TemplateParameterListsAreEqual(NewTemplate->getTemplateParameters(), 1088 OldTemplate->getTemplateParameters(), 1089 false, TPL_TemplateMatch) || 1090 OldType->getReturnType() != NewType->getReturnType())) 1091 return true; 1092 1093 // If the function is a class member, its signature includes the 1094 // cv-qualifiers (if any) and ref-qualifier (if any) on the function itself. 1095 // 1096 // As part of this, also check whether one of the member functions 1097 // is static, in which case they are not overloads (C++ 1098 // 13.1p2). While not part of the definition of the signature, 1099 // this check is important to determine whether these functions 1100 // can be overloaded. 1101 CXXMethodDecl *OldMethod = dyn_cast<CXXMethodDecl>(Old); 1102 CXXMethodDecl *NewMethod = dyn_cast<CXXMethodDecl>(New); 1103 if (OldMethod && NewMethod && 1104 !OldMethod->isStatic() && !NewMethod->isStatic()) { 1105 if (OldMethod->getRefQualifier() != NewMethod->getRefQualifier()) { 1106 if (!UseMemberUsingDeclRules && 1107 (OldMethod->getRefQualifier() == RQ_None || 1108 NewMethod->getRefQualifier() == RQ_None)) { 1109 // C++0x [over.load]p2: 1110 // - Member function declarations with the same name and the same 1111 // parameter-type-list as well as member function template 1112 // declarations with the same name, the same parameter-type-list, and 1113 // the same template parameter lists cannot be overloaded if any of 1114 // them, but not all, have a ref-qualifier (8.3.5). 1115 Diag(NewMethod->getLocation(), diag::err_ref_qualifier_overload) 1116 << NewMethod->getRefQualifier() << OldMethod->getRefQualifier(); 1117 Diag(OldMethod->getLocation(), diag::note_previous_declaration); 1118 } 1119 return true; 1120 } 1121 1122 // We may not have applied the implicit const for a constexpr member 1123 // function yet (because we haven't yet resolved whether this is a static 1124 // or non-static member function). Add it now, on the assumption that this 1125 // is a redeclaration of OldMethod. 1126 unsigned OldQuals = OldMethod->getTypeQualifiers(); 1127 unsigned NewQuals = NewMethod->getTypeQualifiers(); 1128 if (!getLangOpts().CPlusPlus14 && NewMethod->isConstexpr() && 1129 !isa<CXXConstructorDecl>(NewMethod)) 1130 NewQuals |= Qualifiers::Const; 1131 1132 // We do not allow overloading based off of '__restrict'. 1133 OldQuals &= ~Qualifiers::Restrict; 1134 NewQuals &= ~Qualifiers::Restrict; 1135 if (OldQuals != NewQuals) 1136 return true; 1137 } 1138 1139 // Though pass_object_size is placed on parameters and takes an argument, we 1140 // consider it to be a function-level modifier for the sake of function 1141 // identity. Either the function has one or more parameters with 1142 // pass_object_size or it doesn't. 1143 if (functionHasPassObjectSizeParams(New) != 1144 functionHasPassObjectSizeParams(Old)) 1145 return true; 1146 1147 // enable_if attributes are an order-sensitive part of the signature. 1148 for (specific_attr_iterator<EnableIfAttr> 1149 NewI = New->specific_attr_begin<EnableIfAttr>(), 1150 NewE = New->specific_attr_end<EnableIfAttr>(), 1151 OldI = Old->specific_attr_begin<EnableIfAttr>(), 1152 OldE = Old->specific_attr_end<EnableIfAttr>(); 1153 NewI != NewE || OldI != OldE; ++NewI, ++OldI) { 1154 if (NewI == NewE || OldI == OldE) 1155 return true; 1156 llvm::FoldingSetNodeID NewID, OldID; 1157 NewI->getCond()->Profile(NewID, Context, true); 1158 OldI->getCond()->Profile(OldID, Context, true); 1159 if (NewID != OldID) 1160 return true; 1161 } 1162 1163 if (getLangOpts().CUDA && ConsiderCudaAttrs) { 1164 // Don't allow overloading of destructors. (In theory we could, but it 1165 // would be a giant change to clang.) 1166 if (isa<CXXDestructorDecl>(New)) 1167 return false; 1168 1169 CUDAFunctionTarget NewTarget = IdentifyCUDATarget(New), 1170 OldTarget = IdentifyCUDATarget(Old); 1171 if (NewTarget == CFT_InvalidTarget) 1172 return false; 1173 1174 assert((OldTarget != CFT_InvalidTarget) && "Unexpected invalid target."); 1175 1176 // Allow overloading of functions with same signature and different CUDA 1177 // target attributes. 1178 return NewTarget != OldTarget; 1179 } 1180 1181 // The signatures match; this is not an overload. 1182 return false; 1183 } 1184 1185 /// \brief Checks availability of the function depending on the current 1186 /// function context. Inside an unavailable function, unavailability is ignored. 1187 /// 1188 /// \returns true if \arg FD is unavailable and current context is inside 1189 /// an available function, false otherwise. 1190 bool Sema::isFunctionConsideredUnavailable(FunctionDecl *FD) { 1191 if (!FD->isUnavailable()) 1192 return false; 1193 1194 // Walk up the context of the caller. 1195 Decl *C = cast<Decl>(CurContext); 1196 do { 1197 if (C->isUnavailable()) 1198 return false; 1199 } while ((C = cast_or_null<Decl>(C->getDeclContext()))); 1200 return true; 1201 } 1202 1203 /// \brief Tries a user-defined conversion from From to ToType. 1204 /// 1205 /// Produces an implicit conversion sequence for when a standard conversion 1206 /// is not an option. See TryImplicitConversion for more information. 1207 static ImplicitConversionSequence 1208 TryUserDefinedConversion(Sema &S, Expr *From, QualType ToType, 1209 bool SuppressUserConversions, 1210 bool AllowExplicit, 1211 bool InOverloadResolution, 1212 bool CStyle, 1213 bool AllowObjCWritebackConversion, 1214 bool AllowObjCConversionOnExplicit) { 1215 ImplicitConversionSequence ICS; 1216 1217 if (SuppressUserConversions) { 1218 // We're not in the case above, so there is no conversion that 1219 // we can perform. 1220 ICS.setBad(BadConversionSequence::no_conversion, From, ToType); 1221 return ICS; 1222 } 1223 1224 // Attempt user-defined conversion. 1225 OverloadCandidateSet Conversions(From->getExprLoc(), 1226 OverloadCandidateSet::CSK_Normal); 1227 switch (IsUserDefinedConversion(S, From, ToType, ICS.UserDefined, 1228 Conversions, AllowExplicit, 1229 AllowObjCConversionOnExplicit)) { 1230 case OR_Success: 1231 case OR_Deleted: 1232 ICS.setUserDefined(); 1233 // C++ [over.ics.user]p4: 1234 // A conversion of an expression of class type to the same class 1235 // type is given Exact Match rank, and a conversion of an 1236 // expression of class type to a base class of that type is 1237 // given Conversion rank, in spite of the fact that a copy 1238 // constructor (i.e., a user-defined conversion function) is 1239 // called for those cases. 1240 if (CXXConstructorDecl *Constructor 1241 = dyn_cast<CXXConstructorDecl>(ICS.UserDefined.ConversionFunction)) { 1242 QualType FromCanon 1243 = S.Context.getCanonicalType(From->getType().getUnqualifiedType()); 1244 QualType ToCanon 1245 = S.Context.getCanonicalType(ToType).getUnqualifiedType(); 1246 if (Constructor->isCopyConstructor() && 1247 (FromCanon == ToCanon || 1248 S.IsDerivedFrom(From->getLocStart(), FromCanon, ToCanon))) { 1249 // Turn this into a "standard" conversion sequence, so that it 1250 // gets ranked with standard conversion sequences. 1251 DeclAccessPair Found = ICS.UserDefined.FoundConversionFunction; 1252 ICS.setStandard(); 1253 ICS.Standard.setAsIdentityConversion(); 1254 ICS.Standard.setFromType(From->getType()); 1255 ICS.Standard.setAllToTypes(ToType); 1256 ICS.Standard.CopyConstructor = Constructor; 1257 ICS.Standard.FoundCopyConstructor = Found; 1258 if (ToCanon != FromCanon) 1259 ICS.Standard.Second = ICK_Derived_To_Base; 1260 } 1261 } 1262 break; 1263 1264 case OR_Ambiguous: 1265 ICS.setAmbiguous(); 1266 ICS.Ambiguous.setFromType(From->getType()); 1267 ICS.Ambiguous.setToType(ToType); 1268 for (OverloadCandidateSet::iterator Cand = Conversions.begin(); 1269 Cand != Conversions.end(); ++Cand) 1270 if (Cand->Viable) 1271 ICS.Ambiguous.addConversion(Cand->FoundDecl, Cand->Function); 1272 break; 1273 1274 // Fall through. 1275 case OR_No_Viable_Function: 1276 ICS.setBad(BadConversionSequence::no_conversion, From, ToType); 1277 break; 1278 } 1279 1280 return ICS; 1281 } 1282 1283 /// TryImplicitConversion - Attempt to perform an implicit conversion 1284 /// from the given expression (Expr) to the given type (ToType). This 1285 /// function returns an implicit conversion sequence that can be used 1286 /// to perform the initialization. Given 1287 /// 1288 /// void f(float f); 1289 /// void g(int i) { f(i); } 1290 /// 1291 /// this routine would produce an implicit conversion sequence to 1292 /// describe the initialization of f from i, which will be a standard 1293 /// conversion sequence containing an lvalue-to-rvalue conversion (C++ 1294 /// 4.1) followed by a floating-integral conversion (C++ 4.9). 1295 // 1296 /// Note that this routine only determines how the conversion can be 1297 /// performed; it does not actually perform the conversion. As such, 1298 /// it will not produce any diagnostics if no conversion is available, 1299 /// but will instead return an implicit conversion sequence of kind 1300 /// "BadConversion". 1301 /// 1302 /// If @p SuppressUserConversions, then user-defined conversions are 1303 /// not permitted. 1304 /// If @p AllowExplicit, then explicit user-defined conversions are 1305 /// permitted. 1306 /// 1307 /// \param AllowObjCWritebackConversion Whether we allow the Objective-C 1308 /// writeback conversion, which allows __autoreleasing id* parameters to 1309 /// be initialized with __strong id* or __weak id* arguments. 1310 static ImplicitConversionSequence 1311 TryImplicitConversion(Sema &S, Expr *From, QualType ToType, 1312 bool SuppressUserConversions, 1313 bool AllowExplicit, 1314 bool InOverloadResolution, 1315 bool CStyle, 1316 bool AllowObjCWritebackConversion, 1317 bool AllowObjCConversionOnExplicit) { 1318 ImplicitConversionSequence ICS; 1319 if (IsStandardConversion(S, From, ToType, InOverloadResolution, 1320 ICS.Standard, CStyle, AllowObjCWritebackConversion)){ 1321 ICS.setStandard(); 1322 return ICS; 1323 } 1324 1325 if (!S.getLangOpts().CPlusPlus) { 1326 ICS.setBad(BadConversionSequence::no_conversion, From, ToType); 1327 return ICS; 1328 } 1329 1330 // C++ [over.ics.user]p4: 1331 // A conversion of an expression of class type to the same class 1332 // type is given Exact Match rank, and a conversion of an 1333 // expression of class type to a base class of that type is 1334 // given Conversion rank, in spite of the fact that a copy/move 1335 // constructor (i.e., a user-defined conversion function) is 1336 // called for those cases. 1337 QualType FromType = From->getType(); 1338 if (ToType->getAs<RecordType>() && FromType->getAs<RecordType>() && 1339 (S.Context.hasSameUnqualifiedType(FromType, ToType) || 1340 S.IsDerivedFrom(From->getLocStart(), FromType, ToType))) { 1341 ICS.setStandard(); 1342 ICS.Standard.setAsIdentityConversion(); 1343 ICS.Standard.setFromType(FromType); 1344 ICS.Standard.setAllToTypes(ToType); 1345 1346 // We don't actually check at this point whether there is a valid 1347 // copy/move constructor, since overloading just assumes that it 1348 // exists. When we actually perform initialization, we'll find the 1349 // appropriate constructor to copy the returned object, if needed. 1350 ICS.Standard.CopyConstructor = nullptr; 1351 1352 // Determine whether this is considered a derived-to-base conversion. 1353 if (!S.Context.hasSameUnqualifiedType(FromType, ToType)) 1354 ICS.Standard.Second = ICK_Derived_To_Base; 1355 1356 return ICS; 1357 } 1358 1359 return TryUserDefinedConversion(S, From, ToType, SuppressUserConversions, 1360 AllowExplicit, InOverloadResolution, CStyle, 1361 AllowObjCWritebackConversion, 1362 AllowObjCConversionOnExplicit); 1363 } 1364 1365 ImplicitConversionSequence 1366 Sema::TryImplicitConversion(Expr *From, QualType ToType, 1367 bool SuppressUserConversions, 1368 bool AllowExplicit, 1369 bool InOverloadResolution, 1370 bool CStyle, 1371 bool AllowObjCWritebackConversion) { 1372 return ::TryImplicitConversion(*this, From, ToType, 1373 SuppressUserConversions, AllowExplicit, 1374 InOverloadResolution, CStyle, 1375 AllowObjCWritebackConversion, 1376 /*AllowObjCConversionOnExplicit=*/false); 1377 } 1378 1379 /// PerformImplicitConversion - Perform an implicit conversion of the 1380 /// expression From to the type ToType. Returns the 1381 /// converted expression. Flavor is the kind of conversion we're 1382 /// performing, used in the error message. If @p AllowExplicit, 1383 /// explicit user-defined conversions are permitted. 1384 ExprResult 1385 Sema::PerformImplicitConversion(Expr *From, QualType ToType, 1386 AssignmentAction Action, bool AllowExplicit) { 1387 ImplicitConversionSequence ICS; 1388 return PerformImplicitConversion(From, ToType, Action, AllowExplicit, ICS); 1389 } 1390 1391 ExprResult 1392 Sema::PerformImplicitConversion(Expr *From, QualType ToType, 1393 AssignmentAction Action, bool AllowExplicit, 1394 ImplicitConversionSequence& ICS) { 1395 if (checkPlaceholderForOverload(*this, From)) 1396 return ExprError(); 1397 1398 // Objective-C ARC: Determine whether we will allow the writeback conversion. 1399 bool AllowObjCWritebackConversion 1400 = getLangOpts().ObjCAutoRefCount && 1401 (Action == AA_Passing || Action == AA_Sending); 1402 if (getLangOpts().ObjC1) 1403 CheckObjCBridgeRelatedConversions(From->getLocStart(), 1404 ToType, From->getType(), From); 1405 ICS = ::TryImplicitConversion(*this, From, ToType, 1406 /*SuppressUserConversions=*/false, 1407 AllowExplicit, 1408 /*InOverloadResolution=*/false, 1409 /*CStyle=*/false, 1410 AllowObjCWritebackConversion, 1411 /*AllowObjCConversionOnExplicit=*/false); 1412 return PerformImplicitConversion(From, ToType, ICS, Action); 1413 } 1414 1415 /// \brief Determine whether the conversion from FromType to ToType is a valid 1416 /// conversion that strips "noexcept" or "noreturn" off the nested function 1417 /// type. 1418 bool Sema::IsFunctionConversion(QualType FromType, QualType ToType, 1419 QualType &ResultTy) { 1420 if (Context.hasSameUnqualifiedType(FromType, ToType)) 1421 return false; 1422 1423 // Permit the conversion F(t __attribute__((noreturn))) -> F(t) 1424 // or F(t noexcept) -> F(t) 1425 // where F adds one of the following at most once: 1426 // - a pointer 1427 // - a member pointer 1428 // - a block pointer 1429 // Changes here need matching changes in FindCompositePointerType. 1430 CanQualType CanTo = Context.getCanonicalType(ToType); 1431 CanQualType CanFrom = Context.getCanonicalType(FromType); 1432 Type::TypeClass TyClass = CanTo->getTypeClass(); 1433 if (TyClass != CanFrom->getTypeClass()) return false; 1434 if (TyClass != Type::FunctionProto && TyClass != Type::FunctionNoProto) { 1435 if (TyClass == Type::Pointer) { 1436 CanTo = CanTo.getAs<PointerType>()->getPointeeType(); 1437 CanFrom = CanFrom.getAs<PointerType>()->getPointeeType(); 1438 } else if (TyClass == Type::BlockPointer) { 1439 CanTo = CanTo.getAs<BlockPointerType>()->getPointeeType(); 1440 CanFrom = CanFrom.getAs<BlockPointerType>()->getPointeeType(); 1441 } else if (TyClass == Type::MemberPointer) { 1442 auto ToMPT = CanTo.getAs<MemberPointerType>(); 1443 auto FromMPT = CanFrom.getAs<MemberPointerType>(); 1444 // A function pointer conversion cannot change the class of the function. 1445 if (ToMPT->getClass() != FromMPT->getClass()) 1446 return false; 1447 CanTo = ToMPT->getPointeeType(); 1448 CanFrom = FromMPT->getPointeeType(); 1449 } else { 1450 return false; 1451 } 1452 1453 TyClass = CanTo->getTypeClass(); 1454 if (TyClass != CanFrom->getTypeClass()) return false; 1455 if (TyClass != Type::FunctionProto && TyClass != Type::FunctionNoProto) 1456 return false; 1457 } 1458 1459 const auto *FromFn = cast<FunctionType>(CanFrom); 1460 FunctionType::ExtInfo FromEInfo = FromFn->getExtInfo(); 1461 1462 const auto *ToFn = cast<FunctionType>(CanTo); 1463 FunctionType::ExtInfo ToEInfo = ToFn->getExtInfo(); 1464 1465 bool Changed = false; 1466 1467 // Drop 'noreturn' if not present in target type. 1468 if (FromEInfo.getNoReturn() && !ToEInfo.getNoReturn()) { 1469 FromFn = Context.adjustFunctionType(FromFn, FromEInfo.withNoReturn(false)); 1470 Changed = true; 1471 } 1472 1473 // Drop 'noexcept' if not present in target type. 1474 if (const auto *FromFPT = dyn_cast<FunctionProtoType>(FromFn)) { 1475 const auto *ToFPT = cast<FunctionProtoType>(ToFn); 1476 if (FromFPT->isNothrow(Context) && !ToFPT->isNothrow(Context)) { 1477 FromFn = cast<FunctionType>( 1478 Context.getFunctionType(FromFPT->getReturnType(), 1479 FromFPT->getParamTypes(), 1480 FromFPT->getExtProtoInfo().withExceptionSpec( 1481 FunctionProtoType::ExceptionSpecInfo())) 1482 .getTypePtr()); 1483 Changed = true; 1484 } 1485 1486 // Convert FromFPT's ExtParameterInfo if necessary. The conversion is valid 1487 // only if the ExtParameterInfo lists of the two function prototypes can be 1488 // merged and the merged list is identical to ToFPT's ExtParameterInfo list. 1489 SmallVector<FunctionProtoType::ExtParameterInfo, 4> NewParamInfos; 1490 bool CanUseToFPT, CanUseFromFPT; 1491 if (Context.mergeExtParameterInfo(ToFPT, FromFPT, CanUseToFPT, 1492 CanUseFromFPT, NewParamInfos) && 1493 CanUseToFPT && !CanUseFromFPT) { 1494 FunctionProtoType::ExtProtoInfo ExtInfo = FromFPT->getExtProtoInfo(); 1495 ExtInfo.ExtParameterInfos = 1496 NewParamInfos.empty() ? nullptr : NewParamInfos.data(); 1497 QualType QT = Context.getFunctionType(FromFPT->getReturnType(), 1498 FromFPT->getParamTypes(), ExtInfo); 1499 FromFn = QT->getAs<FunctionType>(); 1500 Changed = true; 1501 } 1502 } 1503 1504 if (!Changed) 1505 return false; 1506 1507 assert(QualType(FromFn, 0).isCanonical()); 1508 if (QualType(FromFn, 0) != CanTo) return false; 1509 1510 ResultTy = ToType; 1511 return true; 1512 } 1513 1514 /// \brief Determine whether the conversion from FromType to ToType is a valid 1515 /// vector conversion. 1516 /// 1517 /// \param ICK Will be set to the vector conversion kind, if this is a vector 1518 /// conversion. 1519 static bool IsVectorConversion(Sema &S, QualType FromType, 1520 QualType ToType, ImplicitConversionKind &ICK) { 1521 // We need at least one of these types to be a vector type to have a vector 1522 // conversion. 1523 if (!ToType->isVectorType() && !FromType->isVectorType()) 1524 return false; 1525 1526 // Identical types require no conversions. 1527 if (S.Context.hasSameUnqualifiedType(FromType, ToType)) 1528 return false; 1529 1530 // There are no conversions between extended vector types, only identity. 1531 if (ToType->isExtVectorType()) { 1532 // There are no conversions between extended vector types other than the 1533 // identity conversion. 1534 if (FromType->isExtVectorType()) 1535 return false; 1536 1537 // Vector splat from any arithmetic type to a vector. 1538 if (FromType->isArithmeticType()) { 1539 ICK = ICK_Vector_Splat; 1540 return true; 1541 } 1542 } 1543 1544 // We can perform the conversion between vector types in the following cases: 1545 // 1)vector types are equivalent AltiVec and GCC vector types 1546 // 2)lax vector conversions are permitted and the vector types are of the 1547 // same size 1548 if (ToType->isVectorType() && FromType->isVectorType()) { 1549 if (S.Context.areCompatibleVectorTypes(FromType, ToType) || 1550 S.isLaxVectorConversion(FromType, ToType)) { 1551 ICK = ICK_Vector_Conversion; 1552 return true; 1553 } 1554 } 1555 1556 return false; 1557 } 1558 1559 static bool tryAtomicConversion(Sema &S, Expr *From, QualType ToType, 1560 bool InOverloadResolution, 1561 StandardConversionSequence &SCS, 1562 bool CStyle); 1563 1564 /// IsStandardConversion - Determines whether there is a standard 1565 /// conversion sequence (C++ [conv], C++ [over.ics.scs]) from the 1566 /// expression From to the type ToType. Standard conversion sequences 1567 /// only consider non-class types; for conversions that involve class 1568 /// types, use TryImplicitConversion. If a conversion exists, SCS will 1569 /// contain the standard conversion sequence required to perform this 1570 /// conversion and this routine will return true. Otherwise, this 1571 /// routine will return false and the value of SCS is unspecified. 1572 static bool IsStandardConversion(Sema &S, Expr* From, QualType ToType, 1573 bool InOverloadResolution, 1574 StandardConversionSequence &SCS, 1575 bool CStyle, 1576 bool AllowObjCWritebackConversion) { 1577 QualType FromType = From->getType(); 1578 1579 // Standard conversions (C++ [conv]) 1580 SCS.setAsIdentityConversion(); 1581 SCS.IncompatibleObjC = false; 1582 SCS.setFromType(FromType); 1583 SCS.CopyConstructor = nullptr; 1584 1585 // There are no standard conversions for class types in C++, so 1586 // abort early. When overloading in C, however, we do permit them. 1587 if (S.getLangOpts().CPlusPlus && 1588 (FromType->isRecordType() || ToType->isRecordType())) 1589 return false; 1590 1591 // The first conversion can be an lvalue-to-rvalue conversion, 1592 // array-to-pointer conversion, or function-to-pointer conversion 1593 // (C++ 4p1). 1594 1595 if (FromType == S.Context.OverloadTy) { 1596 DeclAccessPair AccessPair; 1597 if (FunctionDecl *Fn 1598 = S.ResolveAddressOfOverloadedFunction(From, ToType, false, 1599 AccessPair)) { 1600 // We were able to resolve the address of the overloaded function, 1601 // so we can convert to the type of that function. 1602 FromType = Fn->getType(); 1603 SCS.setFromType(FromType); 1604 1605 // we can sometimes resolve &foo<int> regardless of ToType, so check 1606 // if the type matches (identity) or we are converting to bool 1607 if (!S.Context.hasSameUnqualifiedType( 1608 S.ExtractUnqualifiedFunctionType(ToType), FromType)) { 1609 QualType resultTy; 1610 // if the function type matches except for [[noreturn]], it's ok 1611 if (!S.IsFunctionConversion(FromType, 1612 S.ExtractUnqualifiedFunctionType(ToType), resultTy)) 1613 // otherwise, only a boolean conversion is standard 1614 if (!ToType->isBooleanType()) 1615 return false; 1616 } 1617 1618 // Check if the "from" expression is taking the address of an overloaded 1619 // function and recompute the FromType accordingly. Take advantage of the 1620 // fact that non-static member functions *must* have such an address-of 1621 // expression. 1622 CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Fn); 1623 if (Method && !Method->isStatic()) { 1624 assert(isa<UnaryOperator>(From->IgnoreParens()) && 1625 "Non-unary operator on non-static member address"); 1626 assert(cast<UnaryOperator>(From->IgnoreParens())->getOpcode() 1627 == UO_AddrOf && 1628 "Non-address-of operator on non-static member address"); 1629 const Type *ClassType 1630 = S.Context.getTypeDeclType(Method->getParent()).getTypePtr(); 1631 FromType = S.Context.getMemberPointerType(FromType, ClassType); 1632 } else if (isa<UnaryOperator>(From->IgnoreParens())) { 1633 assert(cast<UnaryOperator>(From->IgnoreParens())->getOpcode() == 1634 UO_AddrOf && 1635 "Non-address-of operator for overloaded function expression"); 1636 FromType = S.Context.getPointerType(FromType); 1637 } 1638 1639 // Check that we've computed the proper type after overload resolution. 1640 // FIXME: FixOverloadedFunctionReference has side-effects; we shouldn't 1641 // be calling it from within an NDEBUG block. 1642 assert(S.Context.hasSameType( 1643 FromType, 1644 S.FixOverloadedFunctionReference(From, AccessPair, Fn)->getType())); 1645 } else { 1646 return false; 1647 } 1648 } 1649 // Lvalue-to-rvalue conversion (C++11 4.1): 1650 // A glvalue (3.10) of a non-function, non-array type T can 1651 // be converted to a prvalue. 1652 bool argIsLValue = From->isGLValue(); 1653 if (argIsLValue && 1654 !FromType->isFunctionType() && !FromType->isArrayType() && 1655 S.Context.getCanonicalType(FromType) != S.Context.OverloadTy) { 1656 SCS.First = ICK_Lvalue_To_Rvalue; 1657 1658 // C11 6.3.2.1p2: 1659 // ... if the lvalue has atomic type, the value has the non-atomic version 1660 // of the type of the lvalue ... 1661 if (const AtomicType *Atomic = FromType->getAs<AtomicType>()) 1662 FromType = Atomic->getValueType(); 1663 1664 // If T is a non-class type, the type of the rvalue is the 1665 // cv-unqualified version of T. Otherwise, the type of the rvalue 1666 // is T (C++ 4.1p1). C++ can't get here with class types; in C, we 1667 // just strip the qualifiers because they don't matter. 1668 FromType = FromType.getUnqualifiedType(); 1669 } else if (FromType->isArrayType()) { 1670 // Array-to-pointer conversion (C++ 4.2) 1671 SCS.First = ICK_Array_To_Pointer; 1672 1673 // An lvalue or rvalue of type "array of N T" or "array of unknown 1674 // bound of T" can be converted to an rvalue of type "pointer to 1675 // T" (C++ 4.2p1). 1676 FromType = S.Context.getArrayDecayedType(FromType); 1677 1678 if (S.IsStringLiteralToNonConstPointerConversion(From, ToType)) { 1679 // This conversion is deprecated in C++03 (D.4) 1680 SCS.DeprecatedStringLiteralToCharPtr = true; 1681 1682 // For the purpose of ranking in overload resolution 1683 // (13.3.3.1.1), this conversion is considered an 1684 // array-to-pointer conversion followed by a qualification 1685 // conversion (4.4). (C++ 4.2p2) 1686 SCS.Second = ICK_Identity; 1687 SCS.Third = ICK_Qualification; 1688 SCS.QualificationIncludesObjCLifetime = false; 1689 SCS.setAllToTypes(FromType); 1690 return true; 1691 } 1692 } else if (FromType->isFunctionType() && argIsLValue) { 1693 // Function-to-pointer conversion (C++ 4.3). 1694 SCS.First = ICK_Function_To_Pointer; 1695 1696 if (auto *DRE = dyn_cast<DeclRefExpr>(From->IgnoreParenCasts())) 1697 if (auto *FD = dyn_cast<FunctionDecl>(DRE->getDecl())) 1698 if (!S.checkAddressOfFunctionIsAvailable(FD)) 1699 return false; 1700 1701 // An lvalue of function type T can be converted to an rvalue of 1702 // type "pointer to T." The result is a pointer to the 1703 // function. (C++ 4.3p1). 1704 FromType = S.Context.getPointerType(FromType); 1705 } else { 1706 // We don't require any conversions for the first step. 1707 SCS.First = ICK_Identity; 1708 } 1709 SCS.setToType(0, FromType); 1710 1711 // The second conversion can be an integral promotion, floating 1712 // point promotion, integral conversion, floating point conversion, 1713 // floating-integral conversion, pointer conversion, 1714 // pointer-to-member conversion, or boolean conversion (C++ 4p1). 1715 // For overloading in C, this can also be a "compatible-type" 1716 // conversion. 1717 bool IncompatibleObjC = false; 1718 ImplicitConversionKind SecondICK = ICK_Identity; 1719 if (S.Context.hasSameUnqualifiedType(FromType, ToType)) { 1720 // The unqualified versions of the types are the same: there's no 1721 // conversion to do. 1722 SCS.Second = ICK_Identity; 1723 } else if (S.IsIntegralPromotion(From, FromType, ToType)) { 1724 // Integral promotion (C++ 4.5). 1725 SCS.Second = ICK_Integral_Promotion; 1726 FromType = ToType.getUnqualifiedType(); 1727 } else if (S.IsFloatingPointPromotion(FromType, ToType)) { 1728 // Floating point promotion (C++ 4.6). 1729 SCS.Second = ICK_Floating_Promotion; 1730 FromType = ToType.getUnqualifiedType(); 1731 } else if (S.IsComplexPromotion(FromType, ToType)) { 1732 // Complex promotion (Clang extension) 1733 SCS.Second = ICK_Complex_Promotion; 1734 FromType = ToType.getUnqualifiedType(); 1735 } else if (ToType->isBooleanType() && 1736 (FromType->isArithmeticType() || 1737 FromType->isAnyPointerType() || 1738 FromType->isBlockPointerType() || 1739 FromType->isMemberPointerType() || 1740 FromType->isNullPtrType())) { 1741 // Boolean conversions (C++ 4.12). 1742 SCS.Second = ICK_Boolean_Conversion; 1743 FromType = S.Context.BoolTy; 1744 } else if (FromType->isIntegralOrUnscopedEnumerationType() && 1745 ToType->isIntegralType(S.Context)) { 1746 // Integral conversions (C++ 4.7). 1747 SCS.Second = ICK_Integral_Conversion; 1748 FromType = ToType.getUnqualifiedType(); 1749 } else if (FromType->isAnyComplexType() && ToType->isAnyComplexType()) { 1750 // Complex conversions (C99 6.3.1.6) 1751 SCS.Second = ICK_Complex_Conversion; 1752 FromType = ToType.getUnqualifiedType(); 1753 } else if ((FromType->isAnyComplexType() && ToType->isArithmeticType()) || 1754 (ToType->isAnyComplexType() && FromType->isArithmeticType())) { 1755 // Complex-real conversions (C99 6.3.1.7) 1756 SCS.Second = ICK_Complex_Real; 1757 FromType = ToType.getUnqualifiedType(); 1758 } else if (FromType->isRealFloatingType() && ToType->isRealFloatingType()) { 1759 // FIXME: disable conversions between long double and __float128 if 1760 // their representation is different until there is back end support 1761 // We of course allow this conversion if long double is really double. 1762 if (&S.Context.getFloatTypeSemantics(FromType) != 1763 &S.Context.getFloatTypeSemantics(ToType)) { 1764 bool Float128AndLongDouble = ((FromType == S.Context.Float128Ty && 1765 ToType == S.Context.LongDoubleTy) || 1766 (FromType == S.Context.LongDoubleTy && 1767 ToType == S.Context.Float128Ty)); 1768 if (Float128AndLongDouble && 1769 (&S.Context.getFloatTypeSemantics(S.Context.LongDoubleTy) != 1770 &llvm::APFloat::IEEEdouble())) 1771 return false; 1772 } 1773 // Floating point conversions (C++ 4.8). 1774 SCS.Second = ICK_Floating_Conversion; 1775 FromType = ToType.getUnqualifiedType(); 1776 } else if ((FromType->isRealFloatingType() && 1777 ToType->isIntegralType(S.Context)) || 1778 (FromType->isIntegralOrUnscopedEnumerationType() && 1779 ToType->isRealFloatingType())) { 1780 // Floating-integral conversions (C++ 4.9). 1781 SCS.Second = ICK_Floating_Integral; 1782 FromType = ToType.getUnqualifiedType(); 1783 } else if (S.IsBlockPointerConversion(FromType, ToType, FromType)) { 1784 SCS.Second = ICK_Block_Pointer_Conversion; 1785 } else if (AllowObjCWritebackConversion && 1786 S.isObjCWritebackConversion(FromType, ToType, FromType)) { 1787 SCS.Second = ICK_Writeback_Conversion; 1788 } else if (S.IsPointerConversion(From, FromType, ToType, InOverloadResolution, 1789 FromType, IncompatibleObjC)) { 1790 // Pointer conversions (C++ 4.10). 1791 SCS.Second = ICK_Pointer_Conversion; 1792 SCS.IncompatibleObjC = IncompatibleObjC; 1793 FromType = FromType.getUnqualifiedType(); 1794 } else if (S.IsMemberPointerConversion(From, FromType, ToType, 1795 InOverloadResolution, FromType)) { 1796 // Pointer to member conversions (4.11). 1797 SCS.Second = ICK_Pointer_Member; 1798 } else if (IsVectorConversion(S, FromType, ToType, SecondICK)) { 1799 SCS.Second = SecondICK; 1800 FromType = ToType.getUnqualifiedType(); 1801 } else if (!S.getLangOpts().CPlusPlus && 1802 S.Context.typesAreCompatible(ToType, FromType)) { 1803 // Compatible conversions (Clang extension for C function overloading) 1804 SCS.Second = ICK_Compatible_Conversion; 1805 FromType = ToType.getUnqualifiedType(); 1806 } else if (IsTransparentUnionStandardConversion(S, From, ToType, 1807 InOverloadResolution, 1808 SCS, CStyle)) { 1809 SCS.Second = ICK_TransparentUnionConversion; 1810 FromType = ToType; 1811 } else if (tryAtomicConversion(S, From, ToType, InOverloadResolution, SCS, 1812 CStyle)) { 1813 // tryAtomicConversion has updated the standard conversion sequence 1814 // appropriately. 1815 return true; 1816 } else if (ToType->isEventT() && 1817 From->isIntegerConstantExpr(S.getASTContext()) && 1818 From->EvaluateKnownConstInt(S.getASTContext()) == 0) { 1819 SCS.Second = ICK_Zero_Event_Conversion; 1820 FromType = ToType; 1821 } else if (ToType->isQueueT() && 1822 From->isIntegerConstantExpr(S.getASTContext()) && 1823 (From->EvaluateKnownConstInt(S.getASTContext()) == 0)) { 1824 SCS.Second = ICK_Zero_Queue_Conversion; 1825 FromType = ToType; 1826 } else { 1827 // No second conversion required. 1828 SCS.Second = ICK_Identity; 1829 } 1830 SCS.setToType(1, FromType); 1831 1832 // The third conversion can be a function pointer conversion or a 1833 // qualification conversion (C++ [conv.fctptr], [conv.qual]). 1834 bool ObjCLifetimeConversion; 1835 if (S.IsFunctionConversion(FromType, ToType, FromType)) { 1836 // Function pointer conversions (removing 'noexcept') including removal of 1837 // 'noreturn' (Clang extension). 1838 SCS.Third = ICK_Function_Conversion; 1839 } else if (S.IsQualificationConversion(FromType, ToType, CStyle, 1840 ObjCLifetimeConversion)) { 1841 SCS.Third = ICK_Qualification; 1842 SCS.QualificationIncludesObjCLifetime = ObjCLifetimeConversion; 1843 FromType = ToType; 1844 } else { 1845 // No conversion required 1846 SCS.Third = ICK_Identity; 1847 } 1848 1849 // C++ [over.best.ics]p6: 1850 // [...] Any difference in top-level cv-qualification is 1851 // subsumed by the initialization itself and does not constitute 1852 // a conversion. [...] 1853 QualType CanonFrom = S.Context.getCanonicalType(FromType); 1854 QualType CanonTo = S.Context.getCanonicalType(ToType); 1855 if (CanonFrom.getLocalUnqualifiedType() 1856 == CanonTo.getLocalUnqualifiedType() && 1857 CanonFrom.getLocalQualifiers() != CanonTo.getLocalQualifiers()) { 1858 FromType = ToType; 1859 CanonFrom = CanonTo; 1860 } 1861 1862 SCS.setToType(2, FromType); 1863 1864 if (CanonFrom == CanonTo) 1865 return true; 1866 1867 // If we have not converted the argument type to the parameter type, 1868 // this is a bad conversion sequence, unless we're resolving an overload in C. 1869 if (S.getLangOpts().CPlusPlus || !InOverloadResolution) 1870 return false; 1871 1872 ExprResult ER = ExprResult{From}; 1873 Sema::AssignConvertType Conv = 1874 S.CheckSingleAssignmentConstraints(ToType, ER, 1875 /*Diagnose=*/false, 1876 /*DiagnoseCFAudited=*/false, 1877 /*ConvertRHS=*/false); 1878 ImplicitConversionKind SecondConv; 1879 switch (Conv) { 1880 case Sema::Compatible: 1881 SecondConv = ICK_C_Only_Conversion; 1882 break; 1883 // For our purposes, discarding qualifiers is just as bad as using an 1884 // incompatible pointer. Note that an IncompatiblePointer conversion can drop 1885 // qualifiers, as well. 1886 case Sema::CompatiblePointerDiscardsQualifiers: 1887 case Sema::IncompatiblePointer: 1888 case Sema::IncompatiblePointerSign: 1889 SecondConv = ICK_Incompatible_Pointer_Conversion; 1890 break; 1891 default: 1892 return false; 1893 } 1894 1895 // First can only be an lvalue conversion, so we pretend that this was the 1896 // second conversion. First should already be valid from earlier in the 1897 // function. 1898 SCS.Second = SecondConv; 1899 SCS.setToType(1, ToType); 1900 1901 // Third is Identity, because Second should rank us worse than any other 1902 // conversion. This could also be ICK_Qualification, but it's simpler to just 1903 // lump everything in with the second conversion, and we don't gain anything 1904 // from making this ICK_Qualification. 1905 SCS.Third = ICK_Identity; 1906 SCS.setToType(2, ToType); 1907 return true; 1908 } 1909 1910 static bool 1911 IsTransparentUnionStandardConversion(Sema &S, Expr* From, 1912 QualType &ToType, 1913 bool InOverloadResolution, 1914 StandardConversionSequence &SCS, 1915 bool CStyle) { 1916 1917 const RecordType *UT = ToType->getAsUnionType(); 1918 if (!UT || !UT->getDecl()->hasAttr<TransparentUnionAttr>()) 1919 return false; 1920 // The field to initialize within the transparent union. 1921 RecordDecl *UD = UT->getDecl(); 1922 // It's compatible if the expression matches any of the fields. 1923 for (const auto *it : UD->fields()) { 1924 if (IsStandardConversion(S, From, it->getType(), InOverloadResolution, SCS, 1925 CStyle, /*ObjCWritebackConversion=*/false)) { 1926 ToType = it->getType(); 1927 return true; 1928 } 1929 } 1930 return false; 1931 } 1932 1933 /// IsIntegralPromotion - Determines whether the conversion from the 1934 /// expression From (whose potentially-adjusted type is FromType) to 1935 /// ToType is an integral promotion (C++ 4.5). If so, returns true and 1936 /// sets PromotedType to the promoted type. 1937 bool Sema::IsIntegralPromotion(Expr *From, QualType FromType, QualType ToType) { 1938 const BuiltinType *To = ToType->getAs<BuiltinType>(); 1939 // All integers are built-in. 1940 if (!To) { 1941 return false; 1942 } 1943 1944 // An rvalue of type char, signed char, unsigned char, short int, or 1945 // unsigned short int can be converted to an rvalue of type int if 1946 // int can represent all the values of the source type; otherwise, 1947 // the source rvalue can be converted to an rvalue of type unsigned 1948 // int (C++ 4.5p1). 1949 if (FromType->isPromotableIntegerType() && !FromType->isBooleanType() && 1950 !FromType->isEnumeralType()) { 1951 if (// We can promote any signed, promotable integer type to an int 1952 (FromType->isSignedIntegerType() || 1953 // We can promote any unsigned integer type whose size is 1954 // less than int to an int. 1955 Context.getTypeSize(FromType) < Context.getTypeSize(ToType))) { 1956 return To->getKind() == BuiltinType::Int; 1957 } 1958 1959 return To->getKind() == BuiltinType::UInt; 1960 } 1961 1962 // C++11 [conv.prom]p3: 1963 // A prvalue of an unscoped enumeration type whose underlying type is not 1964 // fixed (7.2) can be converted to an rvalue a prvalue of the first of the 1965 // following types that can represent all the values of the enumeration 1966 // (i.e., the values in the range bmin to bmax as described in 7.2): int, 1967 // unsigned int, long int, unsigned long int, long long int, or unsigned 1968 // long long int. If none of the types in that list can represent all the 1969 // values of the enumeration, an rvalue a prvalue of an unscoped enumeration 1970 // type can be converted to an rvalue a prvalue of the extended integer type 1971 // with lowest integer conversion rank (4.13) greater than the rank of long 1972 // long in which all the values of the enumeration can be represented. If 1973 // there are two such extended types, the signed one is chosen. 1974 // C++11 [conv.prom]p4: 1975 // A prvalue of an unscoped enumeration type whose underlying type is fixed 1976 // can be converted to a prvalue of its underlying type. Moreover, if 1977 // integral promotion can be applied to its underlying type, a prvalue of an 1978 // unscoped enumeration type whose underlying type is fixed can also be 1979 // converted to a prvalue of the promoted underlying type. 1980 if (const EnumType *FromEnumType = FromType->getAs<EnumType>()) { 1981 // C++0x 7.2p9: Note that this implicit enum to int conversion is not 1982 // provided for a scoped enumeration. 1983 if (FromEnumType->getDecl()->isScoped()) 1984 return false; 1985 1986 // We can perform an integral promotion to the underlying type of the enum, 1987 // even if that's not the promoted type. Note that the check for promoting 1988 // the underlying type is based on the type alone, and does not consider 1989 // the bitfield-ness of the actual source expression. 1990 if (FromEnumType->getDecl()->isFixed()) { 1991 QualType Underlying = FromEnumType->getDecl()->getIntegerType(); 1992 return Context.hasSameUnqualifiedType(Underlying, ToType) || 1993 IsIntegralPromotion(nullptr, Underlying, ToType); 1994 } 1995 1996 // We have already pre-calculated the promotion type, so this is trivial. 1997 if (ToType->isIntegerType() && 1998 isCompleteType(From->getLocStart(), FromType)) 1999 return Context.hasSameUnqualifiedType( 2000 ToType, FromEnumType->getDecl()->getPromotionType()); 2001 } 2002 2003 // C++0x [conv.prom]p2: 2004 // A prvalue of type char16_t, char32_t, or wchar_t (3.9.1) can be converted 2005 // to an rvalue a prvalue of the first of the following types that can 2006 // represent all the values of its underlying type: int, unsigned int, 2007 // long int, unsigned long int, long long int, or unsigned long long int. 2008 // If none of the types in that list can represent all the values of its 2009 // underlying type, an rvalue a prvalue of type char16_t, char32_t, 2010 // or wchar_t can be converted to an rvalue a prvalue of its underlying 2011 // type. 2012 if (FromType->isAnyCharacterType() && !FromType->isCharType() && 2013 ToType->isIntegerType()) { 2014 // Determine whether the type we're converting from is signed or 2015 // unsigned. 2016 bool FromIsSigned = FromType->isSignedIntegerType(); 2017 uint64_t FromSize = Context.getTypeSize(FromType); 2018 2019 // The types we'll try to promote to, in the appropriate 2020 // order. Try each of these types. 2021 QualType PromoteTypes[6] = { 2022 Context.IntTy, Context.UnsignedIntTy, 2023 Context.LongTy, Context.UnsignedLongTy , 2024 Context.LongLongTy, Context.UnsignedLongLongTy 2025 }; 2026 for (int Idx = 0; Idx < 6; ++Idx) { 2027 uint64_t ToSize = Context.getTypeSize(PromoteTypes[Idx]); 2028 if (FromSize < ToSize || 2029 (FromSize == ToSize && 2030 FromIsSigned == PromoteTypes[Idx]->isSignedIntegerType())) { 2031 // We found the type that we can promote to. If this is the 2032 // type we wanted, we have a promotion. Otherwise, no 2033 // promotion. 2034 return Context.hasSameUnqualifiedType(ToType, PromoteTypes[Idx]); 2035 } 2036 } 2037 } 2038 2039 // An rvalue for an integral bit-field (9.6) can be converted to an 2040 // rvalue of type int if int can represent all the values of the 2041 // bit-field; otherwise, it can be converted to unsigned int if 2042 // unsigned int can represent all the values of the bit-field. If 2043 // the bit-field is larger yet, no integral promotion applies to 2044 // it. If the bit-field has an enumerated type, it is treated as any 2045 // other value of that type for promotion purposes (C++ 4.5p3). 2046 // FIXME: We should delay checking of bit-fields until we actually perform the 2047 // conversion. 2048 if (From) { 2049 if (FieldDecl *MemberDecl = From->getSourceBitField()) { 2050 llvm::APSInt BitWidth; 2051 if (FromType->isIntegralType(Context) && 2052 MemberDecl->getBitWidth()->isIntegerConstantExpr(BitWidth, Context)) { 2053 llvm::APSInt ToSize(BitWidth.getBitWidth(), BitWidth.isUnsigned()); 2054 ToSize = Context.getTypeSize(ToType); 2055 2056 // Are we promoting to an int from a bitfield that fits in an int? 2057 if (BitWidth < ToSize || 2058 (FromType->isSignedIntegerType() && BitWidth <= ToSize)) { 2059 return To->getKind() == BuiltinType::Int; 2060 } 2061 2062 // Are we promoting to an unsigned int from an unsigned bitfield 2063 // that fits into an unsigned int? 2064 if (FromType->isUnsignedIntegerType() && BitWidth <= ToSize) { 2065 return To->getKind() == BuiltinType::UInt; 2066 } 2067 2068 return false; 2069 } 2070 } 2071 } 2072 2073 // An rvalue of type bool can be converted to an rvalue of type int, 2074 // with false becoming zero and true becoming one (C++ 4.5p4). 2075 if (FromType->isBooleanType() && To->getKind() == BuiltinType::Int) { 2076 return true; 2077 } 2078 2079 return false; 2080 } 2081 2082 /// IsFloatingPointPromotion - Determines whether the conversion from 2083 /// FromType to ToType is a floating point promotion (C++ 4.6). If so, 2084 /// returns true and sets PromotedType to the promoted type. 2085 bool Sema::IsFloatingPointPromotion(QualType FromType, QualType ToType) { 2086 if (const BuiltinType *FromBuiltin = FromType->getAs<BuiltinType>()) 2087 if (const BuiltinType *ToBuiltin = ToType->getAs<BuiltinType>()) { 2088 /// An rvalue of type float can be converted to an rvalue of type 2089 /// double. (C++ 4.6p1). 2090 if (FromBuiltin->getKind() == BuiltinType::Float && 2091 ToBuiltin->getKind() == BuiltinType::Double) 2092 return true; 2093 2094 // C99 6.3.1.5p1: 2095 // When a float is promoted to double or long double, or a 2096 // double is promoted to long double [...]. 2097 if (!getLangOpts().CPlusPlus && 2098 (FromBuiltin->getKind() == BuiltinType::Float || 2099 FromBuiltin->getKind() == BuiltinType::Double) && 2100 (ToBuiltin->getKind() == BuiltinType::LongDouble || 2101 ToBuiltin->getKind() == BuiltinType::Float128)) 2102 return true; 2103 2104 // Half can be promoted to float. 2105 if (!getLangOpts().NativeHalfType && 2106 FromBuiltin->getKind() == BuiltinType::Half && 2107 ToBuiltin->getKind() == BuiltinType::Float) 2108 return true; 2109 } 2110 2111 return false; 2112 } 2113 2114 /// \brief Determine if a conversion is a complex promotion. 2115 /// 2116 /// A complex promotion is defined as a complex -> complex conversion 2117 /// where the conversion between the underlying real types is a 2118 /// floating-point or integral promotion. 2119 bool Sema::IsComplexPromotion(QualType FromType, QualType ToType) { 2120 const ComplexType *FromComplex = FromType->getAs<ComplexType>(); 2121 if (!FromComplex) 2122 return false; 2123 2124 const ComplexType *ToComplex = ToType->getAs<ComplexType>(); 2125 if (!ToComplex) 2126 return false; 2127 2128 return IsFloatingPointPromotion(FromComplex->getElementType(), 2129 ToComplex->getElementType()) || 2130 IsIntegralPromotion(nullptr, FromComplex->getElementType(), 2131 ToComplex->getElementType()); 2132 } 2133 2134 /// BuildSimilarlyQualifiedPointerType - In a pointer conversion from 2135 /// the pointer type FromPtr to a pointer to type ToPointee, with the 2136 /// same type qualifiers as FromPtr has on its pointee type. ToType, 2137 /// if non-empty, will be a pointer to ToType that may or may not have 2138 /// the right set of qualifiers on its pointee. 2139 /// 2140 static QualType 2141 BuildSimilarlyQualifiedPointerType(const Type *FromPtr, 2142 QualType ToPointee, QualType ToType, 2143 ASTContext &Context, 2144 bool StripObjCLifetime = false) { 2145 assert((FromPtr->getTypeClass() == Type::Pointer || 2146 FromPtr->getTypeClass() == Type::ObjCObjectPointer) && 2147 "Invalid similarly-qualified pointer type"); 2148 2149 /// Conversions to 'id' subsume cv-qualifier conversions. 2150 if (ToType->isObjCIdType() || ToType->isObjCQualifiedIdType()) 2151 return ToType.getUnqualifiedType(); 2152 2153 QualType CanonFromPointee 2154 = Context.getCanonicalType(FromPtr->getPointeeType()); 2155 QualType CanonToPointee = Context.getCanonicalType(ToPointee); 2156 Qualifiers Quals = CanonFromPointee.getQualifiers(); 2157 2158 if (StripObjCLifetime) 2159 Quals.removeObjCLifetime(); 2160 2161 // Exact qualifier match -> return the pointer type we're converting to. 2162 if (CanonToPointee.getLocalQualifiers() == Quals) { 2163 // ToType is exactly what we need. Return it. 2164 if (!ToType.isNull()) 2165 return ToType.getUnqualifiedType(); 2166 2167 // Build a pointer to ToPointee. It has the right qualifiers 2168 // already. 2169 if (isa<ObjCObjectPointerType>(ToType)) 2170 return Context.getObjCObjectPointerType(ToPointee); 2171 return Context.getPointerType(ToPointee); 2172 } 2173 2174 // Just build a canonical type that has the right qualifiers. 2175 QualType QualifiedCanonToPointee 2176 = Context.getQualifiedType(CanonToPointee.getLocalUnqualifiedType(), Quals); 2177 2178 if (isa<ObjCObjectPointerType>(ToType)) 2179 return Context.getObjCObjectPointerType(QualifiedCanonToPointee); 2180 return Context.getPointerType(QualifiedCanonToPointee); 2181 } 2182 2183 static bool isNullPointerConstantForConversion(Expr *Expr, 2184 bool InOverloadResolution, 2185 ASTContext &Context) { 2186 // Handle value-dependent integral null pointer constants correctly. 2187 // http://www.open-std.org/jtc1/sc22/wg21/docs/cwg_active.html#903 2188 if (Expr->isValueDependent() && !Expr->isTypeDependent() && 2189 Expr->getType()->isIntegerType() && !Expr->getType()->isEnumeralType()) 2190 return !InOverloadResolution; 2191 2192 return Expr->isNullPointerConstant(Context, 2193 InOverloadResolution? Expr::NPC_ValueDependentIsNotNull 2194 : Expr::NPC_ValueDependentIsNull); 2195 } 2196 2197 /// IsPointerConversion - Determines whether the conversion of the 2198 /// expression From, which has the (possibly adjusted) type FromType, 2199 /// can be converted to the type ToType via a pointer conversion (C++ 2200 /// 4.10). If so, returns true and places the converted type (that 2201 /// might differ from ToType in its cv-qualifiers at some level) into 2202 /// ConvertedType. 2203 /// 2204 /// This routine also supports conversions to and from block pointers 2205 /// and conversions with Objective-C's 'id', 'id<protocols...>', and 2206 /// pointers to interfaces. FIXME: Once we've determined the 2207 /// appropriate overloading rules for Objective-C, we may want to 2208 /// split the Objective-C checks into a different routine; however, 2209 /// GCC seems to consider all of these conversions to be pointer 2210 /// conversions, so for now they live here. IncompatibleObjC will be 2211 /// set if the conversion is an allowed Objective-C conversion that 2212 /// should result in a warning. 2213 bool Sema::IsPointerConversion(Expr *From, QualType FromType, QualType ToType, 2214 bool InOverloadResolution, 2215 QualType& ConvertedType, 2216 bool &IncompatibleObjC) { 2217 IncompatibleObjC = false; 2218 if (isObjCPointerConversion(FromType, ToType, ConvertedType, 2219 IncompatibleObjC)) 2220 return true; 2221 2222 // Conversion from a null pointer constant to any Objective-C pointer type. 2223 if (ToType->isObjCObjectPointerType() && 2224 isNullPointerConstantForConversion(From, InOverloadResolution, Context)) { 2225 ConvertedType = ToType; 2226 return true; 2227 } 2228 2229 // Blocks: Block pointers can be converted to void*. 2230 if (FromType->isBlockPointerType() && ToType->isPointerType() && 2231 ToType->getAs<PointerType>()->getPointeeType()->isVoidType()) { 2232 ConvertedType = ToType; 2233 return true; 2234 } 2235 // Blocks: A null pointer constant can be converted to a block 2236 // pointer type. 2237 if (ToType->isBlockPointerType() && 2238 isNullPointerConstantForConversion(From, InOverloadResolution, Context)) { 2239 ConvertedType = ToType; 2240 return true; 2241 } 2242 2243 // If the left-hand-side is nullptr_t, the right side can be a null 2244 // pointer constant. 2245 if (ToType->isNullPtrType() && 2246 isNullPointerConstantForConversion(From, InOverloadResolution, Context)) { 2247 ConvertedType = ToType; 2248 return true; 2249 } 2250 2251 const PointerType* ToTypePtr = ToType->getAs<PointerType>(); 2252 if (!ToTypePtr) 2253 return false; 2254 2255 // A null pointer constant can be converted to a pointer type (C++ 4.10p1). 2256 if (isNullPointerConstantForConversion(From, InOverloadResolution, Context)) { 2257 ConvertedType = ToType; 2258 return true; 2259 } 2260 2261 // Beyond this point, both types need to be pointers 2262 // , including objective-c pointers. 2263 QualType ToPointeeType = ToTypePtr->getPointeeType(); 2264 if (FromType->isObjCObjectPointerType() && ToPointeeType->isVoidType() && 2265 !getLangOpts().ObjCAutoRefCount) { 2266 ConvertedType = BuildSimilarlyQualifiedPointerType( 2267 FromType->getAs<ObjCObjectPointerType>(), 2268 ToPointeeType, 2269 ToType, Context); 2270 return true; 2271 } 2272 const PointerType *FromTypePtr = FromType->getAs<PointerType>(); 2273 if (!FromTypePtr) 2274 return false; 2275 2276 QualType FromPointeeType = FromTypePtr->getPointeeType(); 2277 2278 // If the unqualified pointee types are the same, this can't be a 2279 // pointer conversion, so don't do all of the work below. 2280 if (Context.hasSameUnqualifiedType(FromPointeeType, ToPointeeType)) 2281 return false; 2282 2283 // An rvalue of type "pointer to cv T," where T is an object type, 2284 // can be converted to an rvalue of type "pointer to cv void" (C++ 2285 // 4.10p2). 2286 if (FromPointeeType->isIncompleteOrObjectType() && 2287 ToPointeeType->isVoidType()) { 2288 ConvertedType = BuildSimilarlyQualifiedPointerType(FromTypePtr, 2289 ToPointeeType, 2290 ToType, Context, 2291 /*StripObjCLifetime=*/true); 2292 return true; 2293 } 2294 2295 // MSVC allows implicit function to void* type conversion. 2296 if (getLangOpts().MSVCCompat && FromPointeeType->isFunctionType() && 2297 ToPointeeType->isVoidType()) { 2298 ConvertedType = BuildSimilarlyQualifiedPointerType(FromTypePtr, 2299 ToPointeeType, 2300 ToType, Context); 2301 return true; 2302 } 2303 2304 // When we're overloading in C, we allow a special kind of pointer 2305 // conversion for compatible-but-not-identical pointee types. 2306 if (!getLangOpts().CPlusPlus && 2307 Context.typesAreCompatible(FromPointeeType, ToPointeeType)) { 2308 ConvertedType = BuildSimilarlyQualifiedPointerType(FromTypePtr, 2309 ToPointeeType, 2310 ToType, Context); 2311 return true; 2312 } 2313 2314 // C++ [conv.ptr]p3: 2315 // 2316 // An rvalue of type "pointer to cv D," where D is a class type, 2317 // can be converted to an rvalue of type "pointer to cv B," where 2318 // B is a base class (clause 10) of D. If B is an inaccessible 2319 // (clause 11) or ambiguous (10.2) base class of D, a program that 2320 // necessitates this conversion is ill-formed. The result of the 2321 // conversion is a pointer to the base class sub-object of the 2322 // derived class object. The null pointer value is converted to 2323 // the null pointer value of the destination type. 2324 // 2325 // Note that we do not check for ambiguity or inaccessibility 2326 // here. That is handled by CheckPointerConversion. 2327 if (getLangOpts().CPlusPlus && 2328 FromPointeeType->isRecordType() && ToPointeeType->isRecordType() && 2329 !Context.hasSameUnqualifiedType(FromPointeeType, ToPointeeType) && 2330 IsDerivedFrom(From->getLocStart(), FromPointeeType, ToPointeeType)) { 2331 ConvertedType = BuildSimilarlyQualifiedPointerType(FromTypePtr, 2332 ToPointeeType, 2333 ToType, Context); 2334 return true; 2335 } 2336 2337 if (FromPointeeType->isVectorType() && ToPointeeType->isVectorType() && 2338 Context.areCompatibleVectorTypes(FromPointeeType, ToPointeeType)) { 2339 ConvertedType = BuildSimilarlyQualifiedPointerType(FromTypePtr, 2340 ToPointeeType, 2341 ToType, Context); 2342 return true; 2343 } 2344 2345 return false; 2346 } 2347 2348 /// \brief Adopt the given qualifiers for the given type. 2349 static QualType AdoptQualifiers(ASTContext &Context, QualType T, Qualifiers Qs){ 2350 Qualifiers TQs = T.getQualifiers(); 2351 2352 // Check whether qualifiers already match. 2353 if (TQs == Qs) 2354 return T; 2355 2356 if (Qs.compatiblyIncludes(TQs)) 2357 return Context.getQualifiedType(T, Qs); 2358 2359 return Context.getQualifiedType(T.getUnqualifiedType(), Qs); 2360 } 2361 2362 /// isObjCPointerConversion - Determines whether this is an 2363 /// Objective-C pointer conversion. Subroutine of IsPointerConversion, 2364 /// with the same arguments and return values. 2365 bool Sema::isObjCPointerConversion(QualType FromType, QualType ToType, 2366 QualType& ConvertedType, 2367 bool &IncompatibleObjC) { 2368 if (!getLangOpts().ObjC1) 2369 return false; 2370 2371 // The set of qualifiers on the type we're converting from. 2372 Qualifiers FromQualifiers = FromType.getQualifiers(); 2373 2374 // First, we handle all conversions on ObjC object pointer types. 2375 const ObjCObjectPointerType* ToObjCPtr = 2376 ToType->getAs<ObjCObjectPointerType>(); 2377 const ObjCObjectPointerType *FromObjCPtr = 2378 FromType->getAs<ObjCObjectPointerType>(); 2379 2380 if (ToObjCPtr && FromObjCPtr) { 2381 // If the pointee types are the same (ignoring qualifications), 2382 // then this is not a pointer conversion. 2383 if (Context.hasSameUnqualifiedType(ToObjCPtr->getPointeeType(), 2384 FromObjCPtr->getPointeeType())) 2385 return false; 2386 2387 // Conversion between Objective-C pointers. 2388 if (Context.canAssignObjCInterfaces(ToObjCPtr, FromObjCPtr)) { 2389 const ObjCInterfaceType* LHS = ToObjCPtr->getInterfaceType(); 2390 const ObjCInterfaceType* RHS = FromObjCPtr->getInterfaceType(); 2391 if (getLangOpts().CPlusPlus && LHS && RHS && 2392 !ToObjCPtr->getPointeeType().isAtLeastAsQualifiedAs( 2393 FromObjCPtr->getPointeeType())) 2394 return false; 2395 ConvertedType = BuildSimilarlyQualifiedPointerType(FromObjCPtr, 2396 ToObjCPtr->getPointeeType(), 2397 ToType, Context); 2398 ConvertedType = AdoptQualifiers(Context, ConvertedType, FromQualifiers); 2399 return true; 2400 } 2401 2402 if (Context.canAssignObjCInterfaces(FromObjCPtr, ToObjCPtr)) { 2403 // Okay: this is some kind of implicit downcast of Objective-C 2404 // interfaces, which is permitted. However, we're going to 2405 // complain about it. 2406 IncompatibleObjC = true; 2407 ConvertedType = BuildSimilarlyQualifiedPointerType(FromObjCPtr, 2408 ToObjCPtr->getPointeeType(), 2409 ToType, Context); 2410 ConvertedType = AdoptQualifiers(Context, ConvertedType, FromQualifiers); 2411 return true; 2412 } 2413 } 2414 // Beyond this point, both types need to be C pointers or block pointers. 2415 QualType ToPointeeType; 2416 if (const PointerType *ToCPtr = ToType->getAs<PointerType>()) 2417 ToPointeeType = ToCPtr->getPointeeType(); 2418 else if (const BlockPointerType *ToBlockPtr = 2419 ToType->getAs<BlockPointerType>()) { 2420 // Objective C++: We're able to convert from a pointer to any object 2421 // to a block pointer type. 2422 if (FromObjCPtr && FromObjCPtr->isObjCBuiltinType()) { 2423 ConvertedType = AdoptQualifiers(Context, ToType, FromQualifiers); 2424 return true; 2425 } 2426 ToPointeeType = ToBlockPtr->getPointeeType(); 2427 } 2428 else if (FromType->getAs<BlockPointerType>() && 2429 ToObjCPtr && ToObjCPtr->isObjCBuiltinType()) { 2430 // Objective C++: We're able to convert from a block pointer type to a 2431 // pointer to any object. 2432 ConvertedType = AdoptQualifiers(Context, ToType, FromQualifiers); 2433 return true; 2434 } 2435 else 2436 return false; 2437 2438 QualType FromPointeeType; 2439 if (const PointerType *FromCPtr = FromType->getAs<PointerType>()) 2440 FromPointeeType = FromCPtr->getPointeeType(); 2441 else if (const BlockPointerType *FromBlockPtr = 2442 FromType->getAs<BlockPointerType>()) 2443 FromPointeeType = FromBlockPtr->getPointeeType(); 2444 else 2445 return false; 2446 2447 // If we have pointers to pointers, recursively check whether this 2448 // is an Objective-C conversion. 2449 if (FromPointeeType->isPointerType() && ToPointeeType->isPointerType() && 2450 isObjCPointerConversion(FromPointeeType, ToPointeeType, ConvertedType, 2451 IncompatibleObjC)) { 2452 // We always complain about this conversion. 2453 IncompatibleObjC = true; 2454 ConvertedType = Context.getPointerType(ConvertedType); 2455 ConvertedType = AdoptQualifiers(Context, ConvertedType, FromQualifiers); 2456 return true; 2457 } 2458 // Allow conversion of pointee being objective-c pointer to another one; 2459 // as in I* to id. 2460 if (FromPointeeType->getAs<ObjCObjectPointerType>() && 2461 ToPointeeType->getAs<ObjCObjectPointerType>() && 2462 isObjCPointerConversion(FromPointeeType, ToPointeeType, ConvertedType, 2463 IncompatibleObjC)) { 2464 2465 ConvertedType = Context.getPointerType(ConvertedType); 2466 ConvertedType = AdoptQualifiers(Context, ConvertedType, FromQualifiers); 2467 return true; 2468 } 2469 2470 // If we have pointers to functions or blocks, check whether the only 2471 // differences in the argument and result types are in Objective-C 2472 // pointer conversions. If so, we permit the conversion (but 2473 // complain about it). 2474 const FunctionProtoType *FromFunctionType 2475 = FromPointeeType->getAs<FunctionProtoType>(); 2476 const FunctionProtoType *ToFunctionType 2477 = ToPointeeType->getAs<FunctionProtoType>(); 2478 if (FromFunctionType && ToFunctionType) { 2479 // If the function types are exactly the same, this isn't an 2480 // Objective-C pointer conversion. 2481 if (Context.getCanonicalType(FromPointeeType) 2482 == Context.getCanonicalType(ToPointeeType)) 2483 return false; 2484 2485 // Perform the quick checks that will tell us whether these 2486 // function types are obviously different. 2487 if (FromFunctionType->getNumParams() != ToFunctionType->getNumParams() || 2488 FromFunctionType->isVariadic() != ToFunctionType->isVariadic() || 2489 FromFunctionType->getTypeQuals() != ToFunctionType->getTypeQuals()) 2490 return false; 2491 2492 bool HasObjCConversion = false; 2493 if (Context.getCanonicalType(FromFunctionType->getReturnType()) == 2494 Context.getCanonicalType(ToFunctionType->getReturnType())) { 2495 // Okay, the types match exactly. Nothing to do. 2496 } else if (isObjCPointerConversion(FromFunctionType->getReturnType(), 2497 ToFunctionType->getReturnType(), 2498 ConvertedType, IncompatibleObjC)) { 2499 // Okay, we have an Objective-C pointer conversion. 2500 HasObjCConversion = true; 2501 } else { 2502 // Function types are too different. Abort. 2503 return false; 2504 } 2505 2506 // Check argument types. 2507 for (unsigned ArgIdx = 0, NumArgs = FromFunctionType->getNumParams(); 2508 ArgIdx != NumArgs; ++ArgIdx) { 2509 QualType FromArgType = FromFunctionType->getParamType(ArgIdx); 2510 QualType ToArgType = ToFunctionType->getParamType(ArgIdx); 2511 if (Context.getCanonicalType(FromArgType) 2512 == Context.getCanonicalType(ToArgType)) { 2513 // Okay, the types match exactly. Nothing to do. 2514 } else if (isObjCPointerConversion(FromArgType, ToArgType, 2515 ConvertedType, IncompatibleObjC)) { 2516 // Okay, we have an Objective-C pointer conversion. 2517 HasObjCConversion = true; 2518 } else { 2519 // Argument types are too different. Abort. 2520 return false; 2521 } 2522 } 2523 2524 if (HasObjCConversion) { 2525 // We had an Objective-C conversion. Allow this pointer 2526 // conversion, but complain about it. 2527 ConvertedType = AdoptQualifiers(Context, ToType, FromQualifiers); 2528 IncompatibleObjC = true; 2529 return true; 2530 } 2531 } 2532 2533 return false; 2534 } 2535 2536 /// \brief Determine whether this is an Objective-C writeback conversion, 2537 /// used for parameter passing when performing automatic reference counting. 2538 /// 2539 /// \param FromType The type we're converting form. 2540 /// 2541 /// \param ToType The type we're converting to. 2542 /// 2543 /// \param ConvertedType The type that will be produced after applying 2544 /// this conversion. 2545 bool Sema::isObjCWritebackConversion(QualType FromType, QualType ToType, 2546 QualType &ConvertedType) { 2547 if (!getLangOpts().ObjCAutoRefCount || 2548 Context.hasSameUnqualifiedType(FromType, ToType)) 2549 return false; 2550 2551 // Parameter must be a pointer to __autoreleasing (with no other qualifiers). 2552 QualType ToPointee; 2553 if (const PointerType *ToPointer = ToType->getAs<PointerType>()) 2554 ToPointee = ToPointer->getPointeeType(); 2555 else 2556 return false; 2557 2558 Qualifiers ToQuals = ToPointee.getQualifiers(); 2559 if (!ToPointee->isObjCLifetimeType() || 2560 ToQuals.getObjCLifetime() != Qualifiers::OCL_Autoreleasing || 2561 !ToQuals.withoutObjCLifetime().empty()) 2562 return false; 2563 2564 // Argument must be a pointer to __strong to __weak. 2565 QualType FromPointee; 2566 if (const PointerType *FromPointer = FromType->getAs<PointerType>()) 2567 FromPointee = FromPointer->getPointeeType(); 2568 else 2569 return false; 2570 2571 Qualifiers FromQuals = FromPointee.getQualifiers(); 2572 if (!FromPointee->isObjCLifetimeType() || 2573 (FromQuals.getObjCLifetime() != Qualifiers::OCL_Strong && 2574 FromQuals.getObjCLifetime() != Qualifiers::OCL_Weak)) 2575 return false; 2576 2577 // Make sure that we have compatible qualifiers. 2578 FromQuals.setObjCLifetime(Qualifiers::OCL_Autoreleasing); 2579 if (!ToQuals.compatiblyIncludes(FromQuals)) 2580 return false; 2581 2582 // Remove qualifiers from the pointee type we're converting from; they 2583 // aren't used in the compatibility check belong, and we'll be adding back 2584 // qualifiers (with __autoreleasing) if the compatibility check succeeds. 2585 FromPointee = FromPointee.getUnqualifiedType(); 2586 2587 // The unqualified form of the pointee types must be compatible. 2588 ToPointee = ToPointee.getUnqualifiedType(); 2589 bool IncompatibleObjC; 2590 if (Context.typesAreCompatible(FromPointee, ToPointee)) 2591 FromPointee = ToPointee; 2592 else if (!isObjCPointerConversion(FromPointee, ToPointee, FromPointee, 2593 IncompatibleObjC)) 2594 return false; 2595 2596 /// \brief Construct the type we're converting to, which is a pointer to 2597 /// __autoreleasing pointee. 2598 FromPointee = Context.getQualifiedType(FromPointee, FromQuals); 2599 ConvertedType = Context.getPointerType(FromPointee); 2600 return true; 2601 } 2602 2603 bool Sema::IsBlockPointerConversion(QualType FromType, QualType ToType, 2604 QualType& ConvertedType) { 2605 QualType ToPointeeType; 2606 if (const BlockPointerType *ToBlockPtr = 2607 ToType->getAs<BlockPointerType>()) 2608 ToPointeeType = ToBlockPtr->getPointeeType(); 2609 else 2610 return false; 2611 2612 QualType FromPointeeType; 2613 if (const BlockPointerType *FromBlockPtr = 2614 FromType->getAs<BlockPointerType>()) 2615 FromPointeeType = FromBlockPtr->getPointeeType(); 2616 else 2617 return false; 2618 // We have pointer to blocks, check whether the only 2619 // differences in the argument and result types are in Objective-C 2620 // pointer conversions. If so, we permit the conversion. 2621 2622 const FunctionProtoType *FromFunctionType 2623 = FromPointeeType->getAs<FunctionProtoType>(); 2624 const FunctionProtoType *ToFunctionType 2625 = ToPointeeType->getAs<FunctionProtoType>(); 2626 2627 if (!FromFunctionType || !ToFunctionType) 2628 return false; 2629 2630 if (Context.hasSameType(FromPointeeType, ToPointeeType)) 2631 return true; 2632 2633 // Perform the quick checks that will tell us whether these 2634 // function types are obviously different. 2635 if (FromFunctionType->getNumParams() != ToFunctionType->getNumParams() || 2636 FromFunctionType->isVariadic() != ToFunctionType->isVariadic()) 2637 return false; 2638 2639 FunctionType::ExtInfo FromEInfo = FromFunctionType->getExtInfo(); 2640 FunctionType::ExtInfo ToEInfo = ToFunctionType->getExtInfo(); 2641 if (FromEInfo != ToEInfo) 2642 return false; 2643 2644 bool IncompatibleObjC = false; 2645 if (Context.hasSameType(FromFunctionType->getReturnType(), 2646 ToFunctionType->getReturnType())) { 2647 // Okay, the types match exactly. Nothing to do. 2648 } else { 2649 QualType RHS = FromFunctionType->getReturnType(); 2650 QualType LHS = ToFunctionType->getReturnType(); 2651 if ((!getLangOpts().CPlusPlus || !RHS->isRecordType()) && 2652 !RHS.hasQualifiers() && LHS.hasQualifiers()) 2653 LHS = LHS.getUnqualifiedType(); 2654 2655 if (Context.hasSameType(RHS,LHS)) { 2656 // OK exact match. 2657 } else if (isObjCPointerConversion(RHS, LHS, 2658 ConvertedType, IncompatibleObjC)) { 2659 if (IncompatibleObjC) 2660 return false; 2661 // Okay, we have an Objective-C pointer conversion. 2662 } 2663 else 2664 return false; 2665 } 2666 2667 // Check argument types. 2668 for (unsigned ArgIdx = 0, NumArgs = FromFunctionType->getNumParams(); 2669 ArgIdx != NumArgs; ++ArgIdx) { 2670 IncompatibleObjC = false; 2671 QualType FromArgType = FromFunctionType->getParamType(ArgIdx); 2672 QualType ToArgType = ToFunctionType->getParamType(ArgIdx); 2673 if (Context.hasSameType(FromArgType, ToArgType)) { 2674 // Okay, the types match exactly. Nothing to do. 2675 } else if (isObjCPointerConversion(ToArgType, FromArgType, 2676 ConvertedType, IncompatibleObjC)) { 2677 if (IncompatibleObjC) 2678 return false; 2679 // Okay, we have an Objective-C pointer conversion. 2680 } else 2681 // Argument types are too different. Abort. 2682 return false; 2683 } 2684 2685 SmallVector<FunctionProtoType::ExtParameterInfo, 4> NewParamInfos; 2686 bool CanUseToFPT, CanUseFromFPT; 2687 if (!Context.mergeExtParameterInfo(ToFunctionType, FromFunctionType, 2688 CanUseToFPT, CanUseFromFPT, 2689 NewParamInfos)) 2690 return false; 2691 2692 ConvertedType = ToType; 2693 return true; 2694 } 2695 2696 enum { 2697 ft_default, 2698 ft_different_class, 2699 ft_parameter_arity, 2700 ft_parameter_mismatch, 2701 ft_return_type, 2702 ft_qualifer_mismatch, 2703 ft_noexcept 2704 }; 2705 2706 /// Attempts to get the FunctionProtoType from a Type. Handles 2707 /// MemberFunctionPointers properly. 2708 static const FunctionProtoType *tryGetFunctionProtoType(QualType FromType) { 2709 if (auto *FPT = FromType->getAs<FunctionProtoType>()) 2710 return FPT; 2711 2712 if (auto *MPT = FromType->getAs<MemberPointerType>()) 2713 return MPT->getPointeeType()->getAs<FunctionProtoType>(); 2714 2715 return nullptr; 2716 } 2717 2718 /// HandleFunctionTypeMismatch - Gives diagnostic information for differeing 2719 /// function types. Catches different number of parameter, mismatch in 2720 /// parameter types, and different return types. 2721 void Sema::HandleFunctionTypeMismatch(PartialDiagnostic &PDiag, 2722 QualType FromType, QualType ToType) { 2723 // If either type is not valid, include no extra info. 2724 if (FromType.isNull() || ToType.isNull()) { 2725 PDiag << ft_default; 2726 return; 2727 } 2728 2729 // Get the function type from the pointers. 2730 if (FromType->isMemberPointerType() && ToType->isMemberPointerType()) { 2731 const MemberPointerType *FromMember = FromType->getAs<MemberPointerType>(), 2732 *ToMember = ToType->getAs<MemberPointerType>(); 2733 if (!Context.hasSameType(FromMember->getClass(), ToMember->getClass())) { 2734 PDiag << ft_different_class << QualType(ToMember->getClass(), 0) 2735 << QualType(FromMember->getClass(), 0); 2736 return; 2737 } 2738 FromType = FromMember->getPointeeType(); 2739 ToType = ToMember->getPointeeType(); 2740 } 2741 2742 if (FromType->isPointerType()) 2743 FromType = FromType->getPointeeType(); 2744 if (ToType->isPointerType()) 2745 ToType = ToType->getPointeeType(); 2746 2747 // Remove references. 2748 FromType = FromType.getNonReferenceType(); 2749 ToType = ToType.getNonReferenceType(); 2750 2751 // Don't print extra info for non-specialized template functions. 2752 if (FromType->isInstantiationDependentType() && 2753 !FromType->getAs<TemplateSpecializationType>()) { 2754 PDiag << ft_default; 2755 return; 2756 } 2757 2758 // No extra info for same types. 2759 if (Context.hasSameType(FromType, ToType)) { 2760 PDiag << ft_default; 2761 return; 2762 } 2763 2764 const FunctionProtoType *FromFunction = tryGetFunctionProtoType(FromType), 2765 *ToFunction = tryGetFunctionProtoType(ToType); 2766 2767 // Both types need to be function types. 2768 if (!FromFunction || !ToFunction) { 2769 PDiag << ft_default; 2770 return; 2771 } 2772 2773 if (FromFunction->getNumParams() != ToFunction->getNumParams()) { 2774 PDiag << ft_parameter_arity << ToFunction->getNumParams() 2775 << FromFunction->getNumParams(); 2776 return; 2777 } 2778 2779 // Handle different parameter types. 2780 unsigned ArgPos; 2781 if (!FunctionParamTypesAreEqual(FromFunction, ToFunction, &ArgPos)) { 2782 PDiag << ft_parameter_mismatch << ArgPos + 1 2783 << ToFunction->getParamType(ArgPos) 2784 << FromFunction->getParamType(ArgPos); 2785 return; 2786 } 2787 2788 // Handle different return type. 2789 if (!Context.hasSameType(FromFunction->getReturnType(), 2790 ToFunction->getReturnType())) { 2791 PDiag << ft_return_type << ToFunction->getReturnType() 2792 << FromFunction->getReturnType(); 2793 return; 2794 } 2795 2796 unsigned FromQuals = FromFunction->getTypeQuals(), 2797 ToQuals = ToFunction->getTypeQuals(); 2798 if (FromQuals != ToQuals) { 2799 PDiag << ft_qualifer_mismatch << ToQuals << FromQuals; 2800 return; 2801 } 2802 2803 // Handle exception specification differences on canonical type (in C++17 2804 // onwards). 2805 if (cast<FunctionProtoType>(FromFunction->getCanonicalTypeUnqualified()) 2806 ->isNothrow(Context) != 2807 cast<FunctionProtoType>(ToFunction->getCanonicalTypeUnqualified()) 2808 ->isNothrow(Context)) { 2809 PDiag << ft_noexcept; 2810 return; 2811 } 2812 2813 // Unable to find a difference, so add no extra info. 2814 PDiag << ft_default; 2815 } 2816 2817 /// FunctionParamTypesAreEqual - This routine checks two function proto types 2818 /// for equality of their argument types. Caller has already checked that 2819 /// they have same number of arguments. If the parameters are different, 2820 /// ArgPos will have the parameter index of the first different parameter. 2821 bool Sema::FunctionParamTypesAreEqual(const FunctionProtoType *OldType, 2822 const FunctionProtoType *NewType, 2823 unsigned *ArgPos) { 2824 for (FunctionProtoType::param_type_iterator O = OldType->param_type_begin(), 2825 N = NewType->param_type_begin(), 2826 E = OldType->param_type_end(); 2827 O && (O != E); ++O, ++N) { 2828 if (!Context.hasSameType(O->getUnqualifiedType(), 2829 N->getUnqualifiedType())) { 2830 if (ArgPos) 2831 *ArgPos = O - OldType->param_type_begin(); 2832 return false; 2833 } 2834 } 2835 return true; 2836 } 2837 2838 /// CheckPointerConversion - Check the pointer conversion from the 2839 /// expression From to the type ToType. This routine checks for 2840 /// ambiguous or inaccessible derived-to-base pointer 2841 /// conversions for which IsPointerConversion has already returned 2842 /// true. It returns true and produces a diagnostic if there was an 2843 /// error, or returns false otherwise. 2844 bool Sema::CheckPointerConversion(Expr *From, QualType ToType, 2845 CastKind &Kind, 2846 CXXCastPath& BasePath, 2847 bool IgnoreBaseAccess, 2848 bool Diagnose) { 2849 QualType FromType = From->getType(); 2850 bool IsCStyleOrFunctionalCast = IgnoreBaseAccess; 2851 2852 Kind = CK_BitCast; 2853 2854 if (Diagnose && !IsCStyleOrFunctionalCast && !FromType->isAnyPointerType() && 2855 From->isNullPointerConstant(Context, Expr::NPC_ValueDependentIsNotNull) == 2856 Expr::NPCK_ZeroExpression) { 2857 if (Context.hasSameUnqualifiedType(From->getType(), Context.BoolTy)) 2858 DiagRuntimeBehavior(From->getExprLoc(), From, 2859 PDiag(diag::warn_impcast_bool_to_null_pointer) 2860 << ToType << From->getSourceRange()); 2861 else if (!isUnevaluatedContext()) 2862 Diag(From->getExprLoc(), diag::warn_non_literal_null_pointer) 2863 << ToType << From->getSourceRange(); 2864 } 2865 if (const PointerType *ToPtrType = ToType->getAs<PointerType>()) { 2866 if (const PointerType *FromPtrType = FromType->getAs<PointerType>()) { 2867 QualType FromPointeeType = FromPtrType->getPointeeType(), 2868 ToPointeeType = ToPtrType->getPointeeType(); 2869 2870 if (FromPointeeType->isRecordType() && ToPointeeType->isRecordType() && 2871 !Context.hasSameUnqualifiedType(FromPointeeType, ToPointeeType)) { 2872 // We must have a derived-to-base conversion. Check an 2873 // ambiguous or inaccessible conversion. 2874 unsigned InaccessibleID = 0; 2875 unsigned AmbigiousID = 0; 2876 if (Diagnose) { 2877 InaccessibleID = diag::err_upcast_to_inaccessible_base; 2878 AmbigiousID = diag::err_ambiguous_derived_to_base_conv; 2879 } 2880 if (CheckDerivedToBaseConversion( 2881 FromPointeeType, ToPointeeType, InaccessibleID, AmbigiousID, 2882 From->getExprLoc(), From->getSourceRange(), DeclarationName(), 2883 &BasePath, IgnoreBaseAccess)) 2884 return true; 2885 2886 // The conversion was successful. 2887 Kind = CK_DerivedToBase; 2888 } 2889 2890 if (Diagnose && !IsCStyleOrFunctionalCast && 2891 FromPointeeType->isFunctionType() && ToPointeeType->isVoidType()) { 2892 assert(getLangOpts().MSVCCompat && 2893 "this should only be possible with MSVCCompat!"); 2894 Diag(From->getExprLoc(), diag::ext_ms_impcast_fn_obj) 2895 << From->getSourceRange(); 2896 } 2897 } 2898 } else if (const ObjCObjectPointerType *ToPtrType = 2899 ToType->getAs<ObjCObjectPointerType>()) { 2900 if (const ObjCObjectPointerType *FromPtrType = 2901 FromType->getAs<ObjCObjectPointerType>()) { 2902 // Objective-C++ conversions are always okay. 2903 // FIXME: We should have a different class of conversions for the 2904 // Objective-C++ implicit conversions. 2905 if (FromPtrType->isObjCBuiltinType() || ToPtrType->isObjCBuiltinType()) 2906 return false; 2907 } else if (FromType->isBlockPointerType()) { 2908 Kind = CK_BlockPointerToObjCPointerCast; 2909 } else { 2910 Kind = CK_CPointerToObjCPointerCast; 2911 } 2912 } else if (ToType->isBlockPointerType()) { 2913 if (!FromType->isBlockPointerType()) 2914 Kind = CK_AnyPointerToBlockPointerCast; 2915 } 2916 2917 // We shouldn't fall into this case unless it's valid for other 2918 // reasons. 2919 if (From->isNullPointerConstant(Context, Expr::NPC_ValueDependentIsNull)) 2920 Kind = CK_NullToPointer; 2921 2922 return false; 2923 } 2924 2925 /// IsMemberPointerConversion - Determines whether the conversion of the 2926 /// expression From, which has the (possibly adjusted) type FromType, can be 2927 /// converted to the type ToType via a member pointer conversion (C++ 4.11). 2928 /// If so, returns true and places the converted type (that might differ from 2929 /// ToType in its cv-qualifiers at some level) into ConvertedType. 2930 bool Sema::IsMemberPointerConversion(Expr *From, QualType FromType, 2931 QualType ToType, 2932 bool InOverloadResolution, 2933 QualType &ConvertedType) { 2934 const MemberPointerType *ToTypePtr = ToType->getAs<MemberPointerType>(); 2935 if (!ToTypePtr) 2936 return false; 2937 2938 // A null pointer constant can be converted to a member pointer (C++ 4.11p1) 2939 if (From->isNullPointerConstant(Context, 2940 InOverloadResolution? Expr::NPC_ValueDependentIsNotNull 2941 : Expr::NPC_ValueDependentIsNull)) { 2942 ConvertedType = ToType; 2943 return true; 2944 } 2945 2946 // Otherwise, both types have to be member pointers. 2947 const MemberPointerType *FromTypePtr = FromType->getAs<MemberPointerType>(); 2948 if (!FromTypePtr) 2949 return false; 2950 2951 // A pointer to member of B can be converted to a pointer to member of D, 2952 // where D is derived from B (C++ 4.11p2). 2953 QualType FromClass(FromTypePtr->getClass(), 0); 2954 QualType ToClass(ToTypePtr->getClass(), 0); 2955 2956 if (!Context.hasSameUnqualifiedType(FromClass, ToClass) && 2957 IsDerivedFrom(From->getLocStart(), ToClass, FromClass)) { 2958 ConvertedType = Context.getMemberPointerType(FromTypePtr->getPointeeType(), 2959 ToClass.getTypePtr()); 2960 return true; 2961 } 2962 2963 return false; 2964 } 2965 2966 /// CheckMemberPointerConversion - Check the member pointer conversion from the 2967 /// expression From to the type ToType. This routine checks for ambiguous or 2968 /// virtual or inaccessible base-to-derived member pointer conversions 2969 /// for which IsMemberPointerConversion has already returned true. It returns 2970 /// true and produces a diagnostic if there was an error, or returns false 2971 /// otherwise. 2972 bool Sema::CheckMemberPointerConversion(Expr *From, QualType ToType, 2973 CastKind &Kind, 2974 CXXCastPath &BasePath, 2975 bool IgnoreBaseAccess) { 2976 QualType FromType = From->getType(); 2977 const MemberPointerType *FromPtrType = FromType->getAs<MemberPointerType>(); 2978 if (!FromPtrType) { 2979 // This must be a null pointer to member pointer conversion 2980 assert(From->isNullPointerConstant(Context, 2981 Expr::NPC_ValueDependentIsNull) && 2982 "Expr must be null pointer constant!"); 2983 Kind = CK_NullToMemberPointer; 2984 return false; 2985 } 2986 2987 const MemberPointerType *ToPtrType = ToType->getAs<MemberPointerType>(); 2988 assert(ToPtrType && "No member pointer cast has a target type " 2989 "that is not a member pointer."); 2990 2991 QualType FromClass = QualType(FromPtrType->getClass(), 0); 2992 QualType ToClass = QualType(ToPtrType->getClass(), 0); 2993 2994 // FIXME: What about dependent types? 2995 assert(FromClass->isRecordType() && "Pointer into non-class."); 2996 assert(ToClass->isRecordType() && "Pointer into non-class."); 2997 2998 CXXBasePaths Paths(/*FindAmbiguities=*/true, /*RecordPaths=*/true, 2999 /*DetectVirtual=*/true); 3000 bool DerivationOkay = 3001 IsDerivedFrom(From->getLocStart(), ToClass, FromClass, Paths); 3002 assert(DerivationOkay && 3003 "Should not have been called if derivation isn't OK."); 3004 (void)DerivationOkay; 3005 3006 if (Paths.isAmbiguous(Context.getCanonicalType(FromClass). 3007 getUnqualifiedType())) { 3008 std::string PathDisplayStr = getAmbiguousPathsDisplayString(Paths); 3009 Diag(From->getExprLoc(), diag::err_ambiguous_memptr_conv) 3010 << 0 << FromClass << ToClass << PathDisplayStr << From->getSourceRange(); 3011 return true; 3012 } 3013 3014 if (const RecordType *VBase = Paths.getDetectedVirtual()) { 3015 Diag(From->getExprLoc(), diag::err_memptr_conv_via_virtual) 3016 << FromClass << ToClass << QualType(VBase, 0) 3017 << From->getSourceRange(); 3018 return true; 3019 } 3020 3021 if (!IgnoreBaseAccess) 3022 CheckBaseClassAccess(From->getExprLoc(), FromClass, ToClass, 3023 Paths.front(), 3024 diag::err_downcast_from_inaccessible_base); 3025 3026 // Must be a base to derived member conversion. 3027 BuildBasePathArray(Paths, BasePath); 3028 Kind = CK_BaseToDerivedMemberPointer; 3029 return false; 3030 } 3031 3032 /// Determine whether the lifetime conversion between the two given 3033 /// qualifiers sets is nontrivial. 3034 static bool isNonTrivialObjCLifetimeConversion(Qualifiers FromQuals, 3035 Qualifiers ToQuals) { 3036 // Converting anything to const __unsafe_unretained is trivial. 3037 if (ToQuals.hasConst() && 3038 ToQuals.getObjCLifetime() == Qualifiers::OCL_ExplicitNone) 3039 return false; 3040 3041 return true; 3042 } 3043 3044 /// IsQualificationConversion - Determines whether the conversion from 3045 /// an rvalue of type FromType to ToType is a qualification conversion 3046 /// (C++ 4.4). 3047 /// 3048 /// \param ObjCLifetimeConversion Output parameter that will be set to indicate 3049 /// when the qualification conversion involves a change in the Objective-C 3050 /// object lifetime. 3051 bool 3052 Sema::IsQualificationConversion(QualType FromType, QualType ToType, 3053 bool CStyle, bool &ObjCLifetimeConversion) { 3054 FromType = Context.getCanonicalType(FromType); 3055 ToType = Context.getCanonicalType(ToType); 3056 ObjCLifetimeConversion = false; 3057 3058 // If FromType and ToType are the same type, this is not a 3059 // qualification conversion. 3060 if (FromType.getUnqualifiedType() == ToType.getUnqualifiedType()) 3061 return false; 3062 3063 // (C++ 4.4p4): 3064 // A conversion can add cv-qualifiers at levels other than the first 3065 // in multi-level pointers, subject to the following rules: [...] 3066 bool PreviousToQualsIncludeConst = true; 3067 bool UnwrappedAnyPointer = false; 3068 while (Context.UnwrapSimilarPointerTypes(FromType, ToType)) { 3069 // Within each iteration of the loop, we check the qualifiers to 3070 // determine if this still looks like a qualification 3071 // conversion. Then, if all is well, we unwrap one more level of 3072 // pointers or pointers-to-members and do it all again 3073 // until there are no more pointers or pointers-to-members left to 3074 // unwrap. 3075 UnwrappedAnyPointer = true; 3076 3077 Qualifiers FromQuals = FromType.getQualifiers(); 3078 Qualifiers ToQuals = ToType.getQualifiers(); 3079 3080 // Ignore __unaligned qualifier if this type is void. 3081 if (ToType.getUnqualifiedType()->isVoidType()) 3082 FromQuals.removeUnaligned(); 3083 3084 // Objective-C ARC: 3085 // Check Objective-C lifetime conversions. 3086 if (FromQuals.getObjCLifetime() != ToQuals.getObjCLifetime() && 3087 UnwrappedAnyPointer) { 3088 if (ToQuals.compatiblyIncludesObjCLifetime(FromQuals)) { 3089 if (isNonTrivialObjCLifetimeConversion(FromQuals, ToQuals)) 3090 ObjCLifetimeConversion = true; 3091 FromQuals.removeObjCLifetime(); 3092 ToQuals.removeObjCLifetime(); 3093 } else { 3094 // Qualification conversions cannot cast between different 3095 // Objective-C lifetime qualifiers. 3096 return false; 3097 } 3098 } 3099 3100 // Allow addition/removal of GC attributes but not changing GC attributes. 3101 if (FromQuals.getObjCGCAttr() != ToQuals.getObjCGCAttr() && 3102 (!FromQuals.hasObjCGCAttr() || !ToQuals.hasObjCGCAttr())) { 3103 FromQuals.removeObjCGCAttr(); 3104 ToQuals.removeObjCGCAttr(); 3105 } 3106 3107 // -- for every j > 0, if const is in cv 1,j then const is in cv 3108 // 2,j, and similarly for volatile. 3109 if (!CStyle && !ToQuals.compatiblyIncludes(FromQuals)) 3110 return false; 3111 3112 // -- if the cv 1,j and cv 2,j are different, then const is in 3113 // every cv for 0 < k < j. 3114 if (!CStyle && FromQuals.getCVRQualifiers() != ToQuals.getCVRQualifiers() 3115 && !PreviousToQualsIncludeConst) 3116 return false; 3117 3118 // Keep track of whether all prior cv-qualifiers in the "to" type 3119 // include const. 3120 PreviousToQualsIncludeConst 3121 = PreviousToQualsIncludeConst && ToQuals.hasConst(); 3122 } 3123 3124 // We are left with FromType and ToType being the pointee types 3125 // after unwrapping the original FromType and ToType the same number 3126 // of types. If we unwrapped any pointers, and if FromType and 3127 // ToType have the same unqualified type (since we checked 3128 // qualifiers above), then this is a qualification conversion. 3129 return UnwrappedAnyPointer && Context.hasSameUnqualifiedType(FromType,ToType); 3130 } 3131 3132 /// \brief - Determine whether this is a conversion from a scalar type to an 3133 /// atomic type. 3134 /// 3135 /// If successful, updates \c SCS's second and third steps in the conversion 3136 /// sequence to finish the conversion. 3137 static bool tryAtomicConversion(Sema &S, Expr *From, QualType ToType, 3138 bool InOverloadResolution, 3139 StandardConversionSequence &SCS, 3140 bool CStyle) { 3141 const AtomicType *ToAtomic = ToType->getAs<AtomicType>(); 3142 if (!ToAtomic) 3143 return false; 3144 3145 StandardConversionSequence InnerSCS; 3146 if (!IsStandardConversion(S, From, ToAtomic->getValueType(), 3147 InOverloadResolution, InnerSCS, 3148 CStyle, /*AllowObjCWritebackConversion=*/false)) 3149 return false; 3150 3151 SCS.Second = InnerSCS.Second; 3152 SCS.setToType(1, InnerSCS.getToType(1)); 3153 SCS.Third = InnerSCS.Third; 3154 SCS.QualificationIncludesObjCLifetime 3155 = InnerSCS.QualificationIncludesObjCLifetime; 3156 SCS.setToType(2, InnerSCS.getToType(2)); 3157 return true; 3158 } 3159 3160 static bool isFirstArgumentCompatibleWithType(ASTContext &Context, 3161 CXXConstructorDecl *Constructor, 3162 QualType Type) { 3163 const FunctionProtoType *CtorType = 3164 Constructor->getType()->getAs<FunctionProtoType>(); 3165 if (CtorType->getNumParams() > 0) { 3166 QualType FirstArg = CtorType->getParamType(0); 3167 if (Context.hasSameUnqualifiedType(Type, FirstArg.getNonReferenceType())) 3168 return true; 3169 } 3170 return false; 3171 } 3172 3173 static OverloadingResult 3174 IsInitializerListConstructorConversion(Sema &S, Expr *From, QualType ToType, 3175 CXXRecordDecl *To, 3176 UserDefinedConversionSequence &User, 3177 OverloadCandidateSet &CandidateSet, 3178 bool AllowExplicit) { 3179 CandidateSet.clear(OverloadCandidateSet::CSK_InitByUserDefinedConversion); 3180 for (auto *D : S.LookupConstructors(To)) { 3181 auto Info = getConstructorInfo(D); 3182 if (!Info) 3183 continue; 3184 3185 bool Usable = !Info.Constructor->isInvalidDecl() && 3186 S.isInitListConstructor(Info.Constructor) && 3187 (AllowExplicit || !Info.Constructor->isExplicit()); 3188 if (Usable) { 3189 // If the first argument is (a reference to) the target type, 3190 // suppress conversions. 3191 bool SuppressUserConversions = isFirstArgumentCompatibleWithType( 3192 S.Context, Info.Constructor, ToType); 3193 if (Info.ConstructorTmpl) 3194 S.AddTemplateOverloadCandidate(Info.ConstructorTmpl, Info.FoundDecl, 3195 /*ExplicitArgs*/ nullptr, From, 3196 CandidateSet, SuppressUserConversions); 3197 else 3198 S.AddOverloadCandidate(Info.Constructor, Info.FoundDecl, From, 3199 CandidateSet, SuppressUserConversions); 3200 } 3201 } 3202 3203 bool HadMultipleCandidates = (CandidateSet.size() > 1); 3204 3205 OverloadCandidateSet::iterator Best; 3206 switch (auto Result = 3207 CandidateSet.BestViableFunction(S, From->getLocStart(), 3208 Best)) { 3209 case OR_Deleted: 3210 case OR_Success: { 3211 // Record the standard conversion we used and the conversion function. 3212 CXXConstructorDecl *Constructor = cast<CXXConstructorDecl>(Best->Function); 3213 QualType ThisType = Constructor->getThisType(S.Context); 3214 // Initializer lists don't have conversions as such. 3215 User.Before.setAsIdentityConversion(); 3216 User.HadMultipleCandidates = HadMultipleCandidates; 3217 User.ConversionFunction = Constructor; 3218 User.FoundConversionFunction = Best->FoundDecl; 3219 User.After.setAsIdentityConversion(); 3220 User.After.setFromType(ThisType->getAs<PointerType>()->getPointeeType()); 3221 User.After.setAllToTypes(ToType); 3222 return Result; 3223 } 3224 3225 case OR_No_Viable_Function: 3226 return OR_No_Viable_Function; 3227 case OR_Ambiguous: 3228 return OR_Ambiguous; 3229 } 3230 3231 llvm_unreachable("Invalid OverloadResult!"); 3232 } 3233 3234 /// Determines whether there is a user-defined conversion sequence 3235 /// (C++ [over.ics.user]) that converts expression From to the type 3236 /// ToType. If such a conversion exists, User will contain the 3237 /// user-defined conversion sequence that performs such a conversion 3238 /// and this routine will return true. Otherwise, this routine returns 3239 /// false and User is unspecified. 3240 /// 3241 /// \param AllowExplicit true if the conversion should consider C++0x 3242 /// "explicit" conversion functions as well as non-explicit conversion 3243 /// functions (C++0x [class.conv.fct]p2). 3244 /// 3245 /// \param AllowObjCConversionOnExplicit true if the conversion should 3246 /// allow an extra Objective-C pointer conversion on uses of explicit 3247 /// constructors. Requires \c AllowExplicit to also be set. 3248 static OverloadingResult 3249 IsUserDefinedConversion(Sema &S, Expr *From, QualType ToType, 3250 UserDefinedConversionSequence &User, 3251 OverloadCandidateSet &CandidateSet, 3252 bool AllowExplicit, 3253 bool AllowObjCConversionOnExplicit) { 3254 assert(AllowExplicit || !AllowObjCConversionOnExplicit); 3255 CandidateSet.clear(OverloadCandidateSet::CSK_InitByUserDefinedConversion); 3256 3257 // Whether we will only visit constructors. 3258 bool ConstructorsOnly = false; 3259 3260 // If the type we are conversion to is a class type, enumerate its 3261 // constructors. 3262 if (const RecordType *ToRecordType = ToType->getAs<RecordType>()) { 3263 // C++ [over.match.ctor]p1: 3264 // When objects of class type are direct-initialized (8.5), or 3265 // copy-initialized from an expression of the same or a 3266 // derived class type (8.5), overload resolution selects the 3267 // constructor. [...] For copy-initialization, the candidate 3268 // functions are all the converting constructors (12.3.1) of 3269 // that class. The argument list is the expression-list within 3270 // the parentheses of the initializer. 3271 if (S.Context.hasSameUnqualifiedType(ToType, From->getType()) || 3272 (From->getType()->getAs<RecordType>() && 3273 S.IsDerivedFrom(From->getLocStart(), From->getType(), ToType))) 3274 ConstructorsOnly = true; 3275 3276 if (!S.isCompleteType(From->getExprLoc(), ToType)) { 3277 // We're not going to find any constructors. 3278 } else if (CXXRecordDecl *ToRecordDecl 3279 = dyn_cast<CXXRecordDecl>(ToRecordType->getDecl())) { 3280 3281 Expr **Args = &From; 3282 unsigned NumArgs = 1; 3283 bool ListInitializing = false; 3284 if (InitListExpr *InitList = dyn_cast<InitListExpr>(From)) { 3285 // But first, see if there is an init-list-constructor that will work. 3286 OverloadingResult Result = IsInitializerListConstructorConversion( 3287 S, From, ToType, ToRecordDecl, User, CandidateSet, AllowExplicit); 3288 if (Result != OR_No_Viable_Function) 3289 return Result; 3290 // Never mind. 3291 CandidateSet.clear( 3292 OverloadCandidateSet::CSK_InitByUserDefinedConversion); 3293 3294 // If we're list-initializing, we pass the individual elements as 3295 // arguments, not the entire list. 3296 Args = InitList->getInits(); 3297 NumArgs = InitList->getNumInits(); 3298 ListInitializing = true; 3299 } 3300 3301 for (auto *D : S.LookupConstructors(ToRecordDecl)) { 3302 auto Info = getConstructorInfo(D); 3303 if (!Info) 3304 continue; 3305 3306 bool Usable = !Info.Constructor->isInvalidDecl(); 3307 if (ListInitializing) 3308 Usable = Usable && (AllowExplicit || !Info.Constructor->isExplicit()); 3309 else 3310 Usable = Usable && 3311 Info.Constructor->isConvertingConstructor(AllowExplicit); 3312 if (Usable) { 3313 bool SuppressUserConversions = !ConstructorsOnly; 3314 if (SuppressUserConversions && ListInitializing) { 3315 SuppressUserConversions = false; 3316 if (NumArgs == 1) { 3317 // If the first argument is (a reference to) the target type, 3318 // suppress conversions. 3319 SuppressUserConversions = isFirstArgumentCompatibleWithType( 3320 S.Context, Info.Constructor, ToType); 3321 } 3322 } 3323 if (Info.ConstructorTmpl) 3324 S.AddTemplateOverloadCandidate( 3325 Info.ConstructorTmpl, Info.FoundDecl, 3326 /*ExplicitArgs*/ nullptr, llvm::makeArrayRef(Args, NumArgs), 3327 CandidateSet, SuppressUserConversions); 3328 else 3329 // Allow one user-defined conversion when user specifies a 3330 // From->ToType conversion via an static cast (c-style, etc). 3331 S.AddOverloadCandidate(Info.Constructor, Info.FoundDecl, 3332 llvm::makeArrayRef(Args, NumArgs), 3333 CandidateSet, SuppressUserConversions); 3334 } 3335 } 3336 } 3337 } 3338 3339 // Enumerate conversion functions, if we're allowed to. 3340 if (ConstructorsOnly || isa<InitListExpr>(From)) { 3341 } else if (!S.isCompleteType(From->getLocStart(), From->getType())) { 3342 // No conversion functions from incomplete types. 3343 } else if (const RecordType *FromRecordType 3344 = From->getType()->getAs<RecordType>()) { 3345 if (CXXRecordDecl *FromRecordDecl 3346 = dyn_cast<CXXRecordDecl>(FromRecordType->getDecl())) { 3347 // Add all of the conversion functions as candidates. 3348 const auto &Conversions = FromRecordDecl->getVisibleConversionFunctions(); 3349 for (auto I = Conversions.begin(), E = Conversions.end(); I != E; ++I) { 3350 DeclAccessPair FoundDecl = I.getPair(); 3351 NamedDecl *D = FoundDecl.getDecl(); 3352 CXXRecordDecl *ActingContext = cast<CXXRecordDecl>(D->getDeclContext()); 3353 if (isa<UsingShadowDecl>(D)) 3354 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 3355 3356 CXXConversionDecl *Conv; 3357 FunctionTemplateDecl *ConvTemplate; 3358 if ((ConvTemplate = dyn_cast<FunctionTemplateDecl>(D))) 3359 Conv = cast<CXXConversionDecl>(ConvTemplate->getTemplatedDecl()); 3360 else 3361 Conv = cast<CXXConversionDecl>(D); 3362 3363 if (AllowExplicit || !Conv->isExplicit()) { 3364 if (ConvTemplate) 3365 S.AddTemplateConversionCandidate(ConvTemplate, FoundDecl, 3366 ActingContext, From, ToType, 3367 CandidateSet, 3368 AllowObjCConversionOnExplicit); 3369 else 3370 S.AddConversionCandidate(Conv, FoundDecl, ActingContext, 3371 From, ToType, CandidateSet, 3372 AllowObjCConversionOnExplicit); 3373 } 3374 } 3375 } 3376 } 3377 3378 bool HadMultipleCandidates = (CandidateSet.size() > 1); 3379 3380 OverloadCandidateSet::iterator Best; 3381 switch (auto Result = CandidateSet.BestViableFunction(S, From->getLocStart(), 3382 Best)) { 3383 case OR_Success: 3384 case OR_Deleted: 3385 // Record the standard conversion we used and the conversion function. 3386 if (CXXConstructorDecl *Constructor 3387 = dyn_cast<CXXConstructorDecl>(Best->Function)) { 3388 // C++ [over.ics.user]p1: 3389 // If the user-defined conversion is specified by a 3390 // constructor (12.3.1), the initial standard conversion 3391 // sequence converts the source type to the type required by 3392 // the argument of the constructor. 3393 // 3394 QualType ThisType = Constructor->getThisType(S.Context); 3395 if (isa<InitListExpr>(From)) { 3396 // Initializer lists don't have conversions as such. 3397 User.Before.setAsIdentityConversion(); 3398 } else { 3399 if (Best->Conversions[0].isEllipsis()) 3400 User.EllipsisConversion = true; 3401 else { 3402 User.Before = Best->Conversions[0].Standard; 3403 User.EllipsisConversion = false; 3404 } 3405 } 3406 User.HadMultipleCandidates = HadMultipleCandidates; 3407 User.ConversionFunction = Constructor; 3408 User.FoundConversionFunction = Best->FoundDecl; 3409 User.After.setAsIdentityConversion(); 3410 User.After.setFromType(ThisType->getAs<PointerType>()->getPointeeType()); 3411 User.After.setAllToTypes(ToType); 3412 return Result; 3413 } 3414 if (CXXConversionDecl *Conversion 3415 = dyn_cast<CXXConversionDecl>(Best->Function)) { 3416 // C++ [over.ics.user]p1: 3417 // 3418 // [...] If the user-defined conversion is specified by a 3419 // conversion function (12.3.2), the initial standard 3420 // conversion sequence converts the source type to the 3421 // implicit object parameter of the conversion function. 3422 User.Before = Best->Conversions[0].Standard; 3423 User.HadMultipleCandidates = HadMultipleCandidates; 3424 User.ConversionFunction = Conversion; 3425 User.FoundConversionFunction = Best->FoundDecl; 3426 User.EllipsisConversion = false; 3427 3428 // C++ [over.ics.user]p2: 3429 // The second standard conversion sequence converts the 3430 // result of the user-defined conversion to the target type 3431 // for the sequence. Since an implicit conversion sequence 3432 // is an initialization, the special rules for 3433 // initialization by user-defined conversion apply when 3434 // selecting the best user-defined conversion for a 3435 // user-defined conversion sequence (see 13.3.3 and 3436 // 13.3.3.1). 3437 User.After = Best->FinalConversion; 3438 return Result; 3439 } 3440 llvm_unreachable("Not a constructor or conversion function?"); 3441 3442 case OR_No_Viable_Function: 3443 return OR_No_Viable_Function; 3444 3445 case OR_Ambiguous: 3446 return OR_Ambiguous; 3447 } 3448 3449 llvm_unreachable("Invalid OverloadResult!"); 3450 } 3451 3452 bool 3453 Sema::DiagnoseMultipleUserDefinedConversion(Expr *From, QualType ToType) { 3454 ImplicitConversionSequence ICS; 3455 OverloadCandidateSet CandidateSet(From->getExprLoc(), 3456 OverloadCandidateSet::CSK_Normal); 3457 OverloadingResult OvResult = 3458 IsUserDefinedConversion(*this, From, ToType, ICS.UserDefined, 3459 CandidateSet, false, false); 3460 if (OvResult == OR_Ambiguous) 3461 Diag(From->getLocStart(), diag::err_typecheck_ambiguous_condition) 3462 << From->getType() << ToType << From->getSourceRange(); 3463 else if (OvResult == OR_No_Viable_Function && !CandidateSet.empty()) { 3464 if (!RequireCompleteType(From->getLocStart(), ToType, 3465 diag::err_typecheck_nonviable_condition_incomplete, 3466 From->getType(), From->getSourceRange())) 3467 Diag(From->getLocStart(), diag::err_typecheck_nonviable_condition) 3468 << false << From->getType() << From->getSourceRange() << ToType; 3469 } else 3470 return false; 3471 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, From); 3472 return true; 3473 } 3474 3475 /// \brief Compare the user-defined conversion functions or constructors 3476 /// of two user-defined conversion sequences to determine whether any ordering 3477 /// is possible. 3478 static ImplicitConversionSequence::CompareKind 3479 compareConversionFunctions(Sema &S, FunctionDecl *Function1, 3480 FunctionDecl *Function2) { 3481 if (!S.getLangOpts().ObjC1 || !S.getLangOpts().CPlusPlus11) 3482 return ImplicitConversionSequence::Indistinguishable; 3483 3484 // Objective-C++: 3485 // If both conversion functions are implicitly-declared conversions from 3486 // a lambda closure type to a function pointer and a block pointer, 3487 // respectively, always prefer the conversion to a function pointer, 3488 // because the function pointer is more lightweight and is more likely 3489 // to keep code working. 3490 CXXConversionDecl *Conv1 = dyn_cast_or_null<CXXConversionDecl>(Function1); 3491 if (!Conv1) 3492 return ImplicitConversionSequence::Indistinguishable; 3493 3494 CXXConversionDecl *Conv2 = dyn_cast<CXXConversionDecl>(Function2); 3495 if (!Conv2) 3496 return ImplicitConversionSequence::Indistinguishable; 3497 3498 if (Conv1->getParent()->isLambda() && Conv2->getParent()->isLambda()) { 3499 bool Block1 = Conv1->getConversionType()->isBlockPointerType(); 3500 bool Block2 = Conv2->getConversionType()->isBlockPointerType(); 3501 if (Block1 != Block2) 3502 return Block1 ? ImplicitConversionSequence::Worse 3503 : ImplicitConversionSequence::Better; 3504 } 3505 3506 return ImplicitConversionSequence::Indistinguishable; 3507 } 3508 3509 static bool hasDeprecatedStringLiteralToCharPtrConversion( 3510 const ImplicitConversionSequence &ICS) { 3511 return (ICS.isStandard() && ICS.Standard.DeprecatedStringLiteralToCharPtr) || 3512 (ICS.isUserDefined() && 3513 ICS.UserDefined.Before.DeprecatedStringLiteralToCharPtr); 3514 } 3515 3516 /// CompareImplicitConversionSequences - Compare two implicit 3517 /// conversion sequences to determine whether one is better than the 3518 /// other or if they are indistinguishable (C++ 13.3.3.2). 3519 static ImplicitConversionSequence::CompareKind 3520 CompareImplicitConversionSequences(Sema &S, SourceLocation Loc, 3521 const ImplicitConversionSequence& ICS1, 3522 const ImplicitConversionSequence& ICS2) 3523 { 3524 // (C++ 13.3.3.2p2): When comparing the basic forms of implicit 3525 // conversion sequences (as defined in 13.3.3.1) 3526 // -- a standard conversion sequence (13.3.3.1.1) is a better 3527 // conversion sequence than a user-defined conversion sequence or 3528 // an ellipsis conversion sequence, and 3529 // -- a user-defined conversion sequence (13.3.3.1.2) is a better 3530 // conversion sequence than an ellipsis conversion sequence 3531 // (13.3.3.1.3). 3532 // 3533 // C++0x [over.best.ics]p10: 3534 // For the purpose of ranking implicit conversion sequences as 3535 // described in 13.3.3.2, the ambiguous conversion sequence is 3536 // treated as a user-defined sequence that is indistinguishable 3537 // from any other user-defined conversion sequence. 3538 3539 // String literal to 'char *' conversion has been deprecated in C++03. It has 3540 // been removed from C++11. We still accept this conversion, if it happens at 3541 // the best viable function. Otherwise, this conversion is considered worse 3542 // than ellipsis conversion. Consider this as an extension; this is not in the 3543 // standard. For example: 3544 // 3545 // int &f(...); // #1 3546 // void f(char*); // #2 3547 // void g() { int &r = f("foo"); } 3548 // 3549 // In C++03, we pick #2 as the best viable function. 3550 // In C++11, we pick #1 as the best viable function, because ellipsis 3551 // conversion is better than string-literal to char* conversion (since there 3552 // is no such conversion in C++11). If there was no #1 at all or #1 couldn't 3553 // convert arguments, #2 would be the best viable function in C++11. 3554 // If the best viable function has this conversion, a warning will be issued 3555 // in C++03, or an ExtWarn (+SFINAE failure) will be issued in C++11. 3556 3557 if (S.getLangOpts().CPlusPlus11 && !S.getLangOpts().WritableStrings && 3558 hasDeprecatedStringLiteralToCharPtrConversion(ICS1) != 3559 hasDeprecatedStringLiteralToCharPtrConversion(ICS2)) 3560 return hasDeprecatedStringLiteralToCharPtrConversion(ICS1) 3561 ? ImplicitConversionSequence::Worse 3562 : ImplicitConversionSequence::Better; 3563 3564 if (ICS1.getKindRank() < ICS2.getKindRank()) 3565 return ImplicitConversionSequence::Better; 3566 if (ICS2.getKindRank() < ICS1.getKindRank()) 3567 return ImplicitConversionSequence::Worse; 3568 3569 // The following checks require both conversion sequences to be of 3570 // the same kind. 3571 if (ICS1.getKind() != ICS2.getKind()) 3572 return ImplicitConversionSequence::Indistinguishable; 3573 3574 ImplicitConversionSequence::CompareKind Result = 3575 ImplicitConversionSequence::Indistinguishable; 3576 3577 // Two implicit conversion sequences of the same form are 3578 // indistinguishable conversion sequences unless one of the 3579 // following rules apply: (C++ 13.3.3.2p3): 3580 3581 // List-initialization sequence L1 is a better conversion sequence than 3582 // list-initialization sequence L2 if: 3583 // - L1 converts to std::initializer_list<X> for some X and L2 does not, or, 3584 // if not that, 3585 // - L1 converts to type "array of N1 T", L2 converts to type "array of N2 T", 3586 // and N1 is smaller than N2., 3587 // even if one of the other rules in this paragraph would otherwise apply. 3588 if (!ICS1.isBad()) { 3589 if (ICS1.isStdInitializerListElement() && 3590 !ICS2.isStdInitializerListElement()) 3591 return ImplicitConversionSequence::Better; 3592 if (!ICS1.isStdInitializerListElement() && 3593 ICS2.isStdInitializerListElement()) 3594 return ImplicitConversionSequence::Worse; 3595 } 3596 3597 if (ICS1.isStandard()) 3598 // Standard conversion sequence S1 is a better conversion sequence than 3599 // standard conversion sequence S2 if [...] 3600 Result = CompareStandardConversionSequences(S, Loc, 3601 ICS1.Standard, ICS2.Standard); 3602 else if (ICS1.isUserDefined()) { 3603 // User-defined conversion sequence U1 is a better conversion 3604 // sequence than another user-defined conversion sequence U2 if 3605 // they contain the same user-defined conversion function or 3606 // constructor and if the second standard conversion sequence of 3607 // U1 is better than the second standard conversion sequence of 3608 // U2 (C++ 13.3.3.2p3). 3609 if (ICS1.UserDefined.ConversionFunction == 3610 ICS2.UserDefined.ConversionFunction) 3611 Result = CompareStandardConversionSequences(S, Loc, 3612 ICS1.UserDefined.After, 3613 ICS2.UserDefined.After); 3614 else 3615 Result = compareConversionFunctions(S, 3616 ICS1.UserDefined.ConversionFunction, 3617 ICS2.UserDefined.ConversionFunction); 3618 } 3619 3620 return Result; 3621 } 3622 3623 static bool hasSimilarType(ASTContext &Context, QualType T1, QualType T2) { 3624 while (Context.UnwrapSimilarPointerTypes(T1, T2)) { 3625 Qualifiers Quals; 3626 T1 = Context.getUnqualifiedArrayType(T1, Quals); 3627 T2 = Context.getUnqualifiedArrayType(T2, Quals); 3628 } 3629 3630 return Context.hasSameUnqualifiedType(T1, T2); 3631 } 3632 3633 // Per 13.3.3.2p3, compare the given standard conversion sequences to 3634 // determine if one is a proper subset of the other. 3635 static ImplicitConversionSequence::CompareKind 3636 compareStandardConversionSubsets(ASTContext &Context, 3637 const StandardConversionSequence& SCS1, 3638 const StandardConversionSequence& SCS2) { 3639 ImplicitConversionSequence::CompareKind Result 3640 = ImplicitConversionSequence::Indistinguishable; 3641 3642 // the identity conversion sequence is considered to be a subsequence of 3643 // any non-identity conversion sequence 3644 if (SCS1.isIdentityConversion() && !SCS2.isIdentityConversion()) 3645 return ImplicitConversionSequence::Better; 3646 else if (!SCS1.isIdentityConversion() && SCS2.isIdentityConversion()) 3647 return ImplicitConversionSequence::Worse; 3648 3649 if (SCS1.Second != SCS2.Second) { 3650 if (SCS1.Second == ICK_Identity) 3651 Result = ImplicitConversionSequence::Better; 3652 else if (SCS2.Second == ICK_Identity) 3653 Result = ImplicitConversionSequence::Worse; 3654 else 3655 return ImplicitConversionSequence::Indistinguishable; 3656 } else if (!hasSimilarType(Context, SCS1.getToType(1), SCS2.getToType(1))) 3657 return ImplicitConversionSequence::Indistinguishable; 3658 3659 if (SCS1.Third == SCS2.Third) { 3660 return Context.hasSameType(SCS1.getToType(2), SCS2.getToType(2))? Result 3661 : ImplicitConversionSequence::Indistinguishable; 3662 } 3663 3664 if (SCS1.Third == ICK_Identity) 3665 return Result == ImplicitConversionSequence::Worse 3666 ? ImplicitConversionSequence::Indistinguishable 3667 : ImplicitConversionSequence::Better; 3668 3669 if (SCS2.Third == ICK_Identity) 3670 return Result == ImplicitConversionSequence::Better 3671 ? ImplicitConversionSequence::Indistinguishable 3672 : ImplicitConversionSequence::Worse; 3673 3674 return ImplicitConversionSequence::Indistinguishable; 3675 } 3676 3677 /// \brief Determine whether one of the given reference bindings is better 3678 /// than the other based on what kind of bindings they are. 3679 static bool 3680 isBetterReferenceBindingKind(const StandardConversionSequence &SCS1, 3681 const StandardConversionSequence &SCS2) { 3682 // C++0x [over.ics.rank]p3b4: 3683 // -- S1 and S2 are reference bindings (8.5.3) and neither refers to an 3684 // implicit object parameter of a non-static member function declared 3685 // without a ref-qualifier, and *either* S1 binds an rvalue reference 3686 // to an rvalue and S2 binds an lvalue reference *or S1 binds an 3687 // lvalue reference to a function lvalue and S2 binds an rvalue 3688 // reference*. 3689 // 3690 // FIXME: Rvalue references. We're going rogue with the above edits, 3691 // because the semantics in the current C++0x working paper (N3225 at the 3692 // time of this writing) break the standard definition of std::forward 3693 // and std::reference_wrapper when dealing with references to functions. 3694 // Proposed wording changes submitted to CWG for consideration. 3695 if (SCS1.BindsImplicitObjectArgumentWithoutRefQualifier || 3696 SCS2.BindsImplicitObjectArgumentWithoutRefQualifier) 3697 return false; 3698 3699 return (!SCS1.IsLvalueReference && SCS1.BindsToRvalue && 3700 SCS2.IsLvalueReference) || 3701 (SCS1.IsLvalueReference && SCS1.BindsToFunctionLvalue && 3702 !SCS2.IsLvalueReference && SCS2.BindsToFunctionLvalue); 3703 } 3704 3705 /// CompareStandardConversionSequences - Compare two standard 3706 /// conversion sequences to determine whether one is better than the 3707 /// other or if they are indistinguishable (C++ 13.3.3.2p3). 3708 static ImplicitConversionSequence::CompareKind 3709 CompareStandardConversionSequences(Sema &S, SourceLocation Loc, 3710 const StandardConversionSequence& SCS1, 3711 const StandardConversionSequence& SCS2) 3712 { 3713 // Standard conversion sequence S1 is a better conversion sequence 3714 // than standard conversion sequence S2 if (C++ 13.3.3.2p3): 3715 3716 // -- S1 is a proper subsequence of S2 (comparing the conversion 3717 // sequences in the canonical form defined by 13.3.3.1.1, 3718 // excluding any Lvalue Transformation; the identity conversion 3719 // sequence is considered to be a subsequence of any 3720 // non-identity conversion sequence) or, if not that, 3721 if (ImplicitConversionSequence::CompareKind CK 3722 = compareStandardConversionSubsets(S.Context, SCS1, SCS2)) 3723 return CK; 3724 3725 // -- the rank of S1 is better than the rank of S2 (by the rules 3726 // defined below), or, if not that, 3727 ImplicitConversionRank Rank1 = SCS1.getRank(); 3728 ImplicitConversionRank Rank2 = SCS2.getRank(); 3729 if (Rank1 < Rank2) 3730 return ImplicitConversionSequence::Better; 3731 else if (Rank2 < Rank1) 3732 return ImplicitConversionSequence::Worse; 3733 3734 // (C++ 13.3.3.2p4): Two conversion sequences with the same rank 3735 // are indistinguishable unless one of the following rules 3736 // applies: 3737 3738 // A conversion that is not a conversion of a pointer, or 3739 // pointer to member, to bool is better than another conversion 3740 // that is such a conversion. 3741 if (SCS1.isPointerConversionToBool() != SCS2.isPointerConversionToBool()) 3742 return SCS2.isPointerConversionToBool() 3743 ? ImplicitConversionSequence::Better 3744 : ImplicitConversionSequence::Worse; 3745 3746 // C++ [over.ics.rank]p4b2: 3747 // 3748 // If class B is derived directly or indirectly from class A, 3749 // conversion of B* to A* is better than conversion of B* to 3750 // void*, and conversion of A* to void* is better than conversion 3751 // of B* to void*. 3752 bool SCS1ConvertsToVoid 3753 = SCS1.isPointerConversionToVoidPointer(S.Context); 3754 bool SCS2ConvertsToVoid 3755 = SCS2.isPointerConversionToVoidPointer(S.Context); 3756 if (SCS1ConvertsToVoid != SCS2ConvertsToVoid) { 3757 // Exactly one of the conversion sequences is a conversion to 3758 // a void pointer; it's the worse conversion. 3759 return SCS2ConvertsToVoid ? ImplicitConversionSequence::Better 3760 : ImplicitConversionSequence::Worse; 3761 } else if (!SCS1ConvertsToVoid && !SCS2ConvertsToVoid) { 3762 // Neither conversion sequence converts to a void pointer; compare 3763 // their derived-to-base conversions. 3764 if (ImplicitConversionSequence::CompareKind DerivedCK 3765 = CompareDerivedToBaseConversions(S, Loc, SCS1, SCS2)) 3766 return DerivedCK; 3767 } else if (SCS1ConvertsToVoid && SCS2ConvertsToVoid && 3768 !S.Context.hasSameType(SCS1.getFromType(), SCS2.getFromType())) { 3769 // Both conversion sequences are conversions to void 3770 // pointers. Compare the source types to determine if there's an 3771 // inheritance relationship in their sources. 3772 QualType FromType1 = SCS1.getFromType(); 3773 QualType FromType2 = SCS2.getFromType(); 3774 3775 // Adjust the types we're converting from via the array-to-pointer 3776 // conversion, if we need to. 3777 if (SCS1.First == ICK_Array_To_Pointer) 3778 FromType1 = S.Context.getArrayDecayedType(FromType1); 3779 if (SCS2.First == ICK_Array_To_Pointer) 3780 FromType2 = S.Context.getArrayDecayedType(FromType2); 3781 3782 QualType FromPointee1 = FromType1->getPointeeType().getUnqualifiedType(); 3783 QualType FromPointee2 = FromType2->getPointeeType().getUnqualifiedType(); 3784 3785 if (S.IsDerivedFrom(Loc, FromPointee2, FromPointee1)) 3786 return ImplicitConversionSequence::Better; 3787 else if (S.IsDerivedFrom(Loc, FromPointee1, FromPointee2)) 3788 return ImplicitConversionSequence::Worse; 3789 3790 // Objective-C++: If one interface is more specific than the 3791 // other, it is the better one. 3792 const ObjCObjectPointerType* FromObjCPtr1 3793 = FromType1->getAs<ObjCObjectPointerType>(); 3794 const ObjCObjectPointerType* FromObjCPtr2 3795 = FromType2->getAs<ObjCObjectPointerType>(); 3796 if (FromObjCPtr1 && FromObjCPtr2) { 3797 bool AssignLeft = S.Context.canAssignObjCInterfaces(FromObjCPtr1, 3798 FromObjCPtr2); 3799 bool AssignRight = S.Context.canAssignObjCInterfaces(FromObjCPtr2, 3800 FromObjCPtr1); 3801 if (AssignLeft != AssignRight) { 3802 return AssignLeft? ImplicitConversionSequence::Better 3803 : ImplicitConversionSequence::Worse; 3804 } 3805 } 3806 } 3807 3808 // Compare based on qualification conversions (C++ 13.3.3.2p3, 3809 // bullet 3). 3810 if (ImplicitConversionSequence::CompareKind QualCK 3811 = CompareQualificationConversions(S, SCS1, SCS2)) 3812 return QualCK; 3813 3814 if (SCS1.ReferenceBinding && SCS2.ReferenceBinding) { 3815 // Check for a better reference binding based on the kind of bindings. 3816 if (isBetterReferenceBindingKind(SCS1, SCS2)) 3817 return ImplicitConversionSequence::Better; 3818 else if (isBetterReferenceBindingKind(SCS2, SCS1)) 3819 return ImplicitConversionSequence::Worse; 3820 3821 // C++ [over.ics.rank]p3b4: 3822 // -- S1 and S2 are reference bindings (8.5.3), and the types to 3823 // which the references refer are the same type except for 3824 // top-level cv-qualifiers, and the type to which the reference 3825 // initialized by S2 refers is more cv-qualified than the type 3826 // to which the reference initialized by S1 refers. 3827 QualType T1 = SCS1.getToType(2); 3828 QualType T2 = SCS2.getToType(2); 3829 T1 = S.Context.getCanonicalType(T1); 3830 T2 = S.Context.getCanonicalType(T2); 3831 Qualifiers T1Quals, T2Quals; 3832 QualType UnqualT1 = S.Context.getUnqualifiedArrayType(T1, T1Quals); 3833 QualType UnqualT2 = S.Context.getUnqualifiedArrayType(T2, T2Quals); 3834 if (UnqualT1 == UnqualT2) { 3835 // Objective-C++ ARC: If the references refer to objects with different 3836 // lifetimes, prefer bindings that don't change lifetime. 3837 if (SCS1.ObjCLifetimeConversionBinding != 3838 SCS2.ObjCLifetimeConversionBinding) { 3839 return SCS1.ObjCLifetimeConversionBinding 3840 ? ImplicitConversionSequence::Worse 3841 : ImplicitConversionSequence::Better; 3842 } 3843 3844 // If the type is an array type, promote the element qualifiers to the 3845 // type for comparison. 3846 if (isa<ArrayType>(T1) && T1Quals) 3847 T1 = S.Context.getQualifiedType(UnqualT1, T1Quals); 3848 if (isa<ArrayType>(T2) && T2Quals) 3849 T2 = S.Context.getQualifiedType(UnqualT2, T2Quals); 3850 if (T2.isMoreQualifiedThan(T1)) 3851 return ImplicitConversionSequence::Better; 3852 else if (T1.isMoreQualifiedThan(T2)) 3853 return ImplicitConversionSequence::Worse; 3854 } 3855 } 3856 3857 // In Microsoft mode, prefer an integral conversion to a 3858 // floating-to-integral conversion if the integral conversion 3859 // is between types of the same size. 3860 // For example: 3861 // void f(float); 3862 // void f(int); 3863 // int main { 3864 // long a; 3865 // f(a); 3866 // } 3867 // Here, MSVC will call f(int) instead of generating a compile error 3868 // as clang will do in standard mode. 3869 if (S.getLangOpts().MSVCCompat && SCS1.Second == ICK_Integral_Conversion && 3870 SCS2.Second == ICK_Floating_Integral && 3871 S.Context.getTypeSize(SCS1.getFromType()) == 3872 S.Context.getTypeSize(SCS1.getToType(2))) 3873 return ImplicitConversionSequence::Better; 3874 3875 return ImplicitConversionSequence::Indistinguishable; 3876 } 3877 3878 /// CompareQualificationConversions - Compares two standard conversion 3879 /// sequences to determine whether they can be ranked based on their 3880 /// qualification conversions (C++ 13.3.3.2p3 bullet 3). 3881 static ImplicitConversionSequence::CompareKind 3882 CompareQualificationConversions(Sema &S, 3883 const StandardConversionSequence& SCS1, 3884 const StandardConversionSequence& SCS2) { 3885 // C++ 13.3.3.2p3: 3886 // -- S1 and S2 differ only in their qualification conversion and 3887 // yield similar types T1 and T2 (C++ 4.4), respectively, and the 3888 // cv-qualification signature of type T1 is a proper subset of 3889 // the cv-qualification signature of type T2, and S1 is not the 3890 // deprecated string literal array-to-pointer conversion (4.2). 3891 if (SCS1.First != SCS2.First || SCS1.Second != SCS2.Second || 3892 SCS1.Third != SCS2.Third || SCS1.Third != ICK_Qualification) 3893 return ImplicitConversionSequence::Indistinguishable; 3894 3895 // FIXME: the example in the standard doesn't use a qualification 3896 // conversion (!) 3897 QualType T1 = SCS1.getToType(2); 3898 QualType T2 = SCS2.getToType(2); 3899 T1 = S.Context.getCanonicalType(T1); 3900 T2 = S.Context.getCanonicalType(T2); 3901 Qualifiers T1Quals, T2Quals; 3902 QualType UnqualT1 = S.Context.getUnqualifiedArrayType(T1, T1Quals); 3903 QualType UnqualT2 = S.Context.getUnqualifiedArrayType(T2, T2Quals); 3904 3905 // If the types are the same, we won't learn anything by unwrapped 3906 // them. 3907 if (UnqualT1 == UnqualT2) 3908 return ImplicitConversionSequence::Indistinguishable; 3909 3910 // If the type is an array type, promote the element qualifiers to the type 3911 // for comparison. 3912 if (isa<ArrayType>(T1) && T1Quals) 3913 T1 = S.Context.getQualifiedType(UnqualT1, T1Quals); 3914 if (isa<ArrayType>(T2) && T2Quals) 3915 T2 = S.Context.getQualifiedType(UnqualT2, T2Quals); 3916 3917 ImplicitConversionSequence::CompareKind Result 3918 = ImplicitConversionSequence::Indistinguishable; 3919 3920 // Objective-C++ ARC: 3921 // Prefer qualification conversions not involving a change in lifetime 3922 // to qualification conversions that do not change lifetime. 3923 if (SCS1.QualificationIncludesObjCLifetime != 3924 SCS2.QualificationIncludesObjCLifetime) { 3925 Result = SCS1.QualificationIncludesObjCLifetime 3926 ? ImplicitConversionSequence::Worse 3927 : ImplicitConversionSequence::Better; 3928 } 3929 3930 while (S.Context.UnwrapSimilarPointerTypes(T1, T2)) { 3931 // Within each iteration of the loop, we check the qualifiers to 3932 // determine if this still looks like a qualification 3933 // conversion. Then, if all is well, we unwrap one more level of 3934 // pointers or pointers-to-members and do it all again 3935 // until there are no more pointers or pointers-to-members left 3936 // to unwrap. This essentially mimics what 3937 // IsQualificationConversion does, but here we're checking for a 3938 // strict subset of qualifiers. 3939 if (T1.getCVRQualifiers() == T2.getCVRQualifiers()) 3940 // The qualifiers are the same, so this doesn't tell us anything 3941 // about how the sequences rank. 3942 ; 3943 else if (T2.isMoreQualifiedThan(T1)) { 3944 // T1 has fewer qualifiers, so it could be the better sequence. 3945 if (Result == ImplicitConversionSequence::Worse) 3946 // Neither has qualifiers that are a subset of the other's 3947 // qualifiers. 3948 return ImplicitConversionSequence::Indistinguishable; 3949 3950 Result = ImplicitConversionSequence::Better; 3951 } else if (T1.isMoreQualifiedThan(T2)) { 3952 // T2 has fewer qualifiers, so it could be the better sequence. 3953 if (Result == ImplicitConversionSequence::Better) 3954 // Neither has qualifiers that are a subset of the other's 3955 // qualifiers. 3956 return ImplicitConversionSequence::Indistinguishable; 3957 3958 Result = ImplicitConversionSequence::Worse; 3959 } else { 3960 // Qualifiers are disjoint. 3961 return ImplicitConversionSequence::Indistinguishable; 3962 } 3963 3964 // If the types after this point are equivalent, we're done. 3965 if (S.Context.hasSameUnqualifiedType(T1, T2)) 3966 break; 3967 } 3968 3969 // Check that the winning standard conversion sequence isn't using 3970 // the deprecated string literal array to pointer conversion. 3971 switch (Result) { 3972 case ImplicitConversionSequence::Better: 3973 if (SCS1.DeprecatedStringLiteralToCharPtr) 3974 Result = ImplicitConversionSequence::Indistinguishable; 3975 break; 3976 3977 case ImplicitConversionSequence::Indistinguishable: 3978 break; 3979 3980 case ImplicitConversionSequence::Worse: 3981 if (SCS2.DeprecatedStringLiteralToCharPtr) 3982 Result = ImplicitConversionSequence::Indistinguishable; 3983 break; 3984 } 3985 3986 return Result; 3987 } 3988 3989 /// CompareDerivedToBaseConversions - Compares two standard conversion 3990 /// sequences to determine whether they can be ranked based on their 3991 /// various kinds of derived-to-base conversions (C++ 3992 /// [over.ics.rank]p4b3). As part of these checks, we also look at 3993 /// conversions between Objective-C interface types. 3994 static ImplicitConversionSequence::CompareKind 3995 CompareDerivedToBaseConversions(Sema &S, SourceLocation Loc, 3996 const StandardConversionSequence& SCS1, 3997 const StandardConversionSequence& SCS2) { 3998 QualType FromType1 = SCS1.getFromType(); 3999 QualType ToType1 = SCS1.getToType(1); 4000 QualType FromType2 = SCS2.getFromType(); 4001 QualType ToType2 = SCS2.getToType(1); 4002 4003 // Adjust the types we're converting from via the array-to-pointer 4004 // conversion, if we need to. 4005 if (SCS1.First == ICK_Array_To_Pointer) 4006 FromType1 = S.Context.getArrayDecayedType(FromType1); 4007 if (SCS2.First == ICK_Array_To_Pointer) 4008 FromType2 = S.Context.getArrayDecayedType(FromType2); 4009 4010 // Canonicalize all of the types. 4011 FromType1 = S.Context.getCanonicalType(FromType1); 4012 ToType1 = S.Context.getCanonicalType(ToType1); 4013 FromType2 = S.Context.getCanonicalType(FromType2); 4014 ToType2 = S.Context.getCanonicalType(ToType2); 4015 4016 // C++ [over.ics.rank]p4b3: 4017 // 4018 // If class B is derived directly or indirectly from class A and 4019 // class C is derived directly or indirectly from B, 4020 // 4021 // Compare based on pointer conversions. 4022 if (SCS1.Second == ICK_Pointer_Conversion && 4023 SCS2.Second == ICK_Pointer_Conversion && 4024 /*FIXME: Remove if Objective-C id conversions get their own rank*/ 4025 FromType1->isPointerType() && FromType2->isPointerType() && 4026 ToType1->isPointerType() && ToType2->isPointerType()) { 4027 QualType FromPointee1 4028 = FromType1->getAs<PointerType>()->getPointeeType().getUnqualifiedType(); 4029 QualType ToPointee1 4030 = ToType1->getAs<PointerType>()->getPointeeType().getUnqualifiedType(); 4031 QualType FromPointee2 4032 = FromType2->getAs<PointerType>()->getPointeeType().getUnqualifiedType(); 4033 QualType ToPointee2 4034 = ToType2->getAs<PointerType>()->getPointeeType().getUnqualifiedType(); 4035 4036 // -- conversion of C* to B* is better than conversion of C* to A*, 4037 if (FromPointee1 == FromPointee2 && ToPointee1 != ToPointee2) { 4038 if (S.IsDerivedFrom(Loc, ToPointee1, ToPointee2)) 4039 return ImplicitConversionSequence::Better; 4040 else if (S.IsDerivedFrom(Loc, ToPointee2, ToPointee1)) 4041 return ImplicitConversionSequence::Worse; 4042 } 4043 4044 // -- conversion of B* to A* is better than conversion of C* to A*, 4045 if (FromPointee1 != FromPointee2 && ToPointee1 == ToPointee2) { 4046 if (S.IsDerivedFrom(Loc, FromPointee2, FromPointee1)) 4047 return ImplicitConversionSequence::Better; 4048 else if (S.IsDerivedFrom(Loc, FromPointee1, FromPointee2)) 4049 return ImplicitConversionSequence::Worse; 4050 } 4051 } else if (SCS1.Second == ICK_Pointer_Conversion && 4052 SCS2.Second == ICK_Pointer_Conversion) { 4053 const ObjCObjectPointerType *FromPtr1 4054 = FromType1->getAs<ObjCObjectPointerType>(); 4055 const ObjCObjectPointerType *FromPtr2 4056 = FromType2->getAs<ObjCObjectPointerType>(); 4057 const ObjCObjectPointerType *ToPtr1 4058 = ToType1->getAs<ObjCObjectPointerType>(); 4059 const ObjCObjectPointerType *ToPtr2 4060 = ToType2->getAs<ObjCObjectPointerType>(); 4061 4062 if (FromPtr1 && FromPtr2 && ToPtr1 && ToPtr2) { 4063 // Apply the same conversion ranking rules for Objective-C pointer types 4064 // that we do for C++ pointers to class types. However, we employ the 4065 // Objective-C pseudo-subtyping relationship used for assignment of 4066 // Objective-C pointer types. 4067 bool FromAssignLeft 4068 = S.Context.canAssignObjCInterfaces(FromPtr1, FromPtr2); 4069 bool FromAssignRight 4070 = S.Context.canAssignObjCInterfaces(FromPtr2, FromPtr1); 4071 bool ToAssignLeft 4072 = S.Context.canAssignObjCInterfaces(ToPtr1, ToPtr2); 4073 bool ToAssignRight 4074 = S.Context.canAssignObjCInterfaces(ToPtr2, ToPtr1); 4075 4076 // A conversion to an a non-id object pointer type or qualified 'id' 4077 // type is better than a conversion to 'id'. 4078 if (ToPtr1->isObjCIdType() && 4079 (ToPtr2->isObjCQualifiedIdType() || ToPtr2->getInterfaceDecl())) 4080 return ImplicitConversionSequence::Worse; 4081 if (ToPtr2->isObjCIdType() && 4082 (ToPtr1->isObjCQualifiedIdType() || ToPtr1->getInterfaceDecl())) 4083 return ImplicitConversionSequence::Better; 4084 4085 // A conversion to a non-id object pointer type is better than a 4086 // conversion to a qualified 'id' type 4087 if (ToPtr1->isObjCQualifiedIdType() && ToPtr2->getInterfaceDecl()) 4088 return ImplicitConversionSequence::Worse; 4089 if (ToPtr2->isObjCQualifiedIdType() && ToPtr1->getInterfaceDecl()) 4090 return ImplicitConversionSequence::Better; 4091 4092 // A conversion to an a non-Class object pointer type or qualified 'Class' 4093 // type is better than a conversion to 'Class'. 4094 if (ToPtr1->isObjCClassType() && 4095 (ToPtr2->isObjCQualifiedClassType() || ToPtr2->getInterfaceDecl())) 4096 return ImplicitConversionSequence::Worse; 4097 if (ToPtr2->isObjCClassType() && 4098 (ToPtr1->isObjCQualifiedClassType() || ToPtr1->getInterfaceDecl())) 4099 return ImplicitConversionSequence::Better; 4100 4101 // A conversion to a non-Class object pointer type is better than a 4102 // conversion to a qualified 'Class' type. 4103 if (ToPtr1->isObjCQualifiedClassType() && ToPtr2->getInterfaceDecl()) 4104 return ImplicitConversionSequence::Worse; 4105 if (ToPtr2->isObjCQualifiedClassType() && ToPtr1->getInterfaceDecl()) 4106 return ImplicitConversionSequence::Better; 4107 4108 // -- "conversion of C* to B* is better than conversion of C* to A*," 4109 if (S.Context.hasSameType(FromType1, FromType2) && 4110 !FromPtr1->isObjCIdType() && !FromPtr1->isObjCClassType() && 4111 (ToAssignLeft != ToAssignRight)) { 4112 if (FromPtr1->isSpecialized()) { 4113 // "conversion of B<A> * to B * is better than conversion of B * to 4114 // C *. 4115 bool IsFirstSame = 4116 FromPtr1->getInterfaceDecl() == ToPtr1->getInterfaceDecl(); 4117 bool IsSecondSame = 4118 FromPtr1->getInterfaceDecl() == ToPtr2->getInterfaceDecl(); 4119 if (IsFirstSame) { 4120 if (!IsSecondSame) 4121 return ImplicitConversionSequence::Better; 4122 } else if (IsSecondSame) 4123 return ImplicitConversionSequence::Worse; 4124 } 4125 return ToAssignLeft? ImplicitConversionSequence::Worse 4126 : ImplicitConversionSequence::Better; 4127 } 4128 4129 // -- "conversion of B* to A* is better than conversion of C* to A*," 4130 if (S.Context.hasSameUnqualifiedType(ToType1, ToType2) && 4131 (FromAssignLeft != FromAssignRight)) 4132 return FromAssignLeft? ImplicitConversionSequence::Better 4133 : ImplicitConversionSequence::Worse; 4134 } 4135 } 4136 4137 // Ranking of member-pointer types. 4138 if (SCS1.Second == ICK_Pointer_Member && SCS2.Second == ICK_Pointer_Member && 4139 FromType1->isMemberPointerType() && FromType2->isMemberPointerType() && 4140 ToType1->isMemberPointerType() && ToType2->isMemberPointerType()) { 4141 const MemberPointerType * FromMemPointer1 = 4142 FromType1->getAs<MemberPointerType>(); 4143 const MemberPointerType * ToMemPointer1 = 4144 ToType1->getAs<MemberPointerType>(); 4145 const MemberPointerType * FromMemPointer2 = 4146 FromType2->getAs<MemberPointerType>(); 4147 const MemberPointerType * ToMemPointer2 = 4148 ToType2->getAs<MemberPointerType>(); 4149 const Type *FromPointeeType1 = FromMemPointer1->getClass(); 4150 const Type *ToPointeeType1 = ToMemPointer1->getClass(); 4151 const Type *FromPointeeType2 = FromMemPointer2->getClass(); 4152 const Type *ToPointeeType2 = ToMemPointer2->getClass(); 4153 QualType FromPointee1 = QualType(FromPointeeType1, 0).getUnqualifiedType(); 4154 QualType ToPointee1 = QualType(ToPointeeType1, 0).getUnqualifiedType(); 4155 QualType FromPointee2 = QualType(FromPointeeType2, 0).getUnqualifiedType(); 4156 QualType ToPointee2 = QualType(ToPointeeType2, 0).getUnqualifiedType(); 4157 // conversion of A::* to B::* is better than conversion of A::* to C::*, 4158 if (FromPointee1 == FromPointee2 && ToPointee1 != ToPointee2) { 4159 if (S.IsDerivedFrom(Loc, ToPointee1, ToPointee2)) 4160 return ImplicitConversionSequence::Worse; 4161 else if (S.IsDerivedFrom(Loc, ToPointee2, ToPointee1)) 4162 return ImplicitConversionSequence::Better; 4163 } 4164 // conversion of B::* to C::* is better than conversion of A::* to C::* 4165 if (ToPointee1 == ToPointee2 && FromPointee1 != FromPointee2) { 4166 if (S.IsDerivedFrom(Loc, FromPointee1, FromPointee2)) 4167 return ImplicitConversionSequence::Better; 4168 else if (S.IsDerivedFrom(Loc, FromPointee2, FromPointee1)) 4169 return ImplicitConversionSequence::Worse; 4170 } 4171 } 4172 4173 if (SCS1.Second == ICK_Derived_To_Base) { 4174 // -- conversion of C to B is better than conversion of C to A, 4175 // -- binding of an expression of type C to a reference of type 4176 // B& is better than binding an expression of type C to a 4177 // reference of type A&, 4178 if (S.Context.hasSameUnqualifiedType(FromType1, FromType2) && 4179 !S.Context.hasSameUnqualifiedType(ToType1, ToType2)) { 4180 if (S.IsDerivedFrom(Loc, ToType1, ToType2)) 4181 return ImplicitConversionSequence::Better; 4182 else if (S.IsDerivedFrom(Loc, ToType2, ToType1)) 4183 return ImplicitConversionSequence::Worse; 4184 } 4185 4186 // -- conversion of B to A is better than conversion of C to A. 4187 // -- binding of an expression of type B to a reference of type 4188 // A& is better than binding an expression of type C to a 4189 // reference of type A&, 4190 if (!S.Context.hasSameUnqualifiedType(FromType1, FromType2) && 4191 S.Context.hasSameUnqualifiedType(ToType1, ToType2)) { 4192 if (S.IsDerivedFrom(Loc, FromType2, FromType1)) 4193 return ImplicitConversionSequence::Better; 4194 else if (S.IsDerivedFrom(Loc, FromType1, FromType2)) 4195 return ImplicitConversionSequence::Worse; 4196 } 4197 } 4198 4199 return ImplicitConversionSequence::Indistinguishable; 4200 } 4201 4202 /// \brief Determine whether the given type is valid, e.g., it is not an invalid 4203 /// C++ class. 4204 static bool isTypeValid(QualType T) { 4205 if (CXXRecordDecl *Record = T->getAsCXXRecordDecl()) 4206 return !Record->isInvalidDecl(); 4207 4208 return true; 4209 } 4210 4211 /// CompareReferenceRelationship - Compare the two types T1 and T2 to 4212 /// determine whether they are reference-related, 4213 /// reference-compatible, reference-compatible with added 4214 /// qualification, or incompatible, for use in C++ initialization by 4215 /// reference (C++ [dcl.ref.init]p4). Neither type can be a reference 4216 /// type, and the first type (T1) is the pointee type of the reference 4217 /// type being initialized. 4218 Sema::ReferenceCompareResult 4219 Sema::CompareReferenceRelationship(SourceLocation Loc, 4220 QualType OrigT1, QualType OrigT2, 4221 bool &DerivedToBase, 4222 bool &ObjCConversion, 4223 bool &ObjCLifetimeConversion) { 4224 assert(!OrigT1->isReferenceType() && 4225 "T1 must be the pointee type of the reference type"); 4226 assert(!OrigT2->isReferenceType() && "T2 cannot be a reference type"); 4227 4228 QualType T1 = Context.getCanonicalType(OrigT1); 4229 QualType T2 = Context.getCanonicalType(OrigT2); 4230 Qualifiers T1Quals, T2Quals; 4231 QualType UnqualT1 = Context.getUnqualifiedArrayType(T1, T1Quals); 4232 QualType UnqualT2 = Context.getUnqualifiedArrayType(T2, T2Quals); 4233 4234 // C++ [dcl.init.ref]p4: 4235 // Given types "cv1 T1" and "cv2 T2," "cv1 T1" is 4236 // reference-related to "cv2 T2" if T1 is the same type as T2, or 4237 // T1 is a base class of T2. 4238 DerivedToBase = false; 4239 ObjCConversion = false; 4240 ObjCLifetimeConversion = false; 4241 QualType ConvertedT2; 4242 if (UnqualT1 == UnqualT2) { 4243 // Nothing to do. 4244 } else if (isCompleteType(Loc, OrigT2) && 4245 isTypeValid(UnqualT1) && isTypeValid(UnqualT2) && 4246 IsDerivedFrom(Loc, UnqualT2, UnqualT1)) 4247 DerivedToBase = true; 4248 else if (UnqualT1->isObjCObjectOrInterfaceType() && 4249 UnqualT2->isObjCObjectOrInterfaceType() && 4250 Context.canBindObjCObjectType(UnqualT1, UnqualT2)) 4251 ObjCConversion = true; 4252 else if (UnqualT2->isFunctionType() && 4253 IsFunctionConversion(UnqualT2, UnqualT1, ConvertedT2)) 4254 // C++1z [dcl.init.ref]p4: 4255 // cv1 T1" is reference-compatible with "cv2 T2" if [...] T2 is "noexcept 4256 // function" and T1 is "function" 4257 // 4258 // We extend this to also apply to 'noreturn', so allow any function 4259 // conversion between function types. 4260 return Ref_Compatible; 4261 else 4262 return Ref_Incompatible; 4263 4264 // At this point, we know that T1 and T2 are reference-related (at 4265 // least). 4266 4267 // If the type is an array type, promote the element qualifiers to the type 4268 // for comparison. 4269 if (isa<ArrayType>(T1) && T1Quals) 4270 T1 = Context.getQualifiedType(UnqualT1, T1Quals); 4271 if (isa<ArrayType>(T2) && T2Quals) 4272 T2 = Context.getQualifiedType(UnqualT2, T2Quals); 4273 4274 // C++ [dcl.init.ref]p4: 4275 // "cv1 T1" is reference-compatible with "cv2 T2" if T1 is 4276 // reference-related to T2 and cv1 is the same cv-qualification 4277 // as, or greater cv-qualification than, cv2. For purposes of 4278 // overload resolution, cases for which cv1 is greater 4279 // cv-qualification than cv2 are identified as 4280 // reference-compatible with added qualification (see 13.3.3.2). 4281 // 4282 // Note that we also require equivalence of Objective-C GC and address-space 4283 // qualifiers when performing these computations, so that e.g., an int in 4284 // address space 1 is not reference-compatible with an int in address 4285 // space 2. 4286 if (T1Quals.getObjCLifetime() != T2Quals.getObjCLifetime() && 4287 T1Quals.compatiblyIncludesObjCLifetime(T2Quals)) { 4288 if (isNonTrivialObjCLifetimeConversion(T2Quals, T1Quals)) 4289 ObjCLifetimeConversion = true; 4290 4291 T1Quals.removeObjCLifetime(); 4292 T2Quals.removeObjCLifetime(); 4293 } 4294 4295 // MS compiler ignores __unaligned qualifier for references; do the same. 4296 T1Quals.removeUnaligned(); 4297 T2Quals.removeUnaligned(); 4298 4299 if (T1Quals.compatiblyIncludes(T2Quals)) 4300 return Ref_Compatible; 4301 else 4302 return Ref_Related; 4303 } 4304 4305 /// \brief Look for a user-defined conversion to a value reference-compatible 4306 /// with DeclType. Return true if something definite is found. 4307 static bool 4308 FindConversionForRefInit(Sema &S, ImplicitConversionSequence &ICS, 4309 QualType DeclType, SourceLocation DeclLoc, 4310 Expr *Init, QualType T2, bool AllowRvalues, 4311 bool AllowExplicit) { 4312 assert(T2->isRecordType() && "Can only find conversions of record types."); 4313 CXXRecordDecl *T2RecordDecl 4314 = dyn_cast<CXXRecordDecl>(T2->getAs<RecordType>()->getDecl()); 4315 4316 OverloadCandidateSet CandidateSet( 4317 DeclLoc, OverloadCandidateSet::CSK_InitByUserDefinedConversion); 4318 const auto &Conversions = T2RecordDecl->getVisibleConversionFunctions(); 4319 for (auto I = Conversions.begin(), E = Conversions.end(); I != E; ++I) { 4320 NamedDecl *D = *I; 4321 CXXRecordDecl *ActingDC = cast<CXXRecordDecl>(D->getDeclContext()); 4322 if (isa<UsingShadowDecl>(D)) 4323 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 4324 4325 FunctionTemplateDecl *ConvTemplate 4326 = dyn_cast<FunctionTemplateDecl>(D); 4327 CXXConversionDecl *Conv; 4328 if (ConvTemplate) 4329 Conv = cast<CXXConversionDecl>(ConvTemplate->getTemplatedDecl()); 4330 else 4331 Conv = cast<CXXConversionDecl>(D); 4332 4333 // If this is an explicit conversion, and we're not allowed to consider 4334 // explicit conversions, skip it. 4335 if (!AllowExplicit && Conv->isExplicit()) 4336 continue; 4337 4338 if (AllowRvalues) { 4339 bool DerivedToBase = false; 4340 bool ObjCConversion = false; 4341 bool ObjCLifetimeConversion = false; 4342 4343 // If we are initializing an rvalue reference, don't permit conversion 4344 // functions that return lvalues. 4345 if (!ConvTemplate && DeclType->isRValueReferenceType()) { 4346 const ReferenceType *RefType 4347 = Conv->getConversionType()->getAs<LValueReferenceType>(); 4348 if (RefType && !RefType->getPointeeType()->isFunctionType()) 4349 continue; 4350 } 4351 4352 if (!ConvTemplate && 4353 S.CompareReferenceRelationship( 4354 DeclLoc, 4355 Conv->getConversionType().getNonReferenceType() 4356 .getUnqualifiedType(), 4357 DeclType.getNonReferenceType().getUnqualifiedType(), 4358 DerivedToBase, ObjCConversion, ObjCLifetimeConversion) == 4359 Sema::Ref_Incompatible) 4360 continue; 4361 } else { 4362 // If the conversion function doesn't return a reference type, 4363 // it can't be considered for this conversion. An rvalue reference 4364 // is only acceptable if its referencee is a function type. 4365 4366 const ReferenceType *RefType = 4367 Conv->getConversionType()->getAs<ReferenceType>(); 4368 if (!RefType || 4369 (!RefType->isLValueReferenceType() && 4370 !RefType->getPointeeType()->isFunctionType())) 4371 continue; 4372 } 4373 4374 if (ConvTemplate) 4375 S.AddTemplateConversionCandidate(ConvTemplate, I.getPair(), ActingDC, 4376 Init, DeclType, CandidateSet, 4377 /*AllowObjCConversionOnExplicit=*/false); 4378 else 4379 S.AddConversionCandidate(Conv, I.getPair(), ActingDC, Init, 4380 DeclType, CandidateSet, 4381 /*AllowObjCConversionOnExplicit=*/false); 4382 } 4383 4384 bool HadMultipleCandidates = (CandidateSet.size() > 1); 4385 4386 OverloadCandidateSet::iterator Best; 4387 switch (CandidateSet.BestViableFunction(S, DeclLoc, Best)) { 4388 case OR_Success: 4389 // C++ [over.ics.ref]p1: 4390 // 4391 // [...] If the parameter binds directly to the result of 4392 // applying a conversion function to the argument 4393 // expression, the implicit conversion sequence is a 4394 // user-defined conversion sequence (13.3.3.1.2), with the 4395 // second standard conversion sequence either an identity 4396 // conversion or, if the conversion function returns an 4397 // entity of a type that is a derived class of the parameter 4398 // type, a derived-to-base Conversion. 4399 if (!Best->FinalConversion.DirectBinding) 4400 return false; 4401 4402 ICS.setUserDefined(); 4403 ICS.UserDefined.Before = Best->Conversions[0].Standard; 4404 ICS.UserDefined.After = Best->FinalConversion; 4405 ICS.UserDefined.HadMultipleCandidates = HadMultipleCandidates; 4406 ICS.UserDefined.ConversionFunction = Best->Function; 4407 ICS.UserDefined.FoundConversionFunction = Best->FoundDecl; 4408 ICS.UserDefined.EllipsisConversion = false; 4409 assert(ICS.UserDefined.After.ReferenceBinding && 4410 ICS.UserDefined.After.DirectBinding && 4411 "Expected a direct reference binding!"); 4412 return true; 4413 4414 case OR_Ambiguous: 4415 ICS.setAmbiguous(); 4416 for (OverloadCandidateSet::iterator Cand = CandidateSet.begin(); 4417 Cand != CandidateSet.end(); ++Cand) 4418 if (Cand->Viable) 4419 ICS.Ambiguous.addConversion(Cand->FoundDecl, Cand->Function); 4420 return true; 4421 4422 case OR_No_Viable_Function: 4423 case OR_Deleted: 4424 // There was no suitable conversion, or we found a deleted 4425 // conversion; continue with other checks. 4426 return false; 4427 } 4428 4429 llvm_unreachable("Invalid OverloadResult!"); 4430 } 4431 4432 /// \brief Compute an implicit conversion sequence for reference 4433 /// initialization. 4434 static ImplicitConversionSequence 4435 TryReferenceInit(Sema &S, Expr *Init, QualType DeclType, 4436 SourceLocation DeclLoc, 4437 bool SuppressUserConversions, 4438 bool AllowExplicit) { 4439 assert(DeclType->isReferenceType() && "Reference init needs a reference"); 4440 4441 // Most paths end in a failed conversion. 4442 ImplicitConversionSequence ICS; 4443 ICS.setBad(BadConversionSequence::no_conversion, Init, DeclType); 4444 4445 QualType T1 = DeclType->getAs<ReferenceType>()->getPointeeType(); 4446 QualType T2 = Init->getType(); 4447 4448 // If the initializer is the address of an overloaded function, try 4449 // to resolve the overloaded function. If all goes well, T2 is the 4450 // type of the resulting function. 4451 if (S.Context.getCanonicalType(T2) == S.Context.OverloadTy) { 4452 DeclAccessPair Found; 4453 if (FunctionDecl *Fn = S.ResolveAddressOfOverloadedFunction(Init, DeclType, 4454 false, Found)) 4455 T2 = Fn->getType(); 4456 } 4457 4458 // Compute some basic properties of the types and the initializer. 4459 bool isRValRef = DeclType->isRValueReferenceType(); 4460 bool DerivedToBase = false; 4461 bool ObjCConversion = false; 4462 bool ObjCLifetimeConversion = false; 4463 Expr::Classification InitCategory = Init->Classify(S.Context); 4464 Sema::ReferenceCompareResult RefRelationship 4465 = S.CompareReferenceRelationship(DeclLoc, T1, T2, DerivedToBase, 4466 ObjCConversion, ObjCLifetimeConversion); 4467 4468 4469 // C++0x [dcl.init.ref]p5: 4470 // A reference to type "cv1 T1" is initialized by an expression 4471 // of type "cv2 T2" as follows: 4472 4473 // -- If reference is an lvalue reference and the initializer expression 4474 if (!isRValRef) { 4475 // -- is an lvalue (but is not a bit-field), and "cv1 T1" is 4476 // reference-compatible with "cv2 T2," or 4477 // 4478 // Per C++ [over.ics.ref]p4, we don't check the bit-field property here. 4479 if (InitCategory.isLValue() && RefRelationship == Sema::Ref_Compatible) { 4480 // C++ [over.ics.ref]p1: 4481 // When a parameter of reference type binds directly (8.5.3) 4482 // to an argument expression, the implicit conversion sequence 4483 // is the identity conversion, unless the argument expression 4484 // has a type that is a derived class of the parameter type, 4485 // in which case the implicit conversion sequence is a 4486 // derived-to-base Conversion (13.3.3.1). 4487 ICS.setStandard(); 4488 ICS.Standard.First = ICK_Identity; 4489 ICS.Standard.Second = DerivedToBase? ICK_Derived_To_Base 4490 : ObjCConversion? ICK_Compatible_Conversion 4491 : ICK_Identity; 4492 ICS.Standard.Third = ICK_Identity; 4493 ICS.Standard.FromTypePtr = T2.getAsOpaquePtr(); 4494 ICS.Standard.setToType(0, T2); 4495 ICS.Standard.setToType(1, T1); 4496 ICS.Standard.setToType(2, T1); 4497 ICS.Standard.ReferenceBinding = true; 4498 ICS.Standard.DirectBinding = true; 4499 ICS.Standard.IsLvalueReference = !isRValRef; 4500 ICS.Standard.BindsToFunctionLvalue = T2->isFunctionType(); 4501 ICS.Standard.BindsToRvalue = false; 4502 ICS.Standard.BindsImplicitObjectArgumentWithoutRefQualifier = false; 4503 ICS.Standard.ObjCLifetimeConversionBinding = ObjCLifetimeConversion; 4504 ICS.Standard.CopyConstructor = nullptr; 4505 ICS.Standard.DeprecatedStringLiteralToCharPtr = false; 4506 4507 // Nothing more to do: the inaccessibility/ambiguity check for 4508 // derived-to-base conversions is suppressed when we're 4509 // computing the implicit conversion sequence (C++ 4510 // [over.best.ics]p2). 4511 return ICS; 4512 } 4513 4514 // -- has a class type (i.e., T2 is a class type), where T1 is 4515 // not reference-related to T2, and can be implicitly 4516 // converted to an lvalue of type "cv3 T3," where "cv1 T1" 4517 // is reference-compatible with "cv3 T3" 92) (this 4518 // conversion is selected by enumerating the applicable 4519 // conversion functions (13.3.1.6) and choosing the best 4520 // one through overload resolution (13.3)), 4521 if (!SuppressUserConversions && T2->isRecordType() && 4522 S.isCompleteType(DeclLoc, T2) && 4523 RefRelationship == Sema::Ref_Incompatible) { 4524 if (FindConversionForRefInit(S, ICS, DeclType, DeclLoc, 4525 Init, T2, /*AllowRvalues=*/false, 4526 AllowExplicit)) 4527 return ICS; 4528 } 4529 } 4530 4531 // -- Otherwise, the reference shall be an lvalue reference to a 4532 // non-volatile const type (i.e., cv1 shall be const), or the reference 4533 // shall be an rvalue reference. 4534 if (!isRValRef && (!T1.isConstQualified() || T1.isVolatileQualified())) 4535 return ICS; 4536 4537 // -- If the initializer expression 4538 // 4539 // -- is an xvalue, class prvalue, array prvalue or function 4540 // lvalue and "cv1 T1" is reference-compatible with "cv2 T2", or 4541 if (RefRelationship == Sema::Ref_Compatible && 4542 (InitCategory.isXValue() || 4543 (InitCategory.isPRValue() && (T2->isRecordType() || T2->isArrayType())) || 4544 (InitCategory.isLValue() && T2->isFunctionType()))) { 4545 ICS.setStandard(); 4546 ICS.Standard.First = ICK_Identity; 4547 ICS.Standard.Second = DerivedToBase? ICK_Derived_To_Base 4548 : ObjCConversion? ICK_Compatible_Conversion 4549 : ICK_Identity; 4550 ICS.Standard.Third = ICK_Identity; 4551 ICS.Standard.FromTypePtr = T2.getAsOpaquePtr(); 4552 ICS.Standard.setToType(0, T2); 4553 ICS.Standard.setToType(1, T1); 4554 ICS.Standard.setToType(2, T1); 4555 ICS.Standard.ReferenceBinding = true; 4556 // In C++0x, this is always a direct binding. In C++98/03, it's a direct 4557 // binding unless we're binding to a class prvalue. 4558 // Note: Although xvalues wouldn't normally show up in C++98/03 code, we 4559 // allow the use of rvalue references in C++98/03 for the benefit of 4560 // standard library implementors; therefore, we need the xvalue check here. 4561 ICS.Standard.DirectBinding = 4562 S.getLangOpts().CPlusPlus11 || 4563 !(InitCategory.isPRValue() || T2->isRecordType()); 4564 ICS.Standard.IsLvalueReference = !isRValRef; 4565 ICS.Standard.BindsToFunctionLvalue = T2->isFunctionType(); 4566 ICS.Standard.BindsToRvalue = InitCategory.isRValue(); 4567 ICS.Standard.BindsImplicitObjectArgumentWithoutRefQualifier = false; 4568 ICS.Standard.ObjCLifetimeConversionBinding = ObjCLifetimeConversion; 4569 ICS.Standard.CopyConstructor = nullptr; 4570 ICS.Standard.DeprecatedStringLiteralToCharPtr = false; 4571 return ICS; 4572 } 4573 4574 // -- has a class type (i.e., T2 is a class type), where T1 is not 4575 // reference-related to T2, and can be implicitly converted to 4576 // an xvalue, class prvalue, or function lvalue of type 4577 // "cv3 T3", where "cv1 T1" is reference-compatible with 4578 // "cv3 T3", 4579 // 4580 // then the reference is bound to the value of the initializer 4581 // expression in the first case and to the result of the conversion 4582 // in the second case (or, in either case, to an appropriate base 4583 // class subobject). 4584 if (!SuppressUserConversions && RefRelationship == Sema::Ref_Incompatible && 4585 T2->isRecordType() && S.isCompleteType(DeclLoc, T2) && 4586 FindConversionForRefInit(S, ICS, DeclType, DeclLoc, 4587 Init, T2, /*AllowRvalues=*/true, 4588 AllowExplicit)) { 4589 // In the second case, if the reference is an rvalue reference 4590 // and the second standard conversion sequence of the 4591 // user-defined conversion sequence includes an lvalue-to-rvalue 4592 // conversion, the program is ill-formed. 4593 if (ICS.isUserDefined() && isRValRef && 4594 ICS.UserDefined.After.First == ICK_Lvalue_To_Rvalue) 4595 ICS.setBad(BadConversionSequence::no_conversion, Init, DeclType); 4596 4597 return ICS; 4598 } 4599 4600 // A temporary of function type cannot be created; don't even try. 4601 if (T1->isFunctionType()) 4602 return ICS; 4603 4604 // -- Otherwise, a temporary of type "cv1 T1" is created and 4605 // initialized from the initializer expression using the 4606 // rules for a non-reference copy initialization (8.5). The 4607 // reference is then bound to the temporary. If T1 is 4608 // reference-related to T2, cv1 must be the same 4609 // cv-qualification as, or greater cv-qualification than, 4610 // cv2; otherwise, the program is ill-formed. 4611 if (RefRelationship == Sema::Ref_Related) { 4612 // If cv1 == cv2 or cv1 is a greater cv-qualified than cv2, then 4613 // we would be reference-compatible or reference-compatible with 4614 // added qualification. But that wasn't the case, so the reference 4615 // initialization fails. 4616 // 4617 // Note that we only want to check address spaces and cvr-qualifiers here. 4618 // ObjC GC, lifetime and unaligned qualifiers aren't important. 4619 Qualifiers T1Quals = T1.getQualifiers(); 4620 Qualifiers T2Quals = T2.getQualifiers(); 4621 T1Quals.removeObjCGCAttr(); 4622 T1Quals.removeObjCLifetime(); 4623 T2Quals.removeObjCGCAttr(); 4624 T2Quals.removeObjCLifetime(); 4625 // MS compiler ignores __unaligned qualifier for references; do the same. 4626 T1Quals.removeUnaligned(); 4627 T2Quals.removeUnaligned(); 4628 if (!T1Quals.compatiblyIncludes(T2Quals)) 4629 return ICS; 4630 } 4631 4632 // If at least one of the types is a class type, the types are not 4633 // related, and we aren't allowed any user conversions, the 4634 // reference binding fails. This case is important for breaking 4635 // recursion, since TryImplicitConversion below will attempt to 4636 // create a temporary through the use of a copy constructor. 4637 if (SuppressUserConversions && RefRelationship == Sema::Ref_Incompatible && 4638 (T1->isRecordType() || T2->isRecordType())) 4639 return ICS; 4640 4641 // If T1 is reference-related to T2 and the reference is an rvalue 4642 // reference, the initializer expression shall not be an lvalue. 4643 if (RefRelationship >= Sema::Ref_Related && 4644 isRValRef && Init->Classify(S.Context).isLValue()) 4645 return ICS; 4646 4647 // C++ [over.ics.ref]p2: 4648 // When a parameter of reference type is not bound directly to 4649 // an argument expression, the conversion sequence is the one 4650 // required to convert the argument expression to the 4651 // underlying type of the reference according to 4652 // 13.3.3.1. Conceptually, this conversion sequence corresponds 4653 // to copy-initializing a temporary of the underlying type with 4654 // the argument expression. Any difference in top-level 4655 // cv-qualification is subsumed by the initialization itself 4656 // and does not constitute a conversion. 4657 ICS = TryImplicitConversion(S, Init, T1, SuppressUserConversions, 4658 /*AllowExplicit=*/false, 4659 /*InOverloadResolution=*/false, 4660 /*CStyle=*/false, 4661 /*AllowObjCWritebackConversion=*/false, 4662 /*AllowObjCConversionOnExplicit=*/false); 4663 4664 // Of course, that's still a reference binding. 4665 if (ICS.isStandard()) { 4666 ICS.Standard.ReferenceBinding = true; 4667 ICS.Standard.IsLvalueReference = !isRValRef; 4668 ICS.Standard.BindsToFunctionLvalue = false; 4669 ICS.Standard.BindsToRvalue = true; 4670 ICS.Standard.BindsImplicitObjectArgumentWithoutRefQualifier = false; 4671 ICS.Standard.ObjCLifetimeConversionBinding = false; 4672 } else if (ICS.isUserDefined()) { 4673 const ReferenceType *LValRefType = 4674 ICS.UserDefined.ConversionFunction->getReturnType() 4675 ->getAs<LValueReferenceType>(); 4676 4677 // C++ [over.ics.ref]p3: 4678 // Except for an implicit object parameter, for which see 13.3.1, a 4679 // standard conversion sequence cannot be formed if it requires [...] 4680 // binding an rvalue reference to an lvalue other than a function 4681 // lvalue. 4682 // Note that the function case is not possible here. 4683 if (DeclType->isRValueReferenceType() && LValRefType) { 4684 // FIXME: This is the wrong BadConversionSequence. The problem is binding 4685 // an rvalue reference to a (non-function) lvalue, not binding an lvalue 4686 // reference to an rvalue! 4687 ICS.setBad(BadConversionSequence::lvalue_ref_to_rvalue, Init, DeclType); 4688 return ICS; 4689 } 4690 4691 ICS.UserDefined.After.ReferenceBinding = true; 4692 ICS.UserDefined.After.IsLvalueReference = !isRValRef; 4693 ICS.UserDefined.After.BindsToFunctionLvalue = false; 4694 ICS.UserDefined.After.BindsToRvalue = !LValRefType; 4695 ICS.UserDefined.After.BindsImplicitObjectArgumentWithoutRefQualifier = false; 4696 ICS.UserDefined.After.ObjCLifetimeConversionBinding = false; 4697 } 4698 4699 return ICS; 4700 } 4701 4702 static ImplicitConversionSequence 4703 TryCopyInitialization(Sema &S, Expr *From, QualType ToType, 4704 bool SuppressUserConversions, 4705 bool InOverloadResolution, 4706 bool AllowObjCWritebackConversion, 4707 bool AllowExplicit = false); 4708 4709 /// TryListConversion - Try to copy-initialize a value of type ToType from the 4710 /// initializer list From. 4711 static ImplicitConversionSequence 4712 TryListConversion(Sema &S, InitListExpr *From, QualType ToType, 4713 bool SuppressUserConversions, 4714 bool InOverloadResolution, 4715 bool AllowObjCWritebackConversion) { 4716 // C++11 [over.ics.list]p1: 4717 // When an argument is an initializer list, it is not an expression and 4718 // special rules apply for converting it to a parameter type. 4719 4720 ImplicitConversionSequence Result; 4721 Result.setBad(BadConversionSequence::no_conversion, From, ToType); 4722 4723 // We need a complete type for what follows. Incomplete types can never be 4724 // initialized from init lists. 4725 if (!S.isCompleteType(From->getLocStart(), ToType)) 4726 return Result; 4727 4728 // Per DR1467: 4729 // If the parameter type is a class X and the initializer list has a single 4730 // element of type cv U, where U is X or a class derived from X, the 4731 // implicit conversion sequence is the one required to convert the element 4732 // to the parameter type. 4733 // 4734 // Otherwise, if the parameter type is a character array [... ] 4735 // and the initializer list has a single element that is an 4736 // appropriately-typed string literal (8.5.2 [dcl.init.string]), the 4737 // implicit conversion sequence is the identity conversion. 4738 if (From->getNumInits() == 1) { 4739 if (ToType->isRecordType()) { 4740 QualType InitType = From->getInit(0)->getType(); 4741 if (S.Context.hasSameUnqualifiedType(InitType, ToType) || 4742 S.IsDerivedFrom(From->getLocStart(), InitType, ToType)) 4743 return TryCopyInitialization(S, From->getInit(0), ToType, 4744 SuppressUserConversions, 4745 InOverloadResolution, 4746 AllowObjCWritebackConversion); 4747 } 4748 // FIXME: Check the other conditions here: array of character type, 4749 // initializer is a string literal. 4750 if (ToType->isArrayType()) { 4751 InitializedEntity Entity = 4752 InitializedEntity::InitializeParameter(S.Context, ToType, 4753 /*Consumed=*/false); 4754 if (S.CanPerformCopyInitialization(Entity, From)) { 4755 Result.setStandard(); 4756 Result.Standard.setAsIdentityConversion(); 4757 Result.Standard.setFromType(ToType); 4758 Result.Standard.setAllToTypes(ToType); 4759 return Result; 4760 } 4761 } 4762 } 4763 4764 // C++14 [over.ics.list]p2: Otherwise, if the parameter type [...] (below). 4765 // C++11 [over.ics.list]p2: 4766 // If the parameter type is std::initializer_list<X> or "array of X" and 4767 // all the elements can be implicitly converted to X, the implicit 4768 // conversion sequence is the worst conversion necessary to convert an 4769 // element of the list to X. 4770 // 4771 // C++14 [over.ics.list]p3: 4772 // Otherwise, if the parameter type is "array of N X", if the initializer 4773 // list has exactly N elements or if it has fewer than N elements and X is 4774 // default-constructible, and if all the elements of the initializer list 4775 // can be implicitly converted to X, the implicit conversion sequence is 4776 // the worst conversion necessary to convert an element of the list to X. 4777 // 4778 // FIXME: We're missing a lot of these checks. 4779 bool toStdInitializerList = false; 4780 QualType X; 4781 if (ToType->isArrayType()) 4782 X = S.Context.getAsArrayType(ToType)->getElementType(); 4783 else 4784 toStdInitializerList = S.isStdInitializerList(ToType, &X); 4785 if (!X.isNull()) { 4786 for (unsigned i = 0, e = From->getNumInits(); i < e; ++i) { 4787 Expr *Init = From->getInit(i); 4788 ImplicitConversionSequence ICS = 4789 TryCopyInitialization(S, Init, X, SuppressUserConversions, 4790 InOverloadResolution, 4791 AllowObjCWritebackConversion); 4792 // If a single element isn't convertible, fail. 4793 if (ICS.isBad()) { 4794 Result = ICS; 4795 break; 4796 } 4797 // Otherwise, look for the worst conversion. 4798 if (Result.isBad() || 4799 CompareImplicitConversionSequences(S, From->getLocStart(), ICS, 4800 Result) == 4801 ImplicitConversionSequence::Worse) 4802 Result = ICS; 4803 } 4804 4805 // For an empty list, we won't have computed any conversion sequence. 4806 // Introduce the identity conversion sequence. 4807 if (From->getNumInits() == 0) { 4808 Result.setStandard(); 4809 Result.Standard.setAsIdentityConversion(); 4810 Result.Standard.setFromType(ToType); 4811 Result.Standard.setAllToTypes(ToType); 4812 } 4813 4814 Result.setStdInitializerListElement(toStdInitializerList); 4815 return Result; 4816 } 4817 4818 // C++14 [over.ics.list]p4: 4819 // C++11 [over.ics.list]p3: 4820 // Otherwise, if the parameter is a non-aggregate class X and overload 4821 // resolution chooses a single best constructor [...] the implicit 4822 // conversion sequence is a user-defined conversion sequence. If multiple 4823 // constructors are viable but none is better than the others, the 4824 // implicit conversion sequence is a user-defined conversion sequence. 4825 if (ToType->isRecordType() && !ToType->isAggregateType()) { 4826 // This function can deal with initializer lists. 4827 return TryUserDefinedConversion(S, From, ToType, SuppressUserConversions, 4828 /*AllowExplicit=*/false, 4829 InOverloadResolution, /*CStyle=*/false, 4830 AllowObjCWritebackConversion, 4831 /*AllowObjCConversionOnExplicit=*/false); 4832 } 4833 4834 // C++14 [over.ics.list]p5: 4835 // C++11 [over.ics.list]p4: 4836 // Otherwise, if the parameter has an aggregate type which can be 4837 // initialized from the initializer list [...] the implicit conversion 4838 // sequence is a user-defined conversion sequence. 4839 if (ToType->isAggregateType()) { 4840 // Type is an aggregate, argument is an init list. At this point it comes 4841 // down to checking whether the initialization works. 4842 // FIXME: Find out whether this parameter is consumed or not. 4843 // FIXME: Expose SemaInit's aggregate initialization code so that we don't 4844 // need to call into the initialization code here; overload resolution 4845 // should not be doing that. 4846 InitializedEntity Entity = 4847 InitializedEntity::InitializeParameter(S.Context, ToType, 4848 /*Consumed=*/false); 4849 if (S.CanPerformCopyInitialization(Entity, From)) { 4850 Result.setUserDefined(); 4851 Result.UserDefined.Before.setAsIdentityConversion(); 4852 // Initializer lists don't have a type. 4853 Result.UserDefined.Before.setFromType(QualType()); 4854 Result.UserDefined.Before.setAllToTypes(QualType()); 4855 4856 Result.UserDefined.After.setAsIdentityConversion(); 4857 Result.UserDefined.After.setFromType(ToType); 4858 Result.UserDefined.After.setAllToTypes(ToType); 4859 Result.UserDefined.ConversionFunction = nullptr; 4860 } 4861 return Result; 4862 } 4863 4864 // C++14 [over.ics.list]p6: 4865 // C++11 [over.ics.list]p5: 4866 // Otherwise, if the parameter is a reference, see 13.3.3.1.4. 4867 if (ToType->isReferenceType()) { 4868 // The standard is notoriously unclear here, since 13.3.3.1.4 doesn't 4869 // mention initializer lists in any way. So we go by what list- 4870 // initialization would do and try to extrapolate from that. 4871 4872 QualType T1 = ToType->getAs<ReferenceType>()->getPointeeType(); 4873 4874 // If the initializer list has a single element that is reference-related 4875 // to the parameter type, we initialize the reference from that. 4876 if (From->getNumInits() == 1) { 4877 Expr *Init = From->getInit(0); 4878 4879 QualType T2 = Init->getType(); 4880 4881 // If the initializer is the address of an overloaded function, try 4882 // to resolve the overloaded function. If all goes well, T2 is the 4883 // type of the resulting function. 4884 if (S.Context.getCanonicalType(T2) == S.Context.OverloadTy) { 4885 DeclAccessPair Found; 4886 if (FunctionDecl *Fn = S.ResolveAddressOfOverloadedFunction( 4887 Init, ToType, false, Found)) 4888 T2 = Fn->getType(); 4889 } 4890 4891 // Compute some basic properties of the types and the initializer. 4892 bool dummy1 = false; 4893 bool dummy2 = false; 4894 bool dummy3 = false; 4895 Sema::ReferenceCompareResult RefRelationship 4896 = S.CompareReferenceRelationship(From->getLocStart(), T1, T2, dummy1, 4897 dummy2, dummy3); 4898 4899 if (RefRelationship >= Sema::Ref_Related) { 4900 return TryReferenceInit(S, Init, ToType, /*FIXME*/From->getLocStart(), 4901 SuppressUserConversions, 4902 /*AllowExplicit=*/false); 4903 } 4904 } 4905 4906 // Otherwise, we bind the reference to a temporary created from the 4907 // initializer list. 4908 Result = TryListConversion(S, From, T1, SuppressUserConversions, 4909 InOverloadResolution, 4910 AllowObjCWritebackConversion); 4911 if (Result.isFailure()) 4912 return Result; 4913 assert(!Result.isEllipsis() && 4914 "Sub-initialization cannot result in ellipsis conversion."); 4915 4916 // Can we even bind to a temporary? 4917 if (ToType->isRValueReferenceType() || 4918 (T1.isConstQualified() && !T1.isVolatileQualified())) { 4919 StandardConversionSequence &SCS = Result.isStandard() ? Result.Standard : 4920 Result.UserDefined.After; 4921 SCS.ReferenceBinding = true; 4922 SCS.IsLvalueReference = ToType->isLValueReferenceType(); 4923 SCS.BindsToRvalue = true; 4924 SCS.BindsToFunctionLvalue = false; 4925 SCS.BindsImplicitObjectArgumentWithoutRefQualifier = false; 4926 SCS.ObjCLifetimeConversionBinding = false; 4927 } else 4928 Result.setBad(BadConversionSequence::lvalue_ref_to_rvalue, 4929 From, ToType); 4930 return Result; 4931 } 4932 4933 // C++14 [over.ics.list]p7: 4934 // C++11 [over.ics.list]p6: 4935 // Otherwise, if the parameter type is not a class: 4936 if (!ToType->isRecordType()) { 4937 // - if the initializer list has one element that is not itself an 4938 // initializer list, the implicit conversion sequence is the one 4939 // required to convert the element to the parameter type. 4940 unsigned NumInits = From->getNumInits(); 4941 if (NumInits == 1 && !isa<InitListExpr>(From->getInit(0))) 4942 Result = TryCopyInitialization(S, From->getInit(0), ToType, 4943 SuppressUserConversions, 4944 InOverloadResolution, 4945 AllowObjCWritebackConversion); 4946 // - if the initializer list has no elements, the implicit conversion 4947 // sequence is the identity conversion. 4948 else if (NumInits == 0) { 4949 Result.setStandard(); 4950 Result.Standard.setAsIdentityConversion(); 4951 Result.Standard.setFromType(ToType); 4952 Result.Standard.setAllToTypes(ToType); 4953 } 4954 return Result; 4955 } 4956 4957 // C++14 [over.ics.list]p8: 4958 // C++11 [over.ics.list]p7: 4959 // In all cases other than those enumerated above, no conversion is possible 4960 return Result; 4961 } 4962 4963 /// TryCopyInitialization - Try to copy-initialize a value of type 4964 /// ToType from the expression From. Return the implicit conversion 4965 /// sequence required to pass this argument, which may be a bad 4966 /// conversion sequence (meaning that the argument cannot be passed to 4967 /// a parameter of this type). If @p SuppressUserConversions, then we 4968 /// do not permit any user-defined conversion sequences. 4969 static ImplicitConversionSequence 4970 TryCopyInitialization(Sema &S, Expr *From, QualType ToType, 4971 bool SuppressUserConversions, 4972 bool InOverloadResolution, 4973 bool AllowObjCWritebackConversion, 4974 bool AllowExplicit) { 4975 if (InitListExpr *FromInitList = dyn_cast<InitListExpr>(From)) 4976 return TryListConversion(S, FromInitList, ToType, SuppressUserConversions, 4977 InOverloadResolution,AllowObjCWritebackConversion); 4978 4979 if (ToType->isReferenceType()) 4980 return TryReferenceInit(S, From, ToType, 4981 /*FIXME:*/From->getLocStart(), 4982 SuppressUserConversions, 4983 AllowExplicit); 4984 4985 return TryImplicitConversion(S, From, ToType, 4986 SuppressUserConversions, 4987 /*AllowExplicit=*/false, 4988 InOverloadResolution, 4989 /*CStyle=*/false, 4990 AllowObjCWritebackConversion, 4991 /*AllowObjCConversionOnExplicit=*/false); 4992 } 4993 4994 static bool TryCopyInitialization(const CanQualType FromQTy, 4995 const CanQualType ToQTy, 4996 Sema &S, 4997 SourceLocation Loc, 4998 ExprValueKind FromVK) { 4999 OpaqueValueExpr TmpExpr(Loc, FromQTy, FromVK); 5000 ImplicitConversionSequence ICS = 5001 TryCopyInitialization(S, &TmpExpr, ToQTy, true, true, false); 5002 5003 return !ICS.isBad(); 5004 } 5005 5006 /// TryObjectArgumentInitialization - Try to initialize the object 5007 /// parameter of the given member function (@c Method) from the 5008 /// expression @p From. 5009 static ImplicitConversionSequence 5010 TryObjectArgumentInitialization(Sema &S, SourceLocation Loc, QualType FromType, 5011 Expr::Classification FromClassification, 5012 CXXMethodDecl *Method, 5013 CXXRecordDecl *ActingContext) { 5014 QualType ClassType = S.Context.getTypeDeclType(ActingContext); 5015 // [class.dtor]p2: A destructor can be invoked for a const, volatile or 5016 // const volatile object. 5017 unsigned Quals = isa<CXXDestructorDecl>(Method) ? 5018 Qualifiers::Const | Qualifiers::Volatile : Method->getTypeQualifiers(); 5019 QualType ImplicitParamType = S.Context.getCVRQualifiedType(ClassType, Quals); 5020 5021 // Set up the conversion sequence as a "bad" conversion, to allow us 5022 // to exit early. 5023 ImplicitConversionSequence ICS; 5024 5025 // We need to have an object of class type. 5026 if (const PointerType *PT = FromType->getAs<PointerType>()) { 5027 FromType = PT->getPointeeType(); 5028 5029 // When we had a pointer, it's implicitly dereferenced, so we 5030 // better have an lvalue. 5031 assert(FromClassification.isLValue()); 5032 } 5033 5034 assert(FromType->isRecordType()); 5035 5036 // C++0x [over.match.funcs]p4: 5037 // For non-static member functions, the type of the implicit object 5038 // parameter is 5039 // 5040 // - "lvalue reference to cv X" for functions declared without a 5041 // ref-qualifier or with the & ref-qualifier 5042 // - "rvalue reference to cv X" for functions declared with the && 5043 // ref-qualifier 5044 // 5045 // where X is the class of which the function is a member and cv is the 5046 // cv-qualification on the member function declaration. 5047 // 5048 // However, when finding an implicit conversion sequence for the argument, we 5049 // are not allowed to perform user-defined conversions 5050 // (C++ [over.match.funcs]p5). We perform a simplified version of 5051 // reference binding here, that allows class rvalues to bind to 5052 // non-constant references. 5053 5054 // First check the qualifiers. 5055 QualType FromTypeCanon = S.Context.getCanonicalType(FromType); 5056 if (ImplicitParamType.getCVRQualifiers() 5057 != FromTypeCanon.getLocalCVRQualifiers() && 5058 !ImplicitParamType.isAtLeastAsQualifiedAs(FromTypeCanon)) { 5059 ICS.setBad(BadConversionSequence::bad_qualifiers, 5060 FromType, ImplicitParamType); 5061 return ICS; 5062 } 5063 5064 // Check that we have either the same type or a derived type. It 5065 // affects the conversion rank. 5066 QualType ClassTypeCanon = S.Context.getCanonicalType(ClassType); 5067 ImplicitConversionKind SecondKind; 5068 if (ClassTypeCanon == FromTypeCanon.getLocalUnqualifiedType()) { 5069 SecondKind = ICK_Identity; 5070 } else if (S.IsDerivedFrom(Loc, FromType, ClassType)) 5071 SecondKind = ICK_Derived_To_Base; 5072 else { 5073 ICS.setBad(BadConversionSequence::unrelated_class, 5074 FromType, ImplicitParamType); 5075 return ICS; 5076 } 5077 5078 // Check the ref-qualifier. 5079 switch (Method->getRefQualifier()) { 5080 case RQ_None: 5081 // Do nothing; we don't care about lvalueness or rvalueness. 5082 break; 5083 5084 case RQ_LValue: 5085 if (!FromClassification.isLValue() && Quals != Qualifiers::Const) { 5086 // non-const lvalue reference cannot bind to an rvalue 5087 ICS.setBad(BadConversionSequence::lvalue_ref_to_rvalue, FromType, 5088 ImplicitParamType); 5089 return ICS; 5090 } 5091 break; 5092 5093 case RQ_RValue: 5094 if (!FromClassification.isRValue()) { 5095 // rvalue reference cannot bind to an lvalue 5096 ICS.setBad(BadConversionSequence::rvalue_ref_to_lvalue, FromType, 5097 ImplicitParamType); 5098 return ICS; 5099 } 5100 break; 5101 } 5102 5103 // Success. Mark this as a reference binding. 5104 ICS.setStandard(); 5105 ICS.Standard.setAsIdentityConversion(); 5106 ICS.Standard.Second = SecondKind; 5107 ICS.Standard.setFromType(FromType); 5108 ICS.Standard.setAllToTypes(ImplicitParamType); 5109 ICS.Standard.ReferenceBinding = true; 5110 ICS.Standard.DirectBinding = true; 5111 ICS.Standard.IsLvalueReference = Method->getRefQualifier() != RQ_RValue; 5112 ICS.Standard.BindsToFunctionLvalue = false; 5113 ICS.Standard.BindsToRvalue = FromClassification.isRValue(); 5114 ICS.Standard.BindsImplicitObjectArgumentWithoutRefQualifier 5115 = (Method->getRefQualifier() == RQ_None); 5116 return ICS; 5117 } 5118 5119 /// PerformObjectArgumentInitialization - Perform initialization of 5120 /// the implicit object parameter for the given Method with the given 5121 /// expression. 5122 ExprResult 5123 Sema::PerformObjectArgumentInitialization(Expr *From, 5124 NestedNameSpecifier *Qualifier, 5125 NamedDecl *FoundDecl, 5126 CXXMethodDecl *Method) { 5127 QualType FromRecordType, DestType; 5128 QualType ImplicitParamRecordType = 5129 Method->getThisType(Context)->getAs<PointerType>()->getPointeeType(); 5130 5131 Expr::Classification FromClassification; 5132 if (const PointerType *PT = From->getType()->getAs<PointerType>()) { 5133 FromRecordType = PT->getPointeeType(); 5134 DestType = Method->getThisType(Context); 5135 FromClassification = Expr::Classification::makeSimpleLValue(); 5136 } else { 5137 FromRecordType = From->getType(); 5138 DestType = ImplicitParamRecordType; 5139 FromClassification = From->Classify(Context); 5140 } 5141 5142 // Note that we always use the true parent context when performing 5143 // the actual argument initialization. 5144 ImplicitConversionSequence ICS = TryObjectArgumentInitialization( 5145 *this, From->getLocStart(), From->getType(), FromClassification, Method, 5146 Method->getParent()); 5147 if (ICS.isBad()) { 5148 if (ICS.Bad.Kind == BadConversionSequence::bad_qualifiers) { 5149 Qualifiers FromQs = FromRecordType.getQualifiers(); 5150 Qualifiers ToQs = DestType.getQualifiers(); 5151 unsigned CVR = FromQs.getCVRQualifiers() & ~ToQs.getCVRQualifiers(); 5152 if (CVR) { 5153 Diag(From->getLocStart(), 5154 diag::err_member_function_call_bad_cvr) 5155 << Method->getDeclName() << FromRecordType << (CVR - 1) 5156 << From->getSourceRange(); 5157 Diag(Method->getLocation(), diag::note_previous_decl) 5158 << Method->getDeclName(); 5159 return ExprError(); 5160 } 5161 } 5162 5163 return Diag(From->getLocStart(), 5164 diag::err_implicit_object_parameter_init) 5165 << ImplicitParamRecordType << FromRecordType << From->getSourceRange(); 5166 } 5167 5168 if (ICS.Standard.Second == ICK_Derived_To_Base) { 5169 ExprResult FromRes = 5170 PerformObjectMemberConversion(From, Qualifier, FoundDecl, Method); 5171 if (FromRes.isInvalid()) 5172 return ExprError(); 5173 From = FromRes.get(); 5174 } 5175 5176 if (!Context.hasSameType(From->getType(), DestType)) 5177 From = ImpCastExprToType(From, DestType, CK_NoOp, 5178 From->getValueKind()).get(); 5179 return From; 5180 } 5181 5182 /// TryContextuallyConvertToBool - Attempt to contextually convert the 5183 /// expression From to bool (C++0x [conv]p3). 5184 static ImplicitConversionSequence 5185 TryContextuallyConvertToBool(Sema &S, Expr *From) { 5186 return TryImplicitConversion(S, From, S.Context.BoolTy, 5187 /*SuppressUserConversions=*/false, 5188 /*AllowExplicit=*/true, 5189 /*InOverloadResolution=*/false, 5190 /*CStyle=*/false, 5191 /*AllowObjCWritebackConversion=*/false, 5192 /*AllowObjCConversionOnExplicit=*/false); 5193 } 5194 5195 /// PerformContextuallyConvertToBool - Perform a contextual conversion 5196 /// of the expression From to bool (C++0x [conv]p3). 5197 ExprResult Sema::PerformContextuallyConvertToBool(Expr *From) { 5198 if (checkPlaceholderForOverload(*this, From)) 5199 return ExprError(); 5200 5201 ImplicitConversionSequence ICS = TryContextuallyConvertToBool(*this, From); 5202 if (!ICS.isBad()) 5203 return PerformImplicitConversion(From, Context.BoolTy, ICS, AA_Converting); 5204 5205 if (!DiagnoseMultipleUserDefinedConversion(From, Context.BoolTy)) 5206 return Diag(From->getLocStart(), 5207 diag::err_typecheck_bool_condition) 5208 << From->getType() << From->getSourceRange(); 5209 return ExprError(); 5210 } 5211 5212 /// Check that the specified conversion is permitted in a converted constant 5213 /// expression, according to C++11 [expr.const]p3. Return true if the conversion 5214 /// is acceptable. 5215 static bool CheckConvertedConstantConversions(Sema &S, 5216 StandardConversionSequence &SCS) { 5217 // Since we know that the target type is an integral or unscoped enumeration 5218 // type, most conversion kinds are impossible. All possible First and Third 5219 // conversions are fine. 5220 switch (SCS.Second) { 5221 case ICK_Identity: 5222 case ICK_Function_Conversion: 5223 case ICK_Integral_Promotion: 5224 case ICK_Integral_Conversion: // Narrowing conversions are checked elsewhere. 5225 case ICK_Zero_Queue_Conversion: 5226 return true; 5227 5228 case ICK_Boolean_Conversion: 5229 // Conversion from an integral or unscoped enumeration type to bool is 5230 // classified as ICK_Boolean_Conversion, but it's also arguably an integral 5231 // conversion, so we allow it in a converted constant expression. 5232 // 5233 // FIXME: Per core issue 1407, we should not allow this, but that breaks 5234 // a lot of popular code. We should at least add a warning for this 5235 // (non-conforming) extension. 5236 return SCS.getFromType()->isIntegralOrUnscopedEnumerationType() && 5237 SCS.getToType(2)->isBooleanType(); 5238 5239 case ICK_Pointer_Conversion: 5240 case ICK_Pointer_Member: 5241 // C++1z: null pointer conversions and null member pointer conversions are 5242 // only permitted if the source type is std::nullptr_t. 5243 return SCS.getFromType()->isNullPtrType(); 5244 5245 case ICK_Floating_Promotion: 5246 case ICK_Complex_Promotion: 5247 case ICK_Floating_Conversion: 5248 case ICK_Complex_Conversion: 5249 case ICK_Floating_Integral: 5250 case ICK_Compatible_Conversion: 5251 case ICK_Derived_To_Base: 5252 case ICK_Vector_Conversion: 5253 case ICK_Vector_Splat: 5254 case ICK_Complex_Real: 5255 case ICK_Block_Pointer_Conversion: 5256 case ICK_TransparentUnionConversion: 5257 case ICK_Writeback_Conversion: 5258 case ICK_Zero_Event_Conversion: 5259 case ICK_C_Only_Conversion: 5260 case ICK_Incompatible_Pointer_Conversion: 5261 return false; 5262 5263 case ICK_Lvalue_To_Rvalue: 5264 case ICK_Array_To_Pointer: 5265 case ICK_Function_To_Pointer: 5266 llvm_unreachable("found a first conversion kind in Second"); 5267 5268 case ICK_Qualification: 5269 llvm_unreachable("found a third conversion kind in Second"); 5270 5271 case ICK_Num_Conversion_Kinds: 5272 break; 5273 } 5274 5275 llvm_unreachable("unknown conversion kind"); 5276 } 5277 5278 /// CheckConvertedConstantExpression - Check that the expression From is a 5279 /// converted constant expression of type T, perform the conversion and produce 5280 /// the converted expression, per C++11 [expr.const]p3. 5281 static ExprResult CheckConvertedConstantExpression(Sema &S, Expr *From, 5282 QualType T, APValue &Value, 5283 Sema::CCEKind CCE, 5284 bool RequireInt) { 5285 assert(S.getLangOpts().CPlusPlus11 && 5286 "converted constant expression outside C++11"); 5287 5288 if (checkPlaceholderForOverload(S, From)) 5289 return ExprError(); 5290 5291 // C++1z [expr.const]p3: 5292 // A converted constant expression of type T is an expression, 5293 // implicitly converted to type T, where the converted 5294 // expression is a constant expression and the implicit conversion 5295 // sequence contains only [... list of conversions ...]. 5296 // C++1z [stmt.if]p2: 5297 // If the if statement is of the form if constexpr, the value of the 5298 // condition shall be a contextually converted constant expression of type 5299 // bool. 5300 ImplicitConversionSequence ICS = 5301 CCE == Sema::CCEK_ConstexprIf 5302 ? TryContextuallyConvertToBool(S, From) 5303 : TryCopyInitialization(S, From, T, 5304 /*SuppressUserConversions=*/false, 5305 /*InOverloadResolution=*/false, 5306 /*AllowObjcWritebackConversion=*/false, 5307 /*AllowExplicit=*/false); 5308 StandardConversionSequence *SCS = nullptr; 5309 switch (ICS.getKind()) { 5310 case ImplicitConversionSequence::StandardConversion: 5311 SCS = &ICS.Standard; 5312 break; 5313 case ImplicitConversionSequence::UserDefinedConversion: 5314 // We are converting to a non-class type, so the Before sequence 5315 // must be trivial. 5316 SCS = &ICS.UserDefined.After; 5317 break; 5318 case ImplicitConversionSequence::AmbiguousConversion: 5319 case ImplicitConversionSequence::BadConversion: 5320 if (!S.DiagnoseMultipleUserDefinedConversion(From, T)) 5321 return S.Diag(From->getLocStart(), 5322 diag::err_typecheck_converted_constant_expression) 5323 << From->getType() << From->getSourceRange() << T; 5324 return ExprError(); 5325 5326 case ImplicitConversionSequence::EllipsisConversion: 5327 llvm_unreachable("ellipsis conversion in converted constant expression"); 5328 } 5329 5330 // Check that we would only use permitted conversions. 5331 if (!CheckConvertedConstantConversions(S, *SCS)) { 5332 return S.Diag(From->getLocStart(), 5333 diag::err_typecheck_converted_constant_expression_disallowed) 5334 << From->getType() << From->getSourceRange() << T; 5335 } 5336 // [...] and where the reference binding (if any) binds directly. 5337 if (SCS->ReferenceBinding && !SCS->DirectBinding) { 5338 return S.Diag(From->getLocStart(), 5339 diag::err_typecheck_converted_constant_expression_indirect) 5340 << From->getType() << From->getSourceRange() << T; 5341 } 5342 5343 ExprResult Result = 5344 S.PerformImplicitConversion(From, T, ICS, Sema::AA_Converting); 5345 if (Result.isInvalid()) 5346 return Result; 5347 5348 // Check for a narrowing implicit conversion. 5349 APValue PreNarrowingValue; 5350 QualType PreNarrowingType; 5351 switch (SCS->getNarrowingKind(S.Context, Result.get(), PreNarrowingValue, 5352 PreNarrowingType)) { 5353 case NK_Dependent_Narrowing: 5354 // Implicit conversion to a narrower type, but the expression is 5355 // value-dependent so we can't tell whether it's actually narrowing. 5356 case NK_Variable_Narrowing: 5357 // Implicit conversion to a narrower type, and the value is not a constant 5358 // expression. We'll diagnose this in a moment. 5359 case NK_Not_Narrowing: 5360 break; 5361 5362 case NK_Constant_Narrowing: 5363 S.Diag(From->getLocStart(), diag::ext_cce_narrowing) 5364 << CCE << /*Constant*/1 5365 << PreNarrowingValue.getAsString(S.Context, PreNarrowingType) << T; 5366 break; 5367 5368 case NK_Type_Narrowing: 5369 S.Diag(From->getLocStart(), diag::ext_cce_narrowing) 5370 << CCE << /*Constant*/0 << From->getType() << T; 5371 break; 5372 } 5373 5374 if (Result.get()->isValueDependent()) { 5375 Value = APValue(); 5376 return Result; 5377 } 5378 5379 // Check the expression is a constant expression. 5380 SmallVector<PartialDiagnosticAt, 8> Notes; 5381 Expr::EvalResult Eval; 5382 Eval.Diag = &Notes; 5383 5384 if ((T->isReferenceType() 5385 ? !Result.get()->EvaluateAsLValue(Eval, S.Context) 5386 : !Result.get()->EvaluateAsRValue(Eval, S.Context)) || 5387 (RequireInt && !Eval.Val.isInt())) { 5388 // The expression can't be folded, so we can't keep it at this position in 5389 // the AST. 5390 Result = ExprError(); 5391 } else { 5392 Value = Eval.Val; 5393 5394 if (Notes.empty()) { 5395 // It's a constant expression. 5396 return Result; 5397 } 5398 } 5399 5400 // It's not a constant expression. Produce an appropriate diagnostic. 5401 if (Notes.size() == 1 && 5402 Notes[0].second.getDiagID() == diag::note_invalid_subexpr_in_const_expr) 5403 S.Diag(Notes[0].first, diag::err_expr_not_cce) << CCE; 5404 else { 5405 S.Diag(From->getLocStart(), diag::err_expr_not_cce) 5406 << CCE << From->getSourceRange(); 5407 for (unsigned I = 0; I < Notes.size(); ++I) 5408 S.Diag(Notes[I].first, Notes[I].second); 5409 } 5410 return ExprError(); 5411 } 5412 5413 ExprResult Sema::CheckConvertedConstantExpression(Expr *From, QualType T, 5414 APValue &Value, CCEKind CCE) { 5415 return ::CheckConvertedConstantExpression(*this, From, T, Value, CCE, false); 5416 } 5417 5418 ExprResult Sema::CheckConvertedConstantExpression(Expr *From, QualType T, 5419 llvm::APSInt &Value, 5420 CCEKind CCE) { 5421 assert(T->isIntegralOrEnumerationType() && "unexpected converted const type"); 5422 5423 APValue V; 5424 auto R = ::CheckConvertedConstantExpression(*this, From, T, V, CCE, true); 5425 if (!R.isInvalid() && !R.get()->isValueDependent()) 5426 Value = V.getInt(); 5427 return R; 5428 } 5429 5430 5431 /// dropPointerConversions - If the given standard conversion sequence 5432 /// involves any pointer conversions, remove them. This may change 5433 /// the result type of the conversion sequence. 5434 static void dropPointerConversion(StandardConversionSequence &SCS) { 5435 if (SCS.Second == ICK_Pointer_Conversion) { 5436 SCS.Second = ICK_Identity; 5437 SCS.Third = ICK_Identity; 5438 SCS.ToTypePtrs[2] = SCS.ToTypePtrs[1] = SCS.ToTypePtrs[0]; 5439 } 5440 } 5441 5442 /// TryContextuallyConvertToObjCPointer - Attempt to contextually 5443 /// convert the expression From to an Objective-C pointer type. 5444 static ImplicitConversionSequence 5445 TryContextuallyConvertToObjCPointer(Sema &S, Expr *From) { 5446 // Do an implicit conversion to 'id'. 5447 QualType Ty = S.Context.getObjCIdType(); 5448 ImplicitConversionSequence ICS 5449 = TryImplicitConversion(S, From, Ty, 5450 // FIXME: Are these flags correct? 5451 /*SuppressUserConversions=*/false, 5452 /*AllowExplicit=*/true, 5453 /*InOverloadResolution=*/false, 5454 /*CStyle=*/false, 5455 /*AllowObjCWritebackConversion=*/false, 5456 /*AllowObjCConversionOnExplicit=*/true); 5457 5458 // Strip off any final conversions to 'id'. 5459 switch (ICS.getKind()) { 5460 case ImplicitConversionSequence::BadConversion: 5461 case ImplicitConversionSequence::AmbiguousConversion: 5462 case ImplicitConversionSequence::EllipsisConversion: 5463 break; 5464 5465 case ImplicitConversionSequence::UserDefinedConversion: 5466 dropPointerConversion(ICS.UserDefined.After); 5467 break; 5468 5469 case ImplicitConversionSequence::StandardConversion: 5470 dropPointerConversion(ICS.Standard); 5471 break; 5472 } 5473 5474 return ICS; 5475 } 5476 5477 /// PerformContextuallyConvertToObjCPointer - Perform a contextual 5478 /// conversion of the expression From to an Objective-C pointer type. 5479 /// Returns a valid but null ExprResult if no conversion sequence exists. 5480 ExprResult Sema::PerformContextuallyConvertToObjCPointer(Expr *From) { 5481 if (checkPlaceholderForOverload(*this, From)) 5482 return ExprError(); 5483 5484 QualType Ty = Context.getObjCIdType(); 5485 ImplicitConversionSequence ICS = 5486 TryContextuallyConvertToObjCPointer(*this, From); 5487 if (!ICS.isBad()) 5488 return PerformImplicitConversion(From, Ty, ICS, AA_Converting); 5489 return ExprResult(); 5490 } 5491 5492 /// Determine whether the provided type is an integral type, or an enumeration 5493 /// type of a permitted flavor. 5494 bool Sema::ICEConvertDiagnoser::match(QualType T) { 5495 return AllowScopedEnumerations ? T->isIntegralOrEnumerationType() 5496 : T->isIntegralOrUnscopedEnumerationType(); 5497 } 5498 5499 static ExprResult 5500 diagnoseAmbiguousConversion(Sema &SemaRef, SourceLocation Loc, Expr *From, 5501 Sema::ContextualImplicitConverter &Converter, 5502 QualType T, UnresolvedSetImpl &ViableConversions) { 5503 5504 if (Converter.Suppress) 5505 return ExprError(); 5506 5507 Converter.diagnoseAmbiguous(SemaRef, Loc, T) << From->getSourceRange(); 5508 for (unsigned I = 0, N = ViableConversions.size(); I != N; ++I) { 5509 CXXConversionDecl *Conv = 5510 cast<CXXConversionDecl>(ViableConversions[I]->getUnderlyingDecl()); 5511 QualType ConvTy = Conv->getConversionType().getNonReferenceType(); 5512 Converter.noteAmbiguous(SemaRef, Conv, ConvTy); 5513 } 5514 return From; 5515 } 5516 5517 static bool 5518 diagnoseNoViableConversion(Sema &SemaRef, SourceLocation Loc, Expr *&From, 5519 Sema::ContextualImplicitConverter &Converter, 5520 QualType T, bool HadMultipleCandidates, 5521 UnresolvedSetImpl &ExplicitConversions) { 5522 if (ExplicitConversions.size() == 1 && !Converter.Suppress) { 5523 DeclAccessPair Found = ExplicitConversions[0]; 5524 CXXConversionDecl *Conversion = 5525 cast<CXXConversionDecl>(Found->getUnderlyingDecl()); 5526 5527 // The user probably meant to invoke the given explicit 5528 // conversion; use it. 5529 QualType ConvTy = Conversion->getConversionType().getNonReferenceType(); 5530 std::string TypeStr; 5531 ConvTy.getAsStringInternal(TypeStr, SemaRef.getPrintingPolicy()); 5532 5533 Converter.diagnoseExplicitConv(SemaRef, Loc, T, ConvTy) 5534 << FixItHint::CreateInsertion(From->getLocStart(), 5535 "static_cast<" + TypeStr + ">(") 5536 << FixItHint::CreateInsertion( 5537 SemaRef.getLocForEndOfToken(From->getLocEnd()), ")"); 5538 Converter.noteExplicitConv(SemaRef, Conversion, ConvTy); 5539 5540 // If we aren't in a SFINAE context, build a call to the 5541 // explicit conversion function. 5542 if (SemaRef.isSFINAEContext()) 5543 return true; 5544 5545 SemaRef.CheckMemberOperatorAccess(From->getExprLoc(), From, nullptr, Found); 5546 ExprResult Result = SemaRef.BuildCXXMemberCallExpr(From, Found, Conversion, 5547 HadMultipleCandidates); 5548 if (Result.isInvalid()) 5549 return true; 5550 // Record usage of conversion in an implicit cast. 5551 From = ImplicitCastExpr::Create(SemaRef.Context, Result.get()->getType(), 5552 CK_UserDefinedConversion, Result.get(), 5553 nullptr, Result.get()->getValueKind()); 5554 } 5555 return false; 5556 } 5557 5558 static bool recordConversion(Sema &SemaRef, SourceLocation Loc, Expr *&From, 5559 Sema::ContextualImplicitConverter &Converter, 5560 QualType T, bool HadMultipleCandidates, 5561 DeclAccessPair &Found) { 5562 CXXConversionDecl *Conversion = 5563 cast<CXXConversionDecl>(Found->getUnderlyingDecl()); 5564 SemaRef.CheckMemberOperatorAccess(From->getExprLoc(), From, nullptr, Found); 5565 5566 QualType ToType = Conversion->getConversionType().getNonReferenceType(); 5567 if (!Converter.SuppressConversion) { 5568 if (SemaRef.isSFINAEContext()) 5569 return true; 5570 5571 Converter.diagnoseConversion(SemaRef, Loc, T, ToType) 5572 << From->getSourceRange(); 5573 } 5574 5575 ExprResult Result = SemaRef.BuildCXXMemberCallExpr(From, Found, Conversion, 5576 HadMultipleCandidates); 5577 if (Result.isInvalid()) 5578 return true; 5579 // Record usage of conversion in an implicit cast. 5580 From = ImplicitCastExpr::Create(SemaRef.Context, Result.get()->getType(), 5581 CK_UserDefinedConversion, Result.get(), 5582 nullptr, Result.get()->getValueKind()); 5583 return false; 5584 } 5585 5586 static ExprResult finishContextualImplicitConversion( 5587 Sema &SemaRef, SourceLocation Loc, Expr *From, 5588 Sema::ContextualImplicitConverter &Converter) { 5589 if (!Converter.match(From->getType()) && !Converter.Suppress) 5590 Converter.diagnoseNoMatch(SemaRef, Loc, From->getType()) 5591 << From->getSourceRange(); 5592 5593 return SemaRef.DefaultLvalueConversion(From); 5594 } 5595 5596 static void 5597 collectViableConversionCandidates(Sema &SemaRef, Expr *From, QualType ToType, 5598 UnresolvedSetImpl &ViableConversions, 5599 OverloadCandidateSet &CandidateSet) { 5600 for (unsigned I = 0, N = ViableConversions.size(); I != N; ++I) { 5601 DeclAccessPair FoundDecl = ViableConversions[I]; 5602 NamedDecl *D = FoundDecl.getDecl(); 5603 CXXRecordDecl *ActingContext = cast<CXXRecordDecl>(D->getDeclContext()); 5604 if (isa<UsingShadowDecl>(D)) 5605 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 5606 5607 CXXConversionDecl *Conv; 5608 FunctionTemplateDecl *ConvTemplate; 5609 if ((ConvTemplate = dyn_cast<FunctionTemplateDecl>(D))) 5610 Conv = cast<CXXConversionDecl>(ConvTemplate->getTemplatedDecl()); 5611 else 5612 Conv = cast<CXXConversionDecl>(D); 5613 5614 if (ConvTemplate) 5615 SemaRef.AddTemplateConversionCandidate( 5616 ConvTemplate, FoundDecl, ActingContext, From, ToType, CandidateSet, 5617 /*AllowObjCConversionOnExplicit=*/false); 5618 else 5619 SemaRef.AddConversionCandidate(Conv, FoundDecl, ActingContext, From, 5620 ToType, CandidateSet, 5621 /*AllowObjCConversionOnExplicit=*/false); 5622 } 5623 } 5624 5625 /// \brief Attempt to convert the given expression to a type which is accepted 5626 /// by the given converter. 5627 /// 5628 /// This routine will attempt to convert an expression of class type to a 5629 /// type accepted by the specified converter. In C++11 and before, the class 5630 /// must have a single non-explicit conversion function converting to a matching 5631 /// type. In C++1y, there can be multiple such conversion functions, but only 5632 /// one target type. 5633 /// 5634 /// \param Loc The source location of the construct that requires the 5635 /// conversion. 5636 /// 5637 /// \param From The expression we're converting from. 5638 /// 5639 /// \param Converter Used to control and diagnose the conversion process. 5640 /// 5641 /// \returns The expression, converted to an integral or enumeration type if 5642 /// successful. 5643 ExprResult Sema::PerformContextualImplicitConversion( 5644 SourceLocation Loc, Expr *From, ContextualImplicitConverter &Converter) { 5645 // We can't perform any more checking for type-dependent expressions. 5646 if (From->isTypeDependent()) 5647 return From; 5648 5649 // Process placeholders immediately. 5650 if (From->hasPlaceholderType()) { 5651 ExprResult result = CheckPlaceholderExpr(From); 5652 if (result.isInvalid()) 5653 return result; 5654 From = result.get(); 5655 } 5656 5657 // If the expression already has a matching type, we're golden. 5658 QualType T = From->getType(); 5659 if (Converter.match(T)) 5660 return DefaultLvalueConversion(From); 5661 5662 // FIXME: Check for missing '()' if T is a function type? 5663 5664 // We can only perform contextual implicit conversions on objects of class 5665 // type. 5666 const RecordType *RecordTy = T->getAs<RecordType>(); 5667 if (!RecordTy || !getLangOpts().CPlusPlus) { 5668 if (!Converter.Suppress) 5669 Converter.diagnoseNoMatch(*this, Loc, T) << From->getSourceRange(); 5670 return From; 5671 } 5672 5673 // We must have a complete class type. 5674 struct TypeDiagnoserPartialDiag : TypeDiagnoser { 5675 ContextualImplicitConverter &Converter; 5676 Expr *From; 5677 5678 TypeDiagnoserPartialDiag(ContextualImplicitConverter &Converter, Expr *From) 5679 : Converter(Converter), From(From) {} 5680 5681 void diagnose(Sema &S, SourceLocation Loc, QualType T) override { 5682 Converter.diagnoseIncomplete(S, Loc, T) << From->getSourceRange(); 5683 } 5684 } IncompleteDiagnoser(Converter, From); 5685 5686 if (Converter.Suppress ? !isCompleteType(Loc, T) 5687 : RequireCompleteType(Loc, T, IncompleteDiagnoser)) 5688 return From; 5689 5690 // Look for a conversion to an integral or enumeration type. 5691 UnresolvedSet<4> 5692 ViableConversions; // These are *potentially* viable in C++1y. 5693 UnresolvedSet<4> ExplicitConversions; 5694 const auto &Conversions = 5695 cast<CXXRecordDecl>(RecordTy->getDecl())->getVisibleConversionFunctions(); 5696 5697 bool HadMultipleCandidates = 5698 (std::distance(Conversions.begin(), Conversions.end()) > 1); 5699 5700 // To check that there is only one target type, in C++1y: 5701 QualType ToType; 5702 bool HasUniqueTargetType = true; 5703 5704 // Collect explicit or viable (potentially in C++1y) conversions. 5705 for (auto I = Conversions.begin(), E = Conversions.end(); I != E; ++I) { 5706 NamedDecl *D = (*I)->getUnderlyingDecl(); 5707 CXXConversionDecl *Conversion; 5708 FunctionTemplateDecl *ConvTemplate = dyn_cast<FunctionTemplateDecl>(D); 5709 if (ConvTemplate) { 5710 if (getLangOpts().CPlusPlus14) 5711 Conversion = cast<CXXConversionDecl>(ConvTemplate->getTemplatedDecl()); 5712 else 5713 continue; // C++11 does not consider conversion operator templates(?). 5714 } else 5715 Conversion = cast<CXXConversionDecl>(D); 5716 5717 assert((!ConvTemplate || getLangOpts().CPlusPlus14) && 5718 "Conversion operator templates are considered potentially " 5719 "viable in C++1y"); 5720 5721 QualType CurToType = Conversion->getConversionType().getNonReferenceType(); 5722 if (Converter.match(CurToType) || ConvTemplate) { 5723 5724 if (Conversion->isExplicit()) { 5725 // FIXME: For C++1y, do we need this restriction? 5726 // cf. diagnoseNoViableConversion() 5727 if (!ConvTemplate) 5728 ExplicitConversions.addDecl(I.getDecl(), I.getAccess()); 5729 } else { 5730 if (!ConvTemplate && getLangOpts().CPlusPlus14) { 5731 if (ToType.isNull()) 5732 ToType = CurToType.getUnqualifiedType(); 5733 else if (HasUniqueTargetType && 5734 (CurToType.getUnqualifiedType() != ToType)) 5735 HasUniqueTargetType = false; 5736 } 5737 ViableConversions.addDecl(I.getDecl(), I.getAccess()); 5738 } 5739 } 5740 } 5741 5742 if (getLangOpts().CPlusPlus14) { 5743 // C++1y [conv]p6: 5744 // ... An expression e of class type E appearing in such a context 5745 // is said to be contextually implicitly converted to a specified 5746 // type T and is well-formed if and only if e can be implicitly 5747 // converted to a type T that is determined as follows: E is searched 5748 // for conversion functions whose return type is cv T or reference to 5749 // cv T such that T is allowed by the context. There shall be 5750 // exactly one such T. 5751 5752 // If no unique T is found: 5753 if (ToType.isNull()) { 5754 if (diagnoseNoViableConversion(*this, Loc, From, Converter, T, 5755 HadMultipleCandidates, 5756 ExplicitConversions)) 5757 return ExprError(); 5758 return finishContextualImplicitConversion(*this, Loc, From, Converter); 5759 } 5760 5761 // If more than one unique Ts are found: 5762 if (!HasUniqueTargetType) 5763 return diagnoseAmbiguousConversion(*this, Loc, From, Converter, T, 5764 ViableConversions); 5765 5766 // If one unique T is found: 5767 // First, build a candidate set from the previously recorded 5768 // potentially viable conversions. 5769 OverloadCandidateSet CandidateSet(Loc, OverloadCandidateSet::CSK_Normal); 5770 collectViableConversionCandidates(*this, From, ToType, ViableConversions, 5771 CandidateSet); 5772 5773 // Then, perform overload resolution over the candidate set. 5774 OverloadCandidateSet::iterator Best; 5775 switch (CandidateSet.BestViableFunction(*this, Loc, Best)) { 5776 case OR_Success: { 5777 // Apply this conversion. 5778 DeclAccessPair Found = 5779 DeclAccessPair::make(Best->Function, Best->FoundDecl.getAccess()); 5780 if (recordConversion(*this, Loc, From, Converter, T, 5781 HadMultipleCandidates, Found)) 5782 return ExprError(); 5783 break; 5784 } 5785 case OR_Ambiguous: 5786 return diagnoseAmbiguousConversion(*this, Loc, From, Converter, T, 5787 ViableConversions); 5788 case OR_No_Viable_Function: 5789 if (diagnoseNoViableConversion(*this, Loc, From, Converter, T, 5790 HadMultipleCandidates, 5791 ExplicitConversions)) 5792 return ExprError(); 5793 // fall through 'OR_Deleted' case. 5794 case OR_Deleted: 5795 // We'll complain below about a non-integral condition type. 5796 break; 5797 } 5798 } else { 5799 switch (ViableConversions.size()) { 5800 case 0: { 5801 if (diagnoseNoViableConversion(*this, Loc, From, Converter, T, 5802 HadMultipleCandidates, 5803 ExplicitConversions)) 5804 return ExprError(); 5805 5806 // We'll complain below about a non-integral condition type. 5807 break; 5808 } 5809 case 1: { 5810 // Apply this conversion. 5811 DeclAccessPair Found = ViableConversions[0]; 5812 if (recordConversion(*this, Loc, From, Converter, T, 5813 HadMultipleCandidates, Found)) 5814 return ExprError(); 5815 break; 5816 } 5817 default: 5818 return diagnoseAmbiguousConversion(*this, Loc, From, Converter, T, 5819 ViableConversions); 5820 } 5821 } 5822 5823 return finishContextualImplicitConversion(*this, Loc, From, Converter); 5824 } 5825 5826 /// IsAcceptableNonMemberOperatorCandidate - Determine whether Fn is 5827 /// an acceptable non-member overloaded operator for a call whose 5828 /// arguments have types T1 (and, if non-empty, T2). This routine 5829 /// implements the check in C++ [over.match.oper]p3b2 concerning 5830 /// enumeration types. 5831 static bool IsAcceptableNonMemberOperatorCandidate(ASTContext &Context, 5832 FunctionDecl *Fn, 5833 ArrayRef<Expr *> Args) { 5834 QualType T1 = Args[0]->getType(); 5835 QualType T2 = Args.size() > 1 ? Args[1]->getType() : QualType(); 5836 5837 if (T1->isDependentType() || (!T2.isNull() && T2->isDependentType())) 5838 return true; 5839 5840 if (T1->isRecordType() || (!T2.isNull() && T2->isRecordType())) 5841 return true; 5842 5843 const FunctionProtoType *Proto = Fn->getType()->getAs<FunctionProtoType>(); 5844 if (Proto->getNumParams() < 1) 5845 return false; 5846 5847 if (T1->isEnumeralType()) { 5848 QualType ArgType = Proto->getParamType(0).getNonReferenceType(); 5849 if (Context.hasSameUnqualifiedType(T1, ArgType)) 5850 return true; 5851 } 5852 5853 if (Proto->getNumParams() < 2) 5854 return false; 5855 5856 if (!T2.isNull() && T2->isEnumeralType()) { 5857 QualType ArgType = Proto->getParamType(1).getNonReferenceType(); 5858 if (Context.hasSameUnqualifiedType(T2, ArgType)) 5859 return true; 5860 } 5861 5862 return false; 5863 } 5864 5865 /// AddOverloadCandidate - Adds the given function to the set of 5866 /// candidate functions, using the given function call arguments. If 5867 /// @p SuppressUserConversions, then don't allow user-defined 5868 /// conversions via constructors or conversion operators. 5869 /// 5870 /// \param PartialOverloading true if we are performing "partial" overloading 5871 /// based on an incomplete set of function arguments. This feature is used by 5872 /// code completion. 5873 void 5874 Sema::AddOverloadCandidate(FunctionDecl *Function, 5875 DeclAccessPair FoundDecl, 5876 ArrayRef<Expr *> Args, 5877 OverloadCandidateSet &CandidateSet, 5878 bool SuppressUserConversions, 5879 bool PartialOverloading, 5880 bool AllowExplicit, 5881 ConversionSequenceList EarlyConversions) { 5882 const FunctionProtoType *Proto 5883 = dyn_cast<FunctionProtoType>(Function->getType()->getAs<FunctionType>()); 5884 assert(Proto && "Functions without a prototype cannot be overloaded"); 5885 assert(!Function->getDescribedFunctionTemplate() && 5886 "Use AddTemplateOverloadCandidate for function templates"); 5887 5888 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Function)) { 5889 if (!isa<CXXConstructorDecl>(Method)) { 5890 // If we get here, it's because we're calling a member function 5891 // that is named without a member access expression (e.g., 5892 // "this->f") that was either written explicitly or created 5893 // implicitly. This can happen with a qualified call to a member 5894 // function, e.g., X::f(). We use an empty type for the implied 5895 // object argument (C++ [over.call.func]p3), and the acting context 5896 // is irrelevant. 5897 AddMethodCandidate(Method, FoundDecl, Method->getParent(), QualType(), 5898 Expr::Classification::makeSimpleLValue(), Args, 5899 CandidateSet, SuppressUserConversions, 5900 PartialOverloading, EarlyConversions); 5901 return; 5902 } 5903 // We treat a constructor like a non-member function, since its object 5904 // argument doesn't participate in overload resolution. 5905 } 5906 5907 if (!CandidateSet.isNewCandidate(Function)) 5908 return; 5909 5910 // C++ [over.match.oper]p3: 5911 // if no operand has a class type, only those non-member functions in the 5912 // lookup set that have a first parameter of type T1 or "reference to 5913 // (possibly cv-qualified) T1", when T1 is an enumeration type, or (if there 5914 // is a right operand) a second parameter of type T2 or "reference to 5915 // (possibly cv-qualified) T2", when T2 is an enumeration type, are 5916 // candidate functions. 5917 if (CandidateSet.getKind() == OverloadCandidateSet::CSK_Operator && 5918 !IsAcceptableNonMemberOperatorCandidate(Context, Function, Args)) 5919 return; 5920 5921 // C++11 [class.copy]p11: [DR1402] 5922 // A defaulted move constructor that is defined as deleted is ignored by 5923 // overload resolution. 5924 CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(Function); 5925 if (Constructor && Constructor->isDefaulted() && Constructor->isDeleted() && 5926 Constructor->isMoveConstructor()) 5927 return; 5928 5929 // Overload resolution is always an unevaluated context. 5930 EnterExpressionEvaluationContext Unevaluated( 5931 *this, Sema::ExpressionEvaluationContext::Unevaluated); 5932 5933 // Add this candidate 5934 OverloadCandidate &Candidate = 5935 CandidateSet.addCandidate(Args.size(), EarlyConversions); 5936 Candidate.FoundDecl = FoundDecl; 5937 Candidate.Function = Function; 5938 Candidate.Viable = true; 5939 Candidate.IsSurrogate = false; 5940 Candidate.IgnoreObjectArgument = false; 5941 Candidate.ExplicitCallArguments = Args.size(); 5942 5943 if (Constructor) { 5944 // C++ [class.copy]p3: 5945 // A member function template is never instantiated to perform the copy 5946 // of a class object to an object of its class type. 5947 QualType ClassType = Context.getTypeDeclType(Constructor->getParent()); 5948 if (Args.size() == 1 && Constructor->isSpecializationCopyingObject() && 5949 (Context.hasSameUnqualifiedType(ClassType, Args[0]->getType()) || 5950 IsDerivedFrom(Args[0]->getLocStart(), Args[0]->getType(), 5951 ClassType))) { 5952 Candidate.Viable = false; 5953 Candidate.FailureKind = ovl_fail_illegal_constructor; 5954 return; 5955 } 5956 5957 // C++ [over.match.funcs]p8: (proposed DR resolution) 5958 // A constructor inherited from class type C that has a first parameter 5959 // of type "reference to P" (including such a constructor instantiated 5960 // from a template) is excluded from the set of candidate functions when 5961 // constructing an object of type cv D if the argument list has exactly 5962 // one argument and D is reference-related to P and P is reference-related 5963 // to C. 5964 auto *Shadow = dyn_cast<ConstructorUsingShadowDecl>(FoundDecl.getDecl()); 5965 if (Shadow && Args.size() == 1 && Constructor->getNumParams() >= 1 && 5966 Constructor->getParamDecl(0)->getType()->isReferenceType()) { 5967 QualType P = Constructor->getParamDecl(0)->getType()->getPointeeType(); 5968 QualType C = Context.getRecordType(Constructor->getParent()); 5969 QualType D = Context.getRecordType(Shadow->getParent()); 5970 SourceLocation Loc = Args.front()->getExprLoc(); 5971 if ((Context.hasSameUnqualifiedType(P, C) || IsDerivedFrom(Loc, P, C)) && 5972 (Context.hasSameUnqualifiedType(D, P) || IsDerivedFrom(Loc, D, P))) { 5973 Candidate.Viable = false; 5974 Candidate.FailureKind = ovl_fail_inhctor_slice; 5975 return; 5976 } 5977 } 5978 } 5979 5980 unsigned NumParams = Proto->getNumParams(); 5981 5982 // (C++ 13.3.2p2): A candidate function having fewer than m 5983 // parameters is viable only if it has an ellipsis in its parameter 5984 // list (8.3.5). 5985 if (TooManyArguments(NumParams, Args.size(), PartialOverloading) && 5986 !Proto->isVariadic()) { 5987 Candidate.Viable = false; 5988 Candidate.FailureKind = ovl_fail_too_many_arguments; 5989 return; 5990 } 5991 5992 // (C++ 13.3.2p2): A candidate function having more than m parameters 5993 // is viable only if the (m+1)st parameter has a default argument 5994 // (8.3.6). For the purposes of overload resolution, the 5995 // parameter list is truncated on the right, so that there are 5996 // exactly m parameters. 5997 unsigned MinRequiredArgs = Function->getMinRequiredArguments(); 5998 if (Args.size() < MinRequiredArgs && !PartialOverloading) { 5999 // Not enough arguments. 6000 Candidate.Viable = false; 6001 Candidate.FailureKind = ovl_fail_too_few_arguments; 6002 return; 6003 } 6004 6005 // (CUDA B.1): Check for invalid calls between targets. 6006 if (getLangOpts().CUDA) 6007 if (const FunctionDecl *Caller = dyn_cast<FunctionDecl>(CurContext)) 6008 // Skip the check for callers that are implicit members, because in this 6009 // case we may not yet know what the member's target is; the target is 6010 // inferred for the member automatically, based on the bases and fields of 6011 // the class. 6012 if (!Caller->isImplicit() && !IsAllowedCUDACall(Caller, Function)) { 6013 Candidate.Viable = false; 6014 Candidate.FailureKind = ovl_fail_bad_target; 6015 return; 6016 } 6017 6018 // Determine the implicit conversion sequences for each of the 6019 // arguments. 6020 for (unsigned ArgIdx = 0; ArgIdx < Args.size(); ++ArgIdx) { 6021 if (Candidate.Conversions[ArgIdx].isInitialized()) { 6022 // We already formed a conversion sequence for this parameter during 6023 // template argument deduction. 6024 } else if (ArgIdx < NumParams) { 6025 // (C++ 13.3.2p3): for F to be a viable function, there shall 6026 // exist for each argument an implicit conversion sequence 6027 // (13.3.3.1) that converts that argument to the corresponding 6028 // parameter of F. 6029 QualType ParamType = Proto->getParamType(ArgIdx); 6030 Candidate.Conversions[ArgIdx] 6031 = TryCopyInitialization(*this, Args[ArgIdx], ParamType, 6032 SuppressUserConversions, 6033 /*InOverloadResolution=*/true, 6034 /*AllowObjCWritebackConversion=*/ 6035 getLangOpts().ObjCAutoRefCount, 6036 AllowExplicit); 6037 if (Candidate.Conversions[ArgIdx].isBad()) { 6038 Candidate.Viable = false; 6039 Candidate.FailureKind = ovl_fail_bad_conversion; 6040 return; 6041 } 6042 } else { 6043 // (C++ 13.3.2p2): For the purposes of overload resolution, any 6044 // argument for which there is no corresponding parameter is 6045 // considered to ""match the ellipsis" (C+ 13.3.3.1.3). 6046 Candidate.Conversions[ArgIdx].setEllipsis(); 6047 } 6048 } 6049 6050 if (EnableIfAttr *FailedAttr = CheckEnableIf(Function, Args)) { 6051 Candidate.Viable = false; 6052 Candidate.FailureKind = ovl_fail_enable_if; 6053 Candidate.DeductionFailure.Data = FailedAttr; 6054 return; 6055 } 6056 6057 if (LangOpts.OpenCL && isOpenCLDisabledDecl(Function)) { 6058 Candidate.Viable = false; 6059 Candidate.FailureKind = ovl_fail_ext_disabled; 6060 return; 6061 } 6062 } 6063 6064 ObjCMethodDecl * 6065 Sema::SelectBestMethod(Selector Sel, MultiExprArg Args, bool IsInstance, 6066 SmallVectorImpl<ObjCMethodDecl *> &Methods) { 6067 if (Methods.size() <= 1) 6068 return nullptr; 6069 6070 for (unsigned b = 0, e = Methods.size(); b < e; b++) { 6071 bool Match = true; 6072 ObjCMethodDecl *Method = Methods[b]; 6073 unsigned NumNamedArgs = Sel.getNumArgs(); 6074 // Method might have more arguments than selector indicates. This is due 6075 // to addition of c-style arguments in method. 6076 if (Method->param_size() > NumNamedArgs) 6077 NumNamedArgs = Method->param_size(); 6078 if (Args.size() < NumNamedArgs) 6079 continue; 6080 6081 for (unsigned i = 0; i < NumNamedArgs; i++) { 6082 // We can't do any type-checking on a type-dependent argument. 6083 if (Args[i]->isTypeDependent()) { 6084 Match = false; 6085 break; 6086 } 6087 6088 ParmVarDecl *param = Method->parameters()[i]; 6089 Expr *argExpr = Args[i]; 6090 assert(argExpr && "SelectBestMethod(): missing expression"); 6091 6092 // Strip the unbridged-cast placeholder expression off unless it's 6093 // a consumed argument. 6094 if (argExpr->hasPlaceholderType(BuiltinType::ARCUnbridgedCast) && 6095 !param->hasAttr<CFConsumedAttr>()) 6096 argExpr = stripARCUnbridgedCast(argExpr); 6097 6098 // If the parameter is __unknown_anytype, move on to the next method. 6099 if (param->getType() == Context.UnknownAnyTy) { 6100 Match = false; 6101 break; 6102 } 6103 6104 ImplicitConversionSequence ConversionState 6105 = TryCopyInitialization(*this, argExpr, param->getType(), 6106 /*SuppressUserConversions*/false, 6107 /*InOverloadResolution=*/true, 6108 /*AllowObjCWritebackConversion=*/ 6109 getLangOpts().ObjCAutoRefCount, 6110 /*AllowExplicit*/false); 6111 // This function looks for a reasonably-exact match, so we consider 6112 // incompatible pointer conversions to be a failure here. 6113 if (ConversionState.isBad() || 6114 (ConversionState.isStandard() && 6115 ConversionState.Standard.Second == 6116 ICK_Incompatible_Pointer_Conversion)) { 6117 Match = false; 6118 break; 6119 } 6120 } 6121 // Promote additional arguments to variadic methods. 6122 if (Match && Method->isVariadic()) { 6123 for (unsigned i = NumNamedArgs, e = Args.size(); i < e; ++i) { 6124 if (Args[i]->isTypeDependent()) { 6125 Match = false; 6126 break; 6127 } 6128 ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], VariadicMethod, 6129 nullptr); 6130 if (Arg.isInvalid()) { 6131 Match = false; 6132 break; 6133 } 6134 } 6135 } else { 6136 // Check for extra arguments to non-variadic methods. 6137 if (Args.size() != NumNamedArgs) 6138 Match = false; 6139 else if (Match && NumNamedArgs == 0 && Methods.size() > 1) { 6140 // Special case when selectors have no argument. In this case, select 6141 // one with the most general result type of 'id'. 6142 for (unsigned b = 0, e = Methods.size(); b < e; b++) { 6143 QualType ReturnT = Methods[b]->getReturnType(); 6144 if (ReturnT->isObjCIdType()) 6145 return Methods[b]; 6146 } 6147 } 6148 } 6149 6150 if (Match) 6151 return Method; 6152 } 6153 return nullptr; 6154 } 6155 6156 // specific_attr_iterator iterates over enable_if attributes in reverse, and 6157 // enable_if is order-sensitive. As a result, we need to reverse things 6158 // sometimes. Size of 4 elements is arbitrary. 6159 static SmallVector<EnableIfAttr *, 4> 6160 getOrderedEnableIfAttrs(const FunctionDecl *Function) { 6161 SmallVector<EnableIfAttr *, 4> Result; 6162 if (!Function->hasAttrs()) 6163 return Result; 6164 6165 const auto &FuncAttrs = Function->getAttrs(); 6166 for (Attr *Attr : FuncAttrs) 6167 if (auto *EnableIf = dyn_cast<EnableIfAttr>(Attr)) 6168 Result.push_back(EnableIf); 6169 6170 std::reverse(Result.begin(), Result.end()); 6171 return Result; 6172 } 6173 6174 static bool 6175 convertArgsForAvailabilityChecks(Sema &S, FunctionDecl *Function, Expr *ThisArg, 6176 ArrayRef<Expr *> Args, Sema::SFINAETrap &Trap, 6177 bool MissingImplicitThis, Expr *&ConvertedThis, 6178 SmallVectorImpl<Expr *> &ConvertedArgs) { 6179 if (ThisArg) { 6180 CXXMethodDecl *Method = cast<CXXMethodDecl>(Function); 6181 assert(!isa<CXXConstructorDecl>(Method) && 6182 "Shouldn't have `this` for ctors!"); 6183 assert(!Method->isStatic() && "Shouldn't have `this` for static methods!"); 6184 ExprResult R = S.PerformObjectArgumentInitialization( 6185 ThisArg, /*Qualifier=*/nullptr, Method, Method); 6186 if (R.isInvalid()) 6187 return false; 6188 ConvertedThis = R.get(); 6189 } else { 6190 if (auto *MD = dyn_cast<CXXMethodDecl>(Function)) { 6191 (void)MD; 6192 assert((MissingImplicitThis || MD->isStatic() || 6193 isa<CXXConstructorDecl>(MD)) && 6194 "Expected `this` for non-ctor instance methods"); 6195 } 6196 ConvertedThis = nullptr; 6197 } 6198 6199 // Ignore any variadic arguments. Converting them is pointless, since the 6200 // user can't refer to them in the function condition. 6201 unsigned ArgSizeNoVarargs = std::min(Function->param_size(), Args.size()); 6202 6203 // Convert the arguments. 6204 for (unsigned I = 0; I != ArgSizeNoVarargs; ++I) { 6205 ExprResult R; 6206 R = S.PerformCopyInitialization(InitializedEntity::InitializeParameter( 6207 S.Context, Function->getParamDecl(I)), 6208 SourceLocation(), Args[I]); 6209 6210 if (R.isInvalid()) 6211 return false; 6212 6213 ConvertedArgs.push_back(R.get()); 6214 } 6215 6216 if (Trap.hasErrorOccurred()) 6217 return false; 6218 6219 // Push default arguments if needed. 6220 if (!Function->isVariadic() && Args.size() < Function->getNumParams()) { 6221 for (unsigned i = Args.size(), e = Function->getNumParams(); i != e; ++i) { 6222 ParmVarDecl *P = Function->getParamDecl(i); 6223 ExprResult R = S.PerformCopyInitialization( 6224 InitializedEntity::InitializeParameter(S.Context, 6225 Function->getParamDecl(i)), 6226 SourceLocation(), 6227 P->hasUninstantiatedDefaultArg() ? P->getUninstantiatedDefaultArg() 6228 : P->getDefaultArg()); 6229 if (R.isInvalid()) 6230 return false; 6231 ConvertedArgs.push_back(R.get()); 6232 } 6233 6234 if (Trap.hasErrorOccurred()) 6235 return false; 6236 } 6237 return true; 6238 } 6239 6240 EnableIfAttr *Sema::CheckEnableIf(FunctionDecl *Function, ArrayRef<Expr *> Args, 6241 bool MissingImplicitThis) { 6242 SmallVector<EnableIfAttr *, 4> EnableIfAttrs = 6243 getOrderedEnableIfAttrs(Function); 6244 if (EnableIfAttrs.empty()) 6245 return nullptr; 6246 6247 SFINAETrap Trap(*this); 6248 SmallVector<Expr *, 16> ConvertedArgs; 6249 // FIXME: We should look into making enable_if late-parsed. 6250 Expr *DiscardedThis; 6251 if (!convertArgsForAvailabilityChecks( 6252 *this, Function, /*ThisArg=*/nullptr, Args, Trap, 6253 /*MissingImplicitThis=*/true, DiscardedThis, ConvertedArgs)) 6254 return EnableIfAttrs[0]; 6255 6256 for (auto *EIA : EnableIfAttrs) { 6257 APValue Result; 6258 // FIXME: This doesn't consider value-dependent cases, because doing so is 6259 // very difficult. Ideally, we should handle them more gracefully. 6260 if (!EIA->getCond()->EvaluateWithSubstitution( 6261 Result, Context, Function, llvm::makeArrayRef(ConvertedArgs))) 6262 return EIA; 6263 6264 if (!Result.isInt() || !Result.getInt().getBoolValue()) 6265 return EIA; 6266 } 6267 return nullptr; 6268 } 6269 6270 template <typename CheckFn> 6271 static bool diagnoseDiagnoseIfAttrsWith(Sema &S, const NamedDecl *ND, 6272 bool ArgDependent, SourceLocation Loc, 6273 CheckFn &&IsSuccessful) { 6274 SmallVector<const DiagnoseIfAttr *, 8> Attrs; 6275 for (const auto *DIA : ND->specific_attrs<DiagnoseIfAttr>()) { 6276 if (ArgDependent == DIA->getArgDependent()) 6277 Attrs.push_back(DIA); 6278 } 6279 6280 // Common case: No diagnose_if attributes, so we can quit early. 6281 if (Attrs.empty()) 6282 return false; 6283 6284 auto WarningBegin = std::stable_partition( 6285 Attrs.begin(), Attrs.end(), 6286 [](const DiagnoseIfAttr *DIA) { return DIA->isError(); }); 6287 6288 // Note that diagnose_if attributes are late-parsed, so they appear in the 6289 // correct order (unlike enable_if attributes). 6290 auto ErrAttr = llvm::find_if(llvm::make_range(Attrs.begin(), WarningBegin), 6291 IsSuccessful); 6292 if (ErrAttr != WarningBegin) { 6293 const DiagnoseIfAttr *DIA = *ErrAttr; 6294 S.Diag(Loc, diag::err_diagnose_if_succeeded) << DIA->getMessage(); 6295 S.Diag(DIA->getLocation(), diag::note_from_diagnose_if) 6296 << DIA->getParent() << DIA->getCond()->getSourceRange(); 6297 return true; 6298 } 6299 6300 for (const auto *DIA : llvm::make_range(WarningBegin, Attrs.end())) 6301 if (IsSuccessful(DIA)) { 6302 S.Diag(Loc, diag::warn_diagnose_if_succeeded) << DIA->getMessage(); 6303 S.Diag(DIA->getLocation(), diag::note_from_diagnose_if) 6304 << DIA->getParent() << DIA->getCond()->getSourceRange(); 6305 } 6306 6307 return false; 6308 } 6309 6310 bool Sema::diagnoseArgDependentDiagnoseIfAttrs(const FunctionDecl *Function, 6311 const Expr *ThisArg, 6312 ArrayRef<const Expr *> Args, 6313 SourceLocation Loc) { 6314 return diagnoseDiagnoseIfAttrsWith( 6315 *this, Function, /*ArgDependent=*/true, Loc, 6316 [&](const DiagnoseIfAttr *DIA) { 6317 APValue Result; 6318 // It's sane to use the same Args for any redecl of this function, since 6319 // EvaluateWithSubstitution only cares about the position of each 6320 // argument in the arg list, not the ParmVarDecl* it maps to. 6321 if (!DIA->getCond()->EvaluateWithSubstitution( 6322 Result, Context, cast<FunctionDecl>(DIA->getParent()), Args, ThisArg)) 6323 return false; 6324 return Result.isInt() && Result.getInt().getBoolValue(); 6325 }); 6326 } 6327 6328 bool Sema::diagnoseArgIndependentDiagnoseIfAttrs(const NamedDecl *ND, 6329 SourceLocation Loc) { 6330 return diagnoseDiagnoseIfAttrsWith( 6331 *this, ND, /*ArgDependent=*/false, Loc, 6332 [&](const DiagnoseIfAttr *DIA) { 6333 bool Result; 6334 return DIA->getCond()->EvaluateAsBooleanCondition(Result, Context) && 6335 Result; 6336 }); 6337 } 6338 6339 /// \brief Add all of the function declarations in the given function set to 6340 /// the overload candidate set. 6341 void Sema::AddFunctionCandidates(const UnresolvedSetImpl &Fns, 6342 ArrayRef<Expr *> Args, 6343 OverloadCandidateSet& CandidateSet, 6344 TemplateArgumentListInfo *ExplicitTemplateArgs, 6345 bool SuppressUserConversions, 6346 bool PartialOverloading) { 6347 for (UnresolvedSetIterator F = Fns.begin(), E = Fns.end(); F != E; ++F) { 6348 NamedDecl *D = F.getDecl()->getUnderlyingDecl(); 6349 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 6350 if (isa<CXXMethodDecl>(FD) && !cast<CXXMethodDecl>(FD)->isStatic()) { 6351 QualType ObjectType; 6352 Expr::Classification ObjectClassification; 6353 if (Expr *E = Args[0]) { 6354 // Use the explit base to restrict the lookup: 6355 ObjectType = E->getType(); 6356 ObjectClassification = E->Classify(Context); 6357 } // .. else there is an implit base. 6358 AddMethodCandidate(cast<CXXMethodDecl>(FD), F.getPair(), 6359 cast<CXXMethodDecl>(FD)->getParent(), ObjectType, 6360 ObjectClassification, Args.slice(1), CandidateSet, 6361 SuppressUserConversions, PartialOverloading); 6362 } else { 6363 AddOverloadCandidate(FD, F.getPair(), Args, CandidateSet, 6364 SuppressUserConversions, PartialOverloading); 6365 } 6366 } else { 6367 FunctionTemplateDecl *FunTmpl = cast<FunctionTemplateDecl>(D); 6368 if (isa<CXXMethodDecl>(FunTmpl->getTemplatedDecl()) && 6369 !cast<CXXMethodDecl>(FunTmpl->getTemplatedDecl())->isStatic()) { 6370 QualType ObjectType; 6371 Expr::Classification ObjectClassification; 6372 if (Expr *E = Args[0]) { 6373 // Use the explit base to restrict the lookup: 6374 ObjectType = E->getType(); 6375 ObjectClassification = E->Classify(Context); 6376 } // .. else there is an implit base. 6377 AddMethodTemplateCandidate( 6378 FunTmpl, F.getPair(), 6379 cast<CXXRecordDecl>(FunTmpl->getDeclContext()), 6380 ExplicitTemplateArgs, ObjectType, ObjectClassification, 6381 Args.slice(1), CandidateSet, SuppressUserConversions, 6382 PartialOverloading); 6383 } else { 6384 AddTemplateOverloadCandidate(FunTmpl, F.getPair(), 6385 ExplicitTemplateArgs, Args, 6386 CandidateSet, SuppressUserConversions, 6387 PartialOverloading); 6388 } 6389 } 6390 } 6391 } 6392 6393 /// AddMethodCandidate - Adds a named decl (which is some kind of 6394 /// method) as a method candidate to the given overload set. 6395 void Sema::AddMethodCandidate(DeclAccessPair FoundDecl, 6396 QualType ObjectType, 6397 Expr::Classification ObjectClassification, 6398 ArrayRef<Expr *> Args, 6399 OverloadCandidateSet& CandidateSet, 6400 bool SuppressUserConversions) { 6401 NamedDecl *Decl = FoundDecl.getDecl(); 6402 CXXRecordDecl *ActingContext = cast<CXXRecordDecl>(Decl->getDeclContext()); 6403 6404 if (isa<UsingShadowDecl>(Decl)) 6405 Decl = cast<UsingShadowDecl>(Decl)->getTargetDecl(); 6406 6407 if (FunctionTemplateDecl *TD = dyn_cast<FunctionTemplateDecl>(Decl)) { 6408 assert(isa<CXXMethodDecl>(TD->getTemplatedDecl()) && 6409 "Expected a member function template"); 6410 AddMethodTemplateCandidate(TD, FoundDecl, ActingContext, 6411 /*ExplicitArgs*/ nullptr, ObjectType, 6412 ObjectClassification, Args, CandidateSet, 6413 SuppressUserConversions); 6414 } else { 6415 AddMethodCandidate(cast<CXXMethodDecl>(Decl), FoundDecl, ActingContext, 6416 ObjectType, ObjectClassification, Args, CandidateSet, 6417 SuppressUserConversions); 6418 } 6419 } 6420 6421 /// AddMethodCandidate - Adds the given C++ member function to the set 6422 /// of candidate functions, using the given function call arguments 6423 /// and the object argument (@c Object). For example, in a call 6424 /// @c o.f(a1,a2), @c Object will contain @c o and @c Args will contain 6425 /// both @c a1 and @c a2. If @p SuppressUserConversions, then don't 6426 /// allow user-defined conversions via constructors or conversion 6427 /// operators. 6428 void 6429 Sema::AddMethodCandidate(CXXMethodDecl *Method, DeclAccessPair FoundDecl, 6430 CXXRecordDecl *ActingContext, QualType ObjectType, 6431 Expr::Classification ObjectClassification, 6432 ArrayRef<Expr *> Args, 6433 OverloadCandidateSet &CandidateSet, 6434 bool SuppressUserConversions, 6435 bool PartialOverloading, 6436 ConversionSequenceList EarlyConversions) { 6437 const FunctionProtoType *Proto 6438 = dyn_cast<FunctionProtoType>(Method->getType()->getAs<FunctionType>()); 6439 assert(Proto && "Methods without a prototype cannot be overloaded"); 6440 assert(!isa<CXXConstructorDecl>(Method) && 6441 "Use AddOverloadCandidate for constructors"); 6442 6443 if (!CandidateSet.isNewCandidate(Method)) 6444 return; 6445 6446 // C++11 [class.copy]p23: [DR1402] 6447 // A defaulted move assignment operator that is defined as deleted is 6448 // ignored by overload resolution. 6449 if (Method->isDefaulted() && Method->isDeleted() && 6450 Method->isMoveAssignmentOperator()) 6451 return; 6452 6453 // Overload resolution is always an unevaluated context. 6454 EnterExpressionEvaluationContext Unevaluated( 6455 *this, Sema::ExpressionEvaluationContext::Unevaluated); 6456 6457 // Add this candidate 6458 OverloadCandidate &Candidate = 6459 CandidateSet.addCandidate(Args.size() + 1, EarlyConversions); 6460 Candidate.FoundDecl = FoundDecl; 6461 Candidate.Function = Method; 6462 Candidate.IsSurrogate = false; 6463 Candidate.IgnoreObjectArgument = false; 6464 Candidate.ExplicitCallArguments = Args.size(); 6465 6466 unsigned NumParams = Proto->getNumParams(); 6467 6468 // (C++ 13.3.2p2): A candidate function having fewer than m 6469 // parameters is viable only if it has an ellipsis in its parameter 6470 // list (8.3.5). 6471 if (TooManyArguments(NumParams, Args.size(), PartialOverloading) && 6472 !Proto->isVariadic()) { 6473 Candidate.Viable = false; 6474 Candidate.FailureKind = ovl_fail_too_many_arguments; 6475 return; 6476 } 6477 6478 // (C++ 13.3.2p2): A candidate function having more than m parameters 6479 // is viable only if the (m+1)st parameter has a default argument 6480 // (8.3.6). For the purposes of overload resolution, the 6481 // parameter list is truncated on the right, so that there are 6482 // exactly m parameters. 6483 unsigned MinRequiredArgs = Method->getMinRequiredArguments(); 6484 if (Args.size() < MinRequiredArgs && !PartialOverloading) { 6485 // Not enough arguments. 6486 Candidate.Viable = false; 6487 Candidate.FailureKind = ovl_fail_too_few_arguments; 6488 return; 6489 } 6490 6491 Candidate.Viable = true; 6492 6493 if (Method->isStatic() || ObjectType.isNull()) 6494 // The implicit object argument is ignored. 6495 Candidate.IgnoreObjectArgument = true; 6496 else { 6497 // Determine the implicit conversion sequence for the object 6498 // parameter. 6499 Candidate.Conversions[0] = TryObjectArgumentInitialization( 6500 *this, CandidateSet.getLocation(), ObjectType, ObjectClassification, 6501 Method, ActingContext); 6502 if (Candidate.Conversions[0].isBad()) { 6503 Candidate.Viable = false; 6504 Candidate.FailureKind = ovl_fail_bad_conversion; 6505 return; 6506 } 6507 } 6508 6509 // (CUDA B.1): Check for invalid calls between targets. 6510 if (getLangOpts().CUDA) 6511 if (const FunctionDecl *Caller = dyn_cast<FunctionDecl>(CurContext)) 6512 if (!IsAllowedCUDACall(Caller, Method)) { 6513 Candidate.Viable = false; 6514 Candidate.FailureKind = ovl_fail_bad_target; 6515 return; 6516 } 6517 6518 // Determine the implicit conversion sequences for each of the 6519 // arguments. 6520 for (unsigned ArgIdx = 0; ArgIdx < Args.size(); ++ArgIdx) { 6521 if (Candidate.Conversions[ArgIdx + 1].isInitialized()) { 6522 // We already formed a conversion sequence for this parameter during 6523 // template argument deduction. 6524 } else if (ArgIdx < NumParams) { 6525 // (C++ 13.3.2p3): for F to be a viable function, there shall 6526 // exist for each argument an implicit conversion sequence 6527 // (13.3.3.1) that converts that argument to the corresponding 6528 // parameter of F. 6529 QualType ParamType = Proto->getParamType(ArgIdx); 6530 Candidate.Conversions[ArgIdx + 1] 6531 = TryCopyInitialization(*this, Args[ArgIdx], ParamType, 6532 SuppressUserConversions, 6533 /*InOverloadResolution=*/true, 6534 /*AllowObjCWritebackConversion=*/ 6535 getLangOpts().ObjCAutoRefCount); 6536 if (Candidate.Conversions[ArgIdx + 1].isBad()) { 6537 Candidate.Viable = false; 6538 Candidate.FailureKind = ovl_fail_bad_conversion; 6539 return; 6540 } 6541 } else { 6542 // (C++ 13.3.2p2): For the purposes of overload resolution, any 6543 // argument for which there is no corresponding parameter is 6544 // considered to "match the ellipsis" (C+ 13.3.3.1.3). 6545 Candidate.Conversions[ArgIdx + 1].setEllipsis(); 6546 } 6547 } 6548 6549 if (EnableIfAttr *FailedAttr = CheckEnableIf(Method, Args, true)) { 6550 Candidate.Viable = false; 6551 Candidate.FailureKind = ovl_fail_enable_if; 6552 Candidate.DeductionFailure.Data = FailedAttr; 6553 return; 6554 } 6555 } 6556 6557 /// \brief Add a C++ member function template as a candidate to the candidate 6558 /// set, using template argument deduction to produce an appropriate member 6559 /// function template specialization. 6560 void 6561 Sema::AddMethodTemplateCandidate(FunctionTemplateDecl *MethodTmpl, 6562 DeclAccessPair FoundDecl, 6563 CXXRecordDecl *ActingContext, 6564 TemplateArgumentListInfo *ExplicitTemplateArgs, 6565 QualType ObjectType, 6566 Expr::Classification ObjectClassification, 6567 ArrayRef<Expr *> Args, 6568 OverloadCandidateSet& CandidateSet, 6569 bool SuppressUserConversions, 6570 bool PartialOverloading) { 6571 if (!CandidateSet.isNewCandidate(MethodTmpl)) 6572 return; 6573 6574 // C++ [over.match.funcs]p7: 6575 // In each case where a candidate is a function template, candidate 6576 // function template specializations are generated using template argument 6577 // deduction (14.8.3, 14.8.2). Those candidates are then handled as 6578 // candidate functions in the usual way.113) A given name can refer to one 6579 // or more function templates and also to a set of overloaded non-template 6580 // functions. In such a case, the candidate functions generated from each 6581 // function template are combined with the set of non-template candidate 6582 // functions. 6583 TemplateDeductionInfo Info(CandidateSet.getLocation()); 6584 FunctionDecl *Specialization = nullptr; 6585 ConversionSequenceList Conversions; 6586 if (TemplateDeductionResult Result = DeduceTemplateArguments( 6587 MethodTmpl, ExplicitTemplateArgs, Args, Specialization, Info, 6588 PartialOverloading, [&](ArrayRef<QualType> ParamTypes) { 6589 return CheckNonDependentConversions( 6590 MethodTmpl, ParamTypes, Args, CandidateSet, Conversions, 6591 SuppressUserConversions, ActingContext, ObjectType, 6592 ObjectClassification); 6593 })) { 6594 OverloadCandidate &Candidate = 6595 CandidateSet.addCandidate(Conversions.size(), Conversions); 6596 Candidate.FoundDecl = FoundDecl; 6597 Candidate.Function = MethodTmpl->getTemplatedDecl(); 6598 Candidate.Viable = false; 6599 Candidate.IsSurrogate = false; 6600 Candidate.IgnoreObjectArgument = 6601 cast<CXXMethodDecl>(Candidate.Function)->isStatic() || 6602 ObjectType.isNull(); 6603 Candidate.ExplicitCallArguments = Args.size(); 6604 if (Result == TDK_NonDependentConversionFailure) 6605 Candidate.FailureKind = ovl_fail_bad_conversion; 6606 else { 6607 Candidate.FailureKind = ovl_fail_bad_deduction; 6608 Candidate.DeductionFailure = MakeDeductionFailureInfo(Context, Result, 6609 Info); 6610 } 6611 return; 6612 } 6613 6614 // Add the function template specialization produced by template argument 6615 // deduction as a candidate. 6616 assert(Specialization && "Missing member function template specialization?"); 6617 assert(isa<CXXMethodDecl>(Specialization) && 6618 "Specialization is not a member function?"); 6619 AddMethodCandidate(cast<CXXMethodDecl>(Specialization), FoundDecl, 6620 ActingContext, ObjectType, ObjectClassification, Args, 6621 CandidateSet, SuppressUserConversions, PartialOverloading, 6622 Conversions); 6623 } 6624 6625 /// \brief Add a C++ function template specialization as a candidate 6626 /// in the candidate set, using template argument deduction to produce 6627 /// an appropriate function template specialization. 6628 void 6629 Sema::AddTemplateOverloadCandidate(FunctionTemplateDecl *FunctionTemplate, 6630 DeclAccessPair FoundDecl, 6631 TemplateArgumentListInfo *ExplicitTemplateArgs, 6632 ArrayRef<Expr *> Args, 6633 OverloadCandidateSet& CandidateSet, 6634 bool SuppressUserConversions, 6635 bool PartialOverloading) { 6636 if (!CandidateSet.isNewCandidate(FunctionTemplate)) 6637 return; 6638 6639 // C++ [over.match.funcs]p7: 6640 // In each case where a candidate is a function template, candidate 6641 // function template specializations are generated using template argument 6642 // deduction (14.8.3, 14.8.2). Those candidates are then handled as 6643 // candidate functions in the usual way.113) A given name can refer to one 6644 // or more function templates and also to a set of overloaded non-template 6645 // functions. In such a case, the candidate functions generated from each 6646 // function template are combined with the set of non-template candidate 6647 // functions. 6648 TemplateDeductionInfo Info(CandidateSet.getLocation()); 6649 FunctionDecl *Specialization = nullptr; 6650 ConversionSequenceList Conversions; 6651 if (TemplateDeductionResult Result = DeduceTemplateArguments( 6652 FunctionTemplate, ExplicitTemplateArgs, Args, Specialization, Info, 6653 PartialOverloading, [&](ArrayRef<QualType> ParamTypes) { 6654 return CheckNonDependentConversions(FunctionTemplate, ParamTypes, 6655 Args, CandidateSet, Conversions, 6656 SuppressUserConversions); 6657 })) { 6658 OverloadCandidate &Candidate = 6659 CandidateSet.addCandidate(Conversions.size(), Conversions); 6660 Candidate.FoundDecl = FoundDecl; 6661 Candidate.Function = FunctionTemplate->getTemplatedDecl(); 6662 Candidate.Viable = false; 6663 Candidate.IsSurrogate = false; 6664 // Ignore the object argument if there is one, since we don't have an object 6665 // type. 6666 Candidate.IgnoreObjectArgument = 6667 isa<CXXMethodDecl>(Candidate.Function) && 6668 !isa<CXXConstructorDecl>(Candidate.Function); 6669 Candidate.ExplicitCallArguments = Args.size(); 6670 if (Result == TDK_NonDependentConversionFailure) 6671 Candidate.FailureKind = ovl_fail_bad_conversion; 6672 else { 6673 Candidate.FailureKind = ovl_fail_bad_deduction; 6674 Candidate.DeductionFailure = MakeDeductionFailureInfo(Context, Result, 6675 Info); 6676 } 6677 return; 6678 } 6679 6680 // Add the function template specialization produced by template argument 6681 // deduction as a candidate. 6682 assert(Specialization && "Missing function template specialization?"); 6683 AddOverloadCandidate(Specialization, FoundDecl, Args, CandidateSet, 6684 SuppressUserConversions, PartialOverloading, 6685 /*AllowExplicit*/false, Conversions); 6686 } 6687 6688 /// Check that implicit conversion sequences can be formed for each argument 6689 /// whose corresponding parameter has a non-dependent type, per DR1391's 6690 /// [temp.deduct.call]p10. 6691 bool Sema::CheckNonDependentConversions( 6692 FunctionTemplateDecl *FunctionTemplate, ArrayRef<QualType> ParamTypes, 6693 ArrayRef<Expr *> Args, OverloadCandidateSet &CandidateSet, 6694 ConversionSequenceList &Conversions, bool SuppressUserConversions, 6695 CXXRecordDecl *ActingContext, QualType ObjectType, 6696 Expr::Classification ObjectClassification) { 6697 // FIXME: The cases in which we allow explicit conversions for constructor 6698 // arguments never consider calling a constructor template. It's not clear 6699 // that is correct. 6700 const bool AllowExplicit = false; 6701 6702 auto *FD = FunctionTemplate->getTemplatedDecl(); 6703 auto *Method = dyn_cast<CXXMethodDecl>(FD); 6704 bool HasThisConversion = Method && !isa<CXXConstructorDecl>(Method); 6705 unsigned ThisConversions = HasThisConversion ? 1 : 0; 6706 6707 Conversions = 6708 CandidateSet.allocateConversionSequences(ThisConversions + Args.size()); 6709 6710 // Overload resolution is always an unevaluated context. 6711 EnterExpressionEvaluationContext Unevaluated( 6712 *this, Sema::ExpressionEvaluationContext::Unevaluated); 6713 6714 // For a method call, check the 'this' conversion here too. DR1391 doesn't 6715 // require that, but this check should never result in a hard error, and 6716 // overload resolution is permitted to sidestep instantiations. 6717 if (HasThisConversion && !cast<CXXMethodDecl>(FD)->isStatic() && 6718 !ObjectType.isNull()) { 6719 Conversions[0] = TryObjectArgumentInitialization( 6720 *this, CandidateSet.getLocation(), ObjectType, ObjectClassification, 6721 Method, ActingContext); 6722 if (Conversions[0].isBad()) 6723 return true; 6724 } 6725 6726 for (unsigned I = 0, N = std::min(ParamTypes.size(), Args.size()); I != N; 6727 ++I) { 6728 QualType ParamType = ParamTypes[I]; 6729 if (!ParamType->isDependentType()) { 6730 Conversions[ThisConversions + I] 6731 = TryCopyInitialization(*this, Args[I], ParamType, 6732 SuppressUserConversions, 6733 /*InOverloadResolution=*/true, 6734 /*AllowObjCWritebackConversion=*/ 6735 getLangOpts().ObjCAutoRefCount, 6736 AllowExplicit); 6737 if (Conversions[ThisConversions + I].isBad()) 6738 return true; 6739 } 6740 } 6741 6742 return false; 6743 } 6744 6745 /// Determine whether this is an allowable conversion from the result 6746 /// of an explicit conversion operator to the expected type, per C++ 6747 /// [over.match.conv]p1 and [over.match.ref]p1. 6748 /// 6749 /// \param ConvType The return type of the conversion function. 6750 /// 6751 /// \param ToType The type we are converting to. 6752 /// 6753 /// \param AllowObjCPointerConversion Allow a conversion from one 6754 /// Objective-C pointer to another. 6755 /// 6756 /// \returns true if the conversion is allowable, false otherwise. 6757 static bool isAllowableExplicitConversion(Sema &S, 6758 QualType ConvType, QualType ToType, 6759 bool AllowObjCPointerConversion) { 6760 QualType ToNonRefType = ToType.getNonReferenceType(); 6761 6762 // Easy case: the types are the same. 6763 if (S.Context.hasSameUnqualifiedType(ConvType, ToNonRefType)) 6764 return true; 6765 6766 // Allow qualification conversions. 6767 bool ObjCLifetimeConversion; 6768 if (S.IsQualificationConversion(ConvType, ToNonRefType, /*CStyle*/false, 6769 ObjCLifetimeConversion)) 6770 return true; 6771 6772 // If we're not allowed to consider Objective-C pointer conversions, 6773 // we're done. 6774 if (!AllowObjCPointerConversion) 6775 return false; 6776 6777 // Is this an Objective-C pointer conversion? 6778 bool IncompatibleObjC = false; 6779 QualType ConvertedType; 6780 return S.isObjCPointerConversion(ConvType, ToNonRefType, ConvertedType, 6781 IncompatibleObjC); 6782 } 6783 6784 /// AddConversionCandidate - Add a C++ conversion function as a 6785 /// candidate in the candidate set (C++ [over.match.conv], 6786 /// C++ [over.match.copy]). From is the expression we're converting from, 6787 /// and ToType is the type that we're eventually trying to convert to 6788 /// (which may or may not be the same type as the type that the 6789 /// conversion function produces). 6790 void 6791 Sema::AddConversionCandidate(CXXConversionDecl *Conversion, 6792 DeclAccessPair FoundDecl, 6793 CXXRecordDecl *ActingContext, 6794 Expr *From, QualType ToType, 6795 OverloadCandidateSet& CandidateSet, 6796 bool AllowObjCConversionOnExplicit, 6797 bool AllowResultConversion) { 6798 assert(!Conversion->getDescribedFunctionTemplate() && 6799 "Conversion function templates use AddTemplateConversionCandidate"); 6800 QualType ConvType = Conversion->getConversionType().getNonReferenceType(); 6801 if (!CandidateSet.isNewCandidate(Conversion)) 6802 return; 6803 6804 // If the conversion function has an undeduced return type, trigger its 6805 // deduction now. 6806 if (getLangOpts().CPlusPlus14 && ConvType->isUndeducedType()) { 6807 if (DeduceReturnType(Conversion, From->getExprLoc())) 6808 return; 6809 ConvType = Conversion->getConversionType().getNonReferenceType(); 6810 } 6811 6812 // If we don't allow any conversion of the result type, ignore conversion 6813 // functions that don't convert to exactly (possibly cv-qualified) T. 6814 if (!AllowResultConversion && 6815 !Context.hasSameUnqualifiedType(Conversion->getConversionType(), ToType)) 6816 return; 6817 6818 // Per C++ [over.match.conv]p1, [over.match.ref]p1, an explicit conversion 6819 // operator is only a candidate if its return type is the target type or 6820 // can be converted to the target type with a qualification conversion. 6821 if (Conversion->isExplicit() && 6822 !isAllowableExplicitConversion(*this, ConvType, ToType, 6823 AllowObjCConversionOnExplicit)) 6824 return; 6825 6826 // Overload resolution is always an unevaluated context. 6827 EnterExpressionEvaluationContext Unevaluated( 6828 *this, Sema::ExpressionEvaluationContext::Unevaluated); 6829 6830 // Add this candidate 6831 OverloadCandidate &Candidate = CandidateSet.addCandidate(1); 6832 Candidate.FoundDecl = FoundDecl; 6833 Candidate.Function = Conversion; 6834 Candidate.IsSurrogate = false; 6835 Candidate.IgnoreObjectArgument = false; 6836 Candidate.FinalConversion.setAsIdentityConversion(); 6837 Candidate.FinalConversion.setFromType(ConvType); 6838 Candidate.FinalConversion.setAllToTypes(ToType); 6839 Candidate.Viable = true; 6840 Candidate.ExplicitCallArguments = 1; 6841 6842 // C++ [over.match.funcs]p4: 6843 // For conversion functions, the function is considered to be a member of 6844 // the class of the implicit implied object argument for the purpose of 6845 // defining the type of the implicit object parameter. 6846 // 6847 // Determine the implicit conversion sequence for the implicit 6848 // object parameter. 6849 QualType ImplicitParamType = From->getType(); 6850 if (const PointerType *FromPtrType = ImplicitParamType->getAs<PointerType>()) 6851 ImplicitParamType = FromPtrType->getPointeeType(); 6852 CXXRecordDecl *ConversionContext 6853 = cast<CXXRecordDecl>(ImplicitParamType->getAs<RecordType>()->getDecl()); 6854 6855 Candidate.Conversions[0] = TryObjectArgumentInitialization( 6856 *this, CandidateSet.getLocation(), From->getType(), 6857 From->Classify(Context), Conversion, ConversionContext); 6858 6859 if (Candidate.Conversions[0].isBad()) { 6860 Candidate.Viable = false; 6861 Candidate.FailureKind = ovl_fail_bad_conversion; 6862 return; 6863 } 6864 6865 // We won't go through a user-defined type conversion function to convert a 6866 // derived to base as such conversions are given Conversion Rank. They only 6867 // go through a copy constructor. 13.3.3.1.2-p4 [over.ics.user] 6868 QualType FromCanon 6869 = Context.getCanonicalType(From->getType().getUnqualifiedType()); 6870 QualType ToCanon = Context.getCanonicalType(ToType).getUnqualifiedType(); 6871 if (FromCanon == ToCanon || 6872 IsDerivedFrom(CandidateSet.getLocation(), FromCanon, ToCanon)) { 6873 Candidate.Viable = false; 6874 Candidate.FailureKind = ovl_fail_trivial_conversion; 6875 return; 6876 } 6877 6878 // To determine what the conversion from the result of calling the 6879 // conversion function to the type we're eventually trying to 6880 // convert to (ToType), we need to synthesize a call to the 6881 // conversion function and attempt copy initialization from it. This 6882 // makes sure that we get the right semantics with respect to 6883 // lvalues/rvalues and the type. Fortunately, we can allocate this 6884 // call on the stack and we don't need its arguments to be 6885 // well-formed. 6886 DeclRefExpr ConversionRef(Conversion, false, Conversion->getType(), 6887 VK_LValue, From->getLocStart()); 6888 ImplicitCastExpr ConversionFn(ImplicitCastExpr::OnStack, 6889 Context.getPointerType(Conversion->getType()), 6890 CK_FunctionToPointerDecay, 6891 &ConversionRef, VK_RValue); 6892 6893 QualType ConversionType = Conversion->getConversionType(); 6894 if (!isCompleteType(From->getLocStart(), ConversionType)) { 6895 Candidate.Viable = false; 6896 Candidate.FailureKind = ovl_fail_bad_final_conversion; 6897 return; 6898 } 6899 6900 ExprValueKind VK = Expr::getValueKindForType(ConversionType); 6901 6902 // Note that it is safe to allocate CallExpr on the stack here because 6903 // there are 0 arguments (i.e., nothing is allocated using ASTContext's 6904 // allocator). 6905 QualType CallResultType = ConversionType.getNonLValueExprType(Context); 6906 CallExpr Call(Context, &ConversionFn, None, CallResultType, VK, 6907 From->getLocStart()); 6908 ImplicitConversionSequence ICS = 6909 TryCopyInitialization(*this, &Call, ToType, 6910 /*SuppressUserConversions=*/true, 6911 /*InOverloadResolution=*/false, 6912 /*AllowObjCWritebackConversion=*/false); 6913 6914 switch (ICS.getKind()) { 6915 case ImplicitConversionSequence::StandardConversion: 6916 Candidate.FinalConversion = ICS.Standard; 6917 6918 // C++ [over.ics.user]p3: 6919 // If the user-defined conversion is specified by a specialization of a 6920 // conversion function template, the second standard conversion sequence 6921 // shall have exact match rank. 6922 if (Conversion->getPrimaryTemplate() && 6923 GetConversionRank(ICS.Standard.Second) != ICR_Exact_Match) { 6924 Candidate.Viable = false; 6925 Candidate.FailureKind = ovl_fail_final_conversion_not_exact; 6926 return; 6927 } 6928 6929 // C++0x [dcl.init.ref]p5: 6930 // In the second case, if the reference is an rvalue reference and 6931 // the second standard conversion sequence of the user-defined 6932 // conversion sequence includes an lvalue-to-rvalue conversion, the 6933 // program is ill-formed. 6934 if (ToType->isRValueReferenceType() && 6935 ICS.Standard.First == ICK_Lvalue_To_Rvalue) { 6936 Candidate.Viable = false; 6937 Candidate.FailureKind = ovl_fail_bad_final_conversion; 6938 return; 6939 } 6940 break; 6941 6942 case ImplicitConversionSequence::BadConversion: 6943 Candidate.Viable = false; 6944 Candidate.FailureKind = ovl_fail_bad_final_conversion; 6945 return; 6946 6947 default: 6948 llvm_unreachable( 6949 "Can only end up with a standard conversion sequence or failure"); 6950 } 6951 6952 if (EnableIfAttr *FailedAttr = CheckEnableIf(Conversion, None)) { 6953 Candidate.Viable = false; 6954 Candidate.FailureKind = ovl_fail_enable_if; 6955 Candidate.DeductionFailure.Data = FailedAttr; 6956 return; 6957 } 6958 } 6959 6960 /// \brief Adds a conversion function template specialization 6961 /// candidate to the overload set, using template argument deduction 6962 /// to deduce the template arguments of the conversion function 6963 /// template from the type that we are converting to (C++ 6964 /// [temp.deduct.conv]). 6965 void 6966 Sema::AddTemplateConversionCandidate(FunctionTemplateDecl *FunctionTemplate, 6967 DeclAccessPair FoundDecl, 6968 CXXRecordDecl *ActingDC, 6969 Expr *From, QualType ToType, 6970 OverloadCandidateSet &CandidateSet, 6971 bool AllowObjCConversionOnExplicit, 6972 bool AllowResultConversion) { 6973 assert(isa<CXXConversionDecl>(FunctionTemplate->getTemplatedDecl()) && 6974 "Only conversion function templates permitted here"); 6975 6976 if (!CandidateSet.isNewCandidate(FunctionTemplate)) 6977 return; 6978 6979 TemplateDeductionInfo Info(CandidateSet.getLocation()); 6980 CXXConversionDecl *Specialization = nullptr; 6981 if (TemplateDeductionResult Result 6982 = DeduceTemplateArguments(FunctionTemplate, ToType, 6983 Specialization, Info)) { 6984 OverloadCandidate &Candidate = CandidateSet.addCandidate(); 6985 Candidate.FoundDecl = FoundDecl; 6986 Candidate.Function = FunctionTemplate->getTemplatedDecl(); 6987 Candidate.Viable = false; 6988 Candidate.FailureKind = ovl_fail_bad_deduction; 6989 Candidate.IsSurrogate = false; 6990 Candidate.IgnoreObjectArgument = false; 6991 Candidate.ExplicitCallArguments = 1; 6992 Candidate.DeductionFailure = MakeDeductionFailureInfo(Context, Result, 6993 Info); 6994 return; 6995 } 6996 6997 // Add the conversion function template specialization produced by 6998 // template argument deduction as a candidate. 6999 assert(Specialization && "Missing function template specialization?"); 7000 AddConversionCandidate(Specialization, FoundDecl, ActingDC, From, ToType, 7001 CandidateSet, AllowObjCConversionOnExplicit, 7002 AllowResultConversion); 7003 } 7004 7005 /// AddSurrogateCandidate - Adds a "surrogate" candidate function that 7006 /// converts the given @c Object to a function pointer via the 7007 /// conversion function @c Conversion, and then attempts to call it 7008 /// with the given arguments (C++ [over.call.object]p2-4). Proto is 7009 /// the type of function that we'll eventually be calling. 7010 void Sema::AddSurrogateCandidate(CXXConversionDecl *Conversion, 7011 DeclAccessPair FoundDecl, 7012 CXXRecordDecl *ActingContext, 7013 const FunctionProtoType *Proto, 7014 Expr *Object, 7015 ArrayRef<Expr *> Args, 7016 OverloadCandidateSet& CandidateSet) { 7017 if (!CandidateSet.isNewCandidate(Conversion)) 7018 return; 7019 7020 // Overload resolution is always an unevaluated context. 7021 EnterExpressionEvaluationContext Unevaluated( 7022 *this, Sema::ExpressionEvaluationContext::Unevaluated); 7023 7024 OverloadCandidate &Candidate = CandidateSet.addCandidate(Args.size() + 1); 7025 Candidate.FoundDecl = FoundDecl; 7026 Candidate.Function = nullptr; 7027 Candidate.Surrogate = Conversion; 7028 Candidate.Viable = true; 7029 Candidate.IsSurrogate = true; 7030 Candidate.IgnoreObjectArgument = false; 7031 Candidate.ExplicitCallArguments = Args.size(); 7032 7033 // Determine the implicit conversion sequence for the implicit 7034 // object parameter. 7035 ImplicitConversionSequence ObjectInit = TryObjectArgumentInitialization( 7036 *this, CandidateSet.getLocation(), Object->getType(), 7037 Object->Classify(Context), Conversion, ActingContext); 7038 if (ObjectInit.isBad()) { 7039 Candidate.Viable = false; 7040 Candidate.FailureKind = ovl_fail_bad_conversion; 7041 Candidate.Conversions[0] = ObjectInit; 7042 return; 7043 } 7044 7045 // The first conversion is actually a user-defined conversion whose 7046 // first conversion is ObjectInit's standard conversion (which is 7047 // effectively a reference binding). Record it as such. 7048 Candidate.Conversions[0].setUserDefined(); 7049 Candidate.Conversions[0].UserDefined.Before = ObjectInit.Standard; 7050 Candidate.Conversions[0].UserDefined.EllipsisConversion = false; 7051 Candidate.Conversions[0].UserDefined.HadMultipleCandidates = false; 7052 Candidate.Conversions[0].UserDefined.ConversionFunction = Conversion; 7053 Candidate.Conversions[0].UserDefined.FoundConversionFunction = FoundDecl; 7054 Candidate.Conversions[0].UserDefined.After 7055 = Candidate.Conversions[0].UserDefined.Before; 7056 Candidate.Conversions[0].UserDefined.After.setAsIdentityConversion(); 7057 7058 // Find the 7059 unsigned NumParams = Proto->getNumParams(); 7060 7061 // (C++ 13.3.2p2): A candidate function having fewer than m 7062 // parameters is viable only if it has an ellipsis in its parameter 7063 // list (8.3.5). 7064 if (Args.size() > NumParams && !Proto->isVariadic()) { 7065 Candidate.Viable = false; 7066 Candidate.FailureKind = ovl_fail_too_many_arguments; 7067 return; 7068 } 7069 7070 // Function types don't have any default arguments, so just check if 7071 // we have enough arguments. 7072 if (Args.size() < NumParams) { 7073 // Not enough arguments. 7074 Candidate.Viable = false; 7075 Candidate.FailureKind = ovl_fail_too_few_arguments; 7076 return; 7077 } 7078 7079 // Determine the implicit conversion sequences for each of the 7080 // arguments. 7081 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 7082 if (ArgIdx < NumParams) { 7083 // (C++ 13.3.2p3): for F to be a viable function, there shall 7084 // exist for each argument an implicit conversion sequence 7085 // (13.3.3.1) that converts that argument to the corresponding 7086 // parameter of F. 7087 QualType ParamType = Proto->getParamType(ArgIdx); 7088 Candidate.Conversions[ArgIdx + 1] 7089 = TryCopyInitialization(*this, Args[ArgIdx], ParamType, 7090 /*SuppressUserConversions=*/false, 7091 /*InOverloadResolution=*/false, 7092 /*AllowObjCWritebackConversion=*/ 7093 getLangOpts().ObjCAutoRefCount); 7094 if (Candidate.Conversions[ArgIdx + 1].isBad()) { 7095 Candidate.Viable = false; 7096 Candidate.FailureKind = ovl_fail_bad_conversion; 7097 return; 7098 } 7099 } else { 7100 // (C++ 13.3.2p2): For the purposes of overload resolution, any 7101 // argument for which there is no corresponding parameter is 7102 // considered to ""match the ellipsis" (C+ 13.3.3.1.3). 7103 Candidate.Conversions[ArgIdx + 1].setEllipsis(); 7104 } 7105 } 7106 7107 if (EnableIfAttr *FailedAttr = CheckEnableIf(Conversion, None)) { 7108 Candidate.Viable = false; 7109 Candidate.FailureKind = ovl_fail_enable_if; 7110 Candidate.DeductionFailure.Data = FailedAttr; 7111 return; 7112 } 7113 } 7114 7115 /// \brief Add overload candidates for overloaded operators that are 7116 /// member functions. 7117 /// 7118 /// Add the overloaded operator candidates that are member functions 7119 /// for the operator Op that was used in an operator expression such 7120 /// as "x Op y". , Args/NumArgs provides the operator arguments, and 7121 /// CandidateSet will store the added overload candidates. (C++ 7122 /// [over.match.oper]). 7123 void Sema::AddMemberOperatorCandidates(OverloadedOperatorKind Op, 7124 SourceLocation OpLoc, 7125 ArrayRef<Expr *> Args, 7126 OverloadCandidateSet& CandidateSet, 7127 SourceRange OpRange) { 7128 DeclarationName OpName = Context.DeclarationNames.getCXXOperatorName(Op); 7129 7130 // C++ [over.match.oper]p3: 7131 // For a unary operator @ with an operand of a type whose 7132 // cv-unqualified version is T1, and for a binary operator @ with 7133 // a left operand of a type whose cv-unqualified version is T1 and 7134 // a right operand of a type whose cv-unqualified version is T2, 7135 // three sets of candidate functions, designated member 7136 // candidates, non-member candidates and built-in candidates, are 7137 // constructed as follows: 7138 QualType T1 = Args[0]->getType(); 7139 7140 // -- If T1 is a complete class type or a class currently being 7141 // defined, the set of member candidates is the result of the 7142 // qualified lookup of T1::operator@ (13.3.1.1.1); otherwise, 7143 // the set of member candidates is empty. 7144 if (const RecordType *T1Rec = T1->getAs<RecordType>()) { 7145 // Complete the type if it can be completed. 7146 if (!isCompleteType(OpLoc, T1) && !T1Rec->isBeingDefined()) 7147 return; 7148 // If the type is neither complete nor being defined, bail out now. 7149 if (!T1Rec->getDecl()->getDefinition()) 7150 return; 7151 7152 LookupResult Operators(*this, OpName, OpLoc, LookupOrdinaryName); 7153 LookupQualifiedName(Operators, T1Rec->getDecl()); 7154 Operators.suppressDiagnostics(); 7155 7156 for (LookupResult::iterator Oper = Operators.begin(), 7157 OperEnd = Operators.end(); 7158 Oper != OperEnd; 7159 ++Oper) 7160 AddMethodCandidate(Oper.getPair(), Args[0]->getType(), 7161 Args[0]->Classify(Context), Args.slice(1), 7162 CandidateSet, /*SuppressUserConversions=*/false); 7163 } 7164 } 7165 7166 /// AddBuiltinCandidate - Add a candidate for a built-in 7167 /// operator. ResultTy and ParamTys are the result and parameter types 7168 /// of the built-in candidate, respectively. Args and NumArgs are the 7169 /// arguments being passed to the candidate. IsAssignmentOperator 7170 /// should be true when this built-in candidate is an assignment 7171 /// operator. NumContextualBoolArguments is the number of arguments 7172 /// (at the beginning of the argument list) that will be contextually 7173 /// converted to bool. 7174 void Sema::AddBuiltinCandidate(QualType *ParamTys, ArrayRef<Expr *> Args, 7175 OverloadCandidateSet& CandidateSet, 7176 bool IsAssignmentOperator, 7177 unsigned NumContextualBoolArguments) { 7178 // Overload resolution is always an unevaluated context. 7179 EnterExpressionEvaluationContext Unevaluated( 7180 *this, Sema::ExpressionEvaluationContext::Unevaluated); 7181 7182 // Add this candidate 7183 OverloadCandidate &Candidate = CandidateSet.addCandidate(Args.size()); 7184 Candidate.FoundDecl = DeclAccessPair::make(nullptr, AS_none); 7185 Candidate.Function = nullptr; 7186 Candidate.IsSurrogate = false; 7187 Candidate.IgnoreObjectArgument = false; 7188 std::copy(ParamTys, ParamTys + Args.size(), Candidate.BuiltinParamTypes); 7189 7190 // Determine the implicit conversion sequences for each of the 7191 // arguments. 7192 Candidate.Viable = true; 7193 Candidate.ExplicitCallArguments = Args.size(); 7194 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 7195 // C++ [over.match.oper]p4: 7196 // For the built-in assignment operators, conversions of the 7197 // left operand are restricted as follows: 7198 // -- no temporaries are introduced to hold the left operand, and 7199 // -- no user-defined conversions are applied to the left 7200 // operand to achieve a type match with the left-most 7201 // parameter of a built-in candidate. 7202 // 7203 // We block these conversions by turning off user-defined 7204 // conversions, since that is the only way that initialization of 7205 // a reference to a non-class type can occur from something that 7206 // is not of the same type. 7207 if (ArgIdx < NumContextualBoolArguments) { 7208 assert(ParamTys[ArgIdx] == Context.BoolTy && 7209 "Contextual conversion to bool requires bool type"); 7210 Candidate.Conversions[ArgIdx] 7211 = TryContextuallyConvertToBool(*this, Args[ArgIdx]); 7212 } else { 7213 Candidate.Conversions[ArgIdx] 7214 = TryCopyInitialization(*this, Args[ArgIdx], ParamTys[ArgIdx], 7215 ArgIdx == 0 && IsAssignmentOperator, 7216 /*InOverloadResolution=*/false, 7217 /*AllowObjCWritebackConversion=*/ 7218 getLangOpts().ObjCAutoRefCount); 7219 } 7220 if (Candidate.Conversions[ArgIdx].isBad()) { 7221 Candidate.Viable = false; 7222 Candidate.FailureKind = ovl_fail_bad_conversion; 7223 break; 7224 } 7225 } 7226 } 7227 7228 namespace { 7229 7230 /// BuiltinCandidateTypeSet - A set of types that will be used for the 7231 /// candidate operator functions for built-in operators (C++ 7232 /// [over.built]). The types are separated into pointer types and 7233 /// enumeration types. 7234 class BuiltinCandidateTypeSet { 7235 /// TypeSet - A set of types. 7236 typedef llvm::SetVector<QualType, SmallVector<QualType, 8>, 7237 llvm::SmallPtrSet<QualType, 8>> TypeSet; 7238 7239 /// PointerTypes - The set of pointer types that will be used in the 7240 /// built-in candidates. 7241 TypeSet PointerTypes; 7242 7243 /// MemberPointerTypes - The set of member pointer types that will be 7244 /// used in the built-in candidates. 7245 TypeSet MemberPointerTypes; 7246 7247 /// EnumerationTypes - The set of enumeration types that will be 7248 /// used in the built-in candidates. 7249 TypeSet EnumerationTypes; 7250 7251 /// \brief The set of vector types that will be used in the built-in 7252 /// candidates. 7253 TypeSet VectorTypes; 7254 7255 /// \brief A flag indicating non-record types are viable candidates 7256 bool HasNonRecordTypes; 7257 7258 /// \brief A flag indicating whether either arithmetic or enumeration types 7259 /// were present in the candidate set. 7260 bool HasArithmeticOrEnumeralTypes; 7261 7262 /// \brief A flag indicating whether the nullptr type was present in the 7263 /// candidate set. 7264 bool HasNullPtrType; 7265 7266 /// Sema - The semantic analysis instance where we are building the 7267 /// candidate type set. 7268 Sema &SemaRef; 7269 7270 /// Context - The AST context in which we will build the type sets. 7271 ASTContext &Context; 7272 7273 bool AddPointerWithMoreQualifiedTypeVariants(QualType Ty, 7274 const Qualifiers &VisibleQuals); 7275 bool AddMemberPointerWithMoreQualifiedTypeVariants(QualType Ty); 7276 7277 public: 7278 /// iterator - Iterates through the types that are part of the set. 7279 typedef TypeSet::iterator iterator; 7280 7281 BuiltinCandidateTypeSet(Sema &SemaRef) 7282 : HasNonRecordTypes(false), 7283 HasArithmeticOrEnumeralTypes(false), 7284 HasNullPtrType(false), 7285 SemaRef(SemaRef), 7286 Context(SemaRef.Context) { } 7287 7288 void AddTypesConvertedFrom(QualType Ty, 7289 SourceLocation Loc, 7290 bool AllowUserConversions, 7291 bool AllowExplicitConversions, 7292 const Qualifiers &VisibleTypeConversionsQuals); 7293 7294 /// pointer_begin - First pointer type found; 7295 iterator pointer_begin() { return PointerTypes.begin(); } 7296 7297 /// pointer_end - Past the last pointer type found; 7298 iterator pointer_end() { return PointerTypes.end(); } 7299 7300 /// member_pointer_begin - First member pointer type found; 7301 iterator member_pointer_begin() { return MemberPointerTypes.begin(); } 7302 7303 /// member_pointer_end - Past the last member pointer type found; 7304 iterator member_pointer_end() { return MemberPointerTypes.end(); } 7305 7306 /// enumeration_begin - First enumeration type found; 7307 iterator enumeration_begin() { return EnumerationTypes.begin(); } 7308 7309 /// enumeration_end - Past the last enumeration type found; 7310 iterator enumeration_end() { return EnumerationTypes.end(); } 7311 7312 iterator vector_begin() { return VectorTypes.begin(); } 7313 iterator vector_end() { return VectorTypes.end(); } 7314 7315 bool hasNonRecordTypes() { return HasNonRecordTypes; } 7316 bool hasArithmeticOrEnumeralTypes() { return HasArithmeticOrEnumeralTypes; } 7317 bool hasNullPtrType() const { return HasNullPtrType; } 7318 }; 7319 7320 } // end anonymous namespace 7321 7322 /// AddPointerWithMoreQualifiedTypeVariants - Add the pointer type @p Ty to 7323 /// the set of pointer types along with any more-qualified variants of 7324 /// that type. For example, if @p Ty is "int const *", this routine 7325 /// will add "int const *", "int const volatile *", "int const 7326 /// restrict *", and "int const volatile restrict *" to the set of 7327 /// pointer types. Returns true if the add of @p Ty itself succeeded, 7328 /// false otherwise. 7329 /// 7330 /// FIXME: what to do about extended qualifiers? 7331 bool 7332 BuiltinCandidateTypeSet::AddPointerWithMoreQualifiedTypeVariants(QualType Ty, 7333 const Qualifiers &VisibleQuals) { 7334 7335 // Insert this type. 7336 if (!PointerTypes.insert(Ty)) 7337 return false; 7338 7339 QualType PointeeTy; 7340 const PointerType *PointerTy = Ty->getAs<PointerType>(); 7341 bool buildObjCPtr = false; 7342 if (!PointerTy) { 7343 const ObjCObjectPointerType *PTy = Ty->castAs<ObjCObjectPointerType>(); 7344 PointeeTy = PTy->getPointeeType(); 7345 buildObjCPtr = true; 7346 } else { 7347 PointeeTy = PointerTy->getPointeeType(); 7348 } 7349 7350 // Don't add qualified variants of arrays. For one, they're not allowed 7351 // (the qualifier would sink to the element type), and for another, the 7352 // only overload situation where it matters is subscript or pointer +- int, 7353 // and those shouldn't have qualifier variants anyway. 7354 if (PointeeTy->isArrayType()) 7355 return true; 7356 7357 unsigned BaseCVR = PointeeTy.getCVRQualifiers(); 7358 bool hasVolatile = VisibleQuals.hasVolatile(); 7359 bool hasRestrict = VisibleQuals.hasRestrict(); 7360 7361 // Iterate through all strict supersets of BaseCVR. 7362 for (unsigned CVR = BaseCVR+1; CVR <= Qualifiers::CVRMask; ++CVR) { 7363 if ((CVR | BaseCVR) != CVR) continue; 7364 // Skip over volatile if no volatile found anywhere in the types. 7365 if ((CVR & Qualifiers::Volatile) && !hasVolatile) continue; 7366 7367 // Skip over restrict if no restrict found anywhere in the types, or if 7368 // the type cannot be restrict-qualified. 7369 if ((CVR & Qualifiers::Restrict) && 7370 (!hasRestrict || 7371 (!(PointeeTy->isAnyPointerType() || PointeeTy->isReferenceType())))) 7372 continue; 7373 7374 // Build qualified pointee type. 7375 QualType QPointeeTy = Context.getCVRQualifiedType(PointeeTy, CVR); 7376 7377 // Build qualified pointer type. 7378 QualType QPointerTy; 7379 if (!buildObjCPtr) 7380 QPointerTy = Context.getPointerType(QPointeeTy); 7381 else 7382 QPointerTy = Context.getObjCObjectPointerType(QPointeeTy); 7383 7384 // Insert qualified pointer type. 7385 PointerTypes.insert(QPointerTy); 7386 } 7387 7388 return true; 7389 } 7390 7391 /// AddMemberPointerWithMoreQualifiedTypeVariants - Add the pointer type @p Ty 7392 /// to the set of pointer types along with any more-qualified variants of 7393 /// that type. For example, if @p Ty is "int const *", this routine 7394 /// will add "int const *", "int const volatile *", "int const 7395 /// restrict *", and "int const volatile restrict *" to the set of 7396 /// pointer types. Returns true if the add of @p Ty itself succeeded, 7397 /// false otherwise. 7398 /// 7399 /// FIXME: what to do about extended qualifiers? 7400 bool 7401 BuiltinCandidateTypeSet::AddMemberPointerWithMoreQualifiedTypeVariants( 7402 QualType Ty) { 7403 // Insert this type. 7404 if (!MemberPointerTypes.insert(Ty)) 7405 return false; 7406 7407 const MemberPointerType *PointerTy = Ty->getAs<MemberPointerType>(); 7408 assert(PointerTy && "type was not a member pointer type!"); 7409 7410 QualType PointeeTy = PointerTy->getPointeeType(); 7411 // Don't add qualified variants of arrays. For one, they're not allowed 7412 // (the qualifier would sink to the element type), and for another, the 7413 // only overload situation where it matters is subscript or pointer +- int, 7414 // and those shouldn't have qualifier variants anyway. 7415 if (PointeeTy->isArrayType()) 7416 return true; 7417 const Type *ClassTy = PointerTy->getClass(); 7418 7419 // Iterate through all strict supersets of the pointee type's CVR 7420 // qualifiers. 7421 unsigned BaseCVR = PointeeTy.getCVRQualifiers(); 7422 for (unsigned CVR = BaseCVR+1; CVR <= Qualifiers::CVRMask; ++CVR) { 7423 if ((CVR | BaseCVR) != CVR) continue; 7424 7425 QualType QPointeeTy = Context.getCVRQualifiedType(PointeeTy, CVR); 7426 MemberPointerTypes.insert( 7427 Context.getMemberPointerType(QPointeeTy, ClassTy)); 7428 } 7429 7430 return true; 7431 } 7432 7433 /// AddTypesConvertedFrom - Add each of the types to which the type @p 7434 /// Ty can be implicit converted to the given set of @p Types. We're 7435 /// primarily interested in pointer types and enumeration types. We also 7436 /// take member pointer types, for the conditional operator. 7437 /// AllowUserConversions is true if we should look at the conversion 7438 /// functions of a class type, and AllowExplicitConversions if we 7439 /// should also include the explicit conversion functions of a class 7440 /// type. 7441 void 7442 BuiltinCandidateTypeSet::AddTypesConvertedFrom(QualType Ty, 7443 SourceLocation Loc, 7444 bool AllowUserConversions, 7445 bool AllowExplicitConversions, 7446 const Qualifiers &VisibleQuals) { 7447 // Only deal with canonical types. 7448 Ty = Context.getCanonicalType(Ty); 7449 7450 // Look through reference types; they aren't part of the type of an 7451 // expression for the purposes of conversions. 7452 if (const ReferenceType *RefTy = Ty->getAs<ReferenceType>()) 7453 Ty = RefTy->getPointeeType(); 7454 7455 // If we're dealing with an array type, decay to the pointer. 7456 if (Ty->isArrayType()) 7457 Ty = SemaRef.Context.getArrayDecayedType(Ty); 7458 7459 // Otherwise, we don't care about qualifiers on the type. 7460 Ty = Ty.getLocalUnqualifiedType(); 7461 7462 // Flag if we ever add a non-record type. 7463 const RecordType *TyRec = Ty->getAs<RecordType>(); 7464 HasNonRecordTypes = HasNonRecordTypes || !TyRec; 7465 7466 // Flag if we encounter an arithmetic type. 7467 HasArithmeticOrEnumeralTypes = 7468 HasArithmeticOrEnumeralTypes || Ty->isArithmeticType(); 7469 7470 if (Ty->isObjCIdType() || Ty->isObjCClassType()) 7471 PointerTypes.insert(Ty); 7472 else if (Ty->getAs<PointerType>() || Ty->getAs<ObjCObjectPointerType>()) { 7473 // Insert our type, and its more-qualified variants, into the set 7474 // of types. 7475 if (!AddPointerWithMoreQualifiedTypeVariants(Ty, VisibleQuals)) 7476 return; 7477 } else if (Ty->isMemberPointerType()) { 7478 // Member pointers are far easier, since the pointee can't be converted. 7479 if (!AddMemberPointerWithMoreQualifiedTypeVariants(Ty)) 7480 return; 7481 } else if (Ty->isEnumeralType()) { 7482 HasArithmeticOrEnumeralTypes = true; 7483 EnumerationTypes.insert(Ty); 7484 } else if (Ty->isVectorType()) { 7485 // We treat vector types as arithmetic types in many contexts as an 7486 // extension. 7487 HasArithmeticOrEnumeralTypes = true; 7488 VectorTypes.insert(Ty); 7489 } else if (Ty->isNullPtrType()) { 7490 HasNullPtrType = true; 7491 } else if (AllowUserConversions && TyRec) { 7492 // No conversion functions in incomplete types. 7493 if (!SemaRef.isCompleteType(Loc, Ty)) 7494 return; 7495 7496 CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(TyRec->getDecl()); 7497 for (NamedDecl *D : ClassDecl->getVisibleConversionFunctions()) { 7498 if (isa<UsingShadowDecl>(D)) 7499 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 7500 7501 // Skip conversion function templates; they don't tell us anything 7502 // about which builtin types we can convert to. 7503 if (isa<FunctionTemplateDecl>(D)) 7504 continue; 7505 7506 CXXConversionDecl *Conv = cast<CXXConversionDecl>(D); 7507 if (AllowExplicitConversions || !Conv->isExplicit()) { 7508 AddTypesConvertedFrom(Conv->getConversionType(), Loc, false, false, 7509 VisibleQuals); 7510 } 7511 } 7512 } 7513 } 7514 7515 /// \brief Helper function for AddBuiltinOperatorCandidates() that adds 7516 /// the volatile- and non-volatile-qualified assignment operators for the 7517 /// given type to the candidate set. 7518 static void AddBuiltinAssignmentOperatorCandidates(Sema &S, 7519 QualType T, 7520 ArrayRef<Expr *> Args, 7521 OverloadCandidateSet &CandidateSet) { 7522 QualType ParamTypes[2]; 7523 7524 // T& operator=(T&, T) 7525 ParamTypes[0] = S.Context.getLValueReferenceType(T); 7526 ParamTypes[1] = T; 7527 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 7528 /*IsAssignmentOperator=*/true); 7529 7530 if (!S.Context.getCanonicalType(T).isVolatileQualified()) { 7531 // volatile T& operator=(volatile T&, T) 7532 ParamTypes[0] 7533 = S.Context.getLValueReferenceType(S.Context.getVolatileType(T)); 7534 ParamTypes[1] = T; 7535 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 7536 /*IsAssignmentOperator=*/true); 7537 } 7538 } 7539 7540 /// CollectVRQualifiers - This routine returns Volatile/Restrict qualifiers, 7541 /// if any, found in visible type conversion functions found in ArgExpr's type. 7542 static Qualifiers CollectVRQualifiers(ASTContext &Context, Expr* ArgExpr) { 7543 Qualifiers VRQuals; 7544 const RecordType *TyRec; 7545 if (const MemberPointerType *RHSMPType = 7546 ArgExpr->getType()->getAs<MemberPointerType>()) 7547 TyRec = RHSMPType->getClass()->getAs<RecordType>(); 7548 else 7549 TyRec = ArgExpr->getType()->getAs<RecordType>(); 7550 if (!TyRec) { 7551 // Just to be safe, assume the worst case. 7552 VRQuals.addVolatile(); 7553 VRQuals.addRestrict(); 7554 return VRQuals; 7555 } 7556 7557 CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(TyRec->getDecl()); 7558 if (!ClassDecl->hasDefinition()) 7559 return VRQuals; 7560 7561 for (NamedDecl *D : ClassDecl->getVisibleConversionFunctions()) { 7562 if (isa<UsingShadowDecl>(D)) 7563 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 7564 if (CXXConversionDecl *Conv = dyn_cast<CXXConversionDecl>(D)) { 7565 QualType CanTy = Context.getCanonicalType(Conv->getConversionType()); 7566 if (const ReferenceType *ResTypeRef = CanTy->getAs<ReferenceType>()) 7567 CanTy = ResTypeRef->getPointeeType(); 7568 // Need to go down the pointer/mempointer chain and add qualifiers 7569 // as see them. 7570 bool done = false; 7571 while (!done) { 7572 if (CanTy.isRestrictQualified()) 7573 VRQuals.addRestrict(); 7574 if (const PointerType *ResTypePtr = CanTy->getAs<PointerType>()) 7575 CanTy = ResTypePtr->getPointeeType(); 7576 else if (const MemberPointerType *ResTypeMPtr = 7577 CanTy->getAs<MemberPointerType>()) 7578 CanTy = ResTypeMPtr->getPointeeType(); 7579 else 7580 done = true; 7581 if (CanTy.isVolatileQualified()) 7582 VRQuals.addVolatile(); 7583 if (VRQuals.hasRestrict() && VRQuals.hasVolatile()) 7584 return VRQuals; 7585 } 7586 } 7587 } 7588 return VRQuals; 7589 } 7590 7591 namespace { 7592 7593 /// \brief Helper class to manage the addition of builtin operator overload 7594 /// candidates. It provides shared state and utility methods used throughout 7595 /// the process, as well as a helper method to add each group of builtin 7596 /// operator overloads from the standard to a candidate set. 7597 class BuiltinOperatorOverloadBuilder { 7598 // Common instance state available to all overload candidate addition methods. 7599 Sema &S; 7600 ArrayRef<Expr *> Args; 7601 Qualifiers VisibleTypeConversionsQuals; 7602 bool HasArithmeticOrEnumeralCandidateType; 7603 SmallVectorImpl<BuiltinCandidateTypeSet> &CandidateTypes; 7604 OverloadCandidateSet &CandidateSet; 7605 7606 // Define some constants used to index and iterate over the arithemetic types 7607 // provided via the getArithmeticType() method below. 7608 // The "promoted arithmetic types" are the arithmetic 7609 // types are that preserved by promotion (C++ [over.built]p2). 7610 static const unsigned FirstIntegralType = 4; 7611 static const unsigned LastIntegralType = 21; 7612 static const unsigned FirstPromotedIntegralType = 4, 7613 LastPromotedIntegralType = 12; 7614 static const unsigned FirstPromotedArithmeticType = 0, 7615 LastPromotedArithmeticType = 12; 7616 static const unsigned NumArithmeticTypes = 21; 7617 7618 /// \brief Get the canonical type for a given arithmetic type index. 7619 CanQualType getArithmeticType(unsigned index) { 7620 assert(index < NumArithmeticTypes); 7621 static CanQualType ASTContext::* const 7622 ArithmeticTypes[NumArithmeticTypes] = { 7623 // Start of promoted types. 7624 &ASTContext::FloatTy, 7625 &ASTContext::DoubleTy, 7626 &ASTContext::LongDoubleTy, 7627 &ASTContext::Float128Ty, 7628 7629 // Start of integral types. 7630 &ASTContext::IntTy, 7631 &ASTContext::LongTy, 7632 &ASTContext::LongLongTy, 7633 &ASTContext::Int128Ty, 7634 &ASTContext::UnsignedIntTy, 7635 &ASTContext::UnsignedLongTy, 7636 &ASTContext::UnsignedLongLongTy, 7637 &ASTContext::UnsignedInt128Ty, 7638 // End of promoted types. 7639 7640 &ASTContext::BoolTy, 7641 &ASTContext::CharTy, 7642 &ASTContext::WCharTy, 7643 &ASTContext::Char16Ty, 7644 &ASTContext::Char32Ty, 7645 &ASTContext::SignedCharTy, 7646 &ASTContext::ShortTy, 7647 &ASTContext::UnsignedCharTy, 7648 &ASTContext::UnsignedShortTy, 7649 // End of integral types. 7650 // FIXME: What about complex? What about half? 7651 }; 7652 return S.Context.*ArithmeticTypes[index]; 7653 } 7654 7655 /// \brief Helper method to factor out the common pattern of adding overloads 7656 /// for '++' and '--' builtin operators. 7657 void addPlusPlusMinusMinusStyleOverloads(QualType CandidateTy, 7658 bool HasVolatile, 7659 bool HasRestrict) { 7660 QualType ParamTypes[2] = { 7661 S.Context.getLValueReferenceType(CandidateTy), 7662 S.Context.IntTy 7663 }; 7664 7665 // Non-volatile version. 7666 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7667 7668 // Use a heuristic to reduce number of builtin candidates in the set: 7669 // add volatile version only if there are conversions to a volatile type. 7670 if (HasVolatile) { 7671 ParamTypes[0] = 7672 S.Context.getLValueReferenceType( 7673 S.Context.getVolatileType(CandidateTy)); 7674 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7675 } 7676 7677 // Add restrict version only if there are conversions to a restrict type 7678 // and our candidate type is a non-restrict-qualified pointer. 7679 if (HasRestrict && CandidateTy->isAnyPointerType() && 7680 !CandidateTy.isRestrictQualified()) { 7681 ParamTypes[0] 7682 = S.Context.getLValueReferenceType( 7683 S.Context.getCVRQualifiedType(CandidateTy, Qualifiers::Restrict)); 7684 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7685 7686 if (HasVolatile) { 7687 ParamTypes[0] 7688 = S.Context.getLValueReferenceType( 7689 S.Context.getCVRQualifiedType(CandidateTy, 7690 (Qualifiers::Volatile | 7691 Qualifiers::Restrict))); 7692 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7693 } 7694 } 7695 7696 } 7697 7698 public: 7699 BuiltinOperatorOverloadBuilder( 7700 Sema &S, ArrayRef<Expr *> Args, 7701 Qualifiers VisibleTypeConversionsQuals, 7702 bool HasArithmeticOrEnumeralCandidateType, 7703 SmallVectorImpl<BuiltinCandidateTypeSet> &CandidateTypes, 7704 OverloadCandidateSet &CandidateSet) 7705 : S(S), Args(Args), 7706 VisibleTypeConversionsQuals(VisibleTypeConversionsQuals), 7707 HasArithmeticOrEnumeralCandidateType( 7708 HasArithmeticOrEnumeralCandidateType), 7709 CandidateTypes(CandidateTypes), 7710 CandidateSet(CandidateSet) { 7711 // Validate some of our static helper constants in debug builds. 7712 assert(getArithmeticType(FirstPromotedIntegralType) == S.Context.IntTy && 7713 "Invalid first promoted integral type"); 7714 assert(getArithmeticType(LastPromotedIntegralType - 1) 7715 == S.Context.UnsignedInt128Ty && 7716 "Invalid last promoted integral type"); 7717 assert(getArithmeticType(FirstPromotedArithmeticType) 7718 == S.Context.FloatTy && 7719 "Invalid first promoted arithmetic type"); 7720 assert(getArithmeticType(LastPromotedArithmeticType - 1) 7721 == S.Context.UnsignedInt128Ty && 7722 "Invalid last promoted arithmetic type"); 7723 } 7724 7725 // C++ [over.built]p3: 7726 // 7727 // For every pair (T, VQ), where T is an arithmetic type, and VQ 7728 // is either volatile or empty, there exist candidate operator 7729 // functions of the form 7730 // 7731 // VQ T& operator++(VQ T&); 7732 // T operator++(VQ T&, int); 7733 // 7734 // C++ [over.built]p4: 7735 // 7736 // For every pair (T, VQ), where T is an arithmetic type other 7737 // than bool, and VQ is either volatile or empty, there exist 7738 // candidate operator functions of the form 7739 // 7740 // VQ T& operator--(VQ T&); 7741 // T operator--(VQ T&, int); 7742 void addPlusPlusMinusMinusArithmeticOverloads(OverloadedOperatorKind Op) { 7743 if (!HasArithmeticOrEnumeralCandidateType) 7744 return; 7745 7746 for (unsigned Arith = (Op == OO_PlusPlus? 0 : 1); 7747 Arith < NumArithmeticTypes; ++Arith) { 7748 addPlusPlusMinusMinusStyleOverloads( 7749 getArithmeticType(Arith), 7750 VisibleTypeConversionsQuals.hasVolatile(), 7751 VisibleTypeConversionsQuals.hasRestrict()); 7752 } 7753 } 7754 7755 // C++ [over.built]p5: 7756 // 7757 // For every pair (T, VQ), where T is a cv-qualified or 7758 // cv-unqualified object type, and VQ is either volatile or 7759 // empty, there exist candidate operator functions of the form 7760 // 7761 // T*VQ& operator++(T*VQ&); 7762 // T*VQ& operator--(T*VQ&); 7763 // T* operator++(T*VQ&, int); 7764 // T* operator--(T*VQ&, int); 7765 void addPlusPlusMinusMinusPointerOverloads() { 7766 for (BuiltinCandidateTypeSet::iterator 7767 Ptr = CandidateTypes[0].pointer_begin(), 7768 PtrEnd = CandidateTypes[0].pointer_end(); 7769 Ptr != PtrEnd; ++Ptr) { 7770 // Skip pointer types that aren't pointers to object types. 7771 if (!(*Ptr)->getPointeeType()->isObjectType()) 7772 continue; 7773 7774 addPlusPlusMinusMinusStyleOverloads(*Ptr, 7775 (!(*Ptr).isVolatileQualified() && 7776 VisibleTypeConversionsQuals.hasVolatile()), 7777 (!(*Ptr).isRestrictQualified() && 7778 VisibleTypeConversionsQuals.hasRestrict())); 7779 } 7780 } 7781 7782 // C++ [over.built]p6: 7783 // For every cv-qualified or cv-unqualified object type T, there 7784 // exist candidate operator functions of the form 7785 // 7786 // T& operator*(T*); 7787 // 7788 // C++ [over.built]p7: 7789 // For every function type T that does not have cv-qualifiers or a 7790 // ref-qualifier, there exist candidate operator functions of the form 7791 // T& operator*(T*); 7792 void addUnaryStarPointerOverloads() { 7793 for (BuiltinCandidateTypeSet::iterator 7794 Ptr = CandidateTypes[0].pointer_begin(), 7795 PtrEnd = CandidateTypes[0].pointer_end(); 7796 Ptr != PtrEnd; ++Ptr) { 7797 QualType ParamTy = *Ptr; 7798 QualType PointeeTy = ParamTy->getPointeeType(); 7799 if (!PointeeTy->isObjectType() && !PointeeTy->isFunctionType()) 7800 continue; 7801 7802 if (const FunctionProtoType *Proto =PointeeTy->getAs<FunctionProtoType>()) 7803 if (Proto->getTypeQuals() || Proto->getRefQualifier()) 7804 continue; 7805 7806 S.AddBuiltinCandidate(&ParamTy, Args, CandidateSet); 7807 } 7808 } 7809 7810 // C++ [over.built]p9: 7811 // For every promoted arithmetic type T, there exist candidate 7812 // operator functions of the form 7813 // 7814 // T operator+(T); 7815 // T operator-(T); 7816 void addUnaryPlusOrMinusArithmeticOverloads() { 7817 if (!HasArithmeticOrEnumeralCandidateType) 7818 return; 7819 7820 for (unsigned Arith = FirstPromotedArithmeticType; 7821 Arith < LastPromotedArithmeticType; ++Arith) { 7822 QualType ArithTy = getArithmeticType(Arith); 7823 S.AddBuiltinCandidate(&ArithTy, Args, CandidateSet); 7824 } 7825 7826 // Extension: We also add these operators for vector types. 7827 for (BuiltinCandidateTypeSet::iterator 7828 Vec = CandidateTypes[0].vector_begin(), 7829 VecEnd = CandidateTypes[0].vector_end(); 7830 Vec != VecEnd; ++Vec) { 7831 QualType VecTy = *Vec; 7832 S.AddBuiltinCandidate(&VecTy, Args, CandidateSet); 7833 } 7834 } 7835 7836 // C++ [over.built]p8: 7837 // For every type T, there exist candidate operator functions of 7838 // the form 7839 // 7840 // T* operator+(T*); 7841 void addUnaryPlusPointerOverloads() { 7842 for (BuiltinCandidateTypeSet::iterator 7843 Ptr = CandidateTypes[0].pointer_begin(), 7844 PtrEnd = CandidateTypes[0].pointer_end(); 7845 Ptr != PtrEnd; ++Ptr) { 7846 QualType ParamTy = *Ptr; 7847 S.AddBuiltinCandidate(&ParamTy, Args, CandidateSet); 7848 } 7849 } 7850 7851 // C++ [over.built]p10: 7852 // For every promoted integral type T, there exist candidate 7853 // operator functions of the form 7854 // 7855 // T operator~(T); 7856 void addUnaryTildePromotedIntegralOverloads() { 7857 if (!HasArithmeticOrEnumeralCandidateType) 7858 return; 7859 7860 for (unsigned Int = FirstPromotedIntegralType; 7861 Int < LastPromotedIntegralType; ++Int) { 7862 QualType IntTy = getArithmeticType(Int); 7863 S.AddBuiltinCandidate(&IntTy, Args, CandidateSet); 7864 } 7865 7866 // Extension: We also add this operator for vector types. 7867 for (BuiltinCandidateTypeSet::iterator 7868 Vec = CandidateTypes[0].vector_begin(), 7869 VecEnd = CandidateTypes[0].vector_end(); 7870 Vec != VecEnd; ++Vec) { 7871 QualType VecTy = *Vec; 7872 S.AddBuiltinCandidate(&VecTy, Args, CandidateSet); 7873 } 7874 } 7875 7876 // C++ [over.match.oper]p16: 7877 // For every pointer to member type T or type std::nullptr_t, there 7878 // exist candidate operator functions of the form 7879 // 7880 // bool operator==(T,T); 7881 // bool operator!=(T,T); 7882 void addEqualEqualOrNotEqualMemberPointerOrNullptrOverloads() { 7883 /// Set of (canonical) types that we've already handled. 7884 llvm::SmallPtrSet<QualType, 8> AddedTypes; 7885 7886 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 7887 for (BuiltinCandidateTypeSet::iterator 7888 MemPtr = CandidateTypes[ArgIdx].member_pointer_begin(), 7889 MemPtrEnd = CandidateTypes[ArgIdx].member_pointer_end(); 7890 MemPtr != MemPtrEnd; 7891 ++MemPtr) { 7892 // Don't add the same builtin candidate twice. 7893 if (!AddedTypes.insert(S.Context.getCanonicalType(*MemPtr)).second) 7894 continue; 7895 7896 QualType ParamTypes[2] = { *MemPtr, *MemPtr }; 7897 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7898 } 7899 7900 if (CandidateTypes[ArgIdx].hasNullPtrType()) { 7901 CanQualType NullPtrTy = S.Context.getCanonicalType(S.Context.NullPtrTy); 7902 if (AddedTypes.insert(NullPtrTy).second) { 7903 QualType ParamTypes[2] = { NullPtrTy, NullPtrTy }; 7904 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7905 } 7906 } 7907 } 7908 } 7909 7910 // C++ [over.built]p15: 7911 // 7912 // For every T, where T is an enumeration type or a pointer type, 7913 // there exist candidate operator functions of the form 7914 // 7915 // bool operator<(T, T); 7916 // bool operator>(T, T); 7917 // bool operator<=(T, T); 7918 // bool operator>=(T, T); 7919 // bool operator==(T, T); 7920 // bool operator!=(T, T); 7921 void addRelationalPointerOrEnumeralOverloads() { 7922 // C++ [over.match.oper]p3: 7923 // [...]the built-in candidates include all of the candidate operator 7924 // functions defined in 13.6 that, compared to the given operator, [...] 7925 // do not have the same parameter-type-list as any non-template non-member 7926 // candidate. 7927 // 7928 // Note that in practice, this only affects enumeration types because there 7929 // aren't any built-in candidates of record type, and a user-defined operator 7930 // must have an operand of record or enumeration type. Also, the only other 7931 // overloaded operator with enumeration arguments, operator=, 7932 // cannot be overloaded for enumeration types, so this is the only place 7933 // where we must suppress candidates like this. 7934 llvm::DenseSet<std::pair<CanQualType, CanQualType> > 7935 UserDefinedBinaryOperators; 7936 7937 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 7938 if (CandidateTypes[ArgIdx].enumeration_begin() != 7939 CandidateTypes[ArgIdx].enumeration_end()) { 7940 for (OverloadCandidateSet::iterator C = CandidateSet.begin(), 7941 CEnd = CandidateSet.end(); 7942 C != CEnd; ++C) { 7943 if (!C->Viable || !C->Function || C->Function->getNumParams() != 2) 7944 continue; 7945 7946 if (C->Function->isFunctionTemplateSpecialization()) 7947 continue; 7948 7949 QualType FirstParamType = 7950 C->Function->getParamDecl(0)->getType().getUnqualifiedType(); 7951 QualType SecondParamType = 7952 C->Function->getParamDecl(1)->getType().getUnqualifiedType(); 7953 7954 // Skip if either parameter isn't of enumeral type. 7955 if (!FirstParamType->isEnumeralType() || 7956 !SecondParamType->isEnumeralType()) 7957 continue; 7958 7959 // Add this operator to the set of known user-defined operators. 7960 UserDefinedBinaryOperators.insert( 7961 std::make_pair(S.Context.getCanonicalType(FirstParamType), 7962 S.Context.getCanonicalType(SecondParamType))); 7963 } 7964 } 7965 } 7966 7967 /// Set of (canonical) types that we've already handled. 7968 llvm::SmallPtrSet<QualType, 8> AddedTypes; 7969 7970 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 7971 for (BuiltinCandidateTypeSet::iterator 7972 Ptr = CandidateTypes[ArgIdx].pointer_begin(), 7973 PtrEnd = CandidateTypes[ArgIdx].pointer_end(); 7974 Ptr != PtrEnd; ++Ptr) { 7975 // Don't add the same builtin candidate twice. 7976 if (!AddedTypes.insert(S.Context.getCanonicalType(*Ptr)).second) 7977 continue; 7978 7979 QualType ParamTypes[2] = { *Ptr, *Ptr }; 7980 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7981 } 7982 for (BuiltinCandidateTypeSet::iterator 7983 Enum = CandidateTypes[ArgIdx].enumeration_begin(), 7984 EnumEnd = CandidateTypes[ArgIdx].enumeration_end(); 7985 Enum != EnumEnd; ++Enum) { 7986 CanQualType CanonType = S.Context.getCanonicalType(*Enum); 7987 7988 // Don't add the same builtin candidate twice, or if a user defined 7989 // candidate exists. 7990 if (!AddedTypes.insert(CanonType).second || 7991 UserDefinedBinaryOperators.count(std::make_pair(CanonType, 7992 CanonType))) 7993 continue; 7994 7995 QualType ParamTypes[2] = { *Enum, *Enum }; 7996 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 7997 } 7998 } 7999 } 8000 8001 // C++ [over.built]p13: 8002 // 8003 // For every cv-qualified or cv-unqualified object type T 8004 // there exist candidate operator functions of the form 8005 // 8006 // T* operator+(T*, ptrdiff_t); 8007 // T& operator[](T*, ptrdiff_t); [BELOW] 8008 // T* operator-(T*, ptrdiff_t); 8009 // T* operator+(ptrdiff_t, T*); 8010 // T& operator[](ptrdiff_t, T*); [BELOW] 8011 // 8012 // C++ [over.built]p14: 8013 // 8014 // For every T, where T is a pointer to object type, there 8015 // exist candidate operator functions of the form 8016 // 8017 // ptrdiff_t operator-(T, T); 8018 void addBinaryPlusOrMinusPointerOverloads(OverloadedOperatorKind Op) { 8019 /// Set of (canonical) types that we've already handled. 8020 llvm::SmallPtrSet<QualType, 8> AddedTypes; 8021 8022 for (int Arg = 0; Arg < 2; ++Arg) { 8023 QualType AsymmetricParamTypes[2] = { 8024 S.Context.getPointerDiffType(), 8025 S.Context.getPointerDiffType(), 8026 }; 8027 for (BuiltinCandidateTypeSet::iterator 8028 Ptr = CandidateTypes[Arg].pointer_begin(), 8029 PtrEnd = CandidateTypes[Arg].pointer_end(); 8030 Ptr != PtrEnd; ++Ptr) { 8031 QualType PointeeTy = (*Ptr)->getPointeeType(); 8032 if (!PointeeTy->isObjectType()) 8033 continue; 8034 8035 AsymmetricParamTypes[Arg] = *Ptr; 8036 if (Arg == 0 || Op == OO_Plus) { 8037 // operator+(T*, ptrdiff_t) or operator-(T*, ptrdiff_t) 8038 // T* operator+(ptrdiff_t, T*); 8039 S.AddBuiltinCandidate(AsymmetricParamTypes, Args, CandidateSet); 8040 } 8041 if (Op == OO_Minus) { 8042 // ptrdiff_t operator-(T, T); 8043 if (!AddedTypes.insert(S.Context.getCanonicalType(*Ptr)).second) 8044 continue; 8045 8046 QualType ParamTypes[2] = { *Ptr, *Ptr }; 8047 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8048 } 8049 } 8050 } 8051 } 8052 8053 // C++ [over.built]p12: 8054 // 8055 // For every pair of promoted arithmetic types L and R, there 8056 // exist candidate operator functions of the form 8057 // 8058 // LR operator*(L, R); 8059 // LR operator/(L, R); 8060 // LR operator+(L, R); 8061 // LR operator-(L, R); 8062 // bool operator<(L, R); 8063 // bool operator>(L, R); 8064 // bool operator<=(L, R); 8065 // bool operator>=(L, R); 8066 // bool operator==(L, R); 8067 // bool operator!=(L, R); 8068 // 8069 // where LR is the result of the usual arithmetic conversions 8070 // between types L and R. 8071 // 8072 // C++ [over.built]p24: 8073 // 8074 // For every pair of promoted arithmetic types L and R, there exist 8075 // candidate operator functions of the form 8076 // 8077 // LR operator?(bool, L, R); 8078 // 8079 // where LR is the result of the usual arithmetic conversions 8080 // between types L and R. 8081 // Our candidates ignore the first parameter. 8082 void addGenericBinaryArithmeticOverloads() { 8083 if (!HasArithmeticOrEnumeralCandidateType) 8084 return; 8085 8086 for (unsigned Left = FirstPromotedArithmeticType; 8087 Left < LastPromotedArithmeticType; ++Left) { 8088 for (unsigned Right = FirstPromotedArithmeticType; 8089 Right < LastPromotedArithmeticType; ++Right) { 8090 QualType LandR[2] = { getArithmeticType(Left), 8091 getArithmeticType(Right) }; 8092 S.AddBuiltinCandidate(LandR, Args, CandidateSet); 8093 } 8094 } 8095 8096 // Extension: Add the binary operators ==, !=, <, <=, >=, >, *, /, and the 8097 // conditional operator for vector types. 8098 for (BuiltinCandidateTypeSet::iterator 8099 Vec1 = CandidateTypes[0].vector_begin(), 8100 Vec1End = CandidateTypes[0].vector_end(); 8101 Vec1 != Vec1End; ++Vec1) { 8102 for (BuiltinCandidateTypeSet::iterator 8103 Vec2 = CandidateTypes[1].vector_begin(), 8104 Vec2End = CandidateTypes[1].vector_end(); 8105 Vec2 != Vec2End; ++Vec2) { 8106 QualType LandR[2] = { *Vec1, *Vec2 }; 8107 S.AddBuiltinCandidate(LandR, Args, CandidateSet); 8108 } 8109 } 8110 } 8111 8112 // C++ [over.built]p17: 8113 // 8114 // For every pair of promoted integral types L and R, there 8115 // exist candidate operator functions of the form 8116 // 8117 // LR operator%(L, R); 8118 // LR operator&(L, R); 8119 // LR operator^(L, R); 8120 // LR operator|(L, R); 8121 // L operator<<(L, R); 8122 // L operator>>(L, R); 8123 // 8124 // where LR is the result of the usual arithmetic conversions 8125 // between types L and R. 8126 void addBinaryBitwiseArithmeticOverloads(OverloadedOperatorKind Op) { 8127 if (!HasArithmeticOrEnumeralCandidateType) 8128 return; 8129 8130 for (unsigned Left = FirstPromotedIntegralType; 8131 Left < LastPromotedIntegralType; ++Left) { 8132 for (unsigned Right = FirstPromotedIntegralType; 8133 Right < LastPromotedIntegralType; ++Right) { 8134 QualType LandR[2] = { getArithmeticType(Left), 8135 getArithmeticType(Right) }; 8136 S.AddBuiltinCandidate(LandR, Args, CandidateSet); 8137 } 8138 } 8139 } 8140 8141 // C++ [over.built]p20: 8142 // 8143 // For every pair (T, VQ), where T is an enumeration or 8144 // pointer to member type and VQ is either volatile or 8145 // empty, there exist candidate operator functions of the form 8146 // 8147 // VQ T& operator=(VQ T&, T); 8148 void addAssignmentMemberPointerOrEnumeralOverloads() { 8149 /// Set of (canonical) types that we've already handled. 8150 llvm::SmallPtrSet<QualType, 8> AddedTypes; 8151 8152 for (unsigned ArgIdx = 0; ArgIdx < 2; ++ArgIdx) { 8153 for (BuiltinCandidateTypeSet::iterator 8154 Enum = CandidateTypes[ArgIdx].enumeration_begin(), 8155 EnumEnd = CandidateTypes[ArgIdx].enumeration_end(); 8156 Enum != EnumEnd; ++Enum) { 8157 if (!AddedTypes.insert(S.Context.getCanonicalType(*Enum)).second) 8158 continue; 8159 8160 AddBuiltinAssignmentOperatorCandidates(S, *Enum, Args, CandidateSet); 8161 } 8162 8163 for (BuiltinCandidateTypeSet::iterator 8164 MemPtr = CandidateTypes[ArgIdx].member_pointer_begin(), 8165 MemPtrEnd = CandidateTypes[ArgIdx].member_pointer_end(); 8166 MemPtr != MemPtrEnd; ++MemPtr) { 8167 if (!AddedTypes.insert(S.Context.getCanonicalType(*MemPtr)).second) 8168 continue; 8169 8170 AddBuiltinAssignmentOperatorCandidates(S, *MemPtr, Args, CandidateSet); 8171 } 8172 } 8173 } 8174 8175 // C++ [over.built]p19: 8176 // 8177 // For every pair (T, VQ), where T is any type and VQ is either 8178 // volatile or empty, there exist candidate operator functions 8179 // of the form 8180 // 8181 // T*VQ& operator=(T*VQ&, T*); 8182 // 8183 // C++ [over.built]p21: 8184 // 8185 // For every pair (T, VQ), where T is a cv-qualified or 8186 // cv-unqualified object type and VQ is either volatile or 8187 // empty, there exist candidate operator functions of the form 8188 // 8189 // T*VQ& operator+=(T*VQ&, ptrdiff_t); 8190 // T*VQ& operator-=(T*VQ&, ptrdiff_t); 8191 void addAssignmentPointerOverloads(bool isEqualOp) { 8192 /// Set of (canonical) types that we've already handled. 8193 llvm::SmallPtrSet<QualType, 8> AddedTypes; 8194 8195 for (BuiltinCandidateTypeSet::iterator 8196 Ptr = CandidateTypes[0].pointer_begin(), 8197 PtrEnd = CandidateTypes[0].pointer_end(); 8198 Ptr != PtrEnd; ++Ptr) { 8199 // If this is operator=, keep track of the builtin candidates we added. 8200 if (isEqualOp) 8201 AddedTypes.insert(S.Context.getCanonicalType(*Ptr)); 8202 else if (!(*Ptr)->getPointeeType()->isObjectType()) 8203 continue; 8204 8205 // non-volatile version 8206 QualType ParamTypes[2] = { 8207 S.Context.getLValueReferenceType(*Ptr), 8208 isEqualOp ? *Ptr : S.Context.getPointerDiffType(), 8209 }; 8210 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8211 /*IsAssigmentOperator=*/ isEqualOp); 8212 8213 bool NeedVolatile = !(*Ptr).isVolatileQualified() && 8214 VisibleTypeConversionsQuals.hasVolatile(); 8215 if (NeedVolatile) { 8216 // volatile version 8217 ParamTypes[0] = 8218 S.Context.getLValueReferenceType(S.Context.getVolatileType(*Ptr)); 8219 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8220 /*IsAssigmentOperator=*/isEqualOp); 8221 } 8222 8223 if (!(*Ptr).isRestrictQualified() && 8224 VisibleTypeConversionsQuals.hasRestrict()) { 8225 // restrict version 8226 ParamTypes[0] 8227 = S.Context.getLValueReferenceType(S.Context.getRestrictType(*Ptr)); 8228 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8229 /*IsAssigmentOperator=*/isEqualOp); 8230 8231 if (NeedVolatile) { 8232 // volatile restrict version 8233 ParamTypes[0] 8234 = S.Context.getLValueReferenceType( 8235 S.Context.getCVRQualifiedType(*Ptr, 8236 (Qualifiers::Volatile | 8237 Qualifiers::Restrict))); 8238 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8239 /*IsAssigmentOperator=*/isEqualOp); 8240 } 8241 } 8242 } 8243 8244 if (isEqualOp) { 8245 for (BuiltinCandidateTypeSet::iterator 8246 Ptr = CandidateTypes[1].pointer_begin(), 8247 PtrEnd = CandidateTypes[1].pointer_end(); 8248 Ptr != PtrEnd; ++Ptr) { 8249 // Make sure we don't add the same candidate twice. 8250 if (!AddedTypes.insert(S.Context.getCanonicalType(*Ptr)).second) 8251 continue; 8252 8253 QualType ParamTypes[2] = { 8254 S.Context.getLValueReferenceType(*Ptr), 8255 *Ptr, 8256 }; 8257 8258 // non-volatile version 8259 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8260 /*IsAssigmentOperator=*/true); 8261 8262 bool NeedVolatile = !(*Ptr).isVolatileQualified() && 8263 VisibleTypeConversionsQuals.hasVolatile(); 8264 if (NeedVolatile) { 8265 // volatile version 8266 ParamTypes[0] = 8267 S.Context.getLValueReferenceType(S.Context.getVolatileType(*Ptr)); 8268 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8269 /*IsAssigmentOperator=*/true); 8270 } 8271 8272 if (!(*Ptr).isRestrictQualified() && 8273 VisibleTypeConversionsQuals.hasRestrict()) { 8274 // restrict version 8275 ParamTypes[0] 8276 = S.Context.getLValueReferenceType(S.Context.getRestrictType(*Ptr)); 8277 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8278 /*IsAssigmentOperator=*/true); 8279 8280 if (NeedVolatile) { 8281 // volatile restrict version 8282 ParamTypes[0] 8283 = S.Context.getLValueReferenceType( 8284 S.Context.getCVRQualifiedType(*Ptr, 8285 (Qualifiers::Volatile | 8286 Qualifiers::Restrict))); 8287 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8288 /*IsAssigmentOperator=*/true); 8289 } 8290 } 8291 } 8292 } 8293 } 8294 8295 // C++ [over.built]p18: 8296 // 8297 // For every triple (L, VQ, R), where L is an arithmetic type, 8298 // VQ is either volatile or empty, and R is a promoted 8299 // arithmetic type, there exist candidate operator functions of 8300 // the form 8301 // 8302 // VQ L& operator=(VQ L&, R); 8303 // VQ L& operator*=(VQ L&, R); 8304 // VQ L& operator/=(VQ L&, R); 8305 // VQ L& operator+=(VQ L&, R); 8306 // VQ L& operator-=(VQ L&, R); 8307 void addAssignmentArithmeticOverloads(bool isEqualOp) { 8308 if (!HasArithmeticOrEnumeralCandidateType) 8309 return; 8310 8311 for (unsigned Left = 0; Left < NumArithmeticTypes; ++Left) { 8312 for (unsigned Right = FirstPromotedArithmeticType; 8313 Right < LastPromotedArithmeticType; ++Right) { 8314 QualType ParamTypes[2]; 8315 ParamTypes[1] = getArithmeticType(Right); 8316 8317 // Add this built-in operator as a candidate (VQ is empty). 8318 ParamTypes[0] = 8319 S.Context.getLValueReferenceType(getArithmeticType(Left)); 8320 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8321 /*IsAssigmentOperator=*/isEqualOp); 8322 8323 // Add this built-in operator as a candidate (VQ is 'volatile'). 8324 if (VisibleTypeConversionsQuals.hasVolatile()) { 8325 ParamTypes[0] = 8326 S.Context.getVolatileType(getArithmeticType(Left)); 8327 ParamTypes[0] = S.Context.getLValueReferenceType(ParamTypes[0]); 8328 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8329 /*IsAssigmentOperator=*/isEqualOp); 8330 } 8331 } 8332 } 8333 8334 // Extension: Add the binary operators =, +=, -=, *=, /= for vector types. 8335 for (BuiltinCandidateTypeSet::iterator 8336 Vec1 = CandidateTypes[0].vector_begin(), 8337 Vec1End = CandidateTypes[0].vector_end(); 8338 Vec1 != Vec1End; ++Vec1) { 8339 for (BuiltinCandidateTypeSet::iterator 8340 Vec2 = CandidateTypes[1].vector_begin(), 8341 Vec2End = CandidateTypes[1].vector_end(); 8342 Vec2 != Vec2End; ++Vec2) { 8343 QualType ParamTypes[2]; 8344 ParamTypes[1] = *Vec2; 8345 // Add this built-in operator as a candidate (VQ is empty). 8346 ParamTypes[0] = S.Context.getLValueReferenceType(*Vec1); 8347 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8348 /*IsAssigmentOperator=*/isEqualOp); 8349 8350 // Add this built-in operator as a candidate (VQ is 'volatile'). 8351 if (VisibleTypeConversionsQuals.hasVolatile()) { 8352 ParamTypes[0] = S.Context.getVolatileType(*Vec1); 8353 ParamTypes[0] = S.Context.getLValueReferenceType(ParamTypes[0]); 8354 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8355 /*IsAssigmentOperator=*/isEqualOp); 8356 } 8357 } 8358 } 8359 } 8360 8361 // C++ [over.built]p22: 8362 // 8363 // For every triple (L, VQ, R), where L is an integral type, VQ 8364 // is either volatile or empty, and R is a promoted integral 8365 // type, there exist candidate operator functions of the form 8366 // 8367 // VQ L& operator%=(VQ L&, R); 8368 // VQ L& operator<<=(VQ L&, R); 8369 // VQ L& operator>>=(VQ L&, R); 8370 // VQ L& operator&=(VQ L&, R); 8371 // VQ L& operator^=(VQ L&, R); 8372 // VQ L& operator|=(VQ L&, R); 8373 void addAssignmentIntegralOverloads() { 8374 if (!HasArithmeticOrEnumeralCandidateType) 8375 return; 8376 8377 for (unsigned Left = FirstIntegralType; Left < LastIntegralType; ++Left) { 8378 for (unsigned Right = FirstPromotedIntegralType; 8379 Right < LastPromotedIntegralType; ++Right) { 8380 QualType ParamTypes[2]; 8381 ParamTypes[1] = getArithmeticType(Right); 8382 8383 // Add this built-in operator as a candidate (VQ is empty). 8384 ParamTypes[0] = 8385 S.Context.getLValueReferenceType(getArithmeticType(Left)); 8386 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8387 if (VisibleTypeConversionsQuals.hasVolatile()) { 8388 // Add this built-in operator as a candidate (VQ is 'volatile'). 8389 ParamTypes[0] = getArithmeticType(Left); 8390 ParamTypes[0] = S.Context.getVolatileType(ParamTypes[0]); 8391 ParamTypes[0] = S.Context.getLValueReferenceType(ParamTypes[0]); 8392 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8393 } 8394 } 8395 } 8396 } 8397 8398 // C++ [over.operator]p23: 8399 // 8400 // There also exist candidate operator functions of the form 8401 // 8402 // bool operator!(bool); 8403 // bool operator&&(bool, bool); 8404 // bool operator||(bool, bool); 8405 void addExclaimOverload() { 8406 QualType ParamTy = S.Context.BoolTy; 8407 S.AddBuiltinCandidate(&ParamTy, Args, CandidateSet, 8408 /*IsAssignmentOperator=*/false, 8409 /*NumContextualBoolArguments=*/1); 8410 } 8411 void addAmpAmpOrPipePipeOverload() { 8412 QualType ParamTypes[2] = { S.Context.BoolTy, S.Context.BoolTy }; 8413 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet, 8414 /*IsAssignmentOperator=*/false, 8415 /*NumContextualBoolArguments=*/2); 8416 } 8417 8418 // C++ [over.built]p13: 8419 // 8420 // For every cv-qualified or cv-unqualified object type T there 8421 // exist candidate operator functions of the form 8422 // 8423 // T* operator+(T*, ptrdiff_t); [ABOVE] 8424 // T& operator[](T*, ptrdiff_t); 8425 // T* operator-(T*, ptrdiff_t); [ABOVE] 8426 // T* operator+(ptrdiff_t, T*); [ABOVE] 8427 // T& operator[](ptrdiff_t, T*); 8428 void addSubscriptOverloads() { 8429 for (BuiltinCandidateTypeSet::iterator 8430 Ptr = CandidateTypes[0].pointer_begin(), 8431 PtrEnd = CandidateTypes[0].pointer_end(); 8432 Ptr != PtrEnd; ++Ptr) { 8433 QualType ParamTypes[2] = { *Ptr, S.Context.getPointerDiffType() }; 8434 QualType PointeeType = (*Ptr)->getPointeeType(); 8435 if (!PointeeType->isObjectType()) 8436 continue; 8437 8438 // T& operator[](T*, ptrdiff_t) 8439 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8440 } 8441 8442 for (BuiltinCandidateTypeSet::iterator 8443 Ptr = CandidateTypes[1].pointer_begin(), 8444 PtrEnd = CandidateTypes[1].pointer_end(); 8445 Ptr != PtrEnd; ++Ptr) { 8446 QualType ParamTypes[2] = { S.Context.getPointerDiffType(), *Ptr }; 8447 QualType PointeeType = (*Ptr)->getPointeeType(); 8448 if (!PointeeType->isObjectType()) 8449 continue; 8450 8451 // T& operator[](ptrdiff_t, T*) 8452 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8453 } 8454 } 8455 8456 // C++ [over.built]p11: 8457 // For every quintuple (C1, C2, T, CV1, CV2), where C2 is a class type, 8458 // C1 is the same type as C2 or is a derived class of C2, T is an object 8459 // type or a function type, and CV1 and CV2 are cv-qualifier-seqs, 8460 // there exist candidate operator functions of the form 8461 // 8462 // CV12 T& operator->*(CV1 C1*, CV2 T C2::*); 8463 // 8464 // where CV12 is the union of CV1 and CV2. 8465 void addArrowStarOverloads() { 8466 for (BuiltinCandidateTypeSet::iterator 8467 Ptr = CandidateTypes[0].pointer_begin(), 8468 PtrEnd = CandidateTypes[0].pointer_end(); 8469 Ptr != PtrEnd; ++Ptr) { 8470 QualType C1Ty = (*Ptr); 8471 QualType C1; 8472 QualifierCollector Q1; 8473 C1 = QualType(Q1.strip(C1Ty->getPointeeType()), 0); 8474 if (!isa<RecordType>(C1)) 8475 continue; 8476 // heuristic to reduce number of builtin candidates in the set. 8477 // Add volatile/restrict version only if there are conversions to a 8478 // volatile/restrict type. 8479 if (!VisibleTypeConversionsQuals.hasVolatile() && Q1.hasVolatile()) 8480 continue; 8481 if (!VisibleTypeConversionsQuals.hasRestrict() && Q1.hasRestrict()) 8482 continue; 8483 for (BuiltinCandidateTypeSet::iterator 8484 MemPtr = CandidateTypes[1].member_pointer_begin(), 8485 MemPtrEnd = CandidateTypes[1].member_pointer_end(); 8486 MemPtr != MemPtrEnd; ++MemPtr) { 8487 const MemberPointerType *mptr = cast<MemberPointerType>(*MemPtr); 8488 QualType C2 = QualType(mptr->getClass(), 0); 8489 C2 = C2.getUnqualifiedType(); 8490 if (C1 != C2 && !S.IsDerivedFrom(CandidateSet.getLocation(), C1, C2)) 8491 break; 8492 QualType ParamTypes[2] = { *Ptr, *MemPtr }; 8493 // build CV12 T& 8494 QualType T = mptr->getPointeeType(); 8495 if (!VisibleTypeConversionsQuals.hasVolatile() && 8496 T.isVolatileQualified()) 8497 continue; 8498 if (!VisibleTypeConversionsQuals.hasRestrict() && 8499 T.isRestrictQualified()) 8500 continue; 8501 T = Q1.apply(S.Context, T); 8502 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8503 } 8504 } 8505 } 8506 8507 // Note that we don't consider the first argument, since it has been 8508 // contextually converted to bool long ago. The candidates below are 8509 // therefore added as binary. 8510 // 8511 // C++ [over.built]p25: 8512 // For every type T, where T is a pointer, pointer-to-member, or scoped 8513 // enumeration type, there exist candidate operator functions of the form 8514 // 8515 // T operator?(bool, T, T); 8516 // 8517 void addConditionalOperatorOverloads() { 8518 /// Set of (canonical) types that we've already handled. 8519 llvm::SmallPtrSet<QualType, 8> AddedTypes; 8520 8521 for (unsigned ArgIdx = 0; ArgIdx < 2; ++ArgIdx) { 8522 for (BuiltinCandidateTypeSet::iterator 8523 Ptr = CandidateTypes[ArgIdx].pointer_begin(), 8524 PtrEnd = CandidateTypes[ArgIdx].pointer_end(); 8525 Ptr != PtrEnd; ++Ptr) { 8526 if (!AddedTypes.insert(S.Context.getCanonicalType(*Ptr)).second) 8527 continue; 8528 8529 QualType ParamTypes[2] = { *Ptr, *Ptr }; 8530 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8531 } 8532 8533 for (BuiltinCandidateTypeSet::iterator 8534 MemPtr = CandidateTypes[ArgIdx].member_pointer_begin(), 8535 MemPtrEnd = CandidateTypes[ArgIdx].member_pointer_end(); 8536 MemPtr != MemPtrEnd; ++MemPtr) { 8537 if (!AddedTypes.insert(S.Context.getCanonicalType(*MemPtr)).second) 8538 continue; 8539 8540 QualType ParamTypes[2] = { *MemPtr, *MemPtr }; 8541 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8542 } 8543 8544 if (S.getLangOpts().CPlusPlus11) { 8545 for (BuiltinCandidateTypeSet::iterator 8546 Enum = CandidateTypes[ArgIdx].enumeration_begin(), 8547 EnumEnd = CandidateTypes[ArgIdx].enumeration_end(); 8548 Enum != EnumEnd; ++Enum) { 8549 if (!(*Enum)->getAs<EnumType>()->getDecl()->isScoped()) 8550 continue; 8551 8552 if (!AddedTypes.insert(S.Context.getCanonicalType(*Enum)).second) 8553 continue; 8554 8555 QualType ParamTypes[2] = { *Enum, *Enum }; 8556 S.AddBuiltinCandidate(ParamTypes, Args, CandidateSet); 8557 } 8558 } 8559 } 8560 } 8561 }; 8562 8563 } // end anonymous namespace 8564 8565 /// AddBuiltinOperatorCandidates - Add the appropriate built-in 8566 /// operator overloads to the candidate set (C++ [over.built]), based 8567 /// on the operator @p Op and the arguments given. For example, if the 8568 /// operator is a binary '+', this routine might add "int 8569 /// operator+(int, int)" to cover integer addition. 8570 void Sema::AddBuiltinOperatorCandidates(OverloadedOperatorKind Op, 8571 SourceLocation OpLoc, 8572 ArrayRef<Expr *> Args, 8573 OverloadCandidateSet &CandidateSet) { 8574 // Find all of the types that the arguments can convert to, but only 8575 // if the operator we're looking at has built-in operator candidates 8576 // that make use of these types. Also record whether we encounter non-record 8577 // candidate types or either arithmetic or enumeral candidate types. 8578 Qualifiers VisibleTypeConversionsQuals; 8579 VisibleTypeConversionsQuals.addConst(); 8580 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) 8581 VisibleTypeConversionsQuals += CollectVRQualifiers(Context, Args[ArgIdx]); 8582 8583 bool HasNonRecordCandidateType = false; 8584 bool HasArithmeticOrEnumeralCandidateType = false; 8585 SmallVector<BuiltinCandidateTypeSet, 2> CandidateTypes; 8586 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 8587 CandidateTypes.emplace_back(*this); 8588 CandidateTypes[ArgIdx].AddTypesConvertedFrom(Args[ArgIdx]->getType(), 8589 OpLoc, 8590 true, 8591 (Op == OO_Exclaim || 8592 Op == OO_AmpAmp || 8593 Op == OO_PipePipe), 8594 VisibleTypeConversionsQuals); 8595 HasNonRecordCandidateType = HasNonRecordCandidateType || 8596 CandidateTypes[ArgIdx].hasNonRecordTypes(); 8597 HasArithmeticOrEnumeralCandidateType = 8598 HasArithmeticOrEnumeralCandidateType || 8599 CandidateTypes[ArgIdx].hasArithmeticOrEnumeralTypes(); 8600 } 8601 8602 // Exit early when no non-record types have been added to the candidate set 8603 // for any of the arguments to the operator. 8604 // 8605 // We can't exit early for !, ||, or &&, since there we have always have 8606 // 'bool' overloads. 8607 if (!HasNonRecordCandidateType && 8608 !(Op == OO_Exclaim || Op == OO_AmpAmp || Op == OO_PipePipe)) 8609 return; 8610 8611 // Setup an object to manage the common state for building overloads. 8612 BuiltinOperatorOverloadBuilder OpBuilder(*this, Args, 8613 VisibleTypeConversionsQuals, 8614 HasArithmeticOrEnumeralCandidateType, 8615 CandidateTypes, CandidateSet); 8616 8617 // Dispatch over the operation to add in only those overloads which apply. 8618 switch (Op) { 8619 case OO_None: 8620 case NUM_OVERLOADED_OPERATORS: 8621 llvm_unreachable("Expected an overloaded operator"); 8622 8623 case OO_New: 8624 case OO_Delete: 8625 case OO_Array_New: 8626 case OO_Array_Delete: 8627 case OO_Call: 8628 llvm_unreachable( 8629 "Special operators don't use AddBuiltinOperatorCandidates"); 8630 8631 case OO_Comma: 8632 case OO_Arrow: 8633 case OO_Coawait: 8634 // C++ [over.match.oper]p3: 8635 // -- For the operator ',', the unary operator '&', the 8636 // operator '->', or the operator 'co_await', the 8637 // built-in candidates set is empty. 8638 break; 8639 8640 case OO_Plus: // '+' is either unary or binary 8641 if (Args.size() == 1) 8642 OpBuilder.addUnaryPlusPointerOverloads(); 8643 // Fall through. 8644 8645 case OO_Minus: // '-' is either unary or binary 8646 if (Args.size() == 1) { 8647 OpBuilder.addUnaryPlusOrMinusArithmeticOverloads(); 8648 } else { 8649 OpBuilder.addBinaryPlusOrMinusPointerOverloads(Op); 8650 OpBuilder.addGenericBinaryArithmeticOverloads(); 8651 } 8652 break; 8653 8654 case OO_Star: // '*' is either unary or binary 8655 if (Args.size() == 1) 8656 OpBuilder.addUnaryStarPointerOverloads(); 8657 else 8658 OpBuilder.addGenericBinaryArithmeticOverloads(); 8659 break; 8660 8661 case OO_Slash: 8662 OpBuilder.addGenericBinaryArithmeticOverloads(); 8663 break; 8664 8665 case OO_PlusPlus: 8666 case OO_MinusMinus: 8667 OpBuilder.addPlusPlusMinusMinusArithmeticOverloads(Op); 8668 OpBuilder.addPlusPlusMinusMinusPointerOverloads(); 8669 break; 8670 8671 case OO_EqualEqual: 8672 case OO_ExclaimEqual: 8673 OpBuilder.addEqualEqualOrNotEqualMemberPointerOrNullptrOverloads(); 8674 // Fall through. 8675 8676 case OO_Less: 8677 case OO_Greater: 8678 case OO_LessEqual: 8679 case OO_GreaterEqual: 8680 OpBuilder.addRelationalPointerOrEnumeralOverloads(); 8681 OpBuilder.addGenericBinaryArithmeticOverloads(); 8682 break; 8683 8684 case OO_Percent: 8685 case OO_Caret: 8686 case OO_Pipe: 8687 case OO_LessLess: 8688 case OO_GreaterGreater: 8689 OpBuilder.addBinaryBitwiseArithmeticOverloads(Op); 8690 break; 8691 8692 case OO_Amp: // '&' is either unary or binary 8693 if (Args.size() == 1) 8694 // C++ [over.match.oper]p3: 8695 // -- For the operator ',', the unary operator '&', or the 8696 // operator '->', the built-in candidates set is empty. 8697 break; 8698 8699 OpBuilder.addBinaryBitwiseArithmeticOverloads(Op); 8700 break; 8701 8702 case OO_Tilde: 8703 OpBuilder.addUnaryTildePromotedIntegralOverloads(); 8704 break; 8705 8706 case OO_Equal: 8707 OpBuilder.addAssignmentMemberPointerOrEnumeralOverloads(); 8708 // Fall through. 8709 8710 case OO_PlusEqual: 8711 case OO_MinusEqual: 8712 OpBuilder.addAssignmentPointerOverloads(Op == OO_Equal); 8713 // Fall through. 8714 8715 case OO_StarEqual: 8716 case OO_SlashEqual: 8717 OpBuilder.addAssignmentArithmeticOverloads(Op == OO_Equal); 8718 break; 8719 8720 case OO_PercentEqual: 8721 case OO_LessLessEqual: 8722 case OO_GreaterGreaterEqual: 8723 case OO_AmpEqual: 8724 case OO_CaretEqual: 8725 case OO_PipeEqual: 8726 OpBuilder.addAssignmentIntegralOverloads(); 8727 break; 8728 8729 case OO_Exclaim: 8730 OpBuilder.addExclaimOverload(); 8731 break; 8732 8733 case OO_AmpAmp: 8734 case OO_PipePipe: 8735 OpBuilder.addAmpAmpOrPipePipeOverload(); 8736 break; 8737 8738 case OO_Subscript: 8739 OpBuilder.addSubscriptOverloads(); 8740 break; 8741 8742 case OO_ArrowStar: 8743 OpBuilder.addArrowStarOverloads(); 8744 break; 8745 8746 case OO_Conditional: 8747 OpBuilder.addConditionalOperatorOverloads(); 8748 OpBuilder.addGenericBinaryArithmeticOverloads(); 8749 break; 8750 } 8751 } 8752 8753 /// \brief Add function candidates found via argument-dependent lookup 8754 /// to the set of overloading candidates. 8755 /// 8756 /// This routine performs argument-dependent name lookup based on the 8757 /// given function name (which may also be an operator name) and adds 8758 /// all of the overload candidates found by ADL to the overload 8759 /// candidate set (C++ [basic.lookup.argdep]). 8760 void 8761 Sema::AddArgumentDependentLookupCandidates(DeclarationName Name, 8762 SourceLocation Loc, 8763 ArrayRef<Expr *> Args, 8764 TemplateArgumentListInfo *ExplicitTemplateArgs, 8765 OverloadCandidateSet& CandidateSet, 8766 bool PartialOverloading) { 8767 ADLResult Fns; 8768 8769 // FIXME: This approach for uniquing ADL results (and removing 8770 // redundant candidates from the set) relies on pointer-equality, 8771 // which means we need to key off the canonical decl. However, 8772 // always going back to the canonical decl might not get us the 8773 // right set of default arguments. What default arguments are 8774 // we supposed to consider on ADL candidates, anyway? 8775 8776 // FIXME: Pass in the explicit template arguments? 8777 ArgumentDependentLookup(Name, Loc, Args, Fns); 8778 8779 // Erase all of the candidates we already knew about. 8780 for (OverloadCandidateSet::iterator Cand = CandidateSet.begin(), 8781 CandEnd = CandidateSet.end(); 8782 Cand != CandEnd; ++Cand) 8783 if (Cand->Function) { 8784 Fns.erase(Cand->Function); 8785 if (FunctionTemplateDecl *FunTmpl = Cand->Function->getPrimaryTemplate()) 8786 Fns.erase(FunTmpl); 8787 } 8788 8789 // For each of the ADL candidates we found, add it to the overload 8790 // set. 8791 for (ADLResult::iterator I = Fns.begin(), E = Fns.end(); I != E; ++I) { 8792 DeclAccessPair FoundDecl = DeclAccessPair::make(*I, AS_none); 8793 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*I)) { 8794 if (ExplicitTemplateArgs) 8795 continue; 8796 8797 AddOverloadCandidate(FD, FoundDecl, Args, CandidateSet, false, 8798 PartialOverloading); 8799 } else 8800 AddTemplateOverloadCandidate(cast<FunctionTemplateDecl>(*I), 8801 FoundDecl, ExplicitTemplateArgs, 8802 Args, CandidateSet, PartialOverloading); 8803 } 8804 } 8805 8806 namespace { 8807 enum class Comparison { Equal, Better, Worse }; 8808 } 8809 8810 /// Compares the enable_if attributes of two FunctionDecls, for the purposes of 8811 /// overload resolution. 8812 /// 8813 /// Cand1's set of enable_if attributes are said to be "better" than Cand2's iff 8814 /// Cand1's first N enable_if attributes have precisely the same conditions as 8815 /// Cand2's first N enable_if attributes (where N = the number of enable_if 8816 /// attributes on Cand2), and Cand1 has more than N enable_if attributes. 8817 /// 8818 /// Note that you can have a pair of candidates such that Cand1's enable_if 8819 /// attributes are worse than Cand2's, and Cand2's enable_if attributes are 8820 /// worse than Cand1's. 8821 static Comparison compareEnableIfAttrs(const Sema &S, const FunctionDecl *Cand1, 8822 const FunctionDecl *Cand2) { 8823 // Common case: One (or both) decls don't have enable_if attrs. 8824 bool Cand1Attr = Cand1->hasAttr<EnableIfAttr>(); 8825 bool Cand2Attr = Cand2->hasAttr<EnableIfAttr>(); 8826 if (!Cand1Attr || !Cand2Attr) { 8827 if (Cand1Attr == Cand2Attr) 8828 return Comparison::Equal; 8829 return Cand1Attr ? Comparison::Better : Comparison::Worse; 8830 } 8831 8832 // FIXME: The next several lines are just 8833 // specific_attr_iterator<EnableIfAttr> but going in declaration order, 8834 // instead of reverse order which is how they're stored in the AST. 8835 auto Cand1Attrs = getOrderedEnableIfAttrs(Cand1); 8836 auto Cand2Attrs = getOrderedEnableIfAttrs(Cand2); 8837 8838 // It's impossible for Cand1 to be better than (or equal to) Cand2 if Cand1 8839 // has fewer enable_if attributes than Cand2. 8840 if (Cand1Attrs.size() < Cand2Attrs.size()) 8841 return Comparison::Worse; 8842 8843 auto Cand1I = Cand1Attrs.begin(); 8844 llvm::FoldingSetNodeID Cand1ID, Cand2ID; 8845 for (auto &Cand2A : Cand2Attrs) { 8846 Cand1ID.clear(); 8847 Cand2ID.clear(); 8848 8849 auto &Cand1A = *Cand1I++; 8850 Cand1A->getCond()->Profile(Cand1ID, S.getASTContext(), true); 8851 Cand2A->getCond()->Profile(Cand2ID, S.getASTContext(), true); 8852 if (Cand1ID != Cand2ID) 8853 return Comparison::Worse; 8854 } 8855 8856 return Cand1I == Cand1Attrs.end() ? Comparison::Equal : Comparison::Better; 8857 } 8858 8859 /// isBetterOverloadCandidate - Determines whether the first overload 8860 /// candidate is a better candidate than the second (C++ 13.3.3p1). 8861 bool clang::isBetterOverloadCandidate( 8862 Sema &S, const OverloadCandidate &Cand1, const OverloadCandidate &Cand2, 8863 SourceLocation Loc, OverloadCandidateSet::CandidateSetKind Kind) { 8864 // Define viable functions to be better candidates than non-viable 8865 // functions. 8866 if (!Cand2.Viable) 8867 return Cand1.Viable; 8868 else if (!Cand1.Viable) 8869 return false; 8870 8871 // C++ [over.match.best]p1: 8872 // 8873 // -- if F is a static member function, ICS1(F) is defined such 8874 // that ICS1(F) is neither better nor worse than ICS1(G) for 8875 // any function G, and, symmetrically, ICS1(G) is neither 8876 // better nor worse than ICS1(F). 8877 unsigned StartArg = 0; 8878 if (Cand1.IgnoreObjectArgument || Cand2.IgnoreObjectArgument) 8879 StartArg = 1; 8880 8881 auto IsIllFormedConversion = [&](const ImplicitConversionSequence &ICS) { 8882 // We don't allow incompatible pointer conversions in C++. 8883 if (!S.getLangOpts().CPlusPlus) 8884 return ICS.isStandard() && 8885 ICS.Standard.Second == ICK_Incompatible_Pointer_Conversion; 8886 8887 // The only ill-formed conversion we allow in C++ is the string literal to 8888 // char* conversion, which is only considered ill-formed after C++11. 8889 return S.getLangOpts().CPlusPlus11 && !S.getLangOpts().WritableStrings && 8890 hasDeprecatedStringLiteralToCharPtrConversion(ICS); 8891 }; 8892 8893 // Define functions that don't require ill-formed conversions for a given 8894 // argument to be better candidates than functions that do. 8895 unsigned NumArgs = Cand1.Conversions.size(); 8896 assert(Cand2.Conversions.size() == NumArgs && "Overload candidate mismatch"); 8897 bool HasBetterConversion = false; 8898 for (unsigned ArgIdx = StartArg; ArgIdx < NumArgs; ++ArgIdx) { 8899 bool Cand1Bad = IsIllFormedConversion(Cand1.Conversions[ArgIdx]); 8900 bool Cand2Bad = IsIllFormedConversion(Cand2.Conversions[ArgIdx]); 8901 if (Cand1Bad != Cand2Bad) { 8902 if (Cand1Bad) 8903 return false; 8904 HasBetterConversion = true; 8905 } 8906 } 8907 8908 if (HasBetterConversion) 8909 return true; 8910 8911 // C++ [over.match.best]p1: 8912 // A viable function F1 is defined to be a better function than another 8913 // viable function F2 if for all arguments i, ICSi(F1) is not a worse 8914 // conversion sequence than ICSi(F2), and then... 8915 for (unsigned ArgIdx = StartArg; ArgIdx < NumArgs; ++ArgIdx) { 8916 switch (CompareImplicitConversionSequences(S, Loc, 8917 Cand1.Conversions[ArgIdx], 8918 Cand2.Conversions[ArgIdx])) { 8919 case ImplicitConversionSequence::Better: 8920 // Cand1 has a better conversion sequence. 8921 HasBetterConversion = true; 8922 break; 8923 8924 case ImplicitConversionSequence::Worse: 8925 // Cand1 can't be better than Cand2. 8926 return false; 8927 8928 case ImplicitConversionSequence::Indistinguishable: 8929 // Do nothing. 8930 break; 8931 } 8932 } 8933 8934 // -- for some argument j, ICSj(F1) is a better conversion sequence than 8935 // ICSj(F2), or, if not that, 8936 if (HasBetterConversion) 8937 return true; 8938 8939 // -- the context is an initialization by user-defined conversion 8940 // (see 8.5, 13.3.1.5) and the standard conversion sequence 8941 // from the return type of F1 to the destination type (i.e., 8942 // the type of the entity being initialized) is a better 8943 // conversion sequence than the standard conversion sequence 8944 // from the return type of F2 to the destination type. 8945 if (Kind == OverloadCandidateSet::CSK_InitByUserDefinedConversion && 8946 Cand1.Function && Cand2.Function && 8947 isa<CXXConversionDecl>(Cand1.Function) && 8948 isa<CXXConversionDecl>(Cand2.Function)) { 8949 // First check whether we prefer one of the conversion functions over the 8950 // other. This only distinguishes the results in non-standard, extension 8951 // cases such as the conversion from a lambda closure type to a function 8952 // pointer or block. 8953 ImplicitConversionSequence::CompareKind Result = 8954 compareConversionFunctions(S, Cand1.Function, Cand2.Function); 8955 if (Result == ImplicitConversionSequence::Indistinguishable) 8956 Result = CompareStandardConversionSequences(S, Loc, 8957 Cand1.FinalConversion, 8958 Cand2.FinalConversion); 8959 8960 if (Result != ImplicitConversionSequence::Indistinguishable) 8961 return Result == ImplicitConversionSequence::Better; 8962 8963 // FIXME: Compare kind of reference binding if conversion functions 8964 // convert to a reference type used in direct reference binding, per 8965 // C++14 [over.match.best]p1 section 2 bullet 3. 8966 } 8967 8968 // -- F1 is generated from a deduction-guide and F2 is not 8969 auto *Guide1 = dyn_cast_or_null<CXXDeductionGuideDecl>(Cand1.Function); 8970 auto *Guide2 = dyn_cast_or_null<CXXDeductionGuideDecl>(Cand2.Function); 8971 if (Guide1 && Guide2 && Guide1->isImplicit() != Guide2->isImplicit()) 8972 return Guide2->isImplicit(); 8973 8974 // -- F1 is a non-template function and F2 is a function template 8975 // specialization, or, if not that, 8976 bool Cand1IsSpecialization = Cand1.Function && 8977 Cand1.Function->getPrimaryTemplate(); 8978 bool Cand2IsSpecialization = Cand2.Function && 8979 Cand2.Function->getPrimaryTemplate(); 8980 if (Cand1IsSpecialization != Cand2IsSpecialization) 8981 return Cand2IsSpecialization; 8982 8983 // -- F1 and F2 are function template specializations, and the function 8984 // template for F1 is more specialized than the template for F2 8985 // according to the partial ordering rules described in 14.5.5.2, or, 8986 // if not that, 8987 if (Cand1IsSpecialization && Cand2IsSpecialization) { 8988 if (FunctionTemplateDecl *BetterTemplate 8989 = S.getMoreSpecializedTemplate(Cand1.Function->getPrimaryTemplate(), 8990 Cand2.Function->getPrimaryTemplate(), 8991 Loc, 8992 isa<CXXConversionDecl>(Cand1.Function)? TPOC_Conversion 8993 : TPOC_Call, 8994 Cand1.ExplicitCallArguments, 8995 Cand2.ExplicitCallArguments)) 8996 return BetterTemplate == Cand1.Function->getPrimaryTemplate(); 8997 } 8998 8999 // FIXME: Work around a defect in the C++17 inheriting constructor wording. 9000 // A derived-class constructor beats an (inherited) base class constructor. 9001 bool Cand1IsInherited = 9002 dyn_cast_or_null<ConstructorUsingShadowDecl>(Cand1.FoundDecl.getDecl()); 9003 bool Cand2IsInherited = 9004 dyn_cast_or_null<ConstructorUsingShadowDecl>(Cand2.FoundDecl.getDecl()); 9005 if (Cand1IsInherited != Cand2IsInherited) 9006 return Cand2IsInherited; 9007 else if (Cand1IsInherited) { 9008 assert(Cand2IsInherited); 9009 auto *Cand1Class = cast<CXXRecordDecl>(Cand1.Function->getDeclContext()); 9010 auto *Cand2Class = cast<CXXRecordDecl>(Cand2.Function->getDeclContext()); 9011 if (Cand1Class->isDerivedFrom(Cand2Class)) 9012 return true; 9013 if (Cand2Class->isDerivedFrom(Cand1Class)) 9014 return false; 9015 // Inherited from sibling base classes: still ambiguous. 9016 } 9017 9018 // FIXME: Work around a defect in the C++17 guaranteed copy elision wording, 9019 // as combined with the resolution to CWG issue 243. 9020 // 9021 // When the context is initialization by constructor ([over.match.ctor] or 9022 // either phase of [over.match.list]), a constructor is preferred over 9023 // a conversion function. 9024 if (Kind == OverloadCandidateSet::CSK_InitByConstructor && NumArgs == 1 && 9025 Cand1.Function && Cand2.Function && 9026 isa<CXXConstructorDecl>(Cand1.Function) != 9027 isa<CXXConstructorDecl>(Cand2.Function)) 9028 return isa<CXXConstructorDecl>(Cand1.Function); 9029 9030 // Check for enable_if value-based overload resolution. 9031 if (Cand1.Function && Cand2.Function) { 9032 Comparison Cmp = compareEnableIfAttrs(S, Cand1.Function, Cand2.Function); 9033 if (Cmp != Comparison::Equal) 9034 return Cmp == Comparison::Better; 9035 } 9036 9037 if (S.getLangOpts().CUDA && Cand1.Function && Cand2.Function) { 9038 FunctionDecl *Caller = dyn_cast<FunctionDecl>(S.CurContext); 9039 return S.IdentifyCUDAPreference(Caller, Cand1.Function) > 9040 S.IdentifyCUDAPreference(Caller, Cand2.Function); 9041 } 9042 9043 bool HasPS1 = Cand1.Function != nullptr && 9044 functionHasPassObjectSizeParams(Cand1.Function); 9045 bool HasPS2 = Cand2.Function != nullptr && 9046 functionHasPassObjectSizeParams(Cand2.Function); 9047 return HasPS1 != HasPS2 && HasPS1; 9048 } 9049 9050 /// Determine whether two declarations are "equivalent" for the purposes of 9051 /// name lookup and overload resolution. This applies when the same internal/no 9052 /// linkage entity is defined by two modules (probably by textually including 9053 /// the same header). In such a case, we don't consider the declarations to 9054 /// declare the same entity, but we also don't want lookups with both 9055 /// declarations visible to be ambiguous in some cases (this happens when using 9056 /// a modularized libstdc++). 9057 bool Sema::isEquivalentInternalLinkageDeclaration(const NamedDecl *A, 9058 const NamedDecl *B) { 9059 auto *VA = dyn_cast_or_null<ValueDecl>(A); 9060 auto *VB = dyn_cast_or_null<ValueDecl>(B); 9061 if (!VA || !VB) 9062 return false; 9063 9064 // The declarations must be declaring the same name as an internal linkage 9065 // entity in different modules. 9066 if (!VA->getDeclContext()->getRedeclContext()->Equals( 9067 VB->getDeclContext()->getRedeclContext()) || 9068 getOwningModule(const_cast<ValueDecl *>(VA)) == 9069 getOwningModule(const_cast<ValueDecl *>(VB)) || 9070 VA->isExternallyVisible() || VB->isExternallyVisible()) 9071 return false; 9072 9073 // Check that the declarations appear to be equivalent. 9074 // 9075 // FIXME: Checking the type isn't really enough to resolve the ambiguity. 9076 // For constants and functions, we should check the initializer or body is 9077 // the same. For non-constant variables, we shouldn't allow it at all. 9078 if (Context.hasSameType(VA->getType(), VB->getType())) 9079 return true; 9080 9081 // Enum constants within unnamed enumerations will have different types, but 9082 // may still be similar enough to be interchangeable for our purposes. 9083 if (auto *EA = dyn_cast<EnumConstantDecl>(VA)) { 9084 if (auto *EB = dyn_cast<EnumConstantDecl>(VB)) { 9085 // Only handle anonymous enums. If the enumerations were named and 9086 // equivalent, they would have been merged to the same type. 9087 auto *EnumA = cast<EnumDecl>(EA->getDeclContext()); 9088 auto *EnumB = cast<EnumDecl>(EB->getDeclContext()); 9089 if (EnumA->hasNameForLinkage() || EnumB->hasNameForLinkage() || 9090 !Context.hasSameType(EnumA->getIntegerType(), 9091 EnumB->getIntegerType())) 9092 return false; 9093 // Allow this only if the value is the same for both enumerators. 9094 return llvm::APSInt::isSameValue(EA->getInitVal(), EB->getInitVal()); 9095 } 9096 } 9097 9098 // Nothing else is sufficiently similar. 9099 return false; 9100 } 9101 9102 void Sema::diagnoseEquivalentInternalLinkageDeclarations( 9103 SourceLocation Loc, const NamedDecl *D, ArrayRef<const NamedDecl *> Equiv) { 9104 Diag(Loc, diag::ext_equivalent_internal_linkage_decl_in_modules) << D; 9105 9106 Module *M = getOwningModule(const_cast<NamedDecl*>(D)); 9107 Diag(D->getLocation(), diag::note_equivalent_internal_linkage_decl) 9108 << !M << (M ? M->getFullModuleName() : ""); 9109 9110 for (auto *E : Equiv) { 9111 Module *M = getOwningModule(const_cast<NamedDecl*>(E)); 9112 Diag(E->getLocation(), diag::note_equivalent_internal_linkage_decl) 9113 << !M << (M ? M->getFullModuleName() : ""); 9114 } 9115 } 9116 9117 /// \brief Computes the best viable function (C++ 13.3.3) 9118 /// within an overload candidate set. 9119 /// 9120 /// \param Loc The location of the function name (or operator symbol) for 9121 /// which overload resolution occurs. 9122 /// 9123 /// \param Best If overload resolution was successful or found a deleted 9124 /// function, \p Best points to the candidate function found. 9125 /// 9126 /// \returns The result of overload resolution. 9127 OverloadingResult 9128 OverloadCandidateSet::BestViableFunction(Sema &S, SourceLocation Loc, 9129 iterator &Best) { 9130 llvm::SmallVector<OverloadCandidate *, 16> Candidates; 9131 std::transform(begin(), end(), std::back_inserter(Candidates), 9132 [](OverloadCandidate &Cand) { return &Cand; }); 9133 9134 // [CUDA] HD->H or HD->D calls are technically not allowed by CUDA but 9135 // are accepted by both clang and NVCC. However, during a particular 9136 // compilation mode only one call variant is viable. We need to 9137 // exclude non-viable overload candidates from consideration based 9138 // only on their host/device attributes. Specifically, if one 9139 // candidate call is WrongSide and the other is SameSide, we ignore 9140 // the WrongSide candidate. 9141 if (S.getLangOpts().CUDA) { 9142 const FunctionDecl *Caller = dyn_cast<FunctionDecl>(S.CurContext); 9143 bool ContainsSameSideCandidate = 9144 llvm::any_of(Candidates, [&](OverloadCandidate *Cand) { 9145 return Cand->Function && 9146 S.IdentifyCUDAPreference(Caller, Cand->Function) == 9147 Sema::CFP_SameSide; 9148 }); 9149 if (ContainsSameSideCandidate) { 9150 auto IsWrongSideCandidate = [&](OverloadCandidate *Cand) { 9151 return Cand->Function && 9152 S.IdentifyCUDAPreference(Caller, Cand->Function) == 9153 Sema::CFP_WrongSide; 9154 }; 9155 llvm::erase_if(Candidates, IsWrongSideCandidate); 9156 } 9157 } 9158 9159 // Find the best viable function. 9160 Best = end(); 9161 for (auto *Cand : Candidates) 9162 if (Cand->Viable) 9163 if (Best == end() || 9164 isBetterOverloadCandidate(S, *Cand, *Best, Loc, Kind)) 9165 Best = Cand; 9166 9167 // If we didn't find any viable functions, abort. 9168 if (Best == end()) 9169 return OR_No_Viable_Function; 9170 9171 llvm::SmallVector<const NamedDecl *, 4> EquivalentCands; 9172 9173 // Make sure that this function is better than every other viable 9174 // function. If not, we have an ambiguity. 9175 for (auto *Cand : Candidates) { 9176 if (Cand->Viable && Cand != Best && 9177 !isBetterOverloadCandidate(S, *Best, *Cand, Loc, Kind)) { 9178 if (S.isEquivalentInternalLinkageDeclaration(Best->Function, 9179 Cand->Function)) { 9180 EquivalentCands.push_back(Cand->Function); 9181 continue; 9182 } 9183 9184 Best = end(); 9185 return OR_Ambiguous; 9186 } 9187 } 9188 9189 // Best is the best viable function. 9190 if (Best->Function && 9191 (Best->Function->isDeleted() || 9192 S.isFunctionConsideredUnavailable(Best->Function))) 9193 return OR_Deleted; 9194 9195 if (!EquivalentCands.empty()) 9196 S.diagnoseEquivalentInternalLinkageDeclarations(Loc, Best->Function, 9197 EquivalentCands); 9198 9199 return OR_Success; 9200 } 9201 9202 namespace { 9203 9204 enum OverloadCandidateKind { 9205 oc_function, 9206 oc_method, 9207 oc_constructor, 9208 oc_function_template, 9209 oc_method_template, 9210 oc_constructor_template, 9211 oc_implicit_default_constructor, 9212 oc_implicit_copy_constructor, 9213 oc_implicit_move_constructor, 9214 oc_implicit_copy_assignment, 9215 oc_implicit_move_assignment, 9216 oc_inherited_constructor, 9217 oc_inherited_constructor_template 9218 }; 9219 9220 static OverloadCandidateKind 9221 ClassifyOverloadCandidate(Sema &S, NamedDecl *Found, FunctionDecl *Fn, 9222 std::string &Description) { 9223 bool isTemplate = false; 9224 9225 if (FunctionTemplateDecl *FunTmpl = Fn->getPrimaryTemplate()) { 9226 isTemplate = true; 9227 Description = S.getTemplateArgumentBindingsText( 9228 FunTmpl->getTemplateParameters(), *Fn->getTemplateSpecializationArgs()); 9229 } 9230 9231 if (CXXConstructorDecl *Ctor = dyn_cast<CXXConstructorDecl>(Fn)) { 9232 if (!Ctor->isImplicit()) { 9233 if (isa<ConstructorUsingShadowDecl>(Found)) 9234 return isTemplate ? oc_inherited_constructor_template 9235 : oc_inherited_constructor; 9236 else 9237 return isTemplate ? oc_constructor_template : oc_constructor; 9238 } 9239 9240 if (Ctor->isDefaultConstructor()) 9241 return oc_implicit_default_constructor; 9242 9243 if (Ctor->isMoveConstructor()) 9244 return oc_implicit_move_constructor; 9245 9246 assert(Ctor->isCopyConstructor() && 9247 "unexpected sort of implicit constructor"); 9248 return oc_implicit_copy_constructor; 9249 } 9250 9251 if (CXXMethodDecl *Meth = dyn_cast<CXXMethodDecl>(Fn)) { 9252 // This actually gets spelled 'candidate function' for now, but 9253 // it doesn't hurt to split it out. 9254 if (!Meth->isImplicit()) 9255 return isTemplate ? oc_method_template : oc_method; 9256 9257 if (Meth->isMoveAssignmentOperator()) 9258 return oc_implicit_move_assignment; 9259 9260 if (Meth->isCopyAssignmentOperator()) 9261 return oc_implicit_copy_assignment; 9262 9263 assert(isa<CXXConversionDecl>(Meth) && "expected conversion"); 9264 return oc_method; 9265 } 9266 9267 return isTemplate ? oc_function_template : oc_function; 9268 } 9269 9270 void MaybeEmitInheritedConstructorNote(Sema &S, Decl *FoundDecl) { 9271 // FIXME: It'd be nice to only emit a note once per using-decl per overload 9272 // set. 9273 if (auto *Shadow = dyn_cast<ConstructorUsingShadowDecl>(FoundDecl)) 9274 S.Diag(FoundDecl->getLocation(), 9275 diag::note_ovl_candidate_inherited_constructor) 9276 << Shadow->getNominatedBaseClass(); 9277 } 9278 9279 } // end anonymous namespace 9280 9281 static bool isFunctionAlwaysEnabled(const ASTContext &Ctx, 9282 const FunctionDecl *FD) { 9283 for (auto *EnableIf : FD->specific_attrs<EnableIfAttr>()) { 9284 bool AlwaysTrue; 9285 if (!EnableIf->getCond()->EvaluateAsBooleanCondition(AlwaysTrue, Ctx)) 9286 return false; 9287 if (!AlwaysTrue) 9288 return false; 9289 } 9290 return true; 9291 } 9292 9293 /// \brief Returns true if we can take the address of the function. 9294 /// 9295 /// \param Complain - If true, we'll emit a diagnostic 9296 /// \param InOverloadResolution - For the purposes of emitting a diagnostic, are 9297 /// we in overload resolution? 9298 /// \param Loc - The location of the statement we're complaining about. Ignored 9299 /// if we're not complaining, or if we're in overload resolution. 9300 static bool checkAddressOfFunctionIsAvailable(Sema &S, const FunctionDecl *FD, 9301 bool Complain, 9302 bool InOverloadResolution, 9303 SourceLocation Loc) { 9304 if (!isFunctionAlwaysEnabled(S.Context, FD)) { 9305 if (Complain) { 9306 if (InOverloadResolution) 9307 S.Diag(FD->getLocStart(), 9308 diag::note_addrof_ovl_candidate_disabled_by_enable_if_attr); 9309 else 9310 S.Diag(Loc, diag::err_addrof_function_disabled_by_enable_if_attr) << FD; 9311 } 9312 return false; 9313 } 9314 9315 auto I = llvm::find_if(FD->parameters(), [](const ParmVarDecl *P) { 9316 return P->hasAttr<PassObjectSizeAttr>(); 9317 }); 9318 if (I == FD->param_end()) 9319 return true; 9320 9321 if (Complain) { 9322 // Add one to ParamNo because it's user-facing 9323 unsigned ParamNo = std::distance(FD->param_begin(), I) + 1; 9324 if (InOverloadResolution) 9325 S.Diag(FD->getLocation(), 9326 diag::note_ovl_candidate_has_pass_object_size_params) 9327 << ParamNo; 9328 else 9329 S.Diag(Loc, diag::err_address_of_function_with_pass_object_size_params) 9330 << FD << ParamNo; 9331 } 9332 return false; 9333 } 9334 9335 static bool checkAddressOfCandidateIsAvailable(Sema &S, 9336 const FunctionDecl *FD) { 9337 return checkAddressOfFunctionIsAvailable(S, FD, /*Complain=*/true, 9338 /*InOverloadResolution=*/true, 9339 /*Loc=*/SourceLocation()); 9340 } 9341 9342 bool Sema::checkAddressOfFunctionIsAvailable(const FunctionDecl *Function, 9343 bool Complain, 9344 SourceLocation Loc) { 9345 return ::checkAddressOfFunctionIsAvailable(*this, Function, Complain, 9346 /*InOverloadResolution=*/false, 9347 Loc); 9348 } 9349 9350 // Notes the location of an overload candidate. 9351 void Sema::NoteOverloadCandidate(NamedDecl *Found, FunctionDecl *Fn, 9352 QualType DestType, bool TakingAddress) { 9353 if (TakingAddress && !checkAddressOfCandidateIsAvailable(*this, Fn)) 9354 return; 9355 9356 std::string FnDesc; 9357 OverloadCandidateKind K = ClassifyOverloadCandidate(*this, Found, Fn, FnDesc); 9358 PartialDiagnostic PD = PDiag(diag::note_ovl_candidate) 9359 << (unsigned) K << Fn << FnDesc; 9360 9361 HandleFunctionTypeMismatch(PD, Fn->getType(), DestType); 9362 Diag(Fn->getLocation(), PD); 9363 MaybeEmitInheritedConstructorNote(*this, Found); 9364 } 9365 9366 // Notes the location of all overload candidates designated through 9367 // OverloadedExpr 9368 void Sema::NoteAllOverloadCandidates(Expr *OverloadedExpr, QualType DestType, 9369 bool TakingAddress) { 9370 assert(OverloadedExpr->getType() == Context.OverloadTy); 9371 9372 OverloadExpr::FindResult Ovl = OverloadExpr::find(OverloadedExpr); 9373 OverloadExpr *OvlExpr = Ovl.Expression; 9374 9375 for (UnresolvedSetIterator I = OvlExpr->decls_begin(), 9376 IEnd = OvlExpr->decls_end(); 9377 I != IEnd; ++I) { 9378 if (FunctionTemplateDecl *FunTmpl = 9379 dyn_cast<FunctionTemplateDecl>((*I)->getUnderlyingDecl()) ) { 9380 NoteOverloadCandidate(*I, FunTmpl->getTemplatedDecl(), DestType, 9381 TakingAddress); 9382 } else if (FunctionDecl *Fun 9383 = dyn_cast<FunctionDecl>((*I)->getUnderlyingDecl()) ) { 9384 NoteOverloadCandidate(*I, Fun, DestType, TakingAddress); 9385 } 9386 } 9387 } 9388 9389 /// Diagnoses an ambiguous conversion. The partial diagnostic is the 9390 /// "lead" diagnostic; it will be given two arguments, the source and 9391 /// target types of the conversion. 9392 void ImplicitConversionSequence::DiagnoseAmbiguousConversion( 9393 Sema &S, 9394 SourceLocation CaretLoc, 9395 const PartialDiagnostic &PDiag) const { 9396 S.Diag(CaretLoc, PDiag) 9397 << Ambiguous.getFromType() << Ambiguous.getToType(); 9398 // FIXME: The note limiting machinery is borrowed from 9399 // OverloadCandidateSet::NoteCandidates; there's an opportunity for 9400 // refactoring here. 9401 const OverloadsShown ShowOverloads = S.Diags.getShowOverloads(); 9402 unsigned CandsShown = 0; 9403 AmbiguousConversionSequence::const_iterator I, E; 9404 for (I = Ambiguous.begin(), E = Ambiguous.end(); I != E; ++I) { 9405 if (CandsShown >= 4 && ShowOverloads == Ovl_Best) 9406 break; 9407 ++CandsShown; 9408 S.NoteOverloadCandidate(I->first, I->second); 9409 } 9410 if (I != E) 9411 S.Diag(SourceLocation(), diag::note_ovl_too_many_candidates) << int(E - I); 9412 } 9413 9414 static void DiagnoseBadConversion(Sema &S, OverloadCandidate *Cand, 9415 unsigned I, bool TakingCandidateAddress) { 9416 const ImplicitConversionSequence &Conv = Cand->Conversions[I]; 9417 assert(Conv.isBad()); 9418 assert(Cand->Function && "for now, candidate must be a function"); 9419 FunctionDecl *Fn = Cand->Function; 9420 9421 // There's a conversion slot for the object argument if this is a 9422 // non-constructor method. Note that 'I' corresponds the 9423 // conversion-slot index. 9424 bool isObjectArgument = false; 9425 if (isa<CXXMethodDecl>(Fn) && !isa<CXXConstructorDecl>(Fn)) { 9426 if (I == 0) 9427 isObjectArgument = true; 9428 else 9429 I--; 9430 } 9431 9432 std::string FnDesc; 9433 OverloadCandidateKind FnKind = 9434 ClassifyOverloadCandidate(S, Cand->FoundDecl, Fn, FnDesc); 9435 9436 Expr *FromExpr = Conv.Bad.FromExpr; 9437 QualType FromTy = Conv.Bad.getFromType(); 9438 QualType ToTy = Conv.Bad.getToType(); 9439 9440 if (FromTy == S.Context.OverloadTy) { 9441 assert(FromExpr && "overload set argument came from implicit argument?"); 9442 Expr *E = FromExpr->IgnoreParens(); 9443 if (isa<UnaryOperator>(E)) 9444 E = cast<UnaryOperator>(E)->getSubExpr()->IgnoreParens(); 9445 DeclarationName Name = cast<OverloadExpr>(E)->getName(); 9446 9447 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_overload) 9448 << (unsigned) FnKind << FnDesc 9449 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9450 << ToTy << Name << I+1; 9451 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9452 return; 9453 } 9454 9455 // Do some hand-waving analysis to see if the non-viability is due 9456 // to a qualifier mismatch. 9457 CanQualType CFromTy = S.Context.getCanonicalType(FromTy); 9458 CanQualType CToTy = S.Context.getCanonicalType(ToTy); 9459 if (CanQual<ReferenceType> RT = CToTy->getAs<ReferenceType>()) 9460 CToTy = RT->getPointeeType(); 9461 else { 9462 // TODO: detect and diagnose the full richness of const mismatches. 9463 if (CanQual<PointerType> FromPT = CFromTy->getAs<PointerType>()) 9464 if (CanQual<PointerType> ToPT = CToTy->getAs<PointerType>()) { 9465 CFromTy = FromPT->getPointeeType(); 9466 CToTy = ToPT->getPointeeType(); 9467 } 9468 } 9469 9470 if (CToTy.getUnqualifiedType() == CFromTy.getUnqualifiedType() && 9471 !CToTy.isAtLeastAsQualifiedAs(CFromTy)) { 9472 Qualifiers FromQs = CFromTy.getQualifiers(); 9473 Qualifiers ToQs = CToTy.getQualifiers(); 9474 9475 if (FromQs.getAddressSpace() != ToQs.getAddressSpace()) { 9476 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_addrspace) 9477 << (unsigned) FnKind << FnDesc 9478 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9479 << FromTy 9480 << FromQs.getAddressSpaceAttributePrintValue() 9481 << ToQs.getAddressSpaceAttributePrintValue() 9482 << (unsigned) isObjectArgument << I+1; 9483 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9484 return; 9485 } 9486 9487 if (FromQs.getObjCLifetime() != ToQs.getObjCLifetime()) { 9488 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_ownership) 9489 << (unsigned) FnKind << FnDesc 9490 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9491 << FromTy 9492 << FromQs.getObjCLifetime() << ToQs.getObjCLifetime() 9493 << (unsigned) isObjectArgument << I+1; 9494 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9495 return; 9496 } 9497 9498 if (FromQs.getObjCGCAttr() != ToQs.getObjCGCAttr()) { 9499 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_gc) 9500 << (unsigned) FnKind << FnDesc 9501 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9502 << FromTy 9503 << FromQs.getObjCGCAttr() << ToQs.getObjCGCAttr() 9504 << (unsigned) isObjectArgument << I+1; 9505 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9506 return; 9507 } 9508 9509 if (FromQs.hasUnaligned() != ToQs.hasUnaligned()) { 9510 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_unaligned) 9511 << (unsigned) FnKind << FnDesc 9512 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9513 << FromTy << FromQs.hasUnaligned() << I+1; 9514 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9515 return; 9516 } 9517 9518 unsigned CVR = FromQs.getCVRQualifiers() & ~ToQs.getCVRQualifiers(); 9519 assert(CVR && "unexpected qualifiers mismatch"); 9520 9521 if (isObjectArgument) { 9522 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_cvr_this) 9523 << (unsigned) FnKind << FnDesc 9524 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9525 << FromTy << (CVR - 1); 9526 } else { 9527 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_cvr) 9528 << (unsigned) FnKind << FnDesc 9529 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9530 << FromTy << (CVR - 1) << I+1; 9531 } 9532 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9533 return; 9534 } 9535 9536 // Special diagnostic for failure to convert an initializer list, since 9537 // telling the user that it has type void is not useful. 9538 if (FromExpr && isa<InitListExpr>(FromExpr)) { 9539 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_list_argument) 9540 << (unsigned) FnKind << FnDesc 9541 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9542 << FromTy << ToTy << (unsigned) isObjectArgument << I+1; 9543 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9544 return; 9545 } 9546 9547 // Diagnose references or pointers to incomplete types differently, 9548 // since it's far from impossible that the incompleteness triggered 9549 // the failure. 9550 QualType TempFromTy = FromTy.getNonReferenceType(); 9551 if (const PointerType *PTy = TempFromTy->getAs<PointerType>()) 9552 TempFromTy = PTy->getPointeeType(); 9553 if (TempFromTy->isIncompleteType()) { 9554 // Emit the generic diagnostic and, optionally, add the hints to it. 9555 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_conv_incomplete) 9556 << (unsigned) FnKind << FnDesc 9557 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9558 << FromTy << ToTy << (unsigned) isObjectArgument << I+1 9559 << (unsigned) (Cand->Fix.Kind); 9560 9561 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9562 return; 9563 } 9564 9565 // Diagnose base -> derived pointer conversions. 9566 unsigned BaseToDerivedConversion = 0; 9567 if (const PointerType *FromPtrTy = FromTy->getAs<PointerType>()) { 9568 if (const PointerType *ToPtrTy = ToTy->getAs<PointerType>()) { 9569 if (ToPtrTy->getPointeeType().isAtLeastAsQualifiedAs( 9570 FromPtrTy->getPointeeType()) && 9571 !FromPtrTy->getPointeeType()->isIncompleteType() && 9572 !ToPtrTy->getPointeeType()->isIncompleteType() && 9573 S.IsDerivedFrom(SourceLocation(), ToPtrTy->getPointeeType(), 9574 FromPtrTy->getPointeeType())) 9575 BaseToDerivedConversion = 1; 9576 } 9577 } else if (const ObjCObjectPointerType *FromPtrTy 9578 = FromTy->getAs<ObjCObjectPointerType>()) { 9579 if (const ObjCObjectPointerType *ToPtrTy 9580 = ToTy->getAs<ObjCObjectPointerType>()) 9581 if (const ObjCInterfaceDecl *FromIface = FromPtrTy->getInterfaceDecl()) 9582 if (const ObjCInterfaceDecl *ToIface = ToPtrTy->getInterfaceDecl()) 9583 if (ToPtrTy->getPointeeType().isAtLeastAsQualifiedAs( 9584 FromPtrTy->getPointeeType()) && 9585 FromIface->isSuperClassOf(ToIface)) 9586 BaseToDerivedConversion = 2; 9587 } else if (const ReferenceType *ToRefTy = ToTy->getAs<ReferenceType>()) { 9588 if (ToRefTy->getPointeeType().isAtLeastAsQualifiedAs(FromTy) && 9589 !FromTy->isIncompleteType() && 9590 !ToRefTy->getPointeeType()->isIncompleteType() && 9591 S.IsDerivedFrom(SourceLocation(), ToRefTy->getPointeeType(), FromTy)) { 9592 BaseToDerivedConversion = 3; 9593 } else if (ToTy->isLValueReferenceType() && !FromExpr->isLValue() && 9594 ToTy.getNonReferenceType().getCanonicalType() == 9595 FromTy.getNonReferenceType().getCanonicalType()) { 9596 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_lvalue) 9597 << (unsigned) FnKind << FnDesc 9598 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9599 << (unsigned) isObjectArgument << I + 1; 9600 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9601 return; 9602 } 9603 } 9604 9605 if (BaseToDerivedConversion) { 9606 S.Diag(Fn->getLocation(), 9607 diag::note_ovl_candidate_bad_base_to_derived_conv) 9608 << (unsigned) FnKind << FnDesc 9609 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9610 << (BaseToDerivedConversion - 1) 9611 << FromTy << ToTy << I+1; 9612 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9613 return; 9614 } 9615 9616 if (isa<ObjCObjectPointerType>(CFromTy) && 9617 isa<PointerType>(CToTy)) { 9618 Qualifiers FromQs = CFromTy.getQualifiers(); 9619 Qualifiers ToQs = CToTy.getQualifiers(); 9620 if (FromQs.getObjCLifetime() != ToQs.getObjCLifetime()) { 9621 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_arc_conv) 9622 << (unsigned) FnKind << FnDesc 9623 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9624 << FromTy << ToTy << (unsigned) isObjectArgument << I+1; 9625 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9626 return; 9627 } 9628 } 9629 9630 if (TakingCandidateAddress && 9631 !checkAddressOfCandidateIsAvailable(S, Cand->Function)) 9632 return; 9633 9634 // Emit the generic diagnostic and, optionally, add the hints to it. 9635 PartialDiagnostic FDiag = S.PDiag(diag::note_ovl_candidate_bad_conv); 9636 FDiag << (unsigned) FnKind << FnDesc 9637 << (FromExpr ? FromExpr->getSourceRange() : SourceRange()) 9638 << FromTy << ToTy << (unsigned) isObjectArgument << I + 1 9639 << (unsigned) (Cand->Fix.Kind); 9640 9641 // If we can fix the conversion, suggest the FixIts. 9642 for (std::vector<FixItHint>::iterator HI = Cand->Fix.Hints.begin(), 9643 HE = Cand->Fix.Hints.end(); HI != HE; ++HI) 9644 FDiag << *HI; 9645 S.Diag(Fn->getLocation(), FDiag); 9646 9647 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 9648 } 9649 9650 /// Additional arity mismatch diagnosis specific to a function overload 9651 /// candidates. This is not covered by the more general DiagnoseArityMismatch() 9652 /// over a candidate in any candidate set. 9653 static bool CheckArityMismatch(Sema &S, OverloadCandidate *Cand, 9654 unsigned NumArgs) { 9655 FunctionDecl *Fn = Cand->Function; 9656 unsigned MinParams = Fn->getMinRequiredArguments(); 9657 9658 // With invalid overloaded operators, it's possible that we think we 9659 // have an arity mismatch when in fact it looks like we have the 9660 // right number of arguments, because only overloaded operators have 9661 // the weird behavior of overloading member and non-member functions. 9662 // Just don't report anything. 9663 if (Fn->isInvalidDecl() && 9664 Fn->getDeclName().getNameKind() == DeclarationName::CXXOperatorName) 9665 return true; 9666 9667 if (NumArgs < MinParams) { 9668 assert((Cand->FailureKind == ovl_fail_too_few_arguments) || 9669 (Cand->FailureKind == ovl_fail_bad_deduction && 9670 Cand->DeductionFailure.Result == Sema::TDK_TooFewArguments)); 9671 } else { 9672 assert((Cand->FailureKind == ovl_fail_too_many_arguments) || 9673 (Cand->FailureKind == ovl_fail_bad_deduction && 9674 Cand->DeductionFailure.Result == Sema::TDK_TooManyArguments)); 9675 } 9676 9677 return false; 9678 } 9679 9680 /// General arity mismatch diagnosis over a candidate in a candidate set. 9681 static void DiagnoseArityMismatch(Sema &S, NamedDecl *Found, Decl *D, 9682 unsigned NumFormalArgs) { 9683 assert(isa<FunctionDecl>(D) && 9684 "The templated declaration should at least be a function" 9685 " when diagnosing bad template argument deduction due to too many" 9686 " or too few arguments"); 9687 9688 FunctionDecl *Fn = cast<FunctionDecl>(D); 9689 9690 // TODO: treat calls to a missing default constructor as a special case 9691 const FunctionProtoType *FnTy = Fn->getType()->getAs<FunctionProtoType>(); 9692 unsigned MinParams = Fn->getMinRequiredArguments(); 9693 9694 // at least / at most / exactly 9695 unsigned mode, modeCount; 9696 if (NumFormalArgs < MinParams) { 9697 if (MinParams != FnTy->getNumParams() || FnTy->isVariadic() || 9698 FnTy->isTemplateVariadic()) 9699 mode = 0; // "at least" 9700 else 9701 mode = 2; // "exactly" 9702 modeCount = MinParams; 9703 } else { 9704 if (MinParams != FnTy->getNumParams()) 9705 mode = 1; // "at most" 9706 else 9707 mode = 2; // "exactly" 9708 modeCount = FnTy->getNumParams(); 9709 } 9710 9711 std::string Description; 9712 OverloadCandidateKind FnKind = 9713 ClassifyOverloadCandidate(S, Found, Fn, Description); 9714 9715 if (modeCount == 1 && Fn->getParamDecl(0)->getDeclName()) 9716 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_arity_one) 9717 << (unsigned) FnKind << (Fn->getDescribedFunctionTemplate() != nullptr) 9718 << mode << Fn->getParamDecl(0) << NumFormalArgs; 9719 else 9720 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_arity) 9721 << (unsigned) FnKind << (Fn->getDescribedFunctionTemplate() != nullptr) 9722 << mode << modeCount << NumFormalArgs; 9723 MaybeEmitInheritedConstructorNote(S, Found); 9724 } 9725 9726 /// Arity mismatch diagnosis specific to a function overload candidate. 9727 static void DiagnoseArityMismatch(Sema &S, OverloadCandidate *Cand, 9728 unsigned NumFormalArgs) { 9729 if (!CheckArityMismatch(S, Cand, NumFormalArgs)) 9730 DiagnoseArityMismatch(S, Cand->FoundDecl, Cand->Function, NumFormalArgs); 9731 } 9732 9733 static TemplateDecl *getDescribedTemplate(Decl *Templated) { 9734 if (TemplateDecl *TD = Templated->getDescribedTemplate()) 9735 return TD; 9736 llvm_unreachable("Unsupported: Getting the described template declaration" 9737 " for bad deduction diagnosis"); 9738 } 9739 9740 /// Diagnose a failed template-argument deduction. 9741 static void DiagnoseBadDeduction(Sema &S, NamedDecl *Found, Decl *Templated, 9742 DeductionFailureInfo &DeductionFailure, 9743 unsigned NumArgs, 9744 bool TakingCandidateAddress) { 9745 TemplateParameter Param = DeductionFailure.getTemplateParameter(); 9746 NamedDecl *ParamD; 9747 (ParamD = Param.dyn_cast<TemplateTypeParmDecl*>()) || 9748 (ParamD = Param.dyn_cast<NonTypeTemplateParmDecl*>()) || 9749 (ParamD = Param.dyn_cast<TemplateTemplateParmDecl*>()); 9750 switch (DeductionFailure.Result) { 9751 case Sema::TDK_Success: 9752 llvm_unreachable("TDK_success while diagnosing bad deduction"); 9753 9754 case Sema::TDK_Incomplete: { 9755 assert(ParamD && "no parameter found for incomplete deduction result"); 9756 S.Diag(Templated->getLocation(), 9757 diag::note_ovl_candidate_incomplete_deduction) 9758 << ParamD->getDeclName(); 9759 MaybeEmitInheritedConstructorNote(S, Found); 9760 return; 9761 } 9762 9763 case Sema::TDK_Underqualified: { 9764 assert(ParamD && "no parameter found for bad qualifiers deduction result"); 9765 TemplateTypeParmDecl *TParam = cast<TemplateTypeParmDecl>(ParamD); 9766 9767 QualType Param = DeductionFailure.getFirstArg()->getAsType(); 9768 9769 // Param will have been canonicalized, but it should just be a 9770 // qualified version of ParamD, so move the qualifiers to that. 9771 QualifierCollector Qs; 9772 Qs.strip(Param); 9773 QualType NonCanonParam = Qs.apply(S.Context, TParam->getTypeForDecl()); 9774 assert(S.Context.hasSameType(Param, NonCanonParam)); 9775 9776 // Arg has also been canonicalized, but there's nothing we can do 9777 // about that. It also doesn't matter as much, because it won't 9778 // have any template parameters in it (because deduction isn't 9779 // done on dependent types). 9780 QualType Arg = DeductionFailure.getSecondArg()->getAsType(); 9781 9782 S.Diag(Templated->getLocation(), diag::note_ovl_candidate_underqualified) 9783 << ParamD->getDeclName() << Arg << NonCanonParam; 9784 MaybeEmitInheritedConstructorNote(S, Found); 9785 return; 9786 } 9787 9788 case Sema::TDK_Inconsistent: { 9789 assert(ParamD && "no parameter found for inconsistent deduction result"); 9790 int which = 0; 9791 if (isa<TemplateTypeParmDecl>(ParamD)) 9792 which = 0; 9793 else if (isa<NonTypeTemplateParmDecl>(ParamD)) { 9794 // Deduction might have failed because we deduced arguments of two 9795 // different types for a non-type template parameter. 9796 // FIXME: Use a different TDK value for this. 9797 QualType T1 = 9798 DeductionFailure.getFirstArg()->getNonTypeTemplateArgumentType(); 9799 QualType T2 = 9800 DeductionFailure.getSecondArg()->getNonTypeTemplateArgumentType(); 9801 if (!S.Context.hasSameType(T1, T2)) { 9802 S.Diag(Templated->getLocation(), 9803 diag::note_ovl_candidate_inconsistent_deduction_types) 9804 << ParamD->getDeclName() << *DeductionFailure.getFirstArg() << T1 9805 << *DeductionFailure.getSecondArg() << T2; 9806 MaybeEmitInheritedConstructorNote(S, Found); 9807 return; 9808 } 9809 9810 which = 1; 9811 } else { 9812 which = 2; 9813 } 9814 9815 S.Diag(Templated->getLocation(), 9816 diag::note_ovl_candidate_inconsistent_deduction) 9817 << which << ParamD->getDeclName() << *DeductionFailure.getFirstArg() 9818 << *DeductionFailure.getSecondArg(); 9819 MaybeEmitInheritedConstructorNote(S, Found); 9820 return; 9821 } 9822 9823 case Sema::TDK_InvalidExplicitArguments: 9824 assert(ParamD && "no parameter found for invalid explicit arguments"); 9825 if (ParamD->getDeclName()) 9826 S.Diag(Templated->getLocation(), 9827 diag::note_ovl_candidate_explicit_arg_mismatch_named) 9828 << ParamD->getDeclName(); 9829 else { 9830 int index = 0; 9831 if (TemplateTypeParmDecl *TTP = dyn_cast<TemplateTypeParmDecl>(ParamD)) 9832 index = TTP->getIndex(); 9833 else if (NonTypeTemplateParmDecl *NTTP 9834 = dyn_cast<NonTypeTemplateParmDecl>(ParamD)) 9835 index = NTTP->getIndex(); 9836 else 9837 index = cast<TemplateTemplateParmDecl>(ParamD)->getIndex(); 9838 S.Diag(Templated->getLocation(), 9839 diag::note_ovl_candidate_explicit_arg_mismatch_unnamed) 9840 << (index + 1); 9841 } 9842 MaybeEmitInheritedConstructorNote(S, Found); 9843 return; 9844 9845 case Sema::TDK_TooManyArguments: 9846 case Sema::TDK_TooFewArguments: 9847 DiagnoseArityMismatch(S, Found, Templated, NumArgs); 9848 return; 9849 9850 case Sema::TDK_InstantiationDepth: 9851 S.Diag(Templated->getLocation(), 9852 diag::note_ovl_candidate_instantiation_depth); 9853 MaybeEmitInheritedConstructorNote(S, Found); 9854 return; 9855 9856 case Sema::TDK_SubstitutionFailure: { 9857 // Format the template argument list into the argument string. 9858 SmallString<128> TemplateArgString; 9859 if (TemplateArgumentList *Args = 9860 DeductionFailure.getTemplateArgumentList()) { 9861 TemplateArgString = " "; 9862 TemplateArgString += S.getTemplateArgumentBindingsText( 9863 getDescribedTemplate(Templated)->getTemplateParameters(), *Args); 9864 } 9865 9866 // If this candidate was disabled by enable_if, say so. 9867 PartialDiagnosticAt *PDiag = DeductionFailure.getSFINAEDiagnostic(); 9868 if (PDiag && PDiag->second.getDiagID() == 9869 diag::err_typename_nested_not_found_enable_if) { 9870 // FIXME: Use the source range of the condition, and the fully-qualified 9871 // name of the enable_if template. These are both present in PDiag. 9872 S.Diag(PDiag->first, diag::note_ovl_candidate_disabled_by_enable_if) 9873 << "'enable_if'" << TemplateArgString; 9874 return; 9875 } 9876 9877 // We found a specific requirement that disabled the enable_if. 9878 if (PDiag && PDiag->second.getDiagID() == 9879 diag::err_typename_nested_not_found_requirement) { 9880 S.Diag(Templated->getLocation(), 9881 diag::note_ovl_candidate_disabled_by_requirement) 9882 << PDiag->second.getStringArg(0) << TemplateArgString; 9883 return; 9884 } 9885 9886 // Format the SFINAE diagnostic into the argument string. 9887 // FIXME: Add a general mechanism to include a PartialDiagnostic *'s 9888 // formatted message in another diagnostic. 9889 SmallString<128> SFINAEArgString; 9890 SourceRange R; 9891 if (PDiag) { 9892 SFINAEArgString = ": "; 9893 R = SourceRange(PDiag->first, PDiag->first); 9894 PDiag->second.EmitToString(S.getDiagnostics(), SFINAEArgString); 9895 } 9896 9897 S.Diag(Templated->getLocation(), 9898 diag::note_ovl_candidate_substitution_failure) 9899 << TemplateArgString << SFINAEArgString << R; 9900 MaybeEmitInheritedConstructorNote(S, Found); 9901 return; 9902 } 9903 9904 case Sema::TDK_DeducedMismatch: 9905 case Sema::TDK_DeducedMismatchNested: { 9906 // Format the template argument list into the argument string. 9907 SmallString<128> TemplateArgString; 9908 if (TemplateArgumentList *Args = 9909 DeductionFailure.getTemplateArgumentList()) { 9910 TemplateArgString = " "; 9911 TemplateArgString += S.getTemplateArgumentBindingsText( 9912 getDescribedTemplate(Templated)->getTemplateParameters(), *Args); 9913 } 9914 9915 S.Diag(Templated->getLocation(), diag::note_ovl_candidate_deduced_mismatch) 9916 << (*DeductionFailure.getCallArgIndex() + 1) 9917 << *DeductionFailure.getFirstArg() << *DeductionFailure.getSecondArg() 9918 << TemplateArgString 9919 << (DeductionFailure.Result == Sema::TDK_DeducedMismatchNested); 9920 break; 9921 } 9922 9923 case Sema::TDK_NonDeducedMismatch: { 9924 // FIXME: Provide a source location to indicate what we couldn't match. 9925 TemplateArgument FirstTA = *DeductionFailure.getFirstArg(); 9926 TemplateArgument SecondTA = *DeductionFailure.getSecondArg(); 9927 if (FirstTA.getKind() == TemplateArgument::Template && 9928 SecondTA.getKind() == TemplateArgument::Template) { 9929 TemplateName FirstTN = FirstTA.getAsTemplate(); 9930 TemplateName SecondTN = SecondTA.getAsTemplate(); 9931 if (FirstTN.getKind() == TemplateName::Template && 9932 SecondTN.getKind() == TemplateName::Template) { 9933 if (FirstTN.getAsTemplateDecl()->getName() == 9934 SecondTN.getAsTemplateDecl()->getName()) { 9935 // FIXME: This fixes a bad diagnostic where both templates are named 9936 // the same. This particular case is a bit difficult since: 9937 // 1) It is passed as a string to the diagnostic printer. 9938 // 2) The diagnostic printer only attempts to find a better 9939 // name for types, not decls. 9940 // Ideally, this should folded into the diagnostic printer. 9941 S.Diag(Templated->getLocation(), 9942 diag::note_ovl_candidate_non_deduced_mismatch_qualified) 9943 << FirstTN.getAsTemplateDecl() << SecondTN.getAsTemplateDecl(); 9944 return; 9945 } 9946 } 9947 } 9948 9949 if (TakingCandidateAddress && isa<FunctionDecl>(Templated) && 9950 !checkAddressOfCandidateIsAvailable(S, cast<FunctionDecl>(Templated))) 9951 return; 9952 9953 // FIXME: For generic lambda parameters, check if the function is a lambda 9954 // call operator, and if so, emit a prettier and more informative 9955 // diagnostic that mentions 'auto' and lambda in addition to 9956 // (or instead of?) the canonical template type parameters. 9957 S.Diag(Templated->getLocation(), 9958 diag::note_ovl_candidate_non_deduced_mismatch) 9959 << FirstTA << SecondTA; 9960 return; 9961 } 9962 // TODO: diagnose these individually, then kill off 9963 // note_ovl_candidate_bad_deduction, which is uselessly vague. 9964 case Sema::TDK_MiscellaneousDeductionFailure: 9965 S.Diag(Templated->getLocation(), diag::note_ovl_candidate_bad_deduction); 9966 MaybeEmitInheritedConstructorNote(S, Found); 9967 return; 9968 case Sema::TDK_CUDATargetMismatch: 9969 S.Diag(Templated->getLocation(), 9970 diag::note_cuda_ovl_candidate_target_mismatch); 9971 return; 9972 } 9973 } 9974 9975 /// Diagnose a failed template-argument deduction, for function calls. 9976 static void DiagnoseBadDeduction(Sema &S, OverloadCandidate *Cand, 9977 unsigned NumArgs, 9978 bool TakingCandidateAddress) { 9979 unsigned TDK = Cand->DeductionFailure.Result; 9980 if (TDK == Sema::TDK_TooFewArguments || TDK == Sema::TDK_TooManyArguments) { 9981 if (CheckArityMismatch(S, Cand, NumArgs)) 9982 return; 9983 } 9984 DiagnoseBadDeduction(S, Cand->FoundDecl, Cand->Function, // pattern 9985 Cand->DeductionFailure, NumArgs, TakingCandidateAddress); 9986 } 9987 9988 /// CUDA: diagnose an invalid call across targets. 9989 static void DiagnoseBadTarget(Sema &S, OverloadCandidate *Cand) { 9990 FunctionDecl *Caller = cast<FunctionDecl>(S.CurContext); 9991 FunctionDecl *Callee = Cand->Function; 9992 9993 Sema::CUDAFunctionTarget CallerTarget = S.IdentifyCUDATarget(Caller), 9994 CalleeTarget = S.IdentifyCUDATarget(Callee); 9995 9996 std::string FnDesc; 9997 OverloadCandidateKind FnKind = 9998 ClassifyOverloadCandidate(S, Cand->FoundDecl, Callee, FnDesc); 9999 10000 S.Diag(Callee->getLocation(), diag::note_ovl_candidate_bad_target) 10001 << (unsigned)FnKind << CalleeTarget << CallerTarget; 10002 10003 // This could be an implicit constructor for which we could not infer the 10004 // target due to a collsion. Diagnose that case. 10005 CXXMethodDecl *Meth = dyn_cast<CXXMethodDecl>(Callee); 10006 if (Meth != nullptr && Meth->isImplicit()) { 10007 CXXRecordDecl *ParentClass = Meth->getParent(); 10008 Sema::CXXSpecialMember CSM; 10009 10010 switch (FnKind) { 10011 default: 10012 return; 10013 case oc_implicit_default_constructor: 10014 CSM = Sema::CXXDefaultConstructor; 10015 break; 10016 case oc_implicit_copy_constructor: 10017 CSM = Sema::CXXCopyConstructor; 10018 break; 10019 case oc_implicit_move_constructor: 10020 CSM = Sema::CXXMoveConstructor; 10021 break; 10022 case oc_implicit_copy_assignment: 10023 CSM = Sema::CXXCopyAssignment; 10024 break; 10025 case oc_implicit_move_assignment: 10026 CSM = Sema::CXXMoveAssignment; 10027 break; 10028 }; 10029 10030 bool ConstRHS = false; 10031 if (Meth->getNumParams()) { 10032 if (const ReferenceType *RT = 10033 Meth->getParamDecl(0)->getType()->getAs<ReferenceType>()) { 10034 ConstRHS = RT->getPointeeType().isConstQualified(); 10035 } 10036 } 10037 10038 S.inferCUDATargetForImplicitSpecialMember(ParentClass, CSM, Meth, 10039 /* ConstRHS */ ConstRHS, 10040 /* Diagnose */ true); 10041 } 10042 } 10043 10044 static void DiagnoseFailedEnableIfAttr(Sema &S, OverloadCandidate *Cand) { 10045 FunctionDecl *Callee = Cand->Function; 10046 EnableIfAttr *Attr = static_cast<EnableIfAttr*>(Cand->DeductionFailure.Data); 10047 10048 S.Diag(Callee->getLocation(), 10049 diag::note_ovl_candidate_disabled_by_function_cond_attr) 10050 << Attr->getCond()->getSourceRange() << Attr->getMessage(); 10051 } 10052 10053 static void DiagnoseOpenCLExtensionDisabled(Sema &S, OverloadCandidate *Cand) { 10054 FunctionDecl *Callee = Cand->Function; 10055 10056 S.Diag(Callee->getLocation(), 10057 diag::note_ovl_candidate_disabled_by_extension); 10058 } 10059 10060 /// Generates a 'note' diagnostic for an overload candidate. We've 10061 /// already generated a primary error at the call site. 10062 /// 10063 /// It really does need to be a single diagnostic with its caret 10064 /// pointed at the candidate declaration. Yes, this creates some 10065 /// major challenges of technical writing. Yes, this makes pointing 10066 /// out problems with specific arguments quite awkward. It's still 10067 /// better than generating twenty screens of text for every failed 10068 /// overload. 10069 /// 10070 /// It would be great to be able to express per-candidate problems 10071 /// more richly for those diagnostic clients that cared, but we'd 10072 /// still have to be just as careful with the default diagnostics. 10073 static void NoteFunctionCandidate(Sema &S, OverloadCandidate *Cand, 10074 unsigned NumArgs, 10075 bool TakingCandidateAddress) { 10076 FunctionDecl *Fn = Cand->Function; 10077 10078 // Note deleted candidates, but only if they're viable. 10079 if (Cand->Viable) { 10080 if (Fn->isDeleted() || S.isFunctionConsideredUnavailable(Fn)) { 10081 std::string FnDesc; 10082 OverloadCandidateKind FnKind = 10083 ClassifyOverloadCandidate(S, Cand->FoundDecl, Fn, FnDesc); 10084 10085 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_deleted) 10086 << FnKind << FnDesc 10087 << (Fn->isDeleted() ? (Fn->isDeletedAsWritten() ? 1 : 2) : 0); 10088 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 10089 return; 10090 } 10091 10092 // We don't really have anything else to say about viable candidates. 10093 S.NoteOverloadCandidate(Cand->FoundDecl, Fn); 10094 return; 10095 } 10096 10097 switch (Cand->FailureKind) { 10098 case ovl_fail_too_many_arguments: 10099 case ovl_fail_too_few_arguments: 10100 return DiagnoseArityMismatch(S, Cand, NumArgs); 10101 10102 case ovl_fail_bad_deduction: 10103 return DiagnoseBadDeduction(S, Cand, NumArgs, 10104 TakingCandidateAddress); 10105 10106 case ovl_fail_illegal_constructor: { 10107 S.Diag(Fn->getLocation(), diag::note_ovl_candidate_illegal_constructor) 10108 << (Fn->getPrimaryTemplate() ? 1 : 0); 10109 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 10110 return; 10111 } 10112 10113 case ovl_fail_trivial_conversion: 10114 case ovl_fail_bad_final_conversion: 10115 case ovl_fail_final_conversion_not_exact: 10116 return S.NoteOverloadCandidate(Cand->FoundDecl, Fn); 10117 10118 case ovl_fail_bad_conversion: { 10119 unsigned I = (Cand->IgnoreObjectArgument ? 1 : 0); 10120 for (unsigned N = Cand->Conversions.size(); I != N; ++I) 10121 if (Cand->Conversions[I].isBad()) 10122 return DiagnoseBadConversion(S, Cand, I, TakingCandidateAddress); 10123 10124 // FIXME: this currently happens when we're called from SemaInit 10125 // when user-conversion overload fails. Figure out how to handle 10126 // those conditions and diagnose them well. 10127 return S.NoteOverloadCandidate(Cand->FoundDecl, Fn); 10128 } 10129 10130 case ovl_fail_bad_target: 10131 return DiagnoseBadTarget(S, Cand); 10132 10133 case ovl_fail_enable_if: 10134 return DiagnoseFailedEnableIfAttr(S, Cand); 10135 10136 case ovl_fail_ext_disabled: 10137 return DiagnoseOpenCLExtensionDisabled(S, Cand); 10138 10139 case ovl_fail_inhctor_slice: 10140 // It's generally not interesting to note copy/move constructors here. 10141 if (cast<CXXConstructorDecl>(Fn)->isCopyOrMoveConstructor()) 10142 return; 10143 S.Diag(Fn->getLocation(), 10144 diag::note_ovl_candidate_inherited_constructor_slice) 10145 << (Fn->getPrimaryTemplate() ? 1 : 0) 10146 << Fn->getParamDecl(0)->getType()->isRValueReferenceType(); 10147 MaybeEmitInheritedConstructorNote(S, Cand->FoundDecl); 10148 return; 10149 10150 case ovl_fail_addr_not_available: { 10151 bool Available = checkAddressOfCandidateIsAvailable(S, Cand->Function); 10152 (void)Available; 10153 assert(!Available); 10154 break; 10155 } 10156 } 10157 } 10158 10159 static void NoteSurrogateCandidate(Sema &S, OverloadCandidate *Cand) { 10160 // Desugar the type of the surrogate down to a function type, 10161 // retaining as many typedefs as possible while still showing 10162 // the function type (and, therefore, its parameter types). 10163 QualType FnType = Cand->Surrogate->getConversionType(); 10164 bool isLValueReference = false; 10165 bool isRValueReference = false; 10166 bool isPointer = false; 10167 if (const LValueReferenceType *FnTypeRef = 10168 FnType->getAs<LValueReferenceType>()) { 10169 FnType = FnTypeRef->getPointeeType(); 10170 isLValueReference = true; 10171 } else if (const RValueReferenceType *FnTypeRef = 10172 FnType->getAs<RValueReferenceType>()) { 10173 FnType = FnTypeRef->getPointeeType(); 10174 isRValueReference = true; 10175 } 10176 if (const PointerType *FnTypePtr = FnType->getAs<PointerType>()) { 10177 FnType = FnTypePtr->getPointeeType(); 10178 isPointer = true; 10179 } 10180 // Desugar down to a function type. 10181 FnType = QualType(FnType->getAs<FunctionType>(), 0); 10182 // Reconstruct the pointer/reference as appropriate. 10183 if (isPointer) FnType = S.Context.getPointerType(FnType); 10184 if (isRValueReference) FnType = S.Context.getRValueReferenceType(FnType); 10185 if (isLValueReference) FnType = S.Context.getLValueReferenceType(FnType); 10186 10187 S.Diag(Cand->Surrogate->getLocation(), diag::note_ovl_surrogate_cand) 10188 << FnType; 10189 } 10190 10191 static void NoteBuiltinOperatorCandidate(Sema &S, StringRef Opc, 10192 SourceLocation OpLoc, 10193 OverloadCandidate *Cand) { 10194 assert(Cand->Conversions.size() <= 2 && "builtin operator is not binary"); 10195 std::string TypeStr("operator"); 10196 TypeStr += Opc; 10197 TypeStr += "("; 10198 TypeStr += Cand->BuiltinParamTypes[0].getAsString(); 10199 if (Cand->Conversions.size() == 1) { 10200 TypeStr += ")"; 10201 S.Diag(OpLoc, diag::note_ovl_builtin_unary_candidate) << TypeStr; 10202 } else { 10203 TypeStr += ", "; 10204 TypeStr += Cand->BuiltinParamTypes[1].getAsString(); 10205 TypeStr += ")"; 10206 S.Diag(OpLoc, diag::note_ovl_builtin_binary_candidate) << TypeStr; 10207 } 10208 } 10209 10210 static void NoteAmbiguousUserConversions(Sema &S, SourceLocation OpLoc, 10211 OverloadCandidate *Cand) { 10212 for (const ImplicitConversionSequence &ICS : Cand->Conversions) { 10213 if (ICS.isBad()) break; // all meaningless after first invalid 10214 if (!ICS.isAmbiguous()) continue; 10215 10216 ICS.DiagnoseAmbiguousConversion( 10217 S, OpLoc, S.PDiag(diag::note_ambiguous_type_conversion)); 10218 } 10219 } 10220 10221 static SourceLocation GetLocationForCandidate(const OverloadCandidate *Cand) { 10222 if (Cand->Function) 10223 return Cand->Function->getLocation(); 10224 if (Cand->IsSurrogate) 10225 return Cand->Surrogate->getLocation(); 10226 return SourceLocation(); 10227 } 10228 10229 static unsigned RankDeductionFailure(const DeductionFailureInfo &DFI) { 10230 switch ((Sema::TemplateDeductionResult)DFI.Result) { 10231 case Sema::TDK_Success: 10232 case Sema::TDK_NonDependentConversionFailure: 10233 llvm_unreachable("non-deduction failure while diagnosing bad deduction"); 10234 10235 case Sema::TDK_Invalid: 10236 case Sema::TDK_Incomplete: 10237 return 1; 10238 10239 case Sema::TDK_Underqualified: 10240 case Sema::TDK_Inconsistent: 10241 return 2; 10242 10243 case Sema::TDK_SubstitutionFailure: 10244 case Sema::TDK_DeducedMismatch: 10245 case Sema::TDK_DeducedMismatchNested: 10246 case Sema::TDK_NonDeducedMismatch: 10247 case Sema::TDK_MiscellaneousDeductionFailure: 10248 case Sema::TDK_CUDATargetMismatch: 10249 return 3; 10250 10251 case Sema::TDK_InstantiationDepth: 10252 return 4; 10253 10254 case Sema::TDK_InvalidExplicitArguments: 10255 return 5; 10256 10257 case Sema::TDK_TooManyArguments: 10258 case Sema::TDK_TooFewArguments: 10259 return 6; 10260 } 10261 llvm_unreachable("Unhandled deduction result"); 10262 } 10263 10264 namespace { 10265 struct CompareOverloadCandidatesForDisplay { 10266 Sema &S; 10267 SourceLocation Loc; 10268 size_t NumArgs; 10269 OverloadCandidateSet::CandidateSetKind CSK; 10270 10271 CompareOverloadCandidatesForDisplay( 10272 Sema &S, SourceLocation Loc, size_t NArgs, 10273 OverloadCandidateSet::CandidateSetKind CSK) 10274 : S(S), NumArgs(NArgs), CSK(CSK) {} 10275 10276 bool operator()(const OverloadCandidate *L, 10277 const OverloadCandidate *R) { 10278 // Fast-path this check. 10279 if (L == R) return false; 10280 10281 // Order first by viability. 10282 if (L->Viable) { 10283 if (!R->Viable) return true; 10284 10285 // TODO: introduce a tri-valued comparison for overload 10286 // candidates. Would be more worthwhile if we had a sort 10287 // that could exploit it. 10288 if (isBetterOverloadCandidate(S, *L, *R, SourceLocation(), CSK)) 10289 return true; 10290 if (isBetterOverloadCandidate(S, *R, *L, SourceLocation(), CSK)) 10291 return false; 10292 } else if (R->Viable) 10293 return false; 10294 10295 assert(L->Viable == R->Viable); 10296 10297 // Criteria by which we can sort non-viable candidates: 10298 if (!L->Viable) { 10299 // 1. Arity mismatches come after other candidates. 10300 if (L->FailureKind == ovl_fail_too_many_arguments || 10301 L->FailureKind == ovl_fail_too_few_arguments) { 10302 if (R->FailureKind == ovl_fail_too_many_arguments || 10303 R->FailureKind == ovl_fail_too_few_arguments) { 10304 int LDist = std::abs((int)L->getNumParams() - (int)NumArgs); 10305 int RDist = std::abs((int)R->getNumParams() - (int)NumArgs); 10306 if (LDist == RDist) { 10307 if (L->FailureKind == R->FailureKind) 10308 // Sort non-surrogates before surrogates. 10309 return !L->IsSurrogate && R->IsSurrogate; 10310 // Sort candidates requiring fewer parameters than there were 10311 // arguments given after candidates requiring more parameters 10312 // than there were arguments given. 10313 return L->FailureKind == ovl_fail_too_many_arguments; 10314 } 10315 return LDist < RDist; 10316 } 10317 return false; 10318 } 10319 if (R->FailureKind == ovl_fail_too_many_arguments || 10320 R->FailureKind == ovl_fail_too_few_arguments) 10321 return true; 10322 10323 // 2. Bad conversions come first and are ordered by the number 10324 // of bad conversions and quality of good conversions. 10325 if (L->FailureKind == ovl_fail_bad_conversion) { 10326 if (R->FailureKind != ovl_fail_bad_conversion) 10327 return true; 10328 10329 // The conversion that can be fixed with a smaller number of changes, 10330 // comes first. 10331 unsigned numLFixes = L->Fix.NumConversionsFixed; 10332 unsigned numRFixes = R->Fix.NumConversionsFixed; 10333 numLFixes = (numLFixes == 0) ? UINT_MAX : numLFixes; 10334 numRFixes = (numRFixes == 0) ? UINT_MAX : numRFixes; 10335 if (numLFixes != numRFixes) { 10336 return numLFixes < numRFixes; 10337 } 10338 10339 // If there's any ordering between the defined conversions... 10340 // FIXME: this might not be transitive. 10341 assert(L->Conversions.size() == R->Conversions.size()); 10342 10343 int leftBetter = 0; 10344 unsigned I = (L->IgnoreObjectArgument || R->IgnoreObjectArgument); 10345 for (unsigned E = L->Conversions.size(); I != E; ++I) { 10346 switch (CompareImplicitConversionSequences(S, Loc, 10347 L->Conversions[I], 10348 R->Conversions[I])) { 10349 case ImplicitConversionSequence::Better: 10350 leftBetter++; 10351 break; 10352 10353 case ImplicitConversionSequence::Worse: 10354 leftBetter--; 10355 break; 10356 10357 case ImplicitConversionSequence::Indistinguishable: 10358 break; 10359 } 10360 } 10361 if (leftBetter > 0) return true; 10362 if (leftBetter < 0) return false; 10363 10364 } else if (R->FailureKind == ovl_fail_bad_conversion) 10365 return false; 10366 10367 if (L->FailureKind == ovl_fail_bad_deduction) { 10368 if (R->FailureKind != ovl_fail_bad_deduction) 10369 return true; 10370 10371 if (L->DeductionFailure.Result != R->DeductionFailure.Result) 10372 return RankDeductionFailure(L->DeductionFailure) 10373 < RankDeductionFailure(R->DeductionFailure); 10374 } else if (R->FailureKind == ovl_fail_bad_deduction) 10375 return false; 10376 10377 // TODO: others? 10378 } 10379 10380 // Sort everything else by location. 10381 SourceLocation LLoc = GetLocationForCandidate(L); 10382 SourceLocation RLoc = GetLocationForCandidate(R); 10383 10384 // Put candidates without locations (e.g. builtins) at the end. 10385 if (LLoc.isInvalid()) return false; 10386 if (RLoc.isInvalid()) return true; 10387 10388 return S.SourceMgr.isBeforeInTranslationUnit(LLoc, RLoc); 10389 } 10390 }; 10391 } 10392 10393 /// CompleteNonViableCandidate - Normally, overload resolution only 10394 /// computes up to the first bad conversion. Produces the FixIt set if 10395 /// possible. 10396 static void CompleteNonViableCandidate(Sema &S, OverloadCandidate *Cand, 10397 ArrayRef<Expr *> Args) { 10398 assert(!Cand->Viable); 10399 10400 // Don't do anything on failures other than bad conversion. 10401 if (Cand->FailureKind != ovl_fail_bad_conversion) return; 10402 10403 // We only want the FixIts if all the arguments can be corrected. 10404 bool Unfixable = false; 10405 // Use a implicit copy initialization to check conversion fixes. 10406 Cand->Fix.setConversionChecker(TryCopyInitialization); 10407 10408 // Attempt to fix the bad conversion. 10409 unsigned ConvCount = Cand->Conversions.size(); 10410 for (unsigned ConvIdx = (Cand->IgnoreObjectArgument ? 1 : 0); /**/; 10411 ++ConvIdx) { 10412 assert(ConvIdx != ConvCount && "no bad conversion in candidate"); 10413 if (Cand->Conversions[ConvIdx].isInitialized() && 10414 Cand->Conversions[ConvIdx].isBad()) { 10415 Unfixable = !Cand->TryToFixBadConversion(ConvIdx, S); 10416 break; 10417 } 10418 } 10419 10420 // FIXME: this should probably be preserved from the overload 10421 // operation somehow. 10422 bool SuppressUserConversions = false; 10423 10424 unsigned ConvIdx = 0; 10425 ArrayRef<QualType> ParamTypes; 10426 10427 if (Cand->IsSurrogate) { 10428 QualType ConvType 10429 = Cand->Surrogate->getConversionType().getNonReferenceType(); 10430 if (const PointerType *ConvPtrType = ConvType->getAs<PointerType>()) 10431 ConvType = ConvPtrType->getPointeeType(); 10432 ParamTypes = ConvType->getAs<FunctionProtoType>()->getParamTypes(); 10433 // Conversion 0 is 'this', which doesn't have a corresponding argument. 10434 ConvIdx = 1; 10435 } else if (Cand->Function) { 10436 ParamTypes = 10437 Cand->Function->getType()->getAs<FunctionProtoType>()->getParamTypes(); 10438 if (isa<CXXMethodDecl>(Cand->Function) && 10439 !isa<CXXConstructorDecl>(Cand->Function)) { 10440 // Conversion 0 is 'this', which doesn't have a corresponding argument. 10441 ConvIdx = 1; 10442 } 10443 } else { 10444 // Builtin operator. 10445 assert(ConvCount <= 3); 10446 ParamTypes = Cand->BuiltinParamTypes; 10447 } 10448 10449 // Fill in the rest of the conversions. 10450 for (unsigned ArgIdx = 0; ConvIdx != ConvCount; ++ConvIdx, ++ArgIdx) { 10451 if (Cand->Conversions[ConvIdx].isInitialized()) { 10452 // We've already checked this conversion. 10453 } else if (ArgIdx < ParamTypes.size()) { 10454 if (ParamTypes[ArgIdx]->isDependentType()) 10455 Cand->Conversions[ConvIdx].setAsIdentityConversion( 10456 Args[ArgIdx]->getType()); 10457 else { 10458 Cand->Conversions[ConvIdx] = 10459 TryCopyInitialization(S, Args[ArgIdx], ParamTypes[ArgIdx], 10460 SuppressUserConversions, 10461 /*InOverloadResolution=*/true, 10462 /*AllowObjCWritebackConversion=*/ 10463 S.getLangOpts().ObjCAutoRefCount); 10464 // Store the FixIt in the candidate if it exists. 10465 if (!Unfixable && Cand->Conversions[ConvIdx].isBad()) 10466 Unfixable = !Cand->TryToFixBadConversion(ConvIdx, S); 10467 } 10468 } else 10469 Cand->Conversions[ConvIdx].setEllipsis(); 10470 } 10471 } 10472 10473 /// PrintOverloadCandidates - When overload resolution fails, prints 10474 /// diagnostic messages containing the candidates in the candidate 10475 /// set. 10476 void OverloadCandidateSet::NoteCandidates( 10477 Sema &S, OverloadCandidateDisplayKind OCD, ArrayRef<Expr *> Args, 10478 StringRef Opc, SourceLocation OpLoc, 10479 llvm::function_ref<bool(OverloadCandidate &)> Filter) { 10480 // Sort the candidates by viability and position. Sorting directly would 10481 // be prohibitive, so we make a set of pointers and sort those. 10482 SmallVector<OverloadCandidate*, 32> Cands; 10483 if (OCD == OCD_AllCandidates) Cands.reserve(size()); 10484 for (iterator Cand = begin(), LastCand = end(); Cand != LastCand; ++Cand) { 10485 if (!Filter(*Cand)) 10486 continue; 10487 if (Cand->Viable) 10488 Cands.push_back(Cand); 10489 else if (OCD == OCD_AllCandidates) { 10490 CompleteNonViableCandidate(S, Cand, Args); 10491 if (Cand->Function || Cand->IsSurrogate) 10492 Cands.push_back(Cand); 10493 // Otherwise, this a non-viable builtin candidate. We do not, in general, 10494 // want to list every possible builtin candidate. 10495 } 10496 } 10497 10498 std::sort(Cands.begin(), Cands.end(), 10499 CompareOverloadCandidatesForDisplay(S, OpLoc, Args.size(), Kind)); 10500 10501 bool ReportedAmbiguousConversions = false; 10502 10503 SmallVectorImpl<OverloadCandidate*>::iterator I, E; 10504 const OverloadsShown ShowOverloads = S.Diags.getShowOverloads(); 10505 unsigned CandsShown = 0; 10506 for (I = Cands.begin(), E = Cands.end(); I != E; ++I) { 10507 OverloadCandidate *Cand = *I; 10508 10509 // Set an arbitrary limit on the number of candidate functions we'll spam 10510 // the user with. FIXME: This limit should depend on details of the 10511 // candidate list. 10512 if (CandsShown >= 4 && ShowOverloads == Ovl_Best) { 10513 break; 10514 } 10515 ++CandsShown; 10516 10517 if (Cand->Function) 10518 NoteFunctionCandidate(S, Cand, Args.size(), 10519 /*TakingCandidateAddress=*/false); 10520 else if (Cand->IsSurrogate) 10521 NoteSurrogateCandidate(S, Cand); 10522 else { 10523 assert(Cand->Viable && 10524 "Non-viable built-in candidates are not added to Cands."); 10525 // Generally we only see ambiguities including viable builtin 10526 // operators if overload resolution got screwed up by an 10527 // ambiguous user-defined conversion. 10528 // 10529 // FIXME: It's quite possible for different conversions to see 10530 // different ambiguities, though. 10531 if (!ReportedAmbiguousConversions) { 10532 NoteAmbiguousUserConversions(S, OpLoc, Cand); 10533 ReportedAmbiguousConversions = true; 10534 } 10535 10536 // If this is a viable builtin, print it. 10537 NoteBuiltinOperatorCandidate(S, Opc, OpLoc, Cand); 10538 } 10539 } 10540 10541 if (I != E) 10542 S.Diag(OpLoc, diag::note_ovl_too_many_candidates) << int(E - I); 10543 } 10544 10545 static SourceLocation 10546 GetLocationForCandidate(const TemplateSpecCandidate *Cand) { 10547 return Cand->Specialization ? Cand->Specialization->getLocation() 10548 : SourceLocation(); 10549 } 10550 10551 namespace { 10552 struct CompareTemplateSpecCandidatesForDisplay { 10553 Sema &S; 10554 CompareTemplateSpecCandidatesForDisplay(Sema &S) : S(S) {} 10555 10556 bool operator()(const TemplateSpecCandidate *L, 10557 const TemplateSpecCandidate *R) { 10558 // Fast-path this check. 10559 if (L == R) 10560 return false; 10561 10562 // Assuming that both candidates are not matches... 10563 10564 // Sort by the ranking of deduction failures. 10565 if (L->DeductionFailure.Result != R->DeductionFailure.Result) 10566 return RankDeductionFailure(L->DeductionFailure) < 10567 RankDeductionFailure(R->DeductionFailure); 10568 10569 // Sort everything else by location. 10570 SourceLocation LLoc = GetLocationForCandidate(L); 10571 SourceLocation RLoc = GetLocationForCandidate(R); 10572 10573 // Put candidates without locations (e.g. builtins) at the end. 10574 if (LLoc.isInvalid()) 10575 return false; 10576 if (RLoc.isInvalid()) 10577 return true; 10578 10579 return S.SourceMgr.isBeforeInTranslationUnit(LLoc, RLoc); 10580 } 10581 }; 10582 } 10583 10584 /// Diagnose a template argument deduction failure. 10585 /// We are treating these failures as overload failures due to bad 10586 /// deductions. 10587 void TemplateSpecCandidate::NoteDeductionFailure(Sema &S, 10588 bool ForTakingAddress) { 10589 DiagnoseBadDeduction(S, FoundDecl, Specialization, // pattern 10590 DeductionFailure, /*NumArgs=*/0, ForTakingAddress); 10591 } 10592 10593 void TemplateSpecCandidateSet::destroyCandidates() { 10594 for (iterator i = begin(), e = end(); i != e; ++i) { 10595 i->DeductionFailure.Destroy(); 10596 } 10597 } 10598 10599 void TemplateSpecCandidateSet::clear() { 10600 destroyCandidates(); 10601 Candidates.clear(); 10602 } 10603 10604 /// NoteCandidates - When no template specialization match is found, prints 10605 /// diagnostic messages containing the non-matching specializations that form 10606 /// the candidate set. 10607 /// This is analoguous to OverloadCandidateSet::NoteCandidates() with 10608 /// OCD == OCD_AllCandidates and Cand->Viable == false. 10609 void TemplateSpecCandidateSet::NoteCandidates(Sema &S, SourceLocation Loc) { 10610 // Sort the candidates by position (assuming no candidate is a match). 10611 // Sorting directly would be prohibitive, so we make a set of pointers 10612 // and sort those. 10613 SmallVector<TemplateSpecCandidate *, 32> Cands; 10614 Cands.reserve(size()); 10615 for (iterator Cand = begin(), LastCand = end(); Cand != LastCand; ++Cand) { 10616 if (Cand->Specialization) 10617 Cands.push_back(Cand); 10618 // Otherwise, this is a non-matching builtin candidate. We do not, 10619 // in general, want to list every possible builtin candidate. 10620 } 10621 10622 std::sort(Cands.begin(), Cands.end(), 10623 CompareTemplateSpecCandidatesForDisplay(S)); 10624 10625 // FIXME: Perhaps rename OverloadsShown and getShowOverloads() 10626 // for generalization purposes (?). 10627 const OverloadsShown ShowOverloads = S.Diags.getShowOverloads(); 10628 10629 SmallVectorImpl<TemplateSpecCandidate *>::iterator I, E; 10630 unsigned CandsShown = 0; 10631 for (I = Cands.begin(), E = Cands.end(); I != E; ++I) { 10632 TemplateSpecCandidate *Cand = *I; 10633 10634 // Set an arbitrary limit on the number of candidates we'll spam 10635 // the user with. FIXME: This limit should depend on details of the 10636 // candidate list. 10637 if (CandsShown >= 4 && ShowOverloads == Ovl_Best) 10638 break; 10639 ++CandsShown; 10640 10641 assert(Cand->Specialization && 10642 "Non-matching built-in candidates are not added to Cands."); 10643 Cand->NoteDeductionFailure(S, ForTakingAddress); 10644 } 10645 10646 if (I != E) 10647 S.Diag(Loc, diag::note_ovl_too_many_candidates) << int(E - I); 10648 } 10649 10650 // [PossiblyAFunctionType] --> [Return] 10651 // NonFunctionType --> NonFunctionType 10652 // R (A) --> R(A) 10653 // R (*)(A) --> R (A) 10654 // R (&)(A) --> R (A) 10655 // R (S::*)(A) --> R (A) 10656 QualType Sema::ExtractUnqualifiedFunctionType(QualType PossiblyAFunctionType) { 10657 QualType Ret = PossiblyAFunctionType; 10658 if (const PointerType *ToTypePtr = 10659 PossiblyAFunctionType->getAs<PointerType>()) 10660 Ret = ToTypePtr->getPointeeType(); 10661 else if (const ReferenceType *ToTypeRef = 10662 PossiblyAFunctionType->getAs<ReferenceType>()) 10663 Ret = ToTypeRef->getPointeeType(); 10664 else if (const MemberPointerType *MemTypePtr = 10665 PossiblyAFunctionType->getAs<MemberPointerType>()) 10666 Ret = MemTypePtr->getPointeeType(); 10667 Ret = 10668 Context.getCanonicalType(Ret).getUnqualifiedType(); 10669 return Ret; 10670 } 10671 10672 static bool completeFunctionType(Sema &S, FunctionDecl *FD, SourceLocation Loc, 10673 bool Complain = true) { 10674 if (S.getLangOpts().CPlusPlus14 && FD->getReturnType()->isUndeducedType() && 10675 S.DeduceReturnType(FD, Loc, Complain)) 10676 return true; 10677 10678 auto *FPT = FD->getType()->castAs<FunctionProtoType>(); 10679 if (S.getLangOpts().CPlusPlus1z && 10680 isUnresolvedExceptionSpec(FPT->getExceptionSpecType()) && 10681 !S.ResolveExceptionSpec(Loc, FPT)) 10682 return true; 10683 10684 return false; 10685 } 10686 10687 namespace { 10688 // A helper class to help with address of function resolution 10689 // - allows us to avoid passing around all those ugly parameters 10690 class AddressOfFunctionResolver { 10691 Sema& S; 10692 Expr* SourceExpr; 10693 const QualType& TargetType; 10694 QualType TargetFunctionType; // Extracted function type from target type 10695 10696 bool Complain; 10697 //DeclAccessPair& ResultFunctionAccessPair; 10698 ASTContext& Context; 10699 10700 bool TargetTypeIsNonStaticMemberFunction; 10701 bool FoundNonTemplateFunction; 10702 bool StaticMemberFunctionFromBoundPointer; 10703 bool HasComplained; 10704 10705 OverloadExpr::FindResult OvlExprInfo; 10706 OverloadExpr *OvlExpr; 10707 TemplateArgumentListInfo OvlExplicitTemplateArgs; 10708 SmallVector<std::pair<DeclAccessPair, FunctionDecl*>, 4> Matches; 10709 TemplateSpecCandidateSet FailedCandidates; 10710 10711 public: 10712 AddressOfFunctionResolver(Sema &S, Expr *SourceExpr, 10713 const QualType &TargetType, bool Complain) 10714 : S(S), SourceExpr(SourceExpr), TargetType(TargetType), 10715 Complain(Complain), Context(S.getASTContext()), 10716 TargetTypeIsNonStaticMemberFunction( 10717 !!TargetType->getAs<MemberPointerType>()), 10718 FoundNonTemplateFunction(false), 10719 StaticMemberFunctionFromBoundPointer(false), 10720 HasComplained(false), 10721 OvlExprInfo(OverloadExpr::find(SourceExpr)), 10722 OvlExpr(OvlExprInfo.Expression), 10723 FailedCandidates(OvlExpr->getNameLoc(), /*ForTakingAddress=*/true) { 10724 ExtractUnqualifiedFunctionTypeFromTargetType(); 10725 10726 if (TargetFunctionType->isFunctionType()) { 10727 if (UnresolvedMemberExpr *UME = dyn_cast<UnresolvedMemberExpr>(OvlExpr)) 10728 if (!UME->isImplicitAccess() && 10729 !S.ResolveSingleFunctionTemplateSpecialization(UME)) 10730 StaticMemberFunctionFromBoundPointer = true; 10731 } else if (OvlExpr->hasExplicitTemplateArgs()) { 10732 DeclAccessPair dap; 10733 if (FunctionDecl *Fn = S.ResolveSingleFunctionTemplateSpecialization( 10734 OvlExpr, false, &dap)) { 10735 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Fn)) 10736 if (!Method->isStatic()) { 10737 // If the target type is a non-function type and the function found 10738 // is a non-static member function, pretend as if that was the 10739 // target, it's the only possible type to end up with. 10740 TargetTypeIsNonStaticMemberFunction = true; 10741 10742 // And skip adding the function if its not in the proper form. 10743 // We'll diagnose this due to an empty set of functions. 10744 if (!OvlExprInfo.HasFormOfMemberPointer) 10745 return; 10746 } 10747 10748 Matches.push_back(std::make_pair(dap, Fn)); 10749 } 10750 return; 10751 } 10752 10753 if (OvlExpr->hasExplicitTemplateArgs()) 10754 OvlExpr->copyTemplateArgumentsInto(OvlExplicitTemplateArgs); 10755 10756 if (FindAllFunctionsThatMatchTargetTypeExactly()) { 10757 // C++ [over.over]p4: 10758 // If more than one function is selected, [...] 10759 if (Matches.size() > 1 && !eliminiateSuboptimalOverloadCandidates()) { 10760 if (FoundNonTemplateFunction) 10761 EliminateAllTemplateMatches(); 10762 else 10763 EliminateAllExceptMostSpecializedTemplate(); 10764 } 10765 } 10766 10767 if (S.getLangOpts().CUDA && Matches.size() > 1) 10768 EliminateSuboptimalCudaMatches(); 10769 } 10770 10771 bool hasComplained() const { return HasComplained; } 10772 10773 private: 10774 bool candidateHasExactlyCorrectType(const FunctionDecl *FD) { 10775 QualType Discard; 10776 return Context.hasSameUnqualifiedType(TargetFunctionType, FD->getType()) || 10777 S.IsFunctionConversion(FD->getType(), TargetFunctionType, Discard); 10778 } 10779 10780 /// \return true if A is considered a better overload candidate for the 10781 /// desired type than B. 10782 bool isBetterCandidate(const FunctionDecl *A, const FunctionDecl *B) { 10783 // If A doesn't have exactly the correct type, we don't want to classify it 10784 // as "better" than anything else. This way, the user is required to 10785 // disambiguate for us if there are multiple candidates and no exact match. 10786 return candidateHasExactlyCorrectType(A) && 10787 (!candidateHasExactlyCorrectType(B) || 10788 compareEnableIfAttrs(S, A, B) == Comparison::Better); 10789 } 10790 10791 /// \return true if we were able to eliminate all but one overload candidate, 10792 /// false otherwise. 10793 bool eliminiateSuboptimalOverloadCandidates() { 10794 // Same algorithm as overload resolution -- one pass to pick the "best", 10795 // another pass to be sure that nothing is better than the best. 10796 auto Best = Matches.begin(); 10797 for (auto I = Matches.begin()+1, E = Matches.end(); I != E; ++I) 10798 if (isBetterCandidate(I->second, Best->second)) 10799 Best = I; 10800 10801 const FunctionDecl *BestFn = Best->second; 10802 auto IsBestOrInferiorToBest = [this, BestFn]( 10803 const std::pair<DeclAccessPair, FunctionDecl *> &Pair) { 10804 return BestFn == Pair.second || isBetterCandidate(BestFn, Pair.second); 10805 }; 10806 10807 // Note: We explicitly leave Matches unmodified if there isn't a clear best 10808 // option, so we can potentially give the user a better error 10809 if (!std::all_of(Matches.begin(), Matches.end(), IsBestOrInferiorToBest)) 10810 return false; 10811 Matches[0] = *Best; 10812 Matches.resize(1); 10813 return true; 10814 } 10815 10816 bool isTargetTypeAFunction() const { 10817 return TargetFunctionType->isFunctionType(); 10818 } 10819 10820 // [ToType] [Return] 10821 10822 // R (*)(A) --> R (A), IsNonStaticMemberFunction = false 10823 // R (&)(A) --> R (A), IsNonStaticMemberFunction = false 10824 // R (S::*)(A) --> R (A), IsNonStaticMemberFunction = true 10825 void inline ExtractUnqualifiedFunctionTypeFromTargetType() { 10826 TargetFunctionType = S.ExtractUnqualifiedFunctionType(TargetType); 10827 } 10828 10829 // return true if any matching specializations were found 10830 bool AddMatchingTemplateFunction(FunctionTemplateDecl* FunctionTemplate, 10831 const DeclAccessPair& CurAccessFunPair) { 10832 if (CXXMethodDecl *Method 10833 = dyn_cast<CXXMethodDecl>(FunctionTemplate->getTemplatedDecl())) { 10834 // Skip non-static function templates when converting to pointer, and 10835 // static when converting to member pointer. 10836 if (Method->isStatic() == TargetTypeIsNonStaticMemberFunction) 10837 return false; 10838 } 10839 else if (TargetTypeIsNonStaticMemberFunction) 10840 return false; 10841 10842 // C++ [over.over]p2: 10843 // If the name is a function template, template argument deduction is 10844 // done (14.8.2.2), and if the argument deduction succeeds, the 10845 // resulting template argument list is used to generate a single 10846 // function template specialization, which is added to the set of 10847 // overloaded functions considered. 10848 FunctionDecl *Specialization = nullptr; 10849 TemplateDeductionInfo Info(FailedCandidates.getLocation()); 10850 if (Sema::TemplateDeductionResult Result 10851 = S.DeduceTemplateArguments(FunctionTemplate, 10852 &OvlExplicitTemplateArgs, 10853 TargetFunctionType, Specialization, 10854 Info, /*IsAddressOfFunction*/true)) { 10855 // Make a note of the failed deduction for diagnostics. 10856 FailedCandidates.addCandidate() 10857 .set(CurAccessFunPair, FunctionTemplate->getTemplatedDecl(), 10858 MakeDeductionFailureInfo(Context, Result, Info)); 10859 return false; 10860 } 10861 10862 // Template argument deduction ensures that we have an exact match or 10863 // compatible pointer-to-function arguments that would be adjusted by ICS. 10864 // This function template specicalization works. 10865 assert(S.isSameOrCompatibleFunctionType( 10866 Context.getCanonicalType(Specialization->getType()), 10867 Context.getCanonicalType(TargetFunctionType))); 10868 10869 if (!S.checkAddressOfFunctionIsAvailable(Specialization)) 10870 return false; 10871 10872 Matches.push_back(std::make_pair(CurAccessFunPair, Specialization)); 10873 return true; 10874 } 10875 10876 bool AddMatchingNonTemplateFunction(NamedDecl* Fn, 10877 const DeclAccessPair& CurAccessFunPair) { 10878 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Fn)) { 10879 // Skip non-static functions when converting to pointer, and static 10880 // when converting to member pointer. 10881 if (Method->isStatic() == TargetTypeIsNonStaticMemberFunction) 10882 return false; 10883 } 10884 else if (TargetTypeIsNonStaticMemberFunction) 10885 return false; 10886 10887 if (FunctionDecl *FunDecl = dyn_cast<FunctionDecl>(Fn)) { 10888 if (S.getLangOpts().CUDA) 10889 if (FunctionDecl *Caller = dyn_cast<FunctionDecl>(S.CurContext)) 10890 if (!Caller->isImplicit() && !S.IsAllowedCUDACall(Caller, FunDecl)) 10891 return false; 10892 10893 // If any candidate has a placeholder return type, trigger its deduction 10894 // now. 10895 if (completeFunctionType(S, FunDecl, SourceExpr->getLocStart(), 10896 Complain)) { 10897 HasComplained |= Complain; 10898 return false; 10899 } 10900 10901 if (!S.checkAddressOfFunctionIsAvailable(FunDecl)) 10902 return false; 10903 10904 // If we're in C, we need to support types that aren't exactly identical. 10905 if (!S.getLangOpts().CPlusPlus || 10906 candidateHasExactlyCorrectType(FunDecl)) { 10907 Matches.push_back(std::make_pair( 10908 CurAccessFunPair, cast<FunctionDecl>(FunDecl->getCanonicalDecl()))); 10909 FoundNonTemplateFunction = true; 10910 return true; 10911 } 10912 } 10913 10914 return false; 10915 } 10916 10917 bool FindAllFunctionsThatMatchTargetTypeExactly() { 10918 bool Ret = false; 10919 10920 // If the overload expression doesn't have the form of a pointer to 10921 // member, don't try to convert it to a pointer-to-member type. 10922 if (IsInvalidFormOfPointerToMemberFunction()) 10923 return false; 10924 10925 for (UnresolvedSetIterator I = OvlExpr->decls_begin(), 10926 E = OvlExpr->decls_end(); 10927 I != E; ++I) { 10928 // Look through any using declarations to find the underlying function. 10929 NamedDecl *Fn = (*I)->getUnderlyingDecl(); 10930 10931 // C++ [over.over]p3: 10932 // Non-member functions and static member functions match 10933 // targets of type "pointer-to-function" or "reference-to-function." 10934 // Nonstatic member functions match targets of 10935 // type "pointer-to-member-function." 10936 // Note that according to DR 247, the containing class does not matter. 10937 if (FunctionTemplateDecl *FunctionTemplate 10938 = dyn_cast<FunctionTemplateDecl>(Fn)) { 10939 if (AddMatchingTemplateFunction(FunctionTemplate, I.getPair())) 10940 Ret = true; 10941 } 10942 // If we have explicit template arguments supplied, skip non-templates. 10943 else if (!OvlExpr->hasExplicitTemplateArgs() && 10944 AddMatchingNonTemplateFunction(Fn, I.getPair())) 10945 Ret = true; 10946 } 10947 assert(Ret || Matches.empty()); 10948 return Ret; 10949 } 10950 10951 void EliminateAllExceptMostSpecializedTemplate() { 10952 // [...] and any given function template specialization F1 is 10953 // eliminated if the set contains a second function template 10954 // specialization whose function template is more specialized 10955 // than the function template of F1 according to the partial 10956 // ordering rules of 14.5.5.2. 10957 10958 // The algorithm specified above is quadratic. We instead use a 10959 // two-pass algorithm (similar to the one used to identify the 10960 // best viable function in an overload set) that identifies the 10961 // best function template (if it exists). 10962 10963 UnresolvedSet<4> MatchesCopy; // TODO: avoid! 10964 for (unsigned I = 0, E = Matches.size(); I != E; ++I) 10965 MatchesCopy.addDecl(Matches[I].second, Matches[I].first.getAccess()); 10966 10967 // TODO: It looks like FailedCandidates does not serve much purpose 10968 // here, since the no_viable diagnostic has index 0. 10969 UnresolvedSetIterator Result = S.getMostSpecialized( 10970 MatchesCopy.begin(), MatchesCopy.end(), FailedCandidates, 10971 SourceExpr->getLocStart(), S.PDiag(), 10972 S.PDiag(diag::err_addr_ovl_ambiguous) 10973 << Matches[0].second->getDeclName(), 10974 S.PDiag(diag::note_ovl_candidate) 10975 << (unsigned)oc_function_template, 10976 Complain, TargetFunctionType); 10977 10978 if (Result != MatchesCopy.end()) { 10979 // Make it the first and only element 10980 Matches[0].first = Matches[Result - MatchesCopy.begin()].first; 10981 Matches[0].second = cast<FunctionDecl>(*Result); 10982 Matches.resize(1); 10983 } else 10984 HasComplained |= Complain; 10985 } 10986 10987 void EliminateAllTemplateMatches() { 10988 // [...] any function template specializations in the set are 10989 // eliminated if the set also contains a non-template function, [...] 10990 for (unsigned I = 0, N = Matches.size(); I != N; ) { 10991 if (Matches[I].second->getPrimaryTemplate() == nullptr) 10992 ++I; 10993 else { 10994 Matches[I] = Matches[--N]; 10995 Matches.resize(N); 10996 } 10997 } 10998 } 10999 11000 void EliminateSuboptimalCudaMatches() { 11001 S.EraseUnwantedCUDAMatches(dyn_cast<FunctionDecl>(S.CurContext), Matches); 11002 } 11003 11004 public: 11005 void ComplainNoMatchesFound() const { 11006 assert(Matches.empty()); 11007 S.Diag(OvlExpr->getLocStart(), diag::err_addr_ovl_no_viable) 11008 << OvlExpr->getName() << TargetFunctionType 11009 << OvlExpr->getSourceRange(); 11010 if (FailedCandidates.empty()) 11011 S.NoteAllOverloadCandidates(OvlExpr, TargetFunctionType, 11012 /*TakingAddress=*/true); 11013 else { 11014 // We have some deduction failure messages. Use them to diagnose 11015 // the function templates, and diagnose the non-template candidates 11016 // normally. 11017 for (UnresolvedSetIterator I = OvlExpr->decls_begin(), 11018 IEnd = OvlExpr->decls_end(); 11019 I != IEnd; ++I) 11020 if (FunctionDecl *Fun = 11021 dyn_cast<FunctionDecl>((*I)->getUnderlyingDecl())) 11022 if (!functionHasPassObjectSizeParams(Fun)) 11023 S.NoteOverloadCandidate(*I, Fun, TargetFunctionType, 11024 /*TakingAddress=*/true); 11025 FailedCandidates.NoteCandidates(S, OvlExpr->getLocStart()); 11026 } 11027 } 11028 11029 bool IsInvalidFormOfPointerToMemberFunction() const { 11030 return TargetTypeIsNonStaticMemberFunction && 11031 !OvlExprInfo.HasFormOfMemberPointer; 11032 } 11033 11034 void ComplainIsInvalidFormOfPointerToMemberFunction() const { 11035 // TODO: Should we condition this on whether any functions might 11036 // have matched, or is it more appropriate to do that in callers? 11037 // TODO: a fixit wouldn't hurt. 11038 S.Diag(OvlExpr->getNameLoc(), diag::err_addr_ovl_no_qualifier) 11039 << TargetType << OvlExpr->getSourceRange(); 11040 } 11041 11042 bool IsStaticMemberFunctionFromBoundPointer() const { 11043 return StaticMemberFunctionFromBoundPointer; 11044 } 11045 11046 void ComplainIsStaticMemberFunctionFromBoundPointer() const { 11047 S.Diag(OvlExpr->getLocStart(), 11048 diag::err_invalid_form_pointer_member_function) 11049 << OvlExpr->getSourceRange(); 11050 } 11051 11052 void ComplainOfInvalidConversion() const { 11053 S.Diag(OvlExpr->getLocStart(), diag::err_addr_ovl_not_func_ptrref) 11054 << OvlExpr->getName() << TargetType; 11055 } 11056 11057 void ComplainMultipleMatchesFound() const { 11058 assert(Matches.size() > 1); 11059 S.Diag(OvlExpr->getLocStart(), diag::err_addr_ovl_ambiguous) 11060 << OvlExpr->getName() 11061 << OvlExpr->getSourceRange(); 11062 S.NoteAllOverloadCandidates(OvlExpr, TargetFunctionType, 11063 /*TakingAddress=*/true); 11064 } 11065 11066 bool hadMultipleCandidates() const { return (OvlExpr->getNumDecls() > 1); } 11067 11068 int getNumMatches() const { return Matches.size(); } 11069 11070 FunctionDecl* getMatchingFunctionDecl() const { 11071 if (Matches.size() != 1) return nullptr; 11072 return Matches[0].second; 11073 } 11074 11075 const DeclAccessPair* getMatchingFunctionAccessPair() const { 11076 if (Matches.size() != 1) return nullptr; 11077 return &Matches[0].first; 11078 } 11079 }; 11080 } 11081 11082 /// ResolveAddressOfOverloadedFunction - Try to resolve the address of 11083 /// an overloaded function (C++ [over.over]), where @p From is an 11084 /// expression with overloaded function type and @p ToType is the type 11085 /// we're trying to resolve to. For example: 11086 /// 11087 /// @code 11088 /// int f(double); 11089 /// int f(int); 11090 /// 11091 /// int (*pfd)(double) = f; // selects f(double) 11092 /// @endcode 11093 /// 11094 /// This routine returns the resulting FunctionDecl if it could be 11095 /// resolved, and NULL otherwise. When @p Complain is true, this 11096 /// routine will emit diagnostics if there is an error. 11097 FunctionDecl * 11098 Sema::ResolveAddressOfOverloadedFunction(Expr *AddressOfExpr, 11099 QualType TargetType, 11100 bool Complain, 11101 DeclAccessPair &FoundResult, 11102 bool *pHadMultipleCandidates) { 11103 assert(AddressOfExpr->getType() == Context.OverloadTy); 11104 11105 AddressOfFunctionResolver Resolver(*this, AddressOfExpr, TargetType, 11106 Complain); 11107 int NumMatches = Resolver.getNumMatches(); 11108 FunctionDecl *Fn = nullptr; 11109 bool ShouldComplain = Complain && !Resolver.hasComplained(); 11110 if (NumMatches == 0 && ShouldComplain) { 11111 if (Resolver.IsInvalidFormOfPointerToMemberFunction()) 11112 Resolver.ComplainIsInvalidFormOfPointerToMemberFunction(); 11113 else 11114 Resolver.ComplainNoMatchesFound(); 11115 } 11116 else if (NumMatches > 1 && ShouldComplain) 11117 Resolver.ComplainMultipleMatchesFound(); 11118 else if (NumMatches == 1) { 11119 Fn = Resolver.getMatchingFunctionDecl(); 11120 assert(Fn); 11121 if (auto *FPT = Fn->getType()->getAs<FunctionProtoType>()) 11122 ResolveExceptionSpec(AddressOfExpr->getExprLoc(), FPT); 11123 FoundResult = *Resolver.getMatchingFunctionAccessPair(); 11124 if (Complain) { 11125 if (Resolver.IsStaticMemberFunctionFromBoundPointer()) 11126 Resolver.ComplainIsStaticMemberFunctionFromBoundPointer(); 11127 else 11128 CheckAddressOfMemberAccess(AddressOfExpr, FoundResult); 11129 } 11130 } 11131 11132 if (pHadMultipleCandidates) 11133 *pHadMultipleCandidates = Resolver.hadMultipleCandidates(); 11134 return Fn; 11135 } 11136 11137 /// \brief Given an expression that refers to an overloaded function, try to 11138 /// resolve that function to a single function that can have its address taken. 11139 /// This will modify `Pair` iff it returns non-null. 11140 /// 11141 /// This routine can only realistically succeed if all but one candidates in the 11142 /// overload set for SrcExpr cannot have their addresses taken. 11143 FunctionDecl * 11144 Sema::resolveAddressOfOnlyViableOverloadCandidate(Expr *E, 11145 DeclAccessPair &Pair) { 11146 OverloadExpr::FindResult R = OverloadExpr::find(E); 11147 OverloadExpr *Ovl = R.Expression; 11148 FunctionDecl *Result = nullptr; 11149 DeclAccessPair DAP; 11150 // Don't use the AddressOfResolver because we're specifically looking for 11151 // cases where we have one overload candidate that lacks 11152 // enable_if/pass_object_size/... 11153 for (auto I = Ovl->decls_begin(), E = Ovl->decls_end(); I != E; ++I) { 11154 auto *FD = dyn_cast<FunctionDecl>(I->getUnderlyingDecl()); 11155 if (!FD) 11156 return nullptr; 11157 11158 if (!checkAddressOfFunctionIsAvailable(FD)) 11159 continue; 11160 11161 // We have more than one result; quit. 11162 if (Result) 11163 return nullptr; 11164 DAP = I.getPair(); 11165 Result = FD; 11166 } 11167 11168 if (Result) 11169 Pair = DAP; 11170 return Result; 11171 } 11172 11173 /// \brief Given an overloaded function, tries to turn it into a non-overloaded 11174 /// function reference using resolveAddressOfOnlyViableOverloadCandidate. This 11175 /// will perform access checks, diagnose the use of the resultant decl, and, if 11176 /// requested, potentially perform a function-to-pointer decay. 11177 /// 11178 /// Returns false if resolveAddressOfOnlyViableOverloadCandidate fails. 11179 /// Otherwise, returns true. This may emit diagnostics and return true. 11180 bool Sema::resolveAndFixAddressOfOnlyViableOverloadCandidate( 11181 ExprResult &SrcExpr, bool DoFunctionPointerConverion) { 11182 Expr *E = SrcExpr.get(); 11183 assert(E->getType() == Context.OverloadTy && "SrcExpr must be an overload"); 11184 11185 DeclAccessPair DAP; 11186 FunctionDecl *Found = resolveAddressOfOnlyViableOverloadCandidate(E, DAP); 11187 if (!Found) 11188 return false; 11189 11190 // Emitting multiple diagnostics for a function that is both inaccessible and 11191 // unavailable is consistent with our behavior elsewhere. So, always check 11192 // for both. 11193 DiagnoseUseOfDecl(Found, E->getExprLoc()); 11194 CheckAddressOfMemberAccess(E, DAP); 11195 Expr *Fixed = FixOverloadedFunctionReference(E, DAP, Found); 11196 if (DoFunctionPointerConverion && Fixed->getType()->isFunctionType()) 11197 SrcExpr = DefaultFunctionArrayConversion(Fixed, /*Diagnose=*/false); 11198 else 11199 SrcExpr = Fixed; 11200 return true; 11201 } 11202 11203 /// \brief Given an expression that refers to an overloaded function, try to 11204 /// resolve that overloaded function expression down to a single function. 11205 /// 11206 /// This routine can only resolve template-ids that refer to a single function 11207 /// template, where that template-id refers to a single template whose template 11208 /// arguments are either provided by the template-id or have defaults, 11209 /// as described in C++0x [temp.arg.explicit]p3. 11210 /// 11211 /// If no template-ids are found, no diagnostics are emitted and NULL is 11212 /// returned. 11213 FunctionDecl * 11214 Sema::ResolveSingleFunctionTemplateSpecialization(OverloadExpr *ovl, 11215 bool Complain, 11216 DeclAccessPair *FoundResult) { 11217 // C++ [over.over]p1: 11218 // [...] [Note: any redundant set of parentheses surrounding the 11219 // overloaded function name is ignored (5.1). ] 11220 // C++ [over.over]p1: 11221 // [...] The overloaded function name can be preceded by the & 11222 // operator. 11223 11224 // If we didn't actually find any template-ids, we're done. 11225 if (!ovl->hasExplicitTemplateArgs()) 11226 return nullptr; 11227 11228 TemplateArgumentListInfo ExplicitTemplateArgs; 11229 ovl->copyTemplateArgumentsInto(ExplicitTemplateArgs); 11230 TemplateSpecCandidateSet FailedCandidates(ovl->getNameLoc()); 11231 11232 // Look through all of the overloaded functions, searching for one 11233 // whose type matches exactly. 11234 FunctionDecl *Matched = nullptr; 11235 for (UnresolvedSetIterator I = ovl->decls_begin(), 11236 E = ovl->decls_end(); I != E; ++I) { 11237 // C++0x [temp.arg.explicit]p3: 11238 // [...] In contexts where deduction is done and fails, or in contexts 11239 // where deduction is not done, if a template argument list is 11240 // specified and it, along with any default template arguments, 11241 // identifies a single function template specialization, then the 11242 // template-id is an lvalue for the function template specialization. 11243 FunctionTemplateDecl *FunctionTemplate 11244 = cast<FunctionTemplateDecl>((*I)->getUnderlyingDecl()); 11245 11246 // C++ [over.over]p2: 11247 // If the name is a function template, template argument deduction is 11248 // done (14.8.2.2), and if the argument deduction succeeds, the 11249 // resulting template argument list is used to generate a single 11250 // function template specialization, which is added to the set of 11251 // overloaded functions considered. 11252 FunctionDecl *Specialization = nullptr; 11253 TemplateDeductionInfo Info(FailedCandidates.getLocation()); 11254 if (TemplateDeductionResult Result 11255 = DeduceTemplateArguments(FunctionTemplate, &ExplicitTemplateArgs, 11256 Specialization, Info, 11257 /*IsAddressOfFunction*/true)) { 11258 // Make a note of the failed deduction for diagnostics. 11259 // TODO: Actually use the failed-deduction info? 11260 FailedCandidates.addCandidate() 11261 .set(I.getPair(), FunctionTemplate->getTemplatedDecl(), 11262 MakeDeductionFailureInfo(Context, Result, Info)); 11263 continue; 11264 } 11265 11266 assert(Specialization && "no specialization and no error?"); 11267 11268 // Multiple matches; we can't resolve to a single declaration. 11269 if (Matched) { 11270 if (Complain) { 11271 Diag(ovl->getExprLoc(), diag::err_addr_ovl_ambiguous) 11272 << ovl->getName(); 11273 NoteAllOverloadCandidates(ovl); 11274 } 11275 return nullptr; 11276 } 11277 11278 Matched = Specialization; 11279 if (FoundResult) *FoundResult = I.getPair(); 11280 } 11281 11282 if (Matched && 11283 completeFunctionType(*this, Matched, ovl->getExprLoc(), Complain)) 11284 return nullptr; 11285 11286 return Matched; 11287 } 11288 11289 11290 11291 11292 // Resolve and fix an overloaded expression that can be resolved 11293 // because it identifies a single function template specialization. 11294 // 11295 // Last three arguments should only be supplied if Complain = true 11296 // 11297 // Return true if it was logically possible to so resolve the 11298 // expression, regardless of whether or not it succeeded. Always 11299 // returns true if 'complain' is set. 11300 bool Sema::ResolveAndFixSingleFunctionTemplateSpecialization( 11301 ExprResult &SrcExpr, bool doFunctionPointerConverion, 11302 bool complain, SourceRange OpRangeForComplaining, 11303 QualType DestTypeForComplaining, 11304 unsigned DiagIDForComplaining) { 11305 assert(SrcExpr.get()->getType() == Context.OverloadTy); 11306 11307 OverloadExpr::FindResult ovl = OverloadExpr::find(SrcExpr.get()); 11308 11309 DeclAccessPair found; 11310 ExprResult SingleFunctionExpression; 11311 if (FunctionDecl *fn = ResolveSingleFunctionTemplateSpecialization( 11312 ovl.Expression, /*complain*/ false, &found)) { 11313 if (DiagnoseUseOfDecl(fn, SrcExpr.get()->getLocStart())) { 11314 SrcExpr = ExprError(); 11315 return true; 11316 } 11317 11318 // It is only correct to resolve to an instance method if we're 11319 // resolving a form that's permitted to be a pointer to member. 11320 // Otherwise we'll end up making a bound member expression, which 11321 // is illegal in all the contexts we resolve like this. 11322 if (!ovl.HasFormOfMemberPointer && 11323 isa<CXXMethodDecl>(fn) && 11324 cast<CXXMethodDecl>(fn)->isInstance()) { 11325 if (!complain) return false; 11326 11327 Diag(ovl.Expression->getExprLoc(), 11328 diag::err_bound_member_function) 11329 << 0 << ovl.Expression->getSourceRange(); 11330 11331 // TODO: I believe we only end up here if there's a mix of 11332 // static and non-static candidates (otherwise the expression 11333 // would have 'bound member' type, not 'overload' type). 11334 // Ideally we would note which candidate was chosen and why 11335 // the static candidates were rejected. 11336 SrcExpr = ExprError(); 11337 return true; 11338 } 11339 11340 // Fix the expression to refer to 'fn'. 11341 SingleFunctionExpression = 11342 FixOverloadedFunctionReference(SrcExpr.get(), found, fn); 11343 11344 // If desired, do function-to-pointer decay. 11345 if (doFunctionPointerConverion) { 11346 SingleFunctionExpression = 11347 DefaultFunctionArrayLvalueConversion(SingleFunctionExpression.get()); 11348 if (SingleFunctionExpression.isInvalid()) { 11349 SrcExpr = ExprError(); 11350 return true; 11351 } 11352 } 11353 } 11354 11355 if (!SingleFunctionExpression.isUsable()) { 11356 if (complain) { 11357 Diag(OpRangeForComplaining.getBegin(), DiagIDForComplaining) 11358 << ovl.Expression->getName() 11359 << DestTypeForComplaining 11360 << OpRangeForComplaining 11361 << ovl.Expression->getQualifierLoc().getSourceRange(); 11362 NoteAllOverloadCandidates(SrcExpr.get()); 11363 11364 SrcExpr = ExprError(); 11365 return true; 11366 } 11367 11368 return false; 11369 } 11370 11371 SrcExpr = SingleFunctionExpression; 11372 return true; 11373 } 11374 11375 /// \brief Add a single candidate to the overload set. 11376 static void AddOverloadedCallCandidate(Sema &S, 11377 DeclAccessPair FoundDecl, 11378 TemplateArgumentListInfo *ExplicitTemplateArgs, 11379 ArrayRef<Expr *> Args, 11380 OverloadCandidateSet &CandidateSet, 11381 bool PartialOverloading, 11382 bool KnownValid) { 11383 NamedDecl *Callee = FoundDecl.getDecl(); 11384 if (isa<UsingShadowDecl>(Callee)) 11385 Callee = cast<UsingShadowDecl>(Callee)->getTargetDecl(); 11386 11387 if (FunctionDecl *Func = dyn_cast<FunctionDecl>(Callee)) { 11388 if (ExplicitTemplateArgs) { 11389 assert(!KnownValid && "Explicit template arguments?"); 11390 return; 11391 } 11392 // Prevent ill-formed function decls to be added as overload candidates. 11393 if (!dyn_cast<FunctionProtoType>(Func->getType()->getAs<FunctionType>())) 11394 return; 11395 11396 S.AddOverloadCandidate(Func, FoundDecl, Args, CandidateSet, 11397 /*SuppressUsedConversions=*/false, 11398 PartialOverloading); 11399 return; 11400 } 11401 11402 if (FunctionTemplateDecl *FuncTemplate 11403 = dyn_cast<FunctionTemplateDecl>(Callee)) { 11404 S.AddTemplateOverloadCandidate(FuncTemplate, FoundDecl, 11405 ExplicitTemplateArgs, Args, CandidateSet, 11406 /*SuppressUsedConversions=*/false, 11407 PartialOverloading); 11408 return; 11409 } 11410 11411 assert(!KnownValid && "unhandled case in overloaded call candidate"); 11412 } 11413 11414 /// \brief Add the overload candidates named by callee and/or found by argument 11415 /// dependent lookup to the given overload set. 11416 void Sema::AddOverloadedCallCandidates(UnresolvedLookupExpr *ULE, 11417 ArrayRef<Expr *> Args, 11418 OverloadCandidateSet &CandidateSet, 11419 bool PartialOverloading) { 11420 11421 #ifndef NDEBUG 11422 // Verify that ArgumentDependentLookup is consistent with the rules 11423 // in C++0x [basic.lookup.argdep]p3: 11424 // 11425 // Let X be the lookup set produced by unqualified lookup (3.4.1) 11426 // and let Y be the lookup set produced by argument dependent 11427 // lookup (defined as follows). If X contains 11428 // 11429 // -- a declaration of a class member, or 11430 // 11431 // -- a block-scope function declaration that is not a 11432 // using-declaration, or 11433 // 11434 // -- a declaration that is neither a function or a function 11435 // template 11436 // 11437 // then Y is empty. 11438 11439 if (ULE->requiresADL()) { 11440 for (UnresolvedLookupExpr::decls_iterator I = ULE->decls_begin(), 11441 E = ULE->decls_end(); I != E; ++I) { 11442 assert(!(*I)->getDeclContext()->isRecord()); 11443 assert(isa<UsingShadowDecl>(*I) || 11444 !(*I)->getDeclContext()->isFunctionOrMethod()); 11445 assert((*I)->getUnderlyingDecl()->isFunctionOrFunctionTemplate()); 11446 } 11447 } 11448 #endif 11449 11450 // It would be nice to avoid this copy. 11451 TemplateArgumentListInfo TABuffer; 11452 TemplateArgumentListInfo *ExplicitTemplateArgs = nullptr; 11453 if (ULE->hasExplicitTemplateArgs()) { 11454 ULE->copyTemplateArgumentsInto(TABuffer); 11455 ExplicitTemplateArgs = &TABuffer; 11456 } 11457 11458 for (UnresolvedLookupExpr::decls_iterator I = ULE->decls_begin(), 11459 E = ULE->decls_end(); I != E; ++I) 11460 AddOverloadedCallCandidate(*this, I.getPair(), ExplicitTemplateArgs, Args, 11461 CandidateSet, PartialOverloading, 11462 /*KnownValid*/ true); 11463 11464 if (ULE->requiresADL()) 11465 AddArgumentDependentLookupCandidates(ULE->getName(), ULE->getExprLoc(), 11466 Args, ExplicitTemplateArgs, 11467 CandidateSet, PartialOverloading); 11468 } 11469 11470 /// Determine whether a declaration with the specified name could be moved into 11471 /// a different namespace. 11472 static bool canBeDeclaredInNamespace(const DeclarationName &Name) { 11473 switch (Name.getCXXOverloadedOperator()) { 11474 case OO_New: case OO_Array_New: 11475 case OO_Delete: case OO_Array_Delete: 11476 return false; 11477 11478 default: 11479 return true; 11480 } 11481 } 11482 11483 /// Attempt to recover from an ill-formed use of a non-dependent name in a 11484 /// template, where the non-dependent name was declared after the template 11485 /// was defined. This is common in code written for a compilers which do not 11486 /// correctly implement two-stage name lookup. 11487 /// 11488 /// Returns true if a viable candidate was found and a diagnostic was issued. 11489 static bool 11490 DiagnoseTwoPhaseLookup(Sema &SemaRef, SourceLocation FnLoc, 11491 const CXXScopeSpec &SS, LookupResult &R, 11492 OverloadCandidateSet::CandidateSetKind CSK, 11493 TemplateArgumentListInfo *ExplicitTemplateArgs, 11494 ArrayRef<Expr *> Args, 11495 bool *DoDiagnoseEmptyLookup = nullptr) { 11496 if (!SemaRef.inTemplateInstantiation() || !SS.isEmpty()) 11497 return false; 11498 11499 for (DeclContext *DC = SemaRef.CurContext; DC; DC = DC->getParent()) { 11500 if (DC->isTransparentContext()) 11501 continue; 11502 11503 SemaRef.LookupQualifiedName(R, DC); 11504 11505 if (!R.empty()) { 11506 R.suppressDiagnostics(); 11507 11508 if (isa<CXXRecordDecl>(DC)) { 11509 // Don't diagnose names we find in classes; we get much better 11510 // diagnostics for these from DiagnoseEmptyLookup. 11511 R.clear(); 11512 if (DoDiagnoseEmptyLookup) 11513 *DoDiagnoseEmptyLookup = true; 11514 return false; 11515 } 11516 11517 OverloadCandidateSet Candidates(FnLoc, CSK); 11518 for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) 11519 AddOverloadedCallCandidate(SemaRef, I.getPair(), 11520 ExplicitTemplateArgs, Args, 11521 Candidates, false, /*KnownValid*/ false); 11522 11523 OverloadCandidateSet::iterator Best; 11524 if (Candidates.BestViableFunction(SemaRef, FnLoc, Best) != OR_Success) { 11525 // No viable functions. Don't bother the user with notes for functions 11526 // which don't work and shouldn't be found anyway. 11527 R.clear(); 11528 return false; 11529 } 11530 11531 // Find the namespaces where ADL would have looked, and suggest 11532 // declaring the function there instead. 11533 Sema::AssociatedNamespaceSet AssociatedNamespaces; 11534 Sema::AssociatedClassSet AssociatedClasses; 11535 SemaRef.FindAssociatedClassesAndNamespaces(FnLoc, Args, 11536 AssociatedNamespaces, 11537 AssociatedClasses); 11538 Sema::AssociatedNamespaceSet SuggestedNamespaces; 11539 if (canBeDeclaredInNamespace(R.getLookupName())) { 11540 DeclContext *Std = SemaRef.getStdNamespace(); 11541 for (Sema::AssociatedNamespaceSet::iterator 11542 it = AssociatedNamespaces.begin(), 11543 end = AssociatedNamespaces.end(); it != end; ++it) { 11544 // Never suggest declaring a function within namespace 'std'. 11545 if (Std && Std->Encloses(*it)) 11546 continue; 11547 11548 // Never suggest declaring a function within a namespace with a 11549 // reserved name, like __gnu_cxx. 11550 NamespaceDecl *NS = dyn_cast<NamespaceDecl>(*it); 11551 if (NS && 11552 NS->getQualifiedNameAsString().find("__") != std::string::npos) 11553 continue; 11554 11555 SuggestedNamespaces.insert(*it); 11556 } 11557 } 11558 11559 SemaRef.Diag(R.getNameLoc(), diag::err_not_found_by_two_phase_lookup) 11560 << R.getLookupName(); 11561 if (SuggestedNamespaces.empty()) { 11562 SemaRef.Diag(Best->Function->getLocation(), 11563 diag::note_not_found_by_two_phase_lookup) 11564 << R.getLookupName() << 0; 11565 } else if (SuggestedNamespaces.size() == 1) { 11566 SemaRef.Diag(Best->Function->getLocation(), 11567 diag::note_not_found_by_two_phase_lookup) 11568 << R.getLookupName() << 1 << *SuggestedNamespaces.begin(); 11569 } else { 11570 // FIXME: It would be useful to list the associated namespaces here, 11571 // but the diagnostics infrastructure doesn't provide a way to produce 11572 // a localized representation of a list of items. 11573 SemaRef.Diag(Best->Function->getLocation(), 11574 diag::note_not_found_by_two_phase_lookup) 11575 << R.getLookupName() << 2; 11576 } 11577 11578 // Try to recover by calling this function. 11579 return true; 11580 } 11581 11582 R.clear(); 11583 } 11584 11585 return false; 11586 } 11587 11588 /// Attempt to recover from ill-formed use of a non-dependent operator in a 11589 /// template, where the non-dependent operator was declared after the template 11590 /// was defined. 11591 /// 11592 /// Returns true if a viable candidate was found and a diagnostic was issued. 11593 static bool 11594 DiagnoseTwoPhaseOperatorLookup(Sema &SemaRef, OverloadedOperatorKind Op, 11595 SourceLocation OpLoc, 11596 ArrayRef<Expr *> Args) { 11597 DeclarationName OpName = 11598 SemaRef.Context.DeclarationNames.getCXXOperatorName(Op); 11599 LookupResult R(SemaRef, OpName, OpLoc, Sema::LookupOperatorName); 11600 return DiagnoseTwoPhaseLookup(SemaRef, OpLoc, CXXScopeSpec(), R, 11601 OverloadCandidateSet::CSK_Operator, 11602 /*ExplicitTemplateArgs=*/nullptr, Args); 11603 } 11604 11605 namespace { 11606 class BuildRecoveryCallExprRAII { 11607 Sema &SemaRef; 11608 public: 11609 BuildRecoveryCallExprRAII(Sema &S) : SemaRef(S) { 11610 assert(SemaRef.IsBuildingRecoveryCallExpr == false); 11611 SemaRef.IsBuildingRecoveryCallExpr = true; 11612 } 11613 11614 ~BuildRecoveryCallExprRAII() { 11615 SemaRef.IsBuildingRecoveryCallExpr = false; 11616 } 11617 }; 11618 11619 } 11620 11621 static std::unique_ptr<CorrectionCandidateCallback> 11622 MakeValidator(Sema &SemaRef, MemberExpr *ME, size_t NumArgs, 11623 bool HasTemplateArgs, bool AllowTypoCorrection) { 11624 if (!AllowTypoCorrection) 11625 return llvm::make_unique<NoTypoCorrectionCCC>(); 11626 return llvm::make_unique<FunctionCallFilterCCC>(SemaRef, NumArgs, 11627 HasTemplateArgs, ME); 11628 } 11629 11630 /// Attempts to recover from a call where no functions were found. 11631 /// 11632 /// Returns true if new candidates were found. 11633 static ExprResult 11634 BuildRecoveryCallExpr(Sema &SemaRef, Scope *S, Expr *Fn, 11635 UnresolvedLookupExpr *ULE, 11636 SourceLocation LParenLoc, 11637 MutableArrayRef<Expr *> Args, 11638 SourceLocation RParenLoc, 11639 bool EmptyLookup, bool AllowTypoCorrection) { 11640 // Do not try to recover if it is already building a recovery call. 11641 // This stops infinite loops for template instantiations like 11642 // 11643 // template <typename T> auto foo(T t) -> decltype(foo(t)) {} 11644 // template <typename T> auto foo(T t) -> decltype(foo(&t)) {} 11645 // 11646 if (SemaRef.IsBuildingRecoveryCallExpr) 11647 return ExprError(); 11648 BuildRecoveryCallExprRAII RCE(SemaRef); 11649 11650 CXXScopeSpec SS; 11651 SS.Adopt(ULE->getQualifierLoc()); 11652 SourceLocation TemplateKWLoc = ULE->getTemplateKeywordLoc(); 11653 11654 TemplateArgumentListInfo TABuffer; 11655 TemplateArgumentListInfo *ExplicitTemplateArgs = nullptr; 11656 if (ULE->hasExplicitTemplateArgs()) { 11657 ULE->copyTemplateArgumentsInto(TABuffer); 11658 ExplicitTemplateArgs = &TABuffer; 11659 } 11660 11661 LookupResult R(SemaRef, ULE->getName(), ULE->getNameLoc(), 11662 Sema::LookupOrdinaryName); 11663 bool DoDiagnoseEmptyLookup = EmptyLookup; 11664 if (!DiagnoseTwoPhaseLookup(SemaRef, Fn->getExprLoc(), SS, R, 11665 OverloadCandidateSet::CSK_Normal, 11666 ExplicitTemplateArgs, Args, 11667 &DoDiagnoseEmptyLookup) && 11668 (!DoDiagnoseEmptyLookup || SemaRef.DiagnoseEmptyLookup( 11669 S, SS, R, 11670 MakeValidator(SemaRef, dyn_cast<MemberExpr>(Fn), Args.size(), 11671 ExplicitTemplateArgs != nullptr, AllowTypoCorrection), 11672 ExplicitTemplateArgs, Args))) 11673 return ExprError(); 11674 11675 assert(!R.empty() && "lookup results empty despite recovery"); 11676 11677 // If recovery created an ambiguity, just bail out. 11678 if (R.isAmbiguous()) { 11679 R.suppressDiagnostics(); 11680 return ExprError(); 11681 } 11682 11683 // Build an implicit member call if appropriate. Just drop the 11684 // casts and such from the call, we don't really care. 11685 ExprResult NewFn = ExprError(); 11686 if ((*R.begin())->isCXXClassMember()) 11687 NewFn = SemaRef.BuildPossibleImplicitMemberExpr(SS, TemplateKWLoc, R, 11688 ExplicitTemplateArgs, S); 11689 else if (ExplicitTemplateArgs || TemplateKWLoc.isValid()) 11690 NewFn = SemaRef.BuildTemplateIdExpr(SS, TemplateKWLoc, R, false, 11691 ExplicitTemplateArgs); 11692 else 11693 NewFn = SemaRef.BuildDeclarationNameExpr(SS, R, false); 11694 11695 if (NewFn.isInvalid()) 11696 return ExprError(); 11697 11698 // This shouldn't cause an infinite loop because we're giving it 11699 // an expression with viable lookup results, which should never 11700 // end up here. 11701 return SemaRef.ActOnCallExpr(/*Scope*/ nullptr, NewFn.get(), LParenLoc, 11702 MultiExprArg(Args.data(), Args.size()), 11703 RParenLoc); 11704 } 11705 11706 /// \brief Constructs and populates an OverloadedCandidateSet from 11707 /// the given function. 11708 /// \returns true when an the ExprResult output parameter has been set. 11709 bool Sema::buildOverloadedCallSet(Scope *S, Expr *Fn, 11710 UnresolvedLookupExpr *ULE, 11711 MultiExprArg Args, 11712 SourceLocation RParenLoc, 11713 OverloadCandidateSet *CandidateSet, 11714 ExprResult *Result) { 11715 #ifndef NDEBUG 11716 if (ULE->requiresADL()) { 11717 // To do ADL, we must have found an unqualified name. 11718 assert(!ULE->getQualifier() && "qualified name with ADL"); 11719 11720 // We don't perform ADL for implicit declarations of builtins. 11721 // Verify that this was correctly set up. 11722 FunctionDecl *F; 11723 if (ULE->decls_begin() + 1 == ULE->decls_end() && 11724 (F = dyn_cast<FunctionDecl>(*ULE->decls_begin())) && 11725 F->getBuiltinID() && F->isImplicit()) 11726 llvm_unreachable("performing ADL for builtin"); 11727 11728 // We don't perform ADL in C. 11729 assert(getLangOpts().CPlusPlus && "ADL enabled in C"); 11730 } 11731 #endif 11732 11733 UnbridgedCastsSet UnbridgedCasts; 11734 if (checkArgPlaceholdersForOverload(*this, Args, UnbridgedCasts)) { 11735 *Result = ExprError(); 11736 return true; 11737 } 11738 11739 // Add the functions denoted by the callee to the set of candidate 11740 // functions, including those from argument-dependent lookup. 11741 AddOverloadedCallCandidates(ULE, Args, *CandidateSet); 11742 11743 if (getLangOpts().MSVCCompat && 11744 CurContext->isDependentContext() && !isSFINAEContext() && 11745 (isa<FunctionDecl>(CurContext) || isa<CXXRecordDecl>(CurContext))) { 11746 11747 OverloadCandidateSet::iterator Best; 11748 if (CandidateSet->empty() || 11749 CandidateSet->BestViableFunction(*this, Fn->getLocStart(), Best) == 11750 OR_No_Viable_Function) { 11751 // In Microsoft mode, if we are inside a template class member function then 11752 // create a type dependent CallExpr. The goal is to postpone name lookup 11753 // to instantiation time to be able to search into type dependent base 11754 // classes. 11755 CallExpr *CE = new (Context) CallExpr( 11756 Context, Fn, Args, Context.DependentTy, VK_RValue, RParenLoc); 11757 CE->setTypeDependent(true); 11758 CE->setValueDependent(true); 11759 CE->setInstantiationDependent(true); 11760 *Result = CE; 11761 return true; 11762 } 11763 } 11764 11765 if (CandidateSet->empty()) 11766 return false; 11767 11768 UnbridgedCasts.restore(); 11769 return false; 11770 } 11771 11772 /// FinishOverloadedCallExpr - given an OverloadCandidateSet, builds and returns 11773 /// the completed call expression. If overload resolution fails, emits 11774 /// diagnostics and returns ExprError() 11775 static ExprResult FinishOverloadedCallExpr(Sema &SemaRef, Scope *S, Expr *Fn, 11776 UnresolvedLookupExpr *ULE, 11777 SourceLocation LParenLoc, 11778 MultiExprArg Args, 11779 SourceLocation RParenLoc, 11780 Expr *ExecConfig, 11781 OverloadCandidateSet *CandidateSet, 11782 OverloadCandidateSet::iterator *Best, 11783 OverloadingResult OverloadResult, 11784 bool AllowTypoCorrection) { 11785 if (CandidateSet->empty()) 11786 return BuildRecoveryCallExpr(SemaRef, S, Fn, ULE, LParenLoc, Args, 11787 RParenLoc, /*EmptyLookup=*/true, 11788 AllowTypoCorrection); 11789 11790 switch (OverloadResult) { 11791 case OR_Success: { 11792 FunctionDecl *FDecl = (*Best)->Function; 11793 SemaRef.CheckUnresolvedLookupAccess(ULE, (*Best)->FoundDecl); 11794 if (SemaRef.DiagnoseUseOfDecl(FDecl, ULE->getNameLoc())) 11795 return ExprError(); 11796 Fn = SemaRef.FixOverloadedFunctionReference(Fn, (*Best)->FoundDecl, FDecl); 11797 return SemaRef.BuildResolvedCallExpr(Fn, FDecl, LParenLoc, Args, RParenLoc, 11798 ExecConfig); 11799 } 11800 11801 case OR_No_Viable_Function: { 11802 // Try to recover by looking for viable functions which the user might 11803 // have meant to call. 11804 ExprResult Recovery = BuildRecoveryCallExpr(SemaRef, S, Fn, ULE, LParenLoc, 11805 Args, RParenLoc, 11806 /*EmptyLookup=*/false, 11807 AllowTypoCorrection); 11808 if (!Recovery.isInvalid()) 11809 return Recovery; 11810 11811 // If the user passes in a function that we can't take the address of, we 11812 // generally end up emitting really bad error messages. Here, we attempt to 11813 // emit better ones. 11814 for (const Expr *Arg : Args) { 11815 if (!Arg->getType()->isFunctionType()) 11816 continue; 11817 if (auto *DRE = dyn_cast<DeclRefExpr>(Arg->IgnoreParenImpCasts())) { 11818 auto *FD = dyn_cast<FunctionDecl>(DRE->getDecl()); 11819 if (FD && 11820 !SemaRef.checkAddressOfFunctionIsAvailable(FD, /*Complain=*/true, 11821 Arg->getExprLoc())) 11822 return ExprError(); 11823 } 11824 } 11825 11826 SemaRef.Diag(Fn->getLocStart(), diag::err_ovl_no_viable_function_in_call) 11827 << ULE->getName() << Fn->getSourceRange(); 11828 CandidateSet->NoteCandidates(SemaRef, OCD_AllCandidates, Args); 11829 break; 11830 } 11831 11832 case OR_Ambiguous: 11833 SemaRef.Diag(Fn->getLocStart(), diag::err_ovl_ambiguous_call) 11834 << ULE->getName() << Fn->getSourceRange(); 11835 CandidateSet->NoteCandidates(SemaRef, OCD_ViableCandidates, Args); 11836 break; 11837 11838 case OR_Deleted: { 11839 SemaRef.Diag(Fn->getLocStart(), diag::err_ovl_deleted_call) 11840 << (*Best)->Function->isDeleted() 11841 << ULE->getName() 11842 << SemaRef.getDeletedOrUnavailableSuffix((*Best)->Function) 11843 << Fn->getSourceRange(); 11844 CandidateSet->NoteCandidates(SemaRef, OCD_AllCandidates, Args); 11845 11846 // We emitted an error for the unvailable/deleted function call but keep 11847 // the call in the AST. 11848 FunctionDecl *FDecl = (*Best)->Function; 11849 Fn = SemaRef.FixOverloadedFunctionReference(Fn, (*Best)->FoundDecl, FDecl); 11850 return SemaRef.BuildResolvedCallExpr(Fn, FDecl, LParenLoc, Args, RParenLoc, 11851 ExecConfig); 11852 } 11853 } 11854 11855 // Overload resolution failed. 11856 return ExprError(); 11857 } 11858 11859 static void markUnaddressableCandidatesUnviable(Sema &S, 11860 OverloadCandidateSet &CS) { 11861 for (auto I = CS.begin(), E = CS.end(); I != E; ++I) { 11862 if (I->Viable && 11863 !S.checkAddressOfFunctionIsAvailable(I->Function, /*Complain=*/false)) { 11864 I->Viable = false; 11865 I->FailureKind = ovl_fail_addr_not_available; 11866 } 11867 } 11868 } 11869 11870 /// BuildOverloadedCallExpr - Given the call expression that calls Fn 11871 /// (which eventually refers to the declaration Func) and the call 11872 /// arguments Args/NumArgs, attempt to resolve the function call down 11873 /// to a specific function. If overload resolution succeeds, returns 11874 /// the call expression produced by overload resolution. 11875 /// Otherwise, emits diagnostics and returns ExprError. 11876 ExprResult Sema::BuildOverloadedCallExpr(Scope *S, Expr *Fn, 11877 UnresolvedLookupExpr *ULE, 11878 SourceLocation LParenLoc, 11879 MultiExprArg Args, 11880 SourceLocation RParenLoc, 11881 Expr *ExecConfig, 11882 bool AllowTypoCorrection, 11883 bool CalleesAddressIsTaken) { 11884 OverloadCandidateSet CandidateSet(Fn->getExprLoc(), 11885 OverloadCandidateSet::CSK_Normal); 11886 ExprResult result; 11887 11888 if (buildOverloadedCallSet(S, Fn, ULE, Args, LParenLoc, &CandidateSet, 11889 &result)) 11890 return result; 11891 11892 // If the user handed us something like `(&Foo)(Bar)`, we need to ensure that 11893 // functions that aren't addressible are considered unviable. 11894 if (CalleesAddressIsTaken) 11895 markUnaddressableCandidatesUnviable(*this, CandidateSet); 11896 11897 OverloadCandidateSet::iterator Best; 11898 OverloadingResult OverloadResult = 11899 CandidateSet.BestViableFunction(*this, Fn->getLocStart(), Best); 11900 11901 return FinishOverloadedCallExpr(*this, S, Fn, ULE, LParenLoc, Args, 11902 RParenLoc, ExecConfig, &CandidateSet, 11903 &Best, OverloadResult, 11904 AllowTypoCorrection); 11905 } 11906 11907 static bool IsOverloaded(const UnresolvedSetImpl &Functions) { 11908 return Functions.size() > 1 || 11909 (Functions.size() == 1 && isa<FunctionTemplateDecl>(*Functions.begin())); 11910 } 11911 11912 /// \brief Create a unary operation that may resolve to an overloaded 11913 /// operator. 11914 /// 11915 /// \param OpLoc The location of the operator itself (e.g., '*'). 11916 /// 11917 /// \param Opc The UnaryOperatorKind that describes this operator. 11918 /// 11919 /// \param Fns The set of non-member functions that will be 11920 /// considered by overload resolution. The caller needs to build this 11921 /// set based on the context using, e.g., 11922 /// LookupOverloadedOperatorName() and ArgumentDependentLookup(). This 11923 /// set should not contain any member functions; those will be added 11924 /// by CreateOverloadedUnaryOp(). 11925 /// 11926 /// \param Input The input argument. 11927 ExprResult 11928 Sema::CreateOverloadedUnaryOp(SourceLocation OpLoc, UnaryOperatorKind Opc, 11929 const UnresolvedSetImpl &Fns, 11930 Expr *Input) { 11931 OverloadedOperatorKind Op = UnaryOperator::getOverloadedOperator(Opc); 11932 assert(Op != OO_None && "Invalid opcode for overloaded unary operator"); 11933 DeclarationName OpName = Context.DeclarationNames.getCXXOperatorName(Op); 11934 // TODO: provide better source location info. 11935 DeclarationNameInfo OpNameInfo(OpName, OpLoc); 11936 11937 if (checkPlaceholderForOverload(*this, Input)) 11938 return ExprError(); 11939 11940 Expr *Args[2] = { Input, nullptr }; 11941 unsigned NumArgs = 1; 11942 11943 // For post-increment and post-decrement, add the implicit '0' as 11944 // the second argument, so that we know this is a post-increment or 11945 // post-decrement. 11946 if (Opc == UO_PostInc || Opc == UO_PostDec) { 11947 llvm::APSInt Zero(Context.getTypeSize(Context.IntTy), false); 11948 Args[1] = IntegerLiteral::Create(Context, Zero, Context.IntTy, 11949 SourceLocation()); 11950 NumArgs = 2; 11951 } 11952 11953 ArrayRef<Expr *> ArgsArray(Args, NumArgs); 11954 11955 if (Input->isTypeDependent()) { 11956 if (Fns.empty()) 11957 return new (Context) UnaryOperator(Input, Opc, Context.DependentTy, 11958 VK_RValue, OK_Ordinary, OpLoc); 11959 11960 CXXRecordDecl *NamingClass = nullptr; // lookup ignores member operators 11961 UnresolvedLookupExpr *Fn 11962 = UnresolvedLookupExpr::Create(Context, NamingClass, 11963 NestedNameSpecifierLoc(), OpNameInfo, 11964 /*ADL*/ true, IsOverloaded(Fns), 11965 Fns.begin(), Fns.end()); 11966 return new (Context) 11967 CXXOperatorCallExpr(Context, Op, Fn, ArgsArray, Context.DependentTy, 11968 VK_RValue, OpLoc, FPOptions()); 11969 } 11970 11971 // Build an empty overload set. 11972 OverloadCandidateSet CandidateSet(OpLoc, OverloadCandidateSet::CSK_Operator); 11973 11974 // Add the candidates from the given function set. 11975 AddFunctionCandidates(Fns, ArgsArray, CandidateSet); 11976 11977 // Add operator candidates that are member functions. 11978 AddMemberOperatorCandidates(Op, OpLoc, ArgsArray, CandidateSet); 11979 11980 // Add candidates from ADL. 11981 AddArgumentDependentLookupCandidates(OpName, OpLoc, ArgsArray, 11982 /*ExplicitTemplateArgs*/nullptr, 11983 CandidateSet); 11984 11985 // Add builtin operator candidates. 11986 AddBuiltinOperatorCandidates(Op, OpLoc, ArgsArray, CandidateSet); 11987 11988 bool HadMultipleCandidates = (CandidateSet.size() > 1); 11989 11990 // Perform overload resolution. 11991 OverloadCandidateSet::iterator Best; 11992 switch (CandidateSet.BestViableFunction(*this, OpLoc, Best)) { 11993 case OR_Success: { 11994 // We found a built-in operator or an overloaded operator. 11995 FunctionDecl *FnDecl = Best->Function; 11996 11997 if (FnDecl) { 11998 Expr *Base = nullptr; 11999 // We matched an overloaded operator. Build a call to that 12000 // operator. 12001 12002 // Convert the arguments. 12003 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(FnDecl)) { 12004 CheckMemberOperatorAccess(OpLoc, Args[0], nullptr, Best->FoundDecl); 12005 12006 ExprResult InputRes = 12007 PerformObjectArgumentInitialization(Input, /*Qualifier=*/nullptr, 12008 Best->FoundDecl, Method); 12009 if (InputRes.isInvalid()) 12010 return ExprError(); 12011 Base = Input = InputRes.get(); 12012 } else { 12013 // Convert the arguments. 12014 ExprResult InputInit 12015 = PerformCopyInitialization(InitializedEntity::InitializeParameter( 12016 Context, 12017 FnDecl->getParamDecl(0)), 12018 SourceLocation(), 12019 Input); 12020 if (InputInit.isInvalid()) 12021 return ExprError(); 12022 Input = InputInit.get(); 12023 } 12024 12025 // Build the actual expression node. 12026 ExprResult FnExpr = CreateFunctionRefExpr(*this, FnDecl, Best->FoundDecl, 12027 Base, HadMultipleCandidates, 12028 OpLoc); 12029 if (FnExpr.isInvalid()) 12030 return ExprError(); 12031 12032 // Determine the result type. 12033 QualType ResultTy = FnDecl->getReturnType(); 12034 ExprValueKind VK = Expr::getValueKindForType(ResultTy); 12035 ResultTy = ResultTy.getNonLValueExprType(Context); 12036 12037 Args[0] = Input; 12038 CallExpr *TheCall = 12039 new (Context) CXXOperatorCallExpr(Context, Op, FnExpr.get(), ArgsArray, 12040 ResultTy, VK, OpLoc, FPOptions()); 12041 12042 if (CheckCallReturnType(FnDecl->getReturnType(), OpLoc, TheCall, FnDecl)) 12043 return ExprError(); 12044 12045 if (CheckFunctionCall(FnDecl, TheCall, 12046 FnDecl->getType()->castAs<FunctionProtoType>())) 12047 return ExprError(); 12048 12049 return MaybeBindToTemporary(TheCall); 12050 } else { 12051 // We matched a built-in operator. Convert the arguments, then 12052 // break out so that we will build the appropriate built-in 12053 // operator node. 12054 ExprResult InputRes = PerformImplicitConversion( 12055 Input, Best->BuiltinParamTypes[0], Best->Conversions[0], AA_Passing); 12056 if (InputRes.isInvalid()) 12057 return ExprError(); 12058 Input = InputRes.get(); 12059 break; 12060 } 12061 } 12062 12063 case OR_No_Viable_Function: 12064 // This is an erroneous use of an operator which can be overloaded by 12065 // a non-member function. Check for non-member operators which were 12066 // defined too late to be candidates. 12067 if (DiagnoseTwoPhaseOperatorLookup(*this, Op, OpLoc, ArgsArray)) 12068 // FIXME: Recover by calling the found function. 12069 return ExprError(); 12070 12071 // No viable function; fall through to handling this as a 12072 // built-in operator, which will produce an error message for us. 12073 break; 12074 12075 case OR_Ambiguous: 12076 Diag(OpLoc, diag::err_ovl_ambiguous_oper_unary) 12077 << UnaryOperator::getOpcodeStr(Opc) 12078 << Input->getType() 12079 << Input->getSourceRange(); 12080 CandidateSet.NoteCandidates(*this, OCD_ViableCandidates, ArgsArray, 12081 UnaryOperator::getOpcodeStr(Opc), OpLoc); 12082 return ExprError(); 12083 12084 case OR_Deleted: 12085 Diag(OpLoc, diag::err_ovl_deleted_oper) 12086 << Best->Function->isDeleted() 12087 << UnaryOperator::getOpcodeStr(Opc) 12088 << getDeletedOrUnavailableSuffix(Best->Function) 12089 << Input->getSourceRange(); 12090 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, ArgsArray, 12091 UnaryOperator::getOpcodeStr(Opc), OpLoc); 12092 return ExprError(); 12093 } 12094 12095 // Either we found no viable overloaded operator or we matched a 12096 // built-in operator. In either case, fall through to trying to 12097 // build a built-in operation. 12098 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 12099 } 12100 12101 /// \brief Create a binary operation that may resolve to an overloaded 12102 /// operator. 12103 /// 12104 /// \param OpLoc The location of the operator itself (e.g., '+'). 12105 /// 12106 /// \param Opc The BinaryOperatorKind that describes this operator. 12107 /// 12108 /// \param Fns The set of non-member functions that will be 12109 /// considered by overload resolution. The caller needs to build this 12110 /// set based on the context using, e.g., 12111 /// LookupOverloadedOperatorName() and ArgumentDependentLookup(). This 12112 /// set should not contain any member functions; those will be added 12113 /// by CreateOverloadedBinOp(). 12114 /// 12115 /// \param LHS Left-hand argument. 12116 /// \param RHS Right-hand argument. 12117 ExprResult 12118 Sema::CreateOverloadedBinOp(SourceLocation OpLoc, 12119 BinaryOperatorKind Opc, 12120 const UnresolvedSetImpl &Fns, 12121 Expr *LHS, Expr *RHS) { 12122 Expr *Args[2] = { LHS, RHS }; 12123 LHS=RHS=nullptr; // Please use only Args instead of LHS/RHS couple 12124 12125 OverloadedOperatorKind Op = BinaryOperator::getOverloadedOperator(Opc); 12126 DeclarationName OpName = Context.DeclarationNames.getCXXOperatorName(Op); 12127 12128 // If either side is type-dependent, create an appropriate dependent 12129 // expression. 12130 if (Args[0]->isTypeDependent() || Args[1]->isTypeDependent()) { 12131 if (Fns.empty()) { 12132 // If there are no functions to store, just build a dependent 12133 // BinaryOperator or CompoundAssignment. 12134 if (Opc <= BO_Assign || Opc > BO_OrAssign) 12135 return new (Context) BinaryOperator( 12136 Args[0], Args[1], Opc, Context.DependentTy, VK_RValue, OK_Ordinary, 12137 OpLoc, FPFeatures); 12138 12139 return new (Context) CompoundAssignOperator( 12140 Args[0], Args[1], Opc, Context.DependentTy, VK_LValue, OK_Ordinary, 12141 Context.DependentTy, Context.DependentTy, OpLoc, 12142 FPFeatures); 12143 } 12144 12145 // FIXME: save results of ADL from here? 12146 CXXRecordDecl *NamingClass = nullptr; // lookup ignores member operators 12147 // TODO: provide better source location info in DNLoc component. 12148 DeclarationNameInfo OpNameInfo(OpName, OpLoc); 12149 UnresolvedLookupExpr *Fn 12150 = UnresolvedLookupExpr::Create(Context, NamingClass, 12151 NestedNameSpecifierLoc(), OpNameInfo, 12152 /*ADL*/ true, IsOverloaded(Fns), 12153 Fns.begin(), Fns.end()); 12154 return new (Context) 12155 CXXOperatorCallExpr(Context, Op, Fn, Args, Context.DependentTy, 12156 VK_RValue, OpLoc, FPFeatures); 12157 } 12158 12159 // Always do placeholder-like conversions on the RHS. 12160 if (checkPlaceholderForOverload(*this, Args[1])) 12161 return ExprError(); 12162 12163 // Do placeholder-like conversion on the LHS; note that we should 12164 // not get here with a PseudoObject LHS. 12165 assert(Args[0]->getObjectKind() != OK_ObjCProperty); 12166 if (checkPlaceholderForOverload(*this, Args[0])) 12167 return ExprError(); 12168 12169 // If this is the assignment operator, we only perform overload resolution 12170 // if the left-hand side is a class or enumeration type. This is actually 12171 // a hack. The standard requires that we do overload resolution between the 12172 // various built-in candidates, but as DR507 points out, this can lead to 12173 // problems. So we do it this way, which pretty much follows what GCC does. 12174 // Note that we go the traditional code path for compound assignment forms. 12175 if (Opc == BO_Assign && !Args[0]->getType()->isOverloadableType()) 12176 return CreateBuiltinBinOp(OpLoc, Opc, Args[0], Args[1]); 12177 12178 // If this is the .* operator, which is not overloadable, just 12179 // create a built-in binary operator. 12180 if (Opc == BO_PtrMemD) 12181 return CreateBuiltinBinOp(OpLoc, Opc, Args[0], Args[1]); 12182 12183 // Build an empty overload set. 12184 OverloadCandidateSet CandidateSet(OpLoc, OverloadCandidateSet::CSK_Operator); 12185 12186 // Add the candidates from the given function set. 12187 AddFunctionCandidates(Fns, Args, CandidateSet); 12188 12189 // Add operator candidates that are member functions. 12190 AddMemberOperatorCandidates(Op, OpLoc, Args, CandidateSet); 12191 12192 // Add candidates from ADL. Per [over.match.oper]p2, this lookup is not 12193 // performed for an assignment operator (nor for operator[] nor operator->, 12194 // which don't get here). 12195 if (Opc != BO_Assign) 12196 AddArgumentDependentLookupCandidates(OpName, OpLoc, Args, 12197 /*ExplicitTemplateArgs*/ nullptr, 12198 CandidateSet); 12199 12200 // Add builtin operator candidates. 12201 AddBuiltinOperatorCandidates(Op, OpLoc, Args, CandidateSet); 12202 12203 bool HadMultipleCandidates = (CandidateSet.size() > 1); 12204 12205 // Perform overload resolution. 12206 OverloadCandidateSet::iterator Best; 12207 switch (CandidateSet.BestViableFunction(*this, OpLoc, Best)) { 12208 case OR_Success: { 12209 // We found a built-in operator or an overloaded operator. 12210 FunctionDecl *FnDecl = Best->Function; 12211 12212 if (FnDecl) { 12213 Expr *Base = nullptr; 12214 // We matched an overloaded operator. Build a call to that 12215 // operator. 12216 12217 // Convert the arguments. 12218 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(FnDecl)) { 12219 // Best->Access is only meaningful for class members. 12220 CheckMemberOperatorAccess(OpLoc, Args[0], Args[1], Best->FoundDecl); 12221 12222 ExprResult Arg1 = 12223 PerformCopyInitialization( 12224 InitializedEntity::InitializeParameter(Context, 12225 FnDecl->getParamDecl(0)), 12226 SourceLocation(), Args[1]); 12227 if (Arg1.isInvalid()) 12228 return ExprError(); 12229 12230 ExprResult Arg0 = 12231 PerformObjectArgumentInitialization(Args[0], /*Qualifier=*/nullptr, 12232 Best->FoundDecl, Method); 12233 if (Arg0.isInvalid()) 12234 return ExprError(); 12235 Base = Args[0] = Arg0.getAs<Expr>(); 12236 Args[1] = RHS = Arg1.getAs<Expr>(); 12237 } else { 12238 // Convert the arguments. 12239 ExprResult Arg0 = PerformCopyInitialization( 12240 InitializedEntity::InitializeParameter(Context, 12241 FnDecl->getParamDecl(0)), 12242 SourceLocation(), Args[0]); 12243 if (Arg0.isInvalid()) 12244 return ExprError(); 12245 12246 ExprResult Arg1 = 12247 PerformCopyInitialization( 12248 InitializedEntity::InitializeParameter(Context, 12249 FnDecl->getParamDecl(1)), 12250 SourceLocation(), Args[1]); 12251 if (Arg1.isInvalid()) 12252 return ExprError(); 12253 Args[0] = LHS = Arg0.getAs<Expr>(); 12254 Args[1] = RHS = Arg1.getAs<Expr>(); 12255 } 12256 12257 // Build the actual expression node. 12258 ExprResult FnExpr = CreateFunctionRefExpr(*this, FnDecl, 12259 Best->FoundDecl, Base, 12260 HadMultipleCandidates, OpLoc); 12261 if (FnExpr.isInvalid()) 12262 return ExprError(); 12263 12264 // Determine the result type. 12265 QualType ResultTy = FnDecl->getReturnType(); 12266 ExprValueKind VK = Expr::getValueKindForType(ResultTy); 12267 ResultTy = ResultTy.getNonLValueExprType(Context); 12268 12269 CXXOperatorCallExpr *TheCall = 12270 new (Context) CXXOperatorCallExpr(Context, Op, FnExpr.get(), 12271 Args, ResultTy, VK, OpLoc, 12272 FPFeatures); 12273 12274 if (CheckCallReturnType(FnDecl->getReturnType(), OpLoc, TheCall, 12275 FnDecl)) 12276 return ExprError(); 12277 12278 ArrayRef<const Expr *> ArgsArray(Args, 2); 12279 const Expr *ImplicitThis = nullptr; 12280 // Cut off the implicit 'this'. 12281 if (isa<CXXMethodDecl>(FnDecl)) { 12282 ImplicitThis = ArgsArray[0]; 12283 ArgsArray = ArgsArray.slice(1); 12284 } 12285 12286 // Check for a self move. 12287 if (Op == OO_Equal) 12288 DiagnoseSelfMove(Args[0], Args[1], OpLoc); 12289 12290 checkCall(FnDecl, nullptr, ImplicitThis, ArgsArray, 12291 isa<CXXMethodDecl>(FnDecl), OpLoc, TheCall->getSourceRange(), 12292 VariadicDoesNotApply); 12293 12294 return MaybeBindToTemporary(TheCall); 12295 } else { 12296 // We matched a built-in operator. Convert the arguments, then 12297 // break out so that we will build the appropriate built-in 12298 // operator node. 12299 ExprResult ArgsRes0 = 12300 PerformImplicitConversion(Args[0], Best->BuiltinParamTypes[0], 12301 Best->Conversions[0], AA_Passing); 12302 if (ArgsRes0.isInvalid()) 12303 return ExprError(); 12304 Args[0] = ArgsRes0.get(); 12305 12306 ExprResult ArgsRes1 = 12307 PerformImplicitConversion(Args[1], Best->BuiltinParamTypes[1], 12308 Best->Conversions[1], AA_Passing); 12309 if (ArgsRes1.isInvalid()) 12310 return ExprError(); 12311 Args[1] = ArgsRes1.get(); 12312 break; 12313 } 12314 } 12315 12316 case OR_No_Viable_Function: { 12317 // C++ [over.match.oper]p9: 12318 // If the operator is the operator , [...] and there are no 12319 // viable functions, then the operator is assumed to be the 12320 // built-in operator and interpreted according to clause 5. 12321 if (Opc == BO_Comma) 12322 break; 12323 12324 // For class as left operand for assignment or compound assigment 12325 // operator do not fall through to handling in built-in, but report that 12326 // no overloaded assignment operator found 12327 ExprResult Result = ExprError(); 12328 if (Args[0]->getType()->isRecordType() && 12329 Opc >= BO_Assign && Opc <= BO_OrAssign) { 12330 Diag(OpLoc, diag::err_ovl_no_viable_oper) 12331 << BinaryOperator::getOpcodeStr(Opc) 12332 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12333 if (Args[0]->getType()->isIncompleteType()) { 12334 Diag(OpLoc, diag::note_assign_lhs_incomplete) 12335 << Args[0]->getType() 12336 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12337 } 12338 } else { 12339 // This is an erroneous use of an operator which can be overloaded by 12340 // a non-member function. Check for non-member operators which were 12341 // defined too late to be candidates. 12342 if (DiagnoseTwoPhaseOperatorLookup(*this, Op, OpLoc, Args)) 12343 // FIXME: Recover by calling the found function. 12344 return ExprError(); 12345 12346 // No viable function; try to create a built-in operation, which will 12347 // produce an error. Then, show the non-viable candidates. 12348 Result = CreateBuiltinBinOp(OpLoc, Opc, Args[0], Args[1]); 12349 } 12350 assert(Result.isInvalid() && 12351 "C++ binary operator overloading is missing candidates!"); 12352 if (Result.isInvalid()) 12353 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args, 12354 BinaryOperator::getOpcodeStr(Opc), OpLoc); 12355 return Result; 12356 } 12357 12358 case OR_Ambiguous: 12359 Diag(OpLoc, diag::err_ovl_ambiguous_oper_binary) 12360 << BinaryOperator::getOpcodeStr(Opc) 12361 << Args[0]->getType() << Args[1]->getType() 12362 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12363 CandidateSet.NoteCandidates(*this, OCD_ViableCandidates, Args, 12364 BinaryOperator::getOpcodeStr(Opc), OpLoc); 12365 return ExprError(); 12366 12367 case OR_Deleted: 12368 if (isImplicitlyDeleted(Best->Function)) { 12369 CXXMethodDecl *Method = cast<CXXMethodDecl>(Best->Function); 12370 Diag(OpLoc, diag::err_ovl_deleted_special_oper) 12371 << Context.getRecordType(Method->getParent()) 12372 << getSpecialMember(Method); 12373 12374 // The user probably meant to call this special member. Just 12375 // explain why it's deleted. 12376 NoteDeletedFunction(Method); 12377 return ExprError(); 12378 } else { 12379 Diag(OpLoc, diag::err_ovl_deleted_oper) 12380 << Best->Function->isDeleted() 12381 << BinaryOperator::getOpcodeStr(Opc) 12382 << getDeletedOrUnavailableSuffix(Best->Function) 12383 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12384 } 12385 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args, 12386 BinaryOperator::getOpcodeStr(Opc), OpLoc); 12387 return ExprError(); 12388 } 12389 12390 // We matched a built-in operator; build it. 12391 return CreateBuiltinBinOp(OpLoc, Opc, Args[0], Args[1]); 12392 } 12393 12394 ExprResult 12395 Sema::CreateOverloadedArraySubscriptExpr(SourceLocation LLoc, 12396 SourceLocation RLoc, 12397 Expr *Base, Expr *Idx) { 12398 Expr *Args[2] = { Base, Idx }; 12399 DeclarationName OpName = 12400 Context.DeclarationNames.getCXXOperatorName(OO_Subscript); 12401 12402 // If either side is type-dependent, create an appropriate dependent 12403 // expression. 12404 if (Args[0]->isTypeDependent() || Args[1]->isTypeDependent()) { 12405 12406 CXXRecordDecl *NamingClass = nullptr; // lookup ignores member operators 12407 // CHECKME: no 'operator' keyword? 12408 DeclarationNameInfo OpNameInfo(OpName, LLoc); 12409 OpNameInfo.setCXXOperatorNameRange(SourceRange(LLoc, RLoc)); 12410 UnresolvedLookupExpr *Fn 12411 = UnresolvedLookupExpr::Create(Context, NamingClass, 12412 NestedNameSpecifierLoc(), OpNameInfo, 12413 /*ADL*/ true, /*Overloaded*/ false, 12414 UnresolvedSetIterator(), 12415 UnresolvedSetIterator()); 12416 // Can't add any actual overloads yet 12417 12418 return new (Context) 12419 CXXOperatorCallExpr(Context, OO_Subscript, Fn, Args, 12420 Context.DependentTy, VK_RValue, RLoc, FPOptions()); 12421 } 12422 12423 // Handle placeholders on both operands. 12424 if (checkPlaceholderForOverload(*this, Args[0])) 12425 return ExprError(); 12426 if (checkPlaceholderForOverload(*this, Args[1])) 12427 return ExprError(); 12428 12429 // Build an empty overload set. 12430 OverloadCandidateSet CandidateSet(LLoc, OverloadCandidateSet::CSK_Operator); 12431 12432 // Subscript can only be overloaded as a member function. 12433 12434 // Add operator candidates that are member functions. 12435 AddMemberOperatorCandidates(OO_Subscript, LLoc, Args, CandidateSet); 12436 12437 // Add builtin operator candidates. 12438 AddBuiltinOperatorCandidates(OO_Subscript, LLoc, Args, CandidateSet); 12439 12440 bool HadMultipleCandidates = (CandidateSet.size() > 1); 12441 12442 // Perform overload resolution. 12443 OverloadCandidateSet::iterator Best; 12444 switch (CandidateSet.BestViableFunction(*this, LLoc, Best)) { 12445 case OR_Success: { 12446 // We found a built-in operator or an overloaded operator. 12447 FunctionDecl *FnDecl = Best->Function; 12448 12449 if (FnDecl) { 12450 // We matched an overloaded operator. Build a call to that 12451 // operator. 12452 12453 CheckMemberOperatorAccess(LLoc, Args[0], Args[1], Best->FoundDecl); 12454 12455 // Convert the arguments. 12456 CXXMethodDecl *Method = cast<CXXMethodDecl>(FnDecl); 12457 ExprResult Arg0 = 12458 PerformObjectArgumentInitialization(Args[0], /*Qualifier=*/nullptr, 12459 Best->FoundDecl, Method); 12460 if (Arg0.isInvalid()) 12461 return ExprError(); 12462 Args[0] = Arg0.get(); 12463 12464 // Convert the arguments. 12465 ExprResult InputInit 12466 = PerformCopyInitialization(InitializedEntity::InitializeParameter( 12467 Context, 12468 FnDecl->getParamDecl(0)), 12469 SourceLocation(), 12470 Args[1]); 12471 if (InputInit.isInvalid()) 12472 return ExprError(); 12473 12474 Args[1] = InputInit.getAs<Expr>(); 12475 12476 // Build the actual expression node. 12477 DeclarationNameInfo OpLocInfo(OpName, LLoc); 12478 OpLocInfo.setCXXOperatorNameRange(SourceRange(LLoc, RLoc)); 12479 ExprResult FnExpr = CreateFunctionRefExpr(*this, FnDecl, 12480 Best->FoundDecl, 12481 Base, 12482 HadMultipleCandidates, 12483 OpLocInfo.getLoc(), 12484 OpLocInfo.getInfo()); 12485 if (FnExpr.isInvalid()) 12486 return ExprError(); 12487 12488 // Determine the result type 12489 QualType ResultTy = FnDecl->getReturnType(); 12490 ExprValueKind VK = Expr::getValueKindForType(ResultTy); 12491 ResultTy = ResultTy.getNonLValueExprType(Context); 12492 12493 CXXOperatorCallExpr *TheCall = 12494 new (Context) CXXOperatorCallExpr(Context, OO_Subscript, 12495 FnExpr.get(), Args, 12496 ResultTy, VK, RLoc, 12497 FPOptions()); 12498 12499 if (CheckCallReturnType(FnDecl->getReturnType(), LLoc, TheCall, FnDecl)) 12500 return ExprError(); 12501 12502 if (CheckFunctionCall(Method, TheCall, 12503 Method->getType()->castAs<FunctionProtoType>())) 12504 return ExprError(); 12505 12506 return MaybeBindToTemporary(TheCall); 12507 } else { 12508 // We matched a built-in operator. Convert the arguments, then 12509 // break out so that we will build the appropriate built-in 12510 // operator node. 12511 ExprResult ArgsRes0 = 12512 PerformImplicitConversion(Args[0], Best->BuiltinParamTypes[0], 12513 Best->Conversions[0], AA_Passing); 12514 if (ArgsRes0.isInvalid()) 12515 return ExprError(); 12516 Args[0] = ArgsRes0.get(); 12517 12518 ExprResult ArgsRes1 = 12519 PerformImplicitConversion(Args[1], Best->BuiltinParamTypes[1], 12520 Best->Conversions[1], AA_Passing); 12521 if (ArgsRes1.isInvalid()) 12522 return ExprError(); 12523 Args[1] = ArgsRes1.get(); 12524 12525 break; 12526 } 12527 } 12528 12529 case OR_No_Viable_Function: { 12530 if (CandidateSet.empty()) 12531 Diag(LLoc, diag::err_ovl_no_oper) 12532 << Args[0]->getType() << /*subscript*/ 0 12533 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12534 else 12535 Diag(LLoc, diag::err_ovl_no_viable_subscript) 12536 << Args[0]->getType() 12537 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12538 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args, 12539 "[]", LLoc); 12540 return ExprError(); 12541 } 12542 12543 case OR_Ambiguous: 12544 Diag(LLoc, diag::err_ovl_ambiguous_oper_binary) 12545 << "[]" 12546 << Args[0]->getType() << Args[1]->getType() 12547 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12548 CandidateSet.NoteCandidates(*this, OCD_ViableCandidates, Args, 12549 "[]", LLoc); 12550 return ExprError(); 12551 12552 case OR_Deleted: 12553 Diag(LLoc, diag::err_ovl_deleted_oper) 12554 << Best->Function->isDeleted() << "[]" 12555 << getDeletedOrUnavailableSuffix(Best->Function) 12556 << Args[0]->getSourceRange() << Args[1]->getSourceRange(); 12557 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args, 12558 "[]", LLoc); 12559 return ExprError(); 12560 } 12561 12562 // We matched a built-in operator; build it. 12563 return CreateBuiltinArraySubscriptExpr(Args[0], LLoc, Args[1], RLoc); 12564 } 12565 12566 /// BuildCallToMemberFunction - Build a call to a member 12567 /// function. MemExpr is the expression that refers to the member 12568 /// function (and includes the object parameter), Args/NumArgs are the 12569 /// arguments to the function call (not including the object 12570 /// parameter). The caller needs to validate that the member 12571 /// expression refers to a non-static member function or an overloaded 12572 /// member function. 12573 ExprResult 12574 Sema::BuildCallToMemberFunction(Scope *S, Expr *MemExprE, 12575 SourceLocation LParenLoc, 12576 MultiExprArg Args, 12577 SourceLocation RParenLoc) { 12578 assert(MemExprE->getType() == Context.BoundMemberTy || 12579 MemExprE->getType() == Context.OverloadTy); 12580 12581 // Dig out the member expression. This holds both the object 12582 // argument and the member function we're referring to. 12583 Expr *NakedMemExpr = MemExprE->IgnoreParens(); 12584 12585 // Determine whether this is a call to a pointer-to-member function. 12586 if (BinaryOperator *op = dyn_cast<BinaryOperator>(NakedMemExpr)) { 12587 assert(op->getType() == Context.BoundMemberTy); 12588 assert(op->getOpcode() == BO_PtrMemD || op->getOpcode() == BO_PtrMemI); 12589 12590 QualType fnType = 12591 op->getRHS()->getType()->castAs<MemberPointerType>()->getPointeeType(); 12592 12593 const FunctionProtoType *proto = fnType->castAs<FunctionProtoType>(); 12594 QualType resultType = proto->getCallResultType(Context); 12595 ExprValueKind valueKind = Expr::getValueKindForType(proto->getReturnType()); 12596 12597 // Check that the object type isn't more qualified than the 12598 // member function we're calling. 12599 Qualifiers funcQuals = Qualifiers::fromCVRMask(proto->getTypeQuals()); 12600 12601 QualType objectType = op->getLHS()->getType(); 12602 if (op->getOpcode() == BO_PtrMemI) 12603 objectType = objectType->castAs<PointerType>()->getPointeeType(); 12604 Qualifiers objectQuals = objectType.getQualifiers(); 12605 12606 Qualifiers difference = objectQuals - funcQuals; 12607 difference.removeObjCGCAttr(); 12608 difference.removeAddressSpace(); 12609 if (difference) { 12610 std::string qualsString = difference.getAsString(); 12611 Diag(LParenLoc, diag::err_pointer_to_member_call_drops_quals) 12612 << fnType.getUnqualifiedType() 12613 << qualsString 12614 << (qualsString.find(' ') == std::string::npos ? 1 : 2); 12615 } 12616 12617 CXXMemberCallExpr *call 12618 = new (Context) CXXMemberCallExpr(Context, MemExprE, Args, 12619 resultType, valueKind, RParenLoc); 12620 12621 if (CheckCallReturnType(proto->getReturnType(), op->getRHS()->getLocStart(), 12622 call, nullptr)) 12623 return ExprError(); 12624 12625 if (ConvertArgumentsForCall(call, op, nullptr, proto, Args, RParenLoc)) 12626 return ExprError(); 12627 12628 if (CheckOtherCall(call, proto)) 12629 return ExprError(); 12630 12631 return MaybeBindToTemporary(call); 12632 } 12633 12634 if (isa<CXXPseudoDestructorExpr>(NakedMemExpr)) 12635 return new (Context) 12636 CallExpr(Context, MemExprE, Args, Context.VoidTy, VK_RValue, RParenLoc); 12637 12638 UnbridgedCastsSet UnbridgedCasts; 12639 if (checkArgPlaceholdersForOverload(*this, Args, UnbridgedCasts)) 12640 return ExprError(); 12641 12642 MemberExpr *MemExpr; 12643 CXXMethodDecl *Method = nullptr; 12644 DeclAccessPair FoundDecl = DeclAccessPair::make(nullptr, AS_public); 12645 NestedNameSpecifier *Qualifier = nullptr; 12646 if (isa<MemberExpr>(NakedMemExpr)) { 12647 MemExpr = cast<MemberExpr>(NakedMemExpr); 12648 Method = cast<CXXMethodDecl>(MemExpr->getMemberDecl()); 12649 FoundDecl = MemExpr->getFoundDecl(); 12650 Qualifier = MemExpr->getQualifier(); 12651 UnbridgedCasts.restore(); 12652 } else { 12653 UnresolvedMemberExpr *UnresExpr = cast<UnresolvedMemberExpr>(NakedMemExpr); 12654 Qualifier = UnresExpr->getQualifier(); 12655 12656 QualType ObjectType = UnresExpr->getBaseType(); 12657 Expr::Classification ObjectClassification 12658 = UnresExpr->isArrow()? Expr::Classification::makeSimpleLValue() 12659 : UnresExpr->getBase()->Classify(Context); 12660 12661 // Add overload candidates 12662 OverloadCandidateSet CandidateSet(UnresExpr->getMemberLoc(), 12663 OverloadCandidateSet::CSK_Normal); 12664 12665 // FIXME: avoid copy. 12666 TemplateArgumentListInfo TemplateArgsBuffer, *TemplateArgs = nullptr; 12667 if (UnresExpr->hasExplicitTemplateArgs()) { 12668 UnresExpr->copyTemplateArgumentsInto(TemplateArgsBuffer); 12669 TemplateArgs = &TemplateArgsBuffer; 12670 } 12671 12672 for (UnresolvedMemberExpr::decls_iterator I = UnresExpr->decls_begin(), 12673 E = UnresExpr->decls_end(); I != E; ++I) { 12674 12675 NamedDecl *Func = *I; 12676 CXXRecordDecl *ActingDC = cast<CXXRecordDecl>(Func->getDeclContext()); 12677 if (isa<UsingShadowDecl>(Func)) 12678 Func = cast<UsingShadowDecl>(Func)->getTargetDecl(); 12679 12680 12681 // Microsoft supports direct constructor calls. 12682 if (getLangOpts().MicrosoftExt && isa<CXXConstructorDecl>(Func)) { 12683 AddOverloadCandidate(cast<CXXConstructorDecl>(Func), I.getPair(), 12684 Args, CandidateSet); 12685 } else if ((Method = dyn_cast<CXXMethodDecl>(Func))) { 12686 // If explicit template arguments were provided, we can't call a 12687 // non-template member function. 12688 if (TemplateArgs) 12689 continue; 12690 12691 AddMethodCandidate(Method, I.getPair(), ActingDC, ObjectType, 12692 ObjectClassification, Args, CandidateSet, 12693 /*SuppressUserConversions=*/false); 12694 } else { 12695 AddMethodTemplateCandidate( 12696 cast<FunctionTemplateDecl>(Func), I.getPair(), ActingDC, 12697 TemplateArgs, ObjectType, ObjectClassification, Args, CandidateSet, 12698 /*SuppressUsedConversions=*/false); 12699 } 12700 } 12701 12702 DeclarationName DeclName = UnresExpr->getMemberName(); 12703 12704 UnbridgedCasts.restore(); 12705 12706 OverloadCandidateSet::iterator Best; 12707 switch (CandidateSet.BestViableFunction(*this, UnresExpr->getLocStart(), 12708 Best)) { 12709 case OR_Success: 12710 Method = cast<CXXMethodDecl>(Best->Function); 12711 FoundDecl = Best->FoundDecl; 12712 CheckUnresolvedMemberAccess(UnresExpr, Best->FoundDecl); 12713 if (DiagnoseUseOfDecl(Best->FoundDecl, UnresExpr->getNameLoc())) 12714 return ExprError(); 12715 // If FoundDecl is different from Method (such as if one is a template 12716 // and the other a specialization), make sure DiagnoseUseOfDecl is 12717 // called on both. 12718 // FIXME: This would be more comprehensively addressed by modifying 12719 // DiagnoseUseOfDecl to accept both the FoundDecl and the decl 12720 // being used. 12721 if (Method != FoundDecl.getDecl() && 12722 DiagnoseUseOfDecl(Method, UnresExpr->getNameLoc())) 12723 return ExprError(); 12724 break; 12725 12726 case OR_No_Viable_Function: 12727 Diag(UnresExpr->getMemberLoc(), 12728 diag::err_ovl_no_viable_member_function_in_call) 12729 << DeclName << MemExprE->getSourceRange(); 12730 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args); 12731 // FIXME: Leaking incoming expressions! 12732 return ExprError(); 12733 12734 case OR_Ambiguous: 12735 Diag(UnresExpr->getMemberLoc(), diag::err_ovl_ambiguous_member_call) 12736 << DeclName << MemExprE->getSourceRange(); 12737 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args); 12738 // FIXME: Leaking incoming expressions! 12739 return ExprError(); 12740 12741 case OR_Deleted: 12742 Diag(UnresExpr->getMemberLoc(), diag::err_ovl_deleted_member_call) 12743 << Best->Function->isDeleted() 12744 << DeclName 12745 << getDeletedOrUnavailableSuffix(Best->Function) 12746 << MemExprE->getSourceRange(); 12747 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args); 12748 // FIXME: Leaking incoming expressions! 12749 return ExprError(); 12750 } 12751 12752 MemExprE = FixOverloadedFunctionReference(MemExprE, FoundDecl, Method); 12753 12754 // If overload resolution picked a static member, build a 12755 // non-member call based on that function. 12756 if (Method->isStatic()) { 12757 return BuildResolvedCallExpr(MemExprE, Method, LParenLoc, Args, 12758 RParenLoc); 12759 } 12760 12761 MemExpr = cast<MemberExpr>(MemExprE->IgnoreParens()); 12762 } 12763 12764 QualType ResultType = Method->getReturnType(); 12765 ExprValueKind VK = Expr::getValueKindForType(ResultType); 12766 ResultType = ResultType.getNonLValueExprType(Context); 12767 12768 assert(Method && "Member call to something that isn't a method?"); 12769 CXXMemberCallExpr *TheCall = 12770 new (Context) CXXMemberCallExpr(Context, MemExprE, Args, 12771 ResultType, VK, RParenLoc); 12772 12773 // Check for a valid return type. 12774 if (CheckCallReturnType(Method->getReturnType(), MemExpr->getMemberLoc(), 12775 TheCall, Method)) 12776 return ExprError(); 12777 12778 // Convert the object argument (for a non-static member function call). 12779 // We only need to do this if there was actually an overload; otherwise 12780 // it was done at lookup. 12781 if (!Method->isStatic()) { 12782 ExprResult ObjectArg = 12783 PerformObjectArgumentInitialization(MemExpr->getBase(), Qualifier, 12784 FoundDecl, Method); 12785 if (ObjectArg.isInvalid()) 12786 return ExprError(); 12787 MemExpr->setBase(ObjectArg.get()); 12788 } 12789 12790 // Convert the rest of the arguments 12791 const FunctionProtoType *Proto = 12792 Method->getType()->getAs<FunctionProtoType>(); 12793 if (ConvertArgumentsForCall(TheCall, MemExpr, Method, Proto, Args, 12794 RParenLoc)) 12795 return ExprError(); 12796 12797 DiagnoseSentinelCalls(Method, LParenLoc, Args); 12798 12799 if (CheckFunctionCall(Method, TheCall, Proto)) 12800 return ExprError(); 12801 12802 // In the case the method to call was not selected by the overloading 12803 // resolution process, we still need to handle the enable_if attribute. Do 12804 // that here, so it will not hide previous -- and more relevant -- errors. 12805 if (auto *MemE = dyn_cast<MemberExpr>(NakedMemExpr)) { 12806 if (const EnableIfAttr *Attr = CheckEnableIf(Method, Args, true)) { 12807 Diag(MemE->getMemberLoc(), 12808 diag::err_ovl_no_viable_member_function_in_call) 12809 << Method << Method->getSourceRange(); 12810 Diag(Method->getLocation(), 12811 diag::note_ovl_candidate_disabled_by_function_cond_attr) 12812 << Attr->getCond()->getSourceRange() << Attr->getMessage(); 12813 return ExprError(); 12814 } 12815 } 12816 12817 if ((isa<CXXConstructorDecl>(CurContext) || 12818 isa<CXXDestructorDecl>(CurContext)) && 12819 TheCall->getMethodDecl()->isPure()) { 12820 const CXXMethodDecl *MD = TheCall->getMethodDecl(); 12821 12822 if (isa<CXXThisExpr>(MemExpr->getBase()->IgnoreParenCasts()) && 12823 MemExpr->performsVirtualDispatch(getLangOpts())) { 12824 Diag(MemExpr->getLocStart(), 12825 diag::warn_call_to_pure_virtual_member_function_from_ctor_dtor) 12826 << MD->getDeclName() << isa<CXXDestructorDecl>(CurContext) 12827 << MD->getParent()->getDeclName(); 12828 12829 Diag(MD->getLocStart(), diag::note_previous_decl) << MD->getDeclName(); 12830 if (getLangOpts().AppleKext) 12831 Diag(MemExpr->getLocStart(), 12832 diag::note_pure_qualified_call_kext) 12833 << MD->getParent()->getDeclName() 12834 << MD->getDeclName(); 12835 } 12836 } 12837 12838 if (CXXDestructorDecl *DD = 12839 dyn_cast<CXXDestructorDecl>(TheCall->getMethodDecl())) { 12840 // a->A::f() doesn't go through the vtable, except in AppleKext mode. 12841 bool CallCanBeVirtual = !MemExpr->hasQualifier() || getLangOpts().AppleKext; 12842 CheckVirtualDtorCall(DD, MemExpr->getLocStart(), /*IsDelete=*/false, 12843 CallCanBeVirtual, /*WarnOnNonAbstractTypes=*/true, 12844 MemExpr->getMemberLoc()); 12845 } 12846 12847 return MaybeBindToTemporary(TheCall); 12848 } 12849 12850 /// BuildCallToObjectOfClassType - Build a call to an object of class 12851 /// type (C++ [over.call.object]), which can end up invoking an 12852 /// overloaded function call operator (@c operator()) or performing a 12853 /// user-defined conversion on the object argument. 12854 ExprResult 12855 Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Obj, 12856 SourceLocation LParenLoc, 12857 MultiExprArg Args, 12858 SourceLocation RParenLoc) { 12859 if (checkPlaceholderForOverload(*this, Obj)) 12860 return ExprError(); 12861 ExprResult Object = Obj; 12862 12863 UnbridgedCastsSet UnbridgedCasts; 12864 if (checkArgPlaceholdersForOverload(*this, Args, UnbridgedCasts)) 12865 return ExprError(); 12866 12867 assert(Object.get()->getType()->isRecordType() && 12868 "Requires object type argument"); 12869 const RecordType *Record = Object.get()->getType()->getAs<RecordType>(); 12870 12871 // C++ [over.call.object]p1: 12872 // If the primary-expression E in the function call syntax 12873 // evaluates to a class object of type "cv T", then the set of 12874 // candidate functions includes at least the function call 12875 // operators of T. The function call operators of T are obtained by 12876 // ordinary lookup of the name operator() in the context of 12877 // (E).operator(). 12878 OverloadCandidateSet CandidateSet(LParenLoc, 12879 OverloadCandidateSet::CSK_Operator); 12880 DeclarationName OpName = Context.DeclarationNames.getCXXOperatorName(OO_Call); 12881 12882 if (RequireCompleteType(LParenLoc, Object.get()->getType(), 12883 diag::err_incomplete_object_call, Object.get())) 12884 return true; 12885 12886 LookupResult R(*this, OpName, LParenLoc, LookupOrdinaryName); 12887 LookupQualifiedName(R, Record->getDecl()); 12888 R.suppressDiagnostics(); 12889 12890 for (LookupResult::iterator Oper = R.begin(), OperEnd = R.end(); 12891 Oper != OperEnd; ++Oper) { 12892 AddMethodCandidate(Oper.getPair(), Object.get()->getType(), 12893 Object.get()->Classify(Context), Args, CandidateSet, 12894 /*SuppressUserConversions=*/false); 12895 } 12896 12897 // C++ [over.call.object]p2: 12898 // In addition, for each (non-explicit in C++0x) conversion function 12899 // declared in T of the form 12900 // 12901 // operator conversion-type-id () cv-qualifier; 12902 // 12903 // where cv-qualifier is the same cv-qualification as, or a 12904 // greater cv-qualification than, cv, and where conversion-type-id 12905 // denotes the type "pointer to function of (P1,...,Pn) returning 12906 // R", or the type "reference to pointer to function of 12907 // (P1,...,Pn) returning R", or the type "reference to function 12908 // of (P1,...,Pn) returning R", a surrogate call function [...] 12909 // is also considered as a candidate function. Similarly, 12910 // surrogate call functions are added to the set of candidate 12911 // functions for each conversion function declared in an 12912 // accessible base class provided the function is not hidden 12913 // within T by another intervening declaration. 12914 const auto &Conversions = 12915 cast<CXXRecordDecl>(Record->getDecl())->getVisibleConversionFunctions(); 12916 for (auto I = Conversions.begin(), E = Conversions.end(); I != E; ++I) { 12917 NamedDecl *D = *I; 12918 CXXRecordDecl *ActingContext = cast<CXXRecordDecl>(D->getDeclContext()); 12919 if (isa<UsingShadowDecl>(D)) 12920 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 12921 12922 // Skip over templated conversion functions; they aren't 12923 // surrogates. 12924 if (isa<FunctionTemplateDecl>(D)) 12925 continue; 12926 12927 CXXConversionDecl *Conv = cast<CXXConversionDecl>(D); 12928 if (!Conv->isExplicit()) { 12929 // Strip the reference type (if any) and then the pointer type (if 12930 // any) to get down to what might be a function type. 12931 QualType ConvType = Conv->getConversionType().getNonReferenceType(); 12932 if (const PointerType *ConvPtrType = ConvType->getAs<PointerType>()) 12933 ConvType = ConvPtrType->getPointeeType(); 12934 12935 if (const FunctionProtoType *Proto = ConvType->getAs<FunctionProtoType>()) 12936 { 12937 AddSurrogateCandidate(Conv, I.getPair(), ActingContext, Proto, 12938 Object.get(), Args, CandidateSet); 12939 } 12940 } 12941 } 12942 12943 bool HadMultipleCandidates = (CandidateSet.size() > 1); 12944 12945 // Perform overload resolution. 12946 OverloadCandidateSet::iterator Best; 12947 switch (CandidateSet.BestViableFunction(*this, Object.get()->getLocStart(), 12948 Best)) { 12949 case OR_Success: 12950 // Overload resolution succeeded; we'll build the appropriate call 12951 // below. 12952 break; 12953 12954 case OR_No_Viable_Function: 12955 if (CandidateSet.empty()) 12956 Diag(Object.get()->getLocStart(), diag::err_ovl_no_oper) 12957 << Object.get()->getType() << /*call*/ 1 12958 << Object.get()->getSourceRange(); 12959 else 12960 Diag(Object.get()->getLocStart(), 12961 diag::err_ovl_no_viable_object_call) 12962 << Object.get()->getType() << Object.get()->getSourceRange(); 12963 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args); 12964 break; 12965 12966 case OR_Ambiguous: 12967 Diag(Object.get()->getLocStart(), 12968 diag::err_ovl_ambiguous_object_call) 12969 << Object.get()->getType() << Object.get()->getSourceRange(); 12970 CandidateSet.NoteCandidates(*this, OCD_ViableCandidates, Args); 12971 break; 12972 12973 case OR_Deleted: 12974 Diag(Object.get()->getLocStart(), 12975 diag::err_ovl_deleted_object_call) 12976 << Best->Function->isDeleted() 12977 << Object.get()->getType() 12978 << getDeletedOrUnavailableSuffix(Best->Function) 12979 << Object.get()->getSourceRange(); 12980 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args); 12981 break; 12982 } 12983 12984 if (Best == CandidateSet.end()) 12985 return true; 12986 12987 UnbridgedCasts.restore(); 12988 12989 if (Best->Function == nullptr) { 12990 // Since there is no function declaration, this is one of the 12991 // surrogate candidates. Dig out the conversion function. 12992 CXXConversionDecl *Conv 12993 = cast<CXXConversionDecl>( 12994 Best->Conversions[0].UserDefined.ConversionFunction); 12995 12996 CheckMemberOperatorAccess(LParenLoc, Object.get(), nullptr, 12997 Best->FoundDecl); 12998 if (DiagnoseUseOfDecl(Best->FoundDecl, LParenLoc)) 12999 return ExprError(); 13000 assert(Conv == Best->FoundDecl.getDecl() && 13001 "Found Decl & conversion-to-functionptr should be same, right?!"); 13002 // We selected one of the surrogate functions that converts the 13003 // object parameter to a function pointer. Perform the conversion 13004 // on the object argument, then let ActOnCallExpr finish the job. 13005 13006 // Create an implicit member expr to refer to the conversion operator. 13007 // and then call it. 13008 ExprResult Call = BuildCXXMemberCallExpr(Object.get(), Best->FoundDecl, 13009 Conv, HadMultipleCandidates); 13010 if (Call.isInvalid()) 13011 return ExprError(); 13012 // Record usage of conversion in an implicit cast. 13013 Call = ImplicitCastExpr::Create(Context, Call.get()->getType(), 13014 CK_UserDefinedConversion, Call.get(), 13015 nullptr, VK_RValue); 13016 13017 return ActOnCallExpr(S, Call.get(), LParenLoc, Args, RParenLoc); 13018 } 13019 13020 CheckMemberOperatorAccess(LParenLoc, Object.get(), nullptr, Best->FoundDecl); 13021 13022 // We found an overloaded operator(). Build a CXXOperatorCallExpr 13023 // that calls this method, using Object for the implicit object 13024 // parameter and passing along the remaining arguments. 13025 CXXMethodDecl *Method = cast<CXXMethodDecl>(Best->Function); 13026 13027 // An error diagnostic has already been printed when parsing the declaration. 13028 if (Method->isInvalidDecl()) 13029 return ExprError(); 13030 13031 const FunctionProtoType *Proto = 13032 Method->getType()->getAs<FunctionProtoType>(); 13033 13034 unsigned NumParams = Proto->getNumParams(); 13035 13036 DeclarationNameInfo OpLocInfo( 13037 Context.DeclarationNames.getCXXOperatorName(OO_Call), LParenLoc); 13038 OpLocInfo.setCXXOperatorNameRange(SourceRange(LParenLoc, RParenLoc)); 13039 ExprResult NewFn = CreateFunctionRefExpr(*this, Method, Best->FoundDecl, 13040 Obj, HadMultipleCandidates, 13041 OpLocInfo.getLoc(), 13042 OpLocInfo.getInfo()); 13043 if (NewFn.isInvalid()) 13044 return true; 13045 13046 // Build the full argument list for the method call (the implicit object 13047 // parameter is placed at the beginning of the list). 13048 SmallVector<Expr *, 8> MethodArgs(Args.size() + 1); 13049 MethodArgs[0] = Object.get(); 13050 std::copy(Args.begin(), Args.end(), MethodArgs.begin() + 1); 13051 13052 // Once we've built TheCall, all of the expressions are properly 13053 // owned. 13054 QualType ResultTy = Method->getReturnType(); 13055 ExprValueKind VK = Expr::getValueKindForType(ResultTy); 13056 ResultTy = ResultTy.getNonLValueExprType(Context); 13057 13058 CXXOperatorCallExpr *TheCall = new (Context) 13059 CXXOperatorCallExpr(Context, OO_Call, NewFn.get(), MethodArgs, ResultTy, 13060 VK, RParenLoc, FPOptions()); 13061 13062 if (CheckCallReturnType(Method->getReturnType(), LParenLoc, TheCall, Method)) 13063 return true; 13064 13065 // We may have default arguments. If so, we need to allocate more 13066 // slots in the call for them. 13067 if (Args.size() < NumParams) 13068 TheCall->setNumArgs(Context, NumParams + 1); 13069 13070 bool IsError = false; 13071 13072 // Initialize the implicit object parameter. 13073 ExprResult ObjRes = 13074 PerformObjectArgumentInitialization(Object.get(), /*Qualifier=*/nullptr, 13075 Best->FoundDecl, Method); 13076 if (ObjRes.isInvalid()) 13077 IsError = true; 13078 else 13079 Object = ObjRes; 13080 TheCall->setArg(0, Object.get()); 13081 13082 // Check the argument types. 13083 for (unsigned i = 0; i != NumParams; i++) { 13084 Expr *Arg; 13085 if (i < Args.size()) { 13086 Arg = Args[i]; 13087 13088 // Pass the argument. 13089 13090 ExprResult InputInit 13091 = PerformCopyInitialization(InitializedEntity::InitializeParameter( 13092 Context, 13093 Method->getParamDecl(i)), 13094 SourceLocation(), Arg); 13095 13096 IsError |= InputInit.isInvalid(); 13097 Arg = InputInit.getAs<Expr>(); 13098 } else { 13099 ExprResult DefArg 13100 = BuildCXXDefaultArgExpr(LParenLoc, Method, Method->getParamDecl(i)); 13101 if (DefArg.isInvalid()) { 13102 IsError = true; 13103 break; 13104 } 13105 13106 Arg = DefArg.getAs<Expr>(); 13107 } 13108 13109 TheCall->setArg(i + 1, Arg); 13110 } 13111 13112 // If this is a variadic call, handle args passed through "...". 13113 if (Proto->isVariadic()) { 13114 // Promote the arguments (C99 6.5.2.2p7). 13115 for (unsigned i = NumParams, e = Args.size(); i < e; i++) { 13116 ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], VariadicMethod, 13117 nullptr); 13118 IsError |= Arg.isInvalid(); 13119 TheCall->setArg(i + 1, Arg.get()); 13120 } 13121 } 13122 13123 if (IsError) return true; 13124 13125 DiagnoseSentinelCalls(Method, LParenLoc, Args); 13126 13127 if (CheckFunctionCall(Method, TheCall, Proto)) 13128 return true; 13129 13130 return MaybeBindToTemporary(TheCall); 13131 } 13132 13133 /// BuildOverloadedArrowExpr - Build a call to an overloaded @c operator-> 13134 /// (if one exists), where @c Base is an expression of class type and 13135 /// @c Member is the name of the member we're trying to find. 13136 ExprResult 13137 Sema::BuildOverloadedArrowExpr(Scope *S, Expr *Base, SourceLocation OpLoc, 13138 bool *NoArrowOperatorFound) { 13139 assert(Base->getType()->isRecordType() && 13140 "left-hand side must have class type"); 13141 13142 if (checkPlaceholderForOverload(*this, Base)) 13143 return ExprError(); 13144 13145 SourceLocation Loc = Base->getExprLoc(); 13146 13147 // C++ [over.ref]p1: 13148 // 13149 // [...] An expression x->m is interpreted as (x.operator->())->m 13150 // for a class object x of type T if T::operator->() exists and if 13151 // the operator is selected as the best match function by the 13152 // overload resolution mechanism (13.3). 13153 DeclarationName OpName = 13154 Context.DeclarationNames.getCXXOperatorName(OO_Arrow); 13155 OverloadCandidateSet CandidateSet(Loc, OverloadCandidateSet::CSK_Operator); 13156 const RecordType *BaseRecord = Base->getType()->getAs<RecordType>(); 13157 13158 if (RequireCompleteType(Loc, Base->getType(), 13159 diag::err_typecheck_incomplete_tag, Base)) 13160 return ExprError(); 13161 13162 LookupResult R(*this, OpName, OpLoc, LookupOrdinaryName); 13163 LookupQualifiedName(R, BaseRecord->getDecl()); 13164 R.suppressDiagnostics(); 13165 13166 for (LookupResult::iterator Oper = R.begin(), OperEnd = R.end(); 13167 Oper != OperEnd; ++Oper) { 13168 AddMethodCandidate(Oper.getPair(), Base->getType(), Base->Classify(Context), 13169 None, CandidateSet, /*SuppressUserConversions=*/false); 13170 } 13171 13172 bool HadMultipleCandidates = (CandidateSet.size() > 1); 13173 13174 // Perform overload resolution. 13175 OverloadCandidateSet::iterator Best; 13176 switch (CandidateSet.BestViableFunction(*this, OpLoc, Best)) { 13177 case OR_Success: 13178 // Overload resolution succeeded; we'll build the call below. 13179 break; 13180 13181 case OR_No_Viable_Function: 13182 if (CandidateSet.empty()) { 13183 QualType BaseType = Base->getType(); 13184 if (NoArrowOperatorFound) { 13185 // Report this specific error to the caller instead of emitting a 13186 // diagnostic, as requested. 13187 *NoArrowOperatorFound = true; 13188 return ExprError(); 13189 } 13190 Diag(OpLoc, diag::err_typecheck_member_reference_arrow) 13191 << BaseType << Base->getSourceRange(); 13192 if (BaseType->isRecordType() && !BaseType->isPointerType()) { 13193 Diag(OpLoc, diag::note_typecheck_member_reference_suggestion) 13194 << FixItHint::CreateReplacement(OpLoc, "."); 13195 } 13196 } else 13197 Diag(OpLoc, diag::err_ovl_no_viable_oper) 13198 << "operator->" << Base->getSourceRange(); 13199 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Base); 13200 return ExprError(); 13201 13202 case OR_Ambiguous: 13203 Diag(OpLoc, diag::err_ovl_ambiguous_oper_unary) 13204 << "->" << Base->getType() << Base->getSourceRange(); 13205 CandidateSet.NoteCandidates(*this, OCD_ViableCandidates, Base); 13206 return ExprError(); 13207 13208 case OR_Deleted: 13209 Diag(OpLoc, diag::err_ovl_deleted_oper) 13210 << Best->Function->isDeleted() 13211 << "->" 13212 << getDeletedOrUnavailableSuffix(Best->Function) 13213 << Base->getSourceRange(); 13214 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Base); 13215 return ExprError(); 13216 } 13217 13218 CheckMemberOperatorAccess(OpLoc, Base, nullptr, Best->FoundDecl); 13219 13220 // Convert the object parameter. 13221 CXXMethodDecl *Method = cast<CXXMethodDecl>(Best->Function); 13222 ExprResult BaseResult = 13223 PerformObjectArgumentInitialization(Base, /*Qualifier=*/nullptr, 13224 Best->FoundDecl, Method); 13225 if (BaseResult.isInvalid()) 13226 return ExprError(); 13227 Base = BaseResult.get(); 13228 13229 // Build the operator call. 13230 ExprResult FnExpr = CreateFunctionRefExpr(*this, Method, Best->FoundDecl, 13231 Base, HadMultipleCandidates, OpLoc); 13232 if (FnExpr.isInvalid()) 13233 return ExprError(); 13234 13235 QualType ResultTy = Method->getReturnType(); 13236 ExprValueKind VK = Expr::getValueKindForType(ResultTy); 13237 ResultTy = ResultTy.getNonLValueExprType(Context); 13238 CXXOperatorCallExpr *TheCall = 13239 new (Context) CXXOperatorCallExpr(Context, OO_Arrow, FnExpr.get(), 13240 Base, ResultTy, VK, OpLoc, FPOptions()); 13241 13242 if (CheckCallReturnType(Method->getReturnType(), OpLoc, TheCall, Method)) 13243 return ExprError(); 13244 13245 if (CheckFunctionCall(Method, TheCall, 13246 Method->getType()->castAs<FunctionProtoType>())) 13247 return ExprError(); 13248 13249 return MaybeBindToTemporary(TheCall); 13250 } 13251 13252 /// BuildLiteralOperatorCall - Build a UserDefinedLiteral by creating a call to 13253 /// a literal operator described by the provided lookup results. 13254 ExprResult Sema::BuildLiteralOperatorCall(LookupResult &R, 13255 DeclarationNameInfo &SuffixInfo, 13256 ArrayRef<Expr*> Args, 13257 SourceLocation LitEndLoc, 13258 TemplateArgumentListInfo *TemplateArgs) { 13259 SourceLocation UDSuffixLoc = SuffixInfo.getCXXLiteralOperatorNameLoc(); 13260 13261 OverloadCandidateSet CandidateSet(UDSuffixLoc, 13262 OverloadCandidateSet::CSK_Normal); 13263 AddFunctionCandidates(R.asUnresolvedSet(), Args, CandidateSet, TemplateArgs, 13264 /*SuppressUserConversions=*/true); 13265 13266 bool HadMultipleCandidates = (CandidateSet.size() > 1); 13267 13268 // Perform overload resolution. This will usually be trivial, but might need 13269 // to perform substitutions for a literal operator template. 13270 OverloadCandidateSet::iterator Best; 13271 switch (CandidateSet.BestViableFunction(*this, UDSuffixLoc, Best)) { 13272 case OR_Success: 13273 case OR_Deleted: 13274 break; 13275 13276 case OR_No_Viable_Function: 13277 Diag(UDSuffixLoc, diag::err_ovl_no_viable_function_in_call) 13278 << R.getLookupName(); 13279 CandidateSet.NoteCandidates(*this, OCD_AllCandidates, Args); 13280 return ExprError(); 13281 13282 case OR_Ambiguous: 13283 Diag(R.getNameLoc(), diag::err_ovl_ambiguous_call) << R.getLookupName(); 13284 CandidateSet.NoteCandidates(*this, OCD_ViableCandidates, Args); 13285 return ExprError(); 13286 } 13287 13288 FunctionDecl *FD = Best->Function; 13289 ExprResult Fn = CreateFunctionRefExpr(*this, FD, Best->FoundDecl, 13290 nullptr, HadMultipleCandidates, 13291 SuffixInfo.getLoc(), 13292 SuffixInfo.getInfo()); 13293 if (Fn.isInvalid()) 13294 return true; 13295 13296 // Check the argument types. This should almost always be a no-op, except 13297 // that array-to-pointer decay is applied to string literals. 13298 Expr *ConvArgs[2]; 13299 for (unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) { 13300 ExprResult InputInit = PerformCopyInitialization( 13301 InitializedEntity::InitializeParameter(Context, FD->getParamDecl(ArgIdx)), 13302 SourceLocation(), Args[ArgIdx]); 13303 if (InputInit.isInvalid()) 13304 return true; 13305 ConvArgs[ArgIdx] = InputInit.get(); 13306 } 13307 13308 QualType ResultTy = FD->getReturnType(); 13309 ExprValueKind VK = Expr::getValueKindForType(ResultTy); 13310 ResultTy = ResultTy.getNonLValueExprType(Context); 13311 13312 UserDefinedLiteral *UDL = 13313 new (Context) UserDefinedLiteral(Context, Fn.get(), 13314 llvm::makeArrayRef(ConvArgs, Args.size()), 13315 ResultTy, VK, LitEndLoc, UDSuffixLoc); 13316 13317 if (CheckCallReturnType(FD->getReturnType(), UDSuffixLoc, UDL, FD)) 13318 return ExprError(); 13319 13320 if (CheckFunctionCall(FD, UDL, nullptr)) 13321 return ExprError(); 13322 13323 return MaybeBindToTemporary(UDL); 13324 } 13325 13326 /// Build a call to 'begin' or 'end' for a C++11 for-range statement. If the 13327 /// given LookupResult is non-empty, it is assumed to describe a member which 13328 /// will be invoked. Otherwise, the function will be found via argument 13329 /// dependent lookup. 13330 /// CallExpr is set to a valid expression and FRS_Success returned on success, 13331 /// otherwise CallExpr is set to ExprError() and some non-success value 13332 /// is returned. 13333 Sema::ForRangeStatus 13334 Sema::BuildForRangeBeginEndCall(SourceLocation Loc, 13335 SourceLocation RangeLoc, 13336 const DeclarationNameInfo &NameInfo, 13337 LookupResult &MemberLookup, 13338 OverloadCandidateSet *CandidateSet, 13339 Expr *Range, ExprResult *CallExpr) { 13340 Scope *S = nullptr; 13341 13342 CandidateSet->clear(OverloadCandidateSet::CSK_Normal); 13343 if (!MemberLookup.empty()) { 13344 ExprResult MemberRef = 13345 BuildMemberReferenceExpr(Range, Range->getType(), Loc, 13346 /*IsPtr=*/false, CXXScopeSpec(), 13347 /*TemplateKWLoc=*/SourceLocation(), 13348 /*FirstQualifierInScope=*/nullptr, 13349 MemberLookup, 13350 /*TemplateArgs=*/nullptr, S); 13351 if (MemberRef.isInvalid()) { 13352 *CallExpr = ExprError(); 13353 return FRS_DiagnosticIssued; 13354 } 13355 *CallExpr = ActOnCallExpr(S, MemberRef.get(), Loc, None, Loc, nullptr); 13356 if (CallExpr->isInvalid()) { 13357 *CallExpr = ExprError(); 13358 return FRS_DiagnosticIssued; 13359 } 13360 } else { 13361 UnresolvedSet<0> FoundNames; 13362 UnresolvedLookupExpr *Fn = 13363 UnresolvedLookupExpr::Create(Context, /*NamingClass=*/nullptr, 13364 NestedNameSpecifierLoc(), NameInfo, 13365 /*NeedsADL=*/true, /*Overloaded=*/false, 13366 FoundNames.begin(), FoundNames.end()); 13367 13368 bool CandidateSetError = buildOverloadedCallSet(S, Fn, Fn, Range, Loc, 13369 CandidateSet, CallExpr); 13370 if (CandidateSet->empty() || CandidateSetError) { 13371 *CallExpr = ExprError(); 13372 return FRS_NoViableFunction; 13373 } 13374 OverloadCandidateSet::iterator Best; 13375 OverloadingResult OverloadResult = 13376 CandidateSet->BestViableFunction(*this, Fn->getLocStart(), Best); 13377 13378 if (OverloadResult == OR_No_Viable_Function) { 13379 *CallExpr = ExprError(); 13380 return FRS_NoViableFunction; 13381 } 13382 *CallExpr = FinishOverloadedCallExpr(*this, S, Fn, Fn, Loc, Range, 13383 Loc, nullptr, CandidateSet, &Best, 13384 OverloadResult, 13385 /*AllowTypoCorrection=*/false); 13386 if (CallExpr->isInvalid() || OverloadResult != OR_Success) { 13387 *CallExpr = ExprError(); 13388 return FRS_DiagnosticIssued; 13389 } 13390 } 13391 return FRS_Success; 13392 } 13393 13394 13395 /// FixOverloadedFunctionReference - E is an expression that refers to 13396 /// a C++ overloaded function (possibly with some parentheses and 13397 /// perhaps a '&' around it). We have resolved the overloaded function 13398 /// to the function declaration Fn, so patch up the expression E to 13399 /// refer (possibly indirectly) to Fn. Returns the new expr. 13400 Expr *Sema::FixOverloadedFunctionReference(Expr *E, DeclAccessPair Found, 13401 FunctionDecl *Fn) { 13402 if (ParenExpr *PE = dyn_cast<ParenExpr>(E)) { 13403 Expr *SubExpr = FixOverloadedFunctionReference(PE->getSubExpr(), 13404 Found, Fn); 13405 if (SubExpr == PE->getSubExpr()) 13406 return PE; 13407 13408 return new (Context) ParenExpr(PE->getLParen(), PE->getRParen(), SubExpr); 13409 } 13410 13411 if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E)) { 13412 Expr *SubExpr = FixOverloadedFunctionReference(ICE->getSubExpr(), 13413 Found, Fn); 13414 assert(Context.hasSameType(ICE->getSubExpr()->getType(), 13415 SubExpr->getType()) && 13416 "Implicit cast type cannot be determined from overload"); 13417 assert(ICE->path_empty() && "fixing up hierarchy conversion?"); 13418 if (SubExpr == ICE->getSubExpr()) 13419 return ICE; 13420 13421 return ImplicitCastExpr::Create(Context, ICE->getType(), 13422 ICE->getCastKind(), 13423 SubExpr, nullptr, 13424 ICE->getValueKind()); 13425 } 13426 13427 if (auto *GSE = dyn_cast<GenericSelectionExpr>(E)) { 13428 if (!GSE->isResultDependent()) { 13429 Expr *SubExpr = 13430 FixOverloadedFunctionReference(GSE->getResultExpr(), Found, Fn); 13431 if (SubExpr == GSE->getResultExpr()) 13432 return GSE; 13433 13434 // Replace the resulting type information before rebuilding the generic 13435 // selection expression. 13436 ArrayRef<Expr *> A = GSE->getAssocExprs(); 13437 SmallVector<Expr *, 4> AssocExprs(A.begin(), A.end()); 13438 unsigned ResultIdx = GSE->getResultIndex(); 13439 AssocExprs[ResultIdx] = SubExpr; 13440 13441 return new (Context) GenericSelectionExpr( 13442 Context, GSE->getGenericLoc(), GSE->getControllingExpr(), 13443 GSE->getAssocTypeSourceInfos(), AssocExprs, GSE->getDefaultLoc(), 13444 GSE->getRParenLoc(), GSE->containsUnexpandedParameterPack(), 13445 ResultIdx); 13446 } 13447 // Rather than fall through to the unreachable, return the original generic 13448 // selection expression. 13449 return GSE; 13450 } 13451 13452 if (UnaryOperator *UnOp = dyn_cast<UnaryOperator>(E)) { 13453 assert(UnOp->getOpcode() == UO_AddrOf && 13454 "Can only take the address of an overloaded function"); 13455 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Fn)) { 13456 if (Method->isStatic()) { 13457 // Do nothing: static member functions aren't any different 13458 // from non-member functions. 13459 } else { 13460 // Fix the subexpression, which really has to be an 13461 // UnresolvedLookupExpr holding an overloaded member function 13462 // or template. 13463 Expr *SubExpr = FixOverloadedFunctionReference(UnOp->getSubExpr(), 13464 Found, Fn); 13465 if (SubExpr == UnOp->getSubExpr()) 13466 return UnOp; 13467 13468 assert(isa<DeclRefExpr>(SubExpr) 13469 && "fixed to something other than a decl ref"); 13470 assert(cast<DeclRefExpr>(SubExpr)->getQualifier() 13471 && "fixed to a member ref with no nested name qualifier"); 13472 13473 // We have taken the address of a pointer to member 13474 // function. Perform the computation here so that we get the 13475 // appropriate pointer to member type. 13476 QualType ClassType 13477 = Context.getTypeDeclType(cast<RecordDecl>(Method->getDeclContext())); 13478 QualType MemPtrType 13479 = Context.getMemberPointerType(Fn->getType(), ClassType.getTypePtr()); 13480 // Under the MS ABI, lock down the inheritance model now. 13481 if (Context.getTargetInfo().getCXXABI().isMicrosoft()) 13482 (void)isCompleteType(UnOp->getOperatorLoc(), MemPtrType); 13483 13484 return new (Context) UnaryOperator(SubExpr, UO_AddrOf, MemPtrType, 13485 VK_RValue, OK_Ordinary, 13486 UnOp->getOperatorLoc()); 13487 } 13488 } 13489 Expr *SubExpr = FixOverloadedFunctionReference(UnOp->getSubExpr(), 13490 Found, Fn); 13491 if (SubExpr == UnOp->getSubExpr()) 13492 return UnOp; 13493 13494 return new (Context) UnaryOperator(SubExpr, UO_AddrOf, 13495 Context.getPointerType(SubExpr->getType()), 13496 VK_RValue, OK_Ordinary, 13497 UnOp->getOperatorLoc()); 13498 } 13499 13500 // C++ [except.spec]p17: 13501 // An exception-specification is considered to be needed when: 13502 // - in an expression the function is the unique lookup result or the 13503 // selected member of a set of overloaded functions 13504 if (auto *FPT = Fn->getType()->getAs<FunctionProtoType>()) 13505 ResolveExceptionSpec(E->getExprLoc(), FPT); 13506 13507 if (UnresolvedLookupExpr *ULE = dyn_cast<UnresolvedLookupExpr>(E)) { 13508 // FIXME: avoid copy. 13509 TemplateArgumentListInfo TemplateArgsBuffer, *TemplateArgs = nullptr; 13510 if (ULE->hasExplicitTemplateArgs()) { 13511 ULE->copyTemplateArgumentsInto(TemplateArgsBuffer); 13512 TemplateArgs = &TemplateArgsBuffer; 13513 } 13514 13515 DeclRefExpr *DRE = DeclRefExpr::Create(Context, 13516 ULE->getQualifierLoc(), 13517 ULE->getTemplateKeywordLoc(), 13518 Fn, 13519 /*enclosing*/ false, // FIXME? 13520 ULE->getNameLoc(), 13521 Fn->getType(), 13522 VK_LValue, 13523 Found.getDecl(), 13524 TemplateArgs); 13525 MarkDeclRefReferenced(DRE); 13526 DRE->setHadMultipleCandidates(ULE->getNumDecls() > 1); 13527 return DRE; 13528 } 13529 13530 if (UnresolvedMemberExpr *MemExpr = dyn_cast<UnresolvedMemberExpr>(E)) { 13531 // FIXME: avoid copy. 13532 TemplateArgumentListInfo TemplateArgsBuffer, *TemplateArgs = nullptr; 13533 if (MemExpr->hasExplicitTemplateArgs()) { 13534 MemExpr->copyTemplateArgumentsInto(TemplateArgsBuffer); 13535 TemplateArgs = &TemplateArgsBuffer; 13536 } 13537 13538 Expr *Base; 13539 13540 // If we're filling in a static method where we used to have an 13541 // implicit member access, rewrite to a simple decl ref. 13542 if (MemExpr->isImplicitAccess()) { 13543 if (cast<CXXMethodDecl>(Fn)->isStatic()) { 13544 DeclRefExpr *DRE = DeclRefExpr::Create(Context, 13545 MemExpr->getQualifierLoc(), 13546 MemExpr->getTemplateKeywordLoc(), 13547 Fn, 13548 /*enclosing*/ false, 13549 MemExpr->getMemberLoc(), 13550 Fn->getType(), 13551 VK_LValue, 13552 Found.getDecl(), 13553 TemplateArgs); 13554 MarkDeclRefReferenced(DRE); 13555 DRE->setHadMultipleCandidates(MemExpr->getNumDecls() > 1); 13556 return DRE; 13557 } else { 13558 SourceLocation Loc = MemExpr->getMemberLoc(); 13559 if (MemExpr->getQualifier()) 13560 Loc = MemExpr->getQualifierLoc().getBeginLoc(); 13561 CheckCXXThisCapture(Loc); 13562 Base = new (Context) CXXThisExpr(Loc, 13563 MemExpr->getBaseType(), 13564 /*isImplicit=*/true); 13565 } 13566 } else 13567 Base = MemExpr->getBase(); 13568 13569 ExprValueKind valueKind; 13570 QualType type; 13571 if (cast<CXXMethodDecl>(Fn)->isStatic()) { 13572 valueKind = VK_LValue; 13573 type = Fn->getType(); 13574 } else { 13575 valueKind = VK_RValue; 13576 type = Context.BoundMemberTy; 13577 } 13578 13579 MemberExpr *ME = MemberExpr::Create( 13580 Context, Base, MemExpr->isArrow(), MemExpr->getOperatorLoc(), 13581 MemExpr->getQualifierLoc(), MemExpr->getTemplateKeywordLoc(), Fn, Found, 13582 MemExpr->getMemberNameInfo(), TemplateArgs, type, valueKind, 13583 OK_Ordinary); 13584 ME->setHadMultipleCandidates(true); 13585 MarkMemberReferenced(ME); 13586 return ME; 13587 } 13588 13589 llvm_unreachable("Invalid reference to overloaded function"); 13590 } 13591 13592 ExprResult Sema::FixOverloadedFunctionReference(ExprResult E, 13593 DeclAccessPair Found, 13594 FunctionDecl *Fn) { 13595 return FixOverloadedFunctionReference(E.get(), Found, Fn); 13596 } 13597