1 //===- SemaTemplateDeduction.cpp - Template Argument Deduction ------------===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 // 9 // This file implements C++ template argument deduction. 10 // 11 //===----------------------------------------------------------------------===// 12 13 #include "clang/Sema/TemplateDeduction.h" 14 #include "TreeTransform.h" 15 #include "TypeLocBuilder.h" 16 #include "clang/AST/ASTContext.h" 17 #include "clang/AST/ASTLambda.h" 18 #include "clang/AST/Decl.h" 19 #include "clang/AST/DeclAccessPair.h" 20 #include "clang/AST/DeclBase.h" 21 #include "clang/AST/DeclCXX.h" 22 #include "clang/AST/DeclTemplate.h" 23 #include "clang/AST/DeclarationName.h" 24 #include "clang/AST/Expr.h" 25 #include "clang/AST/ExprCXX.h" 26 #include "clang/AST/NestedNameSpecifier.h" 27 #include "clang/AST/RecursiveASTVisitor.h" 28 #include "clang/AST/TemplateBase.h" 29 #include "clang/AST/TemplateName.h" 30 #include "clang/AST/Type.h" 31 #include "clang/AST/TypeLoc.h" 32 #include "clang/AST/UnresolvedSet.h" 33 #include "clang/Basic/AddressSpaces.h" 34 #include "clang/Basic/ExceptionSpecificationType.h" 35 #include "clang/Basic/LLVM.h" 36 #include "clang/Basic/LangOptions.h" 37 #include "clang/Basic/PartialDiagnostic.h" 38 #include "clang/Basic/SourceLocation.h" 39 #include "clang/Basic/Specifiers.h" 40 #include "clang/Sema/Ownership.h" 41 #include "clang/Sema/Sema.h" 42 #include "clang/Sema/Template.h" 43 #include "llvm/ADT/APInt.h" 44 #include "llvm/ADT/APSInt.h" 45 #include "llvm/ADT/ArrayRef.h" 46 #include "llvm/ADT/DenseMap.h" 47 #include "llvm/ADT/FoldingSet.h" 48 #include "llvm/ADT/Optional.h" 49 #include "llvm/ADT/SmallBitVector.h" 50 #include "llvm/ADT/SmallPtrSet.h" 51 #include "llvm/ADT/SmallVector.h" 52 #include "llvm/Support/Casting.h" 53 #include "llvm/Support/Compiler.h" 54 #include "llvm/Support/ErrorHandling.h" 55 #include <algorithm> 56 #include <cassert> 57 #include <tuple> 58 #include <utility> 59 60 namespace clang { 61 62 /// Various flags that control template argument deduction. 63 /// 64 /// These flags can be bitwise-OR'd together. 65 enum TemplateDeductionFlags { 66 /// No template argument deduction flags, which indicates the 67 /// strictest results for template argument deduction (as used for, e.g., 68 /// matching class template partial specializations). 69 TDF_None = 0, 70 71 /// Within template argument deduction from a function call, we are 72 /// matching with a parameter type for which the original parameter was 73 /// a reference. 74 TDF_ParamWithReferenceType = 0x1, 75 76 /// Within template argument deduction from a function call, we 77 /// are matching in a case where we ignore cv-qualifiers. 78 TDF_IgnoreQualifiers = 0x02, 79 80 /// Within template argument deduction from a function call, 81 /// we are matching in a case where we can perform template argument 82 /// deduction from a template-id of a derived class of the argument type. 83 TDF_DerivedClass = 0x04, 84 85 /// Allow non-dependent types to differ, e.g., when performing 86 /// template argument deduction from a function call where conversions 87 /// may apply. 88 TDF_SkipNonDependent = 0x08, 89 90 /// Whether we are performing template argument deduction for 91 /// parameters and arguments in a top-level template argument 92 TDF_TopLevelParameterTypeList = 0x10, 93 94 /// Within template argument deduction from overload resolution per 95 /// C++ [over.over] allow matching function types that are compatible in 96 /// terms of noreturn and default calling convention adjustments, or 97 /// similarly matching a declared template specialization against a 98 /// possible template, per C++ [temp.deduct.decl]. In either case, permit 99 /// deduction where the parameter is a function type that can be converted 100 /// to the argument type. 101 TDF_AllowCompatibleFunctionType = 0x20, 102 103 /// Within template argument deduction for a conversion function, we are 104 /// matching with an argument type for which the original argument was 105 /// a reference. 106 TDF_ArgWithReferenceType = 0x40, 107 }; 108 } 109 110 using namespace clang; 111 using namespace sema; 112 113 /// Compare two APSInts, extending and switching the sign as 114 /// necessary to compare their values regardless of underlying type. 115 static bool hasSameExtendedValue(llvm::APSInt X, llvm::APSInt Y) { 116 if (Y.getBitWidth() > X.getBitWidth()) 117 X = X.extend(Y.getBitWidth()); 118 else if (Y.getBitWidth() < X.getBitWidth()) 119 Y = Y.extend(X.getBitWidth()); 120 121 // If there is a signedness mismatch, correct it. 122 if (X.isSigned() != Y.isSigned()) { 123 // If the signed value is negative, then the values cannot be the same. 124 if ((Y.isSigned() && Y.isNegative()) || (X.isSigned() && X.isNegative())) 125 return false; 126 127 Y.setIsSigned(true); 128 X.setIsSigned(true); 129 } 130 131 return X == Y; 132 } 133 134 static Sema::TemplateDeductionResult DeduceTemplateArgumentsByTypeMatch( 135 Sema &S, TemplateParameterList *TemplateParams, QualType Param, 136 QualType Arg, TemplateDeductionInfo &Info, 137 SmallVectorImpl<DeducedTemplateArgument> &Deduced, unsigned TDF, 138 bool PartialOrdering = false, bool DeducedFromArrayBound = false); 139 140 static Sema::TemplateDeductionResult 141 DeduceTemplateArguments(Sema &S, TemplateParameterList *TemplateParams, 142 ArrayRef<TemplateArgument> Ps, 143 ArrayRef<TemplateArgument> As, 144 TemplateDeductionInfo &Info, 145 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 146 bool NumberOfArgumentsMustMatch); 147 148 static void MarkUsedTemplateParameters(ASTContext &Ctx, 149 const TemplateArgument &TemplateArg, 150 bool OnlyDeduced, unsigned Depth, 151 llvm::SmallBitVector &Used); 152 153 static void MarkUsedTemplateParameters(ASTContext &Ctx, QualType T, 154 bool OnlyDeduced, unsigned Level, 155 llvm::SmallBitVector &Deduced); 156 157 /// If the given expression is of a form that permits the deduction 158 /// of a non-type template parameter, return the declaration of that 159 /// non-type template parameter. 160 static const NonTypeTemplateParmDecl * 161 getDeducedParameterFromExpr(const Expr *E, unsigned Depth) { 162 // If we are within an alias template, the expression may have undergone 163 // any number of parameter substitutions already. 164 while (true) { 165 if (const auto *IC = dyn_cast<ImplicitCastExpr>(E)) 166 E = IC->getSubExpr(); 167 else if (const auto *CE = dyn_cast<ConstantExpr>(E)) 168 E = CE->getSubExpr(); 169 else if (const auto *Subst = dyn_cast<SubstNonTypeTemplateParmExpr>(E)) 170 E = Subst->getReplacement(); 171 else if (const auto *CCE = dyn_cast<CXXConstructExpr>(E)) { 172 // Look through implicit copy construction from an lvalue of the same type. 173 if (CCE->getParenOrBraceRange().isValid()) 174 break; 175 // Note, there could be default arguments. 176 assert(CCE->getNumArgs() >= 1 && "implicit construct expr should have 1 arg"); 177 E = CCE->getArg(0); 178 } else 179 break; 180 } 181 182 if (const auto *DRE = dyn_cast<DeclRefExpr>(E)) 183 if (const auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(DRE->getDecl())) 184 if (NTTP->getDepth() == Depth) 185 return NTTP; 186 187 return nullptr; 188 } 189 190 static const NonTypeTemplateParmDecl * 191 getDeducedParameterFromExpr(TemplateDeductionInfo &Info, Expr *E) { 192 return getDeducedParameterFromExpr(E, Info.getDeducedDepth()); 193 } 194 195 /// Determine whether two declaration pointers refer to the same 196 /// declaration. 197 static bool isSameDeclaration(Decl *X, Decl *Y) { 198 if (NamedDecl *NX = dyn_cast<NamedDecl>(X)) 199 X = NX->getUnderlyingDecl(); 200 if (NamedDecl *NY = dyn_cast<NamedDecl>(Y)) 201 Y = NY->getUnderlyingDecl(); 202 203 return X->getCanonicalDecl() == Y->getCanonicalDecl(); 204 } 205 206 /// Verify that the given, deduced template arguments are compatible. 207 /// 208 /// \returns The deduced template argument, or a NULL template argument if 209 /// the deduced template arguments were incompatible. 210 static DeducedTemplateArgument 211 checkDeducedTemplateArguments(ASTContext &Context, 212 const DeducedTemplateArgument &X, 213 const DeducedTemplateArgument &Y) { 214 // We have no deduction for one or both of the arguments; they're compatible. 215 if (X.isNull()) 216 return Y; 217 if (Y.isNull()) 218 return X; 219 220 // If we have two non-type template argument values deduced for the same 221 // parameter, they must both match the type of the parameter, and thus must 222 // match each other's type. As we're only keeping one of them, we must check 223 // for that now. The exception is that if either was deduced from an array 224 // bound, the type is permitted to differ. 225 if (!X.wasDeducedFromArrayBound() && !Y.wasDeducedFromArrayBound()) { 226 QualType XType = X.getNonTypeTemplateArgumentType(); 227 if (!XType.isNull()) { 228 QualType YType = Y.getNonTypeTemplateArgumentType(); 229 if (YType.isNull() || !Context.hasSameType(XType, YType)) 230 return DeducedTemplateArgument(); 231 } 232 } 233 234 switch (X.getKind()) { 235 case TemplateArgument::Null: 236 llvm_unreachable("Non-deduced template arguments handled above"); 237 238 case TemplateArgument::Type: 239 // If two template type arguments have the same type, they're compatible. 240 if (Y.getKind() == TemplateArgument::Type && 241 Context.hasSameType(X.getAsType(), Y.getAsType())) 242 return X; 243 244 // If one of the two arguments was deduced from an array bound, the other 245 // supersedes it. 246 if (X.wasDeducedFromArrayBound() != Y.wasDeducedFromArrayBound()) 247 return X.wasDeducedFromArrayBound() ? Y : X; 248 249 // The arguments are not compatible. 250 return DeducedTemplateArgument(); 251 252 case TemplateArgument::Integral: 253 // If we deduced a constant in one case and either a dependent expression or 254 // declaration in another case, keep the integral constant. 255 // If both are integral constants with the same value, keep that value. 256 if (Y.getKind() == TemplateArgument::Expression || 257 Y.getKind() == TemplateArgument::Declaration || 258 (Y.getKind() == TemplateArgument::Integral && 259 hasSameExtendedValue(X.getAsIntegral(), Y.getAsIntegral()))) 260 return X.wasDeducedFromArrayBound() ? Y : X; 261 262 // All other combinations are incompatible. 263 return DeducedTemplateArgument(); 264 265 case TemplateArgument::Template: 266 if (Y.getKind() == TemplateArgument::Template && 267 Context.hasSameTemplateName(X.getAsTemplate(), Y.getAsTemplate())) 268 return X; 269 270 // All other combinations are incompatible. 271 return DeducedTemplateArgument(); 272 273 case TemplateArgument::TemplateExpansion: 274 if (Y.getKind() == TemplateArgument::TemplateExpansion && 275 Context.hasSameTemplateName(X.getAsTemplateOrTemplatePattern(), 276 Y.getAsTemplateOrTemplatePattern())) 277 return X; 278 279 // All other combinations are incompatible. 280 return DeducedTemplateArgument(); 281 282 case TemplateArgument::Expression: { 283 if (Y.getKind() != TemplateArgument::Expression) 284 return checkDeducedTemplateArguments(Context, Y, X); 285 286 // Compare the expressions for equality 287 llvm::FoldingSetNodeID ID1, ID2; 288 X.getAsExpr()->Profile(ID1, Context, true); 289 Y.getAsExpr()->Profile(ID2, Context, true); 290 if (ID1 == ID2) 291 return X.wasDeducedFromArrayBound() ? Y : X; 292 293 // Differing dependent expressions are incompatible. 294 return DeducedTemplateArgument(); 295 } 296 297 case TemplateArgument::Declaration: 298 assert(!X.wasDeducedFromArrayBound()); 299 300 // If we deduced a declaration and a dependent expression, keep the 301 // declaration. 302 if (Y.getKind() == TemplateArgument::Expression) 303 return X; 304 305 // If we deduced a declaration and an integral constant, keep the 306 // integral constant and whichever type did not come from an array 307 // bound. 308 if (Y.getKind() == TemplateArgument::Integral) { 309 if (Y.wasDeducedFromArrayBound()) 310 return TemplateArgument(Context, Y.getAsIntegral(), 311 X.getParamTypeForDecl()); 312 return Y; 313 } 314 315 // If we deduced two declarations, make sure that they refer to the 316 // same declaration. 317 if (Y.getKind() == TemplateArgument::Declaration && 318 isSameDeclaration(X.getAsDecl(), Y.getAsDecl())) 319 return X; 320 321 // All other combinations are incompatible. 322 return DeducedTemplateArgument(); 323 324 case TemplateArgument::NullPtr: 325 // If we deduced a null pointer and a dependent expression, keep the 326 // null pointer. 327 if (Y.getKind() == TemplateArgument::Expression) 328 return X; 329 330 // If we deduced a null pointer and an integral constant, keep the 331 // integral constant. 332 if (Y.getKind() == TemplateArgument::Integral) 333 return Y; 334 335 // If we deduced two null pointers, they are the same. 336 if (Y.getKind() == TemplateArgument::NullPtr) 337 return X; 338 339 // All other combinations are incompatible. 340 return DeducedTemplateArgument(); 341 342 case TemplateArgument::Pack: { 343 if (Y.getKind() != TemplateArgument::Pack || 344 X.pack_size() != Y.pack_size()) 345 return DeducedTemplateArgument(); 346 347 llvm::SmallVector<TemplateArgument, 8> NewPack; 348 for (TemplateArgument::pack_iterator XA = X.pack_begin(), 349 XAEnd = X.pack_end(), 350 YA = Y.pack_begin(); 351 XA != XAEnd; ++XA, ++YA) { 352 TemplateArgument Merged = checkDeducedTemplateArguments( 353 Context, DeducedTemplateArgument(*XA, X.wasDeducedFromArrayBound()), 354 DeducedTemplateArgument(*YA, Y.wasDeducedFromArrayBound())); 355 if (Merged.isNull() && !(XA->isNull() && YA->isNull())) 356 return DeducedTemplateArgument(); 357 NewPack.push_back(Merged); 358 } 359 360 return DeducedTemplateArgument( 361 TemplateArgument::CreatePackCopy(Context, NewPack), 362 X.wasDeducedFromArrayBound() && Y.wasDeducedFromArrayBound()); 363 } 364 } 365 366 llvm_unreachable("Invalid TemplateArgument Kind!"); 367 } 368 369 /// Deduce the value of the given non-type template parameter 370 /// as the given deduced template argument. All non-type template parameter 371 /// deduction is funneled through here. 372 static Sema::TemplateDeductionResult DeduceNonTypeTemplateArgument( 373 Sema &S, TemplateParameterList *TemplateParams, 374 const NonTypeTemplateParmDecl *NTTP, const DeducedTemplateArgument &NewDeduced, 375 QualType ValueType, TemplateDeductionInfo &Info, 376 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 377 assert(NTTP->getDepth() == Info.getDeducedDepth() && 378 "deducing non-type template argument with wrong depth"); 379 380 DeducedTemplateArgument Result = checkDeducedTemplateArguments( 381 S.Context, Deduced[NTTP->getIndex()], NewDeduced); 382 if (Result.isNull()) { 383 Info.Param = const_cast<NonTypeTemplateParmDecl*>(NTTP); 384 Info.FirstArg = Deduced[NTTP->getIndex()]; 385 Info.SecondArg = NewDeduced; 386 return Sema::TDK_Inconsistent; 387 } 388 389 Deduced[NTTP->getIndex()] = Result; 390 if (!S.getLangOpts().CPlusPlus17) 391 return Sema::TDK_Success; 392 393 if (NTTP->isExpandedParameterPack()) 394 // FIXME: We may still need to deduce parts of the type here! But we 395 // don't have any way to find which slice of the type to use, and the 396 // type stored on the NTTP itself is nonsense. Perhaps the type of an 397 // expanded NTTP should be a pack expansion type? 398 return Sema::TDK_Success; 399 400 // Get the type of the parameter for deduction. If it's a (dependent) array 401 // or function type, we will not have decayed it yet, so do that now. 402 QualType ParamType = S.Context.getAdjustedParameterType(NTTP->getType()); 403 if (auto *Expansion = dyn_cast<PackExpansionType>(ParamType)) 404 ParamType = Expansion->getPattern(); 405 406 // FIXME: It's not clear how deduction of a parameter of reference 407 // type from an argument (of non-reference type) should be performed. 408 // For now, we just remove reference types from both sides and let 409 // the final check for matching types sort out the mess. 410 ValueType = ValueType.getNonReferenceType(); 411 if (ParamType->isReferenceType()) 412 ParamType = ParamType.getNonReferenceType(); 413 else 414 // Top-level cv-qualifiers are irrelevant for a non-reference type. 415 ValueType = ValueType.getUnqualifiedType(); 416 417 return DeduceTemplateArgumentsByTypeMatch( 418 S, TemplateParams, ParamType, ValueType, Info, Deduced, 419 TDF_SkipNonDependent, /*PartialOrdering=*/false, 420 /*ArrayBound=*/NewDeduced.wasDeducedFromArrayBound()); 421 } 422 423 /// Deduce the value of the given non-type template parameter 424 /// from the given integral constant. 425 static Sema::TemplateDeductionResult DeduceNonTypeTemplateArgument( 426 Sema &S, TemplateParameterList *TemplateParams, 427 const NonTypeTemplateParmDecl *NTTP, const llvm::APSInt &Value, 428 QualType ValueType, bool DeducedFromArrayBound, TemplateDeductionInfo &Info, 429 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 430 return DeduceNonTypeTemplateArgument( 431 S, TemplateParams, NTTP, 432 DeducedTemplateArgument(S.Context, Value, ValueType, 433 DeducedFromArrayBound), 434 ValueType, Info, Deduced); 435 } 436 437 /// Deduce the value of the given non-type template parameter 438 /// from the given null pointer template argument type. 439 static Sema::TemplateDeductionResult DeduceNullPtrTemplateArgument( 440 Sema &S, TemplateParameterList *TemplateParams, 441 const NonTypeTemplateParmDecl *NTTP, QualType NullPtrType, 442 TemplateDeductionInfo &Info, 443 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 444 Expr *Value = S.ImpCastExprToType( 445 new (S.Context) CXXNullPtrLiteralExpr(S.Context.NullPtrTy, 446 NTTP->getLocation()), 447 NullPtrType, 448 NullPtrType->isMemberPointerType() ? CK_NullToMemberPointer 449 : CK_NullToPointer) 450 .get(); 451 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 452 DeducedTemplateArgument(Value), 453 Value->getType(), Info, Deduced); 454 } 455 456 /// Deduce the value of the given non-type template parameter 457 /// from the given type- or value-dependent expression. 458 /// 459 /// \returns true if deduction succeeded, false otherwise. 460 static Sema::TemplateDeductionResult DeduceNonTypeTemplateArgument( 461 Sema &S, TemplateParameterList *TemplateParams, 462 const NonTypeTemplateParmDecl *NTTP, Expr *Value, TemplateDeductionInfo &Info, 463 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 464 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 465 DeducedTemplateArgument(Value), 466 Value->getType(), Info, Deduced); 467 } 468 469 /// Deduce the value of the given non-type template parameter 470 /// from the given declaration. 471 /// 472 /// \returns true if deduction succeeded, false otherwise. 473 static Sema::TemplateDeductionResult DeduceNonTypeTemplateArgument( 474 Sema &S, TemplateParameterList *TemplateParams, 475 const NonTypeTemplateParmDecl *NTTP, ValueDecl *D, QualType T, 476 TemplateDeductionInfo &Info, 477 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 478 D = D ? cast<ValueDecl>(D->getCanonicalDecl()) : nullptr; 479 TemplateArgument New(D, T); 480 return DeduceNonTypeTemplateArgument( 481 S, TemplateParams, NTTP, DeducedTemplateArgument(New), T, Info, Deduced); 482 } 483 484 static Sema::TemplateDeductionResult 485 DeduceTemplateArguments(Sema &S, 486 TemplateParameterList *TemplateParams, 487 TemplateName Param, 488 TemplateName Arg, 489 TemplateDeductionInfo &Info, 490 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 491 TemplateDecl *ParamDecl = Param.getAsTemplateDecl(); 492 if (!ParamDecl) { 493 // The parameter type is dependent and is not a template template parameter, 494 // so there is nothing that we can deduce. 495 return Sema::TDK_Success; 496 } 497 498 if (TemplateTemplateParmDecl *TempParam 499 = dyn_cast<TemplateTemplateParmDecl>(ParamDecl)) { 500 // If we're not deducing at this depth, there's nothing to deduce. 501 if (TempParam->getDepth() != Info.getDeducedDepth()) 502 return Sema::TDK_Success; 503 504 DeducedTemplateArgument NewDeduced(S.Context.getCanonicalTemplateName(Arg)); 505 DeducedTemplateArgument Result = checkDeducedTemplateArguments(S.Context, 506 Deduced[TempParam->getIndex()], 507 NewDeduced); 508 if (Result.isNull()) { 509 Info.Param = TempParam; 510 Info.FirstArg = Deduced[TempParam->getIndex()]; 511 Info.SecondArg = NewDeduced; 512 return Sema::TDK_Inconsistent; 513 } 514 515 Deduced[TempParam->getIndex()] = Result; 516 return Sema::TDK_Success; 517 } 518 519 // Verify that the two template names are equivalent. 520 if (S.Context.hasSameTemplateName(Param, Arg)) 521 return Sema::TDK_Success; 522 523 // Mismatch of non-dependent template parameter to argument. 524 Info.FirstArg = TemplateArgument(Param); 525 Info.SecondArg = TemplateArgument(Arg); 526 return Sema::TDK_NonDeducedMismatch; 527 } 528 529 /// Deduce the template arguments by comparing the template parameter 530 /// type (which is a template-id) with the template argument type. 531 /// 532 /// \param S the Sema 533 /// 534 /// \param TemplateParams the template parameters that we are deducing 535 /// 536 /// \param P the parameter type 537 /// 538 /// \param A the argument type 539 /// 540 /// \param Info information about the template argument deduction itself 541 /// 542 /// \param Deduced the deduced template arguments 543 /// 544 /// \returns the result of template argument deduction so far. Note that a 545 /// "success" result means that template argument deduction has not yet failed, 546 /// but it may still fail, later, for other reasons. 547 static Sema::TemplateDeductionResult 548 DeduceTemplateSpecArguments(Sema &S, TemplateParameterList *TemplateParams, 549 const QualType P, QualType A, 550 TemplateDeductionInfo &Info, 551 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 552 QualType UP = P; 553 if (const auto *IP = P->getAs<InjectedClassNameType>()) 554 UP = IP->getInjectedSpecializationType(); 555 // FIXME: Try to preserve type sugar here, which is hard 556 // because of the unresolved template arguments. 557 const auto *TP = UP.getCanonicalType()->castAs<TemplateSpecializationType>(); 558 ArrayRef<TemplateArgument> PResolved = TP->template_arguments(); 559 560 QualType UA = A; 561 // Treat an injected-class-name as its underlying template-id. 562 if (const auto *Injected = A->getAs<InjectedClassNameType>()) 563 UA = Injected->getInjectedSpecializationType(); 564 565 // Check whether the template argument is a dependent template-id. 566 // FIXME: Should not lose sugar here. 567 if (const auto *SA = 568 dyn_cast<TemplateSpecializationType>(UA.getCanonicalType())) { 569 // Perform template argument deduction for the template name. 570 if (auto Result = 571 DeduceTemplateArguments(S, TemplateParams, TP->getTemplateName(), 572 SA->getTemplateName(), Info, Deduced)) 573 return Result; 574 // Perform template argument deduction on each template 575 // argument. Ignore any missing/extra arguments, since they could be 576 // filled in by default arguments. 577 return DeduceTemplateArguments(S, TemplateParams, PResolved, 578 SA->template_arguments(), Info, Deduced, 579 /*NumberOfArgumentsMustMatch=*/false); 580 } 581 582 // If the argument type is a class template specialization, we 583 // perform template argument deduction using its template 584 // arguments. 585 const auto *RA = UA->getAs<RecordType>(); 586 const auto *SA = 587 RA ? dyn_cast<ClassTemplateSpecializationDecl>(RA->getDecl()) : nullptr; 588 if (!SA) { 589 Info.FirstArg = TemplateArgument(P); 590 Info.SecondArg = TemplateArgument(A); 591 return Sema::TDK_NonDeducedMismatch; 592 } 593 594 // Perform template argument deduction for the template name. 595 if (auto Result = DeduceTemplateArguments( 596 S, TemplateParams, TP->getTemplateName(), 597 TemplateName(SA->getSpecializedTemplate()), Info, Deduced)) 598 return Result; 599 600 // Perform template argument deduction for the template arguments. 601 return DeduceTemplateArguments(S, TemplateParams, PResolved, 602 SA->getTemplateArgs().asArray(), Info, Deduced, 603 /*NumberOfArgumentsMustMatch=*/true); 604 } 605 606 static bool IsPossiblyOpaquelyQualifiedTypeInternal(const Type *T) { 607 assert(T->isCanonicalUnqualified()); 608 609 switch (T->getTypeClass()) { 610 case Type::TypeOfExpr: 611 case Type::TypeOf: 612 case Type::DependentName: 613 case Type::Decltype: 614 case Type::UnresolvedUsing: 615 case Type::TemplateTypeParm: 616 return true; 617 618 case Type::ConstantArray: 619 case Type::IncompleteArray: 620 case Type::VariableArray: 621 case Type::DependentSizedArray: 622 return IsPossiblyOpaquelyQualifiedTypeInternal( 623 cast<ArrayType>(T)->getElementType().getTypePtr()); 624 625 default: 626 return false; 627 } 628 } 629 630 /// Determines whether the given type is an opaque type that 631 /// might be more qualified when instantiated. 632 static bool IsPossiblyOpaquelyQualifiedType(QualType T) { 633 return IsPossiblyOpaquelyQualifiedTypeInternal( 634 T->getCanonicalTypeInternal().getTypePtr()); 635 } 636 637 /// Helper function to build a TemplateParameter when we don't 638 /// know its type statically. 639 static TemplateParameter makeTemplateParameter(Decl *D) { 640 if (TemplateTypeParmDecl *TTP = dyn_cast<TemplateTypeParmDecl>(D)) 641 return TemplateParameter(TTP); 642 if (NonTypeTemplateParmDecl *NTTP = dyn_cast<NonTypeTemplateParmDecl>(D)) 643 return TemplateParameter(NTTP); 644 645 return TemplateParameter(cast<TemplateTemplateParmDecl>(D)); 646 } 647 648 /// A pack that we're currently deducing. 649 struct clang::DeducedPack { 650 // The index of the pack. 651 unsigned Index; 652 653 // The old value of the pack before we started deducing it. 654 DeducedTemplateArgument Saved; 655 656 // A deferred value of this pack from an inner deduction, that couldn't be 657 // deduced because this deduction hadn't happened yet. 658 DeducedTemplateArgument DeferredDeduction; 659 660 // The new value of the pack. 661 SmallVector<DeducedTemplateArgument, 4> New; 662 663 // The outer deduction for this pack, if any. 664 DeducedPack *Outer = nullptr; 665 666 DeducedPack(unsigned Index) : Index(Index) {} 667 }; 668 669 namespace { 670 671 /// A scope in which we're performing pack deduction. 672 class PackDeductionScope { 673 public: 674 /// Prepare to deduce the packs named within Pattern. 675 PackDeductionScope(Sema &S, TemplateParameterList *TemplateParams, 676 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 677 TemplateDeductionInfo &Info, TemplateArgument Pattern) 678 : S(S), TemplateParams(TemplateParams), Deduced(Deduced), Info(Info) { 679 unsigned NumNamedPacks = addPacks(Pattern); 680 finishConstruction(NumNamedPacks); 681 } 682 683 /// Prepare to directly deduce arguments of the parameter with index \p Index. 684 PackDeductionScope(Sema &S, TemplateParameterList *TemplateParams, 685 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 686 TemplateDeductionInfo &Info, unsigned Index) 687 : S(S), TemplateParams(TemplateParams), Deduced(Deduced), Info(Info) { 688 addPack(Index); 689 finishConstruction(1); 690 } 691 692 private: 693 void addPack(unsigned Index) { 694 // Save the deduced template argument for the parameter pack expanded 695 // by this pack expansion, then clear out the deduction. 696 DeducedPack Pack(Index); 697 Pack.Saved = Deduced[Index]; 698 Deduced[Index] = TemplateArgument(); 699 700 // FIXME: What if we encounter multiple packs with different numbers of 701 // pre-expanded expansions? (This should already have been diagnosed 702 // during substitution.) 703 if (Optional<unsigned> ExpandedPackExpansions = 704 getExpandedPackSize(TemplateParams->getParam(Index))) 705 FixedNumExpansions = ExpandedPackExpansions; 706 707 Packs.push_back(Pack); 708 } 709 710 unsigned addPacks(TemplateArgument Pattern) { 711 // Compute the set of template parameter indices that correspond to 712 // parameter packs expanded by the pack expansion. 713 llvm::SmallBitVector SawIndices(TemplateParams->size()); 714 llvm::SmallVector<TemplateArgument, 4> ExtraDeductions; 715 716 auto AddPack = [&](unsigned Index) { 717 if (SawIndices[Index]) 718 return; 719 SawIndices[Index] = true; 720 addPack(Index); 721 722 // Deducing a parameter pack that is a pack expansion also constrains the 723 // packs appearing in that parameter to have the same deduced arity. Also, 724 // in C++17 onwards, deducing a non-type template parameter deduces its 725 // type, so we need to collect the pending deduced values for those packs. 726 if (auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>( 727 TemplateParams->getParam(Index))) { 728 if (!NTTP->isExpandedParameterPack()) 729 if (auto *Expansion = dyn_cast<PackExpansionType>(NTTP->getType())) 730 ExtraDeductions.push_back(Expansion->getPattern()); 731 } 732 // FIXME: Also collect the unexpanded packs in any type and template 733 // parameter packs that are pack expansions. 734 }; 735 736 auto Collect = [&](TemplateArgument Pattern) { 737 SmallVector<UnexpandedParameterPack, 2> Unexpanded; 738 S.collectUnexpandedParameterPacks(Pattern, Unexpanded); 739 for (unsigned I = 0, N = Unexpanded.size(); I != N; ++I) { 740 unsigned Depth, Index; 741 std::tie(Depth, Index) = getDepthAndIndex(Unexpanded[I]); 742 if (Depth == Info.getDeducedDepth()) 743 AddPack(Index); 744 } 745 }; 746 747 // Look for unexpanded packs in the pattern. 748 Collect(Pattern); 749 assert(!Packs.empty() && "Pack expansion without unexpanded packs?"); 750 751 unsigned NumNamedPacks = Packs.size(); 752 753 // Also look for unexpanded packs that are indirectly deduced by deducing 754 // the sizes of the packs in this pattern. 755 while (!ExtraDeductions.empty()) 756 Collect(ExtraDeductions.pop_back_val()); 757 758 return NumNamedPacks; 759 } 760 761 void finishConstruction(unsigned NumNamedPacks) { 762 // Dig out the partially-substituted pack, if there is one. 763 const TemplateArgument *PartialPackArgs = nullptr; 764 unsigned NumPartialPackArgs = 0; 765 std::pair<unsigned, unsigned> PartialPackDepthIndex(-1u, -1u); 766 if (auto *Scope = S.CurrentInstantiationScope) 767 if (auto *Partial = Scope->getPartiallySubstitutedPack( 768 &PartialPackArgs, &NumPartialPackArgs)) 769 PartialPackDepthIndex = getDepthAndIndex(Partial); 770 771 // This pack expansion will have been partially or fully expanded if 772 // it only names explicitly-specified parameter packs (including the 773 // partially-substituted one, if any). 774 bool IsExpanded = true; 775 for (unsigned I = 0; I != NumNamedPacks; ++I) { 776 if (Packs[I].Index >= Info.getNumExplicitArgs()) { 777 IsExpanded = false; 778 IsPartiallyExpanded = false; 779 break; 780 } 781 if (PartialPackDepthIndex == 782 std::make_pair(Info.getDeducedDepth(), Packs[I].Index)) { 783 IsPartiallyExpanded = true; 784 } 785 } 786 787 // Skip over the pack elements that were expanded into separate arguments. 788 // If we partially expanded, this is the number of partial arguments. 789 if (IsPartiallyExpanded) 790 PackElements += NumPartialPackArgs; 791 else if (IsExpanded) 792 PackElements += *FixedNumExpansions; 793 794 for (auto &Pack : Packs) { 795 if (Info.PendingDeducedPacks.size() > Pack.Index) 796 Pack.Outer = Info.PendingDeducedPacks[Pack.Index]; 797 else 798 Info.PendingDeducedPacks.resize(Pack.Index + 1); 799 Info.PendingDeducedPacks[Pack.Index] = &Pack; 800 801 if (PartialPackDepthIndex == 802 std::make_pair(Info.getDeducedDepth(), Pack.Index)) { 803 Pack.New.append(PartialPackArgs, PartialPackArgs + NumPartialPackArgs); 804 // We pre-populate the deduced value of the partially-substituted 805 // pack with the specified value. This is not entirely correct: the 806 // value is supposed to have been substituted, not deduced, but the 807 // cases where this is observable require an exact type match anyway. 808 // 809 // FIXME: If we could represent a "depth i, index j, pack elem k" 810 // parameter, we could substitute the partially-substituted pack 811 // everywhere and avoid this. 812 if (!IsPartiallyExpanded) 813 Deduced[Pack.Index] = Pack.New[PackElements]; 814 } 815 } 816 } 817 818 public: 819 ~PackDeductionScope() { 820 for (auto &Pack : Packs) 821 Info.PendingDeducedPacks[Pack.Index] = Pack.Outer; 822 } 823 824 /// Determine whether this pack has already been partially expanded into a 825 /// sequence of (prior) function parameters / template arguments. 826 bool isPartiallyExpanded() { return IsPartiallyExpanded; } 827 828 /// Determine whether this pack expansion scope has a known, fixed arity. 829 /// This happens if it involves a pack from an outer template that has 830 /// (notionally) already been expanded. 831 bool hasFixedArity() { return FixedNumExpansions.has_value(); } 832 833 /// Determine whether the next element of the argument is still part of this 834 /// pack. This is the case unless the pack is already expanded to a fixed 835 /// length. 836 bool hasNextElement() { 837 return !FixedNumExpansions || *FixedNumExpansions > PackElements; 838 } 839 840 /// Move to deducing the next element in each pack that is being deduced. 841 void nextPackElement() { 842 // Capture the deduced template arguments for each parameter pack expanded 843 // by this pack expansion, add them to the list of arguments we've deduced 844 // for that pack, then clear out the deduced argument. 845 for (auto &Pack : Packs) { 846 DeducedTemplateArgument &DeducedArg = Deduced[Pack.Index]; 847 if (!Pack.New.empty() || !DeducedArg.isNull()) { 848 while (Pack.New.size() < PackElements) 849 Pack.New.push_back(DeducedTemplateArgument()); 850 if (Pack.New.size() == PackElements) 851 Pack.New.push_back(DeducedArg); 852 else 853 Pack.New[PackElements] = DeducedArg; 854 DeducedArg = Pack.New.size() > PackElements + 1 855 ? Pack.New[PackElements + 1] 856 : DeducedTemplateArgument(); 857 } 858 } 859 ++PackElements; 860 } 861 862 /// Finish template argument deduction for a set of argument packs, 863 /// producing the argument packs and checking for consistency with prior 864 /// deductions. 865 Sema::TemplateDeductionResult finish() { 866 // Build argument packs for each of the parameter packs expanded by this 867 // pack expansion. 868 for (auto &Pack : Packs) { 869 // Put back the old value for this pack. 870 Deduced[Pack.Index] = Pack.Saved; 871 872 // Always make sure the size of this pack is correct, even if we didn't 873 // deduce any values for it. 874 // 875 // FIXME: This isn't required by the normative wording, but substitution 876 // and post-substitution checking will always fail if the arity of any 877 // pack is not equal to the number of elements we processed. (Either that 878 // or something else has gone *very* wrong.) We're permitted to skip any 879 // hard errors from those follow-on steps by the intent (but not the 880 // wording) of C++ [temp.inst]p8: 881 // 882 // If the function selected by overload resolution can be determined 883 // without instantiating a class template definition, it is unspecified 884 // whether that instantiation actually takes place 885 Pack.New.resize(PackElements); 886 887 // Build or find a new value for this pack. 888 DeducedTemplateArgument NewPack; 889 if (Pack.New.empty()) { 890 // If we deduced an empty argument pack, create it now. 891 NewPack = DeducedTemplateArgument(TemplateArgument::getEmptyPack()); 892 } else { 893 TemplateArgument *ArgumentPack = 894 new (S.Context) TemplateArgument[Pack.New.size()]; 895 std::copy(Pack.New.begin(), Pack.New.end(), ArgumentPack); 896 NewPack = DeducedTemplateArgument( 897 TemplateArgument(llvm::makeArrayRef(ArgumentPack, Pack.New.size())), 898 // FIXME: This is wrong, it's possible that some pack elements are 899 // deduced from an array bound and others are not: 900 // template<typename ...T, T ...V> void g(const T (&...p)[V]); 901 // g({1, 2, 3}, {{}, {}}); 902 // ... should deduce T = {int, size_t (from array bound)}. 903 Pack.New[0].wasDeducedFromArrayBound()); 904 } 905 906 // Pick where we're going to put the merged pack. 907 DeducedTemplateArgument *Loc; 908 if (Pack.Outer) { 909 if (Pack.Outer->DeferredDeduction.isNull()) { 910 // Defer checking this pack until we have a complete pack to compare 911 // it against. 912 Pack.Outer->DeferredDeduction = NewPack; 913 continue; 914 } 915 Loc = &Pack.Outer->DeferredDeduction; 916 } else { 917 Loc = &Deduced[Pack.Index]; 918 } 919 920 // Check the new pack matches any previous value. 921 DeducedTemplateArgument OldPack = *Loc; 922 DeducedTemplateArgument Result = 923 checkDeducedTemplateArguments(S.Context, OldPack, NewPack); 924 925 // If we deferred a deduction of this pack, check that one now too. 926 if (!Result.isNull() && !Pack.DeferredDeduction.isNull()) { 927 OldPack = Result; 928 NewPack = Pack.DeferredDeduction; 929 Result = checkDeducedTemplateArguments(S.Context, OldPack, NewPack); 930 } 931 932 NamedDecl *Param = TemplateParams->getParam(Pack.Index); 933 if (Result.isNull()) { 934 Info.Param = makeTemplateParameter(Param); 935 Info.FirstArg = OldPack; 936 Info.SecondArg = NewPack; 937 return Sema::TDK_Inconsistent; 938 } 939 940 // If we have a pre-expanded pack and we didn't deduce enough elements 941 // for it, fail deduction. 942 if (Optional<unsigned> Expansions = getExpandedPackSize(Param)) { 943 if (*Expansions != PackElements) { 944 Info.Param = makeTemplateParameter(Param); 945 Info.FirstArg = Result; 946 return Sema::TDK_IncompletePack; 947 } 948 } 949 950 *Loc = Result; 951 } 952 953 return Sema::TDK_Success; 954 } 955 956 private: 957 Sema &S; 958 TemplateParameterList *TemplateParams; 959 SmallVectorImpl<DeducedTemplateArgument> &Deduced; 960 TemplateDeductionInfo &Info; 961 unsigned PackElements = 0; 962 bool IsPartiallyExpanded = false; 963 /// The number of expansions, if we have a fully-expanded pack in this scope. 964 Optional<unsigned> FixedNumExpansions; 965 966 SmallVector<DeducedPack, 2> Packs; 967 }; 968 969 } // namespace 970 971 /// Deduce the template arguments by comparing the list of parameter 972 /// types to the list of argument types, as in the parameter-type-lists of 973 /// function types (C++ [temp.deduct.type]p10). 974 /// 975 /// \param S The semantic analysis object within which we are deducing 976 /// 977 /// \param TemplateParams The template parameters that we are deducing 978 /// 979 /// \param Params The list of parameter types 980 /// 981 /// \param NumParams The number of types in \c Params 982 /// 983 /// \param Args The list of argument types 984 /// 985 /// \param NumArgs The number of types in \c Args 986 /// 987 /// \param Info information about the template argument deduction itself 988 /// 989 /// \param Deduced the deduced template arguments 990 /// 991 /// \param TDF bitwise OR of the TemplateDeductionFlags bits that describe 992 /// how template argument deduction is performed. 993 /// 994 /// \param PartialOrdering If true, we are performing template argument 995 /// deduction for during partial ordering for a call 996 /// (C++0x [temp.deduct.partial]). 997 /// 998 /// \returns the result of template argument deduction so far. Note that a 999 /// "success" result means that template argument deduction has not yet failed, 1000 /// but it may still fail, later, for other reasons. 1001 static Sema::TemplateDeductionResult 1002 DeduceTemplateArguments(Sema &S, 1003 TemplateParameterList *TemplateParams, 1004 const QualType *Params, unsigned NumParams, 1005 const QualType *Args, unsigned NumArgs, 1006 TemplateDeductionInfo &Info, 1007 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 1008 unsigned TDF, 1009 bool PartialOrdering = false) { 1010 // C++0x [temp.deduct.type]p10: 1011 // Similarly, if P has a form that contains (T), then each parameter type 1012 // Pi of the respective parameter-type- list of P is compared with the 1013 // corresponding parameter type Ai of the corresponding parameter-type-list 1014 // of A. [...] 1015 unsigned ArgIdx = 0, ParamIdx = 0; 1016 for (; ParamIdx != NumParams; ++ParamIdx) { 1017 // Check argument types. 1018 const PackExpansionType *Expansion 1019 = dyn_cast<PackExpansionType>(Params[ParamIdx]); 1020 if (!Expansion) { 1021 // Simple case: compare the parameter and argument types at this point. 1022 1023 // Make sure we have an argument. 1024 if (ArgIdx >= NumArgs) 1025 return Sema::TDK_MiscellaneousDeductionFailure; 1026 1027 if (isa<PackExpansionType>(Args[ArgIdx])) { 1028 // C++0x [temp.deduct.type]p22: 1029 // If the original function parameter associated with A is a function 1030 // parameter pack and the function parameter associated with P is not 1031 // a function parameter pack, then template argument deduction fails. 1032 return Sema::TDK_MiscellaneousDeductionFailure; 1033 } 1034 1035 if (Sema::TemplateDeductionResult Result = 1036 DeduceTemplateArgumentsByTypeMatch( 1037 S, TemplateParams, Params[ParamIdx].getUnqualifiedType(), 1038 Args[ArgIdx].getUnqualifiedType(), Info, Deduced, TDF, 1039 PartialOrdering, 1040 /*DeducedFromArrayBound=*/false)) 1041 return Result; 1042 1043 ++ArgIdx; 1044 continue; 1045 } 1046 1047 // C++0x [temp.deduct.type]p10: 1048 // If the parameter-declaration corresponding to Pi is a function 1049 // parameter pack, then the type of its declarator- id is compared with 1050 // each remaining parameter type in the parameter-type-list of A. Each 1051 // comparison deduces template arguments for subsequent positions in the 1052 // template parameter packs expanded by the function parameter pack. 1053 1054 QualType Pattern = Expansion->getPattern(); 1055 PackDeductionScope PackScope(S, TemplateParams, Deduced, Info, Pattern); 1056 1057 // A pack scope with fixed arity is not really a pack any more, so is not 1058 // a non-deduced context. 1059 if (ParamIdx + 1 == NumParams || PackScope.hasFixedArity()) { 1060 for (; ArgIdx < NumArgs && PackScope.hasNextElement(); ++ArgIdx) { 1061 // Deduce template arguments from the pattern. 1062 if (Sema::TemplateDeductionResult Result = 1063 DeduceTemplateArgumentsByTypeMatch( 1064 S, TemplateParams, Pattern.getUnqualifiedType(), 1065 Args[ArgIdx].getUnqualifiedType(), Info, Deduced, TDF, 1066 PartialOrdering, /*DeducedFromArrayBound=*/false)) 1067 return Result; 1068 1069 PackScope.nextPackElement(); 1070 } 1071 } else { 1072 // C++0x [temp.deduct.type]p5: 1073 // The non-deduced contexts are: 1074 // - A function parameter pack that does not occur at the end of the 1075 // parameter-declaration-clause. 1076 // 1077 // FIXME: There is no wording to say what we should do in this case. We 1078 // choose to resolve this by applying the same rule that is applied for a 1079 // function call: that is, deduce all contained packs to their 1080 // explicitly-specified values (or to <> if there is no such value). 1081 // 1082 // This is seemingly-arbitrarily different from the case of a template-id 1083 // with a non-trailing pack-expansion in its arguments, which renders the 1084 // entire template-argument-list a non-deduced context. 1085 1086 // If the parameter type contains an explicitly-specified pack that we 1087 // could not expand, skip the number of parameters notionally created 1088 // by the expansion. 1089 Optional<unsigned> NumExpansions = Expansion->getNumExpansions(); 1090 if (NumExpansions && !PackScope.isPartiallyExpanded()) { 1091 for (unsigned I = 0; I != *NumExpansions && ArgIdx < NumArgs; 1092 ++I, ++ArgIdx) 1093 PackScope.nextPackElement(); 1094 } 1095 } 1096 1097 // Build argument packs for each of the parameter packs expanded by this 1098 // pack expansion. 1099 if (auto Result = PackScope.finish()) 1100 return Result; 1101 } 1102 1103 // Make sure we don't have any extra arguments. 1104 if (ArgIdx < NumArgs) 1105 return Sema::TDK_MiscellaneousDeductionFailure; 1106 1107 return Sema::TDK_Success; 1108 } 1109 1110 /// Determine whether the parameter has qualifiers that the argument 1111 /// lacks. Put another way, determine whether there is no way to add 1112 /// a deduced set of qualifiers to the ParamType that would result in 1113 /// its qualifiers matching those of the ArgType. 1114 static bool hasInconsistentOrSupersetQualifiersOf(QualType ParamType, 1115 QualType ArgType) { 1116 Qualifiers ParamQs = ParamType.getQualifiers(); 1117 Qualifiers ArgQs = ArgType.getQualifiers(); 1118 1119 if (ParamQs == ArgQs) 1120 return false; 1121 1122 // Mismatched (but not missing) Objective-C GC attributes. 1123 if (ParamQs.getObjCGCAttr() != ArgQs.getObjCGCAttr() && 1124 ParamQs.hasObjCGCAttr()) 1125 return true; 1126 1127 // Mismatched (but not missing) address spaces. 1128 if (ParamQs.getAddressSpace() != ArgQs.getAddressSpace() && 1129 ParamQs.hasAddressSpace()) 1130 return true; 1131 1132 // Mismatched (but not missing) Objective-C lifetime qualifiers. 1133 if (ParamQs.getObjCLifetime() != ArgQs.getObjCLifetime() && 1134 ParamQs.hasObjCLifetime()) 1135 return true; 1136 1137 // CVR qualifiers inconsistent or a superset. 1138 return (ParamQs.getCVRQualifiers() & ~ArgQs.getCVRQualifiers()) != 0; 1139 } 1140 1141 /// Compare types for equality with respect to possibly compatible 1142 /// function types (noreturn adjustment, implicit calling conventions). If any 1143 /// of parameter and argument is not a function, just perform type comparison. 1144 /// 1145 /// \param P the template parameter type. 1146 /// 1147 /// \param A the argument type. 1148 bool Sema::isSameOrCompatibleFunctionType(QualType P, QualType A) { 1149 const FunctionType *PF = P->getAs<FunctionType>(), 1150 *AF = A->getAs<FunctionType>(); 1151 1152 // Just compare if not functions. 1153 if (!PF || !AF) 1154 return Context.hasSameType(P, A); 1155 1156 // Noreturn and noexcept adjustment. 1157 QualType AdjustedParam; 1158 if (IsFunctionConversion(P, A, AdjustedParam)) 1159 return Context.hasSameType(AdjustedParam, A); 1160 1161 // FIXME: Compatible calling conventions. 1162 1163 return Context.hasSameType(P, A); 1164 } 1165 1166 /// Get the index of the first template parameter that was originally from the 1167 /// innermost template-parameter-list. This is 0 except when we concatenate 1168 /// the template parameter lists of a class template and a constructor template 1169 /// when forming an implicit deduction guide. 1170 static unsigned getFirstInnerIndex(FunctionTemplateDecl *FTD) { 1171 auto *Guide = dyn_cast<CXXDeductionGuideDecl>(FTD->getTemplatedDecl()); 1172 if (!Guide || !Guide->isImplicit()) 1173 return 0; 1174 return Guide->getDeducedTemplate()->getTemplateParameters()->size(); 1175 } 1176 1177 /// Determine whether a type denotes a forwarding reference. 1178 static bool isForwardingReference(QualType Param, unsigned FirstInnerIndex) { 1179 // C++1z [temp.deduct.call]p3: 1180 // A forwarding reference is an rvalue reference to a cv-unqualified 1181 // template parameter that does not represent a template parameter of a 1182 // class template. 1183 if (auto *ParamRef = Param->getAs<RValueReferenceType>()) { 1184 if (ParamRef->getPointeeType().getQualifiers()) 1185 return false; 1186 auto *TypeParm = ParamRef->getPointeeType()->getAs<TemplateTypeParmType>(); 1187 return TypeParm && TypeParm->getIndex() >= FirstInnerIndex; 1188 } 1189 return false; 1190 } 1191 1192 static CXXRecordDecl *getCanonicalRD(QualType T) { 1193 return cast<CXXRecordDecl>( 1194 T->castAs<RecordType>()->getDecl()->getCanonicalDecl()); 1195 } 1196 1197 /// Attempt to deduce the template arguments by checking the base types 1198 /// according to (C++20 [temp.deduct.call] p4b3. 1199 /// 1200 /// \param S the semantic analysis object within which we are deducing. 1201 /// 1202 /// \param RD the top level record object we are deducing against. 1203 /// 1204 /// \param TemplateParams the template parameters that we are deducing. 1205 /// 1206 /// \param P the template specialization parameter type. 1207 /// 1208 /// \param Info information about the template argument deduction itself. 1209 /// 1210 /// \param Deduced the deduced template arguments. 1211 /// 1212 /// \returns the result of template argument deduction with the bases. "invalid" 1213 /// means no matches, "success" found a single item, and the 1214 /// "MiscellaneousDeductionFailure" result happens when the match is ambiguous. 1215 static Sema::TemplateDeductionResult 1216 DeduceTemplateBases(Sema &S, const CXXRecordDecl *RD, 1217 TemplateParameterList *TemplateParams, QualType P, 1218 TemplateDeductionInfo &Info, 1219 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 1220 // C++14 [temp.deduct.call] p4b3: 1221 // If P is a class and P has the form simple-template-id, then the 1222 // transformed A can be a derived class of the deduced A. Likewise if 1223 // P is a pointer to a class of the form simple-template-id, the 1224 // transformed A can be a pointer to a derived class pointed to by the 1225 // deduced A. However, if there is a class C that is a (direct or 1226 // indirect) base class of D and derived (directly or indirectly) from a 1227 // class B and that would be a valid deduced A, the deduced A cannot be 1228 // B or pointer to B, respectively. 1229 // 1230 // These alternatives are considered only if type deduction would 1231 // otherwise fail. If they yield more than one possible deduced A, the 1232 // type deduction fails. 1233 1234 // Use a breadth-first search through the bases to collect the set of 1235 // successful matches. Visited contains the set of nodes we have already 1236 // visited, while ToVisit is our stack of records that we still need to 1237 // visit. Matches contains a list of matches that have yet to be 1238 // disqualified. 1239 llvm::SmallPtrSet<const CXXRecordDecl *, 8> Visited; 1240 SmallVector<QualType, 8> ToVisit; 1241 // We iterate over this later, so we have to use MapVector to ensure 1242 // determinism. 1243 llvm::MapVector<const CXXRecordDecl *, 1244 SmallVector<DeducedTemplateArgument, 8>> 1245 Matches; 1246 1247 auto AddBases = [&Visited, &ToVisit](const CXXRecordDecl *RD) { 1248 for (const auto &Base : RD->bases()) { 1249 QualType T = Base.getType(); 1250 assert(T->isRecordType() && "Base class that isn't a record?"); 1251 if (Visited.insert(::getCanonicalRD(T)).second) 1252 ToVisit.push_back(T); 1253 } 1254 }; 1255 1256 // Set up the loop by adding all the bases. 1257 AddBases(RD); 1258 1259 // Search each path of bases until we either run into a successful match 1260 // (where all bases of it are invalid), or we run out of bases. 1261 while (!ToVisit.empty()) { 1262 QualType NextT = ToVisit.pop_back_val(); 1263 1264 SmallVector<DeducedTemplateArgument, 8> DeducedCopy(Deduced.begin(), 1265 Deduced.end()); 1266 TemplateDeductionInfo BaseInfo(TemplateDeductionInfo::ForBase, Info); 1267 Sema::TemplateDeductionResult BaseResult = DeduceTemplateSpecArguments( 1268 S, TemplateParams, P, NextT, BaseInfo, DeducedCopy); 1269 1270 // If this was a successful deduction, add it to the list of matches, 1271 // otherwise we need to continue searching its bases. 1272 const CXXRecordDecl *RD = ::getCanonicalRD(NextT); 1273 if (BaseResult == Sema::TDK_Success) 1274 Matches.insert({RD, DeducedCopy}); 1275 else 1276 AddBases(RD); 1277 } 1278 1279 // At this point, 'Matches' contains a list of seemingly valid bases, however 1280 // in the event that we have more than 1 match, it is possible that the base 1281 // of one of the matches might be disqualified for being a base of another 1282 // valid match. We can count on cyclical instantiations being invalid to 1283 // simplify the disqualifications. That is, if A & B are both matches, and B 1284 // inherits from A (disqualifying A), we know that A cannot inherit from B. 1285 if (Matches.size() > 1) { 1286 Visited.clear(); 1287 for (const auto &Match : Matches) 1288 AddBases(Match.first); 1289 1290 // We can give up once we have a single item (or have run out of things to 1291 // search) since cyclical inheritance isn't valid. 1292 while (Matches.size() > 1 && !ToVisit.empty()) { 1293 const CXXRecordDecl *RD = ::getCanonicalRD(ToVisit.pop_back_val()); 1294 Matches.erase(RD); 1295 1296 // Always add all bases, since the inheritance tree can contain 1297 // disqualifications for multiple matches. 1298 AddBases(RD); 1299 } 1300 } 1301 1302 if (Matches.empty()) 1303 return Sema::TDK_Invalid; 1304 if (Matches.size() > 1) 1305 return Sema::TDK_MiscellaneousDeductionFailure; 1306 1307 std::swap(Matches.front().second, Deduced); 1308 return Sema::TDK_Success; 1309 } 1310 1311 /// Deduce the template arguments by comparing the parameter type and 1312 /// the argument type (C++ [temp.deduct.type]). 1313 /// 1314 /// \param S the semantic analysis object within which we are deducing 1315 /// 1316 /// \param TemplateParams the template parameters that we are deducing 1317 /// 1318 /// \param P the parameter type 1319 /// 1320 /// \param A the argument type 1321 /// 1322 /// \param Info information about the template argument deduction itself 1323 /// 1324 /// \param Deduced the deduced template arguments 1325 /// 1326 /// \param TDF bitwise OR of the TemplateDeductionFlags bits that describe 1327 /// how template argument deduction is performed. 1328 /// 1329 /// \param PartialOrdering Whether we're performing template argument deduction 1330 /// in the context of partial ordering (C++0x [temp.deduct.partial]). 1331 /// 1332 /// \returns the result of template argument deduction so far. Note that a 1333 /// "success" result means that template argument deduction has not yet failed, 1334 /// but it may still fail, later, for other reasons. 1335 static Sema::TemplateDeductionResult DeduceTemplateArgumentsByTypeMatch( 1336 Sema &S, TemplateParameterList *TemplateParams, QualType P, QualType A, 1337 TemplateDeductionInfo &Info, 1338 SmallVectorImpl<DeducedTemplateArgument> &Deduced, unsigned TDF, 1339 bool PartialOrdering, bool DeducedFromArrayBound) { 1340 1341 // If the argument type is a pack expansion, look at its pattern. 1342 // This isn't explicitly called out 1343 if (const auto *AExp = dyn_cast<PackExpansionType>(A)) 1344 A = AExp->getPattern(); 1345 assert(!isa<PackExpansionType>(A.getCanonicalType())); 1346 1347 if (PartialOrdering) { 1348 // C++11 [temp.deduct.partial]p5: 1349 // Before the partial ordering is done, certain transformations are 1350 // performed on the types used for partial ordering: 1351 // - If P is a reference type, P is replaced by the type referred to. 1352 const ReferenceType *PRef = P->getAs<ReferenceType>(); 1353 if (PRef) 1354 P = PRef->getPointeeType(); 1355 1356 // - If A is a reference type, A is replaced by the type referred to. 1357 const ReferenceType *ARef = A->getAs<ReferenceType>(); 1358 if (ARef) 1359 A = A->getPointeeType(); 1360 1361 if (PRef && ARef && S.Context.hasSameUnqualifiedType(P, A)) { 1362 // C++11 [temp.deduct.partial]p9: 1363 // If, for a given type, deduction succeeds in both directions (i.e., 1364 // the types are identical after the transformations above) and both 1365 // P and A were reference types [...]: 1366 // - if [one type] was an lvalue reference and [the other type] was 1367 // not, [the other type] is not considered to be at least as 1368 // specialized as [the first type] 1369 // - if [one type] is more cv-qualified than [the other type], 1370 // [the other type] is not considered to be at least as specialized 1371 // as [the first type] 1372 // Objective-C ARC adds: 1373 // - [one type] has non-trivial lifetime, [the other type] has 1374 // __unsafe_unretained lifetime, and the types are otherwise 1375 // identical 1376 // 1377 // A is "considered to be at least as specialized" as P iff deduction 1378 // succeeds, so we model this as a deduction failure. Note that 1379 // [the first type] is P and [the other type] is A here; the standard 1380 // gets this backwards. 1381 Qualifiers PQuals = P.getQualifiers(), AQuals = A.getQualifiers(); 1382 if ((PRef->isLValueReferenceType() && !ARef->isLValueReferenceType()) || 1383 PQuals.isStrictSupersetOf(AQuals) || 1384 (PQuals.hasNonTrivialObjCLifetime() && 1385 AQuals.getObjCLifetime() == Qualifiers::OCL_ExplicitNone && 1386 PQuals.withoutObjCLifetime() == AQuals.withoutObjCLifetime())) { 1387 Info.FirstArg = TemplateArgument(P); 1388 Info.SecondArg = TemplateArgument(A); 1389 return Sema::TDK_NonDeducedMismatch; 1390 } 1391 } 1392 Qualifiers DiscardedQuals; 1393 // C++11 [temp.deduct.partial]p7: 1394 // Remove any top-level cv-qualifiers: 1395 // - If P is a cv-qualified type, P is replaced by the cv-unqualified 1396 // version of P. 1397 P = S.Context.getUnqualifiedArrayType(P, DiscardedQuals); 1398 // - If A is a cv-qualified type, A is replaced by the cv-unqualified 1399 // version of A. 1400 A = S.Context.getUnqualifiedArrayType(A, DiscardedQuals); 1401 } else { 1402 // C++0x [temp.deduct.call]p4 bullet 1: 1403 // - If the original P is a reference type, the deduced A (i.e., the type 1404 // referred to by the reference) can be more cv-qualified than the 1405 // transformed A. 1406 if (TDF & TDF_ParamWithReferenceType) { 1407 Qualifiers Quals; 1408 QualType UnqualP = S.Context.getUnqualifiedArrayType(P, Quals); 1409 Quals.setCVRQualifiers(Quals.getCVRQualifiers() & A.getCVRQualifiers()); 1410 P = S.Context.getQualifiedType(UnqualP, Quals); 1411 } 1412 1413 if ((TDF & TDF_TopLevelParameterTypeList) && !P->isFunctionType()) { 1414 // C++0x [temp.deduct.type]p10: 1415 // If P and A are function types that originated from deduction when 1416 // taking the address of a function template (14.8.2.2) or when deducing 1417 // template arguments from a function declaration (14.8.2.6) and Pi and 1418 // Ai are parameters of the top-level parameter-type-list of P and A, 1419 // respectively, Pi is adjusted if it is a forwarding reference and Ai 1420 // is an lvalue reference, in 1421 // which case the type of Pi is changed to be the template parameter 1422 // type (i.e., T&& is changed to simply T). [ Note: As a result, when 1423 // Pi is T&& and Ai is X&, the adjusted Pi will be T, causing T to be 1424 // deduced as X&. - end note ] 1425 TDF &= ~TDF_TopLevelParameterTypeList; 1426 if (isForwardingReference(P, /*FirstInnerIndex=*/0) && 1427 A->isLValueReferenceType()) 1428 P = P->getPointeeType(); 1429 } 1430 } 1431 1432 // C++ [temp.deduct.type]p9: 1433 // A template type argument T, a template template argument TT or a 1434 // template non-type argument i can be deduced if P and A have one of 1435 // the following forms: 1436 // 1437 // T 1438 // cv-list T 1439 if (const auto *TTP = P->getAs<TemplateTypeParmType>()) { 1440 // Just skip any attempts to deduce from a placeholder type or a parameter 1441 // at a different depth. 1442 if (A->isPlaceholderType() || Info.getDeducedDepth() != TTP->getDepth()) 1443 return Sema::TDK_Success; 1444 1445 unsigned Index = TTP->getIndex(); 1446 1447 // If the argument type is an array type, move the qualifiers up to the 1448 // top level, so they can be matched with the qualifiers on the parameter. 1449 if (A->isArrayType()) { 1450 Qualifiers Quals; 1451 A = S.Context.getUnqualifiedArrayType(A, Quals); 1452 if (Quals) 1453 A = S.Context.getQualifiedType(A, Quals); 1454 } 1455 1456 // The argument type can not be less qualified than the parameter 1457 // type. 1458 if (!(TDF & TDF_IgnoreQualifiers) && 1459 hasInconsistentOrSupersetQualifiersOf(P, A)) { 1460 Info.Param = cast<TemplateTypeParmDecl>(TemplateParams->getParam(Index)); 1461 Info.FirstArg = TemplateArgument(P); 1462 Info.SecondArg = TemplateArgument(A); 1463 return Sema::TDK_Underqualified; 1464 } 1465 1466 // Do not match a function type with a cv-qualified type. 1467 // http://www.open-std.org/jtc1/sc22/wg21/docs/cwg_active.html#1584 1468 if (A->isFunctionType() && P.hasQualifiers()) 1469 return Sema::TDK_NonDeducedMismatch; 1470 1471 assert(TTP->getDepth() == Info.getDeducedDepth() && 1472 "saw template type parameter with wrong depth"); 1473 assert(A->getCanonicalTypeInternal() != S.Context.OverloadTy && 1474 "Unresolved overloaded function"); 1475 QualType DeducedType = A; 1476 1477 // Remove any qualifiers on the parameter from the deduced type. 1478 // We checked the qualifiers for consistency above. 1479 Qualifiers DeducedQs = DeducedType.getQualifiers(); 1480 Qualifiers ParamQs = P.getQualifiers(); 1481 DeducedQs.removeCVRQualifiers(ParamQs.getCVRQualifiers()); 1482 if (ParamQs.hasObjCGCAttr()) 1483 DeducedQs.removeObjCGCAttr(); 1484 if (ParamQs.hasAddressSpace()) 1485 DeducedQs.removeAddressSpace(); 1486 if (ParamQs.hasObjCLifetime()) 1487 DeducedQs.removeObjCLifetime(); 1488 1489 // Objective-C ARC: 1490 // If template deduction would produce a lifetime qualifier on a type 1491 // that is not a lifetime type, template argument deduction fails. 1492 if (ParamQs.hasObjCLifetime() && !DeducedType->isObjCLifetimeType() && 1493 !DeducedType->isDependentType()) { 1494 Info.Param = cast<TemplateTypeParmDecl>(TemplateParams->getParam(Index)); 1495 Info.FirstArg = TemplateArgument(P); 1496 Info.SecondArg = TemplateArgument(A); 1497 return Sema::TDK_Underqualified; 1498 } 1499 1500 // Objective-C ARC: 1501 // If template deduction would produce an argument type with lifetime type 1502 // but no lifetime qualifier, the __strong lifetime qualifier is inferred. 1503 if (S.getLangOpts().ObjCAutoRefCount && DeducedType->isObjCLifetimeType() && 1504 !DeducedQs.hasObjCLifetime()) 1505 DeducedQs.setObjCLifetime(Qualifiers::OCL_Strong); 1506 1507 DeducedType = 1508 S.Context.getQualifiedType(DeducedType.getUnqualifiedType(), DeducedQs); 1509 1510 DeducedTemplateArgument NewDeduced(DeducedType, DeducedFromArrayBound); 1511 DeducedTemplateArgument Result = 1512 checkDeducedTemplateArguments(S.Context, Deduced[Index], NewDeduced); 1513 if (Result.isNull()) { 1514 Info.Param = cast<TemplateTypeParmDecl>(TemplateParams->getParam(Index)); 1515 Info.FirstArg = Deduced[Index]; 1516 Info.SecondArg = NewDeduced; 1517 return Sema::TDK_Inconsistent; 1518 } 1519 1520 Deduced[Index] = Result; 1521 return Sema::TDK_Success; 1522 } 1523 1524 // Set up the template argument deduction information for a failure. 1525 Info.FirstArg = TemplateArgument(P); 1526 Info.SecondArg = TemplateArgument(A); 1527 1528 // If the parameter is an already-substituted template parameter 1529 // pack, do nothing: we don't know which of its arguments to look 1530 // at, so we have to wait until all of the parameter packs in this 1531 // expansion have arguments. 1532 if (P->getAs<SubstTemplateTypeParmPackType>()) 1533 return Sema::TDK_Success; 1534 1535 // Check the cv-qualifiers on the parameter and argument types. 1536 if (!(TDF & TDF_IgnoreQualifiers)) { 1537 if (TDF & TDF_ParamWithReferenceType) { 1538 if (hasInconsistentOrSupersetQualifiersOf(P, A)) 1539 return Sema::TDK_NonDeducedMismatch; 1540 } else if (TDF & TDF_ArgWithReferenceType) { 1541 // C++ [temp.deduct.conv]p4: 1542 // If the original A is a reference type, A can be more cv-qualified 1543 // than the deduced A 1544 if (!A.getQualifiers().compatiblyIncludes(P.getQualifiers())) 1545 return Sema::TDK_NonDeducedMismatch; 1546 1547 // Strip out all extra qualifiers from the argument to figure out the 1548 // type we're converting to, prior to the qualification conversion. 1549 Qualifiers Quals; 1550 A = S.Context.getUnqualifiedArrayType(A, Quals); 1551 A = S.Context.getQualifiedType(A, P.getQualifiers()); 1552 } else if (!IsPossiblyOpaquelyQualifiedType(P)) { 1553 if (P.getCVRQualifiers() != A.getCVRQualifiers()) 1554 return Sema::TDK_NonDeducedMismatch; 1555 } 1556 } 1557 1558 // If the parameter type is not dependent, there is nothing to deduce. 1559 if (!P->isDependentType()) { 1560 if (TDF & TDF_SkipNonDependent) 1561 return Sema::TDK_Success; 1562 if ((TDF & TDF_IgnoreQualifiers) ? S.Context.hasSameUnqualifiedType(P, A) 1563 : S.Context.hasSameType(P, A)) 1564 return Sema::TDK_Success; 1565 if (TDF & TDF_AllowCompatibleFunctionType && 1566 S.isSameOrCompatibleFunctionType(P, A)) 1567 return Sema::TDK_Success; 1568 if (!(TDF & TDF_IgnoreQualifiers)) 1569 return Sema::TDK_NonDeducedMismatch; 1570 // Otherwise, when ignoring qualifiers, the types not having the same 1571 // unqualified type does not mean they do not match, so in this case we 1572 // must keep going and analyze with a non-dependent parameter type. 1573 } 1574 1575 switch (P.getCanonicalType()->getTypeClass()) { 1576 // Non-canonical types cannot appear here. 1577 #define NON_CANONICAL_TYPE(Class, Base) \ 1578 case Type::Class: llvm_unreachable("deducing non-canonical type: " #Class); 1579 #define TYPE(Class, Base) 1580 #include "clang/AST/TypeNodes.inc" 1581 1582 case Type::TemplateTypeParm: 1583 case Type::SubstTemplateTypeParmPack: 1584 llvm_unreachable("Type nodes handled above"); 1585 1586 case Type::Auto: 1587 // FIXME: Implement deduction in dependent case. 1588 if (P->isDependentType()) 1589 return Sema::TDK_Success; 1590 LLVM_FALLTHROUGH; 1591 case Type::Builtin: 1592 case Type::VariableArray: 1593 case Type::Vector: 1594 case Type::FunctionNoProto: 1595 case Type::Record: 1596 case Type::Enum: 1597 case Type::ObjCObject: 1598 case Type::ObjCInterface: 1599 case Type::ObjCObjectPointer: 1600 case Type::BitInt: 1601 return (TDF & TDF_SkipNonDependent) || 1602 ((TDF & TDF_IgnoreQualifiers) 1603 ? S.Context.hasSameUnqualifiedType(P, A) 1604 : S.Context.hasSameType(P, A)) 1605 ? Sema::TDK_Success 1606 : Sema::TDK_NonDeducedMismatch; 1607 1608 // _Complex T [placeholder extension] 1609 case Type::Complex: { 1610 const auto *CP = P->castAs<ComplexType>(), *CA = A->getAs<ComplexType>(); 1611 if (!CA) 1612 return Sema::TDK_NonDeducedMismatch; 1613 return DeduceTemplateArgumentsByTypeMatch( 1614 S, TemplateParams, CP->getElementType(), CA->getElementType(), Info, 1615 Deduced, TDF); 1616 } 1617 1618 // _Atomic T [extension] 1619 case Type::Atomic: { 1620 const auto *PA = P->castAs<AtomicType>(), *AA = A->getAs<AtomicType>(); 1621 if (!AA) 1622 return Sema::TDK_NonDeducedMismatch; 1623 return DeduceTemplateArgumentsByTypeMatch( 1624 S, TemplateParams, PA->getValueType(), AA->getValueType(), Info, 1625 Deduced, TDF); 1626 } 1627 1628 // T * 1629 case Type::Pointer: { 1630 QualType PointeeType; 1631 if (const auto *PA = A->getAs<PointerType>()) { 1632 PointeeType = PA->getPointeeType(); 1633 } else if (const auto *PA = A->getAs<ObjCObjectPointerType>()) { 1634 PointeeType = PA->getPointeeType(); 1635 } else { 1636 return Sema::TDK_NonDeducedMismatch; 1637 } 1638 return DeduceTemplateArgumentsByTypeMatch( 1639 S, TemplateParams, P->castAs<PointerType>()->getPointeeType(), 1640 PointeeType, Info, Deduced, 1641 TDF & (TDF_IgnoreQualifiers | TDF_DerivedClass)); 1642 } 1643 1644 // T & 1645 case Type::LValueReference: { 1646 const auto *RP = P->castAs<LValueReferenceType>(), 1647 *RA = A->getAs<LValueReferenceType>(); 1648 if (!RA) 1649 return Sema::TDK_NonDeducedMismatch; 1650 1651 return DeduceTemplateArgumentsByTypeMatch( 1652 S, TemplateParams, RP->getPointeeType(), RA->getPointeeType(), Info, 1653 Deduced, 0); 1654 } 1655 1656 // T && [C++0x] 1657 case Type::RValueReference: { 1658 const auto *RP = P->castAs<RValueReferenceType>(), 1659 *RA = A->getAs<RValueReferenceType>(); 1660 if (!RA) 1661 return Sema::TDK_NonDeducedMismatch; 1662 1663 return DeduceTemplateArgumentsByTypeMatch( 1664 S, TemplateParams, RP->getPointeeType(), RA->getPointeeType(), Info, 1665 Deduced, 0); 1666 } 1667 1668 // T [] (implied, but not stated explicitly) 1669 case Type::IncompleteArray: { 1670 const auto *IAA = S.Context.getAsIncompleteArrayType(A); 1671 if (!IAA) 1672 return Sema::TDK_NonDeducedMismatch; 1673 1674 return DeduceTemplateArgumentsByTypeMatch( 1675 S, TemplateParams, 1676 S.Context.getAsIncompleteArrayType(P)->getElementType(), 1677 IAA->getElementType(), Info, Deduced, TDF & TDF_IgnoreQualifiers); 1678 } 1679 1680 // T [integer-constant] 1681 case Type::ConstantArray: { 1682 const auto *CAA = S.Context.getAsConstantArrayType(A), 1683 *CAP = S.Context.getAsConstantArrayType(P); 1684 assert(CAP); 1685 if (!CAA || CAA->getSize() != CAP->getSize()) 1686 return Sema::TDK_NonDeducedMismatch; 1687 1688 return DeduceTemplateArgumentsByTypeMatch( 1689 S, TemplateParams, CAP->getElementType(), CAA->getElementType(), Info, 1690 Deduced, TDF & TDF_IgnoreQualifiers); 1691 } 1692 1693 // type [i] 1694 case Type::DependentSizedArray: { 1695 const auto *AA = S.Context.getAsArrayType(A); 1696 if (!AA) 1697 return Sema::TDK_NonDeducedMismatch; 1698 1699 // Check the element type of the arrays 1700 const auto *DAP = S.Context.getAsDependentSizedArrayType(P); 1701 assert(DAP); 1702 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1703 S, TemplateParams, DAP->getElementType(), AA->getElementType(), 1704 Info, Deduced, TDF & TDF_IgnoreQualifiers)) 1705 return Result; 1706 1707 // Determine the array bound is something we can deduce. 1708 const NonTypeTemplateParmDecl *NTTP = 1709 getDeducedParameterFromExpr(Info, DAP->getSizeExpr()); 1710 if (!NTTP) 1711 return Sema::TDK_Success; 1712 1713 // We can perform template argument deduction for the given non-type 1714 // template parameter. 1715 assert(NTTP->getDepth() == Info.getDeducedDepth() && 1716 "saw non-type template parameter with wrong depth"); 1717 if (const auto *CAA = dyn_cast<ConstantArrayType>(AA)) { 1718 llvm::APSInt Size(CAA->getSize()); 1719 return DeduceNonTypeTemplateArgument( 1720 S, TemplateParams, NTTP, Size, S.Context.getSizeType(), 1721 /*ArrayBound=*/true, Info, Deduced); 1722 } 1723 if (const auto *DAA = dyn_cast<DependentSizedArrayType>(AA)) 1724 if (DAA->getSizeExpr()) 1725 return DeduceNonTypeTemplateArgument( 1726 S, TemplateParams, NTTP, DAA->getSizeExpr(), Info, Deduced); 1727 1728 // Incomplete type does not match a dependently-sized array type 1729 return Sema::TDK_NonDeducedMismatch; 1730 } 1731 1732 // type(*)(T) 1733 // T(*)() 1734 // T(*)(T) 1735 case Type::FunctionProto: { 1736 const auto *FPP = P->castAs<FunctionProtoType>(), 1737 *FPA = A->getAs<FunctionProtoType>(); 1738 if (!FPA) 1739 return Sema::TDK_NonDeducedMismatch; 1740 1741 if (FPP->getMethodQuals() != FPA->getMethodQuals() || 1742 FPP->getRefQualifier() != FPA->getRefQualifier() || 1743 FPP->isVariadic() != FPA->isVariadic()) 1744 return Sema::TDK_NonDeducedMismatch; 1745 1746 // Check return types. 1747 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1748 S, TemplateParams, FPP->getReturnType(), FPA->getReturnType(), 1749 Info, Deduced, 0, 1750 /*PartialOrdering=*/false, 1751 /*DeducedFromArrayBound=*/false)) 1752 return Result; 1753 1754 // Check parameter types. 1755 if (auto Result = DeduceTemplateArguments( 1756 S, TemplateParams, FPP->param_type_begin(), FPP->getNumParams(), 1757 FPA->param_type_begin(), FPA->getNumParams(), Info, Deduced, 1758 TDF & TDF_TopLevelParameterTypeList)) 1759 return Result; 1760 1761 if (TDF & TDF_AllowCompatibleFunctionType) 1762 return Sema::TDK_Success; 1763 1764 // FIXME: Per core-2016/10/1019 (no corresponding core issue yet), permit 1765 // deducing through the noexcept-specifier if it's part of the canonical 1766 // type. libstdc++ relies on this. 1767 Expr *NoexceptExpr = FPP->getNoexceptExpr(); 1768 if (const NonTypeTemplateParmDecl *NTTP = 1769 NoexceptExpr ? getDeducedParameterFromExpr(Info, NoexceptExpr) 1770 : nullptr) { 1771 assert(NTTP->getDepth() == Info.getDeducedDepth() && 1772 "saw non-type template parameter with wrong depth"); 1773 1774 llvm::APSInt Noexcept(1); 1775 switch (FPA->canThrow()) { 1776 case CT_Cannot: 1777 Noexcept = 1; 1778 LLVM_FALLTHROUGH; 1779 1780 case CT_Can: 1781 // We give E in noexcept(E) the "deduced from array bound" treatment. 1782 // FIXME: Should we? 1783 return DeduceNonTypeTemplateArgument( 1784 S, TemplateParams, NTTP, Noexcept, S.Context.BoolTy, 1785 /*DeducedFromArrayBound=*/true, Info, Deduced); 1786 1787 case CT_Dependent: 1788 if (Expr *ArgNoexceptExpr = FPA->getNoexceptExpr()) 1789 return DeduceNonTypeTemplateArgument( 1790 S, TemplateParams, NTTP, ArgNoexceptExpr, Info, Deduced); 1791 // Can't deduce anything from throw(T...). 1792 break; 1793 } 1794 } 1795 // FIXME: Detect non-deduced exception specification mismatches? 1796 // 1797 // Careful about [temp.deduct.call] and [temp.deduct.conv], which allow 1798 // top-level differences in noexcept-specifications. 1799 1800 return Sema::TDK_Success; 1801 } 1802 1803 case Type::InjectedClassName: 1804 // Treat a template's injected-class-name as if the template 1805 // specialization type had been used. 1806 1807 // template-name<T> (where template-name refers to a class template) 1808 // template-name<i> 1809 // TT<T> 1810 // TT<i> 1811 // TT<> 1812 case Type::TemplateSpecialization: { 1813 // When Arg cannot be a derived class, we can just try to deduce template 1814 // arguments from the template-id. 1815 if (!(TDF & TDF_DerivedClass) || !A->isRecordType()) 1816 return DeduceTemplateSpecArguments(S, TemplateParams, P, A, Info, 1817 Deduced); 1818 1819 SmallVector<DeducedTemplateArgument, 8> DeducedOrig(Deduced.begin(), 1820 Deduced.end()); 1821 1822 auto Result = 1823 DeduceTemplateSpecArguments(S, TemplateParams, P, A, Info, Deduced); 1824 if (Result == Sema::TDK_Success) 1825 return Result; 1826 1827 // We cannot inspect base classes as part of deduction when the type 1828 // is incomplete, so either instantiate any templates necessary to 1829 // complete the type, or skip over it if it cannot be completed. 1830 if (!S.isCompleteType(Info.getLocation(), A)) 1831 return Result; 1832 1833 // Reset the incorrectly deduced argument from above. 1834 Deduced = DeducedOrig; 1835 1836 // Check bases according to C++14 [temp.deduct.call] p4b3: 1837 auto BaseResult = DeduceTemplateBases(S, getCanonicalRD(A), 1838 TemplateParams, P, Info, Deduced); 1839 return BaseResult != Sema::TDK_Invalid ? BaseResult : Result; 1840 } 1841 1842 // T type::* 1843 // T T::* 1844 // T (type::*)() 1845 // type (T::*)() 1846 // type (type::*)(T) 1847 // type (T::*)(T) 1848 // T (type::*)(T) 1849 // T (T::*)() 1850 // T (T::*)(T) 1851 case Type::MemberPointer: { 1852 const auto *MPP = P->castAs<MemberPointerType>(), 1853 *MPA = A->getAs<MemberPointerType>(); 1854 if (!MPA) 1855 return Sema::TDK_NonDeducedMismatch; 1856 1857 QualType PPT = MPP->getPointeeType(); 1858 if (PPT->isFunctionType()) 1859 S.adjustMemberFunctionCC(PPT, /*IsStatic=*/true, 1860 /*IsCtorOrDtor=*/false, Info.getLocation()); 1861 QualType APT = MPA->getPointeeType(); 1862 if (APT->isFunctionType()) 1863 S.adjustMemberFunctionCC(APT, /*IsStatic=*/true, 1864 /*IsCtorOrDtor=*/false, Info.getLocation()); 1865 1866 unsigned SubTDF = TDF & TDF_IgnoreQualifiers; 1867 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1868 S, TemplateParams, PPT, APT, Info, Deduced, SubTDF)) 1869 return Result; 1870 return DeduceTemplateArgumentsByTypeMatch( 1871 S, TemplateParams, QualType(MPP->getClass(), 0), 1872 QualType(MPA->getClass(), 0), Info, Deduced, SubTDF); 1873 } 1874 1875 // (clang extension) 1876 // 1877 // type(^)(T) 1878 // T(^)() 1879 // T(^)(T) 1880 case Type::BlockPointer: { 1881 const auto *BPP = P->castAs<BlockPointerType>(), 1882 *BPA = A->getAs<BlockPointerType>(); 1883 if (!BPA) 1884 return Sema::TDK_NonDeducedMismatch; 1885 return DeduceTemplateArgumentsByTypeMatch( 1886 S, TemplateParams, BPP->getPointeeType(), BPA->getPointeeType(), Info, 1887 Deduced, 0); 1888 } 1889 1890 // (clang extension) 1891 // 1892 // T __attribute__(((ext_vector_type(<integral constant>)))) 1893 case Type::ExtVector: { 1894 const auto *VP = P->castAs<ExtVectorType>(); 1895 QualType ElementType; 1896 if (const auto *VA = A->getAs<ExtVectorType>()) { 1897 // Make sure that the vectors have the same number of elements. 1898 if (VP->getNumElements() != VA->getNumElements()) 1899 return Sema::TDK_NonDeducedMismatch; 1900 ElementType = VA->getElementType(); 1901 } else if (const auto *VA = A->getAs<DependentSizedExtVectorType>()) { 1902 // We can't check the number of elements, since the argument has a 1903 // dependent number of elements. This can only occur during partial 1904 // ordering. 1905 ElementType = VA->getElementType(); 1906 } else { 1907 return Sema::TDK_NonDeducedMismatch; 1908 } 1909 // Perform deduction on the element types. 1910 return DeduceTemplateArgumentsByTypeMatch( 1911 S, TemplateParams, VP->getElementType(), ElementType, Info, Deduced, 1912 TDF); 1913 } 1914 1915 case Type::DependentVector: { 1916 const auto *VP = P->castAs<DependentVectorType>(); 1917 1918 if (const auto *VA = A->getAs<VectorType>()) { 1919 // Perform deduction on the element types. 1920 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1921 S, TemplateParams, VP->getElementType(), VA->getElementType(), 1922 Info, Deduced, TDF)) 1923 return Result; 1924 1925 // Perform deduction on the vector size, if we can. 1926 const NonTypeTemplateParmDecl *NTTP = 1927 getDeducedParameterFromExpr(Info, VP->getSizeExpr()); 1928 if (!NTTP) 1929 return Sema::TDK_Success; 1930 1931 llvm::APSInt ArgSize(S.Context.getTypeSize(S.Context.IntTy), false); 1932 ArgSize = VA->getNumElements(); 1933 // Note that we use the "array bound" rules here; just like in that 1934 // case, we don't have any particular type for the vector size, but 1935 // we can provide one if necessary. 1936 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, ArgSize, 1937 S.Context.UnsignedIntTy, true, 1938 Info, Deduced); 1939 } 1940 1941 if (const auto *VA = A->getAs<DependentVectorType>()) { 1942 // Perform deduction on the element types. 1943 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1944 S, TemplateParams, VP->getElementType(), VA->getElementType(), 1945 Info, Deduced, TDF)) 1946 return Result; 1947 1948 // Perform deduction on the vector size, if we can. 1949 const NonTypeTemplateParmDecl *NTTP = 1950 getDeducedParameterFromExpr(Info, VP->getSizeExpr()); 1951 if (!NTTP) 1952 return Sema::TDK_Success; 1953 1954 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 1955 VA->getSizeExpr(), Info, Deduced); 1956 } 1957 1958 return Sema::TDK_NonDeducedMismatch; 1959 } 1960 1961 // (clang extension) 1962 // 1963 // T __attribute__(((ext_vector_type(N)))) 1964 case Type::DependentSizedExtVector: { 1965 const auto *VP = P->castAs<DependentSizedExtVectorType>(); 1966 1967 if (const auto *VA = A->getAs<ExtVectorType>()) { 1968 // Perform deduction on the element types. 1969 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1970 S, TemplateParams, VP->getElementType(), VA->getElementType(), 1971 Info, Deduced, TDF)) 1972 return Result; 1973 1974 // Perform deduction on the vector size, if we can. 1975 const NonTypeTemplateParmDecl *NTTP = 1976 getDeducedParameterFromExpr(Info, VP->getSizeExpr()); 1977 if (!NTTP) 1978 return Sema::TDK_Success; 1979 1980 llvm::APSInt ArgSize(S.Context.getTypeSize(S.Context.IntTy), false); 1981 ArgSize = VA->getNumElements(); 1982 // Note that we use the "array bound" rules here; just like in that 1983 // case, we don't have any particular type for the vector size, but 1984 // we can provide one if necessary. 1985 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, ArgSize, 1986 S.Context.IntTy, true, Info, 1987 Deduced); 1988 } 1989 1990 if (const auto *VA = A->getAs<DependentSizedExtVectorType>()) { 1991 // Perform deduction on the element types. 1992 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 1993 S, TemplateParams, VP->getElementType(), VA->getElementType(), 1994 Info, Deduced, TDF)) 1995 return Result; 1996 1997 // Perform deduction on the vector size, if we can. 1998 const NonTypeTemplateParmDecl *NTTP = 1999 getDeducedParameterFromExpr(Info, VP->getSizeExpr()); 2000 if (!NTTP) 2001 return Sema::TDK_Success; 2002 2003 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 2004 VA->getSizeExpr(), Info, Deduced); 2005 } 2006 2007 return Sema::TDK_NonDeducedMismatch; 2008 } 2009 2010 // (clang extension) 2011 // 2012 // T __attribute__((matrix_type(<integral constant>, 2013 // <integral constant>))) 2014 case Type::ConstantMatrix: { 2015 const auto *MP = P->castAs<ConstantMatrixType>(), 2016 *MA = A->getAs<ConstantMatrixType>(); 2017 if (!MA) 2018 return Sema::TDK_NonDeducedMismatch; 2019 2020 // Check that the dimensions are the same 2021 if (MP->getNumRows() != MA->getNumRows() || 2022 MP->getNumColumns() != MA->getNumColumns()) { 2023 return Sema::TDK_NonDeducedMismatch; 2024 } 2025 // Perform deduction on element types. 2026 return DeduceTemplateArgumentsByTypeMatch( 2027 S, TemplateParams, MP->getElementType(), MA->getElementType(), Info, 2028 Deduced, TDF); 2029 } 2030 2031 case Type::DependentSizedMatrix: { 2032 const auto *MP = P->castAs<DependentSizedMatrixType>(); 2033 const auto *MA = A->getAs<MatrixType>(); 2034 if (!MA) 2035 return Sema::TDK_NonDeducedMismatch; 2036 2037 // Check the element type of the matrixes. 2038 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 2039 S, TemplateParams, MP->getElementType(), MA->getElementType(), 2040 Info, Deduced, TDF)) 2041 return Result; 2042 2043 // Try to deduce a matrix dimension. 2044 auto DeduceMatrixArg = 2045 [&S, &Info, &Deduced, &TemplateParams]( 2046 Expr *ParamExpr, const MatrixType *A, 2047 unsigned (ConstantMatrixType::*GetArgDimension)() const, 2048 Expr *(DependentSizedMatrixType::*GetArgDimensionExpr)() const) { 2049 const auto *ACM = dyn_cast<ConstantMatrixType>(A); 2050 const auto *ADM = dyn_cast<DependentSizedMatrixType>(A); 2051 if (!ParamExpr->isValueDependent()) { 2052 Optional<llvm::APSInt> ParamConst = 2053 ParamExpr->getIntegerConstantExpr(S.Context); 2054 if (!ParamConst) 2055 return Sema::TDK_NonDeducedMismatch; 2056 2057 if (ACM) { 2058 if ((ACM->*GetArgDimension)() == *ParamConst) 2059 return Sema::TDK_Success; 2060 return Sema::TDK_NonDeducedMismatch; 2061 } 2062 2063 Expr *ArgExpr = (ADM->*GetArgDimensionExpr)(); 2064 if (Optional<llvm::APSInt> ArgConst = 2065 ArgExpr->getIntegerConstantExpr(S.Context)) 2066 if (*ArgConst == *ParamConst) 2067 return Sema::TDK_Success; 2068 return Sema::TDK_NonDeducedMismatch; 2069 } 2070 2071 const NonTypeTemplateParmDecl *NTTP = 2072 getDeducedParameterFromExpr(Info, ParamExpr); 2073 if (!NTTP) 2074 return Sema::TDK_Success; 2075 2076 if (ACM) { 2077 llvm::APSInt ArgConst( 2078 S.Context.getTypeSize(S.Context.getSizeType())); 2079 ArgConst = (ACM->*GetArgDimension)(); 2080 return DeduceNonTypeTemplateArgument( 2081 S, TemplateParams, NTTP, ArgConst, S.Context.getSizeType(), 2082 /*ArrayBound=*/true, Info, Deduced); 2083 } 2084 2085 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 2086 (ADM->*GetArgDimensionExpr)(), 2087 Info, Deduced); 2088 }; 2089 2090 if (auto Result = DeduceMatrixArg(MP->getRowExpr(), MA, 2091 &ConstantMatrixType::getNumRows, 2092 &DependentSizedMatrixType::getRowExpr)) 2093 return Result; 2094 2095 return DeduceMatrixArg(MP->getColumnExpr(), MA, 2096 &ConstantMatrixType::getNumColumns, 2097 &DependentSizedMatrixType::getColumnExpr); 2098 } 2099 2100 // (clang extension) 2101 // 2102 // T __attribute__(((address_space(N)))) 2103 case Type::DependentAddressSpace: { 2104 const auto *ASP = P->castAs<DependentAddressSpaceType>(); 2105 2106 if (const auto *ASA = A->getAs<DependentAddressSpaceType>()) { 2107 // Perform deduction on the pointer type. 2108 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 2109 S, TemplateParams, ASP->getPointeeType(), ASA->getPointeeType(), 2110 Info, Deduced, TDF)) 2111 return Result; 2112 2113 // Perform deduction on the address space, if we can. 2114 const NonTypeTemplateParmDecl *NTTP = 2115 getDeducedParameterFromExpr(Info, ASP->getAddrSpaceExpr()); 2116 if (!NTTP) 2117 return Sema::TDK_Success; 2118 2119 return DeduceNonTypeTemplateArgument( 2120 S, TemplateParams, NTTP, ASA->getAddrSpaceExpr(), Info, Deduced); 2121 } 2122 2123 if (isTargetAddressSpace(A.getAddressSpace())) { 2124 llvm::APSInt ArgAddressSpace(S.Context.getTypeSize(S.Context.IntTy), 2125 false); 2126 ArgAddressSpace = toTargetAddressSpace(A.getAddressSpace()); 2127 2128 // Perform deduction on the pointer types. 2129 if (auto Result = DeduceTemplateArgumentsByTypeMatch( 2130 S, TemplateParams, ASP->getPointeeType(), 2131 S.Context.removeAddrSpaceQualType(A), Info, Deduced, TDF)) 2132 return Result; 2133 2134 // Perform deduction on the address space, if we can. 2135 const NonTypeTemplateParmDecl *NTTP = 2136 getDeducedParameterFromExpr(Info, ASP->getAddrSpaceExpr()); 2137 if (!NTTP) 2138 return Sema::TDK_Success; 2139 2140 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 2141 ArgAddressSpace, S.Context.IntTy, 2142 true, Info, Deduced); 2143 } 2144 2145 return Sema::TDK_NonDeducedMismatch; 2146 } 2147 case Type::DependentBitInt: { 2148 const auto *IP = P->castAs<DependentBitIntType>(); 2149 2150 if (const auto *IA = A->getAs<BitIntType>()) { 2151 if (IP->isUnsigned() != IA->isUnsigned()) 2152 return Sema::TDK_NonDeducedMismatch; 2153 2154 const NonTypeTemplateParmDecl *NTTP = 2155 getDeducedParameterFromExpr(Info, IP->getNumBitsExpr()); 2156 if (!NTTP) 2157 return Sema::TDK_Success; 2158 2159 llvm::APSInt ArgSize(S.Context.getTypeSize(S.Context.IntTy), false); 2160 ArgSize = IA->getNumBits(); 2161 2162 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, ArgSize, 2163 S.Context.IntTy, true, Info, 2164 Deduced); 2165 } 2166 2167 if (const auto *IA = A->getAs<DependentBitIntType>()) { 2168 if (IP->isUnsigned() != IA->isUnsigned()) 2169 return Sema::TDK_NonDeducedMismatch; 2170 return Sema::TDK_Success; 2171 } 2172 2173 return Sema::TDK_NonDeducedMismatch; 2174 } 2175 2176 case Type::TypeOfExpr: 2177 case Type::TypeOf: 2178 case Type::DependentName: 2179 case Type::UnresolvedUsing: 2180 case Type::Decltype: 2181 case Type::UnaryTransform: 2182 case Type::DeducedTemplateSpecialization: 2183 case Type::DependentTemplateSpecialization: 2184 case Type::PackExpansion: 2185 case Type::Pipe: 2186 // No template argument deduction for these types 2187 return Sema::TDK_Success; 2188 } 2189 2190 llvm_unreachable("Invalid Type Class!"); 2191 } 2192 2193 static Sema::TemplateDeductionResult 2194 DeduceTemplateArguments(Sema &S, TemplateParameterList *TemplateParams, 2195 const TemplateArgument &P, TemplateArgument A, 2196 TemplateDeductionInfo &Info, 2197 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 2198 // If the template argument is a pack expansion, perform template argument 2199 // deduction against the pattern of that expansion. This only occurs during 2200 // partial ordering. 2201 if (A.isPackExpansion()) 2202 A = A.getPackExpansionPattern(); 2203 2204 switch (P.getKind()) { 2205 case TemplateArgument::Null: 2206 llvm_unreachable("Null template argument in parameter list"); 2207 2208 case TemplateArgument::Type: 2209 if (A.getKind() == TemplateArgument::Type) 2210 return DeduceTemplateArgumentsByTypeMatch( 2211 S, TemplateParams, P.getAsType(), A.getAsType(), Info, Deduced, 0); 2212 Info.FirstArg = P; 2213 Info.SecondArg = A; 2214 return Sema::TDK_NonDeducedMismatch; 2215 2216 case TemplateArgument::Template: 2217 if (A.getKind() == TemplateArgument::Template) 2218 return DeduceTemplateArguments(S, TemplateParams, P.getAsTemplate(), 2219 A.getAsTemplate(), Info, Deduced); 2220 Info.FirstArg = P; 2221 Info.SecondArg = A; 2222 return Sema::TDK_NonDeducedMismatch; 2223 2224 case TemplateArgument::TemplateExpansion: 2225 llvm_unreachable("caller should handle pack expansions"); 2226 2227 case TemplateArgument::Declaration: 2228 if (A.getKind() == TemplateArgument::Declaration && 2229 isSameDeclaration(P.getAsDecl(), A.getAsDecl())) 2230 return Sema::TDK_Success; 2231 2232 Info.FirstArg = P; 2233 Info.SecondArg = A; 2234 return Sema::TDK_NonDeducedMismatch; 2235 2236 case TemplateArgument::NullPtr: 2237 if (A.getKind() == TemplateArgument::NullPtr && 2238 S.Context.hasSameType(P.getNullPtrType(), A.getNullPtrType())) 2239 return Sema::TDK_Success; 2240 2241 Info.FirstArg = P; 2242 Info.SecondArg = A; 2243 return Sema::TDK_NonDeducedMismatch; 2244 2245 case TemplateArgument::Integral: 2246 if (A.getKind() == TemplateArgument::Integral) { 2247 if (hasSameExtendedValue(P.getAsIntegral(), A.getAsIntegral())) 2248 return Sema::TDK_Success; 2249 } 2250 Info.FirstArg = P; 2251 Info.SecondArg = A; 2252 return Sema::TDK_NonDeducedMismatch; 2253 2254 case TemplateArgument::Expression: 2255 if (const NonTypeTemplateParmDecl *NTTP = 2256 getDeducedParameterFromExpr(Info, P.getAsExpr())) { 2257 if (A.getKind() == TemplateArgument::Integral) 2258 return DeduceNonTypeTemplateArgument( 2259 S, TemplateParams, NTTP, A.getAsIntegral(), A.getIntegralType(), 2260 /*ArrayBound=*/false, Info, Deduced); 2261 if (A.getKind() == TemplateArgument::NullPtr) 2262 return DeduceNullPtrTemplateArgument(S, TemplateParams, NTTP, 2263 A.getNullPtrType(), Info, Deduced); 2264 if (A.getKind() == TemplateArgument::Expression) 2265 return DeduceNonTypeTemplateArgument(S, TemplateParams, NTTP, 2266 A.getAsExpr(), Info, Deduced); 2267 if (A.getKind() == TemplateArgument::Declaration) 2268 return DeduceNonTypeTemplateArgument( 2269 S, TemplateParams, NTTP, A.getAsDecl(), A.getParamTypeForDecl(), 2270 Info, Deduced); 2271 2272 Info.FirstArg = P; 2273 Info.SecondArg = A; 2274 return Sema::TDK_NonDeducedMismatch; 2275 } 2276 2277 // Can't deduce anything, but that's okay. 2278 return Sema::TDK_Success; 2279 case TemplateArgument::Pack: 2280 llvm_unreachable("Argument packs should be expanded by the caller!"); 2281 } 2282 2283 llvm_unreachable("Invalid TemplateArgument Kind!"); 2284 } 2285 2286 /// Determine whether there is a template argument to be used for 2287 /// deduction. 2288 /// 2289 /// This routine "expands" argument packs in-place, overriding its input 2290 /// parameters so that \c Args[ArgIdx] will be the available template argument. 2291 /// 2292 /// \returns true if there is another template argument (which will be at 2293 /// \c Args[ArgIdx]), false otherwise. 2294 static bool hasTemplateArgumentForDeduction(ArrayRef<TemplateArgument> &Args, 2295 unsigned &ArgIdx) { 2296 if (ArgIdx == Args.size()) 2297 return false; 2298 2299 const TemplateArgument &Arg = Args[ArgIdx]; 2300 if (Arg.getKind() != TemplateArgument::Pack) 2301 return true; 2302 2303 assert(ArgIdx == Args.size() - 1 && "Pack not at the end of argument list?"); 2304 Args = Arg.pack_elements(); 2305 ArgIdx = 0; 2306 return ArgIdx < Args.size(); 2307 } 2308 2309 /// Determine whether the given set of template arguments has a pack 2310 /// expansion that is not the last template argument. 2311 static bool hasPackExpansionBeforeEnd(ArrayRef<TemplateArgument> Args) { 2312 bool FoundPackExpansion = false; 2313 for (const auto &A : Args) { 2314 if (FoundPackExpansion) 2315 return true; 2316 2317 if (A.getKind() == TemplateArgument::Pack) 2318 return hasPackExpansionBeforeEnd(A.pack_elements()); 2319 2320 // FIXME: If this is a fixed-arity pack expansion from an outer level of 2321 // templates, it should not be treated as a pack expansion. 2322 if (A.isPackExpansion()) 2323 FoundPackExpansion = true; 2324 } 2325 2326 return false; 2327 } 2328 2329 static Sema::TemplateDeductionResult 2330 DeduceTemplateArguments(Sema &S, TemplateParameterList *TemplateParams, 2331 ArrayRef<TemplateArgument> Ps, 2332 ArrayRef<TemplateArgument> As, 2333 TemplateDeductionInfo &Info, 2334 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 2335 bool NumberOfArgumentsMustMatch) { 2336 // C++0x [temp.deduct.type]p9: 2337 // If the template argument list of P contains a pack expansion that is not 2338 // the last template argument, the entire template argument list is a 2339 // non-deduced context. 2340 if (hasPackExpansionBeforeEnd(Ps)) 2341 return Sema::TDK_Success; 2342 2343 // C++0x [temp.deduct.type]p9: 2344 // If P has a form that contains <T> or <i>, then each argument Pi of the 2345 // respective template argument list P is compared with the corresponding 2346 // argument Ai of the corresponding template argument list of A. 2347 unsigned ArgIdx = 0, ParamIdx = 0; 2348 for (; hasTemplateArgumentForDeduction(Ps, ParamIdx); ++ParamIdx) { 2349 const TemplateArgument &P = Ps[ParamIdx]; 2350 if (!P.isPackExpansion()) { 2351 // The simple case: deduce template arguments by matching Pi and Ai. 2352 2353 // Check whether we have enough arguments. 2354 if (!hasTemplateArgumentForDeduction(As, ArgIdx)) 2355 return NumberOfArgumentsMustMatch 2356 ? Sema::TDK_MiscellaneousDeductionFailure 2357 : Sema::TDK_Success; 2358 2359 // C++1z [temp.deduct.type]p9: 2360 // During partial ordering, if Ai was originally a pack expansion [and] 2361 // Pi is not a pack expansion, template argument deduction fails. 2362 if (As[ArgIdx].isPackExpansion()) 2363 return Sema::TDK_MiscellaneousDeductionFailure; 2364 2365 // Perform deduction for this Pi/Ai pair. 2366 if (auto Result = DeduceTemplateArguments(S, TemplateParams, P, 2367 As[ArgIdx], Info, Deduced)) 2368 return Result; 2369 2370 // Move to the next argument. 2371 ++ArgIdx; 2372 continue; 2373 } 2374 2375 // The parameter is a pack expansion. 2376 2377 // C++0x [temp.deduct.type]p9: 2378 // If Pi is a pack expansion, then the pattern of Pi is compared with 2379 // each remaining argument in the template argument list of A. Each 2380 // comparison deduces template arguments for subsequent positions in the 2381 // template parameter packs expanded by Pi. 2382 TemplateArgument Pattern = P.getPackExpansionPattern(); 2383 2384 // Prepare to deduce the packs within the pattern. 2385 PackDeductionScope PackScope(S, TemplateParams, Deduced, Info, Pattern); 2386 2387 // Keep track of the deduced template arguments for each parameter pack 2388 // expanded by this pack expansion (the outer index) and for each 2389 // template argument (the inner SmallVectors). 2390 for (; hasTemplateArgumentForDeduction(As, ArgIdx) && 2391 PackScope.hasNextElement(); 2392 ++ArgIdx) { 2393 // Deduce template arguments from the pattern. 2394 if (auto Result = DeduceTemplateArguments(S, TemplateParams, Pattern, 2395 As[ArgIdx], Info, Deduced)) 2396 return Result; 2397 2398 PackScope.nextPackElement(); 2399 } 2400 2401 // Build argument packs for each of the parameter packs expanded by this 2402 // pack expansion. 2403 if (auto Result = PackScope.finish()) 2404 return Result; 2405 } 2406 2407 return Sema::TDK_Success; 2408 } 2409 2410 static Sema::TemplateDeductionResult 2411 DeduceTemplateArguments(Sema &S, TemplateParameterList *TemplateParams, 2412 const TemplateArgumentList &ParamList, 2413 const TemplateArgumentList &ArgList, 2414 TemplateDeductionInfo &Info, 2415 SmallVectorImpl<DeducedTemplateArgument> &Deduced) { 2416 return DeduceTemplateArguments(S, TemplateParams, ParamList.asArray(), 2417 ArgList.asArray(), Info, Deduced, 2418 /*NumberOfArgumentsMustMatch=*/false); 2419 } 2420 2421 /// Determine whether two template arguments are the same. 2422 static bool isSameTemplateArg(ASTContext &Context, 2423 TemplateArgument X, 2424 const TemplateArgument &Y, 2425 bool PackExpansionMatchesPack = false) { 2426 // If we're checking deduced arguments (X) against original arguments (Y), 2427 // we will have flattened packs to non-expansions in X. 2428 if (PackExpansionMatchesPack && X.isPackExpansion() && !Y.isPackExpansion()) 2429 X = X.getPackExpansionPattern(); 2430 2431 if (X.getKind() != Y.getKind()) 2432 return false; 2433 2434 switch (X.getKind()) { 2435 case TemplateArgument::Null: 2436 llvm_unreachable("Comparing NULL template argument"); 2437 2438 case TemplateArgument::Type: 2439 return Context.getCanonicalType(X.getAsType()) == 2440 Context.getCanonicalType(Y.getAsType()); 2441 2442 case TemplateArgument::Declaration: 2443 return isSameDeclaration(X.getAsDecl(), Y.getAsDecl()); 2444 2445 case TemplateArgument::NullPtr: 2446 return Context.hasSameType(X.getNullPtrType(), Y.getNullPtrType()); 2447 2448 case TemplateArgument::Template: 2449 case TemplateArgument::TemplateExpansion: 2450 return Context.getCanonicalTemplateName( 2451 X.getAsTemplateOrTemplatePattern()).getAsVoidPointer() == 2452 Context.getCanonicalTemplateName( 2453 Y.getAsTemplateOrTemplatePattern()).getAsVoidPointer(); 2454 2455 case TemplateArgument::Integral: 2456 return hasSameExtendedValue(X.getAsIntegral(), Y.getAsIntegral()); 2457 2458 case TemplateArgument::Expression: { 2459 llvm::FoldingSetNodeID XID, YID; 2460 X.getAsExpr()->Profile(XID, Context, true); 2461 Y.getAsExpr()->Profile(YID, Context, true); 2462 return XID == YID; 2463 } 2464 2465 case TemplateArgument::Pack: 2466 if (X.pack_size() != Y.pack_size()) 2467 return false; 2468 2469 for (TemplateArgument::pack_iterator XP = X.pack_begin(), 2470 XPEnd = X.pack_end(), 2471 YP = Y.pack_begin(); 2472 XP != XPEnd; ++XP, ++YP) 2473 if (!isSameTemplateArg(Context, *XP, *YP, PackExpansionMatchesPack)) 2474 return false; 2475 2476 return true; 2477 } 2478 2479 llvm_unreachable("Invalid TemplateArgument Kind!"); 2480 } 2481 2482 /// Allocate a TemplateArgumentLoc where all locations have 2483 /// been initialized to the given location. 2484 /// 2485 /// \param Arg The template argument we are producing template argument 2486 /// location information for. 2487 /// 2488 /// \param NTTPType For a declaration template argument, the type of 2489 /// the non-type template parameter that corresponds to this template 2490 /// argument. Can be null if no type sugar is available to add to the 2491 /// type from the template argument. 2492 /// 2493 /// \param Loc The source location to use for the resulting template 2494 /// argument. 2495 TemplateArgumentLoc 2496 Sema::getTrivialTemplateArgumentLoc(const TemplateArgument &Arg, 2497 QualType NTTPType, SourceLocation Loc) { 2498 switch (Arg.getKind()) { 2499 case TemplateArgument::Null: 2500 llvm_unreachable("Can't get a NULL template argument here"); 2501 2502 case TemplateArgument::Type: 2503 return TemplateArgumentLoc( 2504 Arg, Context.getTrivialTypeSourceInfo(Arg.getAsType(), Loc)); 2505 2506 case TemplateArgument::Declaration: { 2507 if (NTTPType.isNull()) 2508 NTTPType = Arg.getParamTypeForDecl(); 2509 Expr *E = BuildExpressionFromDeclTemplateArgument(Arg, NTTPType, Loc) 2510 .getAs<Expr>(); 2511 return TemplateArgumentLoc(TemplateArgument(E), E); 2512 } 2513 2514 case TemplateArgument::NullPtr: { 2515 if (NTTPType.isNull()) 2516 NTTPType = Arg.getNullPtrType(); 2517 Expr *E = BuildExpressionFromDeclTemplateArgument(Arg, NTTPType, Loc) 2518 .getAs<Expr>(); 2519 return TemplateArgumentLoc(TemplateArgument(NTTPType, /*isNullPtr*/true), 2520 E); 2521 } 2522 2523 case TemplateArgument::Integral: { 2524 Expr *E = 2525 BuildExpressionFromIntegralTemplateArgument(Arg, Loc).getAs<Expr>(); 2526 return TemplateArgumentLoc(TemplateArgument(E), E); 2527 } 2528 2529 case TemplateArgument::Template: 2530 case TemplateArgument::TemplateExpansion: { 2531 NestedNameSpecifierLocBuilder Builder; 2532 TemplateName Template = Arg.getAsTemplateOrTemplatePattern(); 2533 if (DependentTemplateName *DTN = Template.getAsDependentTemplateName()) 2534 Builder.MakeTrivial(Context, DTN->getQualifier(), Loc); 2535 else if (QualifiedTemplateName *QTN = 2536 Template.getAsQualifiedTemplateName()) 2537 Builder.MakeTrivial(Context, QTN->getQualifier(), Loc); 2538 2539 if (Arg.getKind() == TemplateArgument::Template) 2540 return TemplateArgumentLoc(Context, Arg, 2541 Builder.getWithLocInContext(Context), Loc); 2542 2543 return TemplateArgumentLoc( 2544 Context, Arg, Builder.getWithLocInContext(Context), Loc, Loc); 2545 } 2546 2547 case TemplateArgument::Expression: 2548 return TemplateArgumentLoc(Arg, Arg.getAsExpr()); 2549 2550 case TemplateArgument::Pack: 2551 return TemplateArgumentLoc(Arg, TemplateArgumentLocInfo()); 2552 } 2553 2554 llvm_unreachable("Invalid TemplateArgument Kind!"); 2555 } 2556 2557 TemplateArgumentLoc 2558 Sema::getIdentityTemplateArgumentLoc(NamedDecl *TemplateParm, 2559 SourceLocation Location) { 2560 return getTrivialTemplateArgumentLoc( 2561 Context.getInjectedTemplateArg(TemplateParm), QualType(), Location); 2562 } 2563 2564 /// Convert the given deduced template argument and add it to the set of 2565 /// fully-converted template arguments. 2566 static bool 2567 ConvertDeducedTemplateArgument(Sema &S, NamedDecl *Param, 2568 DeducedTemplateArgument Arg, 2569 NamedDecl *Template, 2570 TemplateDeductionInfo &Info, 2571 bool IsDeduced, 2572 SmallVectorImpl<TemplateArgument> &Output) { 2573 auto ConvertArg = [&](DeducedTemplateArgument Arg, 2574 unsigned ArgumentPackIndex) { 2575 // Convert the deduced template argument into a template 2576 // argument that we can check, almost as if the user had written 2577 // the template argument explicitly. 2578 TemplateArgumentLoc ArgLoc = 2579 S.getTrivialTemplateArgumentLoc(Arg, QualType(), Info.getLocation()); 2580 2581 // Check the template argument, converting it as necessary. 2582 return S.CheckTemplateArgument( 2583 Param, ArgLoc, Template, Template->getLocation(), 2584 Template->getSourceRange().getEnd(), ArgumentPackIndex, Output, 2585 IsDeduced 2586 ? (Arg.wasDeducedFromArrayBound() ? Sema::CTAK_DeducedFromArrayBound 2587 : Sema::CTAK_Deduced) 2588 : Sema::CTAK_Specified); 2589 }; 2590 2591 if (Arg.getKind() == TemplateArgument::Pack) { 2592 // This is a template argument pack, so check each of its arguments against 2593 // the template parameter. 2594 SmallVector<TemplateArgument, 2> PackedArgsBuilder; 2595 for (const auto &P : Arg.pack_elements()) { 2596 // When converting the deduced template argument, append it to the 2597 // general output list. We need to do this so that the template argument 2598 // checking logic has all of the prior template arguments available. 2599 DeducedTemplateArgument InnerArg(P); 2600 InnerArg.setDeducedFromArrayBound(Arg.wasDeducedFromArrayBound()); 2601 assert(InnerArg.getKind() != TemplateArgument::Pack && 2602 "deduced nested pack"); 2603 if (P.isNull()) { 2604 // We deduced arguments for some elements of this pack, but not for 2605 // all of them. This happens if we get a conditionally-non-deduced 2606 // context in a pack expansion (such as an overload set in one of the 2607 // arguments). 2608 S.Diag(Param->getLocation(), 2609 diag::err_template_arg_deduced_incomplete_pack) 2610 << Arg << Param; 2611 return true; 2612 } 2613 if (ConvertArg(InnerArg, PackedArgsBuilder.size())) 2614 return true; 2615 2616 // Move the converted template argument into our argument pack. 2617 PackedArgsBuilder.push_back(Output.pop_back_val()); 2618 } 2619 2620 // If the pack is empty, we still need to substitute into the parameter 2621 // itself, in case that substitution fails. 2622 if (PackedArgsBuilder.empty()) { 2623 LocalInstantiationScope Scope(S); 2624 TemplateArgumentList TemplateArgs(TemplateArgumentList::OnStack, Output); 2625 MultiLevelTemplateArgumentList Args(TemplateArgs); 2626 2627 if (auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Param)) { 2628 Sema::InstantiatingTemplate Inst(S, Template->getLocation(), Template, 2629 NTTP, Output, 2630 Template->getSourceRange()); 2631 if (Inst.isInvalid() || 2632 S.SubstType(NTTP->getType(), Args, NTTP->getLocation(), 2633 NTTP->getDeclName()).isNull()) 2634 return true; 2635 } else if (auto *TTP = dyn_cast<TemplateTemplateParmDecl>(Param)) { 2636 Sema::InstantiatingTemplate Inst(S, Template->getLocation(), Template, 2637 TTP, Output, 2638 Template->getSourceRange()); 2639 if (Inst.isInvalid() || !S.SubstDecl(TTP, S.CurContext, Args)) 2640 return true; 2641 } 2642 // For type parameters, no substitution is ever required. 2643 } 2644 2645 // Create the resulting argument pack. 2646 Output.push_back( 2647 TemplateArgument::CreatePackCopy(S.Context, PackedArgsBuilder)); 2648 return false; 2649 } 2650 2651 return ConvertArg(Arg, 0); 2652 } 2653 2654 // FIXME: This should not be a template, but 2655 // ClassTemplatePartialSpecializationDecl sadly does not derive from 2656 // TemplateDecl. 2657 template<typename TemplateDeclT> 2658 static Sema::TemplateDeductionResult ConvertDeducedTemplateArguments( 2659 Sema &S, TemplateDeclT *Template, bool IsDeduced, 2660 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 2661 TemplateDeductionInfo &Info, SmallVectorImpl<TemplateArgument> &Builder, 2662 LocalInstantiationScope *CurrentInstantiationScope = nullptr, 2663 unsigned NumAlreadyConverted = 0, bool PartialOverloading = false) { 2664 TemplateParameterList *TemplateParams = Template->getTemplateParameters(); 2665 2666 for (unsigned I = 0, N = TemplateParams->size(); I != N; ++I) { 2667 NamedDecl *Param = TemplateParams->getParam(I); 2668 2669 // C++0x [temp.arg.explicit]p3: 2670 // A trailing template parameter pack (14.5.3) not otherwise deduced will 2671 // be deduced to an empty sequence of template arguments. 2672 // FIXME: Where did the word "trailing" come from? 2673 if (Deduced[I].isNull() && Param->isTemplateParameterPack()) { 2674 if (auto Result = 2675 PackDeductionScope(S, TemplateParams, Deduced, Info, I).finish()) 2676 return Result; 2677 } 2678 2679 if (!Deduced[I].isNull()) { 2680 if (I < NumAlreadyConverted) { 2681 // We may have had explicitly-specified template arguments for a 2682 // template parameter pack (that may or may not have been extended 2683 // via additional deduced arguments). 2684 if (Param->isParameterPack() && CurrentInstantiationScope && 2685 CurrentInstantiationScope->getPartiallySubstitutedPack() == Param) { 2686 // Forget the partially-substituted pack; its substitution is now 2687 // complete. 2688 CurrentInstantiationScope->ResetPartiallySubstitutedPack(); 2689 // We still need to check the argument in case it was extended by 2690 // deduction. 2691 } else { 2692 // We have already fully type-checked and converted this 2693 // argument, because it was explicitly-specified. Just record the 2694 // presence of this argument. 2695 Builder.push_back(Deduced[I]); 2696 continue; 2697 } 2698 } 2699 2700 // We may have deduced this argument, so it still needs to be 2701 // checked and converted. 2702 if (ConvertDeducedTemplateArgument(S, Param, Deduced[I], Template, Info, 2703 IsDeduced, Builder)) { 2704 Info.Param = makeTemplateParameter(Param); 2705 // FIXME: These template arguments are temporary. Free them! 2706 Info.reset(TemplateArgumentList::CreateCopy(S.Context, Builder)); 2707 return Sema::TDK_SubstitutionFailure; 2708 } 2709 2710 continue; 2711 } 2712 2713 // Substitute into the default template argument, if available. 2714 bool HasDefaultArg = false; 2715 TemplateDecl *TD = dyn_cast<TemplateDecl>(Template); 2716 if (!TD) { 2717 assert(isa<ClassTemplatePartialSpecializationDecl>(Template) || 2718 isa<VarTemplatePartialSpecializationDecl>(Template)); 2719 return Sema::TDK_Incomplete; 2720 } 2721 2722 TemplateArgumentLoc DefArg; 2723 { 2724 Qualifiers ThisTypeQuals; 2725 CXXRecordDecl *ThisContext = nullptr; 2726 if (auto *Rec = dyn_cast<CXXRecordDecl>(TD->getDeclContext())) 2727 if (Rec->isLambda()) 2728 if (auto *Method = dyn_cast<CXXMethodDecl>(Rec->getDeclContext())) { 2729 ThisContext = Method->getParent(); 2730 ThisTypeQuals = Method->getMethodQualifiers(); 2731 } 2732 2733 Sema::CXXThisScopeRAII ThisScope(S, ThisContext, ThisTypeQuals, 2734 S.getLangOpts().CPlusPlus17); 2735 2736 DefArg = S.SubstDefaultTemplateArgumentIfAvailable( 2737 TD, TD->getLocation(), TD->getSourceRange().getEnd(), Param, Builder, 2738 HasDefaultArg); 2739 } 2740 2741 // If there was no default argument, deduction is incomplete. 2742 if (DefArg.getArgument().isNull()) { 2743 Info.Param = makeTemplateParameter( 2744 const_cast<NamedDecl *>(TemplateParams->getParam(I))); 2745 Info.reset(TemplateArgumentList::CreateCopy(S.Context, Builder)); 2746 if (PartialOverloading) break; 2747 2748 return HasDefaultArg ? Sema::TDK_SubstitutionFailure 2749 : Sema::TDK_Incomplete; 2750 } 2751 2752 // Check whether we can actually use the default argument. 2753 if (S.CheckTemplateArgument(Param, DefArg, TD, TD->getLocation(), 2754 TD->getSourceRange().getEnd(), 0, Builder, 2755 Sema::CTAK_Specified)) { 2756 Info.Param = makeTemplateParameter( 2757 const_cast<NamedDecl *>(TemplateParams->getParam(I))); 2758 // FIXME: These template arguments are temporary. Free them! 2759 Info.reset(TemplateArgumentList::CreateCopy(S.Context, Builder)); 2760 return Sema::TDK_SubstitutionFailure; 2761 } 2762 2763 // If we get here, we successfully used the default template argument. 2764 } 2765 2766 return Sema::TDK_Success; 2767 } 2768 2769 static DeclContext *getAsDeclContextOrEnclosing(Decl *D) { 2770 if (auto *DC = dyn_cast<DeclContext>(D)) 2771 return DC; 2772 return D->getDeclContext(); 2773 } 2774 2775 template<typename T> struct IsPartialSpecialization { 2776 static constexpr bool value = false; 2777 }; 2778 template<> 2779 struct IsPartialSpecialization<ClassTemplatePartialSpecializationDecl> { 2780 static constexpr bool value = true; 2781 }; 2782 template<> 2783 struct IsPartialSpecialization<VarTemplatePartialSpecializationDecl> { 2784 static constexpr bool value = true; 2785 }; 2786 2787 template<typename TemplateDeclT> 2788 static Sema::TemplateDeductionResult 2789 CheckDeducedArgumentConstraints(Sema& S, TemplateDeclT *Template, 2790 ArrayRef<TemplateArgument> DeducedArgs, 2791 TemplateDeductionInfo& Info) { 2792 llvm::SmallVector<const Expr *, 3> AssociatedConstraints; 2793 Template->getAssociatedConstraints(AssociatedConstraints); 2794 if (S.CheckConstraintSatisfaction(Template, AssociatedConstraints, 2795 DeducedArgs, Info.getLocation(), 2796 Info.AssociatedConstraintsSatisfaction) || 2797 !Info.AssociatedConstraintsSatisfaction.IsSatisfied) { 2798 Info.reset(TemplateArgumentList::CreateCopy(S.Context, DeducedArgs)); 2799 return Sema::TDK_ConstraintsNotSatisfied; 2800 } 2801 return Sema::TDK_Success; 2802 } 2803 2804 /// Complete template argument deduction for a partial specialization. 2805 template <typename T> 2806 static std::enable_if_t<IsPartialSpecialization<T>::value, 2807 Sema::TemplateDeductionResult> 2808 FinishTemplateArgumentDeduction( 2809 Sema &S, T *Partial, bool IsPartialOrdering, 2810 const TemplateArgumentList &TemplateArgs, 2811 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 2812 TemplateDeductionInfo &Info) { 2813 // Unevaluated SFINAE context. 2814 EnterExpressionEvaluationContext Unevaluated( 2815 S, Sema::ExpressionEvaluationContext::Unevaluated); 2816 Sema::SFINAETrap Trap(S); 2817 2818 Sema::ContextRAII SavedContext(S, getAsDeclContextOrEnclosing(Partial)); 2819 2820 // C++ [temp.deduct.type]p2: 2821 // [...] or if any template argument remains neither deduced nor 2822 // explicitly specified, template argument deduction fails. 2823 SmallVector<TemplateArgument, 4> Builder; 2824 if (auto Result = ConvertDeducedTemplateArguments( 2825 S, Partial, IsPartialOrdering, Deduced, Info, Builder)) 2826 return Result; 2827 2828 // Form the template argument list from the deduced template arguments. 2829 TemplateArgumentList *DeducedArgumentList 2830 = TemplateArgumentList::CreateCopy(S.Context, Builder); 2831 2832 Info.reset(DeducedArgumentList); 2833 2834 // Substitute the deduced template arguments into the template 2835 // arguments of the class template partial specialization, and 2836 // verify that the instantiated template arguments are both valid 2837 // and are equivalent to the template arguments originally provided 2838 // to the class template. 2839 LocalInstantiationScope InstScope(S); 2840 auto *Template = Partial->getSpecializedTemplate(); 2841 const ASTTemplateArgumentListInfo *PartialTemplArgInfo = 2842 Partial->getTemplateArgsAsWritten(); 2843 2844 TemplateArgumentListInfo InstArgs(PartialTemplArgInfo->LAngleLoc, 2845 PartialTemplArgInfo->RAngleLoc); 2846 2847 if (S.SubstTemplateArguments( 2848 PartialTemplArgInfo->arguments(), 2849 MultiLevelTemplateArgumentList(*DeducedArgumentList), InstArgs)) { 2850 unsigned ArgIdx = InstArgs.size(), ParamIdx = ArgIdx; 2851 if (ParamIdx >= Partial->getTemplateParameters()->size()) 2852 ParamIdx = Partial->getTemplateParameters()->size() - 1; 2853 2854 Decl *Param = const_cast<NamedDecl *>( 2855 Partial->getTemplateParameters()->getParam(ParamIdx)); 2856 Info.Param = makeTemplateParameter(Param); 2857 Info.FirstArg = (*PartialTemplArgInfo)[ArgIdx].getArgument(); 2858 return Sema::TDK_SubstitutionFailure; 2859 } 2860 2861 bool ConstraintsNotSatisfied; 2862 SmallVector<TemplateArgument, 4> ConvertedInstArgs; 2863 if (S.CheckTemplateArgumentList(Template, Partial->getLocation(), InstArgs, 2864 false, ConvertedInstArgs, 2865 /*UpdateArgsWithConversions=*/true, 2866 &ConstraintsNotSatisfied)) 2867 return ConstraintsNotSatisfied ? Sema::TDK_ConstraintsNotSatisfied : 2868 Sema::TDK_SubstitutionFailure; 2869 2870 TemplateParameterList *TemplateParams = Template->getTemplateParameters(); 2871 for (unsigned I = 0, E = TemplateParams->size(); I != E; ++I) { 2872 TemplateArgument InstArg = ConvertedInstArgs.data()[I]; 2873 if (!isSameTemplateArg(S.Context, TemplateArgs[I], InstArg)) { 2874 Info.Param = makeTemplateParameter(TemplateParams->getParam(I)); 2875 Info.FirstArg = TemplateArgs[I]; 2876 Info.SecondArg = InstArg; 2877 return Sema::TDK_NonDeducedMismatch; 2878 } 2879 } 2880 2881 if (Trap.hasErrorOccurred()) 2882 return Sema::TDK_SubstitutionFailure; 2883 2884 if (auto Result = CheckDeducedArgumentConstraints(S, Partial, Builder, Info)) 2885 return Result; 2886 2887 return Sema::TDK_Success; 2888 } 2889 2890 /// Complete template argument deduction for a class or variable template, 2891 /// when partial ordering against a partial specialization. 2892 // FIXME: Factor out duplication with partial specialization version above. 2893 static Sema::TemplateDeductionResult FinishTemplateArgumentDeduction( 2894 Sema &S, TemplateDecl *Template, bool PartialOrdering, 2895 const TemplateArgumentList &TemplateArgs, 2896 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 2897 TemplateDeductionInfo &Info) { 2898 // Unevaluated SFINAE context. 2899 EnterExpressionEvaluationContext Unevaluated( 2900 S, Sema::ExpressionEvaluationContext::Unevaluated); 2901 Sema::SFINAETrap Trap(S); 2902 2903 Sema::ContextRAII SavedContext(S, getAsDeclContextOrEnclosing(Template)); 2904 2905 // C++ [temp.deduct.type]p2: 2906 // [...] or if any template argument remains neither deduced nor 2907 // explicitly specified, template argument deduction fails. 2908 SmallVector<TemplateArgument, 4> Builder; 2909 if (auto Result = ConvertDeducedTemplateArguments( 2910 S, Template, /*IsDeduced*/PartialOrdering, Deduced, Info, Builder)) 2911 return Result; 2912 2913 // Check that we produced the correct argument list. 2914 TemplateParameterList *TemplateParams = Template->getTemplateParameters(); 2915 for (unsigned I = 0, E = TemplateParams->size(); I != E; ++I) { 2916 TemplateArgument InstArg = Builder[I]; 2917 if (!isSameTemplateArg(S.Context, TemplateArgs[I], InstArg, 2918 /*PackExpansionMatchesPack*/true)) { 2919 Info.Param = makeTemplateParameter(TemplateParams->getParam(I)); 2920 Info.FirstArg = TemplateArgs[I]; 2921 Info.SecondArg = InstArg; 2922 return Sema::TDK_NonDeducedMismatch; 2923 } 2924 } 2925 2926 if (Trap.hasErrorOccurred()) 2927 return Sema::TDK_SubstitutionFailure; 2928 2929 if (auto Result = CheckDeducedArgumentConstraints(S, Template, Builder, 2930 Info)) 2931 return Result; 2932 2933 return Sema::TDK_Success; 2934 } 2935 2936 /// Perform template argument deduction to determine whether 2937 /// the given template arguments match the given class template 2938 /// partial specialization per C++ [temp.class.spec.match]. 2939 Sema::TemplateDeductionResult 2940 Sema::DeduceTemplateArguments(ClassTemplatePartialSpecializationDecl *Partial, 2941 const TemplateArgumentList &TemplateArgs, 2942 TemplateDeductionInfo &Info) { 2943 if (Partial->isInvalidDecl()) 2944 return TDK_Invalid; 2945 2946 // C++ [temp.class.spec.match]p2: 2947 // A partial specialization matches a given actual template 2948 // argument list if the template arguments of the partial 2949 // specialization can be deduced from the actual template argument 2950 // list (14.8.2). 2951 2952 // Unevaluated SFINAE context. 2953 EnterExpressionEvaluationContext Unevaluated( 2954 *this, Sema::ExpressionEvaluationContext::Unevaluated); 2955 SFINAETrap Trap(*this); 2956 2957 // This deduction has no relation to any outer instantiation we might be 2958 // performing. 2959 LocalInstantiationScope InstantiationScope(*this); 2960 2961 SmallVector<DeducedTemplateArgument, 4> Deduced; 2962 Deduced.resize(Partial->getTemplateParameters()->size()); 2963 if (TemplateDeductionResult Result 2964 = ::DeduceTemplateArguments(*this, 2965 Partial->getTemplateParameters(), 2966 Partial->getTemplateArgs(), 2967 TemplateArgs, Info, Deduced)) 2968 return Result; 2969 2970 SmallVector<TemplateArgument, 4> DeducedArgs(Deduced.begin(), Deduced.end()); 2971 InstantiatingTemplate Inst(*this, Info.getLocation(), Partial, DeducedArgs, 2972 Info); 2973 if (Inst.isInvalid()) 2974 return TDK_InstantiationDepth; 2975 2976 if (Trap.hasErrorOccurred()) 2977 return Sema::TDK_SubstitutionFailure; 2978 2979 TemplateDeductionResult Result; 2980 runWithSufficientStackSpace(Info.getLocation(), [&] { 2981 Result = ::FinishTemplateArgumentDeduction(*this, Partial, 2982 /*IsPartialOrdering=*/false, 2983 TemplateArgs, Deduced, Info); 2984 }); 2985 return Result; 2986 } 2987 2988 /// Perform template argument deduction to determine whether 2989 /// the given template arguments match the given variable template 2990 /// partial specialization per C++ [temp.class.spec.match]. 2991 Sema::TemplateDeductionResult 2992 Sema::DeduceTemplateArguments(VarTemplatePartialSpecializationDecl *Partial, 2993 const TemplateArgumentList &TemplateArgs, 2994 TemplateDeductionInfo &Info) { 2995 if (Partial->isInvalidDecl()) 2996 return TDK_Invalid; 2997 2998 // C++ [temp.class.spec.match]p2: 2999 // A partial specialization matches a given actual template 3000 // argument list if the template arguments of the partial 3001 // specialization can be deduced from the actual template argument 3002 // list (14.8.2). 3003 3004 // Unevaluated SFINAE context. 3005 EnterExpressionEvaluationContext Unevaluated( 3006 *this, Sema::ExpressionEvaluationContext::Unevaluated); 3007 SFINAETrap Trap(*this); 3008 3009 // This deduction has no relation to any outer instantiation we might be 3010 // performing. 3011 LocalInstantiationScope InstantiationScope(*this); 3012 3013 SmallVector<DeducedTemplateArgument, 4> Deduced; 3014 Deduced.resize(Partial->getTemplateParameters()->size()); 3015 if (TemplateDeductionResult Result = ::DeduceTemplateArguments( 3016 *this, Partial->getTemplateParameters(), Partial->getTemplateArgs(), 3017 TemplateArgs, Info, Deduced)) 3018 return Result; 3019 3020 SmallVector<TemplateArgument, 4> DeducedArgs(Deduced.begin(), Deduced.end()); 3021 InstantiatingTemplate Inst(*this, Info.getLocation(), Partial, DeducedArgs, 3022 Info); 3023 if (Inst.isInvalid()) 3024 return TDK_InstantiationDepth; 3025 3026 if (Trap.hasErrorOccurred()) 3027 return Sema::TDK_SubstitutionFailure; 3028 3029 TemplateDeductionResult Result; 3030 runWithSufficientStackSpace(Info.getLocation(), [&] { 3031 Result = ::FinishTemplateArgumentDeduction(*this, Partial, 3032 /*IsPartialOrdering=*/false, 3033 TemplateArgs, Deduced, Info); 3034 }); 3035 return Result; 3036 } 3037 3038 /// Determine whether the given type T is a simple-template-id type. 3039 static bool isSimpleTemplateIdType(QualType T) { 3040 if (const TemplateSpecializationType *Spec 3041 = T->getAs<TemplateSpecializationType>()) 3042 return Spec->getTemplateName().getAsTemplateDecl() != nullptr; 3043 3044 // C++17 [temp.local]p2: 3045 // the injected-class-name [...] is equivalent to the template-name followed 3046 // by the template-arguments of the class template specialization or partial 3047 // specialization enclosed in <> 3048 // ... which means it's equivalent to a simple-template-id. 3049 // 3050 // This only arises during class template argument deduction for a copy 3051 // deduction candidate, where it permits slicing. 3052 if (T->getAs<InjectedClassNameType>()) 3053 return true; 3054 3055 return false; 3056 } 3057 3058 /// Substitute the explicitly-provided template arguments into the 3059 /// given function template according to C++ [temp.arg.explicit]. 3060 /// 3061 /// \param FunctionTemplate the function template into which the explicit 3062 /// template arguments will be substituted. 3063 /// 3064 /// \param ExplicitTemplateArgs the explicitly-specified template 3065 /// arguments. 3066 /// 3067 /// \param Deduced the deduced template arguments, which will be populated 3068 /// with the converted and checked explicit template arguments. 3069 /// 3070 /// \param ParamTypes will be populated with the instantiated function 3071 /// parameters. 3072 /// 3073 /// \param FunctionType if non-NULL, the result type of the function template 3074 /// will also be instantiated and the pointed-to value will be updated with 3075 /// the instantiated function type. 3076 /// 3077 /// \param Info if substitution fails for any reason, this object will be 3078 /// populated with more information about the failure. 3079 /// 3080 /// \returns TDK_Success if substitution was successful, or some failure 3081 /// condition. 3082 Sema::TemplateDeductionResult 3083 Sema::SubstituteExplicitTemplateArguments( 3084 FunctionTemplateDecl *FunctionTemplate, 3085 TemplateArgumentListInfo &ExplicitTemplateArgs, 3086 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 3087 SmallVectorImpl<QualType> &ParamTypes, 3088 QualType *FunctionType, 3089 TemplateDeductionInfo &Info) { 3090 FunctionDecl *Function = FunctionTemplate->getTemplatedDecl(); 3091 TemplateParameterList *TemplateParams 3092 = FunctionTemplate->getTemplateParameters(); 3093 3094 if (ExplicitTemplateArgs.size() == 0) { 3095 // No arguments to substitute; just copy over the parameter types and 3096 // fill in the function type. 3097 for (auto P : Function->parameters()) 3098 ParamTypes.push_back(P->getType()); 3099 3100 if (FunctionType) 3101 *FunctionType = Function->getType(); 3102 return TDK_Success; 3103 } 3104 3105 // Unevaluated SFINAE context. 3106 EnterExpressionEvaluationContext Unevaluated( 3107 *this, Sema::ExpressionEvaluationContext::Unevaluated); 3108 SFINAETrap Trap(*this); 3109 3110 // C++ [temp.arg.explicit]p3: 3111 // Template arguments that are present shall be specified in the 3112 // declaration order of their corresponding template-parameters. The 3113 // template argument list shall not specify more template-arguments than 3114 // there are corresponding template-parameters. 3115 SmallVector<TemplateArgument, 4> Builder; 3116 3117 // Enter a new template instantiation context where we check the 3118 // explicitly-specified template arguments against this function template, 3119 // and then substitute them into the function parameter types. 3120 SmallVector<TemplateArgument, 4> DeducedArgs; 3121 InstantiatingTemplate Inst( 3122 *this, Info.getLocation(), FunctionTemplate, DeducedArgs, 3123 CodeSynthesisContext::ExplicitTemplateArgumentSubstitution, Info); 3124 if (Inst.isInvalid()) 3125 return TDK_InstantiationDepth; 3126 3127 if (CheckTemplateArgumentList(FunctionTemplate, SourceLocation(), 3128 ExplicitTemplateArgs, true, Builder, false) || 3129 Trap.hasErrorOccurred()) { 3130 unsigned Index = Builder.size(); 3131 if (Index >= TemplateParams->size()) 3132 return TDK_SubstitutionFailure; 3133 Info.Param = makeTemplateParameter(TemplateParams->getParam(Index)); 3134 return TDK_InvalidExplicitArguments; 3135 } 3136 3137 // Form the template argument list from the explicitly-specified 3138 // template arguments. 3139 TemplateArgumentList *ExplicitArgumentList 3140 = TemplateArgumentList::CreateCopy(Context, Builder); 3141 Info.setExplicitArgs(ExplicitArgumentList); 3142 3143 // Template argument deduction and the final substitution should be 3144 // done in the context of the templated declaration. Explicit 3145 // argument substitution, on the other hand, needs to happen in the 3146 // calling context. 3147 ContextRAII SavedContext(*this, FunctionTemplate->getTemplatedDecl()); 3148 3149 // If we deduced template arguments for a template parameter pack, 3150 // note that the template argument pack is partially substituted and record 3151 // the explicit template arguments. They'll be used as part of deduction 3152 // for this template parameter pack. 3153 unsigned PartiallySubstitutedPackIndex = -1u; 3154 if (!Builder.empty()) { 3155 const TemplateArgument &Arg = Builder.back(); 3156 if (Arg.getKind() == TemplateArgument::Pack) { 3157 auto *Param = TemplateParams->getParam(Builder.size() - 1); 3158 // If this is a fully-saturated fixed-size pack, it should be 3159 // fully-substituted, not partially-substituted. 3160 Optional<unsigned> Expansions = getExpandedPackSize(Param); 3161 if (!Expansions || Arg.pack_size() < *Expansions) { 3162 PartiallySubstitutedPackIndex = Builder.size() - 1; 3163 CurrentInstantiationScope->SetPartiallySubstitutedPack( 3164 Param, Arg.pack_begin(), Arg.pack_size()); 3165 } 3166 } 3167 } 3168 3169 const FunctionProtoType *Proto 3170 = Function->getType()->getAs<FunctionProtoType>(); 3171 assert(Proto && "Function template does not have a prototype?"); 3172 3173 // Isolate our substituted parameters from our caller. 3174 LocalInstantiationScope InstScope(*this, /*MergeWithOuterScope*/true); 3175 3176 ExtParameterInfoBuilder ExtParamInfos; 3177 3178 // Instantiate the types of each of the function parameters given the 3179 // explicitly-specified template arguments. If the function has a trailing 3180 // return type, substitute it after the arguments to ensure we substitute 3181 // in lexical order. 3182 if (Proto->hasTrailingReturn()) { 3183 if (SubstParmTypes(Function->getLocation(), Function->parameters(), 3184 Proto->getExtParameterInfosOrNull(), 3185 MultiLevelTemplateArgumentList(*ExplicitArgumentList), 3186 ParamTypes, /*params*/ nullptr, ExtParamInfos)) 3187 return TDK_SubstitutionFailure; 3188 } 3189 3190 // Instantiate the return type. 3191 QualType ResultType; 3192 { 3193 // C++11 [expr.prim.general]p3: 3194 // If a declaration declares a member function or member function 3195 // template of a class X, the expression this is a prvalue of type 3196 // "pointer to cv-qualifier-seq X" between the optional cv-qualifer-seq 3197 // and the end of the function-definition, member-declarator, or 3198 // declarator. 3199 Qualifiers ThisTypeQuals; 3200 CXXRecordDecl *ThisContext = nullptr; 3201 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Function)) { 3202 ThisContext = Method->getParent(); 3203 ThisTypeQuals = Method->getMethodQualifiers(); 3204 } 3205 3206 CXXThisScopeRAII ThisScope(*this, ThisContext, ThisTypeQuals, 3207 getLangOpts().CPlusPlus11); 3208 3209 ResultType = 3210 SubstType(Proto->getReturnType(), 3211 MultiLevelTemplateArgumentList(*ExplicitArgumentList), 3212 Function->getTypeSpecStartLoc(), Function->getDeclName()); 3213 if (ResultType.isNull() || Trap.hasErrorOccurred()) 3214 return TDK_SubstitutionFailure; 3215 // CUDA: Kernel function must have 'void' return type. 3216 if (getLangOpts().CUDA) 3217 if (Function->hasAttr<CUDAGlobalAttr>() && !ResultType->isVoidType()) { 3218 Diag(Function->getLocation(), diag::err_kern_type_not_void_return) 3219 << Function->getType() << Function->getSourceRange(); 3220 return TDK_SubstitutionFailure; 3221 } 3222 } 3223 3224 // Instantiate the types of each of the function parameters given the 3225 // explicitly-specified template arguments if we didn't do so earlier. 3226 if (!Proto->hasTrailingReturn() && 3227 SubstParmTypes(Function->getLocation(), Function->parameters(), 3228 Proto->getExtParameterInfosOrNull(), 3229 MultiLevelTemplateArgumentList(*ExplicitArgumentList), 3230 ParamTypes, /*params*/ nullptr, ExtParamInfos)) 3231 return TDK_SubstitutionFailure; 3232 3233 if (FunctionType) { 3234 auto EPI = Proto->getExtProtoInfo(); 3235 EPI.ExtParameterInfos = ExtParamInfos.getPointerOrNull(ParamTypes.size()); 3236 3237 // In C++1z onwards, exception specifications are part of the function type, 3238 // so substitution into the type must also substitute into the exception 3239 // specification. 3240 SmallVector<QualType, 4> ExceptionStorage; 3241 if (getLangOpts().CPlusPlus17 && 3242 SubstExceptionSpec( 3243 Function->getLocation(), EPI.ExceptionSpec, ExceptionStorage, 3244 MultiLevelTemplateArgumentList(*ExplicitArgumentList))) 3245 return TDK_SubstitutionFailure; 3246 3247 *FunctionType = BuildFunctionType(ResultType, ParamTypes, 3248 Function->getLocation(), 3249 Function->getDeclName(), 3250 EPI); 3251 if (FunctionType->isNull() || Trap.hasErrorOccurred()) 3252 return TDK_SubstitutionFailure; 3253 } 3254 3255 // C++ [temp.arg.explicit]p2: 3256 // Trailing template arguments that can be deduced (14.8.2) may be 3257 // omitted from the list of explicit template-arguments. If all of the 3258 // template arguments can be deduced, they may all be omitted; in this 3259 // case, the empty template argument list <> itself may also be omitted. 3260 // 3261 // Take all of the explicitly-specified arguments and put them into 3262 // the set of deduced template arguments. The partially-substituted 3263 // parameter pack, however, will be set to NULL since the deduction 3264 // mechanism handles the partially-substituted argument pack directly. 3265 Deduced.reserve(TemplateParams->size()); 3266 for (unsigned I = 0, N = ExplicitArgumentList->size(); I != N; ++I) { 3267 const TemplateArgument &Arg = ExplicitArgumentList->get(I); 3268 if (I == PartiallySubstitutedPackIndex) 3269 Deduced.push_back(DeducedTemplateArgument()); 3270 else 3271 Deduced.push_back(Arg); 3272 } 3273 3274 return TDK_Success; 3275 } 3276 3277 /// Check whether the deduced argument type for a call to a function 3278 /// template matches the actual argument type per C++ [temp.deduct.call]p4. 3279 static Sema::TemplateDeductionResult 3280 CheckOriginalCallArgDeduction(Sema &S, TemplateDeductionInfo &Info, 3281 Sema::OriginalCallArg OriginalArg, 3282 QualType DeducedA) { 3283 ASTContext &Context = S.Context; 3284 3285 auto Failed = [&]() -> Sema::TemplateDeductionResult { 3286 Info.FirstArg = TemplateArgument(DeducedA); 3287 Info.SecondArg = TemplateArgument(OriginalArg.OriginalArgType); 3288 Info.CallArgIndex = OriginalArg.ArgIdx; 3289 return OriginalArg.DecomposedParam ? Sema::TDK_DeducedMismatchNested 3290 : Sema::TDK_DeducedMismatch; 3291 }; 3292 3293 QualType A = OriginalArg.OriginalArgType; 3294 QualType OriginalParamType = OriginalArg.OriginalParamType; 3295 3296 // Check for type equality (top-level cv-qualifiers are ignored). 3297 if (Context.hasSameUnqualifiedType(A, DeducedA)) 3298 return Sema::TDK_Success; 3299 3300 // Strip off references on the argument types; they aren't needed for 3301 // the following checks. 3302 if (const ReferenceType *DeducedARef = DeducedA->getAs<ReferenceType>()) 3303 DeducedA = DeducedARef->getPointeeType(); 3304 if (const ReferenceType *ARef = A->getAs<ReferenceType>()) 3305 A = ARef->getPointeeType(); 3306 3307 // C++ [temp.deduct.call]p4: 3308 // [...] However, there are three cases that allow a difference: 3309 // - If the original P is a reference type, the deduced A (i.e., the 3310 // type referred to by the reference) can be more cv-qualified than 3311 // the transformed A. 3312 if (const ReferenceType *OriginalParamRef 3313 = OriginalParamType->getAs<ReferenceType>()) { 3314 // We don't want to keep the reference around any more. 3315 OriginalParamType = OriginalParamRef->getPointeeType(); 3316 3317 // FIXME: Resolve core issue (no number yet): if the original P is a 3318 // reference type and the transformed A is function type "noexcept F", 3319 // the deduced A can be F. 3320 QualType Tmp; 3321 if (A->isFunctionType() && S.IsFunctionConversion(A, DeducedA, Tmp)) 3322 return Sema::TDK_Success; 3323 3324 Qualifiers AQuals = A.getQualifiers(); 3325 Qualifiers DeducedAQuals = DeducedA.getQualifiers(); 3326 3327 // Under Objective-C++ ARC, the deduced type may have implicitly 3328 // been given strong or (when dealing with a const reference) 3329 // unsafe_unretained lifetime. If so, update the original 3330 // qualifiers to include this lifetime. 3331 if (S.getLangOpts().ObjCAutoRefCount && 3332 ((DeducedAQuals.getObjCLifetime() == Qualifiers::OCL_Strong && 3333 AQuals.getObjCLifetime() == Qualifiers::OCL_None) || 3334 (DeducedAQuals.hasConst() && 3335 DeducedAQuals.getObjCLifetime() == Qualifiers::OCL_ExplicitNone))) { 3336 AQuals.setObjCLifetime(DeducedAQuals.getObjCLifetime()); 3337 } 3338 3339 if (AQuals == DeducedAQuals) { 3340 // Qualifiers match; there's nothing to do. 3341 } else if (!DeducedAQuals.compatiblyIncludes(AQuals)) { 3342 return Failed(); 3343 } else { 3344 // Qualifiers are compatible, so have the argument type adopt the 3345 // deduced argument type's qualifiers as if we had performed the 3346 // qualification conversion. 3347 A = Context.getQualifiedType(A.getUnqualifiedType(), DeducedAQuals); 3348 } 3349 } 3350 3351 // - The transformed A can be another pointer or pointer to member 3352 // type that can be converted to the deduced A via a function pointer 3353 // conversion and/or a qualification conversion. 3354 // 3355 // Also allow conversions which merely strip __attribute__((noreturn)) from 3356 // function types (recursively). 3357 bool ObjCLifetimeConversion = false; 3358 QualType ResultTy; 3359 if ((A->isAnyPointerType() || A->isMemberPointerType()) && 3360 (S.IsQualificationConversion(A, DeducedA, false, 3361 ObjCLifetimeConversion) || 3362 S.IsFunctionConversion(A, DeducedA, ResultTy))) 3363 return Sema::TDK_Success; 3364 3365 // - If P is a class and P has the form simple-template-id, then the 3366 // transformed A can be a derived class of the deduced A. [...] 3367 // [...] Likewise, if P is a pointer to a class of the form 3368 // simple-template-id, the transformed A can be a pointer to a 3369 // derived class pointed to by the deduced A. 3370 if (const PointerType *OriginalParamPtr 3371 = OriginalParamType->getAs<PointerType>()) { 3372 if (const PointerType *DeducedAPtr = DeducedA->getAs<PointerType>()) { 3373 if (const PointerType *APtr = A->getAs<PointerType>()) { 3374 if (A->getPointeeType()->isRecordType()) { 3375 OriginalParamType = OriginalParamPtr->getPointeeType(); 3376 DeducedA = DeducedAPtr->getPointeeType(); 3377 A = APtr->getPointeeType(); 3378 } 3379 } 3380 } 3381 } 3382 3383 if (Context.hasSameUnqualifiedType(A, DeducedA)) 3384 return Sema::TDK_Success; 3385 3386 if (A->isRecordType() && isSimpleTemplateIdType(OriginalParamType) && 3387 S.IsDerivedFrom(Info.getLocation(), A, DeducedA)) 3388 return Sema::TDK_Success; 3389 3390 return Failed(); 3391 } 3392 3393 /// Find the pack index for a particular parameter index in an instantiation of 3394 /// a function template with specific arguments. 3395 /// 3396 /// \return The pack index for whichever pack produced this parameter, or -1 3397 /// if this was not produced by a parameter. Intended to be used as the 3398 /// ArgumentPackSubstitutionIndex for further substitutions. 3399 // FIXME: We should track this in OriginalCallArgs so we don't need to 3400 // reconstruct it here. 3401 static unsigned getPackIndexForParam(Sema &S, 3402 FunctionTemplateDecl *FunctionTemplate, 3403 const MultiLevelTemplateArgumentList &Args, 3404 unsigned ParamIdx) { 3405 unsigned Idx = 0; 3406 for (auto *PD : FunctionTemplate->getTemplatedDecl()->parameters()) { 3407 if (PD->isParameterPack()) { 3408 unsigned NumExpansions = 3409 S.getNumArgumentsInExpansion(PD->getType(), Args).value_or(1); 3410 if (Idx + NumExpansions > ParamIdx) 3411 return ParamIdx - Idx; 3412 Idx += NumExpansions; 3413 } else { 3414 if (Idx == ParamIdx) 3415 return -1; // Not a pack expansion 3416 ++Idx; 3417 } 3418 } 3419 3420 llvm_unreachable("parameter index would not be produced from template"); 3421 } 3422 3423 /// Finish template argument deduction for a function template, 3424 /// checking the deduced template arguments for completeness and forming 3425 /// the function template specialization. 3426 /// 3427 /// \param OriginalCallArgs If non-NULL, the original call arguments against 3428 /// which the deduced argument types should be compared. 3429 Sema::TemplateDeductionResult Sema::FinishTemplateArgumentDeduction( 3430 FunctionTemplateDecl *FunctionTemplate, 3431 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 3432 unsigned NumExplicitlySpecified, FunctionDecl *&Specialization, 3433 TemplateDeductionInfo &Info, 3434 SmallVectorImpl<OriginalCallArg> const *OriginalCallArgs, 3435 bool PartialOverloading, llvm::function_ref<bool()> CheckNonDependent) { 3436 // Unevaluated SFINAE context. 3437 EnterExpressionEvaluationContext Unevaluated( 3438 *this, Sema::ExpressionEvaluationContext::Unevaluated); 3439 SFINAETrap Trap(*this); 3440 3441 // Enter a new template instantiation context while we instantiate the 3442 // actual function declaration. 3443 SmallVector<TemplateArgument, 4> DeducedArgs(Deduced.begin(), Deduced.end()); 3444 InstantiatingTemplate Inst( 3445 *this, Info.getLocation(), FunctionTemplate, DeducedArgs, 3446 CodeSynthesisContext::DeducedTemplateArgumentSubstitution, Info); 3447 if (Inst.isInvalid()) 3448 return TDK_InstantiationDepth; 3449 3450 ContextRAII SavedContext(*this, FunctionTemplate->getTemplatedDecl()); 3451 3452 // C++ [temp.deduct.type]p2: 3453 // [...] or if any template argument remains neither deduced nor 3454 // explicitly specified, template argument deduction fails. 3455 SmallVector<TemplateArgument, 4> Builder; 3456 if (auto Result = ConvertDeducedTemplateArguments( 3457 *this, FunctionTemplate, /*IsDeduced*/true, Deduced, Info, Builder, 3458 CurrentInstantiationScope, NumExplicitlySpecified, 3459 PartialOverloading)) 3460 return Result; 3461 3462 // C++ [temp.deduct.call]p10: [DR1391] 3463 // If deduction succeeds for all parameters that contain 3464 // template-parameters that participate in template argument deduction, 3465 // and all template arguments are explicitly specified, deduced, or 3466 // obtained from default template arguments, remaining parameters are then 3467 // compared with the corresponding arguments. For each remaining parameter 3468 // P with a type that was non-dependent before substitution of any 3469 // explicitly-specified template arguments, if the corresponding argument 3470 // A cannot be implicitly converted to P, deduction fails. 3471 if (CheckNonDependent()) 3472 return TDK_NonDependentConversionFailure; 3473 3474 // Form the template argument list from the deduced template arguments. 3475 TemplateArgumentList *DeducedArgumentList 3476 = TemplateArgumentList::CreateCopy(Context, Builder); 3477 Info.reset(DeducedArgumentList); 3478 3479 // Substitute the deduced template arguments into the function template 3480 // declaration to produce the function template specialization. 3481 DeclContext *Owner = FunctionTemplate->getDeclContext(); 3482 if (FunctionTemplate->getFriendObjectKind()) 3483 Owner = FunctionTemplate->getLexicalDeclContext(); 3484 MultiLevelTemplateArgumentList SubstArgs(*DeducedArgumentList); 3485 Specialization = cast_or_null<FunctionDecl>( 3486 SubstDecl(FunctionTemplate->getTemplatedDecl(), Owner, SubstArgs)); 3487 if (!Specialization || Specialization->isInvalidDecl()) 3488 return TDK_SubstitutionFailure; 3489 3490 assert(Specialization->getPrimaryTemplate()->getCanonicalDecl() == 3491 FunctionTemplate->getCanonicalDecl()); 3492 3493 // If the template argument list is owned by the function template 3494 // specialization, release it. 3495 if (Specialization->getTemplateSpecializationArgs() == DeducedArgumentList && 3496 !Trap.hasErrorOccurred()) 3497 Info.take(); 3498 3499 // There may have been an error that did not prevent us from constructing a 3500 // declaration. Mark the declaration invalid and return with a substitution 3501 // failure. 3502 if (Trap.hasErrorOccurred()) { 3503 Specialization->setInvalidDecl(true); 3504 return TDK_SubstitutionFailure; 3505 } 3506 3507 // C++2a [temp.deduct]p5 3508 // [...] When all template arguments have been deduced [...] all uses of 3509 // template parameters [...] are replaced with the corresponding deduced 3510 // or default argument values. 3511 // [...] If the function template has associated constraints 3512 // ([temp.constr.decl]), those constraints are checked for satisfaction 3513 // ([temp.constr.constr]). If the constraints are not satisfied, type 3514 // deduction fails. 3515 if (!PartialOverloading || 3516 (Builder.size() == FunctionTemplate->getTemplateParameters()->size())) { 3517 if (CheckInstantiatedFunctionTemplateConstraints(Info.getLocation(), 3518 Specialization, Builder, Info.AssociatedConstraintsSatisfaction)) 3519 return TDK_MiscellaneousDeductionFailure; 3520 3521 if (!Info.AssociatedConstraintsSatisfaction.IsSatisfied) { 3522 Info.reset(TemplateArgumentList::CreateCopy(Context, Builder)); 3523 return TDK_ConstraintsNotSatisfied; 3524 } 3525 } 3526 3527 if (OriginalCallArgs) { 3528 // C++ [temp.deduct.call]p4: 3529 // In general, the deduction process attempts to find template argument 3530 // values that will make the deduced A identical to A (after the type A 3531 // is transformed as described above). [...] 3532 llvm::SmallDenseMap<std::pair<unsigned, QualType>, QualType> DeducedATypes; 3533 for (unsigned I = 0, N = OriginalCallArgs->size(); I != N; ++I) { 3534 OriginalCallArg OriginalArg = (*OriginalCallArgs)[I]; 3535 3536 auto ParamIdx = OriginalArg.ArgIdx; 3537 if (ParamIdx >= Specialization->getNumParams()) 3538 // FIXME: This presumably means a pack ended up smaller than we 3539 // expected while deducing. Should this not result in deduction 3540 // failure? Can it even happen? 3541 continue; 3542 3543 QualType DeducedA; 3544 if (!OriginalArg.DecomposedParam) { 3545 // P is one of the function parameters, just look up its substituted 3546 // type. 3547 DeducedA = Specialization->getParamDecl(ParamIdx)->getType(); 3548 } else { 3549 // P is a decomposed element of a parameter corresponding to a 3550 // braced-init-list argument. Substitute back into P to find the 3551 // deduced A. 3552 QualType &CacheEntry = 3553 DeducedATypes[{ParamIdx, OriginalArg.OriginalParamType}]; 3554 if (CacheEntry.isNull()) { 3555 ArgumentPackSubstitutionIndexRAII PackIndex( 3556 *this, getPackIndexForParam(*this, FunctionTemplate, SubstArgs, 3557 ParamIdx)); 3558 CacheEntry = 3559 SubstType(OriginalArg.OriginalParamType, SubstArgs, 3560 Specialization->getTypeSpecStartLoc(), 3561 Specialization->getDeclName()); 3562 } 3563 DeducedA = CacheEntry; 3564 } 3565 3566 if (auto TDK = 3567 CheckOriginalCallArgDeduction(*this, Info, OriginalArg, DeducedA)) 3568 return TDK; 3569 } 3570 } 3571 3572 // If we suppressed any diagnostics while performing template argument 3573 // deduction, and if we haven't already instantiated this declaration, 3574 // keep track of these diagnostics. They'll be emitted if this specialization 3575 // is actually used. 3576 if (Info.diag_begin() != Info.diag_end()) { 3577 SuppressedDiagnosticsMap::iterator 3578 Pos = SuppressedDiagnostics.find(Specialization->getCanonicalDecl()); 3579 if (Pos == SuppressedDiagnostics.end()) 3580 SuppressedDiagnostics[Specialization->getCanonicalDecl()] 3581 .append(Info.diag_begin(), Info.diag_end()); 3582 } 3583 3584 return TDK_Success; 3585 } 3586 3587 /// Gets the type of a function for template-argument-deducton 3588 /// purposes when it's considered as part of an overload set. 3589 static QualType GetTypeOfFunction(Sema &S, const OverloadExpr::FindResult &R, 3590 FunctionDecl *Fn) { 3591 // We may need to deduce the return type of the function now. 3592 if (S.getLangOpts().CPlusPlus14 && Fn->getReturnType()->isUndeducedType() && 3593 S.DeduceReturnType(Fn, R.Expression->getExprLoc(), /*Diagnose*/ false)) 3594 return {}; 3595 3596 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Fn)) 3597 if (Method->isInstance()) { 3598 // An instance method that's referenced in a form that doesn't 3599 // look like a member pointer is just invalid. 3600 if (!R.HasFormOfMemberPointer) 3601 return {}; 3602 3603 return S.Context.getMemberPointerType(Fn->getType(), 3604 S.Context.getTypeDeclType(Method->getParent()).getTypePtr()); 3605 } 3606 3607 if (!R.IsAddressOfOperand) return Fn->getType(); 3608 return S.Context.getPointerType(Fn->getType()); 3609 } 3610 3611 /// Apply the deduction rules for overload sets. 3612 /// 3613 /// \return the null type if this argument should be treated as an 3614 /// undeduced context 3615 static QualType 3616 ResolveOverloadForDeduction(Sema &S, TemplateParameterList *TemplateParams, 3617 Expr *Arg, QualType ParamType, 3618 bool ParamWasReference) { 3619 3620 OverloadExpr::FindResult R = OverloadExpr::find(Arg); 3621 3622 OverloadExpr *Ovl = R.Expression; 3623 3624 // C++0x [temp.deduct.call]p4 3625 unsigned TDF = 0; 3626 if (ParamWasReference) 3627 TDF |= TDF_ParamWithReferenceType; 3628 if (R.IsAddressOfOperand) 3629 TDF |= TDF_IgnoreQualifiers; 3630 3631 // C++0x [temp.deduct.call]p6: 3632 // When P is a function type, pointer to function type, or pointer 3633 // to member function type: 3634 3635 if (!ParamType->isFunctionType() && 3636 !ParamType->isFunctionPointerType() && 3637 !ParamType->isMemberFunctionPointerType()) { 3638 if (Ovl->hasExplicitTemplateArgs()) { 3639 // But we can still look for an explicit specialization. 3640 if (FunctionDecl *ExplicitSpec 3641 = S.ResolveSingleFunctionTemplateSpecialization(Ovl)) 3642 return GetTypeOfFunction(S, R, ExplicitSpec); 3643 } 3644 3645 DeclAccessPair DAP; 3646 if (FunctionDecl *Viable = 3647 S.resolveAddressOfSingleOverloadCandidate(Arg, DAP)) 3648 return GetTypeOfFunction(S, R, Viable); 3649 3650 return {}; 3651 } 3652 3653 // Gather the explicit template arguments, if any. 3654 TemplateArgumentListInfo ExplicitTemplateArgs; 3655 if (Ovl->hasExplicitTemplateArgs()) 3656 Ovl->copyTemplateArgumentsInto(ExplicitTemplateArgs); 3657 QualType Match; 3658 for (UnresolvedSetIterator I = Ovl->decls_begin(), 3659 E = Ovl->decls_end(); I != E; ++I) { 3660 NamedDecl *D = (*I)->getUnderlyingDecl(); 3661 3662 if (FunctionTemplateDecl *FunTmpl = dyn_cast<FunctionTemplateDecl>(D)) { 3663 // - If the argument is an overload set containing one or more 3664 // function templates, the parameter is treated as a 3665 // non-deduced context. 3666 if (!Ovl->hasExplicitTemplateArgs()) 3667 return {}; 3668 3669 // Otherwise, see if we can resolve a function type 3670 FunctionDecl *Specialization = nullptr; 3671 TemplateDeductionInfo Info(Ovl->getNameLoc()); 3672 if (S.DeduceTemplateArguments(FunTmpl, &ExplicitTemplateArgs, 3673 Specialization, Info)) 3674 continue; 3675 3676 D = Specialization; 3677 } 3678 3679 FunctionDecl *Fn = cast<FunctionDecl>(D); 3680 QualType ArgType = GetTypeOfFunction(S, R, Fn); 3681 if (ArgType.isNull()) continue; 3682 3683 // Function-to-pointer conversion. 3684 if (!ParamWasReference && ParamType->isPointerType() && 3685 ArgType->isFunctionType()) 3686 ArgType = S.Context.getPointerType(ArgType); 3687 3688 // - If the argument is an overload set (not containing function 3689 // templates), trial argument deduction is attempted using each 3690 // of the members of the set. If deduction succeeds for only one 3691 // of the overload set members, that member is used as the 3692 // argument value for the deduction. If deduction succeeds for 3693 // more than one member of the overload set the parameter is 3694 // treated as a non-deduced context. 3695 3696 // We do all of this in a fresh context per C++0x [temp.deduct.type]p2: 3697 // Type deduction is done independently for each P/A pair, and 3698 // the deduced template argument values are then combined. 3699 // So we do not reject deductions which were made elsewhere. 3700 SmallVector<DeducedTemplateArgument, 8> 3701 Deduced(TemplateParams->size()); 3702 TemplateDeductionInfo Info(Ovl->getNameLoc()); 3703 Sema::TemplateDeductionResult Result 3704 = DeduceTemplateArgumentsByTypeMatch(S, TemplateParams, ParamType, 3705 ArgType, Info, Deduced, TDF); 3706 if (Result) continue; 3707 if (!Match.isNull()) 3708 return {}; 3709 Match = ArgType; 3710 } 3711 3712 return Match; 3713 } 3714 3715 /// Perform the adjustments to the parameter and argument types 3716 /// described in C++ [temp.deduct.call]. 3717 /// 3718 /// \returns true if the caller should not attempt to perform any template 3719 /// argument deduction based on this P/A pair because the argument is an 3720 /// overloaded function set that could not be resolved. 3721 static bool AdjustFunctionParmAndArgTypesForDeduction( 3722 Sema &S, TemplateParameterList *TemplateParams, unsigned FirstInnerIndex, 3723 QualType &ParamType, QualType &ArgType, Expr *Arg, unsigned &TDF) { 3724 // C++0x [temp.deduct.call]p3: 3725 // If P is a cv-qualified type, the top level cv-qualifiers of P's type 3726 // are ignored for type deduction. 3727 if (ParamType.hasQualifiers()) 3728 ParamType = ParamType.getUnqualifiedType(); 3729 3730 // [...] If P is a reference type, the type referred to by P is 3731 // used for type deduction. 3732 const ReferenceType *ParamRefType = ParamType->getAs<ReferenceType>(); 3733 if (ParamRefType) 3734 ParamType = ParamRefType->getPointeeType(); 3735 3736 // Overload sets usually make this parameter an undeduced context, 3737 // but there are sometimes special circumstances. Typically 3738 // involving a template-id-expr. 3739 if (ArgType == S.Context.OverloadTy) { 3740 ArgType = ResolveOverloadForDeduction(S, TemplateParams, 3741 Arg, ParamType, 3742 ParamRefType != nullptr); 3743 if (ArgType.isNull()) 3744 return true; 3745 } 3746 3747 if (ParamRefType) { 3748 // If the argument has incomplete array type, try to complete its type. 3749 if (ArgType->isIncompleteArrayType()) 3750 ArgType = S.getCompletedType(Arg); 3751 3752 // C++1z [temp.deduct.call]p3: 3753 // If P is a forwarding reference and the argument is an lvalue, the type 3754 // "lvalue reference to A" is used in place of A for type deduction. 3755 if (isForwardingReference(QualType(ParamRefType, 0), FirstInnerIndex) && 3756 Arg->isLValue()) { 3757 if (S.getLangOpts().OpenCL && !ArgType.hasAddressSpace()) 3758 ArgType = S.Context.getAddrSpaceQualType( 3759 ArgType, S.Context.getDefaultOpenCLPointeeAddrSpace()); 3760 ArgType = S.Context.getLValueReferenceType(ArgType); 3761 } 3762 } else { 3763 // C++ [temp.deduct.call]p2: 3764 // If P is not a reference type: 3765 // - If A is an array type, the pointer type produced by the 3766 // array-to-pointer standard conversion (4.2) is used in place of 3767 // A for type deduction; otherwise, 3768 if (ArgType->isArrayType()) 3769 ArgType = S.Context.getArrayDecayedType(ArgType); 3770 // - If A is a function type, the pointer type produced by the 3771 // function-to-pointer standard conversion (4.3) is used in place 3772 // of A for type deduction; otherwise, 3773 else if (ArgType->isFunctionType()) 3774 ArgType = S.Context.getPointerType(ArgType); 3775 else { 3776 // - If A is a cv-qualified type, the top level cv-qualifiers of A's 3777 // type are ignored for type deduction. 3778 ArgType = ArgType.getUnqualifiedType(); 3779 } 3780 } 3781 3782 // C++0x [temp.deduct.call]p4: 3783 // In general, the deduction process attempts to find template argument 3784 // values that will make the deduced A identical to A (after the type A 3785 // is transformed as described above). [...] 3786 TDF = TDF_SkipNonDependent; 3787 3788 // - If the original P is a reference type, the deduced A (i.e., the 3789 // type referred to by the reference) can be more cv-qualified than 3790 // the transformed A. 3791 if (ParamRefType) 3792 TDF |= TDF_ParamWithReferenceType; 3793 // - The transformed A can be another pointer or pointer to member 3794 // type that can be converted to the deduced A via a qualification 3795 // conversion (4.4). 3796 if (ArgType->isPointerType() || ArgType->isMemberPointerType() || 3797 ArgType->isObjCObjectPointerType()) 3798 TDF |= TDF_IgnoreQualifiers; 3799 // - If P is a class and P has the form simple-template-id, then the 3800 // transformed A can be a derived class of the deduced A. Likewise, 3801 // if P is a pointer to a class of the form simple-template-id, the 3802 // transformed A can be a pointer to a derived class pointed to by 3803 // the deduced A. 3804 if (isSimpleTemplateIdType(ParamType) || 3805 (isa<PointerType>(ParamType) && 3806 isSimpleTemplateIdType( 3807 ParamType->castAs<PointerType>()->getPointeeType()))) 3808 TDF |= TDF_DerivedClass; 3809 3810 return false; 3811 } 3812 3813 static bool 3814 hasDeducibleTemplateParameters(Sema &S, FunctionTemplateDecl *FunctionTemplate, 3815 QualType T); 3816 3817 static Sema::TemplateDeductionResult DeduceTemplateArgumentsFromCallArgument( 3818 Sema &S, TemplateParameterList *TemplateParams, unsigned FirstInnerIndex, 3819 QualType ParamType, Expr *Arg, TemplateDeductionInfo &Info, 3820 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 3821 SmallVectorImpl<Sema::OriginalCallArg> &OriginalCallArgs, 3822 bool DecomposedParam, unsigned ArgIdx, unsigned TDF); 3823 3824 /// Attempt template argument deduction from an initializer list 3825 /// deemed to be an argument in a function call. 3826 static Sema::TemplateDeductionResult DeduceFromInitializerList( 3827 Sema &S, TemplateParameterList *TemplateParams, QualType AdjustedParamType, 3828 InitListExpr *ILE, TemplateDeductionInfo &Info, 3829 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 3830 SmallVectorImpl<Sema::OriginalCallArg> &OriginalCallArgs, unsigned ArgIdx, 3831 unsigned TDF) { 3832 // C++ [temp.deduct.call]p1: (CWG 1591) 3833 // If removing references and cv-qualifiers from P gives 3834 // std::initializer_list<P0> or P0[N] for some P0 and N and the argument is 3835 // a non-empty initializer list, then deduction is performed instead for 3836 // each element of the initializer list, taking P0 as a function template 3837 // parameter type and the initializer element as its argument 3838 // 3839 // We've already removed references and cv-qualifiers here. 3840 if (!ILE->getNumInits()) 3841 return Sema::TDK_Success; 3842 3843 QualType ElTy; 3844 auto *ArrTy = S.Context.getAsArrayType(AdjustedParamType); 3845 if (ArrTy) 3846 ElTy = ArrTy->getElementType(); 3847 else if (!S.isStdInitializerList(AdjustedParamType, &ElTy)) { 3848 // Otherwise, an initializer list argument causes the parameter to be 3849 // considered a non-deduced context 3850 return Sema::TDK_Success; 3851 } 3852 3853 // Resolving a core issue: a braced-init-list containing any designators is 3854 // a non-deduced context. 3855 for (Expr *E : ILE->inits()) 3856 if (isa<DesignatedInitExpr>(E)) 3857 return Sema::TDK_Success; 3858 3859 // Deduction only needs to be done for dependent types. 3860 if (ElTy->isDependentType()) { 3861 for (Expr *E : ILE->inits()) { 3862 if (auto Result = DeduceTemplateArgumentsFromCallArgument( 3863 S, TemplateParams, 0, ElTy, E, Info, Deduced, OriginalCallArgs, true, 3864 ArgIdx, TDF)) 3865 return Result; 3866 } 3867 } 3868 3869 // in the P0[N] case, if N is a non-type template parameter, N is deduced 3870 // from the length of the initializer list. 3871 if (auto *DependentArrTy = dyn_cast_or_null<DependentSizedArrayType>(ArrTy)) { 3872 // Determine the array bound is something we can deduce. 3873 if (const NonTypeTemplateParmDecl *NTTP = 3874 getDeducedParameterFromExpr(Info, DependentArrTy->getSizeExpr())) { 3875 // We can perform template argument deduction for the given non-type 3876 // template parameter. 3877 // C++ [temp.deduct.type]p13: 3878 // The type of N in the type T[N] is std::size_t. 3879 QualType T = S.Context.getSizeType(); 3880 llvm::APInt Size(S.Context.getIntWidth(T), ILE->getNumInits()); 3881 if (auto Result = DeduceNonTypeTemplateArgument( 3882 S, TemplateParams, NTTP, llvm::APSInt(Size), T, 3883 /*ArrayBound=*/true, Info, Deduced)) 3884 return Result; 3885 } 3886 } 3887 3888 return Sema::TDK_Success; 3889 } 3890 3891 /// Perform template argument deduction per [temp.deduct.call] for a 3892 /// single parameter / argument pair. 3893 static Sema::TemplateDeductionResult DeduceTemplateArgumentsFromCallArgument( 3894 Sema &S, TemplateParameterList *TemplateParams, unsigned FirstInnerIndex, 3895 QualType ParamType, Expr *Arg, TemplateDeductionInfo &Info, 3896 SmallVectorImpl<DeducedTemplateArgument> &Deduced, 3897 SmallVectorImpl<Sema::OriginalCallArg> &OriginalCallArgs, 3898 bool DecomposedParam, unsigned ArgIdx, unsigned TDF) { 3899 QualType ArgType = Arg->getType(); 3900 QualType OrigParamType = ParamType; 3901 3902 // If P is a reference type [...] 3903 // If P is a cv-qualified type [...] 3904 if (AdjustFunctionParmAndArgTypesForDeduction( 3905 S, TemplateParams, FirstInnerIndex, ParamType, ArgType, Arg, TDF)) 3906 return Sema::TDK_Success; 3907 3908 // If [...] the argument is a non-empty initializer list [...] 3909 if (InitListExpr *ILE = dyn_cast<InitListExpr>(Arg)) 3910 return DeduceFromInitializerList(S, TemplateParams, ParamType, ILE, Info, 3911 Deduced, OriginalCallArgs, ArgIdx, TDF); 3912 3913 // [...] the deduction process attempts to find template argument values 3914 // that will make the deduced A identical to A 3915 // 3916 // Keep track of the argument type and corresponding parameter index, 3917 // so we can check for compatibility between the deduced A and A. 3918 OriginalCallArgs.push_back( 3919 Sema::OriginalCallArg(OrigParamType, DecomposedParam, ArgIdx, ArgType)); 3920 return DeduceTemplateArgumentsByTypeMatch(S, TemplateParams, ParamType, 3921 ArgType, Info, Deduced, TDF); 3922 } 3923 3924 /// Perform template argument deduction from a function call 3925 /// (C++ [temp.deduct.call]). 3926 /// 3927 /// \param FunctionTemplate the function template for which we are performing 3928 /// template argument deduction. 3929 /// 3930 /// \param ExplicitTemplateArgs the explicit template arguments provided 3931 /// for this call. 3932 /// 3933 /// \param Args the function call arguments 3934 /// 3935 /// \param Specialization if template argument deduction was successful, 3936 /// this will be set to the function template specialization produced by 3937 /// template argument deduction. 3938 /// 3939 /// \param Info the argument will be updated to provide additional information 3940 /// about template argument deduction. 3941 /// 3942 /// \param CheckNonDependent A callback to invoke to check conversions for 3943 /// non-dependent parameters, between deduction and substitution, per DR1391. 3944 /// If this returns true, substitution will be skipped and we return 3945 /// TDK_NonDependentConversionFailure. The callback is passed the parameter 3946 /// types (after substituting explicit template arguments). 3947 /// 3948 /// \returns the result of template argument deduction. 3949 Sema::TemplateDeductionResult Sema::DeduceTemplateArguments( 3950 FunctionTemplateDecl *FunctionTemplate, 3951 TemplateArgumentListInfo *ExplicitTemplateArgs, ArrayRef<Expr *> Args, 3952 FunctionDecl *&Specialization, TemplateDeductionInfo &Info, 3953 bool PartialOverloading, 3954 llvm::function_ref<bool(ArrayRef<QualType>)> CheckNonDependent) { 3955 if (FunctionTemplate->isInvalidDecl()) 3956 return TDK_Invalid; 3957 3958 FunctionDecl *Function = FunctionTemplate->getTemplatedDecl(); 3959 unsigned NumParams = Function->getNumParams(); 3960 3961 unsigned FirstInnerIndex = getFirstInnerIndex(FunctionTemplate); 3962 3963 // C++ [temp.deduct.call]p1: 3964 // Template argument deduction is done by comparing each function template 3965 // parameter type (call it P) with the type of the corresponding argument 3966 // of the call (call it A) as described below. 3967 if (Args.size() < Function->getMinRequiredArguments() && !PartialOverloading) 3968 return TDK_TooFewArguments; 3969 else if (TooManyArguments(NumParams, Args.size(), PartialOverloading)) { 3970 const auto *Proto = Function->getType()->castAs<FunctionProtoType>(); 3971 if (Proto->isTemplateVariadic()) 3972 /* Do nothing */; 3973 else if (!Proto->isVariadic()) 3974 return TDK_TooManyArguments; 3975 } 3976 3977 // The types of the parameters from which we will perform template argument 3978 // deduction. 3979 LocalInstantiationScope InstScope(*this); 3980 TemplateParameterList *TemplateParams 3981 = FunctionTemplate->getTemplateParameters(); 3982 SmallVector<DeducedTemplateArgument, 4> Deduced; 3983 SmallVector<QualType, 8> ParamTypes; 3984 unsigned NumExplicitlySpecified = 0; 3985 if (ExplicitTemplateArgs) { 3986 TemplateDeductionResult Result; 3987 runWithSufficientStackSpace(Info.getLocation(), [&] { 3988 Result = SubstituteExplicitTemplateArguments( 3989 FunctionTemplate, *ExplicitTemplateArgs, Deduced, ParamTypes, nullptr, 3990 Info); 3991 }); 3992 if (Result) 3993 return Result; 3994 3995 NumExplicitlySpecified = Deduced.size(); 3996 } else { 3997 // Just fill in the parameter types from the function declaration. 3998 for (unsigned I = 0; I != NumParams; ++I) 3999 ParamTypes.push_back(Function->getParamDecl(I)->getType()); 4000 } 4001 4002 SmallVector<OriginalCallArg, 8> OriginalCallArgs; 4003 4004 // Deduce an argument of type ParamType from an expression with index ArgIdx. 4005 auto DeduceCallArgument = [&](QualType ParamType, unsigned ArgIdx) { 4006 // C++ [demp.deduct.call]p1: (DR1391) 4007 // Template argument deduction is done by comparing each function template 4008 // parameter that contains template-parameters that participate in 4009 // template argument deduction ... 4010 if (!hasDeducibleTemplateParameters(*this, FunctionTemplate, ParamType)) 4011 return Sema::TDK_Success; 4012 4013 // ... with the type of the corresponding argument 4014 return DeduceTemplateArgumentsFromCallArgument( 4015 *this, TemplateParams, FirstInnerIndex, ParamType, Args[ArgIdx], Info, Deduced, 4016 OriginalCallArgs, /*Decomposed*/false, ArgIdx, /*TDF*/ 0); 4017 }; 4018 4019 // Deduce template arguments from the function parameters. 4020 Deduced.resize(TemplateParams->size()); 4021 SmallVector<QualType, 8> ParamTypesForArgChecking; 4022 for (unsigned ParamIdx = 0, NumParamTypes = ParamTypes.size(), ArgIdx = 0; 4023 ParamIdx != NumParamTypes; ++ParamIdx) { 4024 QualType ParamType = ParamTypes[ParamIdx]; 4025 4026 const PackExpansionType *ParamExpansion = 4027 dyn_cast<PackExpansionType>(ParamType); 4028 if (!ParamExpansion) { 4029 // Simple case: matching a function parameter to a function argument. 4030 if (ArgIdx >= Args.size()) 4031 break; 4032 4033 ParamTypesForArgChecking.push_back(ParamType); 4034 if (auto Result = DeduceCallArgument(ParamType, ArgIdx++)) 4035 return Result; 4036 4037 continue; 4038 } 4039 4040 QualType ParamPattern = ParamExpansion->getPattern(); 4041 PackDeductionScope PackScope(*this, TemplateParams, Deduced, Info, 4042 ParamPattern); 4043 4044 // C++0x [temp.deduct.call]p1: 4045 // For a function parameter pack that occurs at the end of the 4046 // parameter-declaration-list, the type A of each remaining argument of 4047 // the call is compared with the type P of the declarator-id of the 4048 // function parameter pack. Each comparison deduces template arguments 4049 // for subsequent positions in the template parameter packs expanded by 4050 // the function parameter pack. When a function parameter pack appears 4051 // in a non-deduced context [not at the end of the list], the type of 4052 // that parameter pack is never deduced. 4053 // 4054 // FIXME: The above rule allows the size of the parameter pack to change 4055 // after we skip it (in the non-deduced case). That makes no sense, so 4056 // we instead notionally deduce the pack against N arguments, where N is 4057 // the length of the explicitly-specified pack if it's expanded by the 4058 // parameter pack and 0 otherwise, and we treat each deduction as a 4059 // non-deduced context. 4060 if (ParamIdx + 1 == NumParamTypes || PackScope.hasFixedArity()) { 4061 for (; ArgIdx < Args.size() && PackScope.hasNextElement(); 4062 PackScope.nextPackElement(), ++ArgIdx) { 4063 ParamTypesForArgChecking.push_back(ParamPattern); 4064 if (auto Result = DeduceCallArgument(ParamPattern, ArgIdx)) 4065 return Result; 4066 } 4067 } else { 4068 // If the parameter type contains an explicitly-specified pack that we 4069 // could not expand, skip the number of parameters notionally created 4070 // by the expansion. 4071 Optional<unsigned> NumExpansions = ParamExpansion->getNumExpansions(); 4072 if (NumExpansions && !PackScope.isPartiallyExpanded()) { 4073 for (unsigned I = 0; I != *NumExpansions && ArgIdx < Args.size(); 4074 ++I, ++ArgIdx) { 4075 ParamTypesForArgChecking.push_back(ParamPattern); 4076 // FIXME: Should we add OriginalCallArgs for these? What if the 4077 // corresponding argument is a list? 4078 PackScope.nextPackElement(); 4079 } 4080 } 4081 } 4082 4083 // Build argument packs for each of the parameter packs expanded by this 4084 // pack expansion. 4085 if (auto Result = PackScope.finish()) 4086 return Result; 4087 } 4088 4089 // Capture the context in which the function call is made. This is the context 4090 // that is needed when the accessibility of template arguments is checked. 4091 DeclContext *CallingCtx = CurContext; 4092 4093 TemplateDeductionResult Result; 4094 runWithSufficientStackSpace(Info.getLocation(), [&] { 4095 Result = FinishTemplateArgumentDeduction( 4096 FunctionTemplate, Deduced, NumExplicitlySpecified, Specialization, Info, 4097 &OriginalCallArgs, PartialOverloading, [&, CallingCtx]() { 4098 ContextRAII SavedContext(*this, CallingCtx); 4099 return CheckNonDependent(ParamTypesForArgChecking); 4100 }); 4101 }); 4102 return Result; 4103 } 4104 4105 QualType Sema::adjustCCAndNoReturn(QualType ArgFunctionType, 4106 QualType FunctionType, 4107 bool AdjustExceptionSpec) { 4108 if (ArgFunctionType.isNull()) 4109 return ArgFunctionType; 4110 4111 const auto *FunctionTypeP = FunctionType->castAs<FunctionProtoType>(); 4112 const auto *ArgFunctionTypeP = ArgFunctionType->castAs<FunctionProtoType>(); 4113 FunctionProtoType::ExtProtoInfo EPI = ArgFunctionTypeP->getExtProtoInfo(); 4114 bool Rebuild = false; 4115 4116 CallingConv CC = FunctionTypeP->getCallConv(); 4117 if (EPI.ExtInfo.getCC() != CC) { 4118 EPI.ExtInfo = EPI.ExtInfo.withCallingConv(CC); 4119 Rebuild = true; 4120 } 4121 4122 bool NoReturn = FunctionTypeP->getNoReturnAttr(); 4123 if (EPI.ExtInfo.getNoReturn() != NoReturn) { 4124 EPI.ExtInfo = EPI.ExtInfo.withNoReturn(NoReturn); 4125 Rebuild = true; 4126 } 4127 4128 if (AdjustExceptionSpec && (FunctionTypeP->hasExceptionSpec() || 4129 ArgFunctionTypeP->hasExceptionSpec())) { 4130 EPI.ExceptionSpec = FunctionTypeP->getExtProtoInfo().ExceptionSpec; 4131 Rebuild = true; 4132 } 4133 4134 if (!Rebuild) 4135 return ArgFunctionType; 4136 4137 return Context.getFunctionType(ArgFunctionTypeP->getReturnType(), 4138 ArgFunctionTypeP->getParamTypes(), EPI); 4139 } 4140 4141 /// Deduce template arguments when taking the address of a function 4142 /// template (C++ [temp.deduct.funcaddr]) or matching a specialization to 4143 /// a template. 4144 /// 4145 /// \param FunctionTemplate the function template for which we are performing 4146 /// template argument deduction. 4147 /// 4148 /// \param ExplicitTemplateArgs the explicitly-specified template 4149 /// arguments. 4150 /// 4151 /// \param ArgFunctionType the function type that will be used as the 4152 /// "argument" type (A) when performing template argument deduction from the 4153 /// function template's function type. This type may be NULL, if there is no 4154 /// argument type to compare against, in C++0x [temp.arg.explicit]p3. 4155 /// 4156 /// \param Specialization if template argument deduction was successful, 4157 /// this will be set to the function template specialization produced by 4158 /// template argument deduction. 4159 /// 4160 /// \param Info the argument will be updated to provide additional information 4161 /// about template argument deduction. 4162 /// 4163 /// \param IsAddressOfFunction If \c true, we are deducing as part of taking 4164 /// the address of a function template per [temp.deduct.funcaddr] and 4165 /// [over.over]. If \c false, we are looking up a function template 4166 /// specialization based on its signature, per [temp.deduct.decl]. 4167 /// 4168 /// \returns the result of template argument deduction. 4169 Sema::TemplateDeductionResult Sema::DeduceTemplateArguments( 4170 FunctionTemplateDecl *FunctionTemplate, 4171 TemplateArgumentListInfo *ExplicitTemplateArgs, QualType ArgFunctionType, 4172 FunctionDecl *&Specialization, TemplateDeductionInfo &Info, 4173 bool IsAddressOfFunction) { 4174 if (FunctionTemplate->isInvalidDecl()) 4175 return TDK_Invalid; 4176 4177 FunctionDecl *Function = FunctionTemplate->getTemplatedDecl(); 4178 TemplateParameterList *TemplateParams 4179 = FunctionTemplate->getTemplateParameters(); 4180 QualType FunctionType = Function->getType(); 4181 4182 // Substitute any explicit template arguments. 4183 LocalInstantiationScope InstScope(*this); 4184 SmallVector<DeducedTemplateArgument, 4> Deduced; 4185 unsigned NumExplicitlySpecified = 0; 4186 SmallVector<QualType, 4> ParamTypes; 4187 if (ExplicitTemplateArgs) { 4188 TemplateDeductionResult Result; 4189 runWithSufficientStackSpace(Info.getLocation(), [&] { 4190 Result = SubstituteExplicitTemplateArguments( 4191 FunctionTemplate, *ExplicitTemplateArgs, Deduced, ParamTypes, 4192 &FunctionType, Info); 4193 }); 4194 if (Result) 4195 return Result; 4196 4197 NumExplicitlySpecified = Deduced.size(); 4198 } 4199 4200 // When taking the address of a function, we require convertibility of 4201 // the resulting function type. Otherwise, we allow arbitrary mismatches 4202 // of calling convention and noreturn. 4203 if (!IsAddressOfFunction) 4204 ArgFunctionType = adjustCCAndNoReturn(ArgFunctionType, FunctionType, 4205 /*AdjustExceptionSpec*/false); 4206 4207 // Unevaluated SFINAE context. 4208 EnterExpressionEvaluationContext Unevaluated( 4209 *this, Sema::ExpressionEvaluationContext::Unevaluated); 4210 SFINAETrap Trap(*this); 4211 4212 Deduced.resize(TemplateParams->size()); 4213 4214 // If the function has a deduced return type, substitute it for a dependent 4215 // type so that we treat it as a non-deduced context in what follows. If we 4216 // are looking up by signature, the signature type should also have a deduced 4217 // return type, which we instead expect to exactly match. 4218 bool HasDeducedReturnType = false; 4219 if (getLangOpts().CPlusPlus14 && IsAddressOfFunction && 4220 Function->getReturnType()->getContainedAutoType()) { 4221 FunctionType = SubstAutoTypeDependent(FunctionType); 4222 HasDeducedReturnType = true; 4223 } 4224 4225 if (!ArgFunctionType.isNull() && !FunctionType.isNull()) { 4226 unsigned TDF = 4227 TDF_TopLevelParameterTypeList | TDF_AllowCompatibleFunctionType; 4228 // Deduce template arguments from the function type. 4229 if (TemplateDeductionResult Result 4230 = DeduceTemplateArgumentsByTypeMatch(*this, TemplateParams, 4231 FunctionType, ArgFunctionType, 4232 Info, Deduced, TDF)) 4233 return Result; 4234 } 4235 4236 TemplateDeductionResult Result; 4237 runWithSufficientStackSpace(Info.getLocation(), [&] { 4238 Result = FinishTemplateArgumentDeduction(FunctionTemplate, Deduced, 4239 NumExplicitlySpecified, 4240 Specialization, Info); 4241 }); 4242 if (Result) 4243 return Result; 4244 4245 // If the function has a deduced return type, deduce it now, so we can check 4246 // that the deduced function type matches the requested type. 4247 if (HasDeducedReturnType && 4248 Specialization->getReturnType()->isUndeducedType() && 4249 DeduceReturnType(Specialization, Info.getLocation(), false)) 4250 return TDK_MiscellaneousDeductionFailure; 4251 4252 // If the function has a dependent exception specification, resolve it now, 4253 // so we can check that the exception specification matches. 4254 auto *SpecializationFPT = 4255 Specialization->getType()->castAs<FunctionProtoType>(); 4256 if (getLangOpts().CPlusPlus17 && 4257 isUnresolvedExceptionSpec(SpecializationFPT->getExceptionSpecType()) && 4258 !ResolveExceptionSpec(Info.getLocation(), SpecializationFPT)) 4259 return TDK_MiscellaneousDeductionFailure; 4260 4261 // Adjust the exception specification of the argument to match the 4262 // substituted and resolved type we just formed. (Calling convention and 4263 // noreturn can't be dependent, so we don't actually need this for them 4264 // right now.) 4265 QualType SpecializationType = Specialization->getType(); 4266 if (!IsAddressOfFunction) 4267 ArgFunctionType = adjustCCAndNoReturn(ArgFunctionType, SpecializationType, 4268 /*AdjustExceptionSpec*/true); 4269 4270 // If the requested function type does not match the actual type of the 4271 // specialization with respect to arguments of compatible pointer to function 4272 // types, template argument deduction fails. 4273 if (!ArgFunctionType.isNull()) { 4274 if (IsAddressOfFunction && 4275 !isSameOrCompatibleFunctionType( 4276 Context.getCanonicalType(SpecializationType), 4277 Context.getCanonicalType(ArgFunctionType))) 4278 return TDK_MiscellaneousDeductionFailure; 4279 4280 if (!IsAddressOfFunction && 4281 !Context.hasSameType(SpecializationType, ArgFunctionType)) 4282 return TDK_MiscellaneousDeductionFailure; 4283 } 4284 4285 return TDK_Success; 4286 } 4287 4288 /// Deduce template arguments for a templated conversion 4289 /// function (C++ [temp.deduct.conv]) and, if successful, produce a 4290 /// conversion function template specialization. 4291 Sema::TemplateDeductionResult 4292 Sema::DeduceTemplateArguments(FunctionTemplateDecl *ConversionTemplate, 4293 QualType ToType, 4294 CXXConversionDecl *&Specialization, 4295 TemplateDeductionInfo &Info) { 4296 if (ConversionTemplate->isInvalidDecl()) 4297 return TDK_Invalid; 4298 4299 CXXConversionDecl *ConversionGeneric 4300 = cast<CXXConversionDecl>(ConversionTemplate->getTemplatedDecl()); 4301 4302 QualType FromType = ConversionGeneric->getConversionType(); 4303 4304 // Canonicalize the types for deduction. 4305 QualType P = Context.getCanonicalType(FromType); 4306 QualType A = Context.getCanonicalType(ToType); 4307 4308 // C++0x [temp.deduct.conv]p2: 4309 // If P is a reference type, the type referred to by P is used for 4310 // type deduction. 4311 if (const ReferenceType *PRef = P->getAs<ReferenceType>()) 4312 P = PRef->getPointeeType(); 4313 4314 // C++0x [temp.deduct.conv]p4: 4315 // [...] If A is a reference type, the type referred to by A is used 4316 // for type deduction. 4317 if (const ReferenceType *ARef = A->getAs<ReferenceType>()) { 4318 A = ARef->getPointeeType(); 4319 // We work around a defect in the standard here: cv-qualifiers are also 4320 // removed from P and A in this case, unless P was a reference type. This 4321 // seems to mostly match what other compilers are doing. 4322 if (!FromType->getAs<ReferenceType>()) { 4323 A = A.getUnqualifiedType(); 4324 P = P.getUnqualifiedType(); 4325 } 4326 4327 // C++ [temp.deduct.conv]p3: 4328 // 4329 // If A is not a reference type: 4330 } else { 4331 assert(!A->isReferenceType() && "Reference types were handled above"); 4332 4333 // - If P is an array type, the pointer type produced by the 4334 // array-to-pointer standard conversion (4.2) is used in place 4335 // of P for type deduction; otherwise, 4336 if (P->isArrayType()) 4337 P = Context.getArrayDecayedType(P); 4338 // - If P is a function type, the pointer type produced by the 4339 // function-to-pointer standard conversion (4.3) is used in 4340 // place of P for type deduction; otherwise, 4341 else if (P->isFunctionType()) 4342 P = Context.getPointerType(P); 4343 // - If P is a cv-qualified type, the top level cv-qualifiers of 4344 // P's type are ignored for type deduction. 4345 else 4346 P = P.getUnqualifiedType(); 4347 4348 // C++0x [temp.deduct.conv]p4: 4349 // If A is a cv-qualified type, the top level cv-qualifiers of A's 4350 // type are ignored for type deduction. If A is a reference type, the type 4351 // referred to by A is used for type deduction. 4352 A = A.getUnqualifiedType(); 4353 } 4354 4355 // Unevaluated SFINAE context. 4356 EnterExpressionEvaluationContext Unevaluated( 4357 *this, Sema::ExpressionEvaluationContext::Unevaluated); 4358 SFINAETrap Trap(*this); 4359 4360 // C++ [temp.deduct.conv]p1: 4361 // Template argument deduction is done by comparing the return 4362 // type of the template conversion function (call it P) with the 4363 // type that is required as the result of the conversion (call it 4364 // A) as described in 14.8.2.4. 4365 TemplateParameterList *TemplateParams 4366 = ConversionTemplate->getTemplateParameters(); 4367 SmallVector<DeducedTemplateArgument, 4> Deduced; 4368 Deduced.resize(TemplateParams->size()); 4369 4370 // C++0x [temp.deduct.conv]p4: 4371 // In general, the deduction process attempts to find template 4372 // argument values that will make the deduced A identical to 4373 // A. However, there are two cases that allow a difference: 4374 unsigned TDF = 0; 4375 // - If the original A is a reference type, A can be more 4376 // cv-qualified than the deduced A (i.e., the type referred to 4377 // by the reference) 4378 if (ToType->isReferenceType()) 4379 TDF |= TDF_ArgWithReferenceType; 4380 // - The deduced A can be another pointer or pointer to member 4381 // type that can be converted to A via a qualification 4382 // conversion. 4383 // 4384 // (C++0x [temp.deduct.conv]p6 clarifies that this only happens when 4385 // both P and A are pointers or member pointers. In this case, we 4386 // just ignore cv-qualifiers completely). 4387 if ((P->isPointerType() && A->isPointerType()) || 4388 (P->isMemberPointerType() && A->isMemberPointerType())) 4389 TDF |= TDF_IgnoreQualifiers; 4390 if (TemplateDeductionResult Result 4391 = DeduceTemplateArgumentsByTypeMatch(*this, TemplateParams, 4392 P, A, Info, Deduced, TDF)) 4393 return Result; 4394 4395 // Create an Instantiation Scope for finalizing the operator. 4396 LocalInstantiationScope InstScope(*this); 4397 // Finish template argument deduction. 4398 FunctionDecl *ConversionSpecialized = nullptr; 4399 TemplateDeductionResult Result; 4400 runWithSufficientStackSpace(Info.getLocation(), [&] { 4401 Result = FinishTemplateArgumentDeduction(ConversionTemplate, Deduced, 0, 4402 ConversionSpecialized, Info); 4403 }); 4404 Specialization = cast_or_null<CXXConversionDecl>(ConversionSpecialized); 4405 return Result; 4406 } 4407 4408 /// Deduce template arguments for a function template when there is 4409 /// nothing to deduce against (C++0x [temp.arg.explicit]p3). 4410 /// 4411 /// \param FunctionTemplate the function template for which we are performing 4412 /// template argument deduction. 4413 /// 4414 /// \param ExplicitTemplateArgs the explicitly-specified template 4415 /// arguments. 4416 /// 4417 /// \param Specialization if template argument deduction was successful, 4418 /// this will be set to the function template specialization produced by 4419 /// template argument deduction. 4420 /// 4421 /// \param Info the argument will be updated to provide additional information 4422 /// about template argument deduction. 4423 /// 4424 /// \param IsAddressOfFunction If \c true, we are deducing as part of taking 4425 /// the address of a function template in a context where we do not have a 4426 /// target type, per [over.over]. If \c false, we are looking up a function 4427 /// template specialization based on its signature, which only happens when 4428 /// deducing a function parameter type from an argument that is a template-id 4429 /// naming a function template specialization. 4430 /// 4431 /// \returns the result of template argument deduction. 4432 Sema::TemplateDeductionResult Sema::DeduceTemplateArguments( 4433 FunctionTemplateDecl *FunctionTemplate, 4434 TemplateArgumentListInfo *ExplicitTemplateArgs, 4435 FunctionDecl *&Specialization, TemplateDeductionInfo &Info, 4436 bool IsAddressOfFunction) { 4437 return DeduceTemplateArguments(FunctionTemplate, ExplicitTemplateArgs, 4438 QualType(), Specialization, Info, 4439 IsAddressOfFunction); 4440 } 4441 4442 namespace { 4443 struct DependentAuto { bool IsPack; }; 4444 4445 /// Substitute the 'auto' specifier or deduced template specialization type 4446 /// specifier within a type for a given replacement type. 4447 class SubstituteDeducedTypeTransform : 4448 public TreeTransform<SubstituteDeducedTypeTransform> { 4449 QualType Replacement; 4450 bool ReplacementIsPack; 4451 bool UseTypeSugar; 4452 4453 public: 4454 SubstituteDeducedTypeTransform(Sema &SemaRef, DependentAuto DA) 4455 : TreeTransform<SubstituteDeducedTypeTransform>(SemaRef), 4456 ReplacementIsPack(DA.IsPack), UseTypeSugar(true) {} 4457 4458 SubstituteDeducedTypeTransform(Sema &SemaRef, QualType Replacement, 4459 bool UseTypeSugar = true) 4460 : TreeTransform<SubstituteDeducedTypeTransform>(SemaRef), 4461 Replacement(Replacement), ReplacementIsPack(false), 4462 UseTypeSugar(UseTypeSugar) {} 4463 4464 QualType TransformDesugared(TypeLocBuilder &TLB, DeducedTypeLoc TL) { 4465 assert(isa<TemplateTypeParmType>(Replacement) && 4466 "unexpected unsugared replacement kind"); 4467 QualType Result = Replacement; 4468 TemplateTypeParmTypeLoc NewTL = TLB.push<TemplateTypeParmTypeLoc>(Result); 4469 NewTL.setNameLoc(TL.getNameLoc()); 4470 return Result; 4471 } 4472 4473 QualType TransformAutoType(TypeLocBuilder &TLB, AutoTypeLoc TL) { 4474 // If we're building the type pattern to deduce against, don't wrap the 4475 // substituted type in an AutoType. Certain template deduction rules 4476 // apply only when a template type parameter appears directly (and not if 4477 // the parameter is found through desugaring). For instance: 4478 // auto &&lref = lvalue; 4479 // must transform into "rvalue reference to T" not "rvalue reference to 4480 // auto type deduced as T" in order for [temp.deduct.call]p3 to apply. 4481 // 4482 // FIXME: Is this still necessary? 4483 if (!UseTypeSugar) 4484 return TransformDesugared(TLB, TL); 4485 4486 QualType Result = SemaRef.Context.getAutoType( 4487 Replacement, TL.getTypePtr()->getKeyword(), Replacement.isNull(), 4488 ReplacementIsPack, TL.getTypePtr()->getTypeConstraintConcept(), 4489 TL.getTypePtr()->getTypeConstraintArguments()); 4490 auto NewTL = TLB.push<AutoTypeLoc>(Result); 4491 NewTL.copy(TL); 4492 return Result; 4493 } 4494 4495 QualType TransformDeducedTemplateSpecializationType( 4496 TypeLocBuilder &TLB, DeducedTemplateSpecializationTypeLoc TL) { 4497 if (!UseTypeSugar) 4498 return TransformDesugared(TLB, TL); 4499 4500 QualType Result = SemaRef.Context.getDeducedTemplateSpecializationType( 4501 TL.getTypePtr()->getTemplateName(), 4502 Replacement, Replacement.isNull()); 4503 auto NewTL = TLB.push<DeducedTemplateSpecializationTypeLoc>(Result); 4504 NewTL.setNameLoc(TL.getNameLoc()); 4505 return Result; 4506 } 4507 4508 ExprResult TransformLambdaExpr(LambdaExpr *E) { 4509 // Lambdas never need to be transformed. 4510 return E; 4511 } 4512 4513 QualType Apply(TypeLoc TL) { 4514 // Create some scratch storage for the transformed type locations. 4515 // FIXME: We're just going to throw this information away. Don't build it. 4516 TypeLocBuilder TLB; 4517 TLB.reserve(TL.getFullDataSize()); 4518 return TransformType(TLB, TL); 4519 } 4520 }; 4521 4522 } // namespace 4523 4524 Sema::DeduceAutoResult 4525 Sema::DeduceAutoType(TypeSourceInfo *Type, Expr *&Init, QualType &Result, 4526 Optional<unsigned> DependentDeductionDepth, 4527 bool IgnoreConstraints) { 4528 return DeduceAutoType(Type->getTypeLoc(), Init, Result, 4529 DependentDeductionDepth, IgnoreConstraints); 4530 } 4531 4532 /// Attempt to produce an informative diagostic explaining why auto deduction 4533 /// failed. 4534 /// \return \c true if diagnosed, \c false if not. 4535 static bool diagnoseAutoDeductionFailure(Sema &S, 4536 Sema::TemplateDeductionResult TDK, 4537 TemplateDeductionInfo &Info, 4538 ArrayRef<SourceRange> Ranges) { 4539 switch (TDK) { 4540 case Sema::TDK_Inconsistent: { 4541 // Inconsistent deduction means we were deducing from an initializer list. 4542 auto D = S.Diag(Info.getLocation(), diag::err_auto_inconsistent_deduction); 4543 D << Info.FirstArg << Info.SecondArg; 4544 for (auto R : Ranges) 4545 D << R; 4546 return true; 4547 } 4548 4549 // FIXME: Are there other cases for which a custom diagnostic is more useful 4550 // than the basic "types don't match" diagnostic? 4551 4552 default: 4553 return false; 4554 } 4555 } 4556 4557 static Sema::DeduceAutoResult 4558 CheckDeducedPlaceholderConstraints(Sema &S, const AutoType &Type, 4559 AutoTypeLoc TypeLoc, QualType Deduced) { 4560 ConstraintSatisfaction Satisfaction; 4561 ConceptDecl *Concept = Type.getTypeConstraintConcept(); 4562 TemplateArgumentListInfo TemplateArgs(TypeLoc.getLAngleLoc(), 4563 TypeLoc.getRAngleLoc()); 4564 TemplateArgs.addArgument( 4565 TemplateArgumentLoc(TemplateArgument(Deduced), 4566 S.Context.getTrivialTypeSourceInfo( 4567 Deduced, TypeLoc.getNameLoc()))); 4568 for (unsigned I = 0, C = TypeLoc.getNumArgs(); I != C; ++I) 4569 TemplateArgs.addArgument(TypeLoc.getArgLoc(I)); 4570 4571 llvm::SmallVector<TemplateArgument, 4> Converted; 4572 if (S.CheckTemplateArgumentList(Concept, SourceLocation(), TemplateArgs, 4573 /*PartialTemplateArgs=*/false, Converted)) 4574 return Sema::DAR_FailedAlreadyDiagnosed; 4575 if (S.CheckConstraintSatisfaction(Concept, {Concept->getConstraintExpr()}, 4576 Converted, TypeLoc.getLocalSourceRange(), 4577 Satisfaction)) 4578 return Sema::DAR_FailedAlreadyDiagnosed; 4579 if (!Satisfaction.IsSatisfied) { 4580 std::string Buf; 4581 llvm::raw_string_ostream OS(Buf); 4582 OS << "'" << Concept->getName(); 4583 if (TypeLoc.hasExplicitTemplateArgs()) { 4584 printTemplateArgumentList( 4585 OS, Type.getTypeConstraintArguments(), S.getPrintingPolicy(), 4586 Type.getTypeConstraintConcept()->getTemplateParameters()); 4587 } 4588 OS << "'"; 4589 OS.flush(); 4590 S.Diag(TypeLoc.getConceptNameLoc(), 4591 diag::err_placeholder_constraints_not_satisfied) 4592 << Deduced << Buf << TypeLoc.getLocalSourceRange(); 4593 S.DiagnoseUnsatisfiedConstraint(Satisfaction); 4594 return Sema::DAR_FailedAlreadyDiagnosed; 4595 } 4596 return Sema::DAR_Succeeded; 4597 } 4598 4599 /// Deduce the type for an auto type-specifier (C++11 [dcl.spec.auto]p6) 4600 /// 4601 /// Note that this is done even if the initializer is dependent. (This is 4602 /// necessary to support partial ordering of templates using 'auto'.) 4603 /// A dependent type will be produced when deducing from a dependent type. 4604 /// 4605 /// \param Type the type pattern using the auto type-specifier. 4606 /// \param Init the initializer for the variable whose type is to be deduced. 4607 /// \param Result if type deduction was successful, this will be set to the 4608 /// deduced type. 4609 /// \param DependentDeductionDepth Set if we should permit deduction in 4610 /// dependent cases. This is necessary for template partial ordering with 4611 /// 'auto' template parameters. The value specified is the template 4612 /// parameter depth at which we should perform 'auto' deduction. 4613 /// \param IgnoreConstraints Set if we should not fail if the deduced type does 4614 /// not satisfy the type-constraint in the auto type. 4615 Sema::DeduceAutoResult 4616 Sema::DeduceAutoType(TypeLoc Type, Expr *&Init, QualType &Result, 4617 Optional<unsigned> DependentDeductionDepth, 4618 bool IgnoreConstraints) { 4619 if (Init->containsErrors()) 4620 return DAR_FailedAlreadyDiagnosed; 4621 if (Init->getType()->isNonOverloadPlaceholderType()) { 4622 ExprResult NonPlaceholder = CheckPlaceholderExpr(Init); 4623 if (NonPlaceholder.isInvalid()) 4624 return DAR_FailedAlreadyDiagnosed; 4625 Init = NonPlaceholder.get(); 4626 } 4627 4628 DependentAuto DependentResult = { 4629 /*.IsPack = */ (bool)Type.getAs<PackExpansionTypeLoc>()}; 4630 4631 if (!DependentDeductionDepth && 4632 (Type.getType()->isDependentType() || Init->isTypeDependent() || 4633 Init->containsUnexpandedParameterPack())) { 4634 Result = SubstituteDeducedTypeTransform(*this, DependentResult).Apply(Type); 4635 assert(!Result.isNull() && "substituting DependentTy can't fail"); 4636 return DAR_Succeeded; 4637 } 4638 4639 // Find the depth of template parameter to synthesize. 4640 unsigned Depth = DependentDeductionDepth.value_or(0); 4641 4642 // If this is a 'decltype(auto)' specifier, do the decltype dance. 4643 // Since 'decltype(auto)' can only occur at the top of the type, we 4644 // don't need to go digging for it. 4645 if (const AutoType *AT = Type.getType()->getAs<AutoType>()) { 4646 if (AT->isDecltypeAuto()) { 4647 if (isa<InitListExpr>(Init)) { 4648 Diag(Init->getBeginLoc(), diag::err_decltype_auto_initializer_list); 4649 return DAR_FailedAlreadyDiagnosed; 4650 } 4651 4652 ExprResult ER = CheckPlaceholderExpr(Init); 4653 if (ER.isInvalid()) 4654 return DAR_FailedAlreadyDiagnosed; 4655 QualType Deduced = getDecltypeForExpr(ER.get()); 4656 assert(!Deduced.isNull()); 4657 if (AT->isConstrained() && !IgnoreConstraints) { 4658 auto ConstraintsResult = 4659 CheckDeducedPlaceholderConstraints(*this, *AT, 4660 Type.getContainedAutoTypeLoc(), 4661 Deduced); 4662 if (ConstraintsResult != DAR_Succeeded) 4663 return ConstraintsResult; 4664 } 4665 Result = SubstituteDeducedTypeTransform(*this, Deduced).Apply(Type); 4666 if (Result.isNull()) 4667 return DAR_FailedAlreadyDiagnosed; 4668 return DAR_Succeeded; 4669 } else if (!getLangOpts().CPlusPlus) { 4670 if (isa<InitListExpr>(Init)) { 4671 Diag(Init->getBeginLoc(), diag::err_auto_init_list_from_c); 4672 return DAR_FailedAlreadyDiagnosed; 4673 } 4674 } 4675 } 4676 4677 SourceLocation Loc = Init->getExprLoc(); 4678 4679 LocalInstantiationScope InstScope(*this); 4680 4681 // Build template<class TemplParam> void Func(FuncParam); 4682 TemplateTypeParmDecl *TemplParam = TemplateTypeParmDecl::Create( 4683 Context, nullptr, SourceLocation(), Loc, Depth, 0, nullptr, false, false, 4684 false); 4685 QualType TemplArg = QualType(TemplParam->getTypeForDecl(), 0); 4686 NamedDecl *TemplParamPtr = TemplParam; 4687 FixedSizeTemplateParameterListStorage<1, false> TemplateParamsSt( 4688 Context, Loc, Loc, TemplParamPtr, Loc, nullptr); 4689 4690 QualType FuncParam = 4691 SubstituteDeducedTypeTransform(*this, TemplArg, /*UseTypeSugar*/ true) 4692 .Apply(Type); 4693 assert(!FuncParam.isNull() && 4694 "substituting template parameter for 'auto' failed"); 4695 4696 // Deduce type of TemplParam in Func(Init) 4697 SmallVector<DeducedTemplateArgument, 1> Deduced; 4698 Deduced.resize(1); 4699 4700 TemplateDeductionInfo Info(Loc, Depth); 4701 4702 // If deduction failed, don't diagnose if the initializer is dependent; it 4703 // might acquire a matching type in the instantiation. 4704 auto DeductionFailed = [&](TemplateDeductionResult TDK, 4705 ArrayRef<SourceRange> Ranges) -> DeduceAutoResult { 4706 if (Init->isTypeDependent()) { 4707 Result = 4708 SubstituteDeducedTypeTransform(*this, DependentResult).Apply(Type); 4709 assert(!Result.isNull() && "substituting DependentTy can't fail"); 4710 return DAR_Succeeded; 4711 } 4712 if (diagnoseAutoDeductionFailure(*this, TDK, Info, Ranges)) 4713 return DAR_FailedAlreadyDiagnosed; 4714 return DAR_Failed; 4715 }; 4716 4717 SmallVector<OriginalCallArg, 4> OriginalCallArgs; 4718 4719 InitListExpr *InitList = dyn_cast<InitListExpr>(Init); 4720 if (InitList) { 4721 // Notionally, we substitute std::initializer_list<T> for 'auto' and deduce 4722 // against that. Such deduction only succeeds if removing cv-qualifiers and 4723 // references results in std::initializer_list<T>. 4724 if (!Type.getType().getNonReferenceType()->getAs<AutoType>()) 4725 return DAR_Failed; 4726 4727 // Resolving a core issue: a braced-init-list containing any designators is 4728 // a non-deduced context. 4729 for (Expr *E : InitList->inits()) 4730 if (isa<DesignatedInitExpr>(E)) 4731 return DAR_Failed; 4732 4733 SourceRange DeducedFromInitRange; 4734 for (unsigned i = 0, e = InitList->getNumInits(); i < e; ++i) { 4735 Expr *Init = InitList->getInit(i); 4736 4737 if (auto TDK = DeduceTemplateArgumentsFromCallArgument( 4738 *this, TemplateParamsSt.get(), 0, TemplArg, Init, 4739 Info, Deduced, OriginalCallArgs, /*Decomposed*/ true, 4740 /*ArgIdx*/ 0, /*TDF*/ 0)) 4741 return DeductionFailed(TDK, {DeducedFromInitRange, 4742 Init->getSourceRange()}); 4743 4744 if (DeducedFromInitRange.isInvalid() && 4745 Deduced[0].getKind() != TemplateArgument::Null) 4746 DeducedFromInitRange = Init->getSourceRange(); 4747 } 4748 } else { 4749 if (!getLangOpts().CPlusPlus && Init->refersToBitField()) { 4750 Diag(Loc, diag::err_auto_bitfield); 4751 return DAR_FailedAlreadyDiagnosed; 4752 } 4753 4754 if (auto TDK = DeduceTemplateArgumentsFromCallArgument( 4755 *this, TemplateParamsSt.get(), 0, FuncParam, Init, Info, Deduced, 4756 OriginalCallArgs, /*Decomposed*/ false, /*ArgIdx*/ 0, /*TDF*/ 0)) 4757 return DeductionFailed(TDK, {}); 4758 } 4759 4760 // Could be null if somehow 'auto' appears in a non-deduced context. 4761 if (Deduced[0].getKind() != TemplateArgument::Type) 4762 return DeductionFailed(TDK_Incomplete, {}); 4763 4764 QualType DeducedType = Deduced[0].getAsType(); 4765 4766 if (InitList) { 4767 DeducedType = BuildStdInitializerList(DeducedType, Loc); 4768 if (DeducedType.isNull()) 4769 return DAR_FailedAlreadyDiagnosed; 4770 } 4771 4772 QualType MaybeAuto = Type.getType().getNonReferenceType(); 4773 while (MaybeAuto->isPointerType()) 4774 MaybeAuto = MaybeAuto->getPointeeType(); 4775 if (const auto *AT = MaybeAuto->getAs<AutoType>()) { 4776 if (AT->isConstrained() && !IgnoreConstraints) { 4777 auto ConstraintsResult = CheckDeducedPlaceholderConstraints( 4778 *this, *AT, Type.getContainedAutoTypeLoc(), DeducedType); 4779 if (ConstraintsResult != DAR_Succeeded) 4780 return ConstraintsResult; 4781 } 4782 } 4783 4784 Result = SubstituteDeducedTypeTransform(*this, DeducedType).Apply(Type); 4785 if (Result.isNull()) 4786 return DAR_FailedAlreadyDiagnosed; 4787 4788 // Check that the deduced argument type is compatible with the original 4789 // argument type per C++ [temp.deduct.call]p4. 4790 QualType DeducedA = InitList ? Deduced[0].getAsType() : Result; 4791 for (const OriginalCallArg &OriginalArg : OriginalCallArgs) { 4792 assert((bool)InitList == OriginalArg.DecomposedParam && 4793 "decomposed non-init-list in auto deduction?"); 4794 if (auto TDK = 4795 CheckOriginalCallArgDeduction(*this, Info, OriginalArg, DeducedA)) { 4796 Result = QualType(); 4797 return DeductionFailed(TDK, {}); 4798 } 4799 } 4800 4801 return DAR_Succeeded; 4802 } 4803 4804 QualType Sema::SubstAutoType(QualType TypeWithAuto, 4805 QualType TypeToReplaceAuto) { 4806 assert(TypeToReplaceAuto != Context.DependentTy); 4807 return SubstituteDeducedTypeTransform(*this, TypeToReplaceAuto) 4808 .TransformType(TypeWithAuto); 4809 } 4810 4811 TypeSourceInfo *Sema::SubstAutoTypeSourceInfo(TypeSourceInfo *TypeWithAuto, 4812 QualType TypeToReplaceAuto) { 4813 assert(TypeToReplaceAuto != Context.DependentTy); 4814 return SubstituteDeducedTypeTransform(*this, TypeToReplaceAuto) 4815 .TransformType(TypeWithAuto); 4816 } 4817 4818 QualType Sema::SubstAutoTypeDependent(QualType TypeWithAuto) { 4819 return SubstituteDeducedTypeTransform(*this, DependentAuto{false}) 4820 .TransformType(TypeWithAuto); 4821 } 4822 4823 TypeSourceInfo * 4824 Sema::SubstAutoTypeSourceInfoDependent(TypeSourceInfo *TypeWithAuto) { 4825 return SubstituteDeducedTypeTransform(*this, DependentAuto{false}) 4826 .TransformType(TypeWithAuto); 4827 } 4828 4829 QualType Sema::ReplaceAutoType(QualType TypeWithAuto, 4830 QualType TypeToReplaceAuto) { 4831 return SubstituteDeducedTypeTransform(*this, TypeToReplaceAuto, 4832 /*UseTypeSugar*/ false) 4833 .TransformType(TypeWithAuto); 4834 } 4835 4836 TypeSourceInfo *Sema::ReplaceAutoTypeSourceInfo(TypeSourceInfo *TypeWithAuto, 4837 QualType TypeToReplaceAuto) { 4838 return SubstituteDeducedTypeTransform(*this, TypeToReplaceAuto, 4839 /*UseTypeSugar*/ false) 4840 .TransformType(TypeWithAuto); 4841 } 4842 4843 void Sema::DiagnoseAutoDeductionFailure(VarDecl *VDecl, Expr *Init) { 4844 if (isa<InitListExpr>(Init)) 4845 Diag(VDecl->getLocation(), 4846 VDecl->isInitCapture() 4847 ? diag::err_init_capture_deduction_failure_from_init_list 4848 : diag::err_auto_var_deduction_failure_from_init_list) 4849 << VDecl->getDeclName() << VDecl->getType() << Init->getSourceRange(); 4850 else 4851 Diag(VDecl->getLocation(), 4852 VDecl->isInitCapture() ? diag::err_init_capture_deduction_failure 4853 : diag::err_auto_var_deduction_failure) 4854 << VDecl->getDeclName() << VDecl->getType() << Init->getType() 4855 << Init->getSourceRange(); 4856 } 4857 4858 bool Sema::DeduceReturnType(FunctionDecl *FD, SourceLocation Loc, 4859 bool Diagnose) { 4860 assert(FD->getReturnType()->isUndeducedType()); 4861 4862 // For a lambda's conversion operator, deduce any 'auto' or 'decltype(auto)' 4863 // within the return type from the call operator's type. 4864 if (isLambdaConversionOperator(FD)) { 4865 CXXRecordDecl *Lambda = cast<CXXMethodDecl>(FD)->getParent(); 4866 FunctionDecl *CallOp = Lambda->getLambdaCallOperator(); 4867 4868 // For a generic lambda, instantiate the call operator if needed. 4869 if (auto *Args = FD->getTemplateSpecializationArgs()) { 4870 CallOp = InstantiateFunctionDeclaration( 4871 CallOp->getDescribedFunctionTemplate(), Args, Loc); 4872 if (!CallOp || CallOp->isInvalidDecl()) 4873 return true; 4874 4875 // We might need to deduce the return type by instantiating the definition 4876 // of the operator() function. 4877 if (CallOp->getReturnType()->isUndeducedType()) { 4878 runWithSufficientStackSpace(Loc, [&] { 4879 InstantiateFunctionDefinition(Loc, CallOp); 4880 }); 4881 } 4882 } 4883 4884 if (CallOp->isInvalidDecl()) 4885 return true; 4886 assert(!CallOp->getReturnType()->isUndeducedType() && 4887 "failed to deduce lambda return type"); 4888 4889 // Build the new return type from scratch. 4890 CallingConv RetTyCC = FD->getReturnType() 4891 ->getPointeeType() 4892 ->castAs<FunctionType>() 4893 ->getCallConv(); 4894 QualType RetType = getLambdaConversionFunctionResultType( 4895 CallOp->getType()->castAs<FunctionProtoType>(), RetTyCC); 4896 if (FD->getReturnType()->getAs<PointerType>()) 4897 RetType = Context.getPointerType(RetType); 4898 else { 4899 assert(FD->getReturnType()->getAs<BlockPointerType>()); 4900 RetType = Context.getBlockPointerType(RetType); 4901 } 4902 Context.adjustDeducedFunctionResultType(FD, RetType); 4903 return false; 4904 } 4905 4906 if (FD->getTemplateInstantiationPattern()) { 4907 runWithSufficientStackSpace(Loc, [&] { 4908 InstantiateFunctionDefinition(Loc, FD); 4909 }); 4910 } 4911 4912 bool StillUndeduced = FD->getReturnType()->isUndeducedType(); 4913 if (StillUndeduced && Diagnose && !FD->isInvalidDecl()) { 4914 Diag(Loc, diag::err_auto_fn_used_before_defined) << FD; 4915 Diag(FD->getLocation(), diag::note_callee_decl) << FD; 4916 } 4917 4918 return StillUndeduced; 4919 } 4920 4921 /// If this is a non-static member function, 4922 static void 4923 AddImplicitObjectParameterType(ASTContext &Context, 4924 CXXMethodDecl *Method, 4925 SmallVectorImpl<QualType> &ArgTypes) { 4926 // C++11 [temp.func.order]p3: 4927 // [...] The new parameter is of type "reference to cv A," where cv are 4928 // the cv-qualifiers of the function template (if any) and A is 4929 // the class of which the function template is a member. 4930 // 4931 // The standard doesn't say explicitly, but we pick the appropriate kind of 4932 // reference type based on [over.match.funcs]p4. 4933 QualType ArgTy = Context.getTypeDeclType(Method->getParent()); 4934 ArgTy = Context.getQualifiedType(ArgTy, Method->getMethodQualifiers()); 4935 if (Method->getRefQualifier() == RQ_RValue) 4936 ArgTy = Context.getRValueReferenceType(ArgTy); 4937 else 4938 ArgTy = Context.getLValueReferenceType(ArgTy); 4939 ArgTypes.push_back(ArgTy); 4940 } 4941 4942 /// Determine whether the function template \p FT1 is at least as 4943 /// specialized as \p FT2. 4944 static bool isAtLeastAsSpecializedAs(Sema &S, 4945 SourceLocation Loc, 4946 FunctionTemplateDecl *FT1, 4947 FunctionTemplateDecl *FT2, 4948 TemplatePartialOrderingContext TPOC, 4949 unsigned NumCallArguments1, 4950 bool Reversed) { 4951 assert(!Reversed || TPOC == TPOC_Call); 4952 4953 FunctionDecl *FD1 = FT1->getTemplatedDecl(); 4954 FunctionDecl *FD2 = FT2->getTemplatedDecl(); 4955 const FunctionProtoType *Proto1 = FD1->getType()->getAs<FunctionProtoType>(); 4956 const FunctionProtoType *Proto2 = FD2->getType()->getAs<FunctionProtoType>(); 4957 4958 assert(Proto1 && Proto2 && "Function templates must have prototypes"); 4959 TemplateParameterList *TemplateParams = FT2->getTemplateParameters(); 4960 SmallVector<DeducedTemplateArgument, 4> Deduced; 4961 Deduced.resize(TemplateParams->size()); 4962 4963 // C++0x [temp.deduct.partial]p3: 4964 // The types used to determine the ordering depend on the context in which 4965 // the partial ordering is done: 4966 TemplateDeductionInfo Info(Loc); 4967 SmallVector<QualType, 4> Args2; 4968 switch (TPOC) { 4969 case TPOC_Call: { 4970 // - In the context of a function call, the function parameter types are 4971 // used. 4972 CXXMethodDecl *Method1 = dyn_cast<CXXMethodDecl>(FD1); 4973 CXXMethodDecl *Method2 = dyn_cast<CXXMethodDecl>(FD2); 4974 4975 // C++11 [temp.func.order]p3: 4976 // [...] If only one of the function templates is a non-static 4977 // member, that function template is considered to have a new 4978 // first parameter inserted in its function parameter list. The 4979 // new parameter is of type "reference to cv A," where cv are 4980 // the cv-qualifiers of the function template (if any) and A is 4981 // the class of which the function template is a member. 4982 // 4983 // Note that we interpret this to mean "if one of the function 4984 // templates is a non-static member and the other is a non-member"; 4985 // otherwise, the ordering rules for static functions against non-static 4986 // functions don't make any sense. 4987 // 4988 // C++98/03 doesn't have this provision but we've extended DR532 to cover 4989 // it as wording was broken prior to it. 4990 SmallVector<QualType, 4> Args1; 4991 4992 unsigned NumComparedArguments = NumCallArguments1; 4993 4994 if (!Method2 && Method1 && !Method1->isStatic()) { 4995 // Compare 'this' from Method1 against first parameter from Method2. 4996 AddImplicitObjectParameterType(S.Context, Method1, Args1); 4997 ++NumComparedArguments; 4998 } else if (!Method1 && Method2 && !Method2->isStatic()) { 4999 // Compare 'this' from Method2 against first parameter from Method1. 5000 AddImplicitObjectParameterType(S.Context, Method2, Args2); 5001 } else if (Method1 && Method2 && Reversed) { 5002 // Compare 'this' from Method1 against second parameter from Method2 5003 // and 'this' from Method2 against second parameter from Method1. 5004 AddImplicitObjectParameterType(S.Context, Method1, Args1); 5005 AddImplicitObjectParameterType(S.Context, Method2, Args2); 5006 ++NumComparedArguments; 5007 } 5008 5009 Args1.insert(Args1.end(), Proto1->param_type_begin(), 5010 Proto1->param_type_end()); 5011 Args2.insert(Args2.end(), Proto2->param_type_begin(), 5012 Proto2->param_type_end()); 5013 5014 // C++ [temp.func.order]p5: 5015 // The presence of unused ellipsis and default arguments has no effect on 5016 // the partial ordering of function templates. 5017 if (Args1.size() > NumComparedArguments) 5018 Args1.resize(NumComparedArguments); 5019 if (Args2.size() > NumComparedArguments) 5020 Args2.resize(NumComparedArguments); 5021 if (Reversed) 5022 std::reverse(Args2.begin(), Args2.end()); 5023 5024 if (DeduceTemplateArguments(S, TemplateParams, Args2.data(), Args2.size(), 5025 Args1.data(), Args1.size(), Info, Deduced, 5026 TDF_None, /*PartialOrdering=*/true)) 5027 return false; 5028 5029 break; 5030 } 5031 5032 case TPOC_Conversion: 5033 // - In the context of a call to a conversion operator, the return types 5034 // of the conversion function templates are used. 5035 if (DeduceTemplateArgumentsByTypeMatch( 5036 S, TemplateParams, Proto2->getReturnType(), Proto1->getReturnType(), 5037 Info, Deduced, TDF_None, 5038 /*PartialOrdering=*/true)) 5039 return false; 5040 break; 5041 5042 case TPOC_Other: 5043 // - In other contexts (14.6.6.2) the function template's function type 5044 // is used. 5045 if (DeduceTemplateArgumentsByTypeMatch(S, TemplateParams, 5046 FD2->getType(), FD1->getType(), 5047 Info, Deduced, TDF_None, 5048 /*PartialOrdering=*/true)) 5049 return false; 5050 break; 5051 } 5052 5053 // C++0x [temp.deduct.partial]p11: 5054 // In most cases, all template parameters must have values in order for 5055 // deduction to succeed, but for partial ordering purposes a template 5056 // parameter may remain without a value provided it is not used in the 5057 // types being used for partial ordering. [ Note: a template parameter used 5058 // in a non-deduced context is considered used. -end note] 5059 unsigned ArgIdx = 0, NumArgs = Deduced.size(); 5060 for (; ArgIdx != NumArgs; ++ArgIdx) 5061 if (Deduced[ArgIdx].isNull()) 5062 break; 5063 5064 // FIXME: We fail to implement [temp.deduct.type]p1 along this path. We need 5065 // to substitute the deduced arguments back into the template and check that 5066 // we get the right type. 5067 5068 if (ArgIdx == NumArgs) { 5069 // All template arguments were deduced. FT1 is at least as specialized 5070 // as FT2. 5071 return true; 5072 } 5073 5074 // Figure out which template parameters were used. 5075 llvm::SmallBitVector UsedParameters(TemplateParams->size()); 5076 switch (TPOC) { 5077 case TPOC_Call: 5078 for (unsigned I = 0, N = Args2.size(); I != N; ++I) 5079 ::MarkUsedTemplateParameters(S.Context, Args2[I], false, 5080 TemplateParams->getDepth(), 5081 UsedParameters); 5082 break; 5083 5084 case TPOC_Conversion: 5085 ::MarkUsedTemplateParameters(S.Context, Proto2->getReturnType(), false, 5086 TemplateParams->getDepth(), UsedParameters); 5087 break; 5088 5089 case TPOC_Other: 5090 ::MarkUsedTemplateParameters(S.Context, FD2->getType(), false, 5091 TemplateParams->getDepth(), 5092 UsedParameters); 5093 break; 5094 } 5095 5096 for (; ArgIdx != NumArgs; ++ArgIdx) 5097 // If this argument had no value deduced but was used in one of the types 5098 // used for partial ordering, then deduction fails. 5099 if (Deduced[ArgIdx].isNull() && UsedParameters[ArgIdx]) 5100 return false; 5101 5102 return true; 5103 } 5104 5105 /// Determine whether this a function template whose parameter-type-list 5106 /// ends with a function parameter pack. 5107 static bool isVariadicFunctionTemplate(FunctionTemplateDecl *FunTmpl) { 5108 FunctionDecl *Function = FunTmpl->getTemplatedDecl(); 5109 unsigned NumParams = Function->getNumParams(); 5110 if (NumParams == 0) 5111 return false; 5112 5113 ParmVarDecl *Last = Function->getParamDecl(NumParams - 1); 5114 if (!Last->isParameterPack()) 5115 return false; 5116 5117 // Make sure that no previous parameter is a parameter pack. 5118 while (--NumParams > 0) { 5119 if (Function->getParamDecl(NumParams - 1)->isParameterPack()) 5120 return false; 5121 } 5122 5123 return true; 5124 } 5125 5126 /// Returns the more specialized function template according 5127 /// to the rules of function template partial ordering (C++ [temp.func.order]). 5128 /// 5129 /// \param FT1 the first function template 5130 /// 5131 /// \param FT2 the second function template 5132 /// 5133 /// \param TPOC the context in which we are performing partial ordering of 5134 /// function templates. 5135 /// 5136 /// \param NumCallArguments1 The number of arguments in the call to FT1, used 5137 /// only when \c TPOC is \c TPOC_Call. 5138 /// 5139 /// \param NumCallArguments2 The number of arguments in the call to FT2, used 5140 /// only when \c TPOC is \c TPOC_Call. 5141 /// 5142 /// \param Reversed If \c true, exactly one of FT1 and FT2 is an overload 5143 /// candidate with a reversed parameter order. In this case, the corresponding 5144 /// P/A pairs between FT1 and FT2 are reversed. 5145 /// 5146 /// \param AllowOrderingByConstraints If \c is false, don't check whether one 5147 /// of the templates is more constrained than the other. Default is true. 5148 /// 5149 /// \returns the more specialized function template. If neither 5150 /// template is more specialized, returns NULL. 5151 FunctionTemplateDecl *Sema::getMoreSpecializedTemplate( 5152 FunctionTemplateDecl *FT1, FunctionTemplateDecl *FT2, SourceLocation Loc, 5153 TemplatePartialOrderingContext TPOC, unsigned NumCallArguments1, 5154 unsigned NumCallArguments2, bool Reversed, 5155 bool AllowOrderingByConstraints) { 5156 5157 auto JudgeByConstraints = [&]() -> FunctionTemplateDecl * { 5158 if (!AllowOrderingByConstraints) 5159 return nullptr; 5160 llvm::SmallVector<const Expr *, 3> AC1, AC2; 5161 FT1->getAssociatedConstraints(AC1); 5162 FT2->getAssociatedConstraints(AC2); 5163 bool AtLeastAsConstrained1, AtLeastAsConstrained2; 5164 if (IsAtLeastAsConstrained(FT1, AC1, FT2, AC2, AtLeastAsConstrained1)) 5165 return nullptr; 5166 if (IsAtLeastAsConstrained(FT2, AC2, FT1, AC1, AtLeastAsConstrained2)) 5167 return nullptr; 5168 if (AtLeastAsConstrained1 == AtLeastAsConstrained2) 5169 return nullptr; 5170 return AtLeastAsConstrained1 ? FT1 : FT2; 5171 }; 5172 5173 bool Better1 = isAtLeastAsSpecializedAs(*this, Loc, FT1, FT2, TPOC, 5174 NumCallArguments1, Reversed); 5175 bool Better2 = isAtLeastAsSpecializedAs(*this, Loc, FT2, FT1, TPOC, 5176 NumCallArguments2, Reversed); 5177 5178 if (Better1 != Better2) // We have a clear winner 5179 return Better1 ? FT1 : FT2; 5180 5181 if (!Better1 && !Better2) // Neither is better than the other 5182 return JudgeByConstraints(); 5183 5184 // FIXME: This mimics what GCC implements, but doesn't match up with the 5185 // proposed resolution for core issue 692. This area needs to be sorted out, 5186 // but for now we attempt to maintain compatibility. 5187 bool Variadic1 = isVariadicFunctionTemplate(FT1); 5188 bool Variadic2 = isVariadicFunctionTemplate(FT2); 5189 if (Variadic1 != Variadic2) 5190 return Variadic1? FT2 : FT1; 5191 5192 return JudgeByConstraints(); 5193 } 5194 5195 /// Determine if the two templates are equivalent. 5196 static bool isSameTemplate(TemplateDecl *T1, TemplateDecl *T2) { 5197 if (T1 == T2) 5198 return true; 5199 5200 if (!T1 || !T2) 5201 return false; 5202 5203 return T1->getCanonicalDecl() == T2->getCanonicalDecl(); 5204 } 5205 5206 /// Retrieve the most specialized of the given function template 5207 /// specializations. 5208 /// 5209 /// \param SpecBegin the start iterator of the function template 5210 /// specializations that we will be comparing. 5211 /// 5212 /// \param SpecEnd the end iterator of the function template 5213 /// specializations, paired with \p SpecBegin. 5214 /// 5215 /// \param Loc the location where the ambiguity or no-specializations 5216 /// diagnostic should occur. 5217 /// 5218 /// \param NoneDiag partial diagnostic used to diagnose cases where there are 5219 /// no matching candidates. 5220 /// 5221 /// \param AmbigDiag partial diagnostic used to diagnose an ambiguity, if one 5222 /// occurs. 5223 /// 5224 /// \param CandidateDiag partial diagnostic used for each function template 5225 /// specialization that is a candidate in the ambiguous ordering. One parameter 5226 /// in this diagnostic should be unbound, which will correspond to the string 5227 /// describing the template arguments for the function template specialization. 5228 /// 5229 /// \returns the most specialized function template specialization, if 5230 /// found. Otherwise, returns SpecEnd. 5231 UnresolvedSetIterator Sema::getMostSpecialized( 5232 UnresolvedSetIterator SpecBegin, UnresolvedSetIterator SpecEnd, 5233 TemplateSpecCandidateSet &FailedCandidates, 5234 SourceLocation Loc, const PartialDiagnostic &NoneDiag, 5235 const PartialDiagnostic &AmbigDiag, const PartialDiagnostic &CandidateDiag, 5236 bool Complain, QualType TargetType) { 5237 if (SpecBegin == SpecEnd) { 5238 if (Complain) { 5239 Diag(Loc, NoneDiag); 5240 FailedCandidates.NoteCandidates(*this, Loc); 5241 } 5242 return SpecEnd; 5243 } 5244 5245 if (SpecBegin + 1 == SpecEnd) 5246 return SpecBegin; 5247 5248 // Find the function template that is better than all of the templates it 5249 // has been compared to. 5250 UnresolvedSetIterator Best = SpecBegin; 5251 FunctionTemplateDecl *BestTemplate 5252 = cast<FunctionDecl>(*Best)->getPrimaryTemplate(); 5253 assert(BestTemplate && "Not a function template specialization?"); 5254 for (UnresolvedSetIterator I = SpecBegin + 1; I != SpecEnd; ++I) { 5255 FunctionTemplateDecl *Challenger 5256 = cast<FunctionDecl>(*I)->getPrimaryTemplate(); 5257 assert(Challenger && "Not a function template specialization?"); 5258 if (isSameTemplate(getMoreSpecializedTemplate(BestTemplate, Challenger, 5259 Loc, TPOC_Other, 0, 0), 5260 Challenger)) { 5261 Best = I; 5262 BestTemplate = Challenger; 5263 } 5264 } 5265 5266 // Make sure that the "best" function template is more specialized than all 5267 // of the others. 5268 bool Ambiguous = false; 5269 for (UnresolvedSetIterator I = SpecBegin; I != SpecEnd; ++I) { 5270 FunctionTemplateDecl *Challenger 5271 = cast<FunctionDecl>(*I)->getPrimaryTemplate(); 5272 if (I != Best && 5273 !isSameTemplate(getMoreSpecializedTemplate(BestTemplate, Challenger, 5274 Loc, TPOC_Other, 0, 0), 5275 BestTemplate)) { 5276 Ambiguous = true; 5277 break; 5278 } 5279 } 5280 5281 if (!Ambiguous) { 5282 // We found an answer. Return it. 5283 return Best; 5284 } 5285 5286 // Diagnose the ambiguity. 5287 if (Complain) { 5288 Diag(Loc, AmbigDiag); 5289 5290 // FIXME: Can we order the candidates in some sane way? 5291 for (UnresolvedSetIterator I = SpecBegin; I != SpecEnd; ++I) { 5292 PartialDiagnostic PD = CandidateDiag; 5293 const auto *FD = cast<FunctionDecl>(*I); 5294 PD << FD << getTemplateArgumentBindingsText( 5295 FD->getPrimaryTemplate()->getTemplateParameters(), 5296 *FD->getTemplateSpecializationArgs()); 5297 if (!TargetType.isNull()) 5298 HandleFunctionTypeMismatch(PD, FD->getType(), TargetType); 5299 Diag((*I)->getLocation(), PD); 5300 } 5301 } 5302 5303 return SpecEnd; 5304 } 5305 5306 /// Determine whether one partial specialization, P1, is at least as 5307 /// specialized than another, P2. 5308 /// 5309 /// \tparam TemplateLikeDecl The kind of P2, which must be a 5310 /// TemplateDecl or {Class,Var}TemplatePartialSpecializationDecl. 5311 /// \param T1 The injected-class-name of P1 (faked for a variable template). 5312 /// \param T2 The injected-class-name of P2 (faked for a variable template). 5313 template<typename TemplateLikeDecl> 5314 static bool isAtLeastAsSpecializedAs(Sema &S, QualType T1, QualType T2, 5315 TemplateLikeDecl *P2, 5316 TemplateDeductionInfo &Info) { 5317 // C++ [temp.class.order]p1: 5318 // For two class template partial specializations, the first is at least as 5319 // specialized as the second if, given the following rewrite to two 5320 // function templates, the first function template is at least as 5321 // specialized as the second according to the ordering rules for function 5322 // templates (14.6.6.2): 5323 // - the first function template has the same template parameters as the 5324 // first partial specialization and has a single function parameter 5325 // whose type is a class template specialization with the template 5326 // arguments of the first partial specialization, and 5327 // - the second function template has the same template parameters as the 5328 // second partial specialization and has a single function parameter 5329 // whose type is a class template specialization with the template 5330 // arguments of the second partial specialization. 5331 // 5332 // Rather than synthesize function templates, we merely perform the 5333 // equivalent partial ordering by performing deduction directly on 5334 // the template arguments of the class template partial 5335 // specializations. This computation is slightly simpler than the 5336 // general problem of function template partial ordering, because 5337 // class template partial specializations are more constrained. We 5338 // know that every template parameter is deducible from the class 5339 // template partial specialization's template arguments, for 5340 // example. 5341 SmallVector<DeducedTemplateArgument, 4> Deduced; 5342 5343 // Determine whether P1 is at least as specialized as P2. 5344 Deduced.resize(P2->getTemplateParameters()->size()); 5345 if (DeduceTemplateArgumentsByTypeMatch(S, P2->getTemplateParameters(), 5346 T2, T1, Info, Deduced, TDF_None, 5347 /*PartialOrdering=*/true)) 5348 return false; 5349 5350 SmallVector<TemplateArgument, 4> DeducedArgs(Deduced.begin(), 5351 Deduced.end()); 5352 Sema::InstantiatingTemplate Inst(S, Info.getLocation(), P2, DeducedArgs, 5353 Info); 5354 if (Inst.isInvalid()) 5355 return false; 5356 5357 auto *TST1 = T1->castAs<TemplateSpecializationType>(); 5358 bool AtLeastAsSpecialized; 5359 S.runWithSufficientStackSpace(Info.getLocation(), [&] { 5360 AtLeastAsSpecialized = !FinishTemplateArgumentDeduction( 5361 S, P2, /*IsPartialOrdering=*/true, 5362 TemplateArgumentList(TemplateArgumentList::OnStack, 5363 TST1->template_arguments()), 5364 Deduced, Info); 5365 }); 5366 return AtLeastAsSpecialized; 5367 } 5368 5369 /// Returns the more specialized class template partial specialization 5370 /// according to the rules of partial ordering of class template partial 5371 /// specializations (C++ [temp.class.order]). 5372 /// 5373 /// \param PS1 the first class template partial specialization 5374 /// 5375 /// \param PS2 the second class template partial specialization 5376 /// 5377 /// \returns the more specialized class template partial specialization. If 5378 /// neither partial specialization is more specialized, returns NULL. 5379 ClassTemplatePartialSpecializationDecl * 5380 Sema::getMoreSpecializedPartialSpecialization( 5381 ClassTemplatePartialSpecializationDecl *PS1, 5382 ClassTemplatePartialSpecializationDecl *PS2, 5383 SourceLocation Loc) { 5384 QualType PT1 = PS1->getInjectedSpecializationType(); 5385 QualType PT2 = PS2->getInjectedSpecializationType(); 5386 5387 TemplateDeductionInfo Info(Loc); 5388 bool Better1 = isAtLeastAsSpecializedAs(*this, PT1, PT2, PS2, Info); 5389 bool Better2 = isAtLeastAsSpecializedAs(*this, PT2, PT1, PS1, Info); 5390 5391 if (!Better1 && !Better2) 5392 return nullptr; 5393 if (Better1 && Better2) { 5394 llvm::SmallVector<const Expr *, 3> AC1, AC2; 5395 PS1->getAssociatedConstraints(AC1); 5396 PS2->getAssociatedConstraints(AC2); 5397 bool AtLeastAsConstrained1, AtLeastAsConstrained2; 5398 if (IsAtLeastAsConstrained(PS1, AC1, PS2, AC2, AtLeastAsConstrained1)) 5399 return nullptr; 5400 if (IsAtLeastAsConstrained(PS2, AC2, PS1, AC1, AtLeastAsConstrained2)) 5401 return nullptr; 5402 if (AtLeastAsConstrained1 == AtLeastAsConstrained2) 5403 return nullptr; 5404 return AtLeastAsConstrained1 ? PS1 : PS2; 5405 } 5406 5407 return Better1 ? PS1 : PS2; 5408 } 5409 5410 bool Sema::isMoreSpecializedThanPrimary( 5411 ClassTemplatePartialSpecializationDecl *Spec, TemplateDeductionInfo &Info) { 5412 ClassTemplateDecl *Primary = Spec->getSpecializedTemplate(); 5413 QualType PrimaryT = Primary->getInjectedClassNameSpecialization(); 5414 QualType PartialT = Spec->getInjectedSpecializationType(); 5415 if (!isAtLeastAsSpecializedAs(*this, PartialT, PrimaryT, Primary, Info)) 5416 return false; 5417 if (!isAtLeastAsSpecializedAs(*this, PrimaryT, PartialT, Spec, Info)) 5418 return true; 5419 Info.clearSFINAEDiagnostic(); 5420 llvm::SmallVector<const Expr *, 3> PrimaryAC, SpecAC; 5421 Primary->getAssociatedConstraints(PrimaryAC); 5422 Spec->getAssociatedConstraints(SpecAC); 5423 bool AtLeastAsConstrainedPrimary, AtLeastAsConstrainedSpec; 5424 if (IsAtLeastAsConstrained(Spec, SpecAC, Primary, PrimaryAC, 5425 AtLeastAsConstrainedSpec)) 5426 return false; 5427 if (!AtLeastAsConstrainedSpec) 5428 return false; 5429 if (IsAtLeastAsConstrained(Primary, PrimaryAC, Spec, SpecAC, 5430 AtLeastAsConstrainedPrimary)) 5431 return false; 5432 return !AtLeastAsConstrainedPrimary; 5433 } 5434 5435 VarTemplatePartialSpecializationDecl * 5436 Sema::getMoreSpecializedPartialSpecialization( 5437 VarTemplatePartialSpecializationDecl *PS1, 5438 VarTemplatePartialSpecializationDecl *PS2, SourceLocation Loc) { 5439 // Pretend the variable template specializations are class template 5440 // specializations and form a fake injected class name type for comparison. 5441 assert(PS1->getSpecializedTemplate() == PS2->getSpecializedTemplate() && 5442 "the partial specializations being compared should specialize" 5443 " the same template."); 5444 TemplateName Name(PS1->getSpecializedTemplate()); 5445 TemplateName CanonTemplate = Context.getCanonicalTemplateName(Name); 5446 QualType PT1 = Context.getTemplateSpecializationType( 5447 CanonTemplate, PS1->getTemplateArgs().asArray()); 5448 QualType PT2 = Context.getTemplateSpecializationType( 5449 CanonTemplate, PS2->getTemplateArgs().asArray()); 5450 5451 TemplateDeductionInfo Info(Loc); 5452 bool Better1 = isAtLeastAsSpecializedAs(*this, PT1, PT2, PS2, Info); 5453 bool Better2 = isAtLeastAsSpecializedAs(*this, PT2, PT1, PS1, Info); 5454 5455 if (!Better1 && !Better2) 5456 return nullptr; 5457 if (Better1 && Better2) { 5458 llvm::SmallVector<const Expr *, 3> AC1, AC2; 5459 PS1->getAssociatedConstraints(AC1); 5460 PS2->getAssociatedConstraints(AC2); 5461 bool AtLeastAsConstrained1, AtLeastAsConstrained2; 5462 if (IsAtLeastAsConstrained(PS1, AC1, PS2, AC2, AtLeastAsConstrained1)) 5463 return nullptr; 5464 if (IsAtLeastAsConstrained(PS2, AC2, PS1, AC1, AtLeastAsConstrained2)) 5465 return nullptr; 5466 if (AtLeastAsConstrained1 == AtLeastAsConstrained2) 5467 return nullptr; 5468 return AtLeastAsConstrained1 ? PS1 : PS2; 5469 } 5470 5471 return Better1 ? PS1 : PS2; 5472 } 5473 5474 bool Sema::isMoreSpecializedThanPrimary( 5475 VarTemplatePartialSpecializationDecl *Spec, TemplateDeductionInfo &Info) { 5476 TemplateDecl *Primary = Spec->getSpecializedTemplate(); 5477 // FIXME: Cache the injected template arguments rather than recomputing 5478 // them for each partial specialization. 5479 SmallVector<TemplateArgument, 8> PrimaryArgs; 5480 Context.getInjectedTemplateArgs(Primary->getTemplateParameters(), 5481 PrimaryArgs); 5482 5483 TemplateName CanonTemplate = 5484 Context.getCanonicalTemplateName(TemplateName(Primary)); 5485 QualType PrimaryT = Context.getTemplateSpecializationType( 5486 CanonTemplate, PrimaryArgs); 5487 QualType PartialT = Context.getTemplateSpecializationType( 5488 CanonTemplate, Spec->getTemplateArgs().asArray()); 5489 5490 if (!isAtLeastAsSpecializedAs(*this, PartialT, PrimaryT, Primary, Info)) 5491 return false; 5492 if (!isAtLeastAsSpecializedAs(*this, PrimaryT, PartialT, Spec, Info)) 5493 return true; 5494 Info.clearSFINAEDiagnostic(); 5495 llvm::SmallVector<const Expr *, 3> PrimaryAC, SpecAC; 5496 Primary->getAssociatedConstraints(PrimaryAC); 5497 Spec->getAssociatedConstraints(SpecAC); 5498 bool AtLeastAsConstrainedPrimary, AtLeastAsConstrainedSpec; 5499 if (IsAtLeastAsConstrained(Spec, SpecAC, Primary, PrimaryAC, 5500 AtLeastAsConstrainedSpec)) 5501 return false; 5502 if (!AtLeastAsConstrainedSpec) 5503 return false; 5504 if (IsAtLeastAsConstrained(Primary, PrimaryAC, Spec, SpecAC, 5505 AtLeastAsConstrainedPrimary)) 5506 return false; 5507 return !AtLeastAsConstrainedPrimary; 5508 } 5509 5510 bool Sema::isTemplateTemplateParameterAtLeastAsSpecializedAs( 5511 TemplateParameterList *P, TemplateDecl *AArg, SourceLocation Loc) { 5512 // C++1z [temp.arg.template]p4: (DR 150) 5513 // A template template-parameter P is at least as specialized as a 5514 // template template-argument A if, given the following rewrite to two 5515 // function templates... 5516 5517 // Rather than synthesize function templates, we merely perform the 5518 // equivalent partial ordering by performing deduction directly on 5519 // the template parameter lists of the template template parameters. 5520 // 5521 // Given an invented class template X with the template parameter list of 5522 // A (including default arguments): 5523 TemplateName X = Context.getCanonicalTemplateName(TemplateName(AArg)); 5524 TemplateParameterList *A = AArg->getTemplateParameters(); 5525 5526 // - Each function template has a single function parameter whose type is 5527 // a specialization of X with template arguments corresponding to the 5528 // template parameters from the respective function template 5529 SmallVector<TemplateArgument, 8> AArgs; 5530 Context.getInjectedTemplateArgs(A, AArgs); 5531 5532 // Check P's arguments against A's parameter list. This will fill in default 5533 // template arguments as needed. AArgs are already correct by construction. 5534 // We can't just use CheckTemplateIdType because that will expand alias 5535 // templates. 5536 SmallVector<TemplateArgument, 4> PArgs; 5537 { 5538 SFINAETrap Trap(*this); 5539 5540 Context.getInjectedTemplateArgs(P, PArgs); 5541 TemplateArgumentListInfo PArgList(P->getLAngleLoc(), 5542 P->getRAngleLoc()); 5543 for (unsigned I = 0, N = P->size(); I != N; ++I) { 5544 // Unwrap packs that getInjectedTemplateArgs wrapped around pack 5545 // expansions, to form an "as written" argument list. 5546 TemplateArgument Arg = PArgs[I]; 5547 if (Arg.getKind() == TemplateArgument::Pack) { 5548 assert(Arg.pack_size() == 1 && Arg.pack_begin()->isPackExpansion()); 5549 Arg = *Arg.pack_begin(); 5550 } 5551 PArgList.addArgument(getTrivialTemplateArgumentLoc( 5552 Arg, QualType(), P->getParam(I)->getLocation())); 5553 } 5554 PArgs.clear(); 5555 5556 // C++1z [temp.arg.template]p3: 5557 // If the rewrite produces an invalid type, then P is not at least as 5558 // specialized as A. 5559 if (CheckTemplateArgumentList(AArg, Loc, PArgList, false, PArgs) || 5560 Trap.hasErrorOccurred()) 5561 return false; 5562 } 5563 5564 QualType AType = Context.getTemplateSpecializationType(X, AArgs); 5565 QualType PType = Context.getTemplateSpecializationType(X, PArgs); 5566 5567 // ... the function template corresponding to P is at least as specialized 5568 // as the function template corresponding to A according to the partial 5569 // ordering rules for function templates. 5570 TemplateDeductionInfo Info(Loc, A->getDepth()); 5571 return isAtLeastAsSpecializedAs(*this, PType, AType, AArg, Info); 5572 } 5573 5574 namespace { 5575 struct MarkUsedTemplateParameterVisitor : 5576 RecursiveASTVisitor<MarkUsedTemplateParameterVisitor> { 5577 llvm::SmallBitVector &Used; 5578 unsigned Depth; 5579 5580 MarkUsedTemplateParameterVisitor(llvm::SmallBitVector &Used, 5581 unsigned Depth) 5582 : Used(Used), Depth(Depth) { } 5583 5584 bool VisitTemplateTypeParmType(TemplateTypeParmType *T) { 5585 if (T->getDepth() == Depth) 5586 Used[T->getIndex()] = true; 5587 return true; 5588 } 5589 5590 bool TraverseTemplateName(TemplateName Template) { 5591 if (auto *TTP = 5592 dyn_cast<TemplateTemplateParmDecl>(Template.getAsTemplateDecl())) 5593 if (TTP->getDepth() == Depth) 5594 Used[TTP->getIndex()] = true; 5595 RecursiveASTVisitor<MarkUsedTemplateParameterVisitor>:: 5596 TraverseTemplateName(Template); 5597 return true; 5598 } 5599 5600 bool VisitDeclRefExpr(DeclRefExpr *E) { 5601 if (auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(E->getDecl())) 5602 if (NTTP->getDepth() == Depth) 5603 Used[NTTP->getIndex()] = true; 5604 return true; 5605 } 5606 }; 5607 } 5608 5609 /// Mark the template parameters that are used by the given 5610 /// expression. 5611 static void 5612 MarkUsedTemplateParameters(ASTContext &Ctx, 5613 const Expr *E, 5614 bool OnlyDeduced, 5615 unsigned Depth, 5616 llvm::SmallBitVector &Used) { 5617 if (!OnlyDeduced) { 5618 MarkUsedTemplateParameterVisitor(Used, Depth) 5619 .TraverseStmt(const_cast<Expr *>(E)); 5620 return; 5621 } 5622 5623 // We can deduce from a pack expansion. 5624 if (const PackExpansionExpr *Expansion = dyn_cast<PackExpansionExpr>(E)) 5625 E = Expansion->getPattern(); 5626 5627 const NonTypeTemplateParmDecl *NTTP = getDeducedParameterFromExpr(E, Depth); 5628 if (!NTTP) 5629 return; 5630 5631 if (NTTP->getDepth() == Depth) 5632 Used[NTTP->getIndex()] = true; 5633 5634 // In C++17 mode, additional arguments may be deduced from the type of a 5635 // non-type argument. 5636 if (Ctx.getLangOpts().CPlusPlus17) 5637 MarkUsedTemplateParameters(Ctx, NTTP->getType(), OnlyDeduced, Depth, Used); 5638 } 5639 5640 /// Mark the template parameters that are used by the given 5641 /// nested name specifier. 5642 static void 5643 MarkUsedTemplateParameters(ASTContext &Ctx, 5644 NestedNameSpecifier *NNS, 5645 bool OnlyDeduced, 5646 unsigned Depth, 5647 llvm::SmallBitVector &Used) { 5648 if (!NNS) 5649 return; 5650 5651 MarkUsedTemplateParameters(Ctx, NNS->getPrefix(), OnlyDeduced, Depth, 5652 Used); 5653 MarkUsedTemplateParameters(Ctx, QualType(NNS->getAsType(), 0), 5654 OnlyDeduced, Depth, Used); 5655 } 5656 5657 /// Mark the template parameters that are used by the given 5658 /// template name. 5659 static void 5660 MarkUsedTemplateParameters(ASTContext &Ctx, 5661 TemplateName Name, 5662 bool OnlyDeduced, 5663 unsigned Depth, 5664 llvm::SmallBitVector &Used) { 5665 if (TemplateDecl *Template = Name.getAsTemplateDecl()) { 5666 if (TemplateTemplateParmDecl *TTP 5667 = dyn_cast<TemplateTemplateParmDecl>(Template)) { 5668 if (TTP->getDepth() == Depth) 5669 Used[TTP->getIndex()] = true; 5670 } 5671 return; 5672 } 5673 5674 if (QualifiedTemplateName *QTN = Name.getAsQualifiedTemplateName()) 5675 MarkUsedTemplateParameters(Ctx, QTN->getQualifier(), OnlyDeduced, 5676 Depth, Used); 5677 if (DependentTemplateName *DTN = Name.getAsDependentTemplateName()) 5678 MarkUsedTemplateParameters(Ctx, DTN->getQualifier(), OnlyDeduced, 5679 Depth, Used); 5680 } 5681 5682 /// Mark the template parameters that are used by the given 5683 /// type. 5684 static void 5685 MarkUsedTemplateParameters(ASTContext &Ctx, QualType T, 5686 bool OnlyDeduced, 5687 unsigned Depth, 5688 llvm::SmallBitVector &Used) { 5689 if (T.isNull()) 5690 return; 5691 5692 // Non-dependent types have nothing deducible 5693 if (!T->isDependentType()) 5694 return; 5695 5696 T = Ctx.getCanonicalType(T); 5697 switch (T->getTypeClass()) { 5698 case Type::Pointer: 5699 MarkUsedTemplateParameters(Ctx, 5700 cast<PointerType>(T)->getPointeeType(), 5701 OnlyDeduced, 5702 Depth, 5703 Used); 5704 break; 5705 5706 case Type::BlockPointer: 5707 MarkUsedTemplateParameters(Ctx, 5708 cast<BlockPointerType>(T)->getPointeeType(), 5709 OnlyDeduced, 5710 Depth, 5711 Used); 5712 break; 5713 5714 case Type::LValueReference: 5715 case Type::RValueReference: 5716 MarkUsedTemplateParameters(Ctx, 5717 cast<ReferenceType>(T)->getPointeeType(), 5718 OnlyDeduced, 5719 Depth, 5720 Used); 5721 break; 5722 5723 case Type::MemberPointer: { 5724 const MemberPointerType *MemPtr = cast<MemberPointerType>(T.getTypePtr()); 5725 MarkUsedTemplateParameters(Ctx, MemPtr->getPointeeType(), OnlyDeduced, 5726 Depth, Used); 5727 MarkUsedTemplateParameters(Ctx, QualType(MemPtr->getClass(), 0), 5728 OnlyDeduced, Depth, Used); 5729 break; 5730 } 5731 5732 case Type::DependentSizedArray: 5733 MarkUsedTemplateParameters(Ctx, 5734 cast<DependentSizedArrayType>(T)->getSizeExpr(), 5735 OnlyDeduced, Depth, Used); 5736 // Fall through to check the element type 5737 LLVM_FALLTHROUGH; 5738 5739 case Type::ConstantArray: 5740 case Type::IncompleteArray: 5741 MarkUsedTemplateParameters(Ctx, 5742 cast<ArrayType>(T)->getElementType(), 5743 OnlyDeduced, Depth, Used); 5744 break; 5745 5746 case Type::Vector: 5747 case Type::ExtVector: 5748 MarkUsedTemplateParameters(Ctx, 5749 cast<VectorType>(T)->getElementType(), 5750 OnlyDeduced, Depth, Used); 5751 break; 5752 5753 case Type::DependentVector: { 5754 const auto *VecType = cast<DependentVectorType>(T); 5755 MarkUsedTemplateParameters(Ctx, VecType->getElementType(), OnlyDeduced, 5756 Depth, Used); 5757 MarkUsedTemplateParameters(Ctx, VecType->getSizeExpr(), OnlyDeduced, Depth, 5758 Used); 5759 break; 5760 } 5761 case Type::DependentSizedExtVector: { 5762 const DependentSizedExtVectorType *VecType 5763 = cast<DependentSizedExtVectorType>(T); 5764 MarkUsedTemplateParameters(Ctx, VecType->getElementType(), OnlyDeduced, 5765 Depth, Used); 5766 MarkUsedTemplateParameters(Ctx, VecType->getSizeExpr(), OnlyDeduced, 5767 Depth, Used); 5768 break; 5769 } 5770 5771 case Type::DependentAddressSpace: { 5772 const DependentAddressSpaceType *DependentASType = 5773 cast<DependentAddressSpaceType>(T); 5774 MarkUsedTemplateParameters(Ctx, DependentASType->getPointeeType(), 5775 OnlyDeduced, Depth, Used); 5776 MarkUsedTemplateParameters(Ctx, 5777 DependentASType->getAddrSpaceExpr(), 5778 OnlyDeduced, Depth, Used); 5779 break; 5780 } 5781 5782 case Type::ConstantMatrix: { 5783 const ConstantMatrixType *MatType = cast<ConstantMatrixType>(T); 5784 MarkUsedTemplateParameters(Ctx, MatType->getElementType(), OnlyDeduced, 5785 Depth, Used); 5786 break; 5787 } 5788 5789 case Type::DependentSizedMatrix: { 5790 const DependentSizedMatrixType *MatType = cast<DependentSizedMatrixType>(T); 5791 MarkUsedTemplateParameters(Ctx, MatType->getElementType(), OnlyDeduced, 5792 Depth, Used); 5793 MarkUsedTemplateParameters(Ctx, MatType->getRowExpr(), OnlyDeduced, Depth, 5794 Used); 5795 MarkUsedTemplateParameters(Ctx, MatType->getColumnExpr(), OnlyDeduced, 5796 Depth, Used); 5797 break; 5798 } 5799 5800 case Type::FunctionProto: { 5801 const FunctionProtoType *Proto = cast<FunctionProtoType>(T); 5802 MarkUsedTemplateParameters(Ctx, Proto->getReturnType(), OnlyDeduced, Depth, 5803 Used); 5804 for (unsigned I = 0, N = Proto->getNumParams(); I != N; ++I) { 5805 // C++17 [temp.deduct.type]p5: 5806 // The non-deduced contexts are: [...] 5807 // -- A function parameter pack that does not occur at the end of the 5808 // parameter-declaration-list. 5809 if (!OnlyDeduced || I + 1 == N || 5810 !Proto->getParamType(I)->getAs<PackExpansionType>()) { 5811 MarkUsedTemplateParameters(Ctx, Proto->getParamType(I), OnlyDeduced, 5812 Depth, Used); 5813 } else { 5814 // FIXME: C++17 [temp.deduct.call]p1: 5815 // When a function parameter pack appears in a non-deduced context, 5816 // the type of that pack is never deduced. 5817 // 5818 // We should also track a set of "never deduced" parameters, and 5819 // subtract that from the list of deduced parameters after marking. 5820 } 5821 } 5822 if (auto *E = Proto->getNoexceptExpr()) 5823 MarkUsedTemplateParameters(Ctx, E, OnlyDeduced, Depth, Used); 5824 break; 5825 } 5826 5827 case Type::TemplateTypeParm: { 5828 const TemplateTypeParmType *TTP = cast<TemplateTypeParmType>(T); 5829 if (TTP->getDepth() == Depth) 5830 Used[TTP->getIndex()] = true; 5831 break; 5832 } 5833 5834 case Type::SubstTemplateTypeParmPack: { 5835 const SubstTemplateTypeParmPackType *Subst 5836 = cast<SubstTemplateTypeParmPackType>(T); 5837 MarkUsedTemplateParameters(Ctx, 5838 QualType(Subst->getReplacedParameter(), 0), 5839 OnlyDeduced, Depth, Used); 5840 MarkUsedTemplateParameters(Ctx, Subst->getArgumentPack(), 5841 OnlyDeduced, Depth, Used); 5842 break; 5843 } 5844 5845 case Type::InjectedClassName: 5846 T = cast<InjectedClassNameType>(T)->getInjectedSpecializationType(); 5847 LLVM_FALLTHROUGH; 5848 5849 case Type::TemplateSpecialization: { 5850 const TemplateSpecializationType *Spec 5851 = cast<TemplateSpecializationType>(T); 5852 MarkUsedTemplateParameters(Ctx, Spec->getTemplateName(), OnlyDeduced, 5853 Depth, Used); 5854 5855 // C++0x [temp.deduct.type]p9: 5856 // If the template argument list of P contains a pack expansion that is 5857 // not the last template argument, the entire template argument list is a 5858 // non-deduced context. 5859 if (OnlyDeduced && 5860 hasPackExpansionBeforeEnd(Spec->template_arguments())) 5861 break; 5862 5863 for (unsigned I = 0, N = Spec->getNumArgs(); I != N; ++I) 5864 MarkUsedTemplateParameters(Ctx, Spec->getArg(I), OnlyDeduced, Depth, 5865 Used); 5866 break; 5867 } 5868 5869 case Type::Complex: 5870 if (!OnlyDeduced) 5871 MarkUsedTemplateParameters(Ctx, 5872 cast<ComplexType>(T)->getElementType(), 5873 OnlyDeduced, Depth, Used); 5874 break; 5875 5876 case Type::Atomic: 5877 if (!OnlyDeduced) 5878 MarkUsedTemplateParameters(Ctx, 5879 cast<AtomicType>(T)->getValueType(), 5880 OnlyDeduced, Depth, Used); 5881 break; 5882 5883 case Type::DependentName: 5884 if (!OnlyDeduced) 5885 MarkUsedTemplateParameters(Ctx, 5886 cast<DependentNameType>(T)->getQualifier(), 5887 OnlyDeduced, Depth, Used); 5888 break; 5889 5890 case Type::DependentTemplateSpecialization: { 5891 // C++14 [temp.deduct.type]p5: 5892 // The non-deduced contexts are: 5893 // -- The nested-name-specifier of a type that was specified using a 5894 // qualified-id 5895 // 5896 // C++14 [temp.deduct.type]p6: 5897 // When a type name is specified in a way that includes a non-deduced 5898 // context, all of the types that comprise that type name are also 5899 // non-deduced. 5900 if (OnlyDeduced) 5901 break; 5902 5903 const DependentTemplateSpecializationType *Spec 5904 = cast<DependentTemplateSpecializationType>(T); 5905 5906 MarkUsedTemplateParameters(Ctx, Spec->getQualifier(), 5907 OnlyDeduced, Depth, Used); 5908 5909 for (unsigned I = 0, N = Spec->getNumArgs(); I != N; ++I) 5910 MarkUsedTemplateParameters(Ctx, Spec->getArg(I), OnlyDeduced, Depth, 5911 Used); 5912 break; 5913 } 5914 5915 case Type::TypeOf: 5916 if (!OnlyDeduced) 5917 MarkUsedTemplateParameters(Ctx, 5918 cast<TypeOfType>(T)->getUnderlyingType(), 5919 OnlyDeduced, Depth, Used); 5920 break; 5921 5922 case Type::TypeOfExpr: 5923 if (!OnlyDeduced) 5924 MarkUsedTemplateParameters(Ctx, 5925 cast<TypeOfExprType>(T)->getUnderlyingExpr(), 5926 OnlyDeduced, Depth, Used); 5927 break; 5928 5929 case Type::Decltype: 5930 if (!OnlyDeduced) 5931 MarkUsedTemplateParameters(Ctx, 5932 cast<DecltypeType>(T)->getUnderlyingExpr(), 5933 OnlyDeduced, Depth, Used); 5934 break; 5935 5936 case Type::UnaryTransform: 5937 if (!OnlyDeduced) 5938 MarkUsedTemplateParameters(Ctx, 5939 cast<UnaryTransformType>(T)->getUnderlyingType(), 5940 OnlyDeduced, Depth, Used); 5941 break; 5942 5943 case Type::PackExpansion: 5944 MarkUsedTemplateParameters(Ctx, 5945 cast<PackExpansionType>(T)->getPattern(), 5946 OnlyDeduced, Depth, Used); 5947 break; 5948 5949 case Type::Auto: 5950 case Type::DeducedTemplateSpecialization: 5951 MarkUsedTemplateParameters(Ctx, 5952 cast<DeducedType>(T)->getDeducedType(), 5953 OnlyDeduced, Depth, Used); 5954 break; 5955 case Type::DependentBitInt: 5956 MarkUsedTemplateParameters(Ctx, 5957 cast<DependentBitIntType>(T)->getNumBitsExpr(), 5958 OnlyDeduced, Depth, Used); 5959 break; 5960 5961 // None of these types have any template parameters in them. 5962 case Type::Builtin: 5963 case Type::VariableArray: 5964 case Type::FunctionNoProto: 5965 case Type::Record: 5966 case Type::Enum: 5967 case Type::ObjCInterface: 5968 case Type::ObjCObject: 5969 case Type::ObjCObjectPointer: 5970 case Type::UnresolvedUsing: 5971 case Type::Pipe: 5972 case Type::BitInt: 5973 #define TYPE(Class, Base) 5974 #define ABSTRACT_TYPE(Class, Base) 5975 #define DEPENDENT_TYPE(Class, Base) 5976 #define NON_CANONICAL_TYPE(Class, Base) case Type::Class: 5977 #include "clang/AST/TypeNodes.inc" 5978 break; 5979 } 5980 } 5981 5982 /// Mark the template parameters that are used by this 5983 /// template argument. 5984 static void 5985 MarkUsedTemplateParameters(ASTContext &Ctx, 5986 const TemplateArgument &TemplateArg, 5987 bool OnlyDeduced, 5988 unsigned Depth, 5989 llvm::SmallBitVector &Used) { 5990 switch (TemplateArg.getKind()) { 5991 case TemplateArgument::Null: 5992 case TemplateArgument::Integral: 5993 case TemplateArgument::Declaration: 5994 break; 5995 5996 case TemplateArgument::NullPtr: 5997 MarkUsedTemplateParameters(Ctx, TemplateArg.getNullPtrType(), OnlyDeduced, 5998 Depth, Used); 5999 break; 6000 6001 case TemplateArgument::Type: 6002 MarkUsedTemplateParameters(Ctx, TemplateArg.getAsType(), OnlyDeduced, 6003 Depth, Used); 6004 break; 6005 6006 case TemplateArgument::Template: 6007 case TemplateArgument::TemplateExpansion: 6008 MarkUsedTemplateParameters(Ctx, 6009 TemplateArg.getAsTemplateOrTemplatePattern(), 6010 OnlyDeduced, Depth, Used); 6011 break; 6012 6013 case TemplateArgument::Expression: 6014 MarkUsedTemplateParameters(Ctx, TemplateArg.getAsExpr(), OnlyDeduced, 6015 Depth, Used); 6016 break; 6017 6018 case TemplateArgument::Pack: 6019 for (const auto &P : TemplateArg.pack_elements()) 6020 MarkUsedTemplateParameters(Ctx, P, OnlyDeduced, Depth, Used); 6021 break; 6022 } 6023 } 6024 6025 /// Mark which template parameters are used in a given expression. 6026 /// 6027 /// \param E the expression from which template parameters will be deduced. 6028 /// 6029 /// \param Used a bit vector whose elements will be set to \c true 6030 /// to indicate when the corresponding template parameter will be 6031 /// deduced. 6032 void 6033 Sema::MarkUsedTemplateParameters(const Expr *E, bool OnlyDeduced, 6034 unsigned Depth, 6035 llvm::SmallBitVector &Used) { 6036 ::MarkUsedTemplateParameters(Context, E, OnlyDeduced, Depth, Used); 6037 } 6038 6039 /// Mark which template parameters can be deduced from a given 6040 /// template argument list. 6041 /// 6042 /// \param TemplateArgs the template argument list from which template 6043 /// parameters will be deduced. 6044 /// 6045 /// \param Used a bit vector whose elements will be set to \c true 6046 /// to indicate when the corresponding template parameter will be 6047 /// deduced. 6048 void 6049 Sema::MarkUsedTemplateParameters(const TemplateArgumentList &TemplateArgs, 6050 bool OnlyDeduced, unsigned Depth, 6051 llvm::SmallBitVector &Used) { 6052 // C++0x [temp.deduct.type]p9: 6053 // If the template argument list of P contains a pack expansion that is not 6054 // the last template argument, the entire template argument list is a 6055 // non-deduced context. 6056 if (OnlyDeduced && 6057 hasPackExpansionBeforeEnd(TemplateArgs.asArray())) 6058 return; 6059 6060 for (unsigned I = 0, N = TemplateArgs.size(); I != N; ++I) 6061 ::MarkUsedTemplateParameters(Context, TemplateArgs[I], OnlyDeduced, 6062 Depth, Used); 6063 } 6064 6065 /// Marks all of the template parameters that will be deduced by a 6066 /// call to the given function template. 6067 void Sema::MarkDeducedTemplateParameters( 6068 ASTContext &Ctx, const FunctionTemplateDecl *FunctionTemplate, 6069 llvm::SmallBitVector &Deduced) { 6070 TemplateParameterList *TemplateParams 6071 = FunctionTemplate->getTemplateParameters(); 6072 Deduced.clear(); 6073 Deduced.resize(TemplateParams->size()); 6074 6075 FunctionDecl *Function = FunctionTemplate->getTemplatedDecl(); 6076 for (unsigned I = 0, N = Function->getNumParams(); I != N; ++I) 6077 ::MarkUsedTemplateParameters(Ctx, Function->getParamDecl(I)->getType(), 6078 true, TemplateParams->getDepth(), Deduced); 6079 } 6080 6081 bool hasDeducibleTemplateParameters(Sema &S, 6082 FunctionTemplateDecl *FunctionTemplate, 6083 QualType T) { 6084 if (!T->isDependentType()) 6085 return false; 6086 6087 TemplateParameterList *TemplateParams 6088 = FunctionTemplate->getTemplateParameters(); 6089 llvm::SmallBitVector Deduced(TemplateParams->size()); 6090 ::MarkUsedTemplateParameters(S.Context, T, true, TemplateParams->getDepth(), 6091 Deduced); 6092 6093 return Deduced.any(); 6094 } 6095