40#include "llvm/ADT/DenseSet.h"
41#include "llvm/ADT/STLExtras.h"
42#include "llvm/ADT/STLForwardCompat.h"
43#include "llvm/ADT/ScopeExit.h"
44#include "llvm/ADT/SmallPtrSet.h"
45#include "llvm/ADT/SmallVector.h"
59 return P->hasAttr<PassObjectSizeAttr>();
80 if (HadMultipleCandidates)
91 CK_FunctionToPointerDecay);
95 bool InOverloadResolution,
98 bool AllowObjCWritebackConversion);
102 bool InOverloadResolution,
110 bool AllowObjCConversionOnExplicit);
178 return Rank[(int)Kind];
203 static const char *
const Name[] = {
207 "Function-to-pointer",
208 "Function pointer conversion",
210 "Integral promotion",
211 "Floating point promotion",
213 "Integral conversion",
214 "Floating conversion",
215 "Complex conversion",
216 "Floating-integral conversion",
217 "Pointer conversion",
218 "Pointer-to-member conversion",
219 "Boolean conversion",
220 "Compatible-types conversion",
221 "Derived-to-base conversion",
223 "SVE Vector conversion",
224 "RVV Vector conversion",
226 "Complex-real conversion",
227 "Block Pointer conversion",
228 "Transparent Union Conversion",
229 "Writeback conversion",
230 "OpenCL Zero Event Conversion",
231 "OpenCL Zero Queue Conversion",
232 "C specific type conversion",
233 "Incompatible pointer conversion",
234 "Fixed point conversion",
235 "HLSL vector truncation",
236 "HLSL matrix truncation",
237 "Non-decaying array conversion",
315 FromType = Context.getArrayDecayedType(FromType);
327 const Expr *Converted) {
330 if (
auto *EWC = dyn_cast<ExprWithCleanups>(Converted)) {
337 while (
auto *ICE = dyn_cast<ImplicitCastExpr>(Converted)) {
338 switch (ICE->getCastKind()) {
340 case CK_IntegralCast:
341 case CK_IntegralToBoolean:
342 case CK_IntegralToFloating:
343 case CK_BooleanToSignedIntegral:
344 case CK_FloatingToIntegral:
345 case CK_FloatingToBoolean:
346 case CK_FloatingCast:
347 Converted = ICE->getSubExpr();
371 QualType &ConstantType,
bool IgnoreFloatToIntegralConversion)
const {
373 "narrowing check outside C++");
384 ToType = ED->getIntegerType();
390 goto FloatingIntegralConversion;
392 goto IntegralConversion;
403 FloatingIntegralConversion:
408 if (IgnoreFloatToIntegralConversion)
411 assert(
Initializer &&
"Unknown conversion expression");
417 if (std::optional<llvm::APSInt> IntConstantValue =
421 Result.convertFromAPInt(*IntConstantValue, IntConstantValue->isSigned(),
422 llvm::APFloat::rmNearestTiesToEven);
424 llvm::APSInt ConvertedValue = *IntConstantValue;
426 llvm::APFloat::opStatus Status =
Result.convertToInteger(
427 ConvertedValue, llvm::APFloat::rmTowardZero, &ignored);
430 if (Status == llvm::APFloat::opInvalidOp ||
431 *IntConstantValue != ConvertedValue) {
432 ConstantValue =
APValue(*IntConstantValue);
460 Initializer->isCXX11ConstantExpr(Ctx, &ConstantValue)))) {
463 ConstantValue = R.Val;
464 assert(ConstantValue.
isFloat());
465 llvm::APFloat FloatVal = ConstantValue.
getFloat();
468 llvm::APFloat Converted = FloatVal;
469 llvm::APFloat::opStatus ConvertStatus =
471 llvm::APFloat::rmNearestTiesToEven, &ignored);
473 llvm::APFloat::rmNearestTiesToEven, &ignored);
475 if (FloatVal.isNaN() && Converted.isNaN() &&
476 !FloatVal.isSignaling() && !Converted.isSignaling()) {
482 if (!Converted.bitwiseIsEqual(FloatVal)) {
489 if (ConvertStatus & llvm::APFloat::opOverflow) {
511 IntegralConversion: {
519 constexpr auto CanRepresentAll = [](
bool FromSigned,
unsigned FromWidth,
520 bool ToSigned,
unsigned ToWidth) {
521 return (FromWidth < ToWidth + (FromSigned == ToSigned)) &&
522 !(FromSigned && !ToSigned);
525 if (CanRepresentAll(FromSigned, FromWidth, ToSigned, ToWidth))
531 bool DependentBitField =
false;
533 if (BitField->getBitWidth()->isValueDependent())
534 DependentBitField =
true;
535 else if (
unsigned BitFieldWidth = BitField->getBitWidthValue();
536 BitFieldWidth < FromWidth) {
537 if (CanRepresentAll(FromSigned, BitFieldWidth, ToSigned, ToWidth))
541 FromWidth = BitFieldWidth;
549 std::optional<llvm::APSInt> OptInitializerValue =
551 if (!OptInitializerValue) {
555 if (DependentBitField && !(FromSigned && !ToSigned))
561 llvm::APSInt &InitializerValue = *OptInitializerValue;
562 bool Narrowing =
false;
563 if (FromWidth < ToWidth) {
566 if (InitializerValue.isSigned() && InitializerValue.isNegative())
572 InitializerValue.extend(InitializerValue.getBitWidth() + 1);
574 llvm::APSInt ConvertedValue = InitializerValue;
575 ConvertedValue = ConvertedValue.trunc(ToWidth);
576 ConvertedValue.setIsSigned(ToSigned);
577 ConvertedValue = ConvertedValue.extend(InitializerValue.getBitWidth());
578 ConvertedValue.setIsSigned(InitializerValue.isSigned());
580 if (ConvertedValue != InitializerValue)
585 ConstantValue =
APValue(InitializerValue);
601 ConstantValue = R.Val;
602 assert(ConstantValue.
isFloat());
603 llvm::APFloat FloatVal = ConstantValue.
getFloat();
608 if (FloatVal.isNaN() && FloatVal.isSignaling()) {
624 raw_ostream &OS = llvm::errs();
625 bool PrintedSomething =
false;
628 PrintedSomething =
true;
632 if (PrintedSomething) {
638 OS <<
" (by copy constructor)";
640 OS <<
" (direct reference binding)";
642 OS <<
" (reference binding)";
644 PrintedSomething =
true;
648 if (PrintedSomething) {
652 PrintedSomething =
true;
655 if (!PrintedSomething) {
656 OS <<
"No conversions required";
663 raw_ostream &OS = llvm::errs();
671 OS <<
"aggregate initialization";
681 raw_ostream &OS = llvm::errs();
683 OS <<
"Worst list element conversion: ";
684 switch (ConversionKind) {
686 OS <<
"Standard conversion: ";
690 OS <<
"User-defined conversion: ";
694 OS <<
"Ellipsis conversion";
697 OS <<
"Ambiguous conversion";
700 OS <<
"Bad conversion";
725 struct DFIArguments {
731 struct DFIParamWithArguments : DFIArguments {
736 struct DFIDeducedMismatchArgs : DFIArguments {
737 TemplateArgumentList *TemplateArgs;
738 unsigned CallArgIndex;
743 TemplateArgumentList *TemplateArgs;
744 ConstraintSatisfaction Satisfaction;
755 Result.Result =
static_cast<unsigned>(TDK);
756 Result.HasDiagnostic =
false;
776 Result.HasDiagnostic =
true;
783 auto *Saved =
new (Context) DFIDeducedMismatchArgs;
794 DFIArguments *Saved =
new (Context) DFIArguments;
806 DFIParamWithArguments *Saved =
new (Context) DFIParamWithArguments;
807 Saved->Param = Info.
Param;
820 Result.HasDiagnostic =
true;
825 CNSInfo *Saved =
new (Context) CNSInfo;
835 llvm_unreachable(
"not a deduction failure");
868 Diag->~PartialDiagnosticAt();
875 static_cast<CNSInfo *
>(
Data)->Satisfaction.~ConstraintSatisfaction();
878 Diag->~PartialDiagnosticAt();
914 return TemplateParameter::getFromOpaqueValue(
Data);
919 return static_cast<DFIParamWithArguments*
>(
Data)->Param;
949 return static_cast<DFIDeducedMismatchArgs*
>(
Data)->TemplateArgs;
955 return static_cast<CNSInfo*
>(
Data)->TemplateArgs;
987 return &
static_cast<DFIArguments*
>(
Data)->FirstArg;
1019 return &
static_cast<DFIArguments*
>(
Data)->SecondArg;
1034 return static_cast<DFIDeducedMismatchArgs*
>(
Data)->CallArgIndex;
1037 return std::nullopt;
1050 for (
unsigned I = 0; I <
X->getNumParams(); ++I)
1054 if (
auto *FTX =
X->getDescribedFunctionTemplate()) {
1059 FTY->getTemplateParameters()))
1068 OverloadedOperatorKind::OO_EqualEqual);
1080 OverloadedOperatorKind::OO_ExclaimEqual);
1098 auto *NotEqFD = Op->getAsFunction();
1099 if (
auto *UD = dyn_cast<UsingShadowDecl>(Op))
1100 NotEqFD = UD->getUnderlyingDecl()->getAsFunction();
1113 return Op == OO_EqualEqual || Op == OO_Spaceship;
1121 if (Op == OverloadedOperatorKind::OO_EqualEqual) {
1122 assert(OriginalArgs.size() == 2);
1124 S,
OpLoc, OriginalArgs[1], FD))
1135void OverloadCandidateSet::destroyCandidates() {
1136 for (
iterator i = Candidates.begin(), e = Candidates.end(); i != e; ++i) {
1137 for (
auto &
C : i->Conversions)
1138 C.~ImplicitConversionSequence();
1140 i->DeductionFailure.Destroy();
1145 destroyCandidates();
1146 SlabAllocator.Reset();
1147 NumInlineBytesUsed = 0;
1151 FirstDeferredCandidate =
nullptr;
1152 DeferredCandidatesCount = 0;
1153 HasDeferredTemplateConstructors =
false;
1154 ResolutionByPerfectCandidateIsDisabled =
false;
1158 class UnbridgedCastsSet {
1168 Entry entry = { &E, E };
1169 Entries.push_back(entry);
1174 for (SmallVectorImpl<Entry>::iterator
1175 i = Entries.begin(), e = Entries.end(); i != e; ++i)
1176 *i->Addr = i->Saved;
1190 UnbridgedCastsSet *unbridgedCasts =
nullptr) {
1194 if (placeholder->getKind() == BuiltinType::Overload)
return false;
1198 if (placeholder->getKind() == BuiltinType::ARCUnbridgedCast &&
1200 unbridgedCasts->save(S, E);
1220 UnbridgedCastsSet &unbridged) {
1221 for (
unsigned i = 0, e = Args.size(); i != e; ++i)
1230 bool NewIsUsingDecl) {
1235 bool OldIsUsingDecl =
false;
1237 OldIsUsingDecl =
true;
1241 if (NewIsUsingDecl)
continue;
1248 if ((OldIsUsingDecl || NewIsUsingDecl) && !
isVisible(*I))
1256 bool UseMemberUsingDeclRules =
1257 (OldIsUsingDecl || NewIsUsingDecl) &&
CurContext->isRecord() &&
1258 !
New->getFriendObjectKind();
1262 if (UseMemberUsingDeclRules && OldIsUsingDecl) {
1268 !shouldLinkPossiblyHiddenDecl(*I,
New))
1287 }
else if (
auto *UUD = dyn_cast<UnresolvedUsingValueDecl>(OldD)) {
1294 if (UUD->getQualifier().isDependent() && !UUD->isCXXClassMember()) {
1322 if (
New->getFriendObjectKind() &&
New->getQualifier() &&
1323 !
New->getDescribedFunctionTemplate() &&
1324 !
New->getDependentSpecializationInfo() &&
1325 !
New->getType()->isDependentType()) {
1330 New->setInvalidDecl();
1342 assert(D &&
"function decl should not be null");
1343 if (
auto *A = D->
getAttr<AttrT>())
1344 return !A->isImplicit();
1350 bool UseMemberUsingDeclRules,
1351 bool ConsiderCudaAttrs,
1352 bool UseOverrideRules =
false) {
1358 if (
New->isMSVCRTEntryPoint())
1369 if ((OldTemplate ==
nullptr) != (NewTemplate ==
nullptr))
1392 if (OldQType != NewQType && OldType->isVariadic() != NewType->isVariadic())
1396 if ((
New->isMemberLikeConstrainedFriend() ||
1407 OldDecl = OldTemplate;
1408 NewDecl = NewTemplate;
1426 bool ConstraintsInTemplateHead =
1437 if (UseMemberUsingDeclRules && ConstraintsInTemplateHead &&
1438 !SameTemplateParameterList)
1440 if (!UseMemberUsingDeclRules &&
1441 (!SameTemplateParameterList || !SameReturnType))
1445 const auto *OldMethod = dyn_cast<CXXMethodDecl>(Old);
1446 const auto *NewMethod = dyn_cast<CXXMethodDecl>(
New);
1448 int OldParamsOffset = 0;
1449 int NewParamsOffset = 0;
1457 if (ThisType.isConstQualified())
1477 BS.
Quals = NormalizeQualifiers(OldMethod, BS.
Quals);
1478 DS.Quals = NormalizeQualifiers(NewMethod, DS.Quals);
1480 if (OldMethod->isExplicitObjectMemberFunction()) {
1482 DS.Quals.removeVolatile();
1485 return BS.
Quals == DS.Quals;
1489 auto BS =
Base.getNonReferenceType().getCanonicalType().split();
1490 auto DS = D.getNonReferenceType().getCanonicalType().split();
1492 if (!AreQualifiersEqual(BS, DS))
1495 if (OldMethod->isImplicitObjectMemberFunction() &&
1496 OldMethod->getParent() != NewMethod->getParent()) {
1508 if (
Base->isLValueReferenceType())
1509 return D->isLValueReferenceType();
1510 return Base->isRValueReferenceType() == D->isRValueReferenceType();
1515 auto DiagnoseInconsistentRefQualifiers = [&]() {
1516 if (SemaRef.
LangOpts.CPlusPlus23 && !UseOverrideRules)
1518 if (OldMethod->getRefQualifier() == NewMethod->getRefQualifier())
1520 if (OldMethod->isExplicitObjectMemberFunction() ||
1521 NewMethod->isExplicitObjectMemberFunction())
1523 if (!UseMemberUsingDeclRules && (OldMethod->getRefQualifier() ==
RQ_None ||
1524 NewMethod->getRefQualifier() ==
RQ_None)) {
1525 SemaRef.
Diag(NewMethod->getLocation(), diag::err_ref_qualifier_overload)
1526 << NewMethod->getRefQualifier() << OldMethod->getRefQualifier();
1527 SemaRef.
Diag(OldMethod->getLocation(), diag::note_previous_declaration);
1536 bool ShouldDiagnoseInconsistentRefQualifiers =
false;
1537 bool HaveInconsistentQualifiers =
false;
1539 if (OldMethod && OldMethod->isExplicitObjectMemberFunction())
1541 if (NewMethod && NewMethod->isExplicitObjectMemberFunction())
1544 if (OldType->getNumParams() - OldParamsOffset !=
1545 NewType->getNumParams() - NewParamsOffset ||
1547 {OldType->param_type_begin() + OldParamsOffset,
1548 OldType->param_type_end()},
1549 {NewType->param_type_begin() + NewParamsOffset,
1550 NewType->param_type_end()},
1555 if (OldMethod && NewMethod && !OldMethod->isStatic() &&
1556 !NewMethod->isStatic()) {
1557 bool HaveCorrespondingObjectParameters = [&](
const CXXMethodDecl *Old,
1559 auto NewObjectType =
New->getFunctionObjectParameterReferenceType();
1563 return F->getRefQualifier() ==
RQ_None &&
1564 !F->isExplicitObjectMemberFunction();
1567 if (IsImplicitWithNoRefQual(Old) != IsImplicitWithNoRefQual(
New) &&
1568 CompareType(OldObjectType.getNonReferenceType(),
1569 NewObjectType.getNonReferenceType()))
1571 return CompareType(OldObjectType, NewObjectType);
1572 }(OldMethod, NewMethod);
1574 if (!HaveCorrespondingObjectParameters) {
1575 ShouldDiagnoseInconsistentRefQualifiers =
true;
1579 if (!UseOverrideRules || (!NewMethod->isExplicitObjectMemberFunction() &&
1580 !OldMethod->isExplicitObjectMemberFunction()))
1581 HaveInconsistentQualifiers =
true;
1585 if (NewMethod && OldMethod && OldMethod->isImplicitObjectMemberFunction() &&
1586 NewMethod->isImplicitObjectMemberFunction())
1587 ShouldDiagnoseInconsistentRefQualifiers =
true;
1589 if (!UseOverrideRules &&
1593 if (!NewRC != !OldRC)
1613 NewI =
New->specific_attr_begin<EnableIfAttr>(),
1614 NewE =
New->specific_attr_end<EnableIfAttr>(),
1617 NewI != NewE || OldI != OldE; ++NewI, ++OldI) {
1618 if (NewI == NewE || OldI == OldE)
1620 llvm::FoldingSetNodeID NewID, OldID;
1621 NewI->getCond()->Profile(NewID, SemaRef.
Context,
true);
1622 OldI->getCond()->Profile(OldID, SemaRef.
Context,
true);
1627 if ((ShouldDiagnoseInconsistentRefQualifiers &&
1628 DiagnoseInconsistentRefQualifiers()) ||
1629 HaveInconsistentQualifiers)
1633 if (SemaRef.
getLangOpts().CUDA && ConsiderCudaAttrs) {
1641 "Unexpected invalid target.");
1645 if (NewTarget != OldTarget) {
1648 if (OldMethod && NewMethod && OldMethod->isVirtual() &&
1649 OldMethod->isConstexpr() && !NewMethod->isConstexpr() &&
1667 bool UseMemberUsingDeclRules,
bool ConsiderCudaAttrs) {
1673 bool UseMemberUsingDeclRules,
bool ConsiderCudaAttrs) {
1686 bool SuppressUserConversions,
1688 bool InOverloadResolution,
1690 bool AllowObjCWritebackConversion,
1691 bool AllowObjCConversionOnExplicit) {
1694 if (SuppressUserConversions) {
1705 Conversions, AllowExplicit,
1706 AllowObjCConversionOnExplicit)) {
1727 bool FromListInit =
false;
1728 if (
const auto *InitList = dyn_cast<InitListExpr>(From);
1729 InitList && InitList->getNumInits() == 1 &&
1731 const Expr *SingleInit = InitList->getInit(0);
1732 FromType = SingleInit->
getType();
1734 FromListInit =
true;
1743 if ((FromCanon == ToCanon ||
1755 if (ToCanon != FromCanon)
1766 Cand != Conversions.
end(); ++Cand)
1807static ImplicitConversionSequence
1809 bool SuppressUserConversions,
1811 bool InOverloadResolution,
1813 bool AllowObjCWritebackConversion,
1814 bool AllowObjCConversionOnExplicit) {
1817 ICS.
Standard, CStyle, AllowObjCWritebackConversion)){
1868 bool CanConvert =
false;
1874 FromResType->getWrappedType()) &&
1876 FromResType->getContainedType()) &&
1877 ToResType->getAttrs() == FromResType->getAttrs())
1879 }
else if (ToTy->isHLSLResourceType()) {
1893 AllowExplicit, InOverloadResolution, CStyle,
1894 AllowObjCWritebackConversion,
1895 AllowObjCConversionOnExplicit);
1898ImplicitConversionSequence
1900 bool SuppressUserConversions,
1902 bool InOverloadResolution,
1904 bool AllowObjCWritebackConversion) {
1905 return ::TryImplicitConversion(*
this, From, ToType, SuppressUserConversions,
1906 AllowExplicit, InOverloadResolution, CStyle,
1907 AllowObjCWritebackConversion,
1913 bool AllowExplicit) {
1918 bool AllowObjCWritebackConversion =
1925 *
this, From, ToType,
1927 AllowExplicit ? AllowedExplicit::All : AllowedExplicit::None,
1929 false, AllowObjCWritebackConversion,
1943 if (
Context.hasSameUnqualifiedType(FromType, ToType))
1956 if (TyClass != CanFrom->getTypeClass())
return false;
1957 if (TyClass != Type::FunctionProto && TyClass != Type::FunctionNoProto) {
1958 if (TyClass == Type::Pointer) {
1961 }
else if (TyClass == Type::BlockPointer) {
1964 }
else if (TyClass == Type::MemberPointer) {
1971 CanTo = ToMPT->getPointeeType();
1977 TyClass = CanTo->getTypeClass();
1978 if (TyClass != CanFrom->getTypeClass())
return false;
1979 if (TyClass != Type::FunctionProto && TyClass != Type::FunctionNoProto)
1989 bool Changed =
false;
1997 const auto *FromFPT = dyn_cast<FunctionProtoType>(FromFn);
1998 const auto *ToFPT = dyn_cast<FunctionProtoType>(ToFn);
2000 if (FromFPT && ToFPT) {
2001 if (FromFPT->hasCFIUncheckedCallee() != ToFPT->hasCFIUncheckedCallee()) {
2003 FromFPT->getReturnType(), FromFPT->getParamTypes(),
2004 FromFPT->getExtProtoInfo().withCFIUncheckedCallee(
2005 ToFPT->hasCFIUncheckedCallee()));
2013 if (FromFPT && ToFPT) {
2014 if (FromFPT->isNothrow() && !ToFPT->isNothrow()) {
2026 bool CanUseToFPT, CanUseFromFPT;
2027 if (
Context.mergeExtParameterInfo(ToFPT, FromFPT, CanUseToFPT,
2028 CanUseFromFPT, NewParamInfos) &&
2029 CanUseToFPT && !CanUseFromFPT) {
2032 NewParamInfos.empty() ?
nullptr : NewParamInfos.data();
2034 FromFPT->getParamTypes(), ExtInfo);
2039 if (
Context.hasAnyFunctionEffects()) {
2044 const auto FromFX = FromFPT->getFunctionEffects();
2045 const auto ToFX = ToFPT->getFunctionEffects();
2046 if (FromFX != ToFX) {
2050 FromFPT->getReturnType(), FromFPT->getParamTypes(), ExtInfo);
2060 assert(
QualType(FromFn, 0).isCanonical());
2061 if (
QualType(FromFn, 0) != CanTo)
return false;
2088 if ((&FromSem == &llvm::APFloat::PPCDoubleDouble() &&
2089 &ToSem == &llvm::APFloat::IEEEquad()) ||
2090 (&FromSem == &llvm::APFloat::IEEEquad() &&
2091 &ToSem == &llvm::APFloat::PPCDoubleDouble()))
2147 bool InOverloadResolution,
bool CStyle) {
2157 if (ToMatrixType && FromMatrixType) {
2159 unsigned ToCols = ToMatrixType->getNumColumns();
2160 if (FromCols < ToCols)
2163 unsigned FromRows = FromMatrixType->
getNumRows();
2164 unsigned ToRows = ToMatrixType->getNumRows();
2165 if (FromRows < ToRows)
2168 if (FromRows == ToRows && FromCols == ToCols)
2174 QualType ToElTy = ToMatrixType->getElementType();
2183 QualType ToElTy = ToMatrixType->getElementType();
2186 if (FromMatrixType && !ToMatrixType) {
2205 bool InOverloadResolution,
bool CStyle) {
2222 if (ToExtType && FromExtType) {
2224 unsigned ToElts = ToExtType->getNumElements();
2225 if (FromElts < ToElts)
2227 if (FromElts == ToElts)
2233 QualType ToElTy = ToExtType->getElementType();
2238 if (FromExtType && !ToExtType) {
2252 if (ToExtType->getNumElements() != FromExtType->getNumElements())
2257 FromExtType->getElementType()->isIntegerType()) {
2269 QualType ToElTy = ToExtType->getElementType();
2304 !ToType->
hasAttr(attr::ArmMveStrictPolymorphism))) {
2309 !InOverloadResolution && !CStyle) {
2311 << FromType << ToType;
2322 bool InOverloadResolution,
2323 StandardConversionSequence &SCS,
2328 bool InOverloadResolution,
2329 StandardConversionSequence &SCS,
2341 bool InOverloadResolution,
2344 bool AllowObjCWritebackConversion) {
2370 FromType = Fn->getType();
2390 if (Method && !Method->isStatic() &&
2391 !Method->isExplicitObjectMemberFunction()) {
2393 "Non-unary operator on non-static member address");
2396 "Non-address-of operator on non-static member address");
2398 FromType, std::nullopt, Method->getParent());
2402 "Non-address-of operator for overloaded function expression");
2448 FromType =
Atomic->getValueType();
2483 if (
auto *FD = dyn_cast<FunctionDecl>(DRE->getDecl()))
2503 bool IncompatibleObjC =
false;
2565 }
else if (AllowObjCWritebackConversion &&
2569 FromType, IncompatibleObjC)) {
2575 InOverloadResolution, FromType)) {
2579 From, InOverloadResolution, CStyle)) {
2584 From, InOverloadResolution, CStyle)) {
2594 S, From, ToType, InOverloadResolution, SCS, CStyle)) {
2603 S, From, ToType, InOverloadResolution, SCS, CStyle)) {
2633 bool ObjCLifetimeConversion;
2639 ObjCLifetimeConversion)) {
2658 CanonFrom = CanonTo;
2663 if (CanonFrom == CanonTo)
2668 if (S.
getLangOpts().CPlusPlus || !InOverloadResolution)
2680 case AssignConvertType::
2681 CompatibleVoidPtrToNonVoidPtr:
2714 bool InOverloadResolution,
2723 if (!UD->
hasAttr<TransparentUnionAttr>())
2726 for (
const auto *it : UD->
fields()) {
2729 ToType = it->getType();
2755 return To->
getKind() == BuiltinType::Int;
2758 return To->
getKind() == BuiltinType::UInt;
2782 if (FromED->isScoped())
2789 if (FromED->isFixed()) {
2790 QualType Underlying = FromED->getIntegerType();
2791 return Context.hasSameUnqualifiedType(Underlying, ToType) ||
2798 return Context.hasSameUnqualifiedType(ToType, FromED->getPromotionType());
2823 uint64_t FromSize =
Context.getTypeSize(FromType);
2832 for (
int Idx = 0; Idx < 6; ++Idx) {
2833 uint64_t ToSize =
Context.getTypeSize(PromoteTypes[Idx]);
2834 if (FromSize < ToSize ||
2835 (FromSize == ToSize &&
2836 FromIsSigned == PromoteTypes[Idx]->isSignedIntegerType())) {
2840 return Context.hasSameUnqualifiedType(ToType, PromoteTypes[Idx]);
2861 std::optional<llvm::APSInt> BitWidth;
2864 MemberDecl->getBitWidth()->getIntegerConstantExpr(
Context))) {
2865 llvm::APSInt ToSize(BitWidth->getBitWidth(), BitWidth->isUnsigned());
2866 ToSize =
Context.getTypeSize(ToType);
2869 if (*BitWidth < ToSize ||
2871 return To->
getKind() == BuiltinType::Int;
2877 return To->
getKind() == BuiltinType::UInt;
2895 return Context.getTypeSize(FromType) <
Context.getTypeSize(ToType);
2905 if (FromBuiltin->getKind() == BuiltinType::Float &&
2906 ToBuiltin->getKind() == BuiltinType::Double)
2913 (FromBuiltin->getKind() == BuiltinType::Float ||
2914 FromBuiltin->getKind() == BuiltinType::Double) &&
2915 (ToBuiltin->getKind() == BuiltinType::LongDouble ||
2916 ToBuiltin->getKind() == BuiltinType::Float128 ||
2917 ToBuiltin->getKind() == BuiltinType::Ibm128))
2922 if (
getLangOpts().
HLSL && FromBuiltin->getKind() == BuiltinType::Half &&
2923 (ToBuiltin->getKind() == BuiltinType::Float ||
2924 ToBuiltin->getKind() == BuiltinType::Double))
2929 FromBuiltin->getKind() == BuiltinType::Half &&
2930 ToBuiltin->getKind() == BuiltinType::Float)
2959 return Context.getTypeSize(FromType) <
Context.getTypeSize(ToType);
2971 if (
const EnumType *ToEnumType = ToType->
getAs<EnumType>()) {
2983 return Context.getTypeSize(FromType) >
Context.getTypeSize(ToType);
2998 bool StripObjCLifetime =
false) {
3001 "Invalid similarly-qualified pointer type");
3012 if (StripObjCLifetime)
3024 return Context.getObjCObjectPointerType(ToPointee);
3025 return Context.getPointerType(ToPointee);
3033 return Context.getObjCObjectPointerType(QualifiedCanonToPointee);
3034 return Context.getPointerType(QualifiedCanonToPointee);
3038 bool InOverloadResolution,
3044 return !InOverloadResolution;
3052 bool InOverloadResolution,
3054 bool &IncompatibleObjC) {
3055 IncompatibleObjC =
false;
3063 ConvertedType = ToType;
3070 ConvertedType = ToType;
3077 ConvertedType = ToType;
3085 ConvertedType = ToType;
3095 ConvertedType = ToType;
3117 if (
Context.hasSameUnqualifiedType(FromPointeeType, ToPointeeType))
3144 Context.typesAreCompatible(FromPointeeType, ToPointeeType)) {
3166 !
Context.hasSameUnqualifiedType(FromPointeeType, ToPointeeType) &&
3175 Context.areCompatibleVectorTypes(FromPointeeType, ToPointeeType)) {
3194 return Context.getQualifiedType(T, Qs);
3196 return Context.getQualifiedType(T.getUnqualifiedType(), Qs);
3201 bool &IncompatibleObjC) {
3214 if (ToObjCPtr && FromObjCPtr) {
3222 if (
Context.canAssignObjCInterfaces(ToObjCPtr, FromObjCPtr)) {
3236 if (
Context.canAssignObjCInterfaces(FromObjCPtr, ToObjCPtr)) {
3240 IncompatibleObjC =
true;
3256 if (FromObjCPtr && FromObjCPtr->isObjCBuiltinType()) {
3285 IncompatibleObjC)) {
3287 IncompatibleObjC =
true;
3288 ConvertedType =
Context.getPointerType(ConvertedType);
3297 IncompatibleObjC)) {
3299 ConvertedType =
Context.getPointerType(ConvertedType);
3312 if (FromFunctionType && ToFunctionType) {
3315 if (
Context.getCanonicalType(FromPointeeType)
3316 ==
Context.getCanonicalType(ToPointeeType))
3321 if (FromFunctionType->
getNumParams() != ToFunctionType->getNumParams() ||
3322 FromFunctionType->
isVariadic() != ToFunctionType->isVariadic() ||
3323 FromFunctionType->
getMethodQuals() != ToFunctionType->getMethodQuals())
3326 bool HasObjCConversion =
false;
3328 Context.getCanonicalType(ToFunctionType->getReturnType())) {
3331 ToFunctionType->getReturnType(),
3332 ConvertedType, IncompatibleObjC)) {
3334 HasObjCConversion =
true;
3341 for (
unsigned ArgIdx = 0, NumArgs = FromFunctionType->
getNumParams();
3342 ArgIdx != NumArgs; ++ArgIdx) {
3344 QualType ToArgType = ToFunctionType->getParamType(ArgIdx);
3345 if (
Context.getCanonicalType(FromArgType)
3346 ==
Context.getCanonicalType(ToArgType)) {
3349 ConvertedType, IncompatibleObjC)) {
3351 HasObjCConversion =
true;
3358 if (HasObjCConversion) {
3362 IncompatibleObjC =
true;
3394 if (!FromFunctionType || !ToFunctionType)
3397 if (
Context.hasSameType(FromPointeeType, ToPointeeType))
3402 if (FromFunctionType->
getNumParams() != ToFunctionType->getNumParams() ||
3403 FromFunctionType->
isVariadic() != ToFunctionType->isVariadic())
3408 if (FromEInfo != ToEInfo)
3411 bool IncompatibleObjC =
false;
3413 ToFunctionType->getReturnType())) {
3417 QualType LHS = ToFunctionType->getReturnType();
3422 if (
Context.hasSameType(RHS,LHS)) {
3425 ConvertedType, IncompatibleObjC)) {
3426 if (IncompatibleObjC)
3435 for (
unsigned ArgIdx = 0, NumArgs = FromFunctionType->
getNumParams();
3436 ArgIdx != NumArgs; ++ArgIdx) {
3437 IncompatibleObjC =
false;
3439 QualType ToArgType = ToFunctionType->getParamType(ArgIdx);
3440 if (
Context.hasSameType(FromArgType, ToArgType)) {
3443 ConvertedType, IncompatibleObjC)) {
3444 if (IncompatibleObjC)
3453 bool CanUseToFPT, CanUseFromFPT;
3454 if (!
Context.mergeExtParameterInfo(ToFunctionType, FromFunctionType,
3455 CanUseToFPT, CanUseFromFPT,
3459 ConvertedType = ToType;
3498 ToMember->getMostRecentCXXRecordDecl())) {
3500 if (ToMember->isSugared())
3502 ToMember->getMostRecentCXXRecordDecl());
3504 PDiag << ToMember->getQualifier();
3505 if (FromMember->isSugared())
3507 FromMember->getMostRecentCXXRecordDecl());
3509 PDiag << FromMember->getQualifier();
3527 !FromType->
getAs<TemplateSpecializationType>()) {
3533 if (
Context.hasSameType(FromType, ToType)) {
3542 if (!FromFunction || !ToFunction) {
3547 if (FromFunction->
getNumParams() != ToFunction->getNumParams()) {
3557 << ToFunction->getParamType(ArgPos)
3564 ToFunction->getReturnType())) {
3570 if (FromFunction->
getMethodQuals() != ToFunction->getMethodQuals()) {
3593 assert(llvm::size(Old) == llvm::size(
New) &&
3594 "Can't compare parameters of functions with different number of "
3597 for (
auto &&[Idx,
Type] : llvm::enumerate(Old)) {
3599 size_t J =
Reversed ? (llvm::size(
New) - Idx - 1) : Idx;
3604 Context.removePtrSizeAddrSpace(
Type.getUnqualifiedType());
3606 Context.removePtrSizeAddrSpace((
New.begin() + J)->getUnqualifiedType());
3608 if (!
Context.hasSameType(OldType, NewType)) {
3633 unsigned OldIgnore =
3635 unsigned NewIgnore =
3642 NewPT->param_types().slice(NewIgnore),
3649 bool IgnoreBaseAccess,
3652 bool IsCStyleOrFunctionalCast = IgnoreBaseAccess;
3661 PDiag(diag::warn_impcast_bool_to_null_pointer)
3672 if (FromPointeeType->
isRecordType() && ToPointeeType->isRecordType() &&
3673 !
Context.hasSameUnqualifiedType(FromPointeeType, ToPointeeType)) {
3676 unsigned InaccessibleID = 0;
3677 unsigned AmbiguousID = 0;
3679 InaccessibleID = diag::err_upcast_to_inaccessible_base;
3680 AmbiguousID = diag::err_ambiguous_derived_to_base_conv;
3683 FromPointeeType, ToPointeeType, InaccessibleID, AmbiguousID,
3685 &BasePath, IgnoreBaseAccess))
3689 Kind = CK_DerivedToBase;
3692 if (
Diagnose && !IsCStyleOrFunctionalCast &&
3693 FromPointeeType->
isFunctionType() && ToPointeeType->isVoidType()) {
3695 "this should only be possible with MSVCCompat!");
3707 if (FromPtrType->isObjCBuiltinType() || ToPtrType->isObjCBuiltinType())
3710 Kind = CK_BlockPointerToObjCPointerCast;
3712 Kind = CK_CPointerToObjCPointerCast;
3716 Kind = CK_AnyPointerToBlockPointerCast;
3722 Kind = CK_NullToPointer;
3729 bool InOverloadResolution,
3739 ConvertedType = ToType;
3755 ConvertedType =
Context.getMemberPointerType(
3769 if (
Context.getTargetInfo().getCXXABI().isMicrosoft()) {
3777 Kind = CK_NullToMemberPointer;
3795 PD <<
Context.getCanonicalTagType(Cls);
3805 std::swap(
Base, Derived);
3814 PD <<
int(Direction);
3822 DiagFromTo(PD) <<
QualType(VBase, 0) << OpRange;
3830 ? CK_DerivedToBaseMemberPointer
3831 : CK_BaseToDerivedMemberPointer;
3833 if (!IgnoreBaseAccess)
3837 ? diag::err_upcast_to_inaccessible_base
3838 : diag::err_downcast_from_inaccessible_base,
3840 NestedNameSpecifier BaseQual = FromPtrType->getQualifier(),
3841 DerivedQual = ToPtrType->getQualifier();
3842 if (Direction == MemberPointerConversionDirection::Upcast)
3843 std::swap(BaseQual, DerivedQual);
3844 DiagCls(PD, DerivedQual, Derived);
3845 DiagCls(PD, BaseQual, Base);
3880 bool CStyle,
bool IsTopLevel,
3881 bool &PreviousToQualsIncludeConst,
3882 bool &ObjCLifetimeConversion,
3895 ObjCLifetimeConversion =
true;
3935 !PreviousToQualsIncludeConst)
3953 PreviousToQualsIncludeConst =
3954 PreviousToQualsIncludeConst && ToQuals.
hasConst();
3960 bool CStyle,
bool &ObjCLifetimeConversion) {
3961 FromType =
Context.getCanonicalType(FromType);
3962 ToType =
Context.getCanonicalType(ToType);
3963 ObjCLifetimeConversion =
false;
3973 bool PreviousToQualsIncludeConst =
true;
3974 bool UnwrappedAnyPointer =
false;
3975 while (
Context.UnwrapSimilarTypes(FromType, ToType)) {
3977 !UnwrappedAnyPointer,
3978 PreviousToQualsIncludeConst,
3981 UnwrappedAnyPointer =
true;
3989 return UnwrappedAnyPointer &&
Context.hasSameUnqualifiedType(FromType,ToType);
3998 bool InOverloadResolution,
4007 InOverloadResolution, InnerSCS,
4022 bool InOverloadResolution,
4025 const OverflowBehaviorType *ToOBT = ToType->
getAs<OverflowBehaviorType>();
4036 InOverloadResolution, InnerSCS, CStyle,
4053 if (CtorType->getNumParams() > 0) {
4054 QualType FirstArg = CtorType->getParamType(0);
4066 bool AllowExplicit) {
4073 bool Usable = !Info.Constructor->isInvalidDecl() &&
4076 bool SuppressUserConversions =
false;
4077 if (Info.ConstructorTmpl)
4080 CandidateSet, SuppressUserConversions,
4085 CandidateSet, SuppressUserConversions,
4086 false, AllowExplicit);
4090 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
4117 llvm_unreachable(
"Invalid OverloadResult!");
4139 bool AllowObjCConversionOnExplicit) {
4140 assert(AllowExplicit != AllowedExplicit::None ||
4141 !AllowObjCConversionOnExplicit);
4145 bool ConstructorsOnly =
false;
4149 if (
const RecordType *ToRecordType = ToType->
getAsCanonical<RecordType>()) {
4161 ConstructorsOnly =
true;
4165 }
else if (
auto *ToRecordDecl =
4166 dyn_cast<CXXRecordDecl>(ToRecordType->getDecl())) {
4167 ToRecordDecl = ToRecordDecl->getDefinitionOrSelf();
4169 Expr **Args = &From;
4170 unsigned NumArgs = 1;
4171 bool ListInitializing =
false;
4172 if (
InitListExpr *InitList = dyn_cast<InitListExpr>(From)) {
4175 S, From, ToType, ToRecordDecl, User, CandidateSet,
4176 AllowExplicit == AllowedExplicit::All);
4185 Args = InitList->getInits();
4186 NumArgs = InitList->getNumInits();
4187 ListInitializing =
true;
4195 bool Usable = !Info.Constructor->isInvalidDecl();
4196 if (!ListInitializing)
4197 Usable = Usable && Info.Constructor->isConvertingConstructor(
4200 bool SuppressUserConversions = !ConstructorsOnly;
4208 if (SuppressUserConversions && ListInitializing) {
4209 SuppressUserConversions =
4214 if (Info.ConstructorTmpl)
4216 Info.ConstructorTmpl, Info.FoundDecl,
4218 CandidateSet, SuppressUserConversions,
4220 AllowExplicit == AllowedExplicit::All);
4226 SuppressUserConversions,
4228 AllowExplicit == AllowedExplicit::All);
4238 }
else if (
const RecordType *FromRecordType =
4240 if (
auto *FromRecordDecl =
4241 dyn_cast<CXXRecordDecl>(FromRecordType->getDecl())) {
4242 FromRecordDecl = FromRecordDecl->getDefinitionOrSelf();
4244 const auto &Conversions = FromRecordDecl->getVisibleConversionFunctions();
4245 for (
auto I = Conversions.begin(), E = Conversions.end(); I != E; ++I) {
4254 if ((ConvTemplate = dyn_cast<FunctionTemplateDecl>(D)))
4261 ConvTemplate, FoundDecl, ActingContext, From, ToType,
4262 CandidateSet, AllowObjCConversionOnExplicit,
4263 AllowExplicit != AllowedExplicit::None);
4266 CandidateSet, AllowObjCConversionOnExplicit,
4267 AllowExplicit != AllowedExplicit::None);
4272 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
4281 = dyn_cast<CXXConstructorDecl>(Best->Function)) {
4293 if (Best->Conversions[0].isEllipsis())
4296 User.
Before = Best->Conversions[0].Standard;
4309 = dyn_cast<CXXConversionDecl>(Best->Function)) {
4311 assert(Best->HasFinalConversion);
4319 User.
Before = Best->Conversions[0].Standard;
4334 User.
After = Best->FinalConversion;
4337 llvm_unreachable(
"Not a constructor or conversion function?");
4346 llvm_unreachable(
"Invalid OverloadResult!");
4356 CandidateSet, AllowedExplicit::None,
false);
4371 diag::err_typecheck_nonviable_condition_incomplete,
4378 *
this, From, Cands);
4404 if (!Conv1 || !Conv2)
4419 if (Block1 != Block2)
4432 if (Conv1FuncRet && Conv2FuncRet &&
4441 CallOp->getType()->castAs<
FunctionType>()->getCallConv();
4443 CallOpProto->isVariadic(),
false);
4445 CallOpProto->isVariadic(),
true);
4447 CallingConv PrefOrder[] = {DefaultFree, DefaultMember, CallOpCC};
4542 if (!ICS1.
isBad()) {
4543 bool StdInit1 =
false, StdInit2 =
false;
4550 if (StdInit1 != StdInit2)
4561 CAT2->getElementType())) {
4563 if (CAT1->getSize() != CAT2->getSize())
4565 return CAT1->getSize().ult(CAT2->getSize())
4600 if (ConvFunc1 == ConvFunc2)
4702 if (!
Enum->isFixed())
4738 else if (Rank2 < Rank1)
4773 bool SCS1ConvertsToVoid
4775 bool SCS2ConvertsToVoid
4777 if (SCS1ConvertsToVoid != SCS2ConvertsToVoid) {
4782 }
else if (!SCS1ConvertsToVoid && !SCS2ConvertsToVoid) {
4788 }
else if (SCS1ConvertsToVoid && SCS2ConvertsToVoid &&
4817 if (FromObjCPtr1 && FromObjCPtr2) {
4822 if (AssignLeft != AssignRight) {
4861 if (UnqualT1 == UnqualT2) {
4923 if (SCS1IsCompatibleVectorConversion != SCS2IsCompatibleVectorConversion)
4924 return SCS1IsCompatibleVectorConversion
4931 bool SCS1IsCompatibleSVEVectorConversion =
4933 bool SCS2IsCompatibleSVEVectorConversion =
4936 if (SCS1IsCompatibleSVEVectorConversion !=
4937 SCS2IsCompatibleSVEVectorConversion)
4938 return SCS1IsCompatibleSVEVectorConversion
4945 bool SCS1IsCompatibleRVVVectorConversion =
4947 bool SCS2IsCompatibleRVVVectorConversion =
4950 if (SCS1IsCompatibleRVVVectorConversion !=
4951 SCS2IsCompatibleRVVVectorConversion)
4952 return SCS1IsCompatibleRVVVectorConversion
5011 if (UnqualT1 == UnqualT2)
5029 bool ObjCLifetimeConversion;
5039 if (CanPick1 != CanPick2)
5093 if (FromPointee1 == FromPointee2 && ToPointee1 != ToPointee2) {
5101 if (FromPointee1 != FromPointee2 && ToPointee1 == ToPointee2) {
5118 if (FromPtr1 && FromPtr2 && ToPtr1 && ToPtr2) {
5125 bool FromAssignRight
5134 if (ToPtr1->isObjCIdType() &&
5135 (ToPtr2->isObjCQualifiedIdType() || ToPtr2->getInterfaceDecl()))
5137 if (ToPtr2->isObjCIdType() &&
5138 (ToPtr1->isObjCQualifiedIdType() || ToPtr1->getInterfaceDecl()))
5143 if (ToPtr1->isObjCQualifiedIdType() && ToPtr2->getInterfaceDecl())
5145 if (ToPtr2->isObjCQualifiedIdType() && ToPtr1->getInterfaceDecl())
5150 if (ToPtr1->isObjCClassType() &&
5151 (ToPtr2->isObjCQualifiedClassType() || ToPtr2->getInterfaceDecl()))
5153 if (ToPtr2->isObjCClassType() &&
5154 (ToPtr1->isObjCQualifiedClassType() || ToPtr1->getInterfaceDecl()))
5159 if (ToPtr1->isObjCQualifiedClassType() && ToPtr2->getInterfaceDecl())
5161 if (ToPtr2->isObjCQualifiedClassType() && ToPtr1->getInterfaceDecl())
5167 (ToAssignLeft != ToAssignRight)) {
5178 }
else if (IsSecondSame)
5187 (FromAssignLeft != FromAssignRight))
5201 CXXRecordDecl *FromPointee1 = FromMemPointer1->getMostRecentCXXRecordDecl();
5206 if (FromPointee1 == FromPointee2 && ToPointee1 != ToPointee2) {
5213 if (ToPointee1 == ToPointee2 && FromPointee1 != FromPointee2) {
5251 if (!T.getQualifiers().hasUnaligned())
5265 "T1 must be the pointee type of the reference type");
5266 assert(!OrigT2->
isReferenceType() &&
"T2 cannot be a reference type");
5289 if (UnqualT1 == UnqualT2) {
5293 Conv |= ReferenceConversions::DerivedToBase;
5296 Context.canBindObjCObjectType(UnqualT1, UnqualT2))
5297 Conv |= ReferenceConversions::ObjC;
5300 Conv |= ReferenceConversions::Function;
5304 bool ConvertedReferent = Conv != 0;
5308 bool PreviousToQualsIncludeConst =
true;
5309 bool TopLevel =
true;
5315 Conv |= ReferenceConversions::Qualification;
5321 Conv |= ReferenceConversions::NestedQualification;
5329 bool ObjCLifetimeConversion =
false;
5331 PreviousToQualsIncludeConst,
5333 return (ConvertedReferent ||
Context.hasSimilarType(T1, T2))
5338 if (ObjCLifetimeConversion)
5339 Conv |= ReferenceConversions::ObjCLifetime;
5342 }
while (
Context.UnwrapSimilarTypes(T1, T2));
5347 return (ConvertedReferent ||
Context.hasSameUnqualifiedType(T1, T2))
5358 bool AllowExplicit) {
5359 assert(T2->
isRecordType() &&
"Can only find conversions of record types.");
5363 const auto &Conversions = T2RecordDecl->getVisibleConversionFunctions();
5364 for (
auto I = Conversions.begin(), E = Conversions.end(); I != E; ++I) {
5371 = dyn_cast<FunctionTemplateDecl>(D);
5388 if (!ConvTemplate &&
5412 ConvTemplate, I.getPair(), ActingDC,
Init, DeclType, CandidateSet,
5413 false, AllowExplicit);
5416 Conv, I.getPair(), ActingDC,
Init, DeclType, CandidateSet,
5417 false, AllowExplicit);
5420 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
5426 assert(Best->HasFinalConversion);
5438 if (!Best->FinalConversion.DirectBinding)
5450 "Expected a direct reference binding!");
5456 Cand != CandidateSet.
end(); ++Cand)
5468 llvm_unreachable(
"Invalid OverloadResult!");
5473static ImplicitConversionSequence
5476 bool SuppressUserConversions,
5477 bool AllowExplicit) {
5478 assert(DeclType->
isReferenceType() &&
"Reference init needs a reference");
5505 auto SetAsReferenceBinding = [&](
bool BindsDirectly) {
5510 ICS.
Standard.
Second = (RefConv & Sema::ReferenceConversions::DerivedToBase)
5512 : (RefConv & Sema::ReferenceConversions::ObjC)
5520 Sema::ReferenceConversions::NestedQualification)
5534 (RefConv & Sema::ReferenceConversions::ObjCLifetime) != 0;
5558 SetAsReferenceBinding(
true);
5607 SetAsReferenceBinding(S.
getLangOpts().CPlusPlus11 ||
5698 AllowedExplicit::None,
5723 if (isRValRef && LValRefType) {
5740static ImplicitConversionSequence
5742 bool SuppressUserConversions,
5743 bool InOverloadResolution,
5744 bool AllowObjCWritebackConversion,
5745 bool AllowExplicit =
false);
5749static ImplicitConversionSequence
5751 bool SuppressUserConversions,
5752 bool InOverloadResolution,
5753 bool AllowObjCWritebackConversion) {
5766 if (
const auto *IAT = dyn_cast<IncompleteArrayType>(AT))
5768 InitTy = IAT->getElementType();
5794 if (From->
getNumInits() == 1 && !IsDesignatedInit) {
5800 SuppressUserConversions,
5801 InOverloadResolution,
5802 AllowObjCWritebackConversion);
5811 Result.Standard.setAsIdentityConversion();
5812 Result.Standard.setFromType(ToType);
5813 Result.Standard.setAllToTypes(ToType);
5838 bool IsUnbounded =
false;
5842 if (CT->getSize().ult(e)) {
5846 Result.setInitializerListContainerType(ContTy, IsUnbounded);
5849 if (CT->getSize().ugt(e)) {
5855 S, &EmptyList, InitTy, SuppressUserConversions,
5856 InOverloadResolution, AllowObjCWritebackConversion);
5857 if (DfltElt.
isBad()) {
5861 Result.setInitializerListContainerType(ContTy, IsUnbounded);
5872 Result.setInitializerListContainerType(ContTy, IsUnbounded);
5882 Result.Standard.setAsIdentityConversion();
5883 Result.Standard.setFromType(InitTy);
5884 Result.Standard.setAllToTypes(InitTy);
5885 for (
unsigned i = 0; i < e; ++i) {
5888 S,
Init, InitTy, SuppressUserConversions, InOverloadResolution,
5889 AllowObjCWritebackConversion);
5900 Result.setInitializerListContainerType(ContTy, IsUnbounded);
5914 Result.setInitializerListContainerType(ContTy, IsUnbounded);
5928 AllowedExplicit::None,
5929 InOverloadResolution,
false,
5930 AllowObjCWritebackConversion,
5949 Result.UserDefined.Before.setAsIdentityConversion();
5954 Result.UserDefined.After.setAsIdentityConversion();
5955 Result.UserDefined.After.setFromType(ToType);
5956 Result.UserDefined.After.setAllToTypes(ToType);
5957 Result.UserDefined.ConversionFunction =
nullptr;
5974 if (From->
getNumInits() == 1 && !IsDesignatedInit) {
5995 SuppressUserConversions,
6003 InOverloadResolution,
6004 AllowObjCWritebackConversion);
6007 assert(!
Result.isEllipsis() &&
6008 "Sub-initialization cannot result in ellipsis conversion.");
6014 Result.UserDefined.After;
6042 S, From->
getInit(0), ToType, SuppressUserConversions,
6043 InOverloadResolution, AllowObjCWritebackConversion);
6045 Result.Standard.FromBracedInitList =
true;
6049 else if (NumInits == 0) {
6051 Result.Standard.setAsIdentityConversion();
6052 Result.Standard.setFromType(ToType);
6053 Result.Standard.setAllToTypes(ToType);
6070static ImplicitConversionSequence
6072 bool SuppressUserConversions,
6073 bool InOverloadResolution,
6074 bool AllowObjCWritebackConversion,
6075 bool AllowExplicit) {
6076 if (
InitListExpr *FromInitList = dyn_cast<InitListExpr>(From))
6078 InOverloadResolution,AllowObjCWritebackConversion);
6083 SuppressUserConversions, AllowExplicit);
6086 SuppressUserConversions,
6087 AllowedExplicit::None,
6088 InOverloadResolution,
6090 AllowObjCWritebackConversion,
6103 return !ICS.
isBad();
6112 const CXXRecordDecl *ActingContext,
bool InOverloadResolution =
false,
6114 bool SuppressUserConversion =
false) {
6122 assert(FromClassification.
isLValue());
6133 if (Method->isExplicitObjectMemberFunction()) {
6134 if (ExplicitParameterType.isNull())
6135 ExplicitParameterType = Method->getFunctionObjectParameterReferenceType();
6137 ValueKindFromClassification(FromClassification));
6139 S, &TmpExpr, ExplicitParameterType, SuppressUserConversion,
6156 Qualifiers Quals = Method->getMethodQualifiers();
6194 FromType, ImplicitParamType);
6204 FromType, ImplicitParamType);
6217 }
else if (!Method->isExplicitObjectMemberFunction()) {
6219 FromType, ImplicitParamType);
6224 switch (Method->getRefQualifier()) {
6239 if (!FromClassification.
isRValue()) {
6261 = (Method->getRefQualifier() ==
RQ_None);
6272 QualType ImplicitParamRecordType =
Method->getFunctionObjectParameterType();
6277 DestType =
Method->getThisType();
6280 FromRecordType = From->
getType();
6281 DestType = ImplicitParamRecordType;
6289 Method->getRefQualifier() !=
6307 <<
Method->getDeclName() << FromRecordType << (CVR - 1)
6309 Diag(
Method->getLocation(), diag::note_previous_decl)
6310 <<
Method->getDeclName();
6318 bool IsRValueQualified =
6322 << IsRValueQualified;
6323 Diag(
Method->getLocation(), diag::note_previous_decl)
6324 <<
Method->getDeclName();
6334 llvm_unreachable(
"Lists are not objects");
6337 return Diag(From->
getBeginLoc(), diag::err_member_function_call_bad_type)
6338 << ImplicitParamRecordType << FromRecordType
6347 From = FromRes.
get();
6356 CK = CK_AddressSpaceConversion;
6381 AllowedExplicit::Conversions,
6392 return AMDGPU().ExpandAMDGPUPredicateBuiltIn(From);
6465 llvm_unreachable(
"found a first conversion kind in Second");
6469 llvm_unreachable(
"found a third conversion kind in Second");
6475 llvm_unreachable(
"unknown conversion kind");
6485 [[maybe_unused]]
bool isCCEAllowedPreCXX11 =
6487 assert((S.
getLangOpts().CPlusPlus11 || isCCEAllowedPreCXX11) &&
6488 "converted constant expression outside C++11 or TTP matching");
6520 if (T->isRecordType())
6529 diag::err_typecheck_converted_constant_expression)
6535 llvm_unreachable(
"bad conversion in converted constant expression");
6541 diag::err_typecheck_converted_constant_expression_disallowed)
6547 diag::err_typecheck_converted_constant_expression_indirect)
6557 diag::err_reference_bind_to_bitfield_in_cce)
6565 bool IsTemplateArgument =
6567 if (T->isRecordType()) {
6568 assert(IsTemplateArgument &&
6569 "unexpected class type converted constant expr");
6585 IsTemplateArgument);
6590 bool ReturnPreNarrowingValue =
false;
6593 PreNarrowingType)) {
6603 PreNarrowingValue.
isInt()) {
6606 ReturnPreNarrowingValue =
true;
6632 << CCE << 0 << From->
getType() << T;
6637 if (!ReturnPreNarrowingValue)
6638 PreNarrowingValue = {};
6654 if (
Result.isInvalid() ||
Result.get()->isValueDependent()) {
6659 RequireInt, PreNarrowingValue);
6666 return ::BuildConvertedConstantExpression(*
this, From, T, CCE, Dest,
6673 return ::CheckConvertedConstantExpression(*
this, From, T,
Value, CCE,
false,
6678 llvm::APSInt &
Value,
6680 assert(T->isIntegralOrEnumerationType() &&
"unexpected converted const type");
6685 if (!R.isInvalid() && !R.get()->isValueDependent())
6693 const APValue &PreNarrowingValue) {
6705 Kind = ConstantExprKind::ClassTemplateArgument;
6707 Kind = ConstantExprKind::NonClassTemplateArgument;
6709 Kind = ConstantExprKind::Normal;
6712 (RequireInt && !Eval.
Val.
isInt())) {
6719 if (Notes.empty()) {
6722 if (
const auto *CE = dyn_cast<ConstantExpr>(E)) {
6726 "ConstantExpr has no value associated with it");
6732 Value = std::move(PreNarrowingValue);
6738 if (Notes.size() == 1 &&
6739 Notes[0].second.getDiagID() == diag::note_invalid_subexpr_in_const_expr) {
6740 Diag(Notes[0].first, diag::err_expr_not_cce) << CCE;
6741 }
else if (!Notes.empty() && Notes[0].second.getDiagID() ==
6742 diag::note_constexpr_invalid_template_arg) {
6743 Notes[0].second.setDiagID(diag::err_constexpr_invalid_template_arg);
6744 for (
unsigned I = 0; I < Notes.size(); ++I)
6745 Diag(Notes[I].first, Notes[I].second);
6749 for (
unsigned I = 0; I < Notes.size(); ++I)
6750 Diag(Notes[I].first, Notes[I].second);
6769static ImplicitConversionSequence
6777 AllowedExplicit::Conversions,
6819 "expected a member expression");
6821 if (
const auto M = dyn_cast<UnresolvedMemberExpr>(MemExprE);
6822 M && !M->isImplicitAccess())
6823 Base = M->getBase();
6824 else if (
const auto M = dyn_cast<MemberExpr>(MemExprE);
6825 M && !M->isImplicitAccess())
6826 Base = M->getBase();
6830 if (T->isPointerType())
6859 assert(Method->isExplicitObjectMemberFunction() &&
6860 "Method is not an explicit member function");
6861 assert(NewArgs.empty() &&
"NewArgs should be empty");
6863 NewArgs.reserve(Args.size() + 1);
6865 NewArgs.push_back(
This);
6866 NewArgs.append(Args.begin(), Args.end());
6869 Method,
Object->getBeginLoc());
6875 return AllowScopedEnumerations ? T->isIntegralOrEnumerationType()
6876 : T->isIntegralOrUnscopedEnumerationType();
6888 for (
unsigned I = 0, N = ViableConversions.
size(); I != N; ++I) {
6900 QualType T,
bool HadMultipleCandidates,
6902 if (ExplicitConversions.
size() == 1 && !Converter.
Suppress) {
6910 std::string TypeStr;
6915 "static_cast<" + TypeStr +
">(")
6927 HadMultipleCandidates);
6934 From,
Result.get()->getType());
6944 QualType T,
bool HadMultipleCandidates,
6960 HadMultipleCandidates);
6965 CK_UserDefinedConversion,
Result.get(),
6966 nullptr,
Result.get()->getValueKind(),
6991 if (
auto *ConvTemplate = dyn_cast<FunctionTemplateDecl>(D)) {
6993 ConvTemplate, FoundDecl, ActingContext, From, ToType, CandidateSet,
6999 Conv, FoundDecl, ActingContext, From, ToType, CandidateSet,
7033 From = result.
get();
7039 From = Converted.
isUsable() ? Converted.
get() :
nullptr;
7041 if (Converter.
match(T))
7048 const RecordType *RecordTy = T->getAsCanonical<RecordType>();
7061 : Converter(Converter), From(From) {}
7066 } IncompleteDiagnoser(Converter, From);
7077 ->getDefinitionOrSelf()
7078 ->getVisibleConversionFunctions();
7080 bool HadMultipleCandidates =
7085 bool HasUniqueTargetType =
true;
7101 "Conversion operator templates are considered potentially "
7105 if (Converter.
match(CurToType) || ConvTemplate) {
7111 ExplicitConversions.
addDecl(I.getDecl(), I.getAccess());
7116 else if (HasUniqueTargetType &&
7118 HasUniqueTargetType =
false;
7120 ViableConversions.
addDecl(I.getDecl(), I.getAccess());
7138 HadMultipleCandidates,
7139 ExplicitConversions))
7145 if (!HasUniqueTargetType)
7164 HadMultipleCandidates,
Found))
7173 HadMultipleCandidates,
7174 ExplicitConversions))
7182 switch (ViableConversions.
size()) {
7185 HadMultipleCandidates,
7186 ExplicitConversions))
7196 HadMultipleCandidates,
Found))
7227 if (Proto->getNumParams() < 1)
7231 QualType ArgType = Proto->getParamType(0).getNonReferenceType();
7232 if (Context.hasSameUnqualifiedType(T1, ArgType))
7236 if (Proto->getNumParams() < 2)
7240 QualType ArgType = Proto->getParamType(1).getNonReferenceType();
7241 if (Context.hasSameUnqualifiedType(T2, ArgType))
7260 unsigned SeenAt = 0;
7262 bool HasDefault =
false;
7271 return HasDefault || SeenAt != 0;
7277 bool PartialOverloading,
bool AllowExplicit,
bool AllowExplicitConversions,
7280 bool StrictPackMatch) {
7283 assert(Proto &&
"Functions without a prototype cannot be overloaded");
7284 assert(!
Function->getDescribedFunctionTemplate() &&
7285 "Use AddTemplateOverloadCandidate for function templates");
7298 CandidateSet, SuppressUserConversions,
7299 PartialOverloading, EarlyConversions, PO,
7335 CandidateSet.
addCandidate(Args.size(), EarlyConversions);
7349 Candidate.
Viable =
false;
7362 bool IsImplicitlyInstantiated =
false;
7363 if (
auto *SpecInfo =
Function->getTemplateSpecializationInfo()) {
7364 ND = SpecInfo->getTemplate();
7365 IsImplicitlyInstantiated = SpecInfo->getTemplateSpecializationKind() ==
7376 const bool IsInlineFunctionInGMF =
7378 (IsImplicitlyInstantiated ||
Function->isInlined());
7381 Candidate.
Viable =
false;
7388 Candidate.
Viable =
false;
7399 if (Args.size() == 1 &&
Constructor->isSpecializationCopyingObject() &&
7400 (
Context.hasSameUnqualifiedType(ClassType, Args[0]->getType()) ||
7403 Candidate.
Viable =
false;
7415 auto *Shadow = dyn_cast<ConstructorUsingShadowDecl>(FoundDecl.
getDecl());
7416 if (Shadow && Args.size() == 1 &&
Constructor->getNumParams() >= 1 &&
7417 Constructor->getParamDecl(0)->getType()->isReferenceType()) {
7424 Candidate.
Viable =
false;
7433 Constructor->getMethodQualifiers().getAddressSpace(),
7435 Candidate.
Viable =
false;
7448 Candidate.
Viable =
false;
7458 unsigned MinRequiredArgs =
Function->getMinRequiredArguments();
7459 if (!AggregateCandidateDeduction && Args.size() < MinRequiredArgs &&
7460 !PartialOverloading) {
7462 Candidate.
Viable =
false;
7476 Candidate.
Viable =
false;
7482 if (
Function->getTrailingRequiresClause()) {
7487 Candidate.
Viable =
false;
7496 for (
unsigned ArgIdx = 0; ArgIdx < Args.size(); ++ArgIdx) {
7499 if (Candidate.
Conversions[ConvIdx].isInitialized()) {
7502 }
else if (ArgIdx < NumParams) {
7513 Args[ArgIdx]->
getType().getAddressSpace() ==
7515 Diag(Args[ArgIdx]->getBeginLoc(), diag::warn_hlsl_groupshared_inout);
7518 *
this, Args[ArgIdx], ParamType, SuppressUserConversions,
7521 getLangOpts().ObjCAutoRefCount, AllowExplicitConversions);
7523 Candidate.
Viable =
false;
7535 if (EnableIfAttr *FailedAttr =
7537 Candidate.
Viable =
false;
7547 if (Methods.size() <= 1)
7550 for (
unsigned b = 0, e = Methods.size(); b < e; b++) {
7556 if (
Method->param_size() > NumNamedArgs)
7557 NumNamedArgs =
Method->param_size();
7558 if (Args.size() < NumNamedArgs)
7561 for (
unsigned i = 0; i < NumNamedArgs; i++) {
7563 if (Args[i]->isTypeDependent()) {
7569 Expr *argExpr = Args[i];
7570 assert(argExpr &&
"SelectBestMethod(): missing expression");
7575 !param->
hasAttr<CFConsumedAttr>())
7576 argExpr =
ObjC().stripARCUnbridgedCast(argExpr);
7593 if (ConversionState.
isBad() ||
7603 for (
unsigned i = NumNamedArgs, e = Args.size(); i < e; ++i) {
7604 if (Args[i]->isTypeDependent()) {
7617 if (Args.size() != NumNamedArgs)
7619 else if (
Match && NumNamedArgs == 0 && Methods.size() > 1) {
7622 for (
unsigned b = 0, e = Methods.size(); b < e; b++) {
7623 QualType ReturnT = Methods[b]->getReturnType();
7643 "Shouldn't have `this` for ctors!");
7644 assert(!Method->isStatic() &&
"Shouldn't have `this` for static methods!");
7646 ThisArg, std::nullopt, Method, Method);
7649 ConvertedThis = R.get();
7651 if (
auto *MD = dyn_cast<CXXMethodDecl>(Function)) {
7653 assert((MissingImplicitThis || MD->isStatic() ||
7655 "Expected `this` for non-ctor instance methods");
7657 ConvertedThis =
nullptr;
7662 unsigned ArgSizeNoVarargs = std::min(Function->param_size(), Args.size());
7665 for (
unsigned I = 0; I != ArgSizeNoVarargs; ++I) {
7668 S.
Context, Function->getParamDecl(I)),
7674 ConvertedArgs.push_back(R.get());
7681 if (!Function->isVariadic() && Args.size() < Function->getNumParams()) {
7682 for (
unsigned i = Args.size(), e = Function->getNumParams(); i != e; ++i) {
7689 ConvertedArgs.push_back(R.get());
7701 bool MissingImplicitThis) {
7702 auto EnableIfAttrs =
Function->specific_attrs<EnableIfAttr>();
7703 if (EnableIfAttrs.begin() == EnableIfAttrs.end())
7709 llvm::scope_exit UndelayDiags(
7711 DelayedDiagnostics.popUndelayed(CurrentState);
7715 Expr *DiscardedThis;
7717 *
this,
Function,
nullptr, CallLoc, Args, Trap,
7718 true, DiscardedThis, ConvertedArgs))
7719 return *EnableIfAttrs.begin();
7721 for (
auto *EIA : EnableIfAttrs) {
7725 if (EIA->getCond()->isValueDependent() ||
7726 !EIA->getCond()->EvaluateWithSubstitution(
7730 if (!
Result.isInt() || !
Result.getInt().getBoolValue())
7736template <
typename CheckFn>
7739 CheckFn &&IsSuccessful) {
7742 if (ArgDependent == DIA->getArgDependent())
7743 Attrs.push_back(DIA);
7750 auto WarningBegin = std::stable_partition(
7751 Attrs.begin(), Attrs.end(), [](
const DiagnoseIfAttr *DIA) {
7752 return DIA->getDefaultSeverity() == DiagnoseIfAttr::DS_error &&
7753 DIA->getWarningGroup().empty();
7758 auto ErrAttr = llvm::find_if(llvm::make_range(Attrs.begin(), WarningBegin),
7760 if (ErrAttr != WarningBegin) {
7761 const DiagnoseIfAttr *DIA = *ErrAttr;
7762 S.
Diag(Loc, diag::err_diagnose_if_succeeded) << DIA->getMessage();
7763 S.
Diag(DIA->getLocation(), diag::note_from_diagnose_if)
7764 << DIA->getParent() << DIA->getCond()->getSourceRange();
7768 auto ToSeverity = [](DiagnoseIfAttr::DefaultSeverity Sev) {
7770 case DiagnoseIfAttr::DS_warning:
7772 case DiagnoseIfAttr::DS_error:
7775 llvm_unreachable(
"Fully covered switch above!");
7778 for (
const auto *DIA : llvm::make_range(WarningBegin, Attrs.end()))
7779 if (IsSuccessful(DIA)) {
7780 if (DIA->getWarningGroup().empty() &&
7781 DIA->getDefaultSeverity() == DiagnoseIfAttr::DS_warning) {
7782 S.
Diag(Loc, diag::warn_diagnose_if_succeeded) << DIA->getMessage();
7783 S.
Diag(DIA->getLocation(), diag::note_from_diagnose_if)
7784 << DIA->getParent() << DIA->getCond()->getSourceRange();
7787 DIA->getWarningGroup());
7790 {ToSeverity(DIA->getDefaultSeverity()),
"%0",
7792 S.
Diag(Loc, DiagID) << DIA->getMessage();
7800 const Expr *ThisArg,
7805 [&](
const DiagnoseIfAttr *DIA) {
7810 if (!DIA->getCond()->EvaluateWithSubstitution(
7813 return Result.isInt() &&
Result.getInt().getBoolValue();
7820 *
this, ND,
false, Loc,
7821 [&](
const DiagnoseIfAttr *DIA) {
7823 return DIA->getCond()->EvaluateAsBooleanCondition(
Result,
Context) &&
7832 bool SuppressUserConversions,
7833 bool PartialOverloading,
7834 bool FirstArgumentIsBase) {
7846 if (Args.size() > 0) {
7847 if (
Expr *E = Args[0]) {
7857 FunctionArgs = Args.slice(1);
7861 FunTmpl, F.getPair(),
7863 ExplicitTemplateArgs, ObjectType, ObjectClassification,
7864 FunctionArgs, CandidateSet, SuppressUserConversions,
7865 PartialOverloading);
7869 ObjectClassification, FunctionArgs, CandidateSet,
7870 SuppressUserConversions, PartialOverloading);
7877 if (Args.size() > 0 &&
7881 FunctionArgs = Args.slice(1);
7885 ExplicitTemplateArgs, FunctionArgs,
7886 CandidateSet, SuppressUserConversions,
7887 PartialOverloading);
7890 SuppressUserConversions, PartialOverloading);
7900 bool SuppressUserConversions,
7910 "Expected a member function template");
7912 nullptr, ObjectType,
7913 ObjectClassification, Args, CandidateSet,
7914 SuppressUserConversions,
false, PO);
7917 ObjectType, ObjectClassification, Args, CandidateSet,
7918 SuppressUserConversions,
false, {}, PO);
7931 assert(Proto &&
"Methods without a prototype cannot be overloaded");
7933 "Use AddOverloadCandidate for constructors");
7942 Method->isMoveAssignmentOperator())
7949 bool IgnoreExplicitObject =
7950 (
Method->isExplicitObjectMemberFunction() &&
7953 bool ImplicitObjectMethodTreatedAsStatic =
7956 Method->isImplicitObjectMemberFunction();
7958 unsigned ExplicitOffset =
7959 !IgnoreExplicitObject &&
Method->isExplicitObjectMemberFunction() ? 1 : 0;
7961 unsigned NumParams =
Method->getNumParams() - ExplicitOffset +
7962 int(ImplicitObjectMethodTreatedAsStatic);
7964 unsigned ExtraArgs =
7971 CandidateSet.
addCandidate(Args.size() + ExtraArgs, EarlyConversions);
7987 Candidate.
Viable =
false;
7997 unsigned MinRequiredArgs =
Method->getMinRequiredArguments() -
7999 int(ImplicitObjectMethodTreatedAsStatic);
8001 if (Args.size() < MinRequiredArgs && !PartialOverloading) {
8003 Candidate.
Viable =
false;
8011 if (!IgnoreExplicitObject) {
8014 else if (
Method->isStatic()) {
8024 Candidate.
Conversions[FirstConvIdx].setStaticObjectArgument();
8029 *
this, CandidateSet.
getLocation(), ObjectType, ObjectClassification,
8030 Method, ActingContext,
true);
8031 if (Candidate.
Conversions[FirstConvIdx].isBad()) {
8032 Candidate.
Viable =
false;
8043 Candidate.
Viable =
false;
8048 if (
Method->getTrailingRequiresClause()) {
8053 Candidate.
Viable =
false;
8061 for (
unsigned ArgIdx = 0; ArgIdx < Args.size(); ++ArgIdx) {
8064 if (Candidate.
Conversions[ConvIdx].isInitialized()) {
8067 }
else if (ArgIdx < NumParams) {
8073 if (ImplicitObjectMethodTreatedAsStatic) {
8074 ParamType = ArgIdx == 0
8075 ?
Method->getFunctionObjectParameterReferenceType()
8078 ParamType = Proto->
getParamType(ArgIdx + ExplicitOffset);
8082 SuppressUserConversions,
8087 Candidate.
Viable =
false;
8099 if (EnableIfAttr *FailedAttr =
8101 Candidate.
Viable =
false;
8108 Candidate.
Viable =
false;
8119 bool SuppressUserConversions,
bool PartialOverloading,
8137 PartialOverloading,
false,
8138 false, ObjectType, ObjectClassification,
8142 bool OnlyInitializeNonUserDefinedConversions) {
8143 return S.CheckNonDependentConversions(
8144 MethodTmpl, ParamTypes, Args, CandidateSet, Conversions,
8145 Sema::CheckNonDependentConversionsFlag(
8146 SuppressUserConversions,
8147 OnlyInitializeNonUserDefinedConversions),
8148 ActingContext, ObjectType, ObjectClassification, PO);
8152 CandidateSet.
addCandidate(Conversions.size(), Conversions);
8155 Candidate.
Viable =
false;
8164 Method->isStatic() ||
8165 (!Method->isExplicitObjectMemberFunction() && ObjectType.
isNull());
8179 assert(
Specialization &&
"Missing member function template specialization?");
8181 "Specialization is not a member function?");
8184 ObjectClassification, Args, CandidateSet, SuppressUserConversions,
8198 if (ExplicitTemplateArgs ||
8201 *
this, CandidateSet, MethodTmpl, FoundDecl, ActingContext,
8202 ExplicitTemplateArgs, ObjectType, ObjectClassification, Args,
8203 SuppressUserConversions, PartialOverloading, PO);
8208 MethodTmpl, FoundDecl, ActingContext, ObjectType, ObjectClassification,
8209 Args, SuppressUserConversions, PartialOverloading, PO);
8227 bool SuppressUserConversions,
bool PartialOverloading,
bool AllowExplicit,
8229 bool AggregateCandidateDeduction) {
8238 Candidate.
Viable =
false;
8258 PartialOverloading, AggregateCandidateDeduction,
8265 bool OnlyInitializeNonUserDefinedConversions) {
8266 return S.CheckNonDependentConversions(
8267 FunctionTemplate, ParamTypes, Args, CandidateSet, Conversions,
8268 Sema::CheckNonDependentConversionsFlag(
8269 SuppressUserConversions,
8270 OnlyInitializeNonUserDefinedConversions),
8271 nullptr, QualType(), {}, PO);
8274 OverloadCandidate &Candidate =
8275 CandidateSet.addCandidate(Conversions.size(), Conversions);
8278 Candidate.
Viable =
false;
8280 CandidateSet.getRewriteInfo().getRewriteKind(Candidate.
Function, PO);
8286 CandidateSet.getKind() ==
8292 ->isExplicitObjectMemberFunction() &&
8308 assert(
Specialization &&
"Missing function template specialization?");
8310 Specialization, FoundDecl, Args, CandidateSet, SuppressUserConversions,
8311 PartialOverloading, AllowExplicit,
8312 false, IsADLCandidate, Conversions, PO,
8313 Info.AggregateDeductionCandidateHasMismatchedArity,
8314 Info.hasStrictPackMatch());
8321 bool PartialOverloading,
bool AllowExplicit,
ADLCallKind IsADLCandidate,
8328 if (ExplicitTemplateArgs ||
8331 DependentExplicitSpecifier)) {
8335 Args, SuppressUserConversions, PartialOverloading, AllowExplicit,
8336 IsADLCandidate, PO, AggregateCandidateDeduction);
8338 if (DependentExplicitSpecifier)
8345 PartialOverloading, AllowExplicit, IsADLCandidate, PO,
8346 AggregateCandidateDeduction);
8359 const bool AllowExplicit =
false;
8361 bool ForOverloadSetAddressResolution =
8364 auto *
Method = dyn_cast<CXXMethodDecl>(FD);
8365 bool HasThisConversion = !ForOverloadSetAddressResolution &&
Method &&
8367 unsigned ThisConversions = HasThisConversion ? 1 : 0;
8383 if (!FD->hasCXXExplicitFunctionObjectParameter() ||
8384 !ParamTypes[0]->isDependentType()) {
8386 *
this, CandidateSet.
getLocation(), ObjectType, ObjectClassification,
8387 Method, ActingContext,
true,
8388 FD->hasCXXExplicitFunctionObjectParameter() ? ParamTypes[0]
8398 auto MaybeInvolveUserDefinedConversion = [&](
QualType ParamType,
8422 if (
auto *RD =
ArgType->getAsCXXRecordDecl();
8423 RD && RD->hasDefinition() &&
8424 !RD->getVisibleConversionFunctions().empty())
8431 HasThisConversion &&
Method->hasCXXExplicitFunctionObjectParameter() ? 1
8434 for (
unsigned I = 0, N = std::min(ParamTypes.size() - Offset, Args.size());
8436 QualType ParamType = ParamTypes[I + Offset];
8440 ConvIdx = Args.size() - 1 - I;
8441 assert(Args.size() + ThisConversions == 2 &&
8442 "number of args (including 'this') must be exactly 2 for "
8446 assert(!HasThisConversion || (ConvIdx == 0 && I == 0));
8449 ConvIdx = ThisConversions + I;
8454 MaybeInvolveUserDefinedConversion(ParamType, Args[I]->
getType()))
8483 bool AllowObjCPointerConversion) {
8491 bool ObjCLifetimeConversion;
8493 ObjCLifetimeConversion))
8498 if (!AllowObjCPointerConversion)
8502 bool IncompatibleObjC =
false;
8512 bool AllowExplicit,
bool AllowResultConversion,
bool StrictPackMatch) {
8514 "Conversion function templates use AddTemplateConversionCandidate");
8529 if (!AllowResultConversion &&
8541 AllowObjCConversionOnExplicit))
8563 if (!AllowExplicit && Conversion->
isExplicit()) {
8564 Candidate.
Viable =
false;
8591 Candidate.
Viable =
false;
8600 Candidate.
Viable =
false;
8611 QualType ToCanon =
Context.getCanonicalType(ToType).getUnqualifiedType();
8612 if (FromCanon == ToCanon ||
8614 Candidate.
Viable =
false;
8631 CK_FunctionToPointerDecay, &ConversionRef,
8636 Candidate.
Viable =
false;
8666 Candidate.
Viable =
false;
8678 Candidate.
Viable =
false;
8685 Candidate.
Viable =
false;
8691 "Can only end up with a standard conversion sequence or failure");
8694 if (EnableIfAttr *FailedAttr =
8696 Candidate.
Viable =
false;
8703 Candidate.
Viable =
false;
8712 bool AllowObjCConversionOnExplicit,
bool AllowExplicit,
8713 bool AllowResultConversion) {
8722 Candidate.
Viable =
false;
8739 Candidate.
Viable =
false;
8749 assert(
Specialization &&
"Missing function template specialization?");
8751 ToType, CandidateSet, AllowObjCConversionOnExplicit,
8752 AllowExplicit, AllowResultConversion,
8760 bool AllowExplicit,
bool AllowResultConversion) {
8762 "Only conversion function templates permitted here");
8773 ToType, AllowObjCConversionOnExplicit, AllowExplicit,
8774 AllowResultConversion);
8782 AllowObjCConversionOnExplicit, AllowExplicit, AllowResultConversion);
8821 if (ObjectInit.
isBad()) {
8822 Candidate.
Viable =
false;
8833 Candidate.
Conversions[0].UserDefined.EllipsisConversion =
false;
8834 Candidate.
Conversions[0].UserDefined.HadMultipleCandidates =
false;
8835 Candidate.
Conversions[0].UserDefined.ConversionFunction = Conversion;
8836 Candidate.
Conversions[0].UserDefined.FoundConversionFunction = FoundDecl;
8839 Candidate.
Conversions[0].UserDefined.After.setAsIdentityConversion();
8847 if (Args.size() > NumParams && !Proto->
isVariadic()) {
8848 Candidate.
Viable =
false;
8855 if (Args.size() < NumParams) {
8857 Candidate.
Viable =
false;
8864 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
8865 if (ArgIdx < NumParams) {
8878 Candidate.
Viable =
false;
8895 Candidate.
Viable =
false;
8901 if (EnableIfAttr *FailedAttr =
8903 Candidate.
Viable =
false;
8927 "unqualified operator lookup found a member function");
8931 FunctionArgs, CandidateSet);
8937 FunctionArgs[1], FunctionArgs[0]);
8939 Reversed, CandidateSet,
false,
false,
true,
8940 ADLCallKind::NotADL,
8944 if (ExplicitTemplateArgs)
8949 {FunctionArgs[1], FunctionArgs[0]}, CandidateSet,
8950 false,
false,
true,
false, ADLCallKind::NotADL, {},
8982 if (!T1RD || (!IsComplete && !T1RD->isBeingDefined()))
8990 OperEnd = Operators.
end();
8991 Oper != OperEnd; ++Oper) {
8992 if (Oper->getAsFunction() &&
8995 *
this, {Args[1], Args[0]}, Oper->getAsFunction()))
8998 Args[0]->Classify(
Context), Args.slice(1),
8999 CandidateSet,
false, PO);
9006 bool IsAssignmentOperator,
9007 unsigned NumContextualBoolArguments) {
9022 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
9035 if (ArgIdx < NumContextualBoolArguments) {
9036 assert(ParamTys[ArgIdx] ==
Context.BoolTy &&
9037 "Contextual conversion to bool requires bool type");
9043 ArgIdx == 0 && IsAssignmentOperator,
9049 Candidate.
Viable =
false;
9062class BuiltinCandidateTypeSet {
9068 TypeSet PointerTypes;
9072 TypeSet MemberPointerTypes;
9076 TypeSet EnumerationTypes;
9080 TypeSet VectorTypes;
9084 TypeSet MatrixTypes;
9087 TypeSet BitIntTypes;
9090 bool HasNonRecordTypes;
9094 bool HasArithmeticOrEnumeralTypes;
9098 bool HasNullPtrType;
9107 bool AddPointerWithMoreQualifiedTypeVariants(
QualType Ty,
9109 bool AddMemberPointerWithMoreQualifiedTypeVariants(
QualType Ty);
9113 typedef TypeSet::iterator
iterator;
9115 BuiltinCandidateTypeSet(
Sema &SemaRef)
9116 : HasNonRecordTypes(
false),
9117 HasArithmeticOrEnumeralTypes(
false),
9118 HasNullPtrType(
false),
9120 Context(SemaRef.Context) { }
9122 void AddTypesConvertedFrom(
QualType Ty,
9124 bool AllowUserConversions,
9125 bool AllowExplicitConversions,
9126 const Qualifiers &VisibleTypeConversionsQuals);
9128 llvm::iterator_range<iterator> pointer_types() {
return PointerTypes; }
9129 llvm::iterator_range<iterator> member_pointer_types() {
9130 return MemberPointerTypes;
9132 llvm::iterator_range<iterator> enumeration_types() {
9133 return EnumerationTypes;
9135 llvm::iterator_range<iterator> vector_types() {
return VectorTypes; }
9136 llvm::iterator_range<iterator> matrix_types() {
return MatrixTypes; }
9137 llvm::iterator_range<iterator> bitint_types() {
return BitIntTypes; }
9139 bool containsMatrixType(QualType Ty)
const {
return MatrixTypes.count(Ty); }
9140 bool hasNonRecordTypes() {
return HasNonRecordTypes; }
9141 bool hasArithmeticOrEnumeralTypes() {
return HasArithmeticOrEnumeralTypes; }
9142 bool hasNullPtrType()
const {
return HasNullPtrType; }
9157BuiltinCandidateTypeSet::AddPointerWithMoreQualifiedTypeVariants(QualType Ty,
9158 const Qualifiers &VisibleQuals) {
9161 if (!PointerTypes.insert(Ty))
9165 const PointerType *PointerTy = Ty->
getAs<PointerType>();
9166 bool buildObjCPtr =
false;
9168 const ObjCObjectPointerType *PTy = Ty->
castAs<ObjCObjectPointerType>();
9170 buildObjCPtr =
true;
9182 unsigned BaseCVR = PointeeTy.getCVRQualifiers();
9188 if ((CVR | BaseCVR) != CVR)
continue;
9203 QualType QPointerTy;
9210 PointerTypes.insert(QPointerTy);
9226BuiltinCandidateTypeSet::AddMemberPointerWithMoreQualifiedTypeVariants(
9229 if (!MemberPointerTypes.insert(Ty))
9232 const MemberPointerType *PointerTy = Ty->
getAs<MemberPointerType>();
9233 assert(PointerTy &&
"type was not a member pointer type!");
9248 if ((CVR | BaseCVR) != CVR)
continue;
9252 QPointeeTy, std::nullopt, Cls));
9267BuiltinCandidateTypeSet::AddTypesConvertedFrom(QualType Ty,
9269 bool AllowUserConversions,
9270 bool AllowExplicitConversions,
9271 const Qualifiers &VisibleQuals) {
9277 if (
const ReferenceType *RefTy = Ty->
getAs<ReferenceType>())
9282 Ty = SemaRef.Context.getArrayDecayedType(Ty);
9289 HasNonRecordTypes = HasNonRecordTypes || !TyIsRec;
9292 HasArithmeticOrEnumeralTypes =
9296 PointerTypes.insert(Ty);
9297 else if (Ty->
getAs<PointerType>() || Ty->
getAs<ObjCObjectPointerType>()) {
9300 if (!AddPointerWithMoreQualifiedTypeVariants(Ty, VisibleQuals))
9304 if (!AddMemberPointerWithMoreQualifiedTypeVariants(Ty))
9307 HasArithmeticOrEnumeralTypes =
true;
9308 EnumerationTypes.insert(Ty);
9310 HasArithmeticOrEnumeralTypes =
true;
9311 BitIntTypes.insert(Ty);
9315 HasArithmeticOrEnumeralTypes =
true;
9316 VectorTypes.insert(Ty);
9320 HasArithmeticOrEnumeralTypes =
true;
9321 MatrixTypes.insert(Ty);
9323 HasNullPtrType =
true;
9324 }
else if (AllowUserConversions && TyIsRec) {
9326 if (!SemaRef.isCompleteType(Loc, Ty))
9330 for (NamedDecl *D : ClassDecl->getVisibleConversionFunctions()) {
9340 if (AllowExplicitConversions || !Conv->
isExplicit()) {
9388 ClassDecl = RHSMPType->getMostRecentCXXRecordDecl();
9436 if (Available.hasAtomic()) {
9437 Available.removeAtomic();
9444 if (Available.hasVolatile()) {
9445 Available.removeVolatile();
9479class BuiltinOperatorOverloadBuilder {
9482 ArrayRef<Expr *> Args;
9483 QualifiersAndAtomic VisibleTypeConversionsQuals;
9484 bool HasArithmeticOrEnumeralCandidateType;
9485 SmallVectorImpl<BuiltinCandidateTypeSet> &CandidateTypes;
9486 OverloadCandidateSet &CandidateSet;
9488 static constexpr int ArithmeticTypesCap = 26;
9489 SmallVector<CanQualType, ArithmeticTypesCap> ArithmeticTypes;
9494 unsigned FirstIntegralType,
9496 unsigned FirstPromotedIntegralType,
9497 LastPromotedIntegralType;
9498 unsigned FirstPromotedArithmeticType,
9499 LastPromotedArithmeticType;
9500 unsigned NumArithmeticTypes;
9502 void InitArithmeticTypes() {
9504 FirstPromotedArithmeticType = 0;
9514 FirstIntegralType = ArithmeticTypes.size();
9515 FirstPromotedIntegralType = ArithmeticTypes.size();
9537 llvm::SmallSetVector<CanQualType, 2> BitIntCandidates;
9538 for (BuiltinCandidateTypeSet &Candidate : CandidateTypes) {
9539 for (QualType BitTy : Candidate.bitint_types())
9542 llvm::move(BitIntCandidates, std::back_inserter(ArithmeticTypes));
9543 LastPromotedIntegralType = ArithmeticTypes.size();
9544 LastPromotedArithmeticType = ArithmeticTypes.size();
9558 LastIntegralType = ArithmeticTypes.size();
9559 NumArithmeticTypes = ArithmeticTypes.size();
9566 assert(ArithmeticTypes.size() - BitIntCandidates.size() <=
9567 ArithmeticTypesCap &&
9568 "Enough inline storage for all arithmetic types.");
9573 void addPlusPlusMinusMinusStyleOverloads(QualType CandidateTy,
9576 QualType ParamTypes[2] = {
9616 void AddCandidate(QualType L, QualType R) {
9617 QualType LandR[2] = {L,
R};
9622 BuiltinOperatorOverloadBuilder(
9623 Sema &S, ArrayRef<Expr *> Args,
9624 QualifiersAndAtomic VisibleTypeConversionsQuals,
9625 bool HasArithmeticOrEnumeralCandidateType,
9626 SmallVectorImpl<BuiltinCandidateTypeSet> &CandidateTypes,
9627 OverloadCandidateSet &CandidateSet)
9629 VisibleTypeConversionsQuals(VisibleTypeConversionsQuals),
9630 HasArithmeticOrEnumeralCandidateType(
9631 HasArithmeticOrEnumeralCandidateType),
9632 CandidateTypes(CandidateTypes),
9633 CandidateSet(CandidateSet) {
9635 InitArithmeticTypes();
9658 if (!HasArithmeticOrEnumeralCandidateType)
9661 for (
unsigned Arith = 0; Arith < NumArithmeticTypes; ++Arith) {
9662 const auto TypeOfT = ArithmeticTypes[Arith];
9664 if (Op == OO_MinusMinus)
9666 if (Op == OO_PlusPlus && S.
getLangOpts().CPlusPlus17)
9669 addPlusPlusMinusMinusStyleOverloads(
9686 void addPlusPlusMinusMinusPointerOverloads() {
9687 for (QualType PtrTy : CandidateTypes[0].pointer_types()) {
9689 if (!PtrTy->getPointeeType()->isObjectType())
9692 addPlusPlusMinusMinusStyleOverloads(
9694 (!PtrTy.isVolatileQualified() &&
9696 (!PtrTy.isRestrictQualified() &&
9711 void addUnaryStarPointerOverloads() {
9712 for (QualType ParamTy : CandidateTypes[0].pointer_types()) {
9717 if (
const FunctionProtoType *Proto =PointeeTy->
getAs<FunctionProtoType>())
9718 if (Proto->getMethodQuals() || Proto->getRefQualifier())
9731 void addUnaryPlusOrMinusArithmeticOverloads() {
9732 if (!HasArithmeticOrEnumeralCandidateType)
9735 for (
unsigned Arith = FirstPromotedArithmeticType;
9736 Arith < LastPromotedArithmeticType; ++Arith) {
9737 QualType ArithTy = ArithmeticTypes[Arith];
9742 for (QualType VecTy : CandidateTypes[0].vector_types())
9751 void addUnaryPlusPointerOverloads() {
9752 for (QualType ParamTy : CandidateTypes[0].pointer_types())
9761 void addUnaryTildePromotedIntegralOverloads() {
9762 if (!HasArithmeticOrEnumeralCandidateType)
9765 for (
unsigned Int = FirstPromotedIntegralType;
9766 Int < LastPromotedIntegralType; ++
Int) {
9767 QualType IntTy = ArithmeticTypes[
Int];
9772 for (QualType VecTy : CandidateTypes[0].vector_types())
9782 void addEqualEqualOrNotEqualMemberPointerOrNullptrOverloads() {
9784 llvm::SmallPtrSet<QualType, 8> AddedTypes;
9786 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
9787 for (QualType MemPtrTy : CandidateTypes[ArgIdx].member_pointer_types()) {
9792 QualType ParamTypes[2] = {MemPtrTy, MemPtrTy};
9796 if (CandidateTypes[ArgIdx].hasNullPtrType()) {
9798 if (AddedTypes.insert(NullPtrTy).second) {
9799 QualType ParamTypes[2] = { NullPtrTy, NullPtrTy };
9818 void addGenericBinaryPointerOrEnumeralOverloads(
bool IsSpaceship) {
9831 llvm::DenseSet<std::pair<CanQualType, CanQualType> >
9832 UserDefinedBinaryOperators;
9834 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
9835 if (!CandidateTypes[ArgIdx].enumeration_types().empty()) {
9837 CEnd = CandidateSet.
end();
9839 if (!
C->Viable || !
C->Function ||
C->Function->getNumParams() != 2)
9842 if (
C->Function->isFunctionTemplateSpecialization())
9849 QualType FirstParamType =
C->Function->getParamDecl(
Reversed ? 1 : 0)
9851 .getUnqualifiedType();
9852 QualType SecondParamType =
C->Function->getParamDecl(
Reversed ? 0 : 1)
9854 .getUnqualifiedType();
9862 UserDefinedBinaryOperators.insert(
9870 llvm::SmallPtrSet<QualType, 8> AddedTypes;
9872 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
9873 for (QualType PtrTy : CandidateTypes[ArgIdx].pointer_types()) {
9877 if (IsSpaceship && PtrTy->isFunctionPointerType())
9880 QualType ParamTypes[2] = {PtrTy, PtrTy};
9883 for (QualType EnumTy : CandidateTypes[ArgIdx].enumeration_types()) {
9888 if (!AddedTypes.insert(CanonType).second ||
9889 UserDefinedBinaryOperators.count(std::make_pair(CanonType,
9892 QualType ParamTypes[2] = {EnumTy, EnumTy};
9917 llvm::SmallPtrSet<QualType, 8> AddedTypes;
9919 for (
int Arg = 0; Arg < 2; ++Arg) {
9920 QualType AsymmetricParamTypes[2] = {
9924 for (QualType PtrTy : CandidateTypes[Arg].pointer_types()) {
9929 AsymmetricParamTypes[Arg] = PtrTy;
9930 if (Arg == 0 || Op == OO_Plus) {
9935 if (Op == OO_Minus) {
9940 QualType ParamTypes[2] = {PtrTy, PtrTy};
9976 void addGenericBinaryArithmeticOverloads() {
9977 if (!HasArithmeticOrEnumeralCandidateType)
9980 for (
unsigned Left = FirstPromotedArithmeticType;
9981 Left < LastPromotedArithmeticType; ++
Left) {
9982 for (
unsigned Right = FirstPromotedArithmeticType;
9983 Right < LastPromotedArithmeticType; ++
Right) {
9984 QualType LandR[2] = { ArithmeticTypes[
Left],
9985 ArithmeticTypes[
Right] };
9992 for (QualType Vec1Ty : CandidateTypes[0].vector_types())
9993 for (QualType Vec2Ty : CandidateTypes[1].vector_types()) {
9994 QualType LandR[2] = {Vec1Ty, Vec2Ty};
10004 void addMatrixBinaryArithmeticOverloads() {
10005 if (!HasArithmeticOrEnumeralCandidateType)
10008 for (QualType M1 : CandidateTypes[0].matrix_types()) {
10010 AddCandidate(M1, M1);
10013 for (QualType M2 : CandidateTypes[1].matrix_types()) {
10015 if (!CandidateTypes[0].containsMatrixType(M2))
10016 AddCandidate(M2, M2);
10051 void addThreeWayArithmeticOverloads() {
10052 addGenericBinaryArithmeticOverloads();
10069 void addBinaryBitwiseArithmeticOverloads() {
10070 if (!HasArithmeticOrEnumeralCandidateType)
10073 for (
unsigned Left = FirstPromotedIntegralType;
10074 Left < LastPromotedIntegralType; ++
Left) {
10075 for (
unsigned Right = FirstPromotedIntegralType;
10076 Right < LastPromotedIntegralType; ++
Right) {
10077 QualType LandR[2] = { ArithmeticTypes[
Left],
10078 ArithmeticTypes[
Right] };
10091 void addAssignmentMemberPointerOrEnumeralOverloads() {
10093 llvm::SmallPtrSet<QualType, 8> AddedTypes;
10095 for (
unsigned ArgIdx = 0; ArgIdx < 2; ++ArgIdx) {
10096 for (QualType EnumTy : CandidateTypes[ArgIdx].enumeration_types()) {
10103 for (QualType MemPtrTy : CandidateTypes[ArgIdx].member_pointer_types()) {
10128 void addAssignmentPointerOverloads(
bool isEqualOp) {
10130 llvm::SmallPtrSet<QualType, 8> AddedTypes;
10132 for (QualType PtrTy : CandidateTypes[0].pointer_types()) {
10136 else if (!PtrTy->getPointeeType()->isObjectType())
10140 QualType ParamTypes[2] = {
10147 bool NeedVolatile = !PtrTy.isVolatileQualified() &&
10149 if (NeedVolatile) {
10157 if (!PtrTy.isRestrictQualified() &&
10165 if (NeedVolatile) {
10177 for (QualType PtrTy : CandidateTypes[1].pointer_types()) {
10182 QualType ParamTypes[2] = {
10191 bool NeedVolatile = !PtrTy.isVolatileQualified() &&
10193 if (NeedVolatile) {
10201 if (!PtrTy.isRestrictQualified() &&
10209 if (NeedVolatile) {
10234 void addAssignmentArithmeticOverloads(
bool isEqualOp) {
10235 if (!HasArithmeticOrEnumeralCandidateType)
10238 for (
unsigned Left = 0;
Left < NumArithmeticTypes; ++
Left) {
10239 for (
unsigned Right = FirstPromotedArithmeticType;
10240 Right < LastPromotedArithmeticType; ++
Right) {
10241 QualType ParamTypes[2];
10242 ParamTypes[1] = ArithmeticTypes[
Right];
10244 S, ArithmeticTypes[Left], Args[0]);
10247 VisibleTypeConversionsQuals, [&](QualifiersAndAtomic Quals) {
10257 for (QualType Vec1Ty : CandidateTypes[0].vector_types())
10258 for (QualType Vec2Ty : CandidateTypes[0].vector_types()) {
10259 QualType ParamTypes[2];
10260 ParamTypes[1] = Vec2Ty;
10288 void addAssignmentIntegralOverloads() {
10289 if (!HasArithmeticOrEnumeralCandidateType)
10292 for (
unsigned Left = FirstIntegralType;
Left < LastIntegralType; ++
Left) {
10293 for (
unsigned Right = FirstPromotedIntegralType;
10294 Right < LastPromotedIntegralType; ++
Right) {
10295 QualType ParamTypes[2];
10296 ParamTypes[1] = ArithmeticTypes[
Right];
10298 S, ArithmeticTypes[Left], Args[0]);
10301 VisibleTypeConversionsQuals, [&](QualifiersAndAtomic Quals) {
10317 void addExclaimOverload() {
10323 void addAmpAmpOrPipePipeOverload() {
10340 void addSubscriptOverloads() {
10341 for (QualType PtrTy : CandidateTypes[0].pointer_types()) {
10351 for (QualType PtrTy : CandidateTypes[1].pointer_types()) {
10371 void addArrowStarOverloads() {
10372 for (QualType PtrTy : CandidateTypes[0].pointer_types()) {
10373 QualType C1Ty = PtrTy;
10375 QualifierCollector Q1;
10386 for (QualType MemPtrTy : CandidateTypes[1].member_pointer_types()) {
10393 QualType ParamTypes[2] = {PtrTy, MemPtrTy};
10396 if (!VisibleTypeConversionsQuals.
hasVolatile() &&
10399 if (!VisibleTypeConversionsQuals.
hasRestrict() &&
10418 void addConditionalOperatorOverloads() {
10420 llvm::SmallPtrSet<QualType, 8> AddedTypes;
10422 for (
unsigned ArgIdx = 0; ArgIdx < 2; ++ArgIdx) {
10423 for (QualType PtrTy : CandidateTypes[ArgIdx].pointer_types()) {
10427 QualType ParamTypes[2] = {PtrTy, PtrTy};
10431 for (QualType MemPtrTy : CandidateTypes[ArgIdx].member_pointer_types()) {
10435 QualType ParamTypes[2] = {MemPtrTy, MemPtrTy};
10440 for (QualType EnumTy : CandidateTypes[ArgIdx].enumeration_types()) {
10441 if (!EnumTy->castAsCanonical<EnumType>()->getDecl()->isScoped())
10447 QualType ParamTypes[2] = {EnumTy, EnumTy};
10466 VisibleTypeConversionsQuals.
addConst();
10467 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
10469 if (Args[ArgIdx]->
getType()->isAtomicType())
10470 VisibleTypeConversionsQuals.
addAtomic();
10473 bool HasNonRecordCandidateType =
false;
10474 bool HasArithmeticOrEnumeralCandidateType =
false;
10476 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
10477 CandidateTypes.emplace_back(*
this);
10478 CandidateTypes[ArgIdx].AddTypesConvertedFrom(Args[ArgIdx]->
getType(),
10481 (Op == OO_Exclaim ||
10483 Op == OO_PipePipe),
10484 VisibleTypeConversionsQuals);
10485 HasNonRecordCandidateType = HasNonRecordCandidateType ||
10486 CandidateTypes[ArgIdx].hasNonRecordTypes();
10487 HasArithmeticOrEnumeralCandidateType =
10488 HasArithmeticOrEnumeralCandidateType ||
10489 CandidateTypes[ArgIdx].hasArithmeticOrEnumeralTypes();
10497 if (!HasNonRecordCandidateType &&
10498 !(Op == OO_Exclaim || Op == OO_AmpAmp || Op == OO_PipePipe))
10502 BuiltinOperatorOverloadBuilder OpBuilder(*
this, Args,
10503 VisibleTypeConversionsQuals,
10504 HasArithmeticOrEnumeralCandidateType,
10505 CandidateTypes, CandidateSet);
10511 llvm_unreachable(
"Expected an overloaded operator");
10516 case OO_Array_Delete:
10519 "Special operators don't use AddBuiltinOperatorCandidates");
10531 if (Args.size() == 1)
10532 OpBuilder.addUnaryPlusPointerOverloads();
10536 if (Args.size() == 1) {
10537 OpBuilder.addUnaryPlusOrMinusArithmeticOverloads();
10539 OpBuilder.addBinaryPlusOrMinusPointerOverloads(Op);
10540 OpBuilder.addGenericBinaryArithmeticOverloads();
10541 OpBuilder.addMatrixBinaryArithmeticOverloads();
10546 if (Args.size() == 1)
10547 OpBuilder.addUnaryStarPointerOverloads();
10549 OpBuilder.addGenericBinaryArithmeticOverloads();
10550 OpBuilder.addMatrixBinaryArithmeticOverloads();
10555 OpBuilder.addGenericBinaryArithmeticOverloads();
10559 case OO_MinusMinus:
10560 OpBuilder.addPlusPlusMinusMinusArithmeticOverloads(Op);
10561 OpBuilder.addPlusPlusMinusMinusPointerOverloads();
10564 case OO_EqualEqual:
10565 case OO_ExclaimEqual:
10566 OpBuilder.addEqualEqualOrNotEqualMemberPointerOrNullptrOverloads();
10567 OpBuilder.addGenericBinaryPointerOrEnumeralOverloads(
false);
10568 OpBuilder.addGenericBinaryArithmeticOverloads();
10574 case OO_GreaterEqual:
10575 OpBuilder.addGenericBinaryPointerOrEnumeralOverloads(
false);
10576 OpBuilder.addGenericBinaryArithmeticOverloads();
10580 OpBuilder.addGenericBinaryPointerOrEnumeralOverloads(
true);
10581 OpBuilder.addThreeWayArithmeticOverloads();
10588 case OO_GreaterGreater:
10589 OpBuilder.addBinaryBitwiseArithmeticOverloads();
10593 if (Args.size() == 1)
10599 OpBuilder.addBinaryBitwiseArithmeticOverloads();
10603 OpBuilder.addUnaryTildePromotedIntegralOverloads();
10607 OpBuilder.addAssignmentMemberPointerOrEnumeralOverloads();
10611 case OO_MinusEqual:
10612 OpBuilder.addAssignmentPointerOverloads(Op == OO_Equal);
10616 case OO_SlashEqual:
10617 OpBuilder.addAssignmentArithmeticOverloads(Op == OO_Equal);
10620 case OO_PercentEqual:
10621 case OO_LessLessEqual:
10622 case OO_GreaterGreaterEqual:
10624 case OO_CaretEqual:
10626 OpBuilder.addAssignmentIntegralOverloads();
10630 OpBuilder.addExclaimOverload();
10635 OpBuilder.addAmpAmpOrPipePipeOverload();
10639 if (Args.size() == 2)
10640 OpBuilder.addSubscriptOverloads();
10644 OpBuilder.addArrowStarOverloads();
10647 case OO_Conditional:
10648 OpBuilder.addConditionalOperatorOverloads();
10649 OpBuilder.addGenericBinaryArithmeticOverloads();
10660 bool PartialOverloading) {
10677 CandEnd = CandidateSet.
end();
10678 Cand != CandEnd; ++Cand)
10679 if (Cand->Function) {
10683 Fns.
erase(FunTmpl);
10692 if (ExplicitTemplateArgs)
10696 FD, FoundDecl, Args, CandidateSet,
false,
10697 PartialOverloading,
true,
10698 false, ADLCallKind::UsesADL);
10701 FD, FoundDecl, {Args[1], Args[0]}, CandidateSet,
10702 false, PartialOverloading,
10709 FTD, FoundDecl, ExplicitTemplateArgs, Args, CandidateSet,
10710 false, PartialOverloading,
10711 true, ADLCallKind::UsesADL);
10713 *
this, Args, FTD->getTemplatedDecl())) {
10717 if (ReversedArgs.empty())
10721 FTD, FoundDecl, ExplicitTemplateArgs, ReversedArgs, CandidateSet,
10722 false, PartialOverloading,
10723 true, ADLCallKind::UsesADL,
10748 bool Cand1Attr = Cand1->
hasAttr<EnableIfAttr>();
10749 bool Cand2Attr = Cand2->
hasAttr<EnableIfAttr>();
10750 if (!Cand1Attr || !Cand2Attr) {
10751 if (Cand1Attr == Cand2Attr)
10752 return Comparison::Equal;
10753 return Cand1Attr ? Comparison::Better : Comparison::Worse;
10759 llvm::FoldingSetNodeID Cand1ID, Cand2ID;
10760 for (
auto Pair : zip_longest(Cand1Attrs, Cand2Attrs)) {
10761 std::optional<EnableIfAttr *> Cand1A = std::get<0>(Pair);
10762 std::optional<EnableIfAttr *> Cand2A = std::get<1>(Pair);
10767 return Comparison::Worse;
10769 return Comparison::Better;
10774 (*Cand1A)->getCond()->Profile(Cand1ID, S.
getASTContext(),
true);
10775 (*Cand2A)->getCond()->Profile(Cand2ID, S.
getASTContext(),
true);
10776 if (Cand1ID != Cand2ID)
10777 return Comparison::Worse;
10780 return Comparison::Equal;
10788 return Comparison::Equal;
10794 return Comparison::Equal;
10795 return Comparison::Worse;
10798 return Comparison::Better;
10804 const auto *Cand1CPUSpec = Cand1.
Function->
getAttr<CPUSpecificAttr>();
10805 const auto *Cand2CPUSpec = Cand2.
Function->
getAttr<CPUSpecificAttr>();
10807 if (!Cand1CPUDisp && !Cand2CPUDisp && !Cand1CPUSpec && !Cand2CPUSpec)
10808 return Comparison::Equal;
10810 if (Cand1CPUDisp && !Cand2CPUDisp)
10811 return Comparison::Better;
10812 if (Cand2CPUDisp && !Cand1CPUDisp)
10813 return Comparison::Worse;
10815 if (Cand1CPUSpec && Cand2CPUSpec) {
10816 if (Cand1CPUSpec->cpus_size() != Cand2CPUSpec->cpus_size())
10817 return Cand1CPUSpec->cpus_size() < Cand2CPUSpec->cpus_size()
10818 ? Comparison::Better
10819 : Comparison::Worse;
10821 std::pair<CPUSpecificAttr::cpus_iterator, CPUSpecificAttr::cpus_iterator>
10822 FirstDiff = std::mismatch(
10823 Cand1CPUSpec->cpus_begin(), Cand1CPUSpec->cpus_end(),
10824 Cand2CPUSpec->cpus_begin(),
10826 return LHS->getName() == RHS->getName();
10829 assert(FirstDiff.first != Cand1CPUSpec->cpus_end() &&
10830 "Two different cpu-specific versions should not have the same "
10831 "identifier list, otherwise they'd be the same decl!");
10832 return (*FirstDiff.first)->getName() < (*FirstDiff.second)->getName()
10833 ? Comparison::Better
10834 : Comparison::Worse;
10836 llvm_unreachable(
"No way to get here unless both had cpu_dispatch");
10842static std::optional<QualType>
10845 return std::nullopt;
10851 return M->getFunctionObjectParameterReferenceType();
10865 PT2->getInstantiatedFromMemberTemplate()))
10876 assert(I < F->getNumParams());
10883 if (F1NumParams != F2NumParams)
10886 unsigned I1 = 0, I2 = 0;
10887 for (
unsigned I = 0; I != F1NumParams; ++I) {
10888 QualType T1 = NextParam(F1, I1, I == 0);
10889 QualType T2 = NextParam(F2, I2, I == 0);
10890 assert(!T1.
isNull() && !T2.
isNull() &&
"Unexpected null param types");
10891 if (!Context.hasSameUnqualifiedType(T1, T2))
10904 bool IsFn1Reversed,
10905 bool IsFn2Reversed) {
10906 assert(Fn1 && Fn2);
10911 IsFn1Reversed ^ IsFn2Reversed))
10914 auto *Mem1 = dyn_cast<CXXMethodDecl>(Fn1);
10915 auto *Mem2 = dyn_cast<CXXMethodDecl>(Fn2);
10916 if (Mem1 && Mem2) {
10919 if (Mem1->getParent() != Mem2->getParent())
10923 if (Mem1->isInstance() && Mem2->isInstance() &&
10925 Mem1->getFunctionObjectParameterReferenceType(),
10926 Mem1->getFunctionObjectParameterReferenceType()))
10932static FunctionDecl *
10934 bool IsFn1Reversed,
bool IsFn2Reversed) {
10944 if (Cand1IsSpecialization || Cand2IsSpecialization)
10961 bool PartialOverloading) {
11007 bool IsCand1ImplicitHD =
11009 bool IsCand2ImplicitHD =
11024 auto EmitThreshold =
11025 (S.
getLangOpts().CUDAIsDevice && IsCallerImplicitHD &&
11026 (IsCand1ImplicitHD || IsCand2ImplicitHD))
11029 auto Cand1Emittable = P1 > EmitThreshold;
11030 auto Cand2Emittable = P2 > EmitThreshold;
11031 if (Cand1Emittable && !Cand2Emittable)
11033 if (!Cand1Emittable && Cand2Emittable)
11044 unsigned StartArg = 0;
11052 return ICS.isStandard() &&
11064 assert(Cand2.
Conversions.size() == NumArgs &&
"Overload candidate mismatch");
11065 bool HasBetterConversion =
false;
11066 for (
unsigned ArgIdx = StartArg; ArgIdx < NumArgs; ++ArgIdx) {
11067 bool Cand1Bad = IsIllFormedConversion(Cand1.
Conversions[ArgIdx]);
11068 bool Cand2Bad = IsIllFormedConversion(Cand2.
Conversions[ArgIdx]);
11069 if (Cand1Bad != Cand2Bad) {
11072 HasBetterConversion =
true;
11076 if (HasBetterConversion)
11083 bool HasWorseConversion =
false;
11084 for (
unsigned ArgIdx = StartArg; ArgIdx < NumArgs; ++ArgIdx) {
11090 HasBetterConversion =
true;
11109 HasWorseConversion =
true;
11124 if (HasBetterConversion && !HasWorseConversion)
11175 bool Cand1IsSpecialization = Cand1.
Function &&
11177 bool Cand2IsSpecialization = Cand2.
Function &&
11179 if (Cand1IsSpecialization != Cand2IsSpecialization)
11180 return Cand2IsSpecialization;
11186 if (Cand1IsSpecialization && Cand2IsSpecialization) {
11187 const auto *Obj1Context =
11189 const auto *Obj2Context =
11218 bool Cand1IsInherited =
11220 bool Cand2IsInherited =
11222 if (Cand1IsInherited != Cand2IsInherited)
11223 return Cand2IsInherited;
11224 else if (Cand1IsInherited) {
11225 assert(Cand2IsInherited);
11228 if (Cand1Class->isDerivedFrom(Cand2Class))
11230 if (Cand2Class->isDerivedFrom(Cand1Class))
11247 auto *Guide1 = dyn_cast_or_null<CXXDeductionGuideDecl>(Cand1.
Function);
11248 auto *Guide2 = dyn_cast_or_null<CXXDeductionGuideDecl>(Cand2.
Function);
11249 if (Guide1 && Guide2) {
11251 if (Guide1->isImplicit() != Guide2->isImplicit())
11252 return Guide2->isImplicit();
11262 const auto *Constructor1 = Guide1->getCorrespondingConstructor();
11263 const auto *Constructor2 = Guide2->getCorrespondingConstructor();
11264 if (Constructor1 && Constructor2) {
11265 bool isC1Templated = Constructor1->getTemplatedKind() !=
11267 bool isC2Templated = Constructor2->getTemplatedKind() !=
11269 if (isC1Templated != isC2Templated)
11270 return isC2Templated;
11278 if (
Cmp != Comparison::Equal)
11279 return Cmp == Comparison::Better;
11282 bool HasPS1 = Cand1.
Function !=
nullptr &&
11284 bool HasPS2 = Cand2.
Function !=
nullptr &&
11286 if (HasPS1 != HasPS2 && HasPS1)
11290 if (MV == Comparison::Better)
11292 if (MV == Comparison::Worse)
11307 const auto *CD1 = dyn_cast_or_null<CXXConstructorDecl>(Cand1.
Function);
11308 const auto *CD2 = dyn_cast_or_null<CXXConstructorDecl>(Cand2.
Function);
11310 LangAS AS1 = CD1->getMethodQualifiers().getAddressSpace();
11311 LangAS AS2 = CD2->getMethodQualifiers().getAddressSpace();
11332 auto *VA = dyn_cast_or_null<ValueDecl>(A);
11333 auto *VB = dyn_cast_or_null<ValueDecl>(B);
11339 if (!VA->getDeclContext()->getRedeclContext()->Equals(
11340 VB->getDeclContext()->getRedeclContext()) ||
11342 VA->isExternallyVisible() || VB->isExternallyVisible())
11350 if (
Context.hasSameType(VA->getType(), VB->getType()))
11355 if (
auto *EA = dyn_cast<EnumConstantDecl>(VA)) {
11356 if (
auto *EB = dyn_cast<EnumConstantDecl>(VB)) {
11361 if (EnumA->hasNameForLinkage() || EnumB->hasNameForLinkage() ||
11362 !
Context.hasSameType(EnumA->getIntegerType(),
11363 EnumB->getIntegerType()))
11366 return llvm::APSInt::isSameValue(EA->getInitVal(), EB->getInitVal());
11376 assert(D &&
"Unknown declaration");
11377 Diag(Loc, diag::ext_equivalent_internal_linkage_decl_in_modules) << D;
11383 for (
auto *E : Equiv) {
11385 Diag(E->getLocation(), diag::note_equivalent_internal_linkage_decl)
11395 ->Satisfaction.ContainsErrors;
11401 bool PartialOverloading,
bool AllowExplicit,
11403 bool AggregateCandidateDeduction) {
11406 allocateDeferredCandidate<DeferredFunctionTemplateOverloadCandidate>();
11411 false, AllowExplicit, SuppressUserConversions,
11412 PartialOverloading, AggregateCandidateDeduction},
11419 HasDeferredTemplateConstructors |=
11427 bool SuppressUserConversions,
bool PartialOverloading,
11433 allocateDeferredCandidate<DeferredMethodTemplateOverloadCandidate>();
11439 false, SuppressUserConversions, PartialOverloading,
11445 ObjectClassification,
11453 bool AllowObjCConversionOnExplicit,
bool AllowExplicit,
11454 bool AllowResultConversion) {
11457 allocateDeferredCandidate<DeferredConversionTemplateOverloadCandidate>();
11461 AllowObjCConversionOnExplicit, AllowResultConversion,
11478 S, CandidateSet,
C.FunctionTemplate,
C.FoundDecl,
C.ActingContext,
11479 nullptr,
C.ObjectType,
C.ObjectClassification,
11480 C.Args,
C.SuppressUserConversions,
C.PartialOverloading,
C.PO);
11487 S, CandidateSet,
C.FunctionTemplate,
C.FoundDecl,
11488 nullptr,
C.Args,
C.SuppressUserConversions,
11489 C.PartialOverloading,
C.AllowExplicit,
C.IsADLCandidate,
C.PO,
11490 C.AggregateCandidateDeduction);
11497 S, CandidateSet,
C.FunctionTemplate,
C.FoundDecl,
C.ActingContext,
C.From,
11498 C.ToType,
C.AllowObjCConversionOnExplicit,
C.AllowExplicit,
11499 C.AllowResultConversion);
11503 Candidates.reserve(Candidates.size() + DeferredCandidatesCount);
11506 switch (Cand->
Kind) {
11525 FirstDeferredCandidate =
nullptr;
11526 DeferredCandidatesCount = 0;
11530OverloadCandidateSet::ResultForBestCandidate(
const iterator &Best) {
11532 if (Best->Function && Best->Function->isDeleted())
11537void OverloadCandidateSet::CudaExcludeWrongSideCandidates(
11554 bool ContainsSameSideCandidate =
11562 if (!ContainsSameSideCandidate)
11565 auto IsWrongSideCandidate = [&](
const OverloadCandidate *Cand) {
11571 llvm::erase_if(Candidates, IsWrongSideCandidate);
11589 DeferredCandidatesCount == 0) &&
11590 "Unexpected deferred template candidates");
11592 bool TwoPhaseResolution =
11593 DeferredCandidatesCount != 0 && !ResolutionByPerfectCandidateIsDisabled;
11595 if (TwoPhaseResolution) {
11597 if (Best !=
end() && Best->isPerfectMatch(S.
Context)) {
11598 if (!(HasDeferredTemplateConstructors &&
11599 isa_and_nonnull<CXXConversionDecl>(Best->Function)))
11605 return BestViableFunctionImpl(S, Loc, Best);
11612 Candidates.reserve(this->Candidates.size());
11613 std::transform(this->Candidates.begin(), this->Candidates.end(),
11614 std::back_inserter(Candidates),
11618 CudaExcludeWrongSideCandidates(S, Candidates);
11621 for (
auto *Cand : Candidates) {
11622 Cand->
Best =
false;
11624 if (Best ==
end() ||
11641 llvm::SmallVector<OverloadCandidate *, 4> PendingBest;
11642 llvm::SmallVector<const NamedDecl *, 4> EquivalentCands;
11643 PendingBest.push_back(&*Best);
11648 while (!PendingBest.empty()) {
11649 auto *Curr = PendingBest.pop_back_val();
11650 for (
auto *Cand : Candidates) {
11653 PendingBest.push_back(Cand);
11658 EquivalentCands.push_back(Cand->
Function);
11670 if (!EquivalentCands.empty())
11678enum OverloadCandidateKind {
11681 oc_reversed_binary_operator,
11683 oc_implicit_default_constructor,
11684 oc_implicit_copy_constructor,
11685 oc_implicit_move_constructor,
11686 oc_implicit_copy_assignment,
11687 oc_implicit_move_assignment,
11688 oc_implicit_equality_comparison,
11689 oc_inherited_constructor
11692enum OverloadCandidateSelect {
11695 ocs_described_template,
11698static std::pair<OverloadCandidateKind, OverloadCandidateSelect>
11699ClassifyOverloadCandidate(Sema &S,
const NamedDecl *
Found,
11700 const FunctionDecl *Fn,
11702 std::string &Description) {
11705 if (FunctionTemplateDecl *FunTmpl =
Fn->getPrimaryTemplate()) {
11708 FunTmpl->getTemplateParameters(), *
Fn->getTemplateSpecializationArgs());
11711 OverloadCandidateSelect Select = [&]() {
11712 if (!Description.empty())
11713 return ocs_described_template;
11714 return isTemplate ? ocs_template : ocs_non_template;
11717 OverloadCandidateKind Kind = [&]() {
11718 if (
Fn->isImplicit() &&
Fn->getOverloadedOperator() == OO_EqualEqual)
11719 return oc_implicit_equality_comparison;
11722 return oc_reversed_binary_operator;
11724 if (
const auto *Ctor = dyn_cast<CXXConstructorDecl>(Fn)) {
11725 if (!Ctor->isImplicit()) {
11727 return oc_inherited_constructor;
11729 return oc_constructor;
11732 if (Ctor->isDefaultConstructor())
11733 return oc_implicit_default_constructor;
11735 if (Ctor->isMoveConstructor())
11736 return oc_implicit_move_constructor;
11738 assert(Ctor->isCopyConstructor() &&
11739 "unexpected sort of implicit constructor");
11740 return oc_implicit_copy_constructor;
11743 if (
const auto *Meth = dyn_cast<CXXMethodDecl>(Fn)) {
11746 if (!Meth->isImplicit())
11749 if (Meth->isMoveAssignmentOperator())
11750 return oc_implicit_move_assignment;
11752 if (Meth->isCopyAssignmentOperator())
11753 return oc_implicit_copy_assignment;
11759 return oc_function;
11762 return std::make_pair(Kind, Select);
11765void MaybeEmitInheritedConstructorNote(Sema &S,
const Decl *FoundDecl) {
11768 if (
const auto *Shadow = dyn_cast<ConstructorUsingShadowDecl>(FoundDecl))
11770 diag::note_ovl_candidate_inherited_constructor)
11771 << Shadow->getNominatedBaseClass();
11780 if (EnableIf->getCond()->isValueDependent() ||
11781 !EnableIf->getCond()->EvaluateAsBooleanCondition(AlwaysTrue, Ctx))
11798 bool InOverloadResolution,
11802 if (InOverloadResolution)
11804 diag::note_addrof_ovl_candidate_disabled_by_enable_if_attr);
11806 S.
Diag(Loc, diag::err_addrof_function_disabled_by_enable_if_attr) << FD;
11817 if (InOverloadResolution) {
11820 TemplateArgString +=
" ";
11822 FunTmpl->getTemplateParameters(),
11827 diag::note_ovl_candidate_unsatisfied_constraints)
11828 << TemplateArgString;
11830 S.
Diag(Loc, diag::err_addrof_function_constraints_not_satisfied)
11839 return P->hasAttr<PassObjectSizeAttr>();
11846 unsigned ParamNo = std::distance(FD->
param_begin(), I) + 1;
11847 if (InOverloadResolution)
11849 diag::note_ovl_candidate_has_pass_object_size_params)
11852 S.
Diag(Loc, diag::err_address_of_function_with_pass_object_size_params)
11868 return ::checkAddressOfFunctionIsAvailable(*
this,
Function, Complain,
11876 const auto *ConvD = dyn_cast<CXXConversionDecl>(Fn);
11881 if (!RD->isLambda())
11886 CallOp->getType()->castAs<
FunctionType>()->getCallConv();
11891 return ConvToCC != CallOpCC;
11897 QualType DestType,
bool TakingAddress) {
11900 if (Fn->isMultiVersion() && Fn->hasAttr<TargetAttr>() &&
11901 !Fn->getAttr<TargetAttr>()->isDefaultVersion())
11903 if (Fn->isMultiVersion() && Fn->hasAttr<TargetVersionAttr>() &&
11904 !Fn->getAttr<TargetVersionAttr>()->isDefaultVersion())
11909 std::string FnDesc;
11910 std::pair<OverloadCandidateKind, OverloadCandidateSelect> KSPair =
11911 ClassifyOverloadCandidate(*
this,
Found, Fn, RewriteKind, FnDesc);
11913 << (
unsigned)KSPair.first << (
unsigned)KSPair.second
11917 Diag(Fn->getLocation(), PD);
11918 MaybeEmitInheritedConstructorNote(*
this,
Found);
11936 FunctionDecl *FirstCand =
nullptr, *SecondCand =
nullptr;
11937 for (
auto I = Cands.begin(), E = Cands.end(); I != E; ++I) {
11941 if (
auto *
Template = I->Function->getPrimaryTemplate())
11942 Template->getAssociatedConstraints(AC);
11944 I->Function->getAssociatedConstraints(AC);
11947 if (FirstCand ==
nullptr) {
11948 FirstCand = I->Function;
11950 }
else if (SecondCand ==
nullptr) {
11951 SecondCand = I->Function;
11964 SecondCand, SecondAC))
11973 bool TakingAddress) {
11983 dyn_cast<FunctionTemplateDecl>((*I)->getUnderlyingDecl()) ) {
11987 = dyn_cast<FunctionDecl>((*I)->getUnderlyingDecl()) ) {
12000 S.
Diag(CaretLoc, PDiag)
12002 unsigned CandsShown = 0;
12016 unsigned I,
bool TakingCandidateAddress) {
12018 assert(Conv.
isBad());
12019 assert(Cand->
Function &&
"for now, candidate must be a function");
12025 bool isObjectArgument =
false;
12029 isObjectArgument =
true;
12034 std::string FnDesc;
12035 std::pair<OverloadCandidateKind, OverloadCandidateSelect> FnKindPair =
12046 bool HasParamPack =
12047 llvm::any_of(Fn->parameters().take_front(I), [](
const ParmVarDecl *Parm) {
12048 return Parm->isParameterPack();
12050 if (!isObjectArgument && !HasParamPack && I < Fn->getNumParams())
12051 ToParamRange = Fn->getParamDecl(I)->getSourceRange();
12054 assert(FromExpr &&
"overload set argument came from implicit argument?");
12060 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_overload)
12061 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12062 << ToParamRange << ToTy << Name << I + 1;
12063 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12072 CToTy = RT->getPointeeType();
12077 CFromTy = FromPT->getPointeeType();
12078 CToTy = ToPT->getPointeeType();
12088 if (isObjectArgument)
12089 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_addrspace_this)
12090 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second
12093 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_addrspace)
12094 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second
12097 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12102 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_ownership)
12103 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12106 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12111 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_gc)
12112 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12115 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12120 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_ptrauth)
12121 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12126 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12131 assert(CVR &&
"expected qualifiers mismatch");
12133 if (isObjectArgument) {
12134 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_cvr_this)
12135 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12136 << FromTy << (CVR - 1);
12138 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_cvr)
12139 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12140 << ToParamRange << FromTy << (CVR - 1) << I + 1;
12142 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12148 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_value_category)
12149 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12150 << (
unsigned)isObjectArgument << I + 1
12153 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12160 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_list_argument)
12161 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12162 << ToParamRange << FromTy << ToTy << (
unsigned)isObjectArgument << I + 1
12167 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12179 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_conv_incomplete)
12180 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12181 << ToParamRange << FromTy << ToTy << (
unsigned)isObjectArgument << I + 1
12182 << (
unsigned)(Cand->
Fix.
Kind);
12184 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12189 unsigned BaseToDerivedConversion = 0;
12192 if (ToPtrTy->getPointeeType().isAtLeastAsQualifiedAs(
12194 !FromPtrTy->getPointeeType()->isIncompleteType() &&
12195 !ToPtrTy->getPointeeType()->isIncompleteType() &&
12197 FromPtrTy->getPointeeType()))
12198 BaseToDerivedConversion = 1;
12206 if (ToPtrTy->getPointeeType().isAtLeastAsQualifiedAs(
12208 FromIface->isSuperClassOf(ToIface))
12209 BaseToDerivedConversion = 2;
12211 if (ToRefTy->getPointeeType().isAtLeastAsQualifiedAs(FromTy,
12214 !ToRefTy->getPointeeType()->isIncompleteType() &&
12216 BaseToDerivedConversion = 3;
12220 if (BaseToDerivedConversion) {
12221 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_base_to_derived_conv)
12222 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12223 << ToParamRange << (BaseToDerivedConversion - 1) << FromTy << ToTy
12225 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12234 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_bad_arc_conv)
12235 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12236 << ToParamRange << FromTy << ToTy << (
unsigned)isObjectArgument
12238 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12248 if (FromTy == S.
Context.AMDGPUFeaturePredicateTy &&
12251 diag::err_amdgcn_predicate_type_needs_explicit_bool_cast)
12258 FDiag << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12259 << ToParamRange << FromTy << ToTy << (
unsigned)isObjectArgument << I + 1
12260 << (
unsigned)(Cand->
Fix.
Kind);
12269 S.
Diag(Fn->getLocation(), FDiag);
12271 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12278 unsigned NumArgs,
bool IsAddressOf =
false) {
12279 assert(Cand->
Function &&
"Candidate is required to be a function.");
12281 unsigned MinParams = Fn->getMinRequiredExplicitArguments() +
12282 ((IsAddressOf && !Fn->isStatic()) ? 1 : 0);
12289 if (Fn->isInvalidDecl() &&
12293 if (NumArgs < MinParams) {
12310 unsigned NumFormalArgs,
12311 bool IsAddressOf =
false) {
12313 "The templated declaration should at least be a function"
12314 " when diagnosing bad template argument deduction due to too many"
12315 " or too few arguments");
12321 unsigned MinParams = Fn->getMinRequiredExplicitArguments() +
12322 ((IsAddressOf && !Fn->isStatic()) ? 1 : 0);
12325 bool HasExplicitObjectParam =
12326 !IsAddressOf && Fn->hasCXXExplicitFunctionObjectParameter();
12328 unsigned ParamCount =
12329 Fn->getNumNonObjectParams() + ((IsAddressOf && !Fn->isStatic()) ? 1 : 0);
12330 unsigned mode, modeCount;
12332 if (NumFormalArgs < MinParams) {
12333 if (MinParams != ParamCount || FnTy->isVariadic() ||
12334 FnTy->isTemplateVariadic())
12338 modeCount = MinParams;
12340 if (MinParams != ParamCount)
12344 modeCount = ParamCount;
12347 std::string Description;
12348 std::pair<OverloadCandidateKind, OverloadCandidateSelect> FnKindPair =
12349 ClassifyOverloadCandidate(S,
Found, Fn,
CRK_None, Description);
12351 unsigned FirstNonObjectParamIdx = HasExplicitObjectParam ? 1 : 0;
12352 if (modeCount == 1 && !IsAddressOf &&
12353 FirstNonObjectParamIdx < Fn->getNumParams() &&
12354 Fn->getParamDecl(FirstNonObjectParamIdx)->getDeclName())
12355 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_arity_one)
12356 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second
12357 << Description << mode << Fn->getParamDecl(FirstNonObjectParamIdx)
12358 << NumFormalArgs << HasExplicitObjectParam
12359 << Fn->getParametersSourceRange();
12361 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_arity)
12362 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second
12363 << Description << mode << modeCount << NumFormalArgs
12364 << HasExplicitObjectParam << Fn->getParametersSourceRange();
12366 MaybeEmitInheritedConstructorNote(S,
Found);
12371 unsigned NumFormalArgs) {
12372 assert(Cand->
Function &&
"Candidate must be a function");
12382 llvm_unreachable(
"Unsupported: Getting the described template declaration"
12383 " for bad deduction diagnosis");
12390 bool TakingCandidateAddress) {
12396 switch (DeductionFailure.
getResult()) {
12399 "TemplateDeductionResult::Success while diagnosing bad deduction");
12401 llvm_unreachable(
"TemplateDeductionResult::NonDependentConversionFailure "
12402 "while diagnosing bad deduction");
12408 assert(ParamD &&
"no parameter found for incomplete deduction result");
12410 diag::note_ovl_candidate_incomplete_deduction)
12412 MaybeEmitInheritedConstructorNote(S,
Found);
12417 assert(ParamD &&
"no parameter found for incomplete deduction result");
12419 diag::note_ovl_candidate_incomplete_deduction_pack)
12421 << (DeductionFailure.
getFirstArg()->pack_size() + 1)
12423 MaybeEmitInheritedConstructorNote(S,
Found);
12428 assert(ParamD &&
"no parameter found for bad qualifiers deduction result");
12446 S.
Diag(Templated->
getLocation(), diag::note_ovl_candidate_underqualified)
12447 << ParamD->
getDeclName() << Arg << NonCanonParam;
12448 MaybeEmitInheritedConstructorNote(S,
Found);
12453 assert(ParamD &&
"no parameter found for inconsistent deduction result");
12467 diag::note_ovl_candidate_inconsistent_deduction_types)
12470 MaybeEmitInheritedConstructorNote(S,
Found);
12490 diag::note_ovl_candidate_inconsistent_deduction)
12493 MaybeEmitInheritedConstructorNote(S,
Found);
12498 assert(ParamD &&
"no parameter found for invalid explicit arguments");
12501 diag::note_ovl_candidate_explicit_arg_mismatch);
12503 Diag << diag::ExplicitArgMismatchNameKind::Named << ParamD->
getDeclName();
12505 Diag << diag::ExplicitArgMismatchNameKind::Unnamed
12510 Diag << diag::ExplicitArgMismatchReasonKind::Detailed << DiagContent;
12512 Diag << diag::ExplicitArgMismatchReasonKind::Vague;
12515 MaybeEmitInheritedConstructorNote(S,
Found);
12522 TemplateArgString =
" ";
12525 if (TemplateArgString.size() == 1)
12526 TemplateArgString.clear();
12528 diag::note_ovl_candidate_unsatisfied_constraints)
12529 << TemplateArgString;
12532 static_cast<CNSInfo*
>(DeductionFailure.
Data)->Satisfaction);
12542 diag::note_ovl_candidate_instantiation_depth);
12543 MaybeEmitInheritedConstructorNote(S,
Found);
12551 TemplateArgString =
" ";
12554 if (TemplateArgString.size() == 1)
12555 TemplateArgString.clear();
12560 if (PDiag && PDiag->second.getDiagID() ==
12561 diag::err_typename_nested_not_found_enable_if) {
12564 S.
Diag(PDiag->first, diag::note_ovl_candidate_disabled_by_enable_if)
12565 <<
"'enable_if'" << TemplateArgString;
12570 if (PDiag && PDiag->second.getDiagID() ==
12571 diag::err_typename_nested_not_found_requirement) {
12573 diag::note_ovl_candidate_disabled_by_requirement)
12574 << PDiag->second.getStringArg(0) << TemplateArgString;
12584 SFINAEArgString =
": ";
12586 PDiag->second.EmitToString(S.
getDiagnostics(), SFINAEArgString);
12590 diag::note_ovl_candidate_substitution_failure)
12591 << TemplateArgString << SFINAEArgString << R;
12592 MaybeEmitInheritedConstructorNote(S,
Found);
12602 TemplateArgString =
" ";
12605 if (TemplateArgString.size() == 1)
12606 TemplateArgString.clear();
12609 S.
Diag(Templated->
getLocation(), diag::note_ovl_candidate_deduced_mismatch)
12612 << TemplateArgString
12637 diag::note_ovl_candidate_non_deduced_mismatch_qualified)
12653 diag::note_ovl_candidate_non_deduced_mismatch)
12654 << FirstTA << SecondTA;
12660 S.
Diag(Templated->
getLocation(), diag::note_ovl_candidate_bad_deduction);
12661 MaybeEmitInheritedConstructorNote(S,
Found);
12665 diag::note_cuda_ovl_candidate_target_mismatch);
12673 bool TakingCandidateAddress) {
12674 assert(Cand->
Function &&
"Candidate must be a function");
12689 assert(Cand->
Function &&
"Candidate must be a Function.");
12695 std::string FnDesc;
12696 std::pair<OverloadCandidateKind, OverloadCandidateSelect> FnKindPair =
12697 ClassifyOverloadCandidate(S, Cand->
FoundDecl, Callee,
12700 S.
Diag(Callee->getLocation(), diag::note_ovl_candidate_bad_target)
12701 << (
unsigned)FnKindPair.first << (
unsigned)ocs_non_template
12703 << CalleeTarget << CallerTarget;
12708 if (Meth !=
nullptr && Meth->
isImplicit()) {
12712 switch (FnKindPair.first) {
12715 case oc_implicit_default_constructor:
12718 case oc_implicit_copy_constructor:
12721 case oc_implicit_move_constructor:
12724 case oc_implicit_copy_assignment:
12727 case oc_implicit_move_assignment:
12732 bool ConstRHS =
false;
12736 ConstRHS = RT->getPointeeType().isConstQualified();
12747 assert(Cand->
Function &&
"Candidate must be a function");
12751 S.
Diag(Callee->getLocation(),
12752 diag::note_ovl_candidate_disabled_by_function_cond_attr)
12753 <<
Attr->getCond()->getSourceRange() <<
Attr->getMessage();
12757 assert(Cand->
Function &&
"Candidate must be a function");
12760 assert(ES.
isExplicit() &&
"not an explicit candidate");
12763 switch (Fn->getDeclKind()) {
12764 case Decl::Kind::CXXConstructor:
12767 case Decl::Kind::CXXConversion:
12770 case Decl::Kind::CXXDeductionGuide:
12771 Kind = Fn->isImplicit() ? 0 : 2;
12774 llvm_unreachable(
"invalid Decl");
12783 First = Pattern->getFirstDecl();
12786 diag::note_ovl_candidate_explicit)
12787 << Kind << (ES.
getExpr() ? 1 : 0)
12792 auto *DG = dyn_cast<CXXDeductionGuideDecl>(Fn);
12799 if (!(DG->isImplicit() || (OriginTemplate && OriginTemplate->
isTypeAlias())))
12801 std::string FunctionProto;
12802 llvm::raw_string_ostream OS(FunctionProto);
12815 "Non-template implicit deduction guides are only possible for "
12818 S.
Diag(DG->getLocation(), diag::note_implicit_deduction_guide)
12823 assert(
Template &&
"Cannot find the associated function template of "
12824 "CXXDeductionGuideDecl?");
12827 S.
Diag(DG->getLocation(), diag::note_implicit_deduction_guide)
12848 bool TakingCandidateAddress,
12850 assert(Cand->
Function &&
"Candidate must be a function");
12858 if (S.
getLangOpts().OpenCL && Fn->isImplicit() &&
12865 !Fn->hasCXXExplicitFunctionObjectParameter() && !Fn->isStatic())
12870 if (Fn->isDeleted()) {
12871 std::string FnDesc;
12872 std::pair<OverloadCandidateKind, OverloadCandidateSelect> FnKindPair =
12873 ClassifyOverloadCandidate(S, Cand->
FoundDecl, Fn,
12876 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_deleted)
12877 << (
unsigned)FnKindPair.first << (
unsigned)FnKindPair.second << FnDesc
12878 << (Fn->isDeleted()
12879 ? (Fn->getCanonicalDecl()->isDeletedAsWritten() ? 1 : 2)
12881 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12908 TakingCandidateAddress);
12911 S.
Diag(Fn->getLocation(), diag::note_ovl_candidate_illegal_constructor)
12912 << (Fn->getPrimaryTemplate() ? 1 : 0);
12913 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12920 S.
Diag(Fn->getLocation(),
12921 diag::note_ovl_candidate_illegal_constructor_adrspace_mismatch)
12922 << QualsForPrinting;
12923 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12934 for (
unsigned N = Cand->
Conversions.size(); I != N; ++I)
12957 S.
Diag(Fn->getLocation(),
12958 diag::note_ovl_candidate_inherited_constructor_slice)
12959 << (Fn->getPrimaryTemplate() ? 1 : 0)
12960 << Fn->getParamDecl(0)->getType()->isRValueReferenceType();
12961 MaybeEmitInheritedConstructorNote(S, Cand->
FoundDecl);
12967 assert(!Available);
12975 std::string FnDesc;
12976 std::pair<OverloadCandidateKind, OverloadCandidateSelect> FnKindPair =
12977 ClassifyOverloadCandidate(S, Cand->
FoundDecl, Fn,
12980 S.
Diag(Fn->getLocation(),
12981 diag::note_ovl_candidate_constraints_not_satisfied)
12982 << (
unsigned)FnKindPair.first << (
unsigned)ocs_non_template
13001 bool isLValueReference =
false;
13002 bool isRValueReference =
false;
13003 bool isPointer =
false;
13007 isLValueReference =
true;
13011 isRValueReference =
true;
13027 diag::note_ovl_surrogate_constraints_not_satisfied)
13041 assert(Cand->
Conversions.size() <= 2 &&
"builtin operator is not binary");
13042 std::string TypeStr(
"operator");
13048 S.
Diag(OpLoc, diag::note_ovl_builtin_candidate) << TypeStr;
13053 S.
Diag(OpLoc, diag::note_ovl_builtin_candidate) << TypeStr;
13060 if (ICS.
isBad())
break;
13064 S, OpLoc, S.
PDiag(diag::note_ambiguous_type_conversion));
13081 llvm_unreachable(
"non-deduction failure while diagnosing bad deduction");
13111 llvm_unreachable(
"Unhandled deduction result");
13116struct CompareOverloadCandidatesForDisplay {
13118 SourceLocation Loc;
13122 CompareOverloadCandidatesForDisplay(
13123 Sema &S, SourceLocation Loc,
size_t NArgs,
13125 : S(S), NumArgs(NArgs), CSK(CSK) {}
13135 if (NumArgs >
C->Function->getNumParams() && !
C->Function->isVariadic())
13137 if (NumArgs < C->
Function->getMinRequiredArguments())
13144 bool operator()(
const OverloadCandidate *L,
13145 const OverloadCandidate *R) {
13147 if (L == R)
return false;
13151 if (!
R->Viable)
return true;
13153 if (
int Ord = CompareConversions(*L, *R))
13156 }
else if (
R->Viable)
13159 assert(L->
Viable ==
R->Viable);
13172 int RDist =
std::abs((
int)
R->getNumParams() - (
int)NumArgs);
13173 if (LDist == RDist) {
13174 if (LFailureKind == RFailureKind)
13182 return LDist < RDist;
13199 unsigned numRFixes =
R->Fix.NumConversionsFixed;
13200 numLFixes = (numLFixes == 0) ?
UINT_MAX : numLFixes;
13201 numRFixes = (numRFixes == 0) ?
UINT_MAX : numRFixes;
13202 if (numLFixes != numRFixes) {
13203 return numLFixes < numRFixes;
13207 if (
int Ord = CompareConversions(*L, *R))
13219 if (LRank != RRank)
13220 return LRank < RRank;
13246 struct ConversionSignals {
13247 unsigned KindRank = 0;
13250 static ConversionSignals ForSequence(ImplicitConversionSequence &
Seq) {
13251 ConversionSignals Sig;
13252 Sig.KindRank =
Seq.getKindRank();
13253 if (
Seq.isStandard())
13254 Sig.Rank =
Seq.Standard.getRank();
13255 else if (
Seq.isUserDefined())
13256 Sig.Rank =
Seq.UserDefined.After.getRank();
13262 static ConversionSignals ForObjectArgument() {
13272 int CompareConversions(
const OverloadCandidate &L,
13273 const OverloadCandidate &R) {
13278 for (
unsigned I = 0, N = L.
Conversions.size(); I != N; ++I) {
13280 ? ConversionSignals::ForObjectArgument()
13281 : ConversionSignals::ForSequence(L.Conversions[I]);
13282 auto RS =
R.IgnoreObjectArgument
13283 ? ConversionSignals::ForObjectArgument()
13284 : ConversionSignals::ForSequence(
R.Conversions[I]);
13285 if (std::tie(LS.KindRank, LS.Rank) != std::tie(RS.KindRank, RS.Rank))
13286 return std::tie(LS.KindRank, LS.Rank) < std::tie(RS.KindRank, RS.Rank)
13311 bool Unfixable =
false;
13317 for (
unsigned ConvIdx =
13321 assert(ConvIdx != ConvCount &&
"no bad conversion in candidate");
13322 if (Cand->
Conversions[ConvIdx].isInitialized() &&
13331 bool SuppressUserConversions =
false;
13333 unsigned ConvIdx = 0;
13334 unsigned ArgIdx = 0;
13363 assert(ConvCount <= 3);
13369 ConvIdx != ConvCount && ArgIdx < Args.size();
13371 if (Cand->
Conversions[ConvIdx].isInitialized()) {
13373 }
else if (
ParamIdx < ParamTypes.size()) {
13374 if (ParamTypes[
ParamIdx]->isDependentType())
13375 Cand->
Conversions[ConvIdx].setAsIdentityConversion(
13380 SuppressUserConversions,
13385 if (!Unfixable && Cand->
Conversions[ConvIdx].isBad())
13404 for (
iterator Cand = Candidates.begin(), LastCand = Candidates.end();
13405 Cand != LastCand; ++Cand) {
13406 if (!Filter(*Cand))
13431 Cands.push_back(Cand);
13435 Cands, CompareOverloadCandidatesForDisplay(S, OpLoc, Args.size(), Kind));
13442 bool DeferHint =
false;
13446 auto WrongSidedCands =
13448 return (Cand.
Viable ==
false &&
13454 DeferHint = !WrongSidedCands.empty();
13470 S.
Diag(PD.first, PD.second);
13475 bool NoteCands =
true;
13476 for (
const Expr *Arg : Args) {
13477 if (Arg->getType()->isWebAssemblyTableType())
13486 {Candidates.begin(), Candidates.end()});
13492 bool ReportedAmbiguousConversions =
false;
13495 unsigned CandsShown = 0;
13496 auto I = Cands.begin(), E = Cands.end();
13497 for (; I != E; ++I) {
13513 "Non-viable built-in candidates are not added to Cands.");
13520 if (!ReportedAmbiguousConversions) {
13522 ReportedAmbiguousConversions =
true;
13536 S.
Diag(OpLoc, diag::note_ovl_too_many_candidates) <<
int(E - I);
13541 const Sema &S)
const {
13547 if (Caller && Caller->
hasAttr<CUDAHostAttr>() &&
13548 Caller->
hasAttr<CUDADeviceAttr>())
13569struct CompareTemplateSpecCandidatesForDisplay {
13571 CompareTemplateSpecCandidatesForDisplay(Sema &S) : S(S) {}
13573 bool operator()(
const TemplateSpecCandidate *L,
13574 const TemplateSpecCandidate *R) {
13605 bool ForTakingAddress) {
13610void TemplateSpecCandidateSet::destroyCandidates() {
13612 i->DeductionFailure.Destroy();
13617 destroyCandidates();
13618 Candidates.clear();
13631 Cands.reserve(
size());
13632 for (
iterator Cand =
begin(), LastCand =
end(); Cand != LastCand; ++Cand) {
13633 if (Cand->Specialization)
13634 Cands.push_back(Cand);
13639 llvm::sort(Cands, CompareTemplateSpecCandidatesForDisplay(S));
13646 unsigned CandsShown = 0;
13647 for (I = Cands.begin(), E = Cands.end(); I != E; ++I) {
13653 if (CandsShown >= 4 && ShowOverloads ==
Ovl_Best)
13658 "Non-matching built-in candidates are not added to Cands.");
13663 S.
Diag(Loc, diag::note_ovl_too_many_candidates) <<
int(E - I);
13673 QualType Ret = PossiblyAFunctionType;
13676 Ret = ToTypePtr->getPointeeType();
13679 Ret = ToTypeRef->getPointeeType();
13682 Ret = MemTypePtr->getPointeeType();
13684 Context.getCanonicalType(Ret).getUnqualifiedType();
13689 bool Complain =
true) {
13706class AddressOfFunctionResolver {
13709 const QualType& TargetType;
13710 QualType TargetFunctionType;
13714 ASTContext& Context;
13716 bool TargetTypeIsNonStaticMemberFunction;
13717 bool FoundNonTemplateFunction;
13718 bool StaticMemberFunctionFromBoundPointer;
13719 bool HasComplained;
13721 OverloadExpr::FindResult OvlExprInfo;
13722 OverloadExpr *OvlExpr;
13723 TemplateArgumentListInfo OvlExplicitTemplateArgs;
13724 SmallVector<std::pair<DeclAccessPair, FunctionDecl*>, 4> Matches;
13725 TemplateSpecCandidateSet FailedCandidates;
13728 AddressOfFunctionResolver(Sema &S, Expr *SourceExpr,
13729 const QualType &TargetType,
bool Complain)
13730 : S(S), SourceExpr(SourceExpr), TargetType(TargetType),
13731 Complain(Complain), Context(S.getASTContext()),
13732 TargetTypeIsNonStaticMemberFunction(
13733 !!TargetType->getAs<MemberPointerType>()),
13734 FoundNonTemplateFunction(
false),
13735 StaticMemberFunctionFromBoundPointer(
false),
13736 HasComplained(
false),
13737 OvlExprInfo(OverloadExpr::find(SourceExpr)),
13739 FailedCandidates(OvlExpr->getNameLoc(),
true) {
13740 ExtractUnqualifiedFunctionTypeFromTargetType();
13743 if (UnresolvedMemberExpr *UME = dyn_cast<UnresolvedMemberExpr>(OvlExpr))
13744 if (!UME->isImplicitAccess() &&
13746 StaticMemberFunctionFromBoundPointer =
true;
13748 DeclAccessPair dap;
13750 OvlExpr,
false, &dap)) {
13751 if (CXXMethodDecl *
Method = dyn_cast<CXXMethodDecl>(Fn))
13752 if (!
Method->isStatic()) {
13756 TargetTypeIsNonStaticMemberFunction =
true;
13764 Matches.push_back(std::make_pair(dap, Fn));
13772 if (FindAllFunctionsThatMatchTargetTypeExactly()) {
13774 EliminateSuboptimalCudaMatches();
13778 if (Matches.size() > 1 && !eliminiateSuboptimalOverloadCandidates()) {
13779 if (FoundNonTemplateFunction) {
13780 EliminateAllTemplateMatches();
13781 EliminateLessPartialOrderingConstrainedMatches();
13783 EliminateAllExceptMostSpecializedTemplate();
13788 bool hasComplained()
const {
return HasComplained; }
13791 bool candidateHasExactlyCorrectType(
const FunctionDecl *FD) {
13798 bool isBetterCandidate(
const FunctionDecl *A,
const FunctionDecl *B) {
13802 return candidateHasExactlyCorrectType(A) &&
13803 (!candidateHasExactlyCorrectType(B) ||
13809 bool eliminiateSuboptimalOverloadCandidates() {
13812 auto Best = Matches.begin();
13813 for (
auto I = Matches.begin()+1, E = Matches.end(); I != E; ++I)
13814 if (isBetterCandidate(I->second, Best->second))
13817 const FunctionDecl *BestFn = Best->second;
13818 auto IsBestOrInferiorToBest = [
this, BestFn](
13819 const std::pair<DeclAccessPair, FunctionDecl *> &Pair) {
13820 return BestFn == Pair.second || isBetterCandidate(BestFn, Pair.second);
13825 if (!llvm::all_of(Matches, IsBestOrInferiorToBest))
13827 Matches[0] = *Best;
13832 bool isTargetTypeAFunction()
const {
13841 void inline ExtractUnqualifiedFunctionTypeFromTargetType() {
13847 const DeclAccessPair& CurAccessFunPair) {
13848 if (CXXMethodDecl *
Method
13852 bool CanConvertToFunctionPointer =
13853 Method->isStatic() ||
Method->isExplicitObjectMemberFunction();
13854 if (CanConvertToFunctionPointer == TargetTypeIsNonStaticMemberFunction)
13857 else if (TargetTypeIsNonStaticMemberFunction)
13867 TemplateDeductionInfo Info(FailedCandidates.
getLocation());
13871 Result != TemplateDeductionResult::Success) {
13889 Matches.push_back(std::make_pair(CurAccessFunPair,
Specialization));
13893 bool AddMatchingNonTemplateFunction(NamedDecl* Fn,
13894 const DeclAccessPair& CurAccessFunPair) {
13895 if (CXXMethodDecl *
Method = dyn_cast<CXXMethodDecl>(Fn)) {
13898 bool CanConvertToFunctionPointer =
13899 Method->isStatic() ||
Method->isExplicitObjectMemberFunction();
13900 if (CanConvertToFunctionPointer == TargetTypeIsNonStaticMemberFunction)
13903 else if (TargetTypeIsNonStaticMemberFunction)
13906 if (FunctionDecl *FunDecl = dyn_cast<FunctionDecl>(Fn)) {
13913 if (FunDecl->isMultiVersion()) {
13914 const auto *TA = FunDecl->getAttr<TargetAttr>();
13915 if (TA && !TA->isDefaultVersion())
13917 const auto *TVA = FunDecl->getAttr<TargetVersionAttr>();
13918 if (TVA && !TVA->isDefaultVersion())
13926 HasComplained |= Complain;
13935 candidateHasExactlyCorrectType(FunDecl)) {
13936 Matches.push_back(std::make_pair(
13938 FoundNonTemplateFunction =
true;
13946 bool FindAllFunctionsThatMatchTargetTypeExactly() {
13951 if (IsInvalidFormOfPointerToMemberFunction())
13954 for (UnresolvedSetIterator I = OvlExpr->
decls_begin(),
13958 NamedDecl *
Fn = (*I)->getUnderlyingDecl();
13967 = dyn_cast<FunctionTemplateDecl>(Fn)) {
13973 AddMatchingNonTemplateFunction(Fn, I.getPair()))
13976 assert(Ret || Matches.empty());
13980 void EliminateAllExceptMostSpecializedTemplate() {
13992 UnresolvedSet<4> MatchesCopy;
13993 for (
unsigned I = 0, E = Matches.size(); I != E; ++I)
13994 MatchesCopy.
addDecl(Matches[I].second, Matches[I].first.getAccess());
13999 MatchesCopy.
begin(), MatchesCopy.
end(), FailedCandidates,
14001 S.
PDiag(diag::err_addr_ovl_ambiguous)
14002 << Matches[0].second->getDeclName(),
14003 S.
PDiag(diag::note_ovl_candidate)
14004 << (
unsigned)oc_function << (
unsigned)ocs_described_template,
14005 Complain, TargetFunctionType);
14009 Matches[0].first = Matches[
Result - MatchesCopy.
begin()].first;
14013 HasComplained |= Complain;
14016 void EliminateAllTemplateMatches() {
14019 for (
unsigned I = 0, N = Matches.size(); I != N; ) {
14020 if (Matches[I].second->getPrimaryTemplate() ==
nullptr)
14023 Matches[I] = Matches[--N];
14029 void EliminateLessPartialOrderingConstrainedMatches() {
14034 assert(Matches[0].second->getPrimaryTemplate() ==
nullptr &&
14035 "Call EliminateAllTemplateMatches() first");
14036 SmallVector<std::pair<DeclAccessPair, FunctionDecl *>, 4> Results;
14037 Results.push_back(Matches[0]);
14038 for (
unsigned I = 1, N = Matches.size(); I < N; ++I) {
14039 assert(Matches[I].second->getPrimaryTemplate() ==
nullptr);
14041 S, Matches[I].second, Results[0].second,
14045 Results.push_back(Matches[I]);
14048 if (F == Matches[I].second) {
14050 Results.push_back(Matches[I]);
14053 std::swap(Matches, Results);
14056 void EliminateSuboptimalCudaMatches() {
14062 void ComplainNoMatchesFound()
const {
14063 assert(Matches.empty());
14065 << OvlExpr->
getName() << TargetFunctionType
14067 if (FailedCandidates.
empty())
14074 for (UnresolvedSetIterator I = OvlExpr->
decls_begin(),
14077 if (FunctionDecl *Fun =
14078 dyn_cast<FunctionDecl>((*I)->getUnderlyingDecl()))
14086 bool IsInvalidFormOfPointerToMemberFunction()
const {
14087 return TargetTypeIsNonStaticMemberFunction &&
14091 void ComplainIsInvalidFormOfPointerToMemberFunction()
const {
14099 bool IsStaticMemberFunctionFromBoundPointer()
const {
14100 return StaticMemberFunctionFromBoundPointer;
14103 void ComplainIsStaticMemberFunctionFromBoundPointer()
const {
14105 diag::err_invalid_form_pointer_member_function)
14109 void ComplainOfInvalidConversion()
const {
14111 << OvlExpr->
getName() << TargetType;
14114 void ComplainMultipleMatchesFound()
const {
14115 assert(Matches.size() > 1);
14122 bool hadMultipleCandidates()
const {
return (OvlExpr->
getNumDecls() > 1); }
14124 int getNumMatches()
const {
return Matches.size(); }
14126 FunctionDecl* getMatchingFunctionDecl()
const {
14127 if (Matches.size() != 1)
return nullptr;
14128 return Matches[0].second;
14131 const DeclAccessPair* getMatchingFunctionAccessPair()
const {
14132 if (Matches.size() != 1)
return nullptr;
14133 return &Matches[0].first;
14143 bool *pHadMultipleCandidates) {
14146 AddressOfFunctionResolver Resolver(*
this, AddressOfExpr, TargetType,
14148 int NumMatches = Resolver.getNumMatches();
14150 bool ShouldComplain = Complain && !Resolver.hasComplained();
14151 if (NumMatches == 0 && ShouldComplain) {
14152 if (Resolver.IsInvalidFormOfPointerToMemberFunction())
14153 Resolver.ComplainIsInvalidFormOfPointerToMemberFunction();
14155 Resolver.ComplainNoMatchesFound();
14157 else if (NumMatches > 1 && ShouldComplain)
14158 Resolver.ComplainMultipleMatchesFound();
14159 else if (NumMatches == 1) {
14160 Fn = Resolver.getMatchingFunctionDecl();
14164 FoundResult = *Resolver.getMatchingFunctionAccessPair();
14166 if (Resolver.IsStaticMemberFunctionFromBoundPointer())
14167 Resolver.ComplainIsStaticMemberFunctionFromBoundPointer();
14173 if (pHadMultipleCandidates)
14174 *pHadMultipleCandidates = Resolver.hadMultipleCandidates();
14182 bool IsResultAmbiguous =
false;
14190 return static_cast<int>(
CUDA().IdentifyPreference(Caller, FD1)) -
14191 static_cast<int>(
CUDA().IdentifyPreference(Caller, FD2));
14198 auto *FD = dyn_cast<FunctionDecl>(I->getUnderlyingDecl());
14206 auto FoundBetter = [&]() {
14207 IsResultAmbiguous =
false;
14219 int PreferenceByCUDA = CheckCUDAPreference(FD,
Result);
14221 if (PreferenceByCUDA != 0) {
14223 if (PreferenceByCUDA > 0)
14239 if (MoreConstrained != FD) {
14240 if (!MoreConstrained) {
14241 IsResultAmbiguous =
true;
14242 AmbiguousDecls.push_back(FD);
14251 if (IsResultAmbiguous)
14272 ExprResult &SrcExpr,
bool DoFunctionPointerConversion) {
14274 assert(E->
getType() ==
Context.OverloadTy &&
"SrcExpr must be an overload");
14278 if (!
Found ||
Found->isCPUDispatchMultiVersion() ||
14279 Found->isCPUSpecificMultiVersion())
14327 dyn_cast<FunctionTemplateDecl>((*I)->getUnderlyingDecl());
14358 if (ForTypeDeduction &&
14372 if (FoundResult) *FoundResult = I.getPair();
14383 ExprResult &SrcExpr,
bool doFunctionPointerConversion,
bool complain,
14385 unsigned DiagIDForComplaining) {
14406 if (!complain)
return false;
14409 diag::err_bound_member_function)
14422 SingleFunctionExpression =
14426 if (doFunctionPointerConversion) {
14427 SingleFunctionExpression =
14429 if (SingleFunctionExpression.
isInvalid()) {
14436 if (!SingleFunctionExpression.
isUsable()) {
14438 Diag(OpRangeForComplaining.
getBegin(), DiagIDForComplaining)
14440 << DestTypeForComplaining
14441 << OpRangeForComplaining
14452 SrcExpr = SingleFunctionExpression;
14462 bool PartialOverloading,
14469 if (ExplicitTemplateArgs) {
14470 assert(!KnownValid &&
"Explicit template arguments?");
14479 PartialOverloading);
14484 = dyn_cast<FunctionTemplateDecl>(Callee)) {
14486 ExplicitTemplateArgs, Args, CandidateSet,
14488 PartialOverloading);
14492 assert(!KnownValid &&
"unhandled case in overloaded call candidate");
14498 bool PartialOverloading) {
14521 assert(!(*I)->getDeclContext()->isRecord());
14523 !(*I)->getDeclContext()->isFunctionOrMethod());
14524 assert((*I)->getUnderlyingDecl()->isFunctionOrFunctionTemplate());
14534 ExplicitTemplateArgs = &TABuffer;
14540 CandidateSet, PartialOverloading,
14545 Args, ExplicitTemplateArgs,
14546 CandidateSet, PartialOverloading);
14554 CandidateSet,
false,
false);
14561 case OO_New:
case OO_Array_New:
14562 case OO_Delete:
case OO_Array_Delete:
14585 if (DC->isTransparentContext())
14591 R.suppressDiagnostics();
14601 if (
auto *RD = dyn_cast<CXXRecordDecl>(DC)) {
14606 if (FoundInClass) {
14607 *FoundInClass = RD;
14610 R.addDecl(Best->FoundDecl.getDecl(), Best->FoundDecl.getAccess());
14627 AssociatedNamespaces,
14628 AssociatedClasses);
14632 for (Sema::AssociatedNamespaceSet::iterator
14633 it = AssociatedNamespaces.begin(),
14634 end = AssociatedNamespaces.end(); it !=
end; ++it) {
14646 SuggestedNamespaces.insert(*it);
14650 SemaRef.
Diag(R.getNameLoc(), diag::err_not_found_by_two_phase_lookup)
14651 << R.getLookupName();
14652 if (SuggestedNamespaces.empty()) {
14653 SemaRef.
Diag(Best->Function->getLocation(),
14654 diag::note_not_found_by_two_phase_lookup)
14655 << R.getLookupName() << 0;
14656 }
else if (SuggestedNamespaces.size() == 1) {
14657 SemaRef.
Diag(Best->Function->getLocation(),
14658 diag::note_not_found_by_two_phase_lookup)
14659 << R.getLookupName() << 1 << *SuggestedNamespaces.begin();
14664 SemaRef.
Diag(Best->Function->getLocation(),
14665 diag::note_not_found_by_two_phase_lookup)
14666 << R.getLookupName() << 2;
14697class BuildRecoveryCallExprRAII {
14699 Sema::SatisfactionStackResetRAII SatStack;
14702 BuildRecoveryCallExprRAII(Sema &S) : SemaRef(S), SatStack(S) {
14724 bool EmptyLookup,
bool AllowTypoCorrection) {
14732 BuildRecoveryCallExprRAII RCE(SemaRef);
14742 ExplicitTemplateArgs = &TABuffer;
14750 ExplicitTemplateArgs, Args, &FoundInClass)) {
14752 }
else if (EmptyLookup) {
14757 ExplicitTemplateArgs !=
nullptr,
14758 dyn_cast<MemberExpr>(Fn));
14760 AllowTypoCorrection
14766 }
else if (FoundInClass && SemaRef.
getLangOpts().MSVCCompat) {
14781 assert(!R.empty() &&
"lookup results empty despite recovery");
14784 if (R.isAmbiguous()) {
14785 R.suppressDiagnostics();
14792 if ((*R.begin())->isCXXClassMember())
14794 ExplicitTemplateArgs, S);
14795 else if (ExplicitTemplateArgs || TemplateKWLoc.
isValid())
14797 ExplicitTemplateArgs);
14821 assert(!ULE->
getQualifier() &&
"qualified name with ADL");
14828 (F = dyn_cast<FunctionDecl>(*ULE->
decls_begin())) &&
14830 llvm_unreachable(
"performing ADL for builtin");
14837 UnbridgedCastsSet UnbridgedCasts;
14852 if (CandidateSet->
empty() ||
14868 if (CandidateSet->
empty())
14871 UnbridgedCasts.restore();
14878 std::optional<QualType>
Result;
14898 if (Best && *Best != CS.
end())
14899 ConsiderCandidate(**Best);
14902 for (
const auto &
C : CS)
14904 ConsiderCandidate(
C);
14907 for (
const auto &
C : CS)
14908 ConsiderCandidate(
C);
14913 if (
Value.isNull() ||
Value->isUndeducedType())
14930 bool AllowTypoCorrection) {
14931 switch (OverloadResult) {
14942 Res.
get(), FDecl, LParenLoc, Args, RParenLoc, ExecConfig,
14948 if (*Best != CandidateSet->
end() &&
14952 dyn_cast_if_present<CXXMethodDecl>((*Best)->Function);
14957 SemaRef.
PDiag(diag::err_member_call_without_object) << 0 << M),
14967 CandidateSet->
empty(),
14968 AllowTypoCorrection);
14975 for (
const Expr *Arg : Args) {
14976 if (!Arg->getType()->isFunctionType())
14978 if (
auto *DRE = dyn_cast<DeclRefExpr>(Arg->IgnoreParenImpCasts())) {
14979 auto *FD = dyn_cast<FunctionDecl>(DRE->getDecl());
14982 Arg->getExprLoc()))
14990 SemaRef.
PDiag(diag::err_ovl_no_viable_function_in_call)
14991 << ULE->
getName() << Fn->getSourceRange()),
14999 SemaRef.
PDiag(diag::err_ovl_ambiguous_call)
15000 << ULE->
getName() << Fn->getSourceRange()),
15007 Fn->getSourceRange(), ULE->
getName(),
15008 *CandidateSet, FDecl, Args);
15017 Res.
get(), FDecl, LParenLoc, Args, RParenLoc, ExecConfig,
15025 SubExprs.append(Args.begin(), Args.end());
15032 for (
auto I = CS.
begin(), E = CS.
end(); I != E; ++I) {
15047 bool AllowTypoCorrection,
15048 bool CalleesAddressIsTaken) {
15063 if (CalleesAddressIsTaken)
15074 Best != CandidateSet.
end()) {
15075 if (
auto *M = dyn_cast_or_null<CXXMethodDecl>(Best->Function);
15076 M && M->isImplicitObjectMemberFunction()) {
15087 CUDA().recordPotentialODRUsedVariable(Args, CandidateSet);
15105 if (
const auto *TP =
15115 ExecConfig, &CandidateSet, &Best,
15116 OverloadResult, AllowTypoCorrection);
15125 Context, NamingClass, NNSLoc, DNI, PerformADL, Fns.
begin(), Fns.
end(),
15131 bool HadMultipleCandidates) {
15141 if (
Method->isExplicitObjectMemberFunction())
15145 E, std::nullopt, FoundDecl,
Method);
15149 if (
Method->getParent()->isLambda() &&
15150 Method->getConversionType()->isBlockPointerType()) {
15154 auto *CE = dyn_cast<CastExpr>(SubE);
15155 if (CE && CE->getCastKind() == CK_NoOp)
15156 SubE = CE->getSubExpr();
15158 if (
auto *BE = dyn_cast<CXXBindTemporaryExpr>(SubE))
15159 SubE = BE->getSubExpr();
15182 if (
Method->isExplicitObjectMemberFunction()) {
15188 Expr *ObjectParam = Exp.
get();
15202 Exp.
get()->getEndLoc(),
15216 Expr *Input,
bool PerformADL) {
15218 assert(Op !=
OO_None &&
"Invalid opcode for overloaded unary operator");
15226 Expr *Args[2] = { Input,
nullptr };
15227 unsigned NumArgs = 1;
15232 if (Opc == UO_PostInc || Opc == UO_PostDec) {
15246 if (Opc == UO_PreDec || Opc == UO_PreInc || Opc == UO_Deref)
15257 if (Fn.isInvalid())
15283 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
15302 if (
Method->isExplicitObjectMemberFunction())
15306 Input, std::nullopt, Best->FoundDecl,
Method);
15309 Base = Input = InputInit.
get();
15320 Input = InputInit.
get();
15325 Base, HadMultipleCandidates,
15337 Context, Op, FnExpr.
get(), ArgsArray, ResultTy,
VK, OpLoc,
15353 Input, Best->BuiltinParamTypes[0], Best->Conversions[0],
15358 Input = InputRes.
get();
15378 PDiag(diag::err_ovl_ambiguous_oper_unary)
15395 << (Msg !=
nullptr)
15396 << (Msg ? Msg->
getString() : StringRef())
15449 if (Op != OO_Equal && PerformADL) {
15456 Context.DeclarationNames.getCXXOperatorName(ExtraOp);
15482 Expr *RHS,
bool PerformADL,
15483 bool AllowRewrittenCandidates,
15485 Expr *Args[2] = { LHS, RHS };
15489 AllowRewrittenCandidates =
false;
15495 if (Args[0]->isTypeDependent() || Args[1]->isTypeDependent()) {
15516 if (Fn.isInvalid())
15525 if (Opc == BO_PtrMemD) {
15526 auto CheckPlaceholder = [&](
Expr *&Arg) {
15535 if (CheckPlaceholder(Args[0]) || CheckPlaceholder(Args[1]))
15559 if (Opc == BO_Assign &&
15568 Op, OpLoc, AllowRewrittenCandidates));
15570 CandidateSet.
exclude(DefaultedFn);
15573 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
15582 bool IsReversed = Best->isReversed();
15584 std::swap(Args[0], Args[1]);
15601 if (Best->RewriteKind && ChosenOp == OO_EqualEqual &&
15605 Diag(OpLoc, IsExtension ? diag::ext_ovl_rewrite_equalequal_not_bool
15606 : diag::err_ovl_rewrite_equalequal_not_bool)
15614 if (AllowRewrittenCandidates && !IsReversed &&
15624 for (
unsigned ArgIdx = 0; ArgIdx < 2; ++ArgIdx) {
15627 Best->Conversions[ArgIdx]) ==
15629 AmbiguousWith.push_back(Cand.
Function);
15636 if (!AmbiguousWith.empty()) {
15637 bool AmbiguousWithSelf =
15638 AmbiguousWith.size() == 1 &&
15640 Diag(OpLoc, diag::ext_ovl_ambiguous_oper_binary_reversed)
15642 << Args[0]->
getType() << Args[1]->
getType() << AmbiguousWithSelf
15644 if (AmbiguousWithSelf) {
15646 diag::note_ovl_ambiguous_oper_binary_reversed_self);
15651 if (
auto *MD = dyn_cast<CXXMethodDecl>(FnDecl))
15652 if (Op == OverloadedOperatorKind::OO_EqualEqual &&
15654 !MD->hasCXXExplicitFunctionObjectParameter() &&
15655 Context.hasSameUnqualifiedType(
15656 MD->getFunctionObjectParameterType(),
15657 MD->getParamDecl(0)->getType().getNonReferenceType()) &&
15658 Context.hasSameUnqualifiedType(
15659 MD->getFunctionObjectParameterType(),
15661 Context.hasSameUnqualifiedType(
15662 MD->getFunctionObjectParameterType(),
15665 diag::note_ovl_ambiguous_eqeq_reversed_self_non_const);
15668 diag::note_ovl_ambiguous_oper_binary_selected_candidate);
15669 for (
auto *F : AmbiguousWith)
15671 diag::note_ovl_ambiguous_oper_binary_reversed_candidate);
15679 if (Op == OO_Equal)
15690 if (
Method->isExplicitObjectMemberFunction()) {
15695 Args[0], std::nullopt, Best->FoundDecl,
Method);
15728 Best->FoundDecl,
Base,
15729 HadMultipleCandidates, OpLoc);
15740 const Expr *ImplicitThis =
nullptr;
15745 Context, ChosenOp, FnExpr.
get(), Args, ResultTy,
VK, OpLoc,
15750 if (
const auto *
Method = dyn_cast<CXXMethodDecl>(FnDecl);
15753 ImplicitThis = ArgsArray[0];
15754 ArgsArray = ArgsArray.slice(1);
15761 if (Op == OO_Equal) {
15766 *
this,
AssignedEntity{Args[0], dyn_cast<CXXMethodDecl>(FnDecl)},
15769 if (ImplicitThis) {
15774 CheckArgAlignment(OpLoc, FnDecl,
"'this'", ThisType,
15778 checkCall(FnDecl,
nullptr, ImplicitThis, ArgsArray,
15793 (Op == OO_Spaceship && IsReversed)) {
15794 if (Op == OO_ExclaimEqual) {
15795 assert(ChosenOp == OO_EqualEqual &&
"unexpected operator name");
15798 assert(ChosenOp == OO_Spaceship &&
"unexpected operator name");
15800 Expr *ZeroLiteral =
15809 OpLoc, Opc, Fns, IsReversed ? ZeroLiteral : R.get(),
15810 IsReversed ? R.get() : ZeroLiteral,
true,
15818 assert(ChosenOp == Op &&
"unexpected operator name");
15822 if (Best->RewriteKind !=
CRK_None)
15831 Args[0], Best->BuiltinParamTypes[0], Best->Conversions[0],
15836 Args[0] = ArgsRes0.
get();
15839 Args[1], Best->BuiltinParamTypes[1], Best->Conversions[1],
15844 Args[1] = ArgsRes1.
get();
15854 if (Opc == BO_Comma)
15859 if (DefaultedFn && Opc == BO_Cmp) {
15861 Args[1], DefaultedFn);
15876 Opc >= BO_Assign && Opc <= BO_OrAssign) {
15877 Diag(OpLoc, diag::err_ovl_no_viable_oper)
15880 if (Args[0]->
getType()->isIncompleteType()) {
15881 Diag(OpLoc, diag::note_assign_lhs_incomplete)
15897 assert(
Result.isInvalid() &&
15898 "C++ binary operator overloading is missing candidates!");
15909 << Args[0]->getSourceRange()
15910 << Args[1]->getSourceRange()),
15920 Diag(OpLoc, diag::err_ovl_deleted_special_oper)
15924 Diag(OpLoc, diag::err_ovl_deleted_comparison)
15925 << Args[0]->
getType() << DeletedFD;
15938 PDiag(diag::err_ovl_deleted_oper)
15940 .getCXXOverloadedOperator())
15941 << (Msg !=
nullptr) << (Msg ? Msg->
getString() : StringRef())
15942 << Args[0]->getSourceRange() << Args[1]->getSourceRange()),
15966 "cannot use prvalue expressions more than once");
15967 Expr *OrigLHS = LHS;
15968 Expr *OrigRHS = RHS;
15985 true, DefaultedFn);
15986 if (
Less.isInvalid())
16013 for (; I >= 0; --I) {
16015 auto *VI = Info->lookupValueInfo(Comparisons[I].
Result);
16038 Context, OrigLHS, OrigRHS, BO_Cmp,
Result.get()->getType(),
16039 Result.get()->getValueKind(),
Result.get()->getObjectKind(), OpLoc,
16041 Expr *SemanticForm[] = {LHS, RHS,
Result.get()};
16051 unsigned NumArgsSlots =
16052 MethodArgs.size() + std::max<unsigned>(Args.size(), NumParams);
16055 MethodArgs.reserve(MethodArgs.size() + NumArgsSlots);
16056 bool IsError =
false;
16059 for (
unsigned i = 0; i != NumParams; i++) {
16061 if (i < Args.size()) {
16065 S.
Context, Method->getParamDecl(i)),
16079 MethodArgs.push_back(Arg);
16089 Args.push_back(
Base);
16090 for (
auto *e : ArgExpr) {
16094 Context.DeclarationNames.getCXXOperatorName(OO_Subscript);
16099 ArgExpr.back()->getEndLoc());
16111 if (Fn.isInvalid())
16121 UnbridgedCastsSet UnbridgedCasts;
16134 if (Args.size() == 2)
16137 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
16157 if (
Method->isExplicitObjectMemberFunction()) {
16162 Args[0] = Res.
get();
16166 Args[0], std::nullopt, Best->FoundDecl,
Method);
16170 MethodArgs.push_back(Arg0.
get());
16174 *
this, MethodArgs,
Method, ArgExpr, LLoc);
16182 *
this, FnDecl, Best->FoundDecl,
Base, HadMultipleCandidates,
16193 Context, OO_Subscript, FnExpr.
get(), MethodArgs, ResultTy,
VK, RLoc,
16210 Args[0], Best->BuiltinParamTypes[0], Best->Conversions[0],
16215 Args[0] = ArgsRes0.
get();
16218 Args[1], Best->BuiltinParamTypes[1], Best->Conversions[1],
16223 Args[1] = ArgsRes1.
get();
16231 CandidateSet.
empty()
16232 ? (
PDiag(diag::err_ovl_no_oper)
16233 << Args[0]->getType() << 0
16234 << Args[0]->getSourceRange() << Range)
16235 : (
PDiag(diag::err_ovl_no_viable_subscript)
16236 << Args[0]->getType() << Args[0]->getSourceRange() << Range);
16243 if (Args.size() == 2) {
16246 LLoc,
PDiag(diag::err_ovl_ambiguous_oper_binary)
16248 << Args[0]->getSourceRange() << Range),
16253 PDiag(diag::err_ovl_ambiguous_subscript_call)
16255 << Args[0]->getSourceRange() << Range),
16264 PDiag(diag::err_ovl_deleted_oper)
16265 <<
"[]" << (Msg !=
nullptr)
16266 << (Msg ? Msg->
getString() : StringRef())
16267 << Args[0]->getSourceRange() << Range),
16281 Expr *ExecConfig,
bool IsExecConfig,
16282 bool AllowRecovery) {
16291 if (
BinaryOperator *op = dyn_cast<BinaryOperator>(NakedMemExpr)) {
16292 assert(op->getType() ==
Context.BoundMemberTy);
16293 assert(op->getOpcode() == BO_PtrMemD || op->getOpcode() == BO_PtrMemI);
16306 QualType objectType = op->getLHS()->getType();
16307 if (op->getOpcode() == BO_PtrMemI)
16311 Qualifiers difference = objectQuals - funcQuals;
16315 std::string qualsString = difference.
getAsString();
16316 Diag(LParenLoc, diag::err_pointer_to_member_call_drops_quals)
16319 << (qualsString.find(
' ') == std::string::npos ? 1 : 2);
16323 Context, MemExprE, Args, resultType, valueKind, RParenLoc,
16333 if (CheckOtherCall(call, proto))
16343 if (!AllowRecovery)
16345 std::vector<Expr *> SubExprs = {MemExprE};
16346 llvm::append_range(SubExprs, Args);
16354 UnbridgedCastsSet UnbridgedCasts;
16360 bool HadMultipleCandidates =
false;
16368 UnbridgedCasts.restore();
16386 TemplateArgs = &TemplateArgsBuffer;
16390 E = UnresExpr->
decls_end(); I != E; ++I) {
16392 QualType ExplicitObjectType = ObjectType;
16399 bool HasExplicitParameter =
false;
16400 if (
const auto *M = dyn_cast<FunctionDecl>(
Func);
16401 M && M->hasCXXExplicitFunctionObjectParameter())
16402 HasExplicitParameter =
true;
16403 else if (
const auto *M = dyn_cast<FunctionTemplateDecl>(
Func);
16405 M->getTemplatedDecl()->hasCXXExplicitFunctionObjectParameter())
16406 HasExplicitParameter =
true;
16408 if (HasExplicitParameter)
16416 }
else if ((
Method = dyn_cast<CXXMethodDecl>(
Func))) {
16423 ObjectClassification, Args, CandidateSet,
16427 I.getPair(), ActingDC, TemplateArgs,
16428 ExplicitObjectType, ObjectClassification,
16429 Args, CandidateSet,
16434 HadMultipleCandidates = (CandidateSet.
size() > 1);
16438 UnbridgedCasts.restore();
16441 bool Succeeded =
false;
16446 FoundDecl = Best->FoundDecl;
16466 PDiag(diag::err_ovl_no_viable_member_function_in_call)
16473 PDiag(diag::err_ovl_ambiguous_member_call)
16480 CandidateSet, Best->Function, Args,
true);
16491 MemExprE = Res.
get();
16495 if (
Method->isStatic()) {
16497 ExecConfig, IsExecConfig);
16507 assert(
Method &&
"Member call to something that isn't a method?");
16512 if (
Method->isExplicitObjectMemberFunction()) {
16520 HadMultipleCandidates, MemExpr->
getExprLoc());
16527 TheCall->setUsesMemberSyntax(
true);
16537 Proto->getNumParams());
16543 return BuildRecoveryExpr(ResultType);
16548 return BuildRecoveryExpr(ResultType);
16558 if (
auto *MemE = dyn_cast<MemberExpr>(NakedMemExpr)) {
16559 if (
const EnableIfAttr *
Attr =
16561 Diag(MemE->getMemberLoc(),
16562 diag::err_ovl_no_viable_member_function_in_call)
16565 diag::note_ovl_candidate_disabled_by_function_cond_attr)
16566 <<
Attr->getCond()->getSourceRange() <<
Attr->getMessage();
16572 TheCall->getDirectCallee()->isPureVirtual()) {
16578 diag::warn_call_to_pure_virtual_member_function_from_ctor_dtor)
16589 if (
auto *DD = dyn_cast<CXXDestructorDecl>(TheCall->getDirectCallee())) {
16593 CallCanBeVirtual,
true,
16598 TheCall->getDirectCallee());
16610 UnbridgedCastsSet UnbridgedCasts;
16614 assert(
Object.get()->getType()->isRecordType() &&
16615 "Requires object type argument");
16629 diag::err_incomplete_object_call,
Object.get()))
16632 auto *
Record =
Object.get()->getType()->castAsCXXRecordDecl();
16635 R.suppressAccessDiagnostics();
16638 Oper != OperEnd; ++Oper) {
16652 bool IgnoreSurrogateFunctions =
false;
16655 if (!Candidate.
Viable &&
16657 IgnoreSurrogateFunctions =
true;
16679 !IgnoreSurrogateFunctions && I != E; ++I) {
16701 Object.get(), Args, CandidateSet);
16706 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
16719 CandidateSet.
empty()
16720 ? (
PDiag(diag::err_ovl_no_oper)
16721 <<
Object.get()->getType() << 1
16722 <<
Object.get()->getSourceRange())
16723 : (
PDiag(diag::err_ovl_no_viable_object_call)
16724 <<
Object.get()->getType() <<
Object.get()->getSourceRange());
16731 if (!R.isAmbiguous())
16734 PDiag(diag::err_ovl_ambiguous_object_call)
16735 <<
Object.get()->getType()
16736 <<
Object.get()->getSourceRange()),
16747 PDiag(diag::err_ovl_deleted_object_call)
16748 <<
Object.get()->getType() << (Msg !=
nullptr)
16749 << (Msg ? Msg->
getString() : StringRef())
16750 <<
Object.get()->getSourceRange()),
16756 if (Best == CandidateSet.
end())
16759 UnbridgedCasts.restore();
16761 if (Best->Function ==
nullptr) {
16766 Best->Conversions[0].UserDefined.ConversionFunction);
16772 assert(Conv == Best->FoundDecl.getDecl() &&
16773 "Found Decl & conversion-to-functionptr should be same, right?!");
16781 Conv, HadMultipleCandidates);
16782 if (
Call.isInvalid())
16786 Context,
Call.get()->getType(), CK_UserDefinedConversion,
Call.get(),
16800 if (
Method->isInvalidDecl())
16807 Context.DeclarationNames.getCXXOperatorName(OO_Call), LParenLoc);
16810 Obj, HadMultipleCandidates,
16817 MethodArgs.reserve(NumParams + 1);
16819 bool IsError =
false;
16823 if (
Method->isExplicitObjectMemberFunction()) {
16832 MethodArgs.push_back(
Object.get());
16836 *
this, MethodArgs,
Method, Args, LParenLoc);
16839 if (Proto->isVariadic()) {
16841 for (
unsigned i = NumParams, e = Args.size(); i < e; i++) {
16845 MethodArgs.push_back(Arg.
get());
16860 Context, OO_Call, NewFn.
get(), MethodArgs, ResultTy,
VK, RParenLoc,
16874 bool *NoArrowOperatorFound) {
16875 assert(
Base->getType()->isRecordType() &&
16876 "left-hand side must have class type");
16890 Context.DeclarationNames.getCXXOperatorName(OO_Arrow);
16894 diag::err_typecheck_incomplete_tag,
Base))
16899 R.suppressAccessDiagnostics();
16902 Oper != OperEnd; ++Oper) {
16908 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
16919 if (CandidateSet.
empty()) {
16921 if (NoArrowOperatorFound) {
16924 *NoArrowOperatorFound =
true;
16927 Diag(OpLoc, diag::err_typecheck_member_reference_arrow)
16928 << BaseType <<
Base->getSourceRange();
16929 if (BaseType->isRecordType() && !BaseType->isPointerType()) {
16930 Diag(OpLoc, diag::note_typecheck_member_reference_suggestion)
16934 Diag(OpLoc, diag::err_ovl_no_viable_oper)
16935 <<
"operator->" <<
Base->getSourceRange();
16940 if (!R.isAmbiguous())
16943 <<
"->" <<
Base->getType()
16944 <<
Base->getSourceRange()),
16952 <<
"->" << (Msg !=
nullptr)
16953 << (Msg ? Msg->
getString() : StringRef())
16954 <<
Base->getSourceRange()),
16965 if (
Method->isExplicitObjectMemberFunction()) {
16972 Base, std::nullopt, Best->FoundDecl,
Method);
16980 Base, HadMultipleCandidates, OpLoc);
17014 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
17027 PDiag(diag::err_ovl_no_viable_function_in_call)
17028 << R.getLookupName()),
17035 << R.getLookupName()),
17042 nullptr, HadMultipleCandidates,
17045 if (Fn.isInvalid())
17051 for (
unsigned ArgIdx = 0, N = Args.size(); ArgIdx != N; ++ArgIdx) {
17057 ConvArgs[ArgIdx] = InputInit.
get();
17084 Scope *S =
nullptr;
17087 if (!MemberLookup.
empty()) {
17114 if (CandidateSet->
empty() || CandidateSetError) {
17127 Loc,
nullptr, CandidateSet, &Best,
17140 if (
ParenExpr *PE = dyn_cast<ParenExpr>(E)) {
17145 if (SubExpr.
get() == PE->getSubExpr())
17149 ParenExpr(PE->getLParen(), PE->getRParen(), SubExpr.
get());
17157 assert(
Context.hasSameType(ICE->getSubExpr()->getType(),
17159 "Implicit cast type cannot be determined from overload");
17160 assert(ICE->path_empty() &&
"fixing up hierarchy conversion?");
17161 if (SubExpr.
get() == ICE->getSubExpr())
17169 if (
auto *GSE = dyn_cast<GenericSelectionExpr>(E)) {
17170 if (!GSE->isResultDependent()) {
17175 if (SubExpr.
get() == GSE->getResultExpr())
17182 unsigned ResultIdx = GSE->getResultIndex();
17183 AssocExprs[ResultIdx] = SubExpr.
get();
17185 if (GSE->isExprPredicate())
17187 Context, GSE->getGenericLoc(), GSE->getControllingExpr(),
17188 GSE->getAssocTypeSourceInfos(), AssocExprs, GSE->getDefaultLoc(),
17189 GSE->getRParenLoc(), GSE->containsUnexpandedParameterPack(),
17192 Context, GSE->getGenericLoc(), GSE->getControllingType(),
17193 GSE->getAssocTypeSourceInfos(), AssocExprs, GSE->getDefaultLoc(),
17194 GSE->getRParenLoc(), GSE->containsUnexpandedParameterPack(),
17203 assert(UnOp->getOpcode() == UO_AddrOf &&
17204 "Can only take the address of an overloaded function");
17206 if (!
Method->isImplicitObjectMemberFunction()) {
17217 if (SubExpr.
get() == UnOp->getSubExpr())
17225 "fixed to something other than a decl ref");
17228 assert(Qualifier &&
17229 "fixed to a member ref with no nested name qualifier");
17235 Fn->getType(), Qualifier,
17238 if (
Context.getTargetInfo().getCXXABI().isMicrosoft())
17243 UnOp->getOperatorLoc(),
false,
17251 if (SubExpr.
get() == UnOp->getSubExpr())
17264 if (ULE->hasExplicitTemplateArgs()) {
17265 ULE->copyTemplateArgumentsInto(TemplateArgsBuffer);
17266 TemplateArgs = &TemplateArgsBuffer;
17271 getLangOpts().CPlusPlus && !Fn->hasCXXExplicitFunctionObjectParameter()
17276 if (
unsigned BID = Fn->getBuiltinID()) {
17277 if (!
Context.BuiltinInfo.isDirectlyAddressable(BID)) {
17284 Fn,
Type, ValueKind, ULE->getNameInfo(), ULE->getQualifierLoc(),
17285 Found.getDecl(), ULE->getTemplateKeywordLoc(), TemplateArgs);
17293 if (MemExpr->hasExplicitTemplateArgs()) {
17294 MemExpr->copyTemplateArgumentsInto(TemplateArgsBuffer);
17295 TemplateArgs = &TemplateArgsBuffer;
17302 if (MemExpr->isImplicitAccess()) {
17305 Fn, Fn->getType(),
VK_LValue, MemExpr->getNameInfo(),
17306 MemExpr->getQualifierLoc(),
Found.getDecl(),
17307 MemExpr->getTemplateKeywordLoc(), TemplateArgs);
17312 if (MemExpr->getQualifier())
17313 Loc = MemExpr->getQualifierLoc().getBeginLoc();
17318 Base = MemExpr->getBase();
17324 type = Fn->getType();
17331 Base, MemExpr->isArrow(), MemExpr->getOperatorLoc(),
17332 MemExpr->getQualifierLoc(), MemExpr->getTemplateKeywordLoc(), Fn,
Found,
17333 true, MemExpr->getMemberNameInfo(),
17337 llvm_unreachable(
"Invalid reference to overloaded function");
17348 if (!PartialOverloading || !
Function)
17352 if (
const auto *Proto =
17353 dyn_cast<FunctionProtoType>(
Function->getFunctionType()))
17354 if (Proto->isTemplateVariadic())
17356 if (
auto *Pattern =
Function->getTemplateInstantiationPattern())
17357 if (
const auto *Proto =
17358 dyn_cast<FunctionProtoType>(Pattern->getFunctionType()))
17359 if (Proto->isTemplateVariadic())
17372 << IsMember << Name << (Msg !=
nullptr)
17373 << (Msg ? Msg->
getString() : StringRef())
Defines the clang::ASTContext interface.
Defines the Diagnostic-related interfaces.
static bool isBooleanType(QualType Ty)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
Defines the clang::Expr interface and subclasses for C++ expressions.
Result
Implement __builtin_bit_cast and related operations.
static const GlobalDecl isTemplate(GlobalDecl GD, const TemplateArgumentList *&TemplateArgs)
static DiagnosticBuilder Diag(DiagnosticsEngine *Diags, const LangOptions &Features, FullSourceLoc TokLoc, const char *TokBegin, const char *TokRangeBegin, const char *TokRangeEnd, unsigned DiagID)
Produce a diagnostic highlighting some portion of a literal.
llvm::MachO::Record Record
Defines an enumeration for C++ overloaded operators.
Implements a partial diagnostic that can be emitted anwyhere in a DiagnosticBuilder stream.
This file declares semantic analysis functions specific to AMDGPU.
This file declares semantic analysis functions specific to ARM.
static bool hasAttr(const Decl *D, bool IgnoreImplicitAttr)
static bool hasExplicitAttr(const VarDecl *D)
This file declares semantic analysis for CUDA constructs.
static void BuildBasePathArray(const CXXBasePath &Path, CXXCastPath &BasePathArray)
static bool isRecordType(QualType T)
static void TryUserDefinedConversion(Sema &S, QualType DestType, const InitializationKind &Kind, Expr *Initializer, InitializationSequence &Sequence, bool TopLevelOfInitList)
Attempt a user-defined conversion between two types (C++ [dcl.init]), which enumerates all conversion...
This file declares semantic analysis for Objective-C.
static ImplicitConversionSequence::CompareKind CompareStandardConversionSequences(Sema &S, SourceLocation Loc, const StandardConversionSequence &SCS1, const StandardConversionSequence &SCS2)
CompareStandardConversionSequences - Compare two standard conversion sequences to determine whether o...
static bool sameFunctionParameterTypeLists(Sema &S, FunctionDecl *Fn1, FunctionDecl *Fn2, bool IsFn1Reversed, bool IsFn2Reversed)
We're allowed to use constraints partial ordering only if the candidates have the same parameter type...
static bool isNullPointerConstantForConversion(Expr *Expr, bool InOverloadResolution, ASTContext &Context)
static bool shouldSkipNotingLambdaConversionDecl(const FunctionDecl *Fn)
static const FunctionType * getConversionOpReturnTyAsFunction(CXXConversionDecl *Conv)
static bool functionHasPassObjectSizeParams(const FunctionDecl *FD)
static Comparison compareEnableIfAttrs(const Sema &S, const FunctionDecl *Cand1, const FunctionDecl *Cand2)
Compares the enable_if attributes of two FunctionDecls, for the purposes of overload resolution.
static Qualifiers CollectVRQualifiers(ASTContext &Context, Expr *ArgExpr)
CollectVRQualifiers - This routine returns Volatile/Restrict qualifiers, if any, found in visible typ...
@ ToPromotedUnderlyingType
static void AddOverloadedCallCandidate(Sema &S, DeclAccessPair FoundDecl, TemplateArgumentListInfo *ExplicitTemplateArgs, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool PartialOverloading, bool KnownValid)
Add a single candidate to the overload set.
static void AddTemplateOverloadCandidateImmediately(Sema &S, OverloadCandidateSet &CandidateSet, FunctionTemplateDecl *FunctionTemplate, DeclAccessPair FoundDecl, TemplateArgumentListInfo *ExplicitTemplateArgs, ArrayRef< Expr * > Args, bool SuppressUserConversions, bool PartialOverloading, bool AllowExplicit, Sema::ADLCallKind IsADLCandidate, OverloadCandidateParamOrder PO, bool AggregateCandidateDeduction)
static bool IsVectorOrMatrixElementConversion(Sema &S, QualType FromType, QualType ToType, ImplicitConversionKind &ICK, Expr *From)
static ExprResult FinishOverloadedCallExpr(Sema &SemaRef, Scope *S, Expr *Fn, UnresolvedLookupExpr *ULE, SourceLocation LParenLoc, MultiExprArg Args, SourceLocation RParenLoc, Expr *ExecConfig, OverloadCandidateSet *CandidateSet, OverloadCandidateSet::iterator *Best, OverloadingResult OverloadResult, bool AllowTypoCorrection)
FinishOverloadedCallExpr - given an OverloadCandidateSet, builds and returns the completed call expre...
static bool isQualificationConversionStep(QualType FromType, QualType ToType, bool CStyle, bool IsTopLevel, bool &PreviousToQualsIncludeConst, bool &ObjCLifetimeConversion, const ASTContext &Ctx)
Perform a single iteration of the loop for checking if a qualification conversion is valid.
static ImplicitConversionSequence::CompareKind CompareQualificationConversions(Sema &S, const StandardConversionSequence &SCS1, const StandardConversionSequence &SCS2)
CompareQualificationConversions - Compares two standard conversion sequences to determine whether the...
static void dropPointerConversion(StandardConversionSequence &SCS)
dropPointerConversions - If the given standard conversion sequence involves any pointer conversions,...
static SourceLocation GetLocationForCandidate(const OverloadCandidate *Cand)
static void DiagnoseArityMismatch(Sema &S, NamedDecl *Found, Decl *D, unsigned NumFormalArgs, bool IsAddressOf=false)
General arity mismatch diagnosis over a candidate in a candidate set.
static const Expr * IgnoreNarrowingConversion(ASTContext &Ctx, const Expr *Converted)
Skip any implicit casts which could be either part of a narrowing conversion or after one in an impli...
static bool allowAmbiguity(ASTContext &Context, const FunctionDecl *F1, const FunctionDecl *F2)
static unsigned RankDeductionFailure(const DeductionFailureInfo &DFI)
static QualType BuildSimilarlyQualifiedPointerType(const Type *FromPtr, QualType ToPointee, QualType ToType, ASTContext &Context, bool StripObjCLifetime=false)
BuildSimilarlyQualifiedPointerType - In a pointer conversion from the pointer type FromPtr to a point...
static void forAllQualifierCombinations(QualifiersAndAtomic Quals, llvm::function_ref< void(QualifiersAndAtomic)> Callback)
static bool FindConversionForRefInit(Sema &S, ImplicitConversionSequence &ICS, QualType DeclType, SourceLocation DeclLoc, Expr *Init, QualType T2, bool AllowRvalues, bool AllowExplicit)
Look for a user-defined conversion to a value reference-compatible with DeclType.
static bool tryAtomicConversion(Sema &S, Expr *From, QualType ToType, bool InOverloadResolution, StandardConversionSequence &SCS, bool CStyle)
static Expr * GetExplicitObjectExpr(Sema &S, Expr *Obj, const FunctionDecl *Fun)
static bool hasDeprecatedStringLiteralToCharPtrConversion(const ImplicitConversionSequence &ICS)
static void AddBuiltinAssignmentOperatorCandidates(Sema &S, QualType T, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet)
Helper function for AddBuiltinOperatorCandidates() that adds the volatile- and non-volatile-qualified...
static bool CheckConvertedConstantConversions(Sema &S, StandardConversionSequence &SCS)
Check that the specified conversion is permitted in a converted constant expression,...
static bool tryOverflowBehaviorTypeConversion(Sema &S, Expr *From, QualType ToType, bool InOverloadResolution, StandardConversionSequence &SCS, bool CStyle)
static void NoteBuiltinOperatorCandidate(Sema &S, StringRef Opc, SourceLocation OpLoc, OverloadCandidate *Cand)
static ImplicitConversionSequence::CompareKind compareConversionFunctions(Sema &S, FunctionDecl *Function1, FunctionDecl *Function2)
Compare the user-defined conversion functions or constructors of two user-defined conversion sequence...
static void forAllQualifierCombinationsImpl(QualifiersAndAtomic Available, QualifiersAndAtomic Applied, llvm::function_ref< void(QualifiersAndAtomic)> Callback)
static const char * GetImplicitConversionName(ImplicitConversionKind Kind)
GetImplicitConversionName - Return the name of this kind of implicit conversion.
static bool checkAddressOfFunctionIsAvailable(Sema &S, const FunctionDecl *FD, bool Complain, bool InOverloadResolution, SourceLocation Loc)
Returns true if we can take the address of the function.
static ImplicitConversionSequence::CompareKind CompareDerivedToBaseConversions(Sema &S, SourceLocation Loc, const StandardConversionSequence &SCS1, const StandardConversionSequence &SCS2)
CompareDerivedToBaseConversions - Compares two standard conversion sequences to determine whether the...
static bool convertArgsForAvailabilityChecks(Sema &S, FunctionDecl *Function, Expr *ThisArg, SourceLocation CallLoc, ArrayRef< Expr * > Args, Sema::SFINAETrap &Trap, bool MissingImplicitThis, Expr *&ConvertedThis, SmallVectorImpl< Expr * > &ConvertedArgs)
static TemplateDecl * getDescribedTemplate(Decl *Templated)
static void CompleteNonViableCandidate(Sema &S, OverloadCandidate *Cand, ArrayRef< Expr * > Args, OverloadCandidateSet::CandidateSetKind CSK)
CompleteNonViableCandidate - Normally, overload resolution only computes up to the first bad conversi...
static QualType AdoptQualifiers(ASTContext &Context, QualType T, Qualifiers Qs)
Adopt the given qualifiers for the given type.
static void NoteAmbiguousUserConversions(Sema &S, SourceLocation OpLoc, OverloadCandidate *Cand)
static bool CheckArityMismatch(Sema &S, OverloadCandidate *Cand, unsigned NumArgs, bool IsAddressOf=false)
Additional arity mismatch diagnosis specific to a function overload candidates.
static ImplicitConversionSequence::CompareKind compareStandardConversionSubsets(ASTContext &Context, const StandardConversionSequence &SCS1, const StandardConversionSequence &SCS2)
static bool hasDependentExplicit(FunctionTemplateDecl *FTD)
static bool IsVectorConversion(Sema &S, QualType FromType, QualType ToType, ImplicitConversionKind &ICK, ImplicitConversionKind &ElConv, Expr *From, bool InOverloadResolution, bool CStyle)
Determine whether the conversion from FromType to ToType is a valid vector conversion.
static ImplicitConversionSequence TryContextuallyConvertToObjCPointer(Sema &S, Expr *From)
TryContextuallyConvertToObjCPointer - Attempt to contextually convert the expression From to an Objec...
static ExprResult CheckConvertedConstantExpression(Sema &S, Expr *From, QualType T, APValue &Value, CCEKind CCE, bool RequireInt, NamedDecl *Dest)
CheckConvertedConstantExpression - Check that the expression From is a converted constant expression ...
static ExprResult CreateFunctionRefExpr(Sema &S, FunctionDecl *Fn, NamedDecl *FoundDecl, const Expr *Base, bool HadMultipleCandidates, SourceLocation Loc=SourceLocation(), const DeclarationNameLoc &LocInfo=DeclarationNameLoc())
A convenience routine for creating a decayed reference to a function.
static std::optional< QualType > getImplicitObjectParamType(ASTContext &Context, const FunctionDecl *F)
Compute the type of the implicit object parameter for the given function, if any.
static bool checkPlaceholderForOverload(Sema &S, Expr *&E, UnbridgedCastsSet *unbridgedCasts=nullptr)
checkPlaceholderForOverload - Do any interesting placeholder-like preprocessing on the given expressi...
static FixedEnumPromotion getFixedEnumPromtion(Sema &S, const StandardConversionSequence &SCS)
Returns kind of fixed enum promotion the SCS uses.
static bool isAllowableExplicitConversion(Sema &S, QualType ConvType, QualType ToType, bool AllowObjCPointerConversion)
Determine whether this is an allowable conversion from the result of an explicit conversion operator ...
static bool isNonViableMultiVersionOverload(FunctionDecl *FD)
static bool FunctionsCorrespond(ASTContext &Ctx, const FunctionDecl *X, const FunctionDecl *Y)
static ImplicitConversionSequence TryImplicitConversion(Sema &S, Expr *From, QualType ToType, bool SuppressUserConversions, AllowedExplicit AllowExplicit, bool InOverloadResolution, bool CStyle, bool AllowObjCWritebackConversion, bool AllowObjCConversionOnExplicit)
TryImplicitConversion - Attempt to perform an implicit conversion from the given expression (Expr) to...
static ExprResult BuildConvertedConstantExpression(Sema &S, Expr *From, QualType T, CCEKind CCE, NamedDecl *Dest, APValue &PreNarrowingValue)
BuildConvertedConstantExpression - Check that the expression From is a converted constant expression ...
static ImplicitConversionSequence TryListConversion(Sema &S, InitListExpr *From, QualType ToType, bool SuppressUserConversions, bool InOverloadResolution, bool AllowObjCWritebackConversion)
TryListConversion - Try to copy-initialize a value of type ToType from the initializer list From.
static bool IsOverloadOrOverrideImpl(Sema &SemaRef, FunctionDecl *New, FunctionDecl *Old, bool UseMemberUsingDeclRules, bool ConsiderCudaAttrs, bool UseOverrideRules=false)
static QualType withoutUnaligned(ASTContext &Ctx, QualType T)
static void DiagnoseBadTarget(Sema &S, OverloadCandidate *Cand)
CUDA: diagnose an invalid call across targets.
static void MaybeDiagnoseAmbiguousConstraints(Sema &S, ArrayRef< OverloadCandidate > Cands)
static bool diagnoseNoViableConversion(Sema &SemaRef, SourceLocation Loc, Expr *&From, Sema::ContextualImplicitConverter &Converter, QualType T, bool HadMultipleCandidates, UnresolvedSetImpl &ExplicitConversions)
static void AddMethodTemplateCandidateImmediately(Sema &S, OverloadCandidateSet &CandidateSet, FunctionTemplateDecl *MethodTmpl, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, TemplateArgumentListInfo *ExplicitTemplateArgs, QualType ObjectType, Expr::Classification ObjectClassification, ArrayRef< Expr * > Args, bool SuppressUserConversions, bool PartialOverloading, OverloadCandidateParamOrder PO)
static void AddTemplateConversionCandidateImmediately(Sema &S, OverloadCandidateSet &CandidateSet, FunctionTemplateDecl *FunctionTemplate, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, Expr *From, QualType ToType, bool AllowObjCConversionOnExplicit, bool AllowExplicit, bool AllowResultConversion)
static ImplicitConversionSequence TryContextuallyConvertToBool(Sema &S, Expr *From)
TryContextuallyConvertToBool - Attempt to contextually convert the expression From to bool (C++0x [co...
static ImplicitConversionSequence TryObjectArgumentInitialization(Sema &S, SourceLocation Loc, QualType FromType, Expr::Classification FromClassification, CXXMethodDecl *Method, const CXXRecordDecl *ActingContext, bool InOverloadResolution=false, QualType ExplicitParameterType=QualType(), bool SuppressUserConversion=false)
TryObjectArgumentInitialization - Try to initialize the object parameter of the given member function...
static bool recordConversion(Sema &SemaRef, SourceLocation Loc, Expr *&From, Sema::ContextualImplicitConverter &Converter, QualType T, bool HadMultipleCandidates, DeclAccessPair &Found)
static ImplicitConversionSequence::CompareKind CompareImplicitConversionSequences(Sema &S, SourceLocation Loc, const ImplicitConversionSequence &ICS1, const ImplicitConversionSequence &ICS2)
CompareImplicitConversionSequences - Compare two implicit conversion sequences to determine whether o...
static ImplicitConversionSequence::CompareKind CompareOverflowBehaviorConversions(Sema &S, const StandardConversionSequence &SCS1, const StandardConversionSequence &SCS2)
CompareOverflowBehaviorConversions - Compares two standard conversion sequences to determine whether ...
static void NoteFunctionCandidate(Sema &S, OverloadCandidate *Cand, unsigned NumArgs, bool TakingCandidateAddress, LangAS CtorDestAS=LangAS::Default)
Generates a 'note' diagnostic for an overload candidate.
static ImplicitConversionSequence TryCopyInitialization(Sema &S, Expr *From, QualType ToType, bool SuppressUserConversions, bool InOverloadResolution, bool AllowObjCWritebackConversion, bool AllowExplicit=false)
TryCopyInitialization - Try to copy-initialize a value of type ToType from the expression From.
static ExprResult diagnoseAmbiguousConversion(Sema &SemaRef, SourceLocation Loc, Expr *From, Sema::ContextualImplicitConverter &Converter, QualType T, UnresolvedSetImpl &ViableConversions)
static void markUnaddressableCandidatesUnviable(Sema &S, OverloadCandidateSet &CS)
static QualType GetExplicitObjectType(Sema &S, const Expr *MemExprE)
Sema::AllowedExplicit AllowedExplicit
static QualType AdjustAddressSpaceForBuiltinOperandType(Sema &S, QualType T, Expr *Arg)
Helper function for adjusting address spaces for the pointer or reference operands of builtin operato...
static void DiagnoseFailedExplicitSpec(Sema &S, OverloadCandidate *Cand)
static bool DiagnoseTwoPhaseLookup(Sema &SemaRef, SourceLocation FnLoc, const CXXScopeSpec &SS, LookupResult &R, OverloadCandidateSet::CandidateSetKind CSK, TemplateArgumentListInfo *ExplicitTemplateArgs, ArrayRef< Expr * > Args, CXXRecordDecl **FoundInClass=nullptr)
Attempt to recover from an ill-formed use of a non-dependent name in a template, where the non-depend...
static bool isBetterReferenceBindingKind(const StandardConversionSequence &SCS1, const StandardConversionSequence &SCS2)
Determine whether one of the given reference bindings is better than the other based on what kind of ...
static bool canBeDeclaredInNamespace(const DeclarationName &Name)
Determine whether a declaration with the specified name could be moved into a different namespace.
static ExprResult finishContextualImplicitConversion(Sema &SemaRef, SourceLocation Loc, Expr *From, Sema::ContextualImplicitConverter &Converter)
static bool IsStandardConversion(Sema &S, Expr *From, QualType ToType, bool InOverloadResolution, StandardConversionSequence &SCS, bool CStyle, bool AllowObjCWritebackConversion)
IsStandardConversion - Determines whether there is a standard conversion sequence (C++ [conv],...
static bool DiagnoseTwoPhaseOperatorLookup(Sema &SemaRef, OverloadedOperatorKind Op, SourceLocation OpLoc, ArrayRef< Expr * > Args)
Attempt to recover from ill-formed use of a non-dependent operator in a template, where the non-depen...
static bool isNonTrivialObjCLifetimeConversion(Qualifiers FromQuals, Qualifiers ToQuals)
Determine whether the lifetime conversion between the two given qualifiers sets is nontrivial.
static void DiagnoseBadConversion(Sema &S, OverloadCandidate *Cand, unsigned I, bool TakingCandidateAddress)
static bool completeFunctionType(Sema &S, FunctionDecl *FD, SourceLocation Loc, bool Complain=true)
static bool shouldAddReversedEqEq(Sema &S, SourceLocation OpLoc, Expr *FirstOperand, FunctionDecl *EqFD)
static bool isFunctionAlwaysEnabled(const ASTContext &Ctx, const FunctionDecl *FD)
static bool PrepareExplicitObjectArgument(Sema &S, CXXMethodDecl *Method, Expr *Object, MultiExprArg &Args, SmallVectorImpl< Expr * > &NewArgs)
static OverloadingResult IsInitializerListConstructorConversion(Sema &S, Expr *From, QualType ToType, CXXRecordDecl *To, UserDefinedConversionSequence &User, OverloadCandidateSet &CandidateSet, bool AllowExplicit)
static bool IsMatrixConversion(Sema &S, QualType FromType, QualType ToType, ImplicitConversionKind &ICK, ImplicitConversionKind &ElConv, Expr *From, bool InOverloadResolution, bool CStyle)
Determine whether the conversion from FromType to ToType is a valid matrix conversion.
static bool checkAddressOfCandidateIsAvailable(Sema &S, const FunctionDecl *FD)
static bool IsFloatingPointConversion(Sema &S, QualType FromType, QualType ToType)
Determine whether the conversion from FromType to ToType is a valid floating point conversion.
static bool isFirstArgumentCompatibleWithType(ASTContext &Context, CXXConstructorDecl *Constructor, QualType Type)
static Comparison isBetterMultiversionCandidate(const OverloadCandidate &Cand1, const OverloadCandidate &Cand2)
static void NoteImplicitDeductionGuide(Sema &S, FunctionDecl *Fn)
static void collectViableConversionCandidates(Sema &SemaRef, Expr *From, QualType ToType, UnresolvedSetImpl &ViableConversions, OverloadCandidateSet &CandidateSet)
static ImplicitConversionSequence TryReferenceInit(Sema &S, Expr *Init, QualType DeclType, SourceLocation DeclLoc, bool SuppressUserConversions, bool AllowExplicit)
Compute an implicit conversion sequence for reference initialization.
static bool isNonDependentlyExplicit(FunctionTemplateDecl *FTD)
Determine whether a given function template has a simple explicit specifier or a non-value-dependent ...
static bool checkArgPlaceholdersForOverload(Sema &S, MultiExprArg Args, UnbridgedCastsSet &unbridged)
checkArgPlaceholdersForOverload - Check a set of call operands for placeholders.
static QualType makeQualifiedLValueReferenceType(QualType Base, QualifiersAndAtomic Quals, Sema &S)
static QualType chooseRecoveryType(OverloadCandidateSet &CS, OverloadCandidateSet::iterator *Best)
static void AddTemplateOverloadCandidate(Sema &S, OverloadCandidateSet &CandidateSet, DeferredMethodTemplateOverloadCandidate &C)
static void NoteSurrogateCandidate(Sema &S, OverloadCandidate *Cand)
static ExprResult BuildRecoveryCallExpr(Sema &SemaRef, Scope *S, Expr *Fn, UnresolvedLookupExpr *ULE, SourceLocation LParenLoc, MutableArrayRef< Expr * > Args, SourceLocation RParenLoc, bool EmptyLookup, bool AllowTypoCorrection)
Attempts to recover from a call where no functions were found.
static void DiagnoseFailedEnableIfAttr(Sema &S, OverloadCandidate *Cand)
static bool diagnoseDiagnoseIfAttrsWith(Sema &S, const NamedDecl *ND, bool ArgDependent, SourceLocation Loc, CheckFn &&IsSuccessful)
static OverloadingResult IsUserDefinedConversion(Sema &S, Expr *From, QualType ToType, UserDefinedConversionSequence &User, OverloadCandidateSet &Conversions, AllowedExplicit AllowExplicit, bool AllowObjCConversionOnExplicit)
Determines whether there is a user-defined conversion sequence (C++ [over.ics.user]) that converts ex...
static bool IsAcceptableNonMemberOperatorCandidate(ASTContext &Context, FunctionDecl *Fn, ArrayRef< Expr * > Args)
IsAcceptableNonMemberOperatorCandidate - Determine whether Fn is an acceptable non-member overloaded ...
static FunctionDecl * getMorePartialOrderingConstrained(Sema &S, FunctionDecl *Fn1, FunctionDecl *Fn2, bool IsFn1Reversed, bool IsFn2Reversed)
static void DiagnoseBadDeduction(Sema &S, NamedDecl *Found, Decl *Templated, DeductionFailureInfo &DeductionFailure, unsigned NumArgs, bool TakingCandidateAddress)
Diagnose a failed template-argument deduction.
static bool IsTransparentUnionStandardConversion(Sema &S, Expr *From, QualType &ToType, bool InOverloadResolution, StandardConversionSequence &SCS, bool CStyle)
static const FunctionProtoType * tryGetFunctionProtoType(QualType FromType)
Attempts to get the FunctionProtoType from a Type.
static bool PrepareArgumentsForCallToObjectOfClassType(Sema &S, SmallVectorImpl< Expr * > &MethodArgs, CXXMethodDecl *Method, MultiExprArg Args, SourceLocation LParenLoc)
static TemplateDeductionResult DeduceTemplateArguments(Sema &S, TemplateParameterList *TemplateParams, ArrayRef< TemplateArgument > Ps, ArrayRef< TemplateArgument > As, TemplateDeductionInfo &Info, SmallVectorImpl< DeducedTemplateArgument > &Deduced, bool NumberOfArgumentsMustMatch, bool PartialOrdering, PackFold PackFold, bool *HasDeducedAnyParam)
Defines the SourceManager interface.
static QualType getPointeeType(const MemRegion *R)
C Language Family Type Representation.
a trap message and trap category.
A class for storing results from argument-dependent lookup.
void erase(NamedDecl *D)
Removes any data associated with a given decl.
llvm::mapped_iterator< decltype(Decls)::iterator, select_second > iterator
APValue - This class implements a discriminated union of [uninitialized] [APSInt] [APFloat],...
std::string getAsString(const ASTContext &Ctx, QualType Ty) const
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
const ConstantArrayType * getAsConstantArrayType(QualType T) const
QualType getAtomicType(QualType T) const
Return the uniqued reference to the atomic type for the specified type.
QualType getRValueReferenceType(QualType T) const
Return the uniqued reference to the type for an rvalue reference to the specified type.
unsigned getIntWidth(QualType T) const
bool areCompatibleRVVTypes(QualType FirstType, QualType SecondType)
Return true if the given types are an RISC-V vector builtin type and a VectorType that is a fixed-len...
const llvm::fltSemantics & getFloatTypeSemantics(QualType T) const
Return the APFloat 'semantics' for the specified scalar floating point type.
static CanQualType getCanonicalType(QualType T)
Return the canonical (structural) type corresponding to the specified potentially non-canonical type ...
DeclarationNameTable DeclarationNames
QualType getArrayParameterType(QualType Ty) const
Return the uniqued reference to a specified array parameter type from the original array type.
QualType getPointerType(QualType T) const
Return the uniqued reference to the type for a pointer to the specified type.
bool canAssignObjCInterfaces(const ObjCObjectPointerType *LHSOPT, const ObjCObjectPointerType *RHSOPT)
canAssignObjCInterfaces - Return true if the two interface types are compatible for assignment from R...
QualType getLValueReferenceType(QualType T, bool SpelledAsLValue=true) const
Return the uniqued reference to the type for an lvalue reference to the specified type.
QualType getConstantArrayType(QualType EltTy, const llvm::APInt &ArySize, const Expr *SizeExpr, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return the unique reference to the type for a constant array of the specified element type.
const LangOptions & getLangOpts() const
CanQualType getLogicalOperationType() const
The result type of logical operations, '<', '>', '!=', etc.
bool areLaxCompatibleRVVTypes(QualType FirstType, QualType SecondType)
Return true if the given vector types are lax-compatible RISC-V vector types as defined by -flax-vect...
CallingConv getDefaultCallingConvention(bool IsVariadic, bool IsCXXMethod) const
Retrieves the default calling convention for the current context.
void forEachMultiversionedFunctionVersion(const FunctionDecl *FD, llvm::function_ref< void(FunctionDecl *)> Pred) const
Visits all versions of a multiversioned function with the passed predicate.
QualType getPointerDiffType() const
Return the unique type for "ptrdiff_t" (C99 7.17) defined in <stddef.h>.
int getFloatingTypeOrder(QualType LHS, QualType RHS) const
Compare the rank of the two specified floating point types, ignoring the domain of the type (i....
const TargetInfo * getAuxTargetInfo() const
CanQualType UnsignedLongTy
QualType getRestrictType(QualType T) const
Return the uniqued reference to the type for a restrict qualified type.
bool areCompatibleOverflowBehaviorTypes(QualType LHS, QualType RHS)
Return true if two OverflowBehaviorTypes are compatible for assignment.
QualType getQualifiedType(SplitQualType split) const
Un-split a SplitQualType.
QualType getObjCObjectPointerType(QualType OIT) const
Return a ObjCObjectPointerType type for the given ObjCObjectType.
QualType getObjCIdType() const
Represents the Objective-CC id type.
const ArrayType * getAsArrayType(QualType T) const
Type Query functions.
bool isSameTemplateParameterList(const TemplateParameterList *X, const TemplateParameterList *Y) const
Determine whether two template parameter lists are similar enough that they may be used in declaratio...
uint64_t getTypeSize(QualType T) const
Return the size of the specified (complete) type T, in bits.
CanQualType UnsignedInt128Ty
CanQualType UnsignedCharTy
CanQualType UnsignedIntTy
QualType getVolatileType(QualType T) const
Return the uniqued reference to the type for a volatile qualified type.
CanQualType UnsignedLongLongTy
QualType getArrayDecayedType(QualType T) const
Return the properly qualified result of decaying the specified array type to a pointer.
CanQualType UnsignedShortTy
QualType getMemberPointerType(QualType T, NestedNameSpecifier Qualifier, const CXXRecordDecl *Cls) const
Return the uniqued reference to the type for a member pointer to the specified type in the specified ...
static bool hasSameType(QualType T1, QualType T2)
Determine whether the given types T1 and T2 are equivalent.
QualType getSizeType() const
Return the unique type for "size_t" (C99 7.17), defined in <stddef.h>.
QualType getCVRQualifiedType(QualType T, unsigned CVR) const
Return a type with additional const, volatile, or restrict qualifiers.
bool areCompatibleVectorTypes(QualType FirstVec, QualType SecondVec)
Return true if the given vector types are of the same unqualified type or if they are equivalent to t...
const TargetInfo & getTargetInfo() const
bool typesAreCompatible(QualType T1, QualType T2, bool CompareUnqualified=false)
Compatibility predicates used to check assignment expressions.
QualType getAddrSpaceQualType(QualType T, LangAS AddressSpace) const
Return the uniqued reference to the type for an address space qualified type with the specified type ...
CanQualType getCanonicalTagType(const TagDecl *TD) const
static bool hasSameUnqualifiedType(QualType T1, QualType T2)
Determine whether the given types are equivalent after cvr-qualifiers have been removed.
QualType getUnqualifiedArrayType(QualType T, Qualifiers &Quals) const
Return this type as a completely-unqualified array type, capturing the qualifiers in Quals.
Represents a constant array type that does not decay to a pointer when used as a function parameter.
QualType getConstantArrayType(const ASTContext &Ctx) const
Represents an array type, per C99 6.7.5.2 - Array Declarators.
QualType getElementType() const
QualType getValueType() const
Gets the type contained by this atomic type, i.e.
Attr - This represents one attribute.
A builtin binary operation expression such as "x + y" or "x <= y".
static OverloadedOperatorKind getOverloadedOperator(Opcode Opc)
Retrieve the overloaded operator kind that corresponds to the given binary opcode.
StringRef getOpcodeStr() const
static StringRef getOpcodeStr(Opcode Op)
getOpcodeStr - Turn an Opcode enum value into the punctuation char it corresponds to,...
static BinaryOperator * Create(const ASTContext &C, Expr *lhs, Expr *rhs, Opcode opc, QualType ResTy, ExprValueKind VK, ExprObjectKind OK, SourceLocation opLoc, FPOptionsOverride FPFeatures)
static bool isCompoundAssignmentOp(Opcode Opc)
This class is used for builtin types like 'int'.
BasePaths - Represents the set of paths from a derived class to one of its (direct or indirect) bases...
const RecordType * getDetectedVirtual() const
The virtual base discovered on the path (if we are merely detecting virtuals).
bool isAmbiguous(CanQualType BaseType) const
Determine whether the path from the most-derived type to the given base type is ambiguous (i....
Represents a C++ constructor within a class.
bool isCopyOrMoveConstructor(unsigned &TypeQuals) const
Determine whether this is a copy or move constructor.
bool isConvertingConstructor(bool AllowExplicit) const
Whether this constructor is a converting constructor (C++ [class.conv.ctor]), which can be used for u...
Represents a C++ conversion function within a class.
bool isExplicit() const
Return true if the declaration is already resolved to be explicit.
QualType getConversionType() const
Returns the type that this conversion function is converting to.
Represents a call to a member function that may be written either with member call syntax (e....
static CXXMemberCallExpr * Create(const ASTContext &Ctx, Expr *Fn, ArrayRef< Expr * > Args, QualType Ty, ExprValueKind VK, SourceLocation RP, FPOptionsOverride FPFeatures, unsigned MinNumArgs=0)
Represents a static or instance method of a struct/union/class.
bool isExplicitObjectMemberFunction() const
[C++2b][dcl.fct]/p7 An explicit object member function is a non-static member function with an explic...
bool isImplicitObjectMemberFunction() const
[C++2b][dcl.fct]/p7 An implicit object member function is a non-static member function without an exp...
QualType getFunctionObjectParameterReferenceType() const
Return the type of the object pointed by this.
const CXXRecordDecl * getParent() const
Return the parent of this method declaration, which is the class in which this method is defined.
static CXXOperatorCallExpr * Create(const ASTContext &Ctx, OverloadedOperatorKind OpKind, Expr *Fn, ArrayRef< Expr * > Args, QualType Ty, ExprValueKind VK, SourceLocation OperatorLoc, FPOptionsOverride FPFeatures, ADLCallKind UsesADL=NotADL, bool IsReversed=false)
Represents a C++ struct/union/class.
bool isLambda() const
Determine whether this class describes a lambda function object.
llvm::iterator_range< conversion_iterator > getVisibleConversionFunctions() const
Get all conversion functions visible in current class, including conversion function templates.
bool isHLSLBuiltinRecord() const
Returns true if the class is a built-in HLSL record.
bool hasDefinition() const
CXXMethodDecl * getLambdaCallOperator() const
Retrieve the lambda call operator of the closure type if this is a closure type.
A rewritten comparison expression that was originally written using operator syntax.
Represents a C++ nested-name-specifier or a global scope specifier.
bool isEmpty() const
No scope specifier.
void Adopt(NestedNameSpecifierLoc Other)
Adopt an existing nested-name-specifier (with source-range information).
CallExpr - Represents a function call (C99 6.5.2.2, C++ [expr.call]).
static CallExpr * Create(const ASTContext &Ctx, Expr *Fn, ArrayRef< Expr * > Args, QualType Ty, ExprValueKind VK, SourceLocation RParenLoc, FPOptionsOverride FPFeatures, unsigned MinNumArgs=0, ADLCallKind UsesADL=NotADL)
Create a call expression.
FunctionDecl * getDirectCallee()
If the callee is a FunctionDecl, return it. Otherwise return null.
void setUsesMemberSyntax(bool V=true)
void markDependentForPostponedNameLookup()
Used by Sema to implement MSVC-compatible delayed name lookup.
Represents a canonical, potentially-qualified type.
bool isAtLeastAsQualifiedAs(CanQual< T > Other, const ASTContext &Ctx) const
Determines whether this canonical type is at least as qualified as the Other canonical type.
static CanQual< Type > CreateUnsafe(QualType Other)
CanProxy< U > castAs() const
CanQual< T > getUnqualifiedType() const
Retrieve the unqualified form of this type.
Qualifiers getQualifiers() const
Retrieve all qualifiers.
CanProxy< U > getAs() const
Retrieve a canonical type pointer with a different static type, upcasting or downcasting as needed.
bool isVolatileQualified() const
const T * getTypePtr() const
Retrieve the underlying type pointer, which refers to a canonical type.
bool isPartial() const
True iff the comparison is not totally ordered.
bool isStrong() const
True iff the comparison is "strong".
Complex values, per C99 6.2.5p11.
QualType getElementType() const
static CompoundAssignOperator * Create(const ASTContext &C, Expr *lhs, Expr *rhs, Opcode opc, QualType ResTy, ExprValueKind VK, ExprObjectKind OK, SourceLocation opLoc, FPOptionsOverride FPFeatures, QualType CompLHSType=QualType(), QualType CompResultType=QualType())
Represents the canonical version of C arrays with a specified constant size.
static ConstantExpr * Create(const ASTContext &Context, Expr *E, const APValue &Result)
Represents a concrete matrix type with constant number of rows and columns.
unsigned getNumColumns() const
Returns the number of columns in the matrix.
unsigned getNumRows() const
Returns the number of rows in the matrix.
The result of a constraint satisfaction check, containing the necessary information to diagnose an un...
Base class for callback objects used by Sema::CorrectTypo to check the validity of a potential typo c...
A POD class for pairing a NamedDecl* with an access specifier.
static DeclAccessPair make(NamedDecl *D, AccessSpecifier AS)
NamedDecl * getDecl() const
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
DeclContext * getParent()
getParent - Returns the containing DeclContext.
lookup_result lookup(DeclarationName Name) const
lookup - Find the declarations (if any) with the given Name in this context.
DeclContext * getEnclosingNamespaceContext()
Retrieve the nearest enclosing namespace context.
bool Encloses(const DeclContext *DC) const
Determine whether this declaration context semantically encloses the declaration context DC.
A reference to a declared variable, function, enum, etc.
void setHadMultipleCandidates(bool V=true)
Sets the flag telling whether this expression refers to a function that was resolved from an overload...
Decl - This represents one declaration (or definition), e.g.
TemplateDecl * getDescribedTemplate() const
If this is a declaration that describes some template, this method returns that template declaration.
ASTContext & getASTContext() const LLVM_READONLY
bool isImplicit() const
isImplicit - Indicates whether the declaration was implicitly generated by the implementation.
const FunctionType * getFunctionType(bool BlocksToo=true) const
Looks through the Decl's underlying type to extract a FunctionType when possible.
FunctionDecl * getAsFunction() LLVM_READONLY
Returns the function itself, or the templated function if this is a function template.
bool isInvalidDecl() const
llvm::iterator_range< specific_attr_iterator< T > > specific_attrs() const
SourceLocation getLocation() const
DeclContext * getDeclContext()
AccessSpecifier getAccess() const
specific_attr_iterator< T > specific_attr_end() const
specific_attr_iterator< T > specific_attr_begin() const
DeclContext * getLexicalDeclContext()
getLexicalDeclContext - The declaration context where this Decl was lexically declared (LexicalDC).
DeclarationNameLoc - Additional source/type location info for a declaration name.
The name of a declaration.
TemplateDecl * getCXXDeductionGuideTemplate() const
If this name is the name of a C++ deduction guide, return the template associated with that name.
OverloadedOperatorKind getCXXOverloadedOperator() const
If this name is the name of an overloadable operator in C++ (e.g., operator+), retrieve the kind of o...
SourceLocation getBeginLoc() const LLVM_READONLY
const AssociatedConstraint & getTrailingRequiresClause() const
Get the constraint-expression introduced by the trailing requires-clause in the function/member decla...
void overloadCandidatesShown(unsigned N)
Call this after showing N overload candidates.
unsigned getNumOverloadCandidatesToShow() const
When a call or operator fails, print out up to this many candidate overloads as suggestions.
OverloadsShown getShowOverloads() const
const IntrusiveRefCntPtr< DiagnosticIDs > & getDiagnosticIDs() const
RAII object that enters a new expression evaluation context.
bool isScoped() const
Returns true if this is a C++11 scoped enumeration.
EnumDecl * getDefinitionOrSelf() const
Store information needed for an explicit specifier.
bool isExplicit() const
Determine whether this specifier is known to correspond to an explicit declaration.
ExplicitSpecKind getKind() const
const Expr * getExpr() const
static ExplicitSpecifier getFromDecl(const FunctionDecl *Function)
static ExprWithCleanups * Create(const ASTContext &C, EmptyShell empty, unsigned numObjects)
The return type of classify().
static Classification makeSimpleLValue()
Create a simple, modifiable lvalue.
This represents one expression.
bool isIntegerConstantExpr(const ASTContext &Ctx) const
Expr * IgnoreParenCasts() LLVM_READONLY
Skip past any parentheses and casts which might surround this expression until reaching a fixed point...
bool isValueDependent() const
Determines whether the value of this expression depends on.
ExprValueKind getValueKind() const
getValueKind - The value kind that this expression produces.
bool isTypeDependent() const
Determines whether the type of this expression depends on.
llvm::APSInt EvaluateKnownConstInt(const ASTContext &Ctx) const
EvaluateKnownConstInt - Call EvaluateAsRValue and return the folded integer.
bool containsErrors() const
Whether this expression contains subexpressions which had errors.
Expr * IgnoreParens() LLVM_READONLY
Skip past any parentheses which might surround this expression until reaching a fixed point.
static bool hasAnyTypeDependentArguments(ArrayRef< Expr * > Exprs)
hasAnyTypeDependentArguments - Determines if any of the expressions in Exprs is type-dependent.
FieldDecl * getSourceBitField()
If this expression refers to a bit-field, retrieve the declaration of that bit-field.
@ NPC_ValueDependentIsNull
Specifies that a value-dependent expression of integral or dependent type should be considered a null...
@ NPC_ValueDependentIsNotNull
Specifies that a value-dependent expression should be considered to never be a null pointer constant.
ExprObjectKind getObjectKind() const
getObjectKind - The object kind that this expression produces.
bool EvaluateAsConstantExpr(EvalResult &Result, const ASTContext &Ctx, ConstantExprKind Kind=ConstantExprKind::Normal) const
Evaluate an expression that is required to be a constant expression.
@ NPCK_ZeroExpression
Expression is a Null pointer constant built from a zero integer expression that is not a simple,...
NullPointerConstantKind isNullPointerConstant(ASTContext &Ctx, NullPointerConstantValueDependence NPC) const
isNullPointerConstant - C99 6.3.2.3p3 - Test if this reduces down to a Null pointer constant.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
bool refersToBitField() const
Returns true if this expression is a gl-value that potentially refers to a bit-field.
Classification Classify(ASTContext &Ctx) const
Classify - Classify this expression according to the C++11 expression taxonomy.
bool hasPlaceholderType() const
Returns whether this expression has a placeholder type.
static ExprValueKind getValueKindForType(QualType T)
getValueKindForType - Given a formal return or parameter type, give its value kind.
ExtVectorType - Extended vector type.
Represents difference between two FPOptions values.
Represents a member of a struct/union/class.
Annotates a diagnostic with some code that should be inserted, removed, or replaced to fix the proble...
static FixItHint CreateReplacement(CharSourceRange RemoveRange, StringRef Code)
Create a code modification hint that replaces the given source range with the given code string.
static FixItHint CreateInsertion(SourceLocation InsertionLoc, StringRef Code, bool BeforePreviousInsertions=false)
Create a code modification hint that inserts the given code string at a specific location.
Represents a function declaration or definition.
bool isMultiVersion() const
True if this function is considered a multiversioned function.
const ParmVarDecl * getParamDecl(unsigned i) const
FunctionTemplateDecl * getDescribedFunctionTemplate() const
Retrieves the function template that is described by this function declaration.
unsigned getBuiltinID(bool ConsiderWrapperFunctions=false) const
Returns a value indicating whether this function corresponds to a builtin function.
param_iterator param_end()
bool isMemberLikeConstrainedFriend() const
Determine whether a function is a friend function that cannot be redeclared outside of its class,...
bool hasCXXExplicitFunctionObjectParameter() const
QualType getReturnType() const
ArrayRef< ParmVarDecl * > parameters() const
FunctionDecl * getTemplateInstantiationPattern(bool ForDefinition=true) const
Retrieve the function declaration from which this function could be instantiated, if it is an instant...
FunctionTemplateDecl * getPrimaryTemplate() const
Retrieve the primary template that this function template specialization either specializes or was in...
FunctionDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
param_iterator param_begin()
bool isVariadic() const
Whether this function is variadic.
const TemplateArgumentList * getTemplateSpecializationArgs() const
Retrieve the template arguments used to produce this function template specialization from the primar...
bool isTemplateInstantiation() const
Determines if the given function was instantiated from a function template.
unsigned getNumNonObjectParams() const
bool isConstexpr() const
Whether this is a (C++11) constexpr function or constexpr constructor.
OverloadedOperatorKind getOverloadedOperator() const
getOverloadedOperator - Which C++ overloaded operator this function represents, if any.
bool isTargetMultiVersion() const
True if this function is a multiversioned dispatch function as a part of the target functionality.
QualType getDeclaredReturnType() const
Get the declared return type, which may differ from the actual return type if the return type is dedu...
bool isTargetMultiVersionDefault() const
True if this function is the default version of a multiversioned dispatch function as a part of the t...
unsigned getNumParams() const
Return the number of parameters this function must have based on its FunctionType.
bool willHaveBody() const
True if this function will eventually have a body, once it's fully parsed.
Represents a prototype with parameter type info, e.g.
ExtParameterInfo getExtParameterInfo(unsigned I) const
unsigned getNumParams() const
Qualifiers getMethodQuals() const
QualType getParamType(unsigned i) const
bool isVariadic() const
Whether this function prototype is variadic.
ArrayRef< QualType > param_types() const
Declaration of a template function.
FunctionDecl * getTemplatedDecl() const
Get the underlying function declaration of the template.
A class which abstracts out some details necessary for making a call.
ExtInfo withNoReturn(bool noReturn) const
ParameterABI getABI() const
Return the ABI treatment of this parameter.
FunctionType - C99 6.7.5.3 - Function Declarators.
ExtInfo getExtInfo() const
CallingConv getCallConv() const
QualType getReturnType() const
QualType getCallResultType(const ASTContext &Context) const
Determine the type of an expression that calls a function of this type.
static GenericSelectionExpr * Create(const ASTContext &Context, SourceLocation GenericLoc, Expr *ControllingExpr, ArrayRef< TypeSourceInfo * > AssocTypes, ArrayRef< Expr * > AssocExprs, SourceLocation DefaultLoc, SourceLocation RParenLoc, bool ContainsUnexpandedParameterPack, unsigned ResultIndex)
Create a non-result-dependent generic selection expression accepting an expression predicate.
One of these records is kept for each identifier that is lexed.
ImplicitCastExpr - Allows us to explicitly represent implicit type conversions, which have no direct ...
static ImplicitCastExpr * Create(const ASTContext &Context, QualType T, CastKind Kind, Expr *Operand, const CXXCastPath *BasePath, ExprValueKind Cat, FPOptionsOverride FPO)
ImplicitConversionSequence - Represents an implicit conversion sequence, which may be a standard conv...
void dump() const
dump - Print this implicit conversion sequence to standard error.
bool isUserDefined() const
@ StaticObjectArgumentConversion
StandardConversionSequence Standard
When ConversionKind == StandardConversion, provides the details of the standard conversion sequence.
void setBad(BadConversionSequence::FailureKind Failure, Expr *FromExpr, QualType ToType)
Sets this sequence as a bad conversion for an explicit argument.
UserDefinedConversionSequence UserDefined
When ConversionKind == UserDefinedConversion, provides the details of the user-defined conversion seq...
static ImplicitConversionSequence getNullptrToBool(QualType SourceType, QualType DestType, bool NeedLValToRVal)
Form an "implicit" conversion sequence from nullptr_t to bool, for a direct-initialization of a bool ...
AmbiguousConversionSequence Ambiguous
When ConversionKind == AmbiguousConversion, provides the details of the ambiguous conversion.
bool hasInitializerListContainerType() const
unsigned getKindRank() const
Return a ranking of the implicit conversion sequence kind, where smaller ranks represent better conve...
bool isInitializerListOfIncompleteArray() const
BadConversionSequence Bad
When ConversionKind == BadConversion, provides the details of the bad conversion.
QualType getInitializerListContainerType() const
void DiagnoseAmbiguousConversion(Sema &S, SourceLocation CaretLoc, const PartialDiagnostic &PDiag) const
Diagnoses an ambiguous conversion.
Describes an C or C++ initializer list.
bool hasDesignatedInit() const
Determine whether this initializer list contains a designated initializer.
unsigned getNumInits() const
SourceLocation getBeginLoc() const LLVM_READONLY
const Expr * getInit(unsigned Init) const
SourceLocation getEndLoc() const LLVM_READONLY
Describes an entity that is being initialized.
static InitializedEntity InitializeParameter(ASTContext &Context, ParmVarDecl *Parm)
Create the initialization entity for a parameter.
static InitializedEntity InitializeTemplateParameter(QualType T, NamedDecl *Param)
Create the initialization entity for a template parameter.
static IntegerLiteral * Create(const ASTContext &C, const llvm::APInt &V, QualType type, SourceLocation l)
Returns a new integer literal with value 'V' and type 'type'.
An lvalue reference type, per C++11 [dcl.ref].
bool isCompatibleWithMSVC() const
Represents the results of name lookup.
void addAllDecls(const LookupResult &Other)
Add all the declarations from another set of lookup results.
DeclClass * getAsSingle() const
bool empty() const
Return true if no decls were found.
Sema::LookupNameKind getLookupKind() const
Gets the kind of lookup to perform.
void suppressAccessDiagnostics()
Suppress the diagnostics that would normally fire because of this lookup due to access control violat...
UnresolvedSetImpl::iterator iterator
QualType getElementType() const
Returns type of the elements being stored in the matrix.
MemberExpr - [C99 6.5.2.3] Structure and Union Members.
SourceLocation getMemberLoc() const
getMemberLoc - Return the location of the "member", in X->F, it is the location of 'F'.
NestedNameSpecifier getQualifier() const
If the member name was qualified, retrieves the nested-name-specifier that precedes the member name.
ValueDecl * getMemberDecl() const
Retrieve the member declaration to which this expression refers.
bool hasQualifier() const
Determines whether this member expression actually had a C++ nested-name-specifier prior to the name ...
bool performsVirtualDispatch(const LangOptions &LO) const
Returns true if virtual dispatch is performed.
SourceLocation getBeginLoc() const LLVM_READONLY
SourceLocation getExprLoc() const LLVM_READONLY
DeclAccessPair getFoundDecl() const
Retrieves the declaration found by lookup.
A pointer to member type per C++ 8.3.3 - Pointers to members.
NestedNameSpecifier getQualifier() const
CXXRecordDecl * getMostRecentCXXRecordDecl() const
Note: this can trigger extra deserialization when external AST sources are used.
QualType getPointeeType() const
Describes a module or submodule.
std::string getFullModuleName(bool AllowStringLiterals=false) const
Retrieve the full name of this module, including the path from its top-level module.
This represents a decl that may have a name.
NamedDecl * getUnderlyingDecl()
Looks through UsingDecls and ObjCCompatibleAliasDecls for the underlying named decl.
StringRef getName() const
Get the name of identifier for this declaration as a StringRef.
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
std::string getQualifiedNameAsString() const
Linkage getFormalLinkage() const
Get the linkage from a semantic point of view.
Represent a C++ namespace.
A C++ nested-name-specifier augmented with source location information.
SourceRange getSourceRange() const LLVM_READONLY
Retrieve the source range covering the entirety of this nested-name-specifier.
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
NonTypeTemplateParmDecl - Declares a non-type template parameter, e.g., "Size" in.
Represents an ObjC class declaration.
Represents typeof(type), a C23 feature and GCC extension, or `typeof_unqual(type),...
ObjCMethodDecl - Represents an instance or class method declaration.
Represents a pointer to an Objective C object.
bool isSpecialized() const
Whether this type is specialized, meaning that it has type arguments.
bool isObjCIdType() const
True if this is equivalent to the 'id' type, i.e.
QualType getPointeeType() const
Gets the type pointed to by this ObjC pointer.
ObjCInterfaceDecl * getInterfaceDecl() const
If this pointer points to an Objective @interface type, gets the declaration for that interface.
const ObjCInterfaceType * getInterfaceType() const
If this pointer points to an Objective C @interface type, gets the type for that interface.
bool isObjCClassType() const
True if this is equivalent to the 'Class' type, i.e.
OpaqueValueExpr - An expression referring to an opaque object of a fixed type and value class.
OverloadCandidateSet - A set of overload candidates, used in C++ overload resolution (C++ 13....
void clear(CandidateSetKind CSK)
Clear out all of the candidates.
void AddDeferredTemplateCandidate(FunctionTemplateDecl *FunctionTemplate, DeclAccessPair FoundDecl, ArrayRef< Expr * > Args, bool SuppressUserConversions, bool PartialOverloading, bool AllowExplicit, CallExpr::ADLCallKind IsADLCandidate, OverloadCandidateParamOrder PO, bool AggregateCandidateDeduction)
bool isNewCandidate(Decl *F, OverloadCandidateParamOrder PO=OverloadCandidateParamOrder::Normal)
Determine when this overload candidate will be new to the overload set.
bool shouldDeferTemplateArgumentDeduction(const Sema &S) const
void AddDeferredConversionTemplateCandidate(FunctionTemplateDecl *FunctionTemplate, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, Expr *From, QualType ToType, bool AllowObjCConversionOnExplicit, bool AllowExplicit, bool AllowResultConversion)
void AddDeferredMethodTemplateCandidate(FunctionTemplateDecl *MethodTmpl, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, QualType ObjectType, Expr::Classification ObjectClassification, ArrayRef< Expr * > Args, bool SuppressUserConversions, bool PartialOverloading, OverloadCandidateParamOrder PO)
void DisableResolutionByPerfectCandidate()
ConversionSequenceList allocateConversionSequences(unsigned NumConversions)
Allocate storage for conversion sequences for NumConversions conversions.
llvm::MutableArrayRef< Expr * > getPersistentArgsArray(unsigned N)
Provide storage for any Expr* arg that must be preserved until deferred template candidates are deduc...
OperatorRewriteInfo getRewriteInfo() const
@ CSK_AddressOfOverloadSet
C++ [over.match.call.general] Resolve a call through the address of an overload set.
@ CSK_InitByConstructor
C++ [over.match.ctor], [over.match.list] Initialization of an object of class type by constructor,...
@ CSK_InitByUserDefinedConversion
C++ [over.match.copy]: Copy-initialization of an object of class type by user-defined conversion.
@ CSK_Normal
Normal lookup.
@ CSK_Operator
C++ [over.match.oper]: Lookup of operator function candidates in a call using operator syntax.
@ CSK_CodeCompletion
When doing overload resolution during code completion, we want to show all viable candidates,...
SmallVectorImpl< OverloadCandidate >::iterator iterator
void NoteCandidates(PartialDiagnosticAt PA, Sema &S, OverloadCandidateDisplayKind OCD, ArrayRef< Expr * > Args, StringRef Opc="", SourceLocation Loc=SourceLocation(), llvm::function_ref< bool(OverloadCandidate &)> Filter=[](OverloadCandidate &) { return true;})
When overload resolution fails, prints diagnostic messages containing the candidates in the candidate...
bool shouldDeferDiags(Sema &S, ArrayRef< Expr * > Args, SourceLocation OpLoc)
Whether diagnostics should be deferred.
OverloadingResult BestViableFunction(Sema &S, SourceLocation Loc, OverloadCandidateSet::iterator &Best)
Find the best viable function on this overload set, if it exists.
void exclude(Decl *F)
Exclude a function from being considered by overload resolution.
SourceLocation getLocation() const
OverloadCandidate & addCandidate(unsigned NumConversions=0, ConversionSequenceList Conversions={})
Add a new candidate with NumConversions conversion sequence slots to the overload set.
void InjectNonDeducedTemplateCandidates(Sema &S)
CandidateSetKind getKind() const
size_t nonDeferredCandidatesCount() const
SmallVector< OverloadCandidate *, 32 > CompleteCandidates(Sema &S, OverloadCandidateDisplayKind OCD, ArrayRef< Expr * > Args, SourceLocation OpLoc=SourceLocation(), llvm::function_ref< bool(OverloadCandidate &)> Filter=[](OverloadCandidate &) { return true;})
A reference to an overloaded function set, either an UnresolvedLookupExpr or an UnresolvedMemberExpr.
bool hasExplicitTemplateArgs() const
Determines whether this expression had explicit template arguments.
static FindResult find(Expr *E)
Finds the overloaded expression in the given expression E of OverloadTy.
NestedNameSpecifier getQualifier() const
Fetches the nested-name qualifier, if one was given.
SourceLocation getNameLoc() const
Gets the location of the name.
UnresolvedSetImpl::iterator decls_iterator
decls_iterator decls_begin() const
unsigned getNumDecls() const
Gets the number of declarations in the unresolved set.
SourceLocation getTemplateKeywordLoc() const
Retrieve the location of the template keyword preceding this name, if any.
NestedNameSpecifierLoc getQualifierLoc() const
Fetches the nested-name qualifier with source-location information, if one was given.
void copyTemplateArgumentsInto(TemplateArgumentListInfo &List) const
Copies the template arguments into the given structure.
decls_iterator decls_end() const
DeclarationName getName() const
Gets the name looked up.
A single parameter index whose accessors require each use to make explicit the parameter index encodi...
ParenExpr - This represents a parenthesized expression, e.g.
Represents a parameter to a function.
bool hasDefaultArg() const
Determines whether this parameter has a default argument, either parsed or not.
bool isEquivalent(PointerAuthQualifier Other) const
std::string getAsString() const
PointerType - C99 6.7.5.1 - Pointer Declarators.
QualType getPointeeType() const
static PseudoObjectExpr * Create(const ASTContext &Context, Expr *syntactic, ArrayRef< Expr * > semantic, unsigned resultIndex)
A (possibly-)qualified type.
bool isVolatileQualified() const
Determine whether this type is volatile-qualified.
bool isRestrictQualified() const
Determine whether this type is restrict-qualified.
bool hasQualifiers() const
Determine whether this type has any qualifiers.
QualType getNonLValueExprType(const ASTContext &Context) const
Determine the type of a (typically non-lvalue) expression with the specified result type.
QualType getLocalUnqualifiedType() const
Return this type with all of the instance-specific qualifiers removed, but without removing any quali...
bool isNull() const
Return true if this QualType doesn't point to a type yet.
const Type * getTypePtr() const
Retrieves a pointer to the underlying (unqualified) type.
LangAS getAddressSpace() const
Return the address space of this type.
Qualifiers getQualifiers() const
Retrieve the set of qualifiers applied to this type.
void getAsStringInternal(std::string &Str, const PrintingPolicy &Policy) const
QualType getNonReferenceType() const
If Type is a reference type (e.g., const int&), returns the type that the reference refers to ("const...
QualType getCanonicalType() const
QualType getUnqualifiedType() const
Retrieve the unqualified variant of the given type, removing as little sugar as possible.
unsigned getLocalCVRQualifiers() const
Retrieve the set of CVR (const-volatile-restrict) qualifiers local to this particular QualType instan...
bool isMoreQualifiedThan(QualType Other, const ASTContext &Ctx) const
Determine whether this type is more qualified than the other given type, requiring exact equality for...
bool isConstQualified() const
Determine whether this type is const-qualified.
bool hasAddressSpace() const
Check if this type has any address space qualifier.
unsigned getCVRQualifiers() const
Retrieve the set of CVR (const-volatile-restrict) qualifiers applied to this type.
static std::string getAsString(SplitQualType split, const PrintingPolicy &Policy)
bool isAtLeastAsQualifiedAs(QualType Other, const ASTContext &Ctx) const
Determine whether this type is at least as qualified as the other given type, requiring exact equalit...
Qualifiers getLocalQualifiers() const
Retrieve the set of qualifiers local to this particular QualType instance, not including any qualifie...
A qualifier set is used to build a set of qualifiers.
const Type * strip(QualType type)
Collect any qualifiers on the given type and return an unqualified type.
QualType apply(const ASTContext &Context, QualType QT) const
Apply the collected qualifiers to the given type.
QualifiersAndAtomic withVolatile()
QualifiersAndAtomic withAtomic()
The collection of all-type qualifiers we support.
unsigned getCVRQualifiers() const
bool hasOnlyConst() const
@ OCL_ExplicitNone
This object can be modified without requiring retains or releases.
void removeObjCLifetime()
bool compatiblyIncludes(Qualifiers other, const ASTContext &Ctx) const
Determines if these qualifiers compatibly include another set.
static bool isAddressSpaceSupersetOf(LangAS A, LangAS B, const ASTContext &Ctx)
Returns true if address space A is equal to or a superset of B.
void removeAddressSpace()
void setAddressSpace(LangAS space)
PointerAuthQualifier getPointerAuth() const
bool hasObjCGCAttr() const
ObjCLifetime getObjCLifetime() const
std::string getAsString() const
LangAS getAddressSpace() const
bool compatiblyIncludesObjCLifetime(Qualifiers other) const
Determines if these qualifiers compatibly include another set of qualifiers from the narrow perspecti...
An rvalue reference type, per C++11 [dcl.ref].
Represents a struct/union/class.
field_range fields() const
RecordDecl * getDefinitionOrSelf() const
Base for LValueReferenceType and RValueReferenceType.
QualType getPointeeType() const
Scope - A scope is a transient data structure that is used while parsing the program.
Smart pointer class that efficiently represents Objective-C method names.
unsigned getNumArgs() const
bool areCompatibleSveTypes(QualType FirstType, QualType SecondType)
Return true if the given types are an SVE builtin and a VectorType that is a fixed-length representat...
bool areLaxCompatibleSveTypes(QualType FirstType, QualType SecondType)
Return true if the given vector types are lax-compatible SVE vector types, false otherwise.
PartialDiagnostic PDiag(unsigned DiagID=0)
Build a partial diagnostic.
SemaDiagnosticBuilder Diag(SourceLocation Loc, unsigned DiagID)
Emit a diagnostic.
bool IsAllowedCall(const FunctionDecl *Caller, const FunctionDecl *Callee)
Determines whether Caller may invoke Callee, based on their CUDA host/device attributes.
CUDAFunctionTarget IdentifyTarget(const FunctionDecl *D, bool IgnoreImplicitHDAttr=false)
Determines whether the given function is a CUDA device/host/kernel/etc.
bool inferTargetForImplicitSpecialMember(CXXRecordDecl *ClassDecl, CXXSpecialMemberKind CSM, CXXMethodDecl *MemberDecl, bool ConstRHS, bool Diagnose)
Given a implicit special member, infer its CUDA target from the calls it needs to make to underlying ...
static bool isImplicitHostDeviceFunction(const FunctionDecl *D)
void EraseUnwantedMatches(const FunctionDecl *Caller, llvm::SmallVectorImpl< std::pair< DeclAccessPair, FunctionDecl * > > &Matches)
Finds a function in Matches with highest calling priority from Caller context and erases all function...
CUDAFunctionPreference IdentifyPreference(const FunctionDecl *Caller, const FunctionDecl *Callee)
Identifies relative preference of a given Caller/Callee combination, based on their host/device attri...
bool isObjCWritebackConversion(QualType FromType, QualType ToType, QualType &ConvertedType)
Determine whether this is an Objective-C writeback conversion, used for parameter passing when perfor...
Expr * stripARCUnbridgedCast(Expr *e)
stripARCUnbridgedCast - Given an expression of ARCUnbridgedCast type, remove the placeholder cast.
Abstract base class used to perform a contextual implicit conversion from an expression to any type p...
virtual SemaDiagnosticBuilder noteAmbiguous(Sema &S, CXXConversionDecl *Conv, QualType ConvTy)=0
Emits a note for one of the candidate conversions.
virtual SemaDiagnosticBuilder diagnoseNoMatch(Sema &S, SourceLocation Loc, QualType T)=0
Emits a diagnostic complaining that the expression does not have integral or enumeration type.
virtual SemaDiagnosticBuilder noteExplicitConv(Sema &S, CXXConversionDecl *Conv, QualType ConvTy)=0
Emits a note for the explicit conversion function.
virtual SemaDiagnosticBuilder diagnoseExplicitConv(Sema &S, SourceLocation Loc, QualType T, QualType ConvTy)=0
Emits a diagnostic when the only matching conversion function is explicit.
virtual SemaDiagnosticBuilder diagnoseConversion(Sema &S, SourceLocation Loc, QualType T, QualType ConvTy)=0
Emits a diagnostic when we picked a conversion function (for cases when we are not allowed to pick a ...
virtual SemaDiagnosticBuilder diagnoseAmbiguous(Sema &S, SourceLocation Loc, QualType T)=0
Emits a diagnostic when there are multiple possible conversion functions.
virtual bool match(QualType T)=0
Determine whether the specified type is a valid destination type for this conversion.
virtual SemaDiagnosticBuilder diagnoseIncomplete(Sema &S, SourceLocation Loc, QualType T)=0
Emits a diagnostic when the expression has incomplete class type.
For a defaulted function, the kind of defaulted function that it is.
bool isSpecialMember() const
bool isComparison() const
CXXSpecialMemberKind asSpecialMember() const
RAII class to control scope of DeferDiags.
A class which encapsulates the logic for delaying diagnostics during parsing and other processing.
DelayedDiagnosticsState pushUndelayed()
Enter a new scope where access and deprecation diagnostics are not delayed.
bool match(QualType T) override
Match an integral or (possibly scoped) enumeration type.
RAII class used to determine whether SFINAE has trapped any errors that occur during template argumen...
bool hasErrorOccurred() const
Determine whether any SFINAE errors have been trapped.
Sema - This implements semantic analysis and AST building for C.
bool TryFunctionConversion(QualType FromType, QualType ToType, QualType &ResultTy) const
Same as IsFunctionConversion, but if this would return true, it sets ResultTy to ToType.
QualType getCurrentThisType()
Try to retrieve the type of the 'this' pointer.
ExprResult BuildBlockForLambdaConversion(SourceLocation CurrentLocation, SourceLocation ConvLocation, CXXConversionDecl *Conv, Expr *Src)
bool diagnoseArgDependentDiagnoseIfAttrs(const FunctionDecl *Function, const Expr *ThisArg, ArrayRef< const Expr * > Args, SourceLocation Loc)
Emit diagnostics for the diagnose_if attributes on Function, ignoring any non-ArgDependent DiagnoseIf...
ExprResult PerformContextuallyConvertToObjCPointer(Expr *From)
PerformContextuallyConvertToObjCPointer - Perform a contextual conversion of the expression From to a...
bool buildOverloadedCallSet(Scope *S, Expr *Fn, UnresolvedLookupExpr *ULE, MultiExprArg Args, SourceLocation RParenLoc, OverloadCandidateSet *CandidateSet, ExprResult *Result)
Constructs and populates an OverloadedCandidateSet from the given function.
void HideUsingShadowDecl(Scope *S, UsingShadowDecl *Shadow)
Hides a using shadow declaration.
bool IsBuildingRecoveryCallExpr
Flag indicating if Sema is building a recovery call expression.
DefaultedFunctionKind getDefaultedFunctionKind(const FunctionDecl *FD)
Determine the kind of defaulting that would be done for a given function.
ExprResult BuildMemberReferenceExpr(Expr *Base, QualType BaseType, SourceLocation OpLoc, bool IsArrow, CXXScopeSpec &SS, SourceLocation TemplateKWLoc, NamedDecl *FirstQualifierInScope, const DeclarationNameInfo &NameInfo, const TemplateArgumentListInfo *TemplateArgs, const Scope *S, ActOnMemberAccessExtraArgs *ExtraArgs=nullptr)
bool IsOverload(FunctionDecl *New, FunctionDecl *Old, bool UseMemberUsingDeclRules, bool ConsiderCudaAttrs=true)
ExprResult CreateBuiltinUnaryOp(SourceLocation OpLoc, UnaryOperatorKind Opc, Expr *InputExpr, bool IsAfterAmp=false)
@ LookupOrdinaryName
Ordinary name lookup, which finds ordinary names (functions, variables, typedefs, etc....
@ LookupUsingDeclName
Look up all declarations in a scope with the given name, including resolved using declarations.
@ LookupOperatorName
Look up of an operator name (e.g., operator+) for use with operator overloading.
@ LookupMemberName
Member name lookup, which finds the names of class/struct/union members.
void DiagnoseSentinelCalls(const NamedDecl *D, SourceLocation Loc, ArrayRef< Expr * > Args)
DiagnoseSentinelCalls - This routine checks whether a call or message-send is to a declaration with t...
ImplicitConversionSequence TryImplicitConversion(Expr *From, QualType ToType, bool SuppressUserConversions, AllowedExplicit AllowExplicit, bool InOverloadResolution, bool CStyle, bool AllowObjCWritebackConversion)
ExprResult BuildLiteralOperatorCall(LookupResult &R, DeclarationNameInfo &SuffixInfo, ArrayRef< Expr * > Args, SourceLocation LitEndLoc, TemplateArgumentListInfo *ExplicitTemplateArgs=nullptr)
BuildLiteralOperatorCall - Build a UserDefinedLiteral by creating a call to a literal operator descri...
bool IsStringInit(Expr *Init, const ArrayType *AT)
ExprResult CreateBuiltinBinOp(SourceLocation OpLoc, BinaryOperatorKind Opc, Expr *LHSExpr, Expr *RHSExpr, bool ForFoldExpression=false)
CreateBuiltinBinOp - Creates a new built-in binary operation with operator Opc at location TokLoc.
ExprResult CreateOverloadedArraySubscriptExpr(SourceLocation LLoc, SourceLocation RLoc, Expr *Base, MultiExprArg Args)
void LookupOverloadedBinOp(OverloadCandidateSet &CandidateSet, OverloadedOperatorKind Op, const UnresolvedSetImpl &Fns, ArrayRef< Expr * > Args, bool RequiresADL=true)
Perform lookup for an overloaded binary operator.
bool isImplicitlyDeleted(FunctionDecl *FD)
Determine whether the given function is an implicitly-deleted special member function.
void PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext, Decl *LambdaContextDecl=nullptr, ExpressionEvaluationContextRecord::ExpressionKind Type=ExpressionEvaluationContextRecord::EK_Other)
bool TemplateParameterListsAreEqual(const TemplateCompareNewDeclInfo &NewInstFrom, TemplateParameterList *New, const NamedDecl *OldInstFrom, TemplateParameterList *Old, bool Complain, TemplateParameterListEqualKind Kind, SourceLocation TemplateArgLoc=SourceLocation())
Determine whether the given template parameter lists are equivalent.
ReferenceCompareResult
ReferenceCompareResult - Expresses the result of comparing two types (cv1 T1 and cv2 T2) to determine...
@ Ref_Incompatible
Ref_Incompatible - The two types are incompatible, so direct reference binding is not possible.
@ Ref_Compatible
Ref_Compatible - The two types are reference-compatible.
@ Ref_Related
Ref_Related - The two types are reference-related, which means that their unqualified forms (T1 and T...
void AddTemplateConversionCandidate(FunctionTemplateDecl *FunctionTemplate, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, Expr *From, QualType ToType, OverloadCandidateSet &CandidateSet, bool AllowObjCConversionOnExplicit, bool AllowExplicit, bool AllowResultConversion=true)
Adds a conversion function template specialization candidate to the overload set, using template argu...
FunctionDecl * getMoreConstrainedFunction(FunctionDecl *FD1, FunctionDecl *FD2)
Returns the more constrained function according to the rules of partial ordering by constraints (C++ ...
void AddBuiltinCandidate(QualType *ParamTys, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool IsAssignmentOperator=false, unsigned NumContextualBoolArguments=0)
AddBuiltinCandidate - Add a candidate for a built-in operator.
ExprResult MaybeBindToTemporary(Expr *E)
MaybeBindToTemporary - If the passed in expression has a record type with a non-trivial destructor,...
void AddArgumentDependentLookupCandidates(DeclarationName Name, SourceLocation Loc, ArrayRef< Expr * > Args, TemplateArgumentListInfo *ExplicitTemplateArgs, OverloadCandidateSet &CandidateSet, bool PartialOverloading=false)
Add function candidates found via argument-dependent lookup to the set of overloading candidates.
ExprResult EvaluateConvertedConstantExpression(Expr *E, QualType T, APValue &Value, CCEKind CCE, bool RequireInt, const APValue &PreNarrowingValue)
EvaluateConvertedConstantExpression - Evaluate an Expression That is a converted constant expression ...
FPOptionsOverride CurFPFeatureOverrides()
ExprResult BuildOverloadedArrowExpr(Scope *S, Expr *Base, SourceLocation OpLoc, bool *NoArrowOperatorFound=nullptr)
BuildOverloadedArrowExpr - Build a call to an overloaded operator-> (if one exists),...
ExprResult BuildCallToMemberFunction(Scope *S, Expr *MemExpr, SourceLocation LParenLoc, MultiExprArg Args, SourceLocation RParenLoc, Expr *ExecConfig=nullptr, bool IsExecConfig=false, bool AllowRecovery=false)
BuildCallToMemberFunction - Build a call to a member function.
AssignConvertType CheckSingleAssignmentConstraints(QualType LHSType, ExprResult &RHS, bool Diagnose=true, bool DiagnoseCFAudited=false, bool ConvertRHS=true)
Check assignment constraints for an assignment of RHS to LHSType.
FunctionDecl * getCurFunctionDecl(bool AllowLambda=false) const
Returns a pointer to the innermost enclosing function, or nullptr if the current context is not insid...
ExprResult PerformContextualImplicitConversion(SourceLocation Loc, Expr *FromE, ContextualImplicitConverter &Converter)
Perform a contextual implicit conversion.
ExprResult DefaultVariadicArgumentPromotion(Expr *E, VariadicCallType CT, FunctionDecl *FDecl)
bool DeduceReturnType(FunctionDecl *FD, SourceLocation Loc, bool Diagnose=true)
bool IsQualificationConversion(QualType FromType, QualType ToType, bool CStyle, bool &ObjCLifetimeConversion)
IsQualificationConversion - Determines whether the conversion from an rvalue of type FromType to ToTy...
void diagnoseNullableToNonnullConversion(QualType DstType, QualType SrcType, SourceLocation Loc)
Warn if we're implicitly casting from a _Nullable pointer type to a _Nonnull one.
bool DiagnoseUseOfDecl(NamedDecl *D, ArrayRef< SourceLocation > Locs, const ObjCInterfaceDecl *UnknownObjCClass=nullptr, bool ObjCPropertyAccess=false, bool AvoidPartialAvailabilityChecks=false, ObjCInterfaceDecl *ClassReceiver=nullptr, bool SkipTrailingRequiresClause=false)
Determine whether the use of this declaration is valid, and emit any corresponding diagnostics.
DiagnosticsEngine & getDiagnostics() const
bool checkAddressOfFunctionIsAvailable(const FunctionDecl *Function, bool Complain=false, SourceLocation Loc=SourceLocation())
Returns whether the given function's address can be taken or not, optionally emitting a diagnostic if...
bool CheckNonDependentConversions(FunctionTemplateDecl *FunctionTemplate, ArrayRef< QualType > ParamTypes, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, ConversionSequenceList &Conversions, CheckNonDependentConversionsFlag UserConversionFlag, CXXRecordDecl *ActingContext=nullptr, QualType ObjectType=QualType(), Expr::Classification ObjectClassification={}, OverloadCandidateParamOrder PO={})
Check that implicit conversion sequences can be formed for each argument whose corresponding paramete...
bool isObjCPointerConversion(QualType FromType, QualType ToType, QualType &ConvertedType, bool &IncompatibleObjC)
isObjCPointerConversion - Determines whether this is an Objective-C pointer conversion.
FunctionDecl * ResolveAddressOfOverloadedFunction(Expr *AddressOfExpr, QualType TargetType, bool Complain, DeclAccessPair &Found, bool *pHadMultipleCandidates=nullptr)
ResolveAddressOfOverloadedFunction - Try to resolve the address of an overloaded function (C++ [over....
bool FunctionParamTypesAreEqual(ArrayRef< QualType > Old, ArrayRef< QualType > New, unsigned *ArgPos=nullptr, bool Reversed=false)
FunctionParamTypesAreEqual - This routine checks two function proto types for equality of their param...
ExprResult PerformImplicitObjectArgumentInitialization(Expr *From, NestedNameSpecifier Qualifier, NamedDecl *FoundDecl, CXXMethodDecl *Method)
PerformObjectArgumentInitialization - Perform initialization of the implicit object parameter for the...
ExprResult DefaultFunctionArrayLvalueConversion(Expr *E, bool Diagnose=true)
ASTContext & getASTContext() const
UnresolvedSetIterator getMostSpecialized(UnresolvedSetIterator SBegin, UnresolvedSetIterator SEnd, TemplateSpecCandidateSet &FailedCandidates, SourceLocation Loc, const PartialDiagnostic &NoneDiag, const PartialDiagnostic &AmbigDiag, const PartialDiagnostic &CandidateDiag, bool Complain=true, QualType TargetType=QualType())
Retrieve the most specialized of the given function template specializations.
bool IsIntegralPromotion(Expr *From, QualType FromType, QualType ToType)
IsIntegralPromotion - Determines whether the conversion from the expression From (whose potentially-a...
bool IsFloatingPointPromotion(QualType FromType, QualType ToType)
IsFloatingPointPromotion - Determines whether the conversion from FromType to ToType is a floating po...
ExprResult BuildTemplateIdExpr(const CXXScopeSpec &SS, SourceLocation TemplateKWLoc, LookupResult &R, bool RequiresADL, const TemplateArgumentListInfo *TemplateArgs)
void PopExpressionEvaluationContext()
ExprResult CreateOverloadedBinOp(SourceLocation OpLoc, BinaryOperatorKind Opc, const UnresolvedSetImpl &Fns, Expr *LHS, Expr *RHS, bool RequiresADL=true, bool AllowRewrittenCandidates=true, FunctionDecl *DefaultedFn=nullptr)
Create a binary operation that may resolve to an overloaded operator.
ExprResult ImpCastExprToType(Expr *E, QualType Type, CastKind CK, ExprValueKind VK=VK_PRValue, const CXXCastPath *BasePath=nullptr, CheckedConversionKind CCK=CheckedConversionKind::Implicit)
ImpCastExprToType - If Expr is not of type 'Type', insert an implicit cast.
bool FunctionNonObjectParamTypesAreEqual(const FunctionDecl *OldFunction, const FunctionDecl *NewFunction, unsigned *ArgPos=nullptr, bool Reversed=false)
bool isInitListConstructor(const FunctionDecl *Ctor)
Determine whether Ctor is an initializer-list constructor, as defined in [dcl.init....
llvm::SmallSetVector< CXXRecordDecl *, 16 > AssociatedClassSet
std::string getAmbiguousPathsDisplayString(CXXBasePaths &Paths)
Builds a string representing ambiguous paths from a specific derived class to different subobjects of...
AccessResult CheckMemberOperatorAccess(SourceLocation Loc, Expr *ObjectExpr, const SourceRange &, DeclAccessPair FoundDecl)
OverloadKind CheckOverload(Scope *S, FunctionDecl *New, const LookupResult &OldDecls, NamedDecl *&OldDecl, bool UseMemberUsingDeclRules)
Determine whether the given New declaration is an overload of the declarations in Old.
QualType ExtractUnqualifiedFunctionType(QualType PossiblyAFunctionType)
bool IsPointerConversion(Expr *From, QualType FromType, QualType ToType, bool InOverloadResolution, QualType &ConvertedType, bool &IncompatibleObjC)
IsPointerConversion - Determines whether the conversion of the expression From, which has the (possib...
@ Conversions
Allow explicit conversion functions but not explicit constructors.
void DiagnoseUseOfDeletedFunction(SourceLocation Loc, SourceRange Range, DeclarationName Name, OverloadCandidateSet &CandidateSet, FunctionDecl *Fn, MultiExprArg Args, bool IsMember=false)
PrintingPolicy getPrintingPolicy() const
Retrieve a suitable printing policy for diagnostics.
bool IsComplexPromotion(QualType FromType, QualType ToType)
Determine if a conversion is a complex promotion.
bool pushCodeSynthesisContext(CodeSynthesisContext Ctx)
Module * getOwningModule(const Decl *Entity)
Get the module owning an entity.
DeclRefExpr * BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK, SourceLocation Loc, const CXXScopeSpec *SS=nullptr)
ExprResult CheckConvertedConstantExpression(Expr *From, QualType T, llvm::APSInt &Value, CCEKind CCE)
@ TPL_TemplateMatch
We are matching the template parameter lists of two templates that might be redeclarations.
void AddConversionCandidate(CXXConversionDecl *Conversion, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, Expr *From, QualType ToType, OverloadCandidateSet &CandidateSet, bool AllowObjCConversionOnExplicit, bool AllowExplicit, bool AllowResultConversion=true, bool StrictPackMatch=false)
AddConversionCandidate - Add a C++ conversion function as a candidate in the candidate set (C++ [over...
bool IsBlockPointerConversion(QualType FromType, QualType ToType, QualType &ConvertedType)
bool CheckFunctionTemplateSpecialization(FunctionDecl *FD, TemplateArgumentListInfo *ExplicitTemplateArgs, LookupResult &Previous, bool QualifiedFriend=false)
Perform semantic analysis for the given function template specialization.
void FindAssociatedClassesAndNamespaces(SourceLocation InstantiationLoc, ArrayRef< Expr * > Args, AssociatedNamespaceSet &AssociatedNamespaces, AssociatedClassSet &AssociatedClasses)
Find the associated classes and namespaces for argument-dependent lookup for a call with the given se...
void AddMethodTemplateCandidate(FunctionTemplateDecl *MethodTmpl, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, TemplateArgumentListInfo *ExplicitTemplateArgs, QualType ObjectType, Expr::Classification ObjectClassification, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool SuppressUserConversions=false, bool PartialOverloading=false, OverloadCandidateParamOrder PO={})
Add a C++ member function template as a candidate to the candidate set, using template argument deduc...
void DiagnoseSelfMove(const Expr *LHSExpr, const Expr *RHSExpr, SourceLocation OpLoc)
DiagnoseSelfMove - Emits a warning if a value is moved to itself.
bool isSameOrCompatibleFunctionType(QualType Param, QualType Arg)
Compare types for equality with respect to possibly compatible function types (noreturn adjustment,...
void AddTemplateOverloadCandidate(FunctionTemplateDecl *FunctionTemplate, DeclAccessPair FoundDecl, TemplateArgumentListInfo *ExplicitTemplateArgs, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool SuppressUserConversions=false, bool PartialOverloading=false, bool AllowExplicit=true, ADLCallKind IsADLCandidate=ADLCallKind::NotADL, OverloadCandidateParamOrder PO={}, bool AggregateCandidateDeduction=false)
Add a C++ function template specialization as a candidate in the candidate set, using template argume...
Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer, TranslationUnitKind TUKind=TU_Complete, CodeCompleteConsumer *CompletionConsumer=nullptr)
SourceLocation getLocForEndOfToken(SourceLocation Loc, unsigned Offset=0)
Calls Lexer::getLocForEndOfToken()
const LangOptions & getLangOpts() const
const FunctionProtoType * ResolveExceptionSpec(SourceLocation Loc, const FunctionProtoType *FPT)
bool isEquivalentInternalLinkageDeclaration(const NamedDecl *A, const NamedDecl *B)
Determine if A and B are equivalent internal linkage declarations from different modules,...
bool DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R, CorrectionCandidateCallback &CCC, TemplateArgumentListInfo *ExplicitTemplateArgs=nullptr, ArrayRef< Expr * > Args={}, DeclContext *LookupCtx=nullptr)
Diagnose an empty lookup.
ExprResult BuildCallExpr(Scope *S, Expr *Fn, SourceLocation LParenLoc, MultiExprArg ArgExprs, SourceLocation RParenLoc, Expr *ExecConfig=nullptr, bool IsExecConfig=false, bool AllowRecovery=false)
BuildCallExpr - Handle a call to Fn with the specified array of arguments.
ExprResult BuildSynthesizedThreeWayComparison(SourceLocation OpLoc, const UnresolvedSetImpl &Fns, Expr *LHS, Expr *RHS, FunctionDecl *DefaultedFn)
AccessResult CheckBaseClassAccess(SourceLocation AccessLoc, QualType Base, QualType Derived, const CXXBasePath &Path, unsigned DiagID, bool ForceCheck=false, bool ForceUnprivileged=false)
Checks access for a hierarchy conversion.
bool CheckUseOfCXXMethodAsAddressOfOperand(SourceLocation OpLoc, const Expr *Op, const CXXMethodDecl *MD)
AccessResult CheckUnresolvedMemberAccess(UnresolvedMemberExpr *E, DeclAccessPair FoundDecl)
Perform access-control checking on a previously-unresolved member access which has now been resolved ...
void AddBuiltinOperatorCandidates(OverloadedOperatorKind Op, SourceLocation OpLoc, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet)
AddBuiltinOperatorCandidates - Add the appropriate built-in operator overloads to the candidate set (...
void AddOverloadCandidate(FunctionDecl *Function, DeclAccessPair FoundDecl, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool SuppressUserConversions=false, bool PartialOverloading=false, bool AllowExplicit=true, bool AllowExplicitConversion=false, ADLCallKind IsADLCandidate=ADLCallKind::NotADL, ConversionSequenceList EarlyConversions={}, OverloadCandidateParamOrder PO={}, bool AggregateCandidateDeduction=false, bool StrictPackMatch=false)
AddOverloadCandidate - Adds the given function to the set of candidate functions, using the given fun...
const LangOptions & LangOpts
bool IsMemberPointerConversion(Expr *From, QualType FromType, QualType ToType, bool InOverloadResolution, QualType &ConvertedType)
IsMemberPointerConversion - Determines whether the conversion of the expression From,...
ExprResult BuildResolvedCallExpr(Expr *Fn, NamedDecl *NDecl, SourceLocation LParenLoc, ArrayRef< Expr * > Arg, SourceLocation RParenLoc, Expr *Config=nullptr, bool IsExecConfig=false, ADLCallKind UsesADL=ADLCallKind::NotADL)
BuildResolvedCallExpr - Build a call to a resolved expression, i.e.
ExprResult BuildCXXMemberCallExpr(Expr *Exp, NamedDecl *FoundDecl, CXXConversionDecl *Method, bool HadMultipleCandidates)
ExprResult CheckForImmediateInvocation(ExprResult E, FunctionDecl *Decl)
Wrap the expression in a ConstantExpr if it is a potential immediate invocation.
llvm::SmallSetVector< DeclContext *, 16 > AssociatedNamespaceSet
MemberPointerConversionDirection
bool diagnoseArgIndependentDiagnoseIfAttrs(const NamedDecl *ND, SourceLocation Loc)
Emit diagnostics for the diagnose_if attributes on Function, ignoring any ArgDependent DiagnoseIfAttr...
ExprResult BuildConvertedConstantExpression(Expr *From, QualType T, CCEKind CCE, NamedDecl *Dest=nullptr)
void popCodeSynthesisContext()
bool AreConstraintExpressionsEqual(const NamedDecl *Old, const Expr *OldConstr, const TemplateCompareNewDeclInfo &New, const Expr *NewConstr)
ReferenceConversionsScope::ReferenceConversions ReferenceConversions
MemberPointerConversionResult CheckMemberPointerConversion(QualType FromType, const MemberPointerType *ToPtrType, CastKind &Kind, CXXCastPath &BasePath, SourceLocation CheckLoc, SourceRange OpRange, bool IgnoreBaseAccess, MemberPointerConversionDirection Direction)
CheckMemberPointerConversion - Check the member pointer conversion from the expression From to the ty...
Expr * BuildCXXThisExpr(SourceLocation Loc, QualType Type, bool IsImplicit)
Build a CXXThisExpr and mark it referenced in the current context.
bool IsOverflowBehaviorTypeConversion(QualType FromType, QualType ToType)
IsOverflowBehaviorTypeConversion - Determines whether the conversion from FromType to ToType necessar...
ExprResult CreateOverloadedUnaryOp(SourceLocation OpLoc, UnaryOperatorKind Opc, const UnresolvedSetImpl &Fns, Expr *input, bool RequiresADL=true)
Create a unary operation that may resolve to an overloaded operator.
void AddOverloadedCallCandidates(UnresolvedLookupExpr *ULE, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool PartialOverloading=false)
Add the overload candidates named by callee and/or found by argument dependent lookup to the given ov...
ExprResult DefaultLvalueConversion(Expr *E)
ExprResult BuildDeclarationNameExpr(const CXXScopeSpec &SS, LookupResult &R, bool NeedsADL, bool AcceptInvalidDecl=false)
bool isVisible(const NamedDecl *D)
Determine whether a declaration is visible to name lookup.
bool CheckDerivedToBaseConversion(QualType Derived, QualType Base, SourceLocation Loc, SourceRange Range, CXXCastPath *BasePath=nullptr, bool IgnoreAccess=false)
void NoteOverloadCandidate(const NamedDecl *Found, const FunctionDecl *Fn, OverloadCandidateRewriteKind RewriteKind=OverloadCandidateRewriteKind(), QualType DestType=QualType(), bool TakingAddress=false)
bool DiagnoseMultipleUserDefinedConversion(Expr *From, QualType ToType)
bool DiagnoseUseOfOverloadedDecl(NamedDecl *D, SourceLocation Loc)
void ArgumentDependentLookup(DeclarationName Name, SourceLocation Loc, ArrayRef< Expr * > Args, ADLResult &Functions)
FunctionDecl * resolveAddressOfSingleOverloadCandidate(Expr *E, DeclAccessPair &FoundResult)
Given an expression that refers to an overloaded function, try to resolve that function to a single f...
DeclContext * CurContext
CurContext - This is the current declaration context of parsing.
MaterializeTemporaryExpr * CreateMaterializeTemporaryExpr(QualType T, Expr *Temporary, bool BoundToLvalueReference)
bool IsOverflowBehaviorTypePromotion(QualType FromType, QualType ToType)
IsOverflowBehaviorTypePromotion - Determines whether the conversion from FromType to ToType involves ...
void DiagnoseUnsatisfiedConstraint(const ConstraintSatisfaction &Satisfaction, SourceLocation Loc={}, bool First=true)
Emit diagnostics explaining why a constraint expression was deemed unsatisfied.
ExprResult PerformContextuallyConvertToBool(Expr *From)
PerformContextuallyConvertToBool - Perform a contextual conversion of the expression From to bool (C+...
bool CheckFunctionConstraints(const FunctionDecl *FD, ConstraintSatisfaction &Satisfaction, SourceLocation UsageLoc=SourceLocation(), bool ForOverloadResolution=false)
Check whether the given function decl's trailing requires clause is satisfied, if any.
bool IsDerivedFrom(SourceLocation Loc, CXXRecordDecl *Derived, CXXRecordDecl *Base, CXXBasePaths &Paths)
Determine whether the type Derived is a C++ class that is derived from the type Base.
bool isUnevaluatedContext() const
Determines whether we are currently in a context that is not evaluated as per C++ [expr] p5.
ObjCMethodDecl * SelectBestMethod(Selector Sel, MultiExprArg Args, bool IsInstance, SmallVectorImpl< ObjCMethodDecl * > &Methods)
FunctionDecl * ResolveSingleFunctionTemplateSpecialization(OverloadExpr *ovl, bool Complain=false, DeclAccessPair *Found=nullptr, TemplateSpecCandidateSet *FailedTSC=nullptr, bool ForTypeDeduction=false)
Given an expression that refers to an overloaded function, try to resolve that overloaded function ex...
AccessResult CheckAddressOfMemberAccess(Expr *OvlExpr, DeclAccessPair FoundDecl)
void MarkDeclRefReferenced(DeclRefExpr *E, const Expr *Base=nullptr)
Perform reference-marking and odr-use handling for a DeclRefExpr.
ExprResult CheckPlaceholderExpr(Expr *E)
Check for operands with placeholder types and complain if found.
EnableIfAttr * CheckEnableIf(FunctionDecl *Function, SourceLocation CallLoc, ArrayRef< Expr * > Args, bool MissingImplicitThis=false)
Check the enable_if expressions on the given function.
ExprResult CreateUnresolvedLookupExpr(CXXRecordDecl *NamingClass, NestedNameSpecifierLoc NNSLoc, DeclarationNameInfo DNI, const UnresolvedSetImpl &Fns, bool PerformADL=true)
bool inTemplateInstantiation() const
Determine whether we are currently performing template instantiation.
void AddMethodCandidate(DeclAccessPair FoundDecl, QualType ObjectType, Expr::Classification ObjectClassification, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool SuppressUserConversion=false, OverloadCandidateParamOrder PO={})
AddMethodCandidate - Adds a named decl (which is some kind of method) as a method candidate to the gi...
void diagnoseEquivalentInternalLinkageDeclarations(SourceLocation Loc, const NamedDecl *D, ArrayRef< const NamedDecl * > Equiv)
ExprResult FixOverloadedFunctionReference(Expr *E, DeclAccessPair FoundDecl, FunctionDecl *Fn)
FixOverloadedFunctionReference - E is an expression that refers to a C++ overloaded function (possibl...
ExprResult ActOnConditionalOp(SourceLocation QuestionLoc, SourceLocation ColonLoc, Expr *CondExpr, Expr *LHSExpr, Expr *RHSExpr)
ActOnConditionalOp - Parse a ?
ExprResult BuildPossibleImplicitMemberExpr(const CXXScopeSpec &SS, SourceLocation TemplateKWLoc, LookupResult &R, const TemplateArgumentListInfo *TemplateArgs, const Scope *S)
Builds an expression which might be an implicit member expression.
bool resolveAndFixAddressOfSingleOverloadCandidate(ExprResult &SrcExpr, bool DoFunctionPointerConversion=false)
Given an overloaded function, tries to turn it into a non-overloaded function reference using resolve...
CallExpr::ADLCallKind ADLCallKind
bool DiagRuntimeBehavior(SourceLocation Loc, const Stmt *Statement, const PartialDiagnostic &PD)
Conditionally issue a diagnostic based on the current evaluation context.
ExprResult BuildCXXDefaultArgExpr(SourceLocation CallLoc, FunctionDecl *FD, ParmVarDecl *Param, Expr *Init=nullptr)
BuildCXXDefaultArgExpr - Creates a CXXDefaultArgExpr, instantiating the default expr if needed.
bool anyAltivecTypes(QualType srcType, QualType destType)
bool isLaxVectorConversion(QualType srcType, QualType destType)
Is this a legal conversion between two types, one of which is known to be a vector type?
ExprResult BuildOverloadedCallExpr(Scope *S, Expr *Fn, UnresolvedLookupExpr *ULE, SourceLocation LParenLoc, MultiExprArg Args, SourceLocation RParenLoc, Expr *ExecConfig, bool AllowTypoCorrection=true, bool CalleesAddressIsTaken=false)
BuildOverloadedCallExpr - Given the call expression that calls Fn (which eventually refers to the dec...
ExprResult PerformImplicitConversion(Expr *From, QualType ToType, const ImplicitConversionSequence &ICS, AssignmentAction Action, CheckedConversionKind CCK=CheckedConversionKind::Implicit)
PerformImplicitConversion - Perform an implicit conversion of the expression From to the type ToType ...
bool isSFINAEContext() const
ExprResult BuildCallToObjectOfClassType(Scope *S, Expr *Object, SourceLocation LParenLoc, MultiExprArg Args, SourceLocation RParenLoc)
BuildCallToObjectOfClassType - Build a call to an object of class type (C++ [over....
bool isCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind=CompleteTypeKind::Default)
bool CanPerformAggregateInitializationForOverloadResolution(const InitializedEntity &Entity, InitListExpr *From)
Determine whether we can perform aggregate initialization for the purposes of overload resolution.
bool IsOverride(FunctionDecl *MD, FunctionDecl *BaseMD, bool UseMemberUsingDeclRules, bool ConsiderCudaAttrs=true)
bool isStdInitializerList(QualType Ty, QualType *Element)
Tests whether Ty is an instance of std::initializer_list and, if it is and Element is not NULL,...
void AddFunctionCandidates(const UnresolvedSetImpl &Functions, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, TemplateArgumentListInfo *ExplicitTemplateArgs=nullptr, bool SuppressUserConversions=false, bool PartialOverloading=false, bool FirstArgumentIsBase=false)
Add all of the function declarations in the given function set to the overload candidate set.
bool CheckPointerConversion(Expr *From, QualType ToType, CastKind &Kind, CXXCastPath &BasePath, bool IgnoreBaseAccess, bool Diagnose=true)
CheckPointerConversion - Check the pointer conversion from the expression From to the type ToType.
void NoteDeletedFunction(FunctionDecl *FD)
Emit a note explaining that this function is deleted.
ExprResult CreateBuiltinArraySubscriptExpr(Expr *Base, SourceLocation LLoc, Expr *Idx, SourceLocation RLoc)
void NoteAllOverloadCandidates(Expr *E, QualType DestType=QualType(), bool TakingAddress=false)
AccessResult CheckUnresolvedLookupAccess(UnresolvedLookupExpr *E, DeclAccessPair FoundDecl)
void AddNonMemberOperatorCandidates(const UnresolvedSetImpl &Functions, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, TemplateArgumentListInfo *ExplicitTemplateArgs=nullptr)
Add all of the non-member operator function declarations in the given function set to the overload ca...
@ PotentiallyEvaluated
The current expression is potentially evaluated at run time, which means that code may be generated t...
@ Unevaluated
The current expression and its subexpressions occur within an unevaluated operand (C++11 [expr]p7),...
bool CheckCallReturnType(QualType ReturnType, SourceLocation Loc, CallExpr *CE, FunctionDecl *FD)
CheckCallReturnType - Checks that a call expression's return type is complete.
bool RequireCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind, TypeDiagnoser &Diagnoser)
Ensure that the type T is a complete type.
ReferenceCompareResult CompareReferenceRelationship(SourceLocation Loc, QualType T1, QualType T2, ReferenceConversions *Conv=nullptr)
CompareReferenceRelationship - Compare the two types T1 and T2 to determine whether they are referenc...
bool LookupQualifiedName(LookupResult &R, DeclContext *LookupCtx, bool InUnqualifiedLookup=false)
Perform qualified name lookup into a given context.
ExprResult PerformObjectMemberConversion(Expr *From, NestedNameSpecifier Qualifier, NamedDecl *FoundDecl, NamedDecl *Member)
Cast a base object to a member's actual type.
MemberPointerConversionResult
SourceManager & SourceMgr
bool DiagnoseDependentMemberLookup(const LookupResult &R)
Diagnose a lookup that found results in an enclosing class during error recovery.
DiagnosticsEngine & Diags
NamespaceDecl * getStdNamespace() const
ExprResult DefaultFunctionArrayConversion(Expr *E, bool Diagnose=true)
DefaultFunctionArrayConversion (C99 6.3.2.1p3, C99 6.3.2.1p4).
ExprResult PerformCopyInitialization(const InitializedEntity &Entity, SourceLocation EqualLoc, ExprResult Init, bool TopLevelOfInitList=false, bool AllowExplicit=false)
bool ResolveAndFixSingleFunctionTemplateSpecialization(ExprResult &SrcExpr, bool DoFunctionPointerConversion=false, bool Complain=false, SourceRange OpRangeForComplaining=SourceRange(), QualType DestTypeForComplaining=QualType(), unsigned DiagIDForComplaining=0)
TemplateDeductionResult DeduceTemplateArguments(ClassTemplatePartialSpecializationDecl *Partial, ArrayRef< TemplateArgument > TemplateArgs, sema::TemplateDeductionInfo &Info)
void AddSurrogateCandidate(CXXConversionDecl *Conversion, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, const FunctionProtoType *Proto, Expr *Object, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet)
AddSurrogateCandidate - Adds a "surrogate" candidate function that converts the given Object to a fun...
MemberExpr * BuildMemberExpr(Expr *Base, bool IsArrow, SourceLocation OpLoc, NestedNameSpecifierLoc NNS, SourceLocation TemplateKWLoc, ValueDecl *Member, DeclAccessPair FoundDecl, bool HadMultipleCandidates, const DeclarationNameInfo &MemberNameInfo, QualType Ty, ExprValueKind VK, ExprObjectKind OK, const TemplateArgumentListInfo *TemplateArgs=nullptr)
ExprResult CreateRecoveryExpr(SourceLocation Begin, SourceLocation End, ArrayRef< Expr * > SubExprs, QualType T=QualType())
Attempts to produce a RecoveryExpr after some AST node cannot be created.
bool IsFunctionConversion(QualType FromType, QualType ToType) const
Determine whether the conversion from FromType to ToType is a valid conversion of ExtInfo/ExtProtoInf...
std::string getTemplateArgumentBindingsText(const TemplateParameterList *Params, const TemplateArgumentList &Args)
Produces a formatted string that describes the binding of template parameters to template arguments.
bool MaybeEmitAmbiguousAtomicConstraintsDiagnostic(const NamedDecl *D1, ArrayRef< AssociatedConstraint > AC1, const NamedDecl *D2, ArrayRef< AssociatedConstraint > AC2)
If D1 was not at least as constrained as D2, but would've been if a pair of atomic constraints involv...
ForRangeStatus BuildForRangeBeginEndCall(SourceLocation Loc, SourceLocation RangeLoc, const DeclarationNameInfo &NameInfo, LookupResult &MemberLookup, OverloadCandidateSet *CandidateSet, Expr *Range, ExprResult *CallExpr)
Build a call to 'begin' or 'end' for a C++11 for-range statement.
@ Diagnose
Diagnose issues that are non-constant or that are extensions.
ExprResult InitializeExplicitObjectArgument(Sema &S, Expr *Obj, FunctionDecl *Fun)
bool CanPerformCopyInitialization(const InitializedEntity &Entity, ExprResult Init)
bool DiagnoseInvalidExplicitObjectParameterInLambda(CXXMethodDecl *Method, SourceLocation CallLoc)
Returns true if the explicit object parameter was invalid.
bool IsStringLiteralToNonConstPointerConversion(Expr *From, QualType ToType)
Helper function to determine whether this is the (deprecated) C++ conversion from a string literal to...
void HandleFunctionTypeMismatch(PartialDiagnostic &PDiag, QualType FromType, QualType ToType)
HandleFunctionTypeMismatch - Gives diagnostic information for differeing function types.
bool ConvertArgumentsForCall(CallExpr *Call, Expr *Fn, FunctionDecl *FDecl, const FunctionProtoType *Proto, ArrayRef< Expr * > Args, SourceLocation RParenLoc, bool ExecConfig=false)
ConvertArgumentsForCall - Converts the arguments specified in Args/NumArgs to the parameter types of ...
DeclContextLookupResult LookupConstructors(CXXRecordDecl *Class)
Look up the constructors for the given class.
FunctionTemplateDecl * getMoreSpecializedTemplate(FunctionTemplateDecl *FT1, FunctionTemplateDecl *FT2, SourceLocation Loc, TemplatePartialOrderingContext TPOC, unsigned NumCallArguments1, QualType RawObj1Ty={}, QualType RawObj2Ty={}, bool Reversed=false, bool PartialOverloading=false)
Returns the more specialized function template according to the rules of function template partial or...
bool CheckFunctionCall(FunctionDecl *FDecl, CallExpr *TheCall, const FunctionProtoType *Proto)
CheckFunctionCall - Check a direct function call for various correctness and safety properties not st...
void AddMemberOperatorCandidates(OverloadedOperatorKind Op, SourceLocation OpLoc, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, OverloadCandidateParamOrder PO={})
Add overload candidates for overloaded operators that are member functions.
void CheckVirtualDtorCall(CXXDestructorDecl *dtor, SourceLocation Loc, bool IsDelete, bool CallCanBeVirtual, bool WarnOnNonAbstractTypes, SourceLocation DtorLoc)
ExprResult ActOnFinishFullExpr(Expr *Expr, bool DiscardedValue)
void checkCall(NamedDecl *FDecl, const FunctionProtoType *Proto, const Expr *ThisArg, ArrayRef< const Expr * > Args, bool IsMemberFunction, SourceLocation Loc, SourceRange Range, VariadicCallType CallType)
Handles the checks for format strings, non-POD arguments to vararg functions, NULL arguments passed t...
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
bool isInSystemHeader(SourceLocation Loc) const
Returns if a SourceLocation is in a system header.
bool isBeforeInTranslationUnit(SourceLocation LHS, SourceLocation RHS) const
Determines the order of 2 source locations in the translation unit.
A trivial tuple used to represent a source range.
SourceLocation getBegin() const
StandardConversionSequence - represents a standard conversion sequence (C++ 13.3.3....
void dump() const
dump - Print this standard conversion sequence to standard error.
void setFromType(QualType T)
DeclAccessPair FoundCopyConstructor
bool isIdentityConversion() const
unsigned BindsToRvalue
Whether we're binding to an rvalue.
ImplicitConversionKind Second
Second - The second conversion can be an integral promotion, floating point promotion,...
QualType getFromType() const
ImplicitConversionKind First
First – The first conversion can be an lvalue-to-rvalue conversion, array-to-pointer conversion,...
unsigned BindsImplicitObjectArgumentWithoutRefQualifier
Whether this binds an implicit object argument to a non-static member function without a ref-qualifie...
unsigned ReferenceBinding
ReferenceBinding - True when this is a reference binding (C++ [over.ics.ref]).
void setAsIdentityConversion()
StandardConversionSequence - Set the standard conversion sequence to the identity conversion.
unsigned DeprecatedStringLiteralToCharPtr
Whether this is the deprecated conversion of a string literal to a pointer to non-const character dat...
CXXConstructorDecl * CopyConstructor
CopyConstructor - The copy constructor that is used to perform this conversion, when the conversion i...
unsigned IncompatibleObjC
IncompatibleObjC - Whether this is an Objective-C conversion that we should warn about (if we actuall...
unsigned ObjCLifetimeConversionBinding
Whether this binds a reference to an object with a different Objective-C lifetime qualifier.
ImplicitConversionKind Third
Third - The third conversion can be a qualification conversion or a function conversion.
unsigned QualificationIncludesObjCLifetime
Whether the qualification conversion involves a change in the Objective-C lifetime (for automatic ref...
void setToType(unsigned Idx, QualType T)
bool isPointerConversionToBool() const
isPointerConversionToBool - Determines whether this conversion is a conversion of a pointer or pointe...
void * ToTypePtrs[3]
ToType - The types that this conversion is converting to in each step.
NarrowingKind getNarrowingKind(ASTContext &Context, const Expr *Converted, APValue &ConstantValue, QualType &ConstantType, bool IgnoreFloatToIntegralConversion=false) const
Check if this standard conversion sequence represents a narrowing conversion, according to C++11 [dcl...
unsigned IsLvalueReference
Whether this is an lvalue reference binding (otherwise, it's an rvalue reference binding).
ImplicitConversionKind Dimension
Dimension - Between the second and third conversion a vector or matrix dimension conversion may occur...
unsigned BindsToFunctionLvalue
Whether we're binding to a function lvalue.
unsigned DirectBinding
DirectBinding - True when this is a reference binding that is a direct binding (C++ [dcl....
ImplicitConversionRank getRank() const
getRank - Retrieve the rank of this standard conversion sequence (C++ 13.3.3.1.1p3).
bool isPointerConversionToVoidPointer(ASTContext &Context) const
isPointerConversionToVoidPointer - Determines whether this conversion is a conversion of a pointer to...
void setAllToTypes(QualType T)
unsigned FromBracedInitList
Whether the source expression was originally a single element braced-init-list.
QualType getToType(unsigned Idx) const
SourceLocation getEndLoc() const LLVM_READONLY
SourceRange getSourceRange() const LLVM_READONLY
SourceLocation tokens are not useful in isolation - they are low level value objects created/interpre...
SourceLocation getBeginLoc() const LLVM_READONLY
StringLiteral - This represents a string literal expression, e.g.
StringRef getString() const
const llvm::Triple & getTriple() const
Returns the target triple of the primary target.
virtual bool hasInt128Type() const
Determine whether the __int128 type is supported on this target.
virtual bool hasIbm128Type() const
Determine whether the __ibm128 type is supported on this target.
virtual bool hasFloat128Type() const
Determine whether the __float128 type is supported on this target.
A convenient class for passing around template argument information.
A template argument list.
Represents a template argument.
QualType getNonTypeTemplateArgumentType() const
If this is a non-type template argument, get its type.
QualType getAsType() const
Retrieve the type for a type template argument.
TemplateName getAsTemplate() const
Retrieve the template name for a template name argument.
unsigned pack_size() const
The number of template arguments in the given template argument pack.
@ Template
The template argument is a template name that was provided for a template template parameter.
@ Pack
The template argument is actually a parameter pack.
ArgKind getKind() const
Return the kind of stored template argument.
The base class of all kinds of template declarations (e.g., class, function, etc.).
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
Represents a C++ template name within the type system.
TemplateDecl * getAsTemplateDecl(bool IgnoreDeduced=false) const
Retrieve the underlying template declaration that this template name refers to, if known.
@ Template
A single template declaration.
bool hasAssociatedConstraints() const
TemplateSpecCandidateSet - A set of generalized overload candidates, used in template specializations...
SmallVector< TemplateSpecCandidate, 16 >::iterator iterator
void NoteCandidates(Sema &S, SourceLocation Loc)
NoteCandidates - When no template specialization match is found, prints diagnostic messages containin...
void clear()
Clear out all of the candidates.
SourceLocation getLocation() const
TemplateSpecCandidate & addCandidate()
Add a new candidate with NumConversions conversion sequence slots to the overload set.
TemplateTemplateParmDecl - Declares a template template parameter, e.g., "T" in.
Declaration of a template type parameter.
const Type * getTypeForDecl() const
The base class of the type hierarchy.
bool isIncompleteOrObjectType() const
Return true if this is an incomplete or object type, in other words, not a function type.
bool isBlockPointerType() const
bool isBooleanType() const
bool isObjCBuiltinType() const
bool isSignedIntegerOrEnumerationType() const
Determines whether this is an integer type that is signed or an enumeration types whose underlying ty...
bool hasAttr(attr::Kind AK) const
Determine whether this type had the specified attribute applied to it (looking through top-level type...
const RecordType * getAsUnionType() const
NOTE: getAs*ArrayType are methods on ASTContext.
bool isIncompleteArrayType() const
bool isSignedIntegerType() const
Return true if this is an integer type that is signed, according to C99 6.2.5p4 [char,...
bool isFloat16Type() const
bool isComplexType() const
isComplexType() does not include complex integers (a GCC extension).
bool isIntegralOrUnscopedEnumerationType() const
Determine whether this type is an integral or unscoped enumeration type.
bool isRValueReferenceType() const
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
bool isConstantArrayType() const
bool canDecayToPointerType() const
Determines whether this type can decay to a pointer type.
bool isConvertibleToFixedPointType() const
Return true if this can be converted to (or from) a fixed point type.
CXXRecordDecl * castAsCXXRecordDecl() const
bool isArithmeticType() const
bool isPointerType() const
bool isArrayParameterType() const
CanQualType getCanonicalTypeUnqualified() const
bool isIntegerType() const
isIntegerType() does not include complex integers (a GCC extension).
bool isSVESizelessBuiltinType() const
Returns true for SVE scalable vector types.
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
bool isEnumeralType() const
bool isIntegralType(const ASTContext &Ctx) const
Determine whether this type is an integral type.
bool isObjCQualifiedIdType() const
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
bool isIntegralOrEnumerationType() const
Determine whether this type is an integral or enumeration type.
bool isAnyCharacterType() const
Determine whether this type is any of the built-in character types.
bool isExtVectorBoolType() const
bool isObjCObjectOrInterfaceType() const
bool isInstantiationDependentType() const
Determine whether this type is an instantiation-dependent type, meaning that the type involves a temp...
bool isLValueReferenceType() const
bool isBitIntType() const
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
bool isAggregateType() const
Determines whether the type is a C++ aggregate type or C aggregate or union type.
bool isAnyComplexType() const
bool isFixedPointType() const
Return true if this is a fixed point type according to ISO/IEC JTC1 SC22 WG14 N1169.
const BuiltinType * getAsPlaceholderType() const
bool isMemberPointerType() const
bool isOverloadableType() const
Determines whether this is a type for which one can define an overloaded operator.
bool isObjCIdType() const
bool isMatrixType() const
bool isOverflowBehaviorType() const
bool isUndeducedType() const
Determine whether this type is an undeduced type, meaning that it somehow involves a C++11 'auto' typ...
bool isObjectType() const
Determine whether this type is an object type.
EnumDecl * getAsEnumDecl() const
Retrieves the EnumDecl this type refers to.
bool isBFloat16Type() const
bool isIncompleteType(NamedDecl **Def=nullptr) const
Types are partitioned into 3 broad categories (C99 6.2.5p1): object types, function types,...
bool isFunctionType() const
bool isObjCObjectPointerType() const
bool isVectorType() const
bool isObjCClassType() const
bool isRealFloatingType() const
Floating point categories.
bool isRVVSizelessBuiltinType() const
Returns true for RVV scalable vector types.
const T * getAsCanonical() const
If this type is canonically the specified type, return its canonical type cast to that specified type...
bool isHLSLAttributedResourceType() const
bool isUnsignedIntegerType() const
Return true if this is an integer type that is unsigned, according to C99 6.2.5p6 [which returns true...
bool isAnyPointerType() const
TypeClass getTypeClass() const
const T * getAs() const
Member-template getAs<specific type>'.
const Type * getUnqualifiedDesugaredType() const
Return the specified type with any "sugar" removed from the type, removing any typedefs,...
bool isNullPtrType() const
bool isRecordType() const
UnaryOperator - This represents the unary-expression's (except sizeof and alignof),...
static OverloadedOperatorKind getOverloadedOperator(Opcode Opc)
Retrieve the overloaded operator kind that corresponds to the given unary opcode.
static UnaryOperator * Create(const ASTContext &C, Expr *input, Opcode opc, QualType type, ExprValueKind VK, ExprObjectKind OK, SourceLocation l, bool CanOverflow, FPOptionsOverride FPFeatures)
static StringRef getOpcodeStr(Opcode Op)
getOpcodeStr - Turn an Opcode enum value into the punctuation char it corresponds to,...
A reference to a name which we were able to look up during parsing but could not resolve to a specifi...
bool requiresADL() const
True if this declaration should be extended by argument-dependent lookup.
static UnresolvedLookupExpr * Create(const ASTContext &Context, CXXRecordDecl *NamingClass, NestedNameSpecifierLoc QualifierLoc, const DeclarationNameInfo &NameInfo, bool RequiresADL, UnresolvedSetIterator Begin, UnresolvedSetIterator End, bool KnownDependent, bool KnownInstantiationDependent)
Represents a C++ member access expression for which lookup produced a set of overloaded functions.
DeclarationName getMemberName() const
Retrieve the name of the member that this expression refers to.
QualType getBaseType() const
bool isArrow() const
Determine whether this member expression used the '->' operator; otherwise, it used the '.
Expr * getBase()
Retrieve the base object of this member expressions, e.g., the x in x.m.
SourceLocation getBeginLoc() const LLVM_READONLY
SourceLocation getMemberLoc() const
Retrieve the location of the name of the member that this expression refers to.
A set of unresolved declarations.
ArrayRef< DeclAccessPair > pairs() const
void addDecl(NamedDecl *D)
The iterator over UnresolvedSets.
A set of unresolved declarations.
A call to a literal operator (C++11 [over.literal]) written as a user-defined literal (C++11 [lit....
static UserDefinedLiteral * Create(const ASTContext &Ctx, Expr *Fn, ArrayRef< Expr * > Args, QualType Ty, ExprValueKind VK, SourceLocation LitEndLoc, SourceLocation SuffixLoc, FPOptionsOverride FPFeatures)
unsigned getNumElements() const
QualType getElementType() const
Provides information about an attempted template argument deduction, whose success or failure was des...
TemplateArgumentList * takeSugared()
Take ownership of the deduced template argument lists.
TemplateArgument SecondArg
The second template argument to which the template argument deduction failure refers.
TemplateParameter Param
The template parameter to which a template argument deduction failure refers.
bool hasSFINAEDiagnostic() const
Is a SFINAE diagnostic available?
TemplateArgument FirstArg
The first template argument to which the template argument deduction failure refers.
ConstraintSatisfaction AssociatedConstraintsSatisfaction
The constraint satisfaction details resulting from the associated constraints satisfaction tests.
void takeSFINAEDiagnostic(PartialDiagnosticAt &PD)
Take ownership of the SFINAE diagnostic.
unsigned CallArgIndex
The index of the function argument that caused a deduction failure.
bool hasStrictPackMatch() const
specific_attr_iterator - Iterates over a subrange of an AttrVec, only providing attributes that are o...
Defines the clang::TargetInfo interface.
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
@ Warning
Present this diagnostic as a warning.
@ Error
Present this diagnostic as an error.
PRESERVE_NONE bool Ret(InterpState &S, CodePtr &PC)
void checkAssignmentLifetime(Sema &SemaRef, const AssignedEntity &Entity, Expr *Init)
Check that the lifetime of the given expr (and its subobjects) is sufficient for assigning to the ent...
The JSON file list parser is used to communicate input to InstallAPI.
ImplicitConversionRank GetDimensionConversionRank(ImplicitConversionRank Base, ImplicitConversionKind Dimension)
CanQual< Type > CanQualType
Represents a canonical, potentially-qualified type.
OverloadedOperatorKind
Enumeration specifying the different kinds of C++ overloaded operators.
@ OO_None
Not an overloaded operator.
@ NUM_OVERLOADED_OPERATORS
@ NonFunction
This is not an overload because the lookup results contain a non-function.
@ Match
This is not an overload because the signature exactly matches an existing declaration.
@ Overload
This is a legitimate overload: the existing declarations are functions or function templates with dif...
bool isa(CodeGen::Address addr)
OverloadingResult
OverloadingResult - Capture the result of performing overload resolution.
@ OR_Deleted
Succeeded, but refers to a deleted function.
@ OR_Success
Overload resolution succeeded.
@ OR_Ambiguous
Ambiguous candidates found.
@ OR_No_Viable_Function
No viable function found.
@ Specialization
We are substituting template parameters for template arguments in order to form a template specializa...
bool isBetterOverloadCandidate(Sema &S, const OverloadCandidate &Cand1, const OverloadCandidate &Cand2, SourceLocation Loc, OverloadCandidateSet::CandidateSetKind Kind, bool PartialOverloading=false)
isBetterOverloadCandidate - Determines whether the first overload candidate is a better candidate tha...
bool isUnresolvedExceptionSpec(ExceptionSpecificationType ESpecType)
@ ovl_fail_final_conversion_not_exact
This conversion function template specialization candidate is not viable because the final conversion...
@ ovl_fail_enable_if
This candidate function was not viable because an enable_if attribute disabled it.
@ ovl_fail_illegal_constructor
This conversion candidate was not considered because it is an illegal instantiation of a constructor ...
@ ovl_fail_bad_final_conversion
This conversion candidate is not viable because its result type is not implicitly convertible to the ...
@ ovl_fail_module_mismatched
This candidate was not viable because it has internal linkage and is from a different module unit tha...
@ ovl_fail_too_few_arguments
@ ovl_fail_addr_not_available
This candidate was not viable because its address could not be taken.
@ ovl_fail_too_many_arguments
@ ovl_non_default_multiversion_function
This candidate was not viable because it is a non-default multiversioned function.
@ ovl_fail_constraints_not_satisfied
This candidate was not viable because its associated constraints were not satisfied.
@ ovl_fail_bad_conversion
@ ovl_fail_bad_target
(CUDA) This candidate was not viable because the callee was not accessible from the caller's target (...
@ ovl_fail_inhctor_slice
This inherited constructor is not viable because it would slice the argument.
@ ovl_fail_object_addrspace_mismatch
This constructor/conversion candidate fail due to an address space mismatch between the object being ...
@ ovl_fail_explicit
This candidate constructor or conversion function is explicit but the context doesn't permit explicit...
@ ovl_fail_trivial_conversion
This conversion candidate was not considered because it duplicates the work of a trivial or derived-t...
@ Comparison
A comparison.
@ RQ_None
No ref-qualifier was provided.
@ RQ_LValue
An lvalue ref-qualifier was provided (&).
@ RQ_RValue
An rvalue ref-qualifier was provided (&&).
ImplicitConversionRank
ImplicitConversionRank - The rank of an implicit conversion kind.
@ ICR_Conversion
Conversion.
@ ICR_Writeback_Conversion
ObjC ARC writeback conversion.
@ ICR_HLSL_Dimension_Reduction
HLSL Matching Dimension Reduction.
@ ICR_HLSL_Dimension_Reduction_Conversion
HLSL Dimension reduction with conversion.
@ ICR_HLSL_Scalar_Widening
HLSL Scalar Widening.
@ ICR_C_Conversion
Conversion only allowed in the C standard (e.g. void* to char*).
@ ICR_OCL_Scalar_Widening
OpenCL Scalar Widening.
@ ICR_Complex_Real_Conversion
Complex <-> Real conversion.
@ ICR_HLSL_Scalar_Widening_Conversion
HLSL Scalar Widening with conversion.
@ ICR_HLSL_Dimension_Reduction_Promotion
HLSL Dimension reduction with promotion.
@ ICR_Promotion
Promotion.
@ ICR_Exact_Match
Exact Match.
@ ICR_C_Conversion_Extension
Conversion not allowed by the C standard, but that we accept as an extension anyway.
@ ICR_HLSL_Scalar_Widening_Promotion
HLSL Scalar Widening with promotion.
OverloadCandidateDisplayKind
@ OCD_AmbiguousCandidates
Requests that only tied-for-best candidates be shown.
@ OCD_ViableCandidates
Requests that only viable candidates be shown.
@ OCD_AllCandidates
Requests that all candidates be shown.
@ OK_ObjCProperty
An Objective-C property is a logical field of an Objective-C object which is read and written via Obj...
@ OK_Ordinary
An ordinary object is located at an address in memory.
Expr::ConstantExprKind ConstantExprKind
OverloadCandidateParamOrder
The parameter ordering that will be used for the candidate.
@ Seq
'seq' clause, allowed on 'loop' and 'routine' directives.
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
OverloadsShown
Specifies which overload candidates to display when overload resolution fails.
@ Ovl_Best
Show just the "best" overload candidates.
llvm::MutableArrayRef< ImplicitConversionSequence > ConversionSequenceList
A list of implicit conversion sequences for the arguments of an OverloadCandidate.
ComparisonCategoryResult
An enumeration representing the possible results of a three-way comparison.
OverloadCandidateRewriteKind
The kinds of rewrite we perform on overload candidates.
@ CRK_Reversed
Candidate is a rewritten candidate with a reversed order of parameters.
@ CRK_None
Candidate is not a rewritten candidate.
@ CRK_DifferentOperator
Candidate is a rewritten candidate with a different operator name.
MutableArrayRef< Expr * > MultiExprArg
@ Internal
Internal linkage, which indicates that the entity can be referred to from within the translation unit...
@ Result
The result type of a method or function.
std::pair< unsigned, unsigned > getDepthAndIndex(const NamedDecl *ND)
Retrieve the depth and index of a template parameter.
OptionalUnsigned< unsigned > UnsignedOrNone
ImplicitConversionKind
ImplicitConversionKind - The kind of implicit conversion used to convert an argument to a parameter's...
@ ICK_Complex_Conversion
Complex conversions (C99 6.3.1.6)
@ ICK_Floating_Promotion
Floating point promotions (C++ [conv.fpprom])
@ ICK_Boolean_Conversion
Boolean conversions (C++ [conv.bool])
@ ICK_Integral_Conversion
Integral conversions (C++ [conv.integral])
@ ICK_Fixed_Point_Conversion
Fixed point type conversions according to N1169.
@ ICK_Vector_Conversion
Vector conversions.
@ ICK_Block_Pointer_Conversion
Block Pointer conversions.
@ ICK_Pointer_Member
Pointer-to-member conversions (C++ [conv.mem])
@ ICK_Floating_Integral
Floating-integral conversions (C++ [conv.fpint])
@ ICK_HLSL_Array_RValue
HLSL non-decaying array rvalue cast.
@ ICK_SVE_Vector_Conversion
Arm SVE Vector conversions.
@ ICK_HLSL_Vector_Truncation
HLSL vector truncation.
@ ICK_Incompatible_Pointer_Conversion
C-only conversion between pointers with incompatible types.
@ ICK_Array_To_Pointer
Array-to-pointer conversion (C++ [conv.array])
@ ICK_RVV_Vector_Conversion
RISC-V RVV Vector conversions.
@ ICK_Complex_Promotion
Complex promotions (Clang extension)
@ ICK_Num_Conversion_Kinds
The number of conversion kinds.
@ ICK_HLSL_Matrix_Splat
HLSL matrix splat from scalar or boolean type.
@ ICK_Function_Conversion
Function pointer conversion (C++17 [conv.fctptr])
@ ICK_Vector_Splat
A vector splat from an arithmetic type.
@ ICK_Zero_Queue_Conversion
Zero constant to queue.
@ ICK_Identity
Identity conversion (no conversion)
@ ICK_Derived_To_Base
Derived-to-base (C++ [over.best.ics])
@ ICK_Lvalue_To_Rvalue
Lvalue-to-rvalue conversion (C++ [conv.lval])
@ ICK_Qualification
Qualification conversions (C++ [conv.qual])
@ ICK_Pointer_Conversion
Pointer conversions (C++ [conv.ptr])
@ ICK_TransparentUnionConversion
Transparent Union Conversions.
@ ICK_Integral_Promotion
Integral promotions (C++ [conv.prom])
@ ICK_HLSL_Matrix_Truncation
HLSL Matrix truncation.
@ ICK_Floating_Conversion
Floating point conversions (C++ [conv.double].
@ ICK_Compatible_Conversion
Conversions between compatible types in C99.
@ ICK_C_Only_Conversion
Conversions allowed in C, but not C++.
@ ICK_Writeback_Conversion
Objective-C ARC writeback conversion.
@ ICK_Zero_Event_Conversion
Zero constant to event (OpenCL1.2 6.12.10)
@ ICK_Complex_Real
Complex-real conversions (C99 6.3.1.7)
@ ICK_Function_To_Pointer
Function-to-pointer (C++ [conv.array])
@ Template
We are parsing a template declaration.
ActionResult< CXXBaseSpecifier * > BaseResult
AssignConvertType
AssignConvertType - All of the 'assignment' semantic checks return this enum to indicate whether the ...
@ IncompatiblePointer
IncompatiblePointer - The assignment is between two pointers types that are not compatible,...
@ CompatiblePointerDiscardsQualifiers
CompatiblePointerDiscardsQualifiers - The assignment discards c/v/r qualifiers, which we accept as an...
@ Compatible
Compatible - the types are compatible according to the standard.
@ IncompatiblePointerSign
IncompatiblePointerSign - The assignment is between two pointers types which point to integers which ...
DeductionFailureInfo MakeDeductionFailureInfo(ASTContext &Context, TemplateDeductionResult TDK, sema::TemplateDeductionInfo &Info)
Convert from Sema's representation of template deduction information to the form used in overload-can...
@ FunctionTemplate
The name was classified as a function template name.
LangAS
Defines the address space values used by the address space qualifier of QualType.
CastKind
CastKind - The kind of operation required for a conversion.
CXXSpecialMemberKind
Kinds of C++ special members.
OverloadedOperatorKind getRewrittenOverloadedOperator(OverloadedOperatorKind Kind)
Get the other overloaded operator that the given operator can be rewritten into, if any such operator...
std::pair< SourceLocation, PartialDiagnostic > PartialDiagnosticAt
A partial diagnostic along with the source location where this diagnostic occurs.
ExprValueKind
The categorization of expression values, currently following the C++11 scheme.
@ VK_PRValue
A pr-value expression (in the C++11 taxonomy) produces a temporary value.
@ VK_XValue
An x-value expression is a reference to an object with independent storage but which can be "moved",...
@ VK_LValue
An l-value expression is a reference to an object with independent storage.
bool shouldEnforceArgLimit(bool PartialOverloading, FunctionDecl *Function)
SmallVector< CXXBaseSpecifier *, 4 > CXXCastPath
A simple array of base specifiers.
llvm::PointerUnion< TemplateTypeParmDecl *, NonTypeTemplateParmDecl *, TemplateTemplateParmDecl * > TemplateParameter
Stores a template parameter of any kind.
NarrowingKind
NarrowingKind - The kind of narrowing conversion being performed by a standard conversion sequence ac...
@ NK_Not_Narrowing
Not a narrowing conversion.
@ NK_Constant_Narrowing
A narrowing conversion, because a constant expression got narrowed.
@ NK_Dependent_Narrowing
Cannot tell whether this is a narrowing conversion because the expression is value-dependent.
@ NK_Type_Narrowing
A narrowing conversion by virtue of the source and destination types.
@ NK_Variable_Narrowing
A narrowing conversion, because a non-constant-expression variable might have got narrowed.
@ TPOC_Conversion
Partial ordering of function templates for a call to a conversion function.
@ TPOC_Call
Partial ordering of function templates for a function call.
bool declaresSameEntity(const Decl *D1, const Decl *D2)
Determine whether two declarations declare the same entity.
TemplateDeductionResult
Describes the result of template argument deduction.
@ MiscellaneousDeductionFailure
Deduction failed; that's all we know.
@ NonDependentConversionFailure
Checking non-dependent argument conversions failed.
@ ConstraintsNotSatisfied
The deduced arguments did not satisfy the constraints associated with the template.
@ Underqualified
Template argument deduction failed due to inconsistent cv-qualifiers on a template parameter type tha...
@ InstantiationDepth
Template argument deduction exceeded the maximum template instantiation depth (which has already been...
@ InvalidExplicitArguments
The explicitly-specified template arguments were not valid template arguments for the given template.
@ CUDATargetMismatch
CUDA Target attributes do not match.
@ TooFewArguments
When performing template argument deduction for a function template, there were too few call argument...
@ Incomplete
Template argument deduction did not deduce a value for every template parameter.
@ Invalid
The declaration was invalid; do nothing.
@ Success
Template argument deduction was successful.
@ SubstitutionFailure
Substitution of the deduced template argument values resulted in an error.
@ IncompletePack
Template argument deduction did not deduce a value for every expansion of an expanded template parame...
@ DeducedMismatch
After substituting deduced template arguments, a dependent parameter type did not match the correspon...
@ Inconsistent
Template argument deduction produced inconsistent deduced values for the given template parameter.
@ TooManyArguments
When performing template argument deduction for a function template, there were too many call argumen...
@ AlreadyDiagnosed
Some error which was already diagnosed.
@ DeducedMismatchNested
After substituting deduced template arguments, an element of a dependent parameter type did not match...
@ NonDeducedMismatch
A non-depnedent component of the parameter did not match the corresponding component of the argument.
@ TSK_ExplicitSpecialization
This template specialization was declared or defined by an explicit specialization (C++ [temp....
@ TSK_ImplicitInstantiation
This template specialization was implicitly instantiated from a template.
CallingConv
CallingConv - Specifies the calling convention that a function uses.
const char * getOperatorSpelling(OverloadedOperatorKind Operator)
Retrieve the spelling of the given overloaded operator, without the preceding "operator" keyword.
U cast(CodeGen::Address addr)
ConstructorInfo getConstructorInfo(NamedDecl *ND)
@ None
The alignment was not explicit in code.
CCEKind
Contexts in which a converted constant expression is required.
@ TemplateArg
Value of a non-type template parameter.
@ Noexcept
Condition in a noexcept(bool) specifier.
@ ArrayBound
Array bound in array declarator or new-expression.
@ TempArgStrict
As above, but applies strict template checking rules.
@ ExplicitBool
Condition in an explicit(bool) specifier.
ImplicitConversionRank GetConversionRank(ImplicitConversionKind Kind)
GetConversionRank - Retrieve the implicit conversion rank corresponding to the given implicit convers...
@ Enum
The "enum" keyword introduces the elaborated-type-specifier.
ActionResult< Expr * > ExprResult
@ EST_None
no exception specification
@ ForBuiltinOverloadedOp
A conversion for an operand of a builtin overloaded operator.
__DEVICE__ _Tp abs(const std::complex< _Tp > &__c)
Represents an ambiguous user-defined conversion sequence.
ConversionSet::const_iterator const_iterator
ConversionSet & conversions()
SmallVector< std::pair< NamedDecl *, FunctionDecl * >, 4 > ConversionSet
void setFromType(QualType T)
void setToType(QualType T)
void addConversion(NamedDecl *Found, FunctionDecl *D)
void copyFrom(const AmbiguousConversionSequence &)
const Expr * ConstraintExpr
UnsignedOrNone ArgPackSubstIndex
QualType getToType() const
QualType getFromType() const
OverloadFixItKind Kind
The type of fix applied.
unsigned NumConversionsFixed
The number of Conversions fixed.
void setConversionChecker(TypeComparisonFuncTy Foo)
Resets the default conversion checker method.
std::vector< FixItHint > Hints
The list of Hints generated so far.
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
SourceLocation getLoc() const
getLoc - Returns the main location of the declaration name.
void setCXXOperatorNameRange(SourceRange R)
setCXXOperatorNameRange - Sets the range of the operator name (without the operator keyword).
const DeclarationNameLoc & getInfo() const
SourceLocation getCXXLiteralOperatorNameLoc() const
getCXXLiteralOperatorNameLoc - Returns the location of the literal operator name (not the operator ke...
A structure used to record information about a failed template argument deduction,...
void * Data
Opaque pointer containing additional data about this deduction failure.
const TemplateArgument * getSecondArg()
Return the second template argument this deduction failure refers to, if any.
unsigned Result
A Sema::TemplateDeductionResult.
PartialDiagnosticAt * getSFINAEDiagnostic()
Retrieve the diagnostic which caused this deduction failure, if any.
unsigned HasDiagnostic
Indicates whether a diagnostic is stored in Diagnostic.
TemplateDeductionResult getResult() const
void Destroy()
Free any memory associated with this deduction failure.
char Diagnostic[sizeof(PartialDiagnosticAt)]
A diagnostic indicating why deduction failed.
UnsignedOrNone getCallArgIndex()
Return the index of the call argument that this deduction failure refers to, if any.
TemplateParameter getTemplateParameter()
Retrieve the template parameter this deduction failure refers to, if any.
TemplateArgumentList * getTemplateArgumentList()
Retrieve the template argument list associated with this deduction failure, if any.
const TemplateArgument * getFirstArg()
Return the first template argument this deduction failure refers to, if any.
DeferredTemplateOverloadCandidate * Next
EvalResult is a struct with detailed info about an evaluated expression.
APValue Val
Val - This is the value the expression can be folded to.
SmallVectorImpl< PartialDiagnosticAt > * Diag
Diag - If this is non-null, it will be filled in with a stack of notes indicating why evaluation fail...
Extra information about a function prototype.
FunctionEffectsRef FunctionEffects
const ExtParameterInfo * ExtParameterInfos
Information about operator rewrites to consider when adding operator functions to a candidate set.
bool allowsReversed(OverloadedOperatorKind Op) const
Determine whether reversing parameter order is allowed for operator Op.
bool shouldAddReversed(Sema &S, ArrayRef< Expr * > OriginalArgs, FunctionDecl *FD) const
Determine whether we should add a rewritten candidate for FD with reversed parameter order.
bool isAcceptableCandidate(const FunctionDecl *FD) const
bool isReversible() const
Determines whether this operator could be implemented by a function with reversed parameter order.
SourceLocation OpLoc
The source location of the operator.
bool AllowRewrittenCandidates
Whether we should include rewritten candidates in the overload set.
OverloadCandidateRewriteKind getRewriteKind(const FunctionDecl *FD, OverloadCandidateParamOrder PO)
Determine the kind of rewrite that should be performed for this candidate.
OverloadCandidate - A single candidate in an overload set (C++ 13.3).
unsigned StrictPackMatch
Have we matched any packs on the parameter side, versus any non-packs on the argument side,...
unsigned IgnoreObjectArgument
IgnoreObjectArgument - True to indicate that the first argument's conversion, which for this function...
bool TryToFixBadConversion(unsigned Idx, Sema &S)
bool NotValidBecauseConstraintExprHasError() const
unsigned IsADLCandidate
True if the candidate was found using ADL.
unsigned IsSurrogate
IsSurrogate - True to indicate that this candidate is a surrogate for a conversion to a function poin...
QualType BuiltinParamTypes[3]
BuiltinParamTypes - Provides the parameter types of a built-in overload candidate.
DeclAccessPair FoundDecl
FoundDecl - The original declaration that was looked up / invented / otherwise found,...
FunctionDecl * Function
Function - The actual function that this candidate represents.
unsigned RewriteKind
Whether this is a rewritten candidate, and if so, of what kind?
ConversionFixItGenerator Fix
The FixIt hints which can be used to fix the Bad candidate.
unsigned Best
Whether this candidate is the best viable function, or tied for being the best viable function.
StandardConversionSequence FinalConversion
FinalConversion - For a conversion function (where Function is a CXXConversionDecl),...
unsigned getNumParams() const
unsigned HasFinalConversion
Whether FinalConversion has been set.
unsigned TookAddressOfOverload
unsigned FailureKind
FailureKind - The reason why this candidate is not viable.
unsigned ExplicitCallArguments
The number of call arguments that were explicitly provided, to be used while performing partial order...
ConversionSequenceList Conversions
The conversion sequences used to convert the function arguments to the function parameters.
DeductionFailureInfo DeductionFailure
unsigned Viable
Viable - True to indicate that this overload candidate is viable.
CXXConversionDecl * Surrogate
Surrogate - The conversion function for which this candidate is a surrogate, but only if IsSurrogate ...
OverloadCandidateRewriteKind getRewriteKind() const
Get RewriteKind value in OverloadCandidateRewriteKind type (This function is to workaround the spurio...
bool HasFormOfMemberPointer
OverloadExpr * Expression
bool SuppressUserConversions
Do not consider any user-defined conversions when constructing the initializing sequence.
bool OnlyInitializeNonUserDefinedConversions
Before constructing the initializing sequence, we check whether the parameter type and argument type ...
A context in which code is being synthesized (where a source location alone is not sufficient to iden...
enum clang::Sema::CodeSynthesisContext::SynthesisKind Kind
@ RewritingOperatorAsSpaceship
We are rewriting a comparison operator in terms of an operator<=>.
Decl * Entity
The entity that is being synthesized.
Abstract class used to diagnose incomplete types.
A std::pair-like structure for storing a qualified type split into its local qualifiers and its local...
const Type * Ty
The locally-unqualified type.
Qualifiers Quals
The local qualifiers.
TemplateSpecCandidate - This is a generalization of OverloadCandidate which keeps track of template a...
void NoteDeductionFailure(Sema &S, bool ForTakingAddress)
Diagnose a template argument deduction failure.
DeductionFailureInfo DeductionFailure
Template argument deduction info.
Decl * Specialization
Specialization - The actual specialization that this candidate represents.
DeclAccessPair FoundDecl
The declaration that was looked up, together with its access.
void set(DeclAccessPair Found, Decl *Spec, DeductionFailureInfo Info)
UserDefinedConversionSequence - Represents a user-defined conversion sequence (C++ 13....
StandardConversionSequence Before
Represents the standard conversion that occurs before the actual user-defined conversion.
FunctionDecl * ConversionFunction
ConversionFunction - The function that will perform the user-defined conversion.
bool HadMultipleCandidates
HadMultipleCandidates - When this is true, it means that the conversion function was resolved from an...
StandardConversionSequence After
After - Represents the standard conversion that occurs after the actual user-defined conversion.
bool EllipsisConversion
EllipsisConversion - When this is true, it means user-defined conversion sequence starts with a ....
DeclAccessPair FoundConversionFunction
The declaration that we found via name lookup, which might be the same as ConversionFunction or it mi...
void dump() const
dump - Print this user-defined conversion sequence to standard error.
Describes an entity that is being assigned.