30#include "llvm/ADT/APInt.h"
31#include "llvm/ADT/FoldingSet.h"
32#include "llvm/ADT/PointerIntPair.h"
33#include "llvm/ADT/STLForwardCompat.h"
34#include "llvm/ADT/SmallVector.h"
35#include "llvm/ADT/StringExtras.h"
36#include "llvm/Support/ErrorHandling.h"
37#include "llvm/Support/raw_ostream.h"
73 if (!isa<ConstantArrayType>(AT) && !isa<IncompleteArrayType>(AT))
91 auto IsCharOrUnsignedChar = [](
const QualType &
T) {
92 const BuiltinType *BT = dyn_cast<BuiltinType>(
T.getTypePtr());
97 case StringLiteralKind::UTF8:
107 case StringLiteralKind::Ordinary:
111 return (SL->
getKind() == StringLiteralKind::UTF8 &&
125 case StringLiteralKind::UTF16:
133 case StringLiteralKind::UTF32:
141 case StringLiteralKind::Wide:
149 case StringLiteralKind::Unevaluated:
150 assert(
false &&
"Unevaluated string literal in initialization");
154 llvm_unreachable(
"missed a StringLiteral kind?");
175 if (isa<StringLiteral>(
E) || isa<ObjCEncodeExpr>(
E))
186 if (isa<CompoundLiteralExpr>(
E))
201 if (
const auto *VD = dyn_cast_if_present<VarDecl>(
D); VD && VD->isConstexpr())
211 Sema &S,
bool CheckC23ConstexprInit =
false) {
213 auto *ConstantArrayTy =
215 uint64_t StrLength = ConstantArrayTy->getZExtSize();
217 if (CheckC23ConstexprInit)
224 llvm::APInt ConstVal(32, StrLength);
250 diag::err_initializer_string_for_char_array_too_long)
256 diag::ext_initializer_string_for_char_array_too_long)
269 if (Field->hasAttr<ExplicitInitAttr>())
270 S.
Diag(Field->getLocation(), diag::note_entity_declared_at) << Field;
311class InitListChecker {
313 bool hadError =
false;
315 bool TreatUnavailableAsInvalid;
316 bool InOverloadResolution;
321 unsigned CurEmbedIndex = 0;
332 unsigned &StructuredIndex);
336 bool TopLevelObject =
false);
339 bool SubobjectIsDesignatorContext,
342 unsigned &StructuredIndex,
343 bool TopLevelObject =
false);
348 unsigned &StructuredIndex,
349 bool DirectlyDesignated =
false);
354 unsigned &StructuredIndex);
359 unsigned &StructuredIndex);
364 unsigned &StructuredIndex);
368 unsigned &StructuredIndex);
373 bool SubobjectIsDesignatorContext,
unsigned &Index,
375 unsigned &StructuredIndex,
376 bool TopLevelObject =
false);
379 llvm::APSInt elementIndex,
380 bool SubobjectIsDesignatorContext,
unsigned &Index,
382 unsigned &StructuredIndex);
388 llvm::APSInt *NextElementIndex,
391 unsigned &StructuredIndex,
392 bool FinishSubobjectInit,
393 bool TopLevelObject);
397 unsigned StructuredIndex,
399 bool IsFullyOverwritten =
false);
400 void UpdateStructuredListElement(
InitListExpr *StructuredList,
401 unsigned &StructuredIndex,
405 unsigned ExpectedNumInits);
406 int numArrayElements(
QualType DeclType);
407 int numStructUnionElements(
QualType DeclType);
415 bool UnionOverride =
false,
416 bool FullyOverwritten =
true) {
421 ? (UnionOverride ? diag::ext_initializer_union_overrides
422 : diag::ext_initializer_overrides)
423 : diag::warn_initializer_overrides;
425 if (InOverloadResolution && SemaRef.
getLangOpts().CPlusPlus) {
446 DiagID = diag::err_initializer_overrides_destructed;
466 << NewInitRange << FullyOverwritten << OldInit->
getType();
495 bool FillWithNoInit);
496 void FillInEmptyInitForField(
unsigned Init,
FieldDecl *Field,
499 bool FillWithNoInit =
false);
503 bool FillWithNoInit =
false);
506 bool TopLevelObject);
511 Expr *Result =
nullptr;
523 assert(AType &&
"expected array type when initializing array");
525 if (
const auto *CAType = dyn_cast<ConstantArrayType>(AType))
526 ElsCount = std::min(CAType->getSize().getZExtValue(),
527 ElsCount - CurEmbedIndex);
537 CurEmbedIndex, ElsCount);
538 CurEmbedIndex += ElsCount;
549 bool VerifyOnly,
bool TreatUnavailableAsInvalid,
550 bool InOverloadResolution =
false,
555 : InitListChecker(S, Entity, IL,
T,
true,
558 &AggrDeductionCandidateParamTypes) {}
560 bool HadError() {
return hadError; }
564 InitListExpr *getFullyStructuredList()
const {
return FullyStructuredList; }
581 bool EmptyInitList = SemaRef.
getLangOpts().CPlusPlus11 &&
594 InitExpr = VerifyOnly ? &DummyInitList
611 if (!InitSeq && EmptyInitList && InitSeq.getFailureKind() ==
615 InitSeq.getFailedCandidateSet()
616 .BestViableFunction(SemaRef,
Kind.getLocation(), Best);
618 assert(O ==
OR_Success &&
"Inconsistent overload resolution");
625 bool IsInStd =
false;
627 ND && !IsInStd; ND = dyn_cast<NamespaceDecl>(ND->getParent())) {
632 if (IsInStd && llvm::StringSwitch<bool>(R->
getName())
633 .Cases(
"basic_string",
"deque",
"forward_list",
true)
634 .Cases(
"list",
"map",
"multimap",
"multiset",
true)
635 .Cases(
"priority_queue",
"queue",
"set",
"stack",
true)
636 .Cases(
"unordered_map",
"unordered_set",
"vector",
true)
638 InitSeq.InitializeFrom(
642 TreatUnavailableAsInvalid);
647 diag::warn_invalid_initializer_from_system_header);
650 diag::note_used_in_initialization_here);
652 SemaRef.
Diag(
Loc, diag::note_used_in_initialization_here);
659 InitSeq.Diagnose(SemaRef, Entity, Kind, SubInit);
662 diag::note_in_omitted_aggregate_initializer)
665 bool IsTrailingArrayNewMember =
668 SemaRef.
Diag(
Loc, diag::note_in_omitted_aggregate_initializer)
669 << (IsTrailingArrayNewMember ? 2 : 0)
678 : InitSeq.Perform(SemaRef, Entity,
Kind, SubInit);
686 if (FullyStructuredList)
688 PerformEmptyInit(
Loc, Entity);
691void InitListChecker::FillInEmptyInitForBase(
694 bool &RequiresSecondPass,
bool FillWithNoInit) {
701 : PerformEmptyInit(ILE->
getEndLoc(), BaseEntity);
708 assert(Init < ILE->getNumInits() &&
"should have been expanded");
713 FillInEmptyInitializations(BaseEntity, InnerILE, RequiresSecondPass,
714 ILE,
Init, FillWithNoInit);
716 dyn_cast<DesignatedInitUpdateExpr>(ILE->
getInit(
Init))) {
717 FillInEmptyInitializations(BaseEntity, InnerDIUE->getUpdater(),
718 RequiresSecondPass, ILE,
Init,
723void InitListChecker::FillInEmptyInitForField(
unsigned Init,
FieldDecl *Field,
726 bool &RequiresSecondPass,
727 bool FillWithNoInit) {
735 if (!RType->getDecl()->isUnion())
736 assert((
Init < NumInits || VerifyOnly) &&
737 "This ILE should have been expanded");
739 if (FillWithNoInit) {
740 assert(!VerifyOnly &&
"should not fill with no-init in verify-only mode");
749 if (!VerifyOnly &&
Field->hasAttr<ExplicitInitAttr>()) {
750 SemaRef.
Diag(ILE->
getExprLoc(), diag::warn_field_requires_explicit_init)
752 SemaRef.
Diag(
Field->getLocation(), diag::note_entity_declared_at)
760 if (
Field->hasInClassInitializer()) {
790 RequiresSecondPass =
true;
795 if (
Field->getType()->isReferenceType()) {
801 SemaRef.
Diag(
Loc, diag::err_init_reference_member_uninitialized)
805 SemaRef.
Diag(
Field->getLocation(), diag::note_uninit_reference_member);
817 if (hadError || VerifyOnly) {
819 }
else if (
Init < NumInits) {
821 }
else if (!isa<ImplicitValueInitExpr>(MemberInit.
get())) {
827 RequiresSecondPass =
true;
831 FillInEmptyInitializations(MemberEntity, InnerILE,
832 RequiresSecondPass, ILE,
Init, FillWithNoInit);
834 dyn_cast<DesignatedInitUpdateExpr>(ILE->
getInit(
Init))) {
835 FillInEmptyInitializations(MemberEntity, InnerDIUE->getUpdater(),
836 RequiresSecondPass, ILE,
Init,
847 bool &RequiresSecondPass,
850 bool FillWithNoInit) {
852 "Should not have void type");
856 if (FillWithNoInit && VerifyOnly)
866 struct UpdateOuterILEWithUpdatedInit {
869 ~UpdateOuterILEWithUpdatedInit() {
873 } UpdateOuterRAII = {OuterILE, OuterIndex};
884 RequiresSecondPass, FillWithNoInit);
886 assert((!RDecl->
isUnion() || !isa<CXXRecordDecl>(RDecl) ||
887 !cast<CXXRecordDecl>(RDecl)->hasInClassInitializer()) &&
888 "We should have computed initialized fields already");
892 unsigned NumElems = numStructUnionElements(ILE->
getType());
900 if (
auto *CXXRD = dyn_cast<CXXRecordDecl>(RDecl)) {
901 for (
auto &
Base : CXXRD->bases()) {
905 FillInEmptyInitForBase(
Init,
Base, Entity, ILE, RequiresSecondPass,
911 for (
auto *Field : RDecl->
fields()) {
912 if (
Field->isUnnamedBitField())
918 FillInEmptyInitForField(
Init, Field, Entity, ILE, RequiresSecondPass,
940 ElementType = AType->getElementType();
941 if (
const auto *CAType = dyn_cast<ConstantArrayType>(AType))
942 NumElements = CAType->getZExtSize();
950 ElementType = VType->getElementType();
951 NumElements = VType->getNumElements();
957 bool SkipEmptyInitChecks =
false;
970 if (!InitExpr && Init < NumInits && ILE->hasArrayFiller())
975 if (SkipEmptyInitChecks)
978 Expr *Filler =
nullptr;
984 PerformEmptyInit(ILE->
getEndLoc(), ElementEntity);
995 }
else if (VerifyOnly) {
996 SkipEmptyInitChecks =
true;
997 }
else if (
Init < NumInits) {
1012 if (!isa<ImplicitValueInitExpr>(Filler) && !isa<NoInitExpr>(Filler)) {
1018 RequiresSecondPass =
true;
1022 = dyn_cast_or_null<InitListExpr>(InitExpr)) {
1023 FillInEmptyInitializations(ElementEntity, InnerILE, RequiresSecondPass,
1024 ILE,
Init, FillWithNoInit);
1026 dyn_cast_or_null<DesignatedInitUpdateExpr>(InitExpr)) {
1027 FillInEmptyInitializations(ElementEntity, InnerDIUE->getUpdater(),
1028 RequiresSecondPass, ILE,
Init,
1036 if (isa_and_nonnull<DesignatedInitExpr>(
Init))
1041InitListChecker::InitListChecker(
1043 bool VerifyOnly,
bool TreatUnavailableAsInvalid,
bool InOverloadResolution,
1045 : SemaRef(S), VerifyOnly(VerifyOnly),
1046 TreatUnavailableAsInvalid(TreatUnavailableAsInvalid),
1047 InOverloadResolution(InOverloadResolution),
1048 AggrDeductionCandidateParamTypes(AggrDeductionCandidateParamTypes) {
1050 FullyStructuredList =
1059 CheckExplicitInitList(Entity, IL,
T, FullyStructuredList,
1062 if (!hadError && !AggrDeductionCandidateParamTypes && FullyStructuredList) {
1063 bool RequiresSecondPass =
false;
1064 FillInEmptyInitializations(Entity, FullyStructuredList, RequiresSecondPass,
1066 if (RequiresSecondPass && !hadError)
1067 FillInEmptyInitializations(Entity, FullyStructuredList,
1068 RequiresSecondPass,
nullptr, 0);
1070 if (hadError && FullyStructuredList)
1074int InitListChecker::numArrayElements(
QualType DeclType) {
1076 int maxElements = 0x7FFFFFFF;
1079 maxElements =
static_cast<int>(CAT->getZExtSize());
1084int InitListChecker::numStructUnionElements(
QualType DeclType) {
1086 int InitializableMembers = 0;
1087 if (
auto *CXXRD = dyn_cast<CXXRecordDecl>(structDecl))
1088 InitializableMembers += CXXRD->getNumBases();
1089 for (
const auto *Field : structDecl->
fields())
1090 if (!
Field->isUnnamedBitField())
1091 ++InitializableMembers;
1094 return std::min(InitializableMembers, 1);
1100 return RT->getDecl();
1102 return Inject->getDecl();
1132 if (
CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(ParentRD)) {
1133 if (CXXRD->getNumBases()) {
1137 auto FieldIt = ParentRD->field_begin();
1138 assert(FieldIt != ParentRD->field_end() &&
1139 "no fields but have initializer for member?");
1140 return ++FieldIt == ParentRD->field_end();
1156 unsigned &StructuredIndex) {
1157 int maxElements = 0;
1160 maxElements = numArrayElements(
T);
1162 maxElements = numStructUnionElements(
T);
1166 llvm_unreachable(
"CheckImplicitInitList(): Illegal type");
1168 if (maxElements == 0) {
1171 diag::err_implicit_empty_initializer);
1178 InitListExpr *StructuredSubobjectInitList = getStructuredSubobjectInit(
1179 ParentIList, Index,
T, StructuredList, StructuredIndex,
1182 unsigned StructuredSubobjectInitIndex = 0;
1185 unsigned StartIndex = Index;
1186 CheckListElementTypes(Entity, ParentIList,
T,
1188 StructuredSubobjectInitList,
1189 StructuredSubobjectInitIndex);
1191 if (StructuredSubobjectInitList) {
1192 StructuredSubobjectInitList->
setType(
T);
1194 unsigned EndIndex = (Index == StartIndex? StartIndex : Index - 1);
1197 if (EndIndex < ParentIList->getNumInits() &&
1198 ParentIList->
getInit(EndIndex)) {
1209 diag::warn_missing_braces)
1215 StructuredSubobjectInitList->
getEndLoc()),
1221 if (!VerifyOnly && CXXRD && CXXRD->hasUserDeclaredConstructor()) {
1223 diag::warn_cxx20_compat_aggregate_init_with_ctors)
1239 unsigned DiagID = 0;
1251 DiagID = diag::warn_braces_around_init;
1258 DiagID = diag::warn_braces_around_init;
1284 llvm_unreachable(
"unexpected braced scalar init");
1303 bool TopLevelObject) {
1304 unsigned Index = 0, StructuredIndex = 0;
1305 CheckListElementTypes(Entity, IList,
T,
true,
1306 Index, StructuredList, StructuredIndex, TopLevelObject);
1307 if (StructuredList) {
1313 StructuredList->
setType(ExprTy);
1321 bool ExtraInitsIsError = SemaRef.
getLangOpts().CPlusPlus ||
1323 hadError = ExtraInitsIsError;
1326 }
else if (StructuredIndex == 1 &&
1331 ? diag::err_excess_initializers_in_char_array_initializer
1332 : diag::ext_excess_initializers_in_char_array_initializer;
1336 unsigned DK = ExtraInitsIsError
1337 ? diag::err_excess_initializers_for_sizeless_type
1338 : diag::ext_excess_initializers_for_sizeless_type;
1348 unsigned DK = ExtraInitsIsError ? diag::err_excess_initializers
1349 : diag::ext_excess_initializers;
1357 !isa<InitListExpr>(IList->
getInit(0)))
1363 if (CXXRD && CXXRD->hasUserDeclaredConstructor()) {
1366 bool HasEquivCtor =
false;
1372 if (!HasEquivCtor) {
1374 diag::warn_cxx20_compat_aggregate_init_with_ctors)
1384 bool SubobjectIsDesignatorContext,
1387 unsigned &StructuredIndex,
1388 bool TopLevelObject) {
1392 CheckComplexType(Entity, IList, DeclType, Index,
1393 StructuredList, StructuredIndex);
1395 CheckScalarType(Entity, IList, DeclType, Index,
1396 StructuredList, StructuredIndex);
1398 CheckVectorType(Entity, IList, DeclType, Index,
1399 StructuredList, StructuredIndex);
1400 }
else if (
const RecordDecl *RD = getRecordDecl(DeclType)) {
1406 "non-aggregate records should be handed in CheckSubElementType");
1407 if (
auto *CXXRD = dyn_cast<CXXRecordDecl>(RD))
1408 Bases = CXXRD->bases();
1410 Bases = cast<CXXRecordDecl>(RD)->bases();
1412 CheckStructUnionTypes(Entity, IList, DeclType, Bases, RD->field_begin(),
1413 SubobjectIsDesignatorContext, Index, StructuredList,
1414 StructuredIndex, TopLevelObject);
1419 CheckArrayType(Entity, IList, DeclType, Zero,
1420 SubobjectIsDesignatorContext, Index,
1421 StructuredList, StructuredIndex);
1426 SemaRef.
Diag(IList->
getBeginLoc(), diag::err_illegal_initializer_type)
1430 CheckReferenceType(Entity, IList, DeclType, Index,
1431 StructuredList, StructuredIndex);
1434 SemaRef.
Diag(IList->
getBeginLoc(), diag::err_init_objc_class) << DeclType;
1439 CheckScalarType(Entity, IList, DeclType, Index, StructuredList,
1446 assert(AggrDeductionCandidateParamTypes);
1447 AggrDeductionCandidateParamTypes->push_back(DeclType);
1450 SemaRef.
Diag(IList->
getBeginLoc(), diag::err_illegal_initializer_type)
1461 unsigned &StructuredIndex,
1462 bool DirectlyDesignated) {
1466 return CheckReferenceType(Entity, IList, ElemType, Index,
1467 StructuredList, StructuredIndex);
1470 if (SubInitList->getNumInits() == 1 &&
1475 expr = SubInitList->getInit(0);
1478 }
else if (isa<ImplicitValueInitExpr>(
expr)) {
1482 "found implicit initialization for the wrong type");
1483 UpdateStructuredListElement(StructuredList, StructuredIndex,
expr);
1505 if (TmpEntity.getType()->isDependentType()) {
1510 assert(AggrDeductionCandidateParamTypes);
1524 if (isa<InitListExpr, DesignatedInitExpr>(
expr) ||
1525 !isa_and_present<ConstantArrayType>(
1528 AggrDeductionCandidateParamTypes->push_back(ElemType);
1540 if (
Seq || isa<InitListExpr>(
expr)) {
1541 if (
auto *Embed = dyn_cast<EmbedExpr>(
expr)) {
1542 expr = HandleEmbed(Embed, Entity);
1546 if (Result.isInvalid())
1549 UpdateStructuredListElement(StructuredList, StructuredIndex,
1550 Result.getAs<
Expr>());
1553 }
else if (StructuredList) {
1554 UpdateStructuredListElement(StructuredList, StructuredIndex,
1559 if (AggrDeductionCandidateParamTypes)
1560 AggrDeductionCandidateParamTypes->push_back(ElemType);
1568 return CheckScalarType(Entity, IList, ElemType, Index,
1569 StructuredList, StructuredIndex);
1583 UpdateStructuredListElement(StructuredList, StructuredIndex,
expr);
1612 UpdateStructuredListElement(StructuredList, StructuredIndex,
1630 CheckImplicitInitList(Entity, IList, ElemType, Index, StructuredList,
1635 if (DirectlyDesignated && SemaRef.
getLangOpts().CPlusPlus && !hadError) {
1636 if (InOverloadResolution)
1640 diag::ext_designated_init_brace_elision)
1641 <<
expr->getSourceRange()
1656 assert(
Copy.isInvalid() &&
1657 "expected non-aggregate initialization to fail");
1669 unsigned &StructuredIndex) {
1670 assert(Index == 0 &&
"Index in explicit init list must be zero");
1680 return CheckScalarType(Entity, IList, DeclType, Index, StructuredList,
1685 if (!SemaRef.
getLangOpts().CPlusPlus && !VerifyOnly)
1694 for (
unsigned i = 0; i < 2; ++i) {
1696 CheckSubElementType(ElementEntity, IList, elementType, Index,
1697 StructuredList, StructuredIndex);
1705 unsigned &StructuredIndex) {
1712 ? diag::warn_cxx98_compat_empty_sizeless_initializer
1713 : diag::err_empty_sizeless_initializer)
1718 ? diag::warn_cxx98_compat_empty_scalar_initializer
1719 : diag::err_empty_scalar_initializer)
1735 SemaRef.
Diag(SubIList->getBeginLoc(), diag::ext_many_braces_around_init)
1738 CheckScalarType(Entity, SubIList, DeclType, Index, StructuredList,
1741 }
else if (isa<DesignatedInitExpr>(
expr)) {
1744 diag::err_designator_for_scalar_or_sizeless_init)
1746 <<
expr->getSourceRange();
1751 }
else if (
auto *Embed = dyn_cast<EmbedExpr>(
expr)) {
1752 expr = HandleEmbed(Embed, Entity);
1758 Result = getDummyInit();
1767 Expr *ResultExpr =
nullptr;
1769 if (Result.isInvalid())
1772 ResultExpr = Result.getAs<
Expr>();
1774 if (ResultExpr !=
expr && !VerifyOnly && !CurEmbed) {
1777 IList->
setInit(Index, ResultExpr);
1781 UpdateStructuredListElement(StructuredList, StructuredIndex, ResultExpr);
1784 if (AggrDeductionCandidateParamTypes)
1785 AggrDeductionCandidateParamTypes->push_back(DeclType);
1792 unsigned &StructuredIndex) {
1800 diag::err_init_reference_member_uninitialized)
1822 Result = getDummyInit();
1831 if (Result.isInvalid())
1836 if (!VerifyOnly &&
expr)
1839 UpdateStructuredListElement(StructuredList, StructuredIndex,
expr);
1841 if (AggrDeductionCandidateParamTypes)
1842 AggrDeductionCandidateParamTypes->push_back(DeclType);
1849 unsigned &StructuredIndex) {
1852 unsigned numEltsInit = 0;
1857 CheckEmptyInitializable(
1867 if (!isa<InitListExpr>(
Init) &&
Init->getType()->isVectorType()) {
1871 Result = getDummyInit();
1880 Expr *ResultExpr =
nullptr;
1881 if (Result.isInvalid())
1884 ResultExpr = Result.getAs<
Expr>();
1886 if (ResultExpr !=
Init && !VerifyOnly) {
1889 IList->
setInit(Index, ResultExpr);
1892 UpdateStructuredListElement(StructuredList, StructuredIndex, ResultExpr);
1894 if (AggrDeductionCandidateParamTypes)
1895 AggrDeductionCandidateParamTypes->push_back(elementType);
1902 for (
unsigned i = 0; i < maxElements; ++i, ++numEltsInit) {
1905 CheckEmptyInitializable(ElementEntity, IList->
getEndLoc());
1910 CheckSubElementType(ElementEntity, IList, elementType, Index,
1911 StructuredList, StructuredIndex);
1919 if (isBigEndian && (
T->getVectorKind() == VectorKind::Neon ||
1920 T->getVectorKind() == VectorKind::NeonPoly)) {
1932 diag::warn_neon_vector_initializer_non_portable);
1934 const char *typeCode;
1944 llvm_unreachable(
"Invalid element type!");
1948 ? diag::note_neon_vector_initializer_non_portable_q
1949 : diag::note_neon_vector_initializer_non_portable)
1950 << typeCode << typeSize;
1960 for (
unsigned i = 0; i < maxElements; ++i) {
1969 CheckSubElementType(ElementEntity, IList, elementType, Index,
1970 StructuredList, StructuredIndex);
1982 CheckSubElementType(ElementEntity, IList, VecType, Index,
1983 StructuredList, StructuredIndex);
1984 numEltsInit += numIElts;
1989 if (numEltsInit != maxElements) {
1992 diag::err_vector_incorrect_num_elements)
1993 << (numEltsInit < maxElements) << maxElements << numEltsInit
2020 SemaRef.
PDiag(diag::err_access_dtor_temp)
2034 InitType =
Parent->getType();
2040 ExprList.size() == 1
2041 ? dyn_cast_if_present<EmbedExpr>(ExprList[0]->IgnoreParens())
2056 llvm::APSInt elementIndex,
2057 bool SubobjectIsDesignatorContext,
2060 unsigned &StructuredIndex) {
2078 if (Index < IList->getNumInits()) {
2091 if (StructuredList) {
2092 UpdateStructuredListElement(StructuredList, StructuredIndex,
2097 if (AggrDeductionCandidateParamTypes)
2098 AggrDeductionCandidateParamTypes->push_back(DeclType);
2119 SemaRef.
Diag(VAT->getSizeExpr()->getBeginLoc(),
2120 diag::err_variable_object_no_init)
2121 << VAT->getSizeExpr()->getSourceRange();
2130 llvm::APSInt maxElements(elementIndex.getBitWidth(),
2131 elementIndex.isUnsigned());
2132 bool maxElementsKnown =
false;
2134 maxElements = CAT->getSize();
2135 elementIndex = elementIndex.extOrTrunc(maxElements.getBitWidth());
2136 elementIndex.setIsUnsigned(maxElements.isUnsigned());
2137 maxElementsKnown =
true;
2141 while (Index < IList->getNumInits()) {
2147 if (!SubobjectIsDesignatorContext)
2152 if (CheckDesignatedInitializer(Entity, IList, DIE, 0,
2153 DeclType,
nullptr, &elementIndex, Index,
2154 StructuredList, StructuredIndex,
true,
2160 if (elementIndex.getBitWidth() > maxElements.getBitWidth())
2161 maxElements = maxElements.extend(elementIndex.getBitWidth());
2162 else if (elementIndex.getBitWidth() < maxElements.getBitWidth())
2163 elementIndex = elementIndex.extend(maxElements.getBitWidth());
2164 elementIndex.setIsUnsigned(maxElements.isUnsigned());
2168 if (!maxElementsKnown && elementIndex > maxElements)
2169 maxElements = elementIndex;
2176 if (maxElementsKnown && elementIndex == maxElements)
2180 SemaRef.
Context, StructuredIndex, Entity);
2182 unsigned EmbedElementIndexBeforeInit = CurEmbedIndex;
2184 CheckSubElementType(ElementEntity, IList, elementType, Index,
2185 StructuredList, StructuredIndex);
2190 elementIndex + CurEmbedIndex - EmbedElementIndexBeforeInit - 1;
2192 auto Embed = cast<EmbedExpr>(
Init);
2194 EmbedElementIndexBeforeInit - 1;
2200 if (!maxElementsKnown && elementIndex > maxElements)
2201 maxElements = elementIndex;
2206 llvm::APSInt
Zero(maxElements.getBitWidth(), maxElements.isUnsigned());
2210 SemaRef.
Diag(IList->
getBeginLoc(), diag::ext_typecheck_zero_array_size);
2214 elementType, maxElements,
nullptr, ArraySizeModifier::Normal, 0);
2221 if ((maxElementsKnown && elementIndex < maxElements) ||
2223 CheckEmptyInitializable(
2232 bool TopLevelObject) {
2234 unsigned FlexArrayDiag;
2235 if (isa<InitListExpr>(InitExpr) &&
2236 cast<InitListExpr>(InitExpr)->getNumInits() == 0) {
2238 FlexArrayDiag = diag::ext_flexible_array_init;
2239 }
else if (!TopLevelObject) {
2241 FlexArrayDiag = diag::err_flexible_array_init;
2244 FlexArrayDiag = diag::err_flexible_array_init;
2245 }
else if (cast<VarDecl>(Entity.
getDecl())->hasLocalStorage()) {
2247 FlexArrayDiag = diag::err_flexible_array_init;
2250 FlexArrayDiag = diag::ext_flexible_array_init;
2256 SemaRef.
Diag(
Field->getLocation(), diag::note_flexible_array_member)
2260 return FlexArrayDiag != diag::ext_flexible_array_init;
2264 return StructuredList && StructuredList->
getNumInits() == 1U;
2267void InitListChecker::CheckStructUnionTypes(
2270 bool SubobjectIsDesignatorContext,
unsigned &Index,
2271 InitListExpr *StructuredList,
unsigned &StructuredIndex,
2272 bool TopLevelObject) {
2273 const RecordDecl *RD = getRecordDecl(DeclType);
2295 if (isa<CXXRecordDecl>(RD) &&
2296 cast<CXXRecordDecl>(RD)->hasInClassInitializer()) {
2297 if (!StructuredList)
2300 Field != FieldEnd; ++Field) {
2301 if (
Field->hasInClassInitializer() ||
2302 (
Field->isAnonymousStructOrUnion() &&
2303 Field->getType()->getAsCXXRecordDecl()->hasInClassInitializer())) {
2309 llvm_unreachable(
"Couldn't find in-class initializer");
2315 Field != FieldEnd; ++Field) {
2316 if (!
Field->isUnnamedBitField()) {
2317 CheckEmptyInitializable(
2328 bool InitializedSomething =
false;
2331 for (
auto I = Bases.begin(),
E = Bases.end(); I !=
E; ++I) {
2337 if (isa_and_nonnull<DesignatedInitExpr>(
Init))
2354 if (AggrDeductionCandidateParamTypes &&
Base.isPackExpansion()) {
2355 AggrDeductionCandidateParamTypes->push_back(
2360 if (Index < IList->getNumInits())
2372 CheckSubElementType(BaseEntity, IList,
Base.getType(), Index,
2373 StructuredList, StructuredIndex);
2374 InitializedSomething =
true;
2376 CheckEmptyInitializable(BaseEntity, InitLoc);
2391 size_t NumRecordDecls = llvm::count_if(RD->
decls(), [&](
const Decl *
D) {
2392 return isa<FieldDecl>(D) || isa<RecordDecl>(D);
2394 bool HasDesignatedInit =
false;
2398 while (Index < IList->getNumInits()) {
2406 if (!SubobjectIsDesignatorContext)
2409 HasDesignatedInit =
true;
2413 bool DesignatedInitFailed = CheckDesignatedInitializer(
2414 Entity, IList, DIE, 0, DeclType, &Field,
nullptr, Index,
2415 StructuredList, StructuredIndex,
true, TopLevelObject);
2416 if (DesignatedInitFailed)
2421 if (!VerifyOnly &&
D->isFieldDesignator()) {
2423 InitializedFields.insert(F);
2424 if (!DesignatedInitFailed) {
2433 InitializedSomething =
true;
2450 if (NumRecordDecls == 1)
2452 if (
const auto *IL = dyn_cast<IntegerLiteral>(I))
2453 return IL->getValue().isZero();
2461 SemaRef.
Diag(InitLoc, diag::err_non_designated_init_used);
2466 if (Field == FieldEnd) {
2472 if (InitializedSomething && RD->
isUnion())
2476 if (
Field->getType()->isIncompleteArrayType())
2479 if (
Field->isUnnamedBitField()) {
2488 InvalidUse = !SemaRef.
CanUseDecl(*Field, TreatUnavailableAsInvalid);
2509 CheckSubElementType(MemberEntity, IList,
Field->getType(), Index,
2510 StructuredList, StructuredIndex);
2511 InitializedSomething =
true;
2512 InitializedFields.insert(*Field);
2524 bool IsCDesignatedInitializer =
2525 HasDesignatedInit && !SemaRef.
getLangOpts().CPlusPlus;
2526 if (!VerifyOnly && InitializedSomething && !RD->
isUnion() &&
2528 !IsCDesignatedInitializer) {
2535 if (HasDesignatedInit && InitializedFields.count(*it))
2538 if (!it->isUnnamedBitField() && !it->hasInClassInitializer() &&
2539 !it->getType()->isIncompleteArrayType()) {
2540 auto Diag = HasDesignatedInit
2541 ? diag::warn_missing_designated_field_initializers
2542 : diag::warn_missing_field_initializers;
2551 if (!StructuredList && Field != FieldEnd && !RD->
isUnion() &&
2552 !
Field->getType()->isIncompleteArrayType()) {
2553 for (;
Field != FieldEnd && !hadError; ++
Field) {
2554 if (!
Field->isUnnamedBitField() && !
Field->hasInClassInitializer())
2555 CheckEmptyInitializable(
2576 if (Field == FieldEnd || !
Field->getType()->isIncompleteArrayType() ||
2580 if (CheckFlexibleArrayInit(Entity, IList->
getInit(Index), *Field,
2590 if (isa<InitListExpr>(IList->
getInit(Index)) ||
2591 AggrDeductionCandidateParamTypes)
2592 CheckSubElementType(MemberEntity, IList,
Field->getType(), Index,
2593 StructuredList, StructuredIndex);
2595 CheckImplicitInitList(MemberEntity, IList,
Field->getType(), Index,
2596 StructuredList, StructuredIndex);
2617 PE = IndirectField->
chain_end(); PI != PE; ++PI) {
2625 assert(isa<FieldDecl>(*PI));
2626 Replacements.back().setFieldDecl(cast<FieldDecl>(*PI));
2633 &Replacements[0] + Replacements.size());
2640 for (
unsigned I = 0; I < NumIndexExprs; ++I)
2654 explicit FieldInitializerValidatorCCC(
const RecordDecl *RD)
2662 std::unique_ptr<CorrectionCandidateCallback>
clone()
override {
2663 return std::make_unique<FieldInitializerValidatorCCC>(*
this);
2716 llvm::APSInt *NextElementIndex,
2719 unsigned &StructuredIndex,
2720 bool FinishSubobjectInit,
2721 bool TopLevelObject) {
2722 if (DesigIdx == DIE->
size()) {
2729 assert(isa<InitListExpr>(
Init) &&
2730 "designator result in direct non-list initialization?");
2735 if (StructuredList) {
2739 UpdateStructuredListElement(StructuredList, StructuredIndex,
2743 if (AggrDeductionCandidateParamTypes)
2744 AggrDeductionCandidateParamTypes->push_back(CurrentObjectType);
2749 bool prevHadError = hadError;
2754 unsigned OldIndex = Index;
2757 CheckSubElementType(Entity, IList, CurrentObjectType, Index, StructuredList,
2758 StructuredIndex,
true);
2764 IList->
setInit(OldIndex, DIE);
2766 return hadError && !prevHadError;
2770 bool IsFirstDesignator = (DesigIdx == 0);
2771 if (IsFirstDesignator ? FullyStructuredList : StructuredList) {
2774 if (IsFirstDesignator)
2775 StructuredList = FullyStructuredList;
2777 Expr *ExistingInit = StructuredIndex < StructuredList->getNumInits() ?
2778 StructuredList->getInit(StructuredIndex) :
nullptr;
2779 if (!ExistingInit && StructuredList->hasArrayFiller())
2780 ExistingInit = StructuredList->getArrayFiller();
2783 StructuredList = getStructuredSubobjectInit(
2784 IList, Index, CurrentObjectType, StructuredList, StructuredIndex,
2786 else if (
InitListExpr *Result = dyn_cast<InitListExpr>(ExistingInit))
2787 StructuredList = Result;
2800 diagnoseInitOverride(ExistingInit,
2807 dyn_cast<DesignatedInitUpdateExpr>(ExistingInit))
2808 StructuredList =
E->getUpdater();
2813 StructuredList->updateInit(SemaRef.
Context, StructuredIndex, DIUE);
2822 StructuredList =
nullptr;
2828 if (
D->isFieldDesignator()) {
2838 RecordDecl *RD = getRecordDecl(CurrentObjectType);
2842 Loc =
D->getFieldLoc();
2844 SemaRef.
Diag(
Loc, diag::err_field_designator_non_aggr)
2845 << SemaRef.
getLangOpts().CPlusPlus << CurrentObjectType;
2854 if (
auto *FD = dyn_cast_if_present<FieldDecl>(VD)) {
2856 }
else if (
auto *IFD = dyn_cast_if_present<IndirectFieldDecl>(VD)) {
2862 KnownField = cast<FieldDecl>(*IFD->chain_begin());
2879 SemaRef.
Diag(
D->getFieldLoc(), diag::err_field_designator_nonfield)
2881 SemaRef.
Diag(Lookup.front()->getLocation(),
2882 diag::note_field_designator_found);
2889 FieldInitializerValidatorCCC CCC(RD);
2896 SemaRef.
PDiag(diag::err_field_designator_unknown_suggest)
2897 << FieldName << CurrentObjectType);
2898 KnownField = Corrected.getCorrectionDeclAs<
FieldDecl>();
2909 SemaRef.
Diag(
Loc, diag::err_field_designator_unknown)
2917 unsigned NumBases = 0;
2918 if (
auto *CXXRD = dyn_cast<CXXRecordDecl>(RD))
2919 NumBases = CXXRD->getNumBases();
2921 unsigned FieldIndex = NumBases;
2923 for (
auto *FI : RD->
fields()) {
2924 if (FI->isUnnamedBitField())
2940 if (StructuredList) {
2941 FieldDecl *CurrentField = StructuredList->getInitializedFieldInUnion();
2943 assert(StructuredList->getNumInits() == 1
2944 &&
"A union should never have more than one initializer!");
2946 Expr *ExistingInit = StructuredList->getInit(0);
2949 diagnoseInitOverride(
2957 StructuredList->resizeInits(SemaRef.
Context, 0);
2958 StructuredList->setInitializedFieldInUnion(
nullptr);
2961 StructuredList->setInitializedFieldInUnion(*Field);
2968 InvalidUse = !SemaRef.
CanUseDecl(*Field, TreatUnavailableAsInvalid);
2991 if (IsFirstDesignator && !VerifyOnly && SemaRef.
getLangOpts().CPlusPlus &&
2994 (*NextField)->getFieldIndex() >
Field->getFieldIndex() + 1)) {
2998 if (FI->isUnnamedBitField())
3009 diag::ext_designated_init_reordered)
3012 unsigned OldIndex = StructuredIndex - 1;
3013 if (StructuredList && OldIndex <= StructuredList->getNumInits()) {
3014 if (
Expr *PrevInit = StructuredList->getInit(OldIndex)) {
3015 SemaRef.
Diag(PrevInit->getBeginLoc(),
3016 diag::note_previous_field_init)
3026 D->setFieldDecl(*Field);
3030 if (StructuredList && FieldIndex >= StructuredList->getNumInits())
3031 StructuredList->resizeInits(SemaRef.
Context, FieldIndex + 1);
3034 if (
Field->getType()->isIncompleteArrayType()) {
3036 if ((DesigIdx + 1) != DIE->
size()) {
3043 diag::err_designator_into_flexible_array_member)
3045 SemaRef.
Diag(
Field->getLocation(), diag::note_flexible_array_member)
3051 if (!hadError && !isa<InitListExpr>(DIE->
getInit()) &&
3052 !isa<StringLiteral>(DIE->
getInit())) {
3056 diag::err_flexible_array_init_needs_braces)
3058 SemaRef.
Diag(
Field->getLocation(), diag::note_flexible_array_member)
3065 if (!
Invalid && CheckFlexibleArrayInit(Entity, DIE->
getInit(), *Field,
3075 bool prevHadError = hadError;
3076 unsigned newStructuredIndex = FieldIndex;
3077 unsigned OldIndex = Index;
3082 CheckSubElementType(MemberEntity, IList,
Field->getType(), Index,
3083 StructuredList, newStructuredIndex);
3085 IList->
setInit(OldIndex, DIE);
3086 if (hadError && !prevHadError) {
3091 StructuredIndex = FieldIndex;
3097 unsigned newStructuredIndex = FieldIndex;
3101 if (CheckDesignatedInitializer(MemberEntity, IList, DIE, DesigIdx + 1,
3102 FieldType,
nullptr,
nullptr, Index,
3103 StructuredList, newStructuredIndex,
3104 FinishSubobjectInit,
false))
3115 if (IsFirstDesignator) {
3122 StructuredIndex = FieldIndex;
3126 if (!FinishSubobjectInit)
3134 bool prevHadError = hadError;
3139 CheckStructUnionTypes(Entity, IList, CurrentObjectType, NoBases, Field,
3140 false, Index, StructuredList, FieldIndex);
3141 return hadError && !prevHadError;
3162 SemaRef.
Diag(
D->getLBracketLoc(), diag::err_array_designator_non_array)
3163 << CurrentObjectType;
3168 Expr *IndexExpr =
nullptr;
3169 llvm::APSInt DesignatedStartIndex, DesignatedEndIndex;
3170 if (
D->isArrayDesignator()) {
3173 DesignatedEndIndex = DesignatedStartIndex;
3175 assert(
D->isArrayRangeDesignator() &&
"Need array-range designator");
3177 DesignatedStartIndex =
3179 DesignatedEndIndex =
3188 if (DesignatedStartIndex.getZExtValue()!=DesignatedEndIndex.getZExtValue()&&
3193 if (isa<ConstantArrayType>(AT)) {
3194 llvm::APSInt MaxElements(cast<ConstantArrayType>(AT)->getSize(),
false);
3195 DesignatedStartIndex
3196 = DesignatedStartIndex.extOrTrunc(MaxElements.getBitWidth());
3197 DesignatedStartIndex.setIsUnsigned(MaxElements.isUnsigned());
3199 = DesignatedEndIndex.extOrTrunc(MaxElements.getBitWidth());
3200 DesignatedEndIndex.setIsUnsigned(MaxElements.isUnsigned());
3201 if (DesignatedEndIndex >= MaxElements) {
3204 diag::err_array_designator_too_large)
3211 unsigned DesignatedIndexBitWidth =
3213 DesignatedStartIndex =
3214 DesignatedStartIndex.extOrTrunc(DesignatedIndexBitWidth);
3215 DesignatedEndIndex =
3216 DesignatedEndIndex.extOrTrunc(DesignatedIndexBitWidth);
3217 DesignatedStartIndex.setIsUnsigned(
true);
3218 DesignatedEndIndex.setIsUnsigned(
true);
3221 bool IsStringLiteralInitUpdate =
3222 StructuredList && StructuredList->isStringLiteralInit();
3223 if (IsStringLiteralInitUpdate && VerifyOnly) {
3226 StructuredList =
nullptr;
3227 }
else if (IsStringLiteralInitUpdate) {
3240 unsigned PromotedCharTyWidth = Context.
getTypeSize(PromotedCharTy);
3245 if (cast<ConstantArrayType>(AT)->getSize().ult(StrLen))
3246 StrLen = cast<ConstantArrayType>(AT)->getZExtSize();
3247 StructuredList->resizeInits(Context, StrLen);
3251 for (
unsigned i = 0, e = StrLen; i != e; ++i) {
3252 llvm::APInt CodeUnit(PromotedCharTyWidth, SL->getCodeUnit(i));
3254 Context, CodeUnit, PromotedCharTy, SubExpr->
getExprLoc());
3255 if (CharTy != PromotedCharTy)
3259 StructuredList->updateInit(Context, i,
Init);
3268 if (cast<ConstantArrayType>(AT)->getSize().ult(StrLen))
3269 StrLen = cast<ConstantArrayType>(AT)->getZExtSize();
3270 StructuredList->resizeInits(Context, StrLen);
3274 for (
unsigned i = 0, e = StrLen; i != e; ++i) {
3275 llvm::APInt CodeUnit(PromotedCharTyWidth, Str[i]);
3277 Context, CodeUnit, PromotedCharTy, SubExpr->
getExprLoc());
3278 if (CharTy != PromotedCharTy)
3282 StructuredList->updateInit(Context, i,
Init);
3289 if (StructuredList &&
3290 DesignatedEndIndex.getZExtValue() >= StructuredList->getNumInits())
3291 StructuredList->resizeInits(SemaRef.
Context,
3292 DesignatedEndIndex.getZExtValue() + 1);
3298 unsigned ElementIndex = DesignatedStartIndex.getZExtValue();
3299 unsigned OldIndex = Index;
3304 while (DesignatedStartIndex <= DesignatedEndIndex) {
3310 if (CheckDesignatedInitializer(
3311 ElementEntity, IList, DIE, DesigIdx + 1, ElementType,
nullptr,
3312 nullptr, Index, StructuredList, ElementIndex,
3313 FinishSubobjectInit && (DesignatedStartIndex == DesignatedEndIndex),
3318 ++DesignatedStartIndex;
3319 ElementIndex = DesignatedStartIndex.getZExtValue();
3324 if (IsFirstDesignator) {
3325 if (NextElementIndex)
3326 *NextElementIndex = DesignatedStartIndex;
3327 StructuredIndex = ElementIndex;
3331 if (!FinishSubobjectInit)
3335 bool prevHadError = hadError;
3336 CheckArrayType(Entity, IList, CurrentObjectType, DesignatedStartIndex,
3338 StructuredList, ElementIndex);
3339 return hadError && !prevHadError;
3345InitListChecker::getStructuredSubobjectInit(
InitListExpr *IList,
unsigned Index,
3348 unsigned StructuredIndex,
3350 bool IsFullyOverwritten) {
3351 if (!StructuredList)
3354 Expr *ExistingInit =
nullptr;
3355 if (StructuredIndex < StructuredList->getNumInits())
3356 ExistingInit = StructuredList->
getInit(StructuredIndex);
3358 if (
InitListExpr *Result = dyn_cast_or_null<InitListExpr>(ExistingInit))
3367 if (!IsFullyOverwritten)
3390 diagnoseInitOverride(ExistingInit, InitRange);
3393 unsigned ExpectedNumInits = 0;
3394 if (Index < IList->getNumInits()) {
3395 if (
auto *
Init = dyn_cast_or_null<InitListExpr>(IList->
getInit(Index)))
3396 ExpectedNumInits =
Init->getNumInits();
3402 createInitListExpr(CurrentObjectType, InitRange, ExpectedNumInits);
3411InitListChecker::createInitListExpr(
QualType CurrentObjectType,
3413 unsigned ExpectedNumInits) {
3417 QualType ResultType = CurrentObjectType;
3420 Result->setType(ResultType);
3423 unsigned NumElements = 0;
3428 NumElements = CAType->getZExtSize();
3431 if (NumElements > ExpectedNumInits)
3435 NumElements = VType->getNumElements();
3437 NumElements = numStructUnionElements(CurrentObjectType);
3442 Result->reserveInits(SemaRef.
Context, NumElements);
3449void InitListChecker::UpdateStructuredListElement(
InitListExpr *StructuredList,
3450 unsigned &StructuredIndex,
3453 if (!StructuredList)
3457 StructuredIndex,
expr)) {
3463 diagnoseInitOverride(PrevInit,
expr->getSourceRange());
3472 InitListChecker Check(*
this, Entity, From,
Type,
true,
3475 return !Check.HadError();
3496 return S.
Diag(
Loc, diag::err_array_designator_negative)
3499 Value.setIsUnsigned(
true);
3517 if (
D.isFieldDesignator()) {
3518 Designators.push_back(ASTDesignator::CreateFieldDesignator(
3519 D.getFieldDecl(),
D.getDotLoc(),
D.getFieldLoc()));
3520 }
else if (
D.isArrayDesignator()) {
3521 Expr *Index =
static_cast<Expr *
>(
D.getArrayIndex());
3522 llvm::APSInt IndexValue;
3523 if (!Index->isTypeDependent() && !Index->isValueDependent())
3528 Designators.push_back(ASTDesignator::CreateArrayDesignator(
3529 InitExpressions.size(),
D.getLBracketLoc(),
D.getRBracketLoc()));
3530 InitExpressions.push_back(Index);
3532 }
else if (
D.isArrayRangeDesignator()) {
3533 Expr *StartIndex =
static_cast<Expr *
>(
D.getArrayRangeStart());
3534 Expr *EndIndex =
static_cast<Expr *
>(
D.getArrayRangeEnd());
3535 llvm::APSInt StartValue;
3536 llvm::APSInt EndValue;
3541 if (!StartDependent)
3547 if (!StartIndex || !EndIndex)
3551 if (StartDependent || EndDependent) {
3553 }
else if (StartValue.getBitWidth() > EndValue.getBitWidth())
3554 EndValue = EndValue.extend(StartValue.getBitWidth());
3555 else if (StartValue.getBitWidth() < EndValue.getBitWidth())
3556 StartValue = StartValue.extend(EndValue.getBitWidth());
3558 if (!StartDependent && !EndDependent && EndValue < StartValue) {
3559 Diag(
D.getEllipsisLoc(), diag::err_array_designator_empty_range)
3564 Designators.push_back(ASTDesignator::CreateArrayRangeDesignator(
3565 InitExpressions.size(),
D.getLBracketLoc(),
D.getEllipsisLoc(),
3566 D.getRBracketLoc()));
3567 InitExpressions.push_back(StartIndex);
3568 InitExpressions.push_back(EndIndex);
3578 EqualOrColonLoc, GNUSyntax,
3586InitializedEntity::InitializedEntity(
ASTContext &Context,
unsigned Index,
3591 Kind = EK_ArrayElement;
3594 Kind = EK_VectorElement;
3598 assert(CT &&
"Unexpected type");
3599 Kind = EK_ComplexElement;
3607 bool IsInheritedVirtualBase,
3612 Result.Base = {
Base, IsInheritedVirtualBase};
3630 return Variable.VariableOrMember->getDeclName();
3652 llvm_unreachable(
"Invalid EntityKind!");
3686 llvm_unreachable(
"Invalid EntityKind!");
3721unsigned InitializedEntity::dumpImpl(raw_ostream &OS)
const {
3724 for (
unsigned I = 0; I != Depth; ++I)
3741 case EK_New: OS <<
"New";
break;
3745 case EK_Base: OS <<
"Base";
break;
3752 OS <<
"Block (lambda)";
3755 OS <<
"LambdaCapture ";
3762 D->printQualifiedName(OS);
3765 OS <<
" '" <<
getType() <<
"'\n";
3771 dumpImpl(llvm::errs());
3826 for (
const Step &S : llvm::reverse(Steps)) {
3886 llvm_unreachable(
"Invalid EntityKind!");
3894InitializationSequence
3897 bool HadMultipleCandidates) {
3901 S.Function.HadMultipleCandidates = HadMultipleCandidates;
3903 S.Function.FoundDecl =
Found;
3922 bool BindingTemporary) {
3947 bool HadMultipleCandidates) {
3951 S.Function.HadMultipleCandidates = HadMultipleCandidates;
3953 S.Function.FoundDecl = FoundDecl;
3992 bool TopLevelOfInitList) {
4010 bool HadMultipleCandidates,
bool FromInitList,
bool AsInitList) {
4016 S.Function.HadMultipleCandidates = HadMultipleCandidates;
4017 S.Function.Function = Constructor;
4018 S.Function.FoundDecl = FoundDecl;
4061 Steps.insert(Steps.begin(), S);
4122 "Can only unwrap trivial init lists.");
4126 Steps.insert(Steps.begin(), S);
4132 "Can only rewrap trivial init lists.");
4136 Steps.insert(Steps.begin(), S);
4140 S.WrappingSyntacticList = Syntactic;
4147 this->Failure = Failure;
4148 this->FailedOverloadResult =
Result;
4169 if (!
Init.empty()) {
4189 "consuming an object of unretainable type?");
4209 bool TreatUnavailableAsInvalid) {
4224 Expr *OVEAsExpr = &OVE;
4227 TreatUnavailableAsInvalid);
4237 bool TreatUnavailableAsInvalid);
4248 bool TreatUnavailableAsInvalid) {
4262 List->getNumInits()),
4267 List->getExprLoc(), List->getBeginLoc(), List->getEndLoc());
4269 TreatUnavailableAsInvalid);
4296 bool CopyInitializing,
bool AllowExplicit,
bool OnlyListConstructors,
4297 bool IsListInit,
bool RequireActualConstructor,
4298 bool SecondStepOfCopyInit =
false) {
4304 if (!Info.Constructor || Info.Constructor->isInvalidDecl())
4321 bool SuppressUserConversions =
4322 SecondStepOfCopyInit ||
4323 (IsListInit && Args.size() == 1 && isa<InitListExpr>(Args[0]) &&
4326 if (Info.ConstructorTmpl)
4328 Info.ConstructorTmpl, Info.FoundDecl,
4329 nullptr, Args, CandidateSet, SuppressUserConversions,
4330 false, AllowExplicit);
4339 bool AllowExplicitConv = AllowExplicit && !CopyInitializing &&
4343 CandidateSet, SuppressUserConversions,
4344 false, AllowExplicit,
4360 if (S.
getLangOpts().CPlusPlus17 && Args.size() == 1 &&
4361 !RequireActualConstructor && !SecondStepOfCopyInit) {
4363 auto *SourceRD =
Initializer->getType()->getAsCXXRecordDecl();
4365 const auto &Conversions = SourceRD->getVisibleConversionFunctions();
4366 for (
auto I = Conversions.begin(),
E = Conversions.end(); I !=
E; ++I) {
4369 D =
D->getUnderlyingDecl();
4376 Conv = cast<CXXConversionDecl>(
D);
4380 ConvTemplate, I.getPair(), ActingDC,
Initializer, DestType,
4381 CandidateSet, AllowExplicit, AllowExplicit,
4385 DestType, CandidateSet, AllowExplicit,
4412 bool IsListInit =
false,
4413 bool IsInitListCopy =
false) {
4414 assert(((!IsListInit && !IsInitListCopy) ||
4415 (Args.size() == 1 && isa<InitListExpr>(Args[0]))) &&
4416 "IsListInit/IsInitListCopy must come with a single initializer list "
4419 (IsListInit || IsInitListCopy) ? cast<InitListExpr>(Args[0]) :
nullptr;
4429 bool RequireActualConstructor =
4435 bool CopyElisionPossible =
false;
4436 auto ElideConstructor = [&] {
4452 if (S.
getLangOpts().CPlusPlus17 && !RequireActualConstructor &&
4453 UnwrappedArgs.size() == 1 && UnwrappedArgs[0]->isPRValue() &&
4475 assert(!IsInitListCopy &&
4476 "IsInitListCopy only possible with aggregate types");
4477 CopyElisionPossible =
true;
4485 assert(DestRecordType &&
"Constructor initialization requires record type");
4487 = cast<CXXRecordDecl>(DestRecordType->
getDecl());
4495 bool AllowExplicit = Kind.AllowExplicit() || IsListInit;
4505 bool AsInitializerList =
false;
4517 AsInitializerList =
true;
4523 S, Kind.getLocation(), Args, CandidateSet, DestType, Ctors, Best,
4524 CopyInitialization, AllowExplicit,
4525 true, IsListInit, RequireActualConstructor);
4540 AsInitializerList =
false;
4542 S, Kind.getLocation(), UnwrappedArgs, CandidateSet, DestType, Ctors,
4543 Best, CopyInitialization, AllowExplicit,
4544 false, IsListInit, RequireActualConstructor);
4556 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
4560 if (
auto *CD = dyn_cast<CXXConversionDecl>(Best->Function)) {
4562 QualType ConvType = CD->getConversionType();
4564 "should not have selected this conversion function");
4566 HadMultipleCandidates);
4577 DestRecordDecl !=
nullptr && DestRecordDecl->
isAggregate() &&
4579 S.
Diag(Kind.getLocation(), diag::warn_field_requires_explicit_init)
4580 << 1 << DestRecordDecl;
4605 if (IsListInit && !Kind.AllowExplicit() && CtorDecl->
isExplicit()) {
4625 Best->FoundDecl, CtorDecl, DestArrayType, HadMultipleCandidates,
4626 IsListInit | IsInitListCopy, AsInitializerList);
4639 bool HadMultipleCandidates =
false;
4642 UnqualifiedTargetType,
4644 &HadMultipleCandidates)) {
4646 HadMultipleCandidates);
4647 SourceType = Fn->getType();
4666 bool TopLevelOfInitList);
4680 bool TreatUnavailableAsInvalid) {
4720 T1Quals, cv2T2, T2, T2Quals, Sequence,
4751 TreatUnavailableAsInvalid);
4783 bool TreatUnavailableAsInvalid) {
4795 TreatUnavailableAsInvalid);
4833 !IsDesignatedInit) {
4838 Expr *InitListAsExpr = InitList;
4857 if (isa<ConstantArrayType>(DestAT) &&
4859 isa<DecompositionDecl>(Entity.
getDecl())) {
4862 "Deduced to other type?");
4866 Entity, SubInit[0], DestType, Sequence,
4867 TreatUnavailableAsInvalid);
4873 if (!isa<VariableArrayType>(DestAT) &&
4883 TreatUnavailableAsInvalid);
4916 TreatUnavailableAsInvalid))
4920 Expr *InitListAsExpr = InitList;
4922 DestType, Sequence,
true);
4940 ET && ET->getDecl()->isFixed() &&
4989 if (
Init->getType()->isRecordType() ||
5000 TreatUnavailableAsInvalid);
5007 InitListChecker CheckInitList(S, Entity, InitList,
5008 DestType,
true, TreatUnavailableAsInvalid);
5009 if (CheckInitList.HadError()) {
5031 "Must have incompatible references when binding via conversion");
5042 bool AllowExplicitCtors =
false;
5043 bool AllowExplicitConvs = Kind.allowExplicitConversionFunctionsInRefBinding();
5054 if (!Info.Constructor)
5057 if (!Info.Constructor->isInvalidDecl() &&
5058 Info.Constructor->isConvertingConstructor(
true)) {
5059 if (Info.ConstructorTmpl)
5061 Info.ConstructorTmpl, Info.FoundDecl,
5064 false, AllowExplicitCtors);
5067 Info.Constructor, Info.FoundDecl,
Initializer, CandidateSet,
5069 false, AllowExplicitCtors);
5084 for (
auto I = Conversions.begin(),
E = Conversions.end(); I !=
E; ++I) {
5087 if (isa<UsingShadowDecl>(
D))
5088 D = cast<UsingShadowDecl>(
D)->getTargetDecl();
5095 Conv = cast<CXXConversionDecl>(
D);
5103 if ((AllowRValues ||
5107 ConvTemplate, I.getPair(), ActingDC,
Initializer, DestType,
5109 false, AllowExplicitConvs);
5112 Conv, I.getPair(), ActingDC,
Initializer, DestType, CandidateSet,
5113 false, AllowExplicitConvs);
5135 if (isa<CXXConversionDecl>(
Function))
5148 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
5150 HadMultipleCandidates);
5160 assert(!isa<CXXConstructorDecl>(
Function) &&
5161 "should not have conversion after constructor");
5165 ICS.
Standard = Best->FinalConversion;
5186 if (RefConv & Sema::ReferenceConversions::DerivedToBase)
5188 else if (RefConv & Sema::ReferenceConversions::ObjC)
5190 else if (RefConv & Sema::ReferenceConversions::Function)
5192 else if (RefConv & Sema::ReferenceConversions::Qualification) {
5209 bool TopLevelOfInitList) {
5227 T1Quals, cv2T2, T2, T2Quals, Sequence,
5228 TopLevelOfInitList);
5252 bool TopLevelOfInitList) {
5276 if (isLValueRef || T1Function) {
5279 (Kind.isCStyleOrFunctionalCast() &&
5283 if (RefConv & (Sema::ReferenceConversions::DerivedToBase |
5284 Sema::ReferenceConversions::ObjC)) {
5287 if (RefConv & (Sema::ReferenceConversions::Qualification))
5291 if (RefConv & Sema::ReferenceConversions::DerivedToBase)
5295 }
else if (RefConv & Sema::ReferenceConversions::Qualification) {
5299 }
else if (RefConv & Sema::ReferenceConversions::Function) {
5319 (isLValueRef || InitCategory.
isRValue())) {
5324 isLValueRef, Sequence);
5359 switch (RefRelationship) {
5371 llvm_unreachable(
"unexpected kind of compatible initializer");
5395 (Kind.isCStyleOrFunctionalCast() &&
5424 auto T1QualsIgnoreAS = T1Quals;
5425 auto T2QualsIgnoreAS = T2Quals;
5428 T2QualsIgnoreAS.removeAddressSpace();
5431 if (T1QualsIgnoreAS != T2QualsIgnoreAS)
5441 cv1T4 = cv1T4WithAS;
5446 if (RefConv & Sema::ReferenceConversions::DerivedToBase)
5448 else if (RefConv & Sema::ReferenceConversions::ObjC)
5450 else if (RefConv & Sema::ReferenceConversions::Qualification) {
5467 isLValueRef, Sequence);
5507 Sema::AllowedExplicit::None,
5509 Kind.isCStyleOrFunctionalCast(),
5528 TopLevelOfInitList);
5537 ((T1CVRQuals | T2CVRQuals) != T1CVRQuals ||
5582 assert((!InitList || InitList->
getNumInits() == 0) &&
5583 "Shouldn't use value-init for non-empty init lists");
5589 assert(!
T->
isVoidType() &&
"Cannot value-init void");
5595 if (
CXXRecordDecl *ClassDecl = dyn_cast<CXXRecordDecl>(RT->getDecl())) {
5596 bool NeedZeroInitialization =
true;
5611 NeedZeroInitialization =
false;
5619 if (NeedZeroInitialization)
5633 ClassDecl->hasUninitializedReferenceMember()) {
5641 Expr *InitListAsExpr = InitList;
5643 bool InitListSyntax = InitList;
5648 S, Entity, Kind, Args,
T, Entity.
getType(), Sequence, InitListSyntax);
5698 unsigned EntityIndexToProcess = 0;
5701 Expr *ArrayFiller =
nullptr;
5702 FieldDecl *InitializedFieldInUnion =
nullptr;
5706 Expr *Arg,
Expr **InitExpr =
nullptr) {
5708 S, SubEntity, SubKind,
5724 ER = IS.
Perform(S, SubEntity, SubKind,
5731 *InitExpr = ER.
get();
5733 InitExprs.push_back(ER.
get());
5741 uint64_t ArrayLength;
5749 ArrayLength = CAT->getZExtSize();
5750 ResultType = Entity.
getType();
5757 const Expr *SE = VAT->getSizeExpr();
5763 ArrayLength = Args.size();
5765 EntityIndexToProcess = ArrayLength;
5769 for (
Expr *
E : Args) {
5774 if (!HandleInitializedEntity(SubEntity, SubKind,
E))
5782 Kind.getLocation(), Kind.getLocation(), Kind.getLocation(),
true);
5783 if (!HandleInitializedEntity(SubEntity, SubKind,
nullptr, &ArrayFiller))
5787 if (ResultType.
isNull()) {
5794 const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
5808 if (EntityIndexToProcess < Args.size()) {
5814 Expr *
E = Args[EntityIndexToProcess];
5817 if (!HandleInitializedEntity(SubEntity, SubKind,
E))
5825 Kind.getLocation(), Kind.getLocation(), Kind.getLocation(),
5827 if (!HandleInitializedEntity(SubEntity, SubKind,
nullptr))
5830 EntityIndexToProcess++;
5843 if (EntityIndexToProcess < Args.size()) {
5845 Expr *
E = Args[EntityIndexToProcess];
5863 if (!HandleInitializedEntity(SubEntity, SubKind,
E))
5871 InitializedFieldInUnion = FD;
5872 EntityIndexToProcess = 1;
5878 if (!VerifyOnly && FD->
hasAttr<ExplicitInitAttr>()) {
5879 S.
Diag(Kind.getLocation(), diag::warn_field_requires_explicit_init)
5890 Kind.getParenOrBraceRange().getEnd(), FD);
5894 InitExprs.push_back(DIE.
get());
5904 S.
Diag(SR.
getEnd(), diag::err_init_reference_member_uninitialized)
5911 Kind.getLocation(), Kind.getLocation(), Kind.getLocation(),
true);
5912 if (!HandleInitializedEntity(SubEntity, SubKind,
nullptr))
5916 EntityIndexToProcess++;
5918 ResultType = Entity.
getType();
5923 if (EntityIndexToProcess < Args.size()) {
5928 SourceRange ExcessInitSR(Args[EntityIndexToProcess]->getBeginLoc(),
5929 Args.back()->getEndLoc());
5930 S.
Diag(Kind.getLocation(), diag::err_excess_initializers)
5931 << InitKind << ExcessInitSR;
5945 CPLIE->setArrayFiller(ArrayFiller);
5946 if (InitializedFieldInUnion)
5947 CPLIE->setInitializedFieldInUnion(InitializedFieldInUnion);
5949 S.
Diag(Kind.getLocation(),
5950 diag::warn_cxx17_compat_aggregate_init_paren_list)
5951 << Kind.getLocation() << SR << ResultType;
5963 bool TopLevelOfInitList) {
5964 assert(!DestType->
isReferenceType() &&
"References are handled elsewhere");
5967 "Must have a class type to perform a user-defined conversion");
5977 bool AllowExplicit = Kind.AllowExplicit();
5983 = cast<CXXRecordDecl>(DestRecordType->getDecl());
5989 if (!Info.Constructor)
5992 if (!Info.Constructor->isInvalidDecl() &&
5993 Info.Constructor->isConvertingConstructor(
true)) {
5994 if (Info.ConstructorTmpl)
5996 Info.ConstructorTmpl, Info.FoundDecl,
5999 false, AllowExplicit);
6004 false, AllowExplicit);
6020 = cast<CXXRecordDecl>(SourceRecordType->getDecl());
6022 const auto &Conversions =
6024 for (
auto I = Conversions.begin(),
E = Conversions.end(); I !=
E; ++I) {
6027 if (isa<UsingShadowDecl>(
D))
6028 D = cast<UsingShadowDecl>(
D)->getTargetDecl();
6035 Conv = cast<CXXConversionDecl>(
D);
6039 ConvTemplate, I.getPair(), ActingDC,
Initializer, DestType,
6040 CandidateSet, AllowExplicit, AllowExplicit);
6043 DestType, CandidateSet, AllowExplicit,
6069 bool HadMultipleCandidates = (CandidateSet.
size() > 1);
6071 if (isa<CXXConstructorDecl>(
Function)) {
6077 HadMultipleCandidates);
6106 HadMultipleCandidates);
6119 Function->getReturnType()->isReferenceType() ||
6129 if (Best->FinalConversion.First || Best->FinalConversion.Second ||
6130 Best->FinalConversion.Third) {
6133 ICS.
Standard = Best->FinalConversion;
6151 isa<CXXBoolLiteralExpr>(
Init) &&
6152 !cast<CXXBoolLiteralExpr>(
Init)->getValue() &&
6161 bool isAddressOf,
bool &isWeakAccess) {
6167 if (op->getOpcode() == UO_AddrOf)
6172 }
else if (
CastExpr *ce = dyn_cast<CastExpr>(e)) {
6173 switch (ce->getCastKind()) {
6176 case CK_LValueBitCast:
6180 case CK_ArrayToPointerDecay:
6183 case CK_NullToPointer:
6191 }
else if (isa<DeclRefExpr>(e)) {
6195 isWeakAccess =
true;
6199 VarDecl *var = dyn_cast<VarDecl>(cast<DeclRefExpr>(e)->getDecl());
6213 }
else if (isa<ArraySubscriptExpr>(e)) {
6229 bool isWeakAccess =
false;
6233 if (S.
getLangOpts().ObjCAutoRefCount && isWeakAccess)
6265 bool ArrayDecay =
false;
6270 ArgPointee = ArgArrayType->getElementType();
6282 bool ShouldCopy =
true;
6353 "cl_intel_device_side_avc_motion_estimation", S.
getLangOpts()) &&
6355 if (DestType->isOCLIntelSubgroupAVCMcePayloadType() ||
6356 DestType->isOCLIntelSubgroupAVCMceResultType())
6370 MultiExprArg Args,
bool TopLevelOfInitList,
bool TreatUnavailableAsInvalid)
6374 TreatUnavailableAsInvalid);
6380 auto *DRE = dyn_cast<DeclRefExpr>(
E);
6381 if (!DRE || !isa<FunctionDecl>(DRE->getDecl()))
6385 cast<FunctionDecl>(DRE->getDecl()));
6402 return isa<DecompositionDecl>(Entity.
getDecl());
6428 bool TopLevelOfInitList,
6429 bool TreatUnavailableAsInvalid) {
6436 for (
unsigned I = 0,
E = Args.size(); I !=
E; ++I)
6437 if (Args[I]->getType()->isNonOverloadPlaceholderType()) {
6444 Args[I] = result.
get();
6466 if (Args.size() == 1) {
6484 TreatUnavailableAsInvalid);
6509 if (Args.size() != 1)
6515 else if (isa<InitListExpr>(Args[0]))
6519 TopLevelOfInitList);
6545 if (
Initializer && isa<VariableArrayType>(DestAT)) {
6577 if (
Initializer && isa<ConstantArrayType>(DestAT) &&
6582 TreatUnavailableAsInvalid);
6590 isa<CompoundLiteralExpr>(
Initializer->IgnoreParens()) &&
6608 *
this, TreatUnavailableAsInvalid);
6610 }
else if (S.
getLangOpts().CPlusPlus20 && !TopLevelOfInitList &&
6626 bool allowObjCWritebackConversion = S.
getLangOpts().ObjCAutoRefCount &&
6635 assert(
Initializer &&
"Initializer must be non-null");
6637 if (allowObjCWritebackConversion &&
6663 SourceType, DestType))))) {
6670 if (
const auto *RD =
6675 S.
getLangOpts().CPlusPlus20 && RD && RD->hasDefinition() &&
6676 RD->isAggregate() &&
Failed() &&
6689 S, Kind.getLocation(), Best);
6707 assert(
Initializer &&
"Initializer must be non-null");
6709 TopLevelOfInitList);
6714 assert(Args.size() >= 1 &&
"Zero-argument case handled above");
6724 for (
auto *Arg : Args) {
6725 if (Arg->getType()->isExtVectorType()) {
6728 for (
unsigned Idx = 0; Idx < Elm; ++Idx) {
6734 VTy->getElementType(), Arg->
getValueKind(), Arg->getObjectKind(),
6738 InitArgs.emplace_back(Arg);
6748 if (Args.size() > 1) {
6751 }
else if (isa<InitListExpr>(Args[0])) {
6759 assert(
Initializer &&
"Initializer must be non-null");
6762 bool NeedAtomicConversion =
false;
6766 Atomic->getValueType())) {
6767 DestType =
Atomic->getValueType();
6768 NeedAtomicConversion =
true;
6773 TopLevelOfInitList);
6775 if (!
Failed() && NeedAtomicConversion)
6802 Sema::AllowedExplicit::None,
6804 Kind.isCStyleOrFunctionalCast(),
6805 allowObjCWritebackConversion);
6813 bool ShouldCopy =
true;
6829 }
else if (ICS.
isBad()) {
6837 else if (
Initializer->getType()->isFunctionType() &&
6850 for (
auto &S : Steps)
6858 bool Diagnose =
false) {
6909 llvm_unreachable(
"Invalid EntityKind!");
6943 llvm_unreachable(
"missed an InitializedEntity kind?");
6977 llvm_unreachable(
"missed an InitializedEntity kind?");
7016 llvm_unreachable(
"missed an InitializedEntity kind?");
7043 bool IsExtraneousCopy) {
7068 S,
Loc, CurInitExpr, CandidateSet,
T, Ctors, Best,
7080 ? diag::ext_rvalue_to_reference_temp_copy_no_viable
7081 : diag::err_temp_copy_no_viable)
7099 S.
Diag(
Loc, diag::err_temp_copy_deleted)
7106 bool HadMultipleCandidates = CandidateSet.
size() > 1;
7115 if (IsExtraneousCopy) {
7126 for (
unsigned I = 1, N = Constructor->getNumParams(); I != N; ++I) {
7129 diag::err_call_incomplete_argument))
7170 Best->Function->getParamDecl(0)->getType().getNonReferenceType(),
7175 Loc,
T, Best->FoundDecl, Constructor, Elidable, ConstructorArgs,
7176 HadMultipleCandidates,
7192 Expr *CurInitExpr) {
7211 S,
Loc, CurInitExpr, CandidateSet, CurInitExpr->
getType(), Ctors, Best,
7224 Best->FoundDecl, Entity,
Diag);
7245void InitializationSequence::PrintInitLocationNote(
Sema &S,
7260 diag::note_method_return_type_change)
7278 switch (Kind.getKind()) {
7284 return NumArgs != 1;
7296 bool &ConstructorInitRequiresZeroInit,
7297 bool IsListInitialization,
7298 bool IsStdInitListInitialization,
7301 unsigned NumArgs = Args.size();
7309 ? Kind.getEqualLoc()
7310 : Kind.getLocation();
7316 assert(Constructor->getParent() &&
"No parent class for constructor.");
7317 if (Constructor->isDefaulted() && Constructor->isDefaultConstructor() &&
7318 Constructor->isTrivial() && !Constructor->isUsed(
false)) {
7333 bool AllowExplicitConv =
7334 Kind.AllowExplicit() && !Kind.isCopyInit() && Args.size() == 1 &&
7339 if (NumArgs == 1 && !Kind.isExplicitCast())
7341 Entity.
getType(), Args.front()->getType(), Kind.getLocation());
7346 ConstructorArgs, AllowExplicitConv,
7347 IsListInitialization))
7356 Constructor->isImplicit()) {
7361 if (I >= ConstructorArgs.size() && FD->
hasAttr<ExplicitInitAttr>()) {
7362 S.
Diag(
Loc, diag::warn_field_requires_explicit_init)
7377 : Kind.getParenOrBraceRange();
7380 if (
auto *Shadow = dyn_cast<ConstructorUsingShadowDecl>(
7390 ConstructorArgs, ParenOrBraceRange, HadMultipleCandidates,
7391 IsListInitialization, IsStdInitListInitialization,
7392 ConstructorInitRequiresZeroInit),
7408 if (IsListInitialization)
7409 ParenOrBraceRange =
SourceRange(LBraceLoc, RBraceLoc);
7411 ParenOrBraceRange = Kind.getParenOrBraceRange();
7420 HadMultipleCandidates,
7421 IsListInitialization,
7422 IsStdInitListInitialization,
7423 ConstructorInitRequiresZeroInit,
7431 HadMultipleCandidates,
7432 IsListInitialization,
7433 IsStdInitListInitialization,
7434 ConstructorInitRequiresZeroInit,
7465 const Expr *PostInit);
7472 bool IsReturnStmt) {
7483 unsigned DiagID = 0;
7513 if (VD->
hasAttr<BlocksAttr>())
7526 if (isa<ParmVarDecl>(VD))
7527 DiagID = diag::warn_redundant_move_on_return;
7529 DiagID = diag::warn_pessimizing_move_on_return;
7531 DiagID = diag::warn_pessimizing_move_on_initialization;
7573 if (UO->getOpcode() == UO_Deref &&
7574 UO->getSubExpr()->IgnoreParenCasts()->
7577 S.
PDiag(diag::warn_binding_null_to_reference)
7578 << UO->getSubExpr()->getSourceRange());
7584 bool BoundToLvalueReference) {
7627 if (!PointeeTy.isNull() &&
7628 PointeeTy.getAddressSpace() != ExprPointeeTy.getAddressSpace())
7629 CK = CK_AddressSpaceConversion;
7631 CK = CK_AddressSpaceConversion;
7646 if (!ZeroInitializationFixit.empty()) {
7648 const auto *VD = dyn_cast_or_null<VarDecl>(
D);
7654 if (!DestType->
isRecordType() && VD && VD->isConstexpr()) {
7656 S.
Diag(Kind.getLocation(), diag::err_constexpr_var_requires_const_init)
7659 ZeroInitializationFixit);
7661 unsigned DiagID = diag::err_default_init_const;
7663 DiagID = diag::ext_default_init_const;
7665 S.
Diag(Kind.getLocation(), DiagID)
7668 ZeroInitializationFixit);
7688 if (isa<InitListExpr>((
Expr *)Args[0])) {
7692 if (
auto *DD = dyn_cast_or_null<DeclaratorDecl>(Entity.
getDecl())) {
7694 TypeLoc TL = TInfo->getTypeLoc();
7697 Brackets = ArrayLoc.getBracketsRange();
7704 ArrayT->getSizeModifier(),
7705 ArrayT->getIndexTypeCVRQualifiers(),
7712 !Kind.isExplicitCast()) {
7714 SourceRange ParenRange = Kind.getParenOrBraceRange();
7719 Kind.isExplicitCast() ||
7729 Args.size() == 1 && isa<InitListExpr>(Args[0]) &&
7735 S.
Diag(
Init->getBeginLoc(), diag::warn_cxx98_compat_reference_list_init)
7736 <<
Init->getSourceRange();
7739 if (S.
getLangOpts().MicrosoftExt && Args.size() == 1 &&
7745 S.
Diag(
Init->getBeginLoc(), diag::ext_init_from_predefined) <<
Init;
7756 S.
Diag(Args[0]->getBeginLoc(), diag::err_opencl_atomic_init)
7776 isa<InitListExpr>(Args[0]);
7777 (void)IsHLSLVectorInit;
7782 switch (Steps.front().Kind) {
7816 assert(Args.size() == 1 || IsHLSLVectorInit);
7835 isa_and_nonnull<InitListExpr>(CurInit.
get()));
7840 auto checkAbstractType = [&](
QualType T) ->
bool {
7845 diag::err_allocation_of_abstract_type);
7850 bool ConstructorInitRequiresZeroInit =
false;
7883 bool IgnoreBaseAccess = Kind.isCStyleOrFunctionalCast();
7895 CK_DerivedToBase, CurInit.
get(),
7911 if (
auto *DRE = dyn_cast<DeclRefExpr>(CurInit.
get()->
IgnoreParens())) {
7912 if (
auto *FD = dyn_cast<FunctionDecl>(DRE->getDecl())) {
7925 assert(CurInit.
get()->
isPRValue() &&
"not a temporary");
7983 bool CreatedObject =
false;
7999 Loc,
Step->
Type, FoundFn, Constructor, ConstructorArgs,
8000 HadMultipleCandidates,
8012 CastKind = CK_ConstructorConversion;
8013 CreatedObject =
true;
8023 HadMultipleCandidates);
8027 CastKind = CK_UserDefinedConversion;
8031 if (CreatedObject && checkAbstractType(CurInit.
get()->
getType()))
8052 S.
PDiag(diag::err_access_dtor_temp) <<
T);
8076 "function reference should be lvalue");
8082 assert(CurInit.
get()->
isPRValue() &&
"cannot convert glvalue to atomic");
8090 if (
const auto *FromPtrType =
8093 if (FromPtrType->getPointeeType()->hasAttr(attr::NoDeref) &&
8094 !ToPtrType->getPointeeType()->hasAttr(attr::NoDeref)) {
8097 if (!Kind.isStaticCast()) {
8099 diag::warn_noderef_to_dereferenceable_pointer)
8118 CurInit = CurInitExprRes;
8139 InitListChecker PerformInitList(S, InitEntity,
8140 InitList, Ty,
false,
8142 if (PerformInitList.HadError())
8150 if ((*ResultType)->isRValueReferenceType())
8152 else if ((*ResultType)->isLValueReferenceType())
8159 PerformInitList.getFullyStructuredList();
8163 : StructuredInitList;
8180 assert(Args.size() == 1 &&
"expected a single argument for list init");
8182 S.
Diag(InitList->
getExprLoc(), diag::warn_cxx98_compat_ctor_list_init)
8188 ConstructorInitRequiresZeroInit,
8197 CurInit = cast<InitListExpr>(CurInit.
get())->getInit(0);
8226 bool IsStdInitListInit =
8230 ? Kind.getParenOrBraceRange()
8233 S, UseTemporary ? TempEntity : Entity, Kind,
8235 ConstructorInitRequiresZeroInit,
8246 if (NextStep != StepEnd &&
8251 ConstructorInitRequiresZeroInit =
true;
8254 !Kind.isImplicitValueInit()) {
8258 Kind.getRange().getBegin());
8262 Kind.getRange().getEnd());
8292 CurInit = CurInitExprRes;
8307 S.
Diag(Kind.getLocation(), diag::err_c23_constexpr_pointer_not_null);
8314 InitialCurInit.
get(),
8317 PrintInitLocationNote(S, Entity);
8319 }
else if (Complained)
8320 PrintInitLocationNote(S, Entity);
8336 CK_ObjCObjectLValueCast,
8348 BaseExpr, Kind.getLocation(), IndexExpr, Kind.getLocation());
8349 ArrayLoopCommonExprs.push_back(BaseExpr);
8354 assert(!ArrayLoopCommonExprs.empty() &&
8355 "mismatched SK_ArrayLoopIndex and SK_ArrayLoopInit");
8356 Expr *Common = ArrayLoopCommonExprs.pop_back_val();
8365 S.
Diag(Kind.getLocation(), diag::ext_array_init_copy)
8379 IncompleteDest->getElementType(), ConstantSource->getSize(),
8389 S.
Diag(Kind.getLocation(), diag::ext_array_init_parens)
8409 diag::warn_cxx98_compat_initializer_list_init)
8422 [[maybe_unused]]
bool IsStdInitializerList =
8424 assert(IsStdInitializerList &&
8425 "StdInitializerList step to non-std::initializer_list");
8429 "std::initializer_list should have already be "
8430 "complete/instantiated by this point");
8432 auto InvalidType = [&] {
8434 diag::err_std_initializer_list_malformed)
8441 return InvalidType();
8444 if (Field ==
Record->field_end())
8445 return InvalidType();
8448 if (!Field->getType()->isPointerType() ||
8451 return InvalidType();
8453 if (++Field ==
Record->field_end())
8454 return InvalidType();
8457 if (
const auto *PT = Field->getType()->getAs<
PointerType>()) {
8460 return InvalidType();
8462 if (Field->isBitField() ||
8464 return InvalidType();
8467 if (++Field !=
Record->field_end())
8468 return InvalidType();
8495 "Sampler initialization on non-sampler type.");
8501 S.
Diag(Kind.getLocation(), diag::err_sampler_argument_required)
8505 auto Var = cast<VarDecl>(DRE->getDecl());
8508 if (!Var->hasGlobalStorage()) {
8520 if (!Var->getInit() || !isa<ImplicitCastExpr>(Var->getInit()))
8522 Init = cast<ImplicitCastExpr>(
const_cast<Expr*
>(
8523 Var->getInit()))->getSubExpr();
8524 SourceType =
Init->getType();
8531 if (!
Init->isConstantInitializer(S.
Context,
false))
8536 S.
Diag(Kind.getLocation(), diag::err_sampler_initializer_not_integer)
8544 const uint64_t SamplerValue =
Result.getLimitedValue();
8551 unsigned AddressingMode = (0x0E & SamplerValue) >> 1;
8552 unsigned FilterMode = (0x30 & SamplerValue) >> 4;
8553 if (FilterMode != 1 && FilterMode != 2 &&
8555 "cl_intel_device_side_avc_motion_estimation", S.
getLangOpts()))
8556 S.
Diag(Kind.getLocation(),
8557 diag::warn_sampler_initializer_invalid_bits)
8559 if (AddressingMode > 4)
8560 S.
Diag(Kind.getLocation(),
8561 diag::warn_sampler_initializer_invalid_bits)
8562 <<
"Addressing Mode";
8568 CK_IntToOCLSampler);
8574 "Wrong type for initialization of OpenCL opaque type.");
8577 CK_ZeroToOCLOpaqueType,
8585 if (CurInit.
get() && ResultType)
8606 cast<FieldDecl>(Entity.
getDecl())->isBitField())
8607 S.CheckBitFieldInitialization(Kind.getLocation(),
8622 S.
Diag(
Loc, diag::err_reference_without_init)
8623 <<
T.getNonReferenceType();
8631 for (
const auto *FI : RD->
fields()) {
8632 if (FI->isUnnamedBitField())
8636 S.
Diag(
Loc, diag::note_value_initialization_here) << RD;
8641 for (
const auto &BI : RD->
bases()) {
8643 S.
Diag(
Loc, diag::note_value_initialization_here) << RD;
8678 if (fromDecl && destDecl && fromDecl->getDeclKind() == Decl::CXXRecord &&
8679 destDecl->getDeclKind() == Decl::CXXRecord &&
8680 !fromDecl->isInvalidDecl() && !destDecl->isInvalidDecl() &&
8681 !fromDecl->hasDefinition() &&
8684 S.
Diag(fromDecl->getLocation(), diag::note_forward_class_conversion)
8714 S.
Diag(
Loc, diag::note_in_reference_temporary_list_initializer) <<
T;
8718 InitListChecker DiagnoseInitList(S, Entity, InitList, DestType,
8721 assert(DiagnoseInitList.HadError() &&
8722 "Inconsistent init list check result.");
8737 if (Args.size() == 1) {
8738 auto *List = dyn_cast<InitListExpr>(Args[0]);
8739 if (List && List->getNumInits() == 1)
8740 OnlyArg = List->getInit(0);
8749 if (
Expr *Resolved =
8769 assert(Diagnosed &&
"couldn't find uninitialized reference to diagnose");
8772 S.
Diag(Kind.getLocation(), diag::err_reference_has_multiple_inits)
8773 <<
SourceRange(Args.front()->getBeginLoc(), Args.back()->getEndLoc());
8776 S.
Diag(Kind.getLocation(), diag::err_list_init_in_parens)
8777 << 1 << Entity.
getType() << Args[0]->getSourceRange();
8781 S.
Diag(Kind.getLocation(), diag::err_array_init_not_init_list) << 0;
8784 S.
Diag(Kind.getLocation(), diag::err_array_init_not_init_list) << 1;
8787 S.
Diag(Kind.getLocation(), diag::err_array_init_not_init_list) << 2;
8790 S.
Diag(Kind.getLocation(), diag::err_array_init_narrow_string_into_wchar);
8793 S.
Diag(Kind.getLocation(), diag::err_array_init_wide_string_into_char);
8796 S.
Diag(Kind.getLocation(),
8797 diag::err_array_init_incompat_wide_string_into_wchar);
8800 S.
Diag(Kind.getLocation(),
8801 diag::err_array_init_plain_string_into_char8_t);
8802 S.
Diag(Args.front()->getBeginLoc(),
8803 diag::note_array_init_plain_string_into_char8_t)
8807 S.
Diag(Kind.getLocation(), diag::err_array_init_utf8_string_into_char)
8812 S.
Diag(Kind.getLocation(),
8814 ? diag::err_array_init_different_type
8815 : diag::err_array_init_non_constant_array))
8818 << Args[0]->getSourceRange();
8822 S.
Diag(Kind.getLocation(), diag::err_variable_object_no_init)
8823 << Args[0]->getSourceRange();
8836 auto *FD = cast<FunctionDecl>(cast<DeclRefExpr>(OnlyArg)->getDecl());
8844 switch (FailedOverloadResult) {
8851 ? (S.
PDiag(diag::err_typecheck_ambiguous_condition)
8852 << OnlyArg->
getType() << DestType
8853 << Args[0]->getSourceRange())
8854 : (S.
PDiag(diag::err_ref_init_ambiguous)
8855 << DestType << OnlyArg->
getType()
8856 << Args[0]->getSourceRange())),
8864 diag::err_typecheck_nonviable_condition_incomplete,
8865 OnlyArg->
getType(), Args[0]->getSourceRange()))
8866 S.
Diag(Kind.getLocation(), diag::err_typecheck_nonviable_condition)
8868 << OnlyArg->
getType() << Args[0]->getSourceRange()
8880 S.
Diag(Kind.getLocation(), diag::err_typecheck_deleted_function)
8882 << (Msg !=
nullptr) << (Msg ? Msg->
getString() : StringRef())
8883 << Args[0]->getSourceRange();
8887 llvm_unreachable(
"Inconsistent overload resolution?");
8893 llvm_unreachable(
"Conversion did not fail!");
8898 if (isa<InitListExpr>(Args[0])) {
8899 S.
Diag(Kind.getLocation(),
8900 diag::err_lvalue_reference_bind_to_initlist)
8903 << Args[0]->getSourceRange();
8909 S.
Diag(Kind.getLocation(),
8911 ? diag::err_lvalue_reference_bind_to_temporary
8912 : diag::err_lvalue_reference_bind_to_unrelated)
8916 << Args[0]->getSourceRange();
8921 FieldDecl *BitField = Args[0]->getSourceBitField();
8922 S.
Diag(Kind.getLocation(), diag::err_reference_bind_to_bitfield)
8925 << (BitField !=
nullptr)
8926 << Args[0]->getSourceRange();
8933 S.
Diag(Kind.getLocation(), diag::err_reference_bind_to_vector_element)
8935 << Args[0]->getSourceRange();
8939 S.
Diag(Kind.getLocation(), diag::err_reference_bind_to_matrix_element)
8944 S.
Diag(Kind.getLocation(), diag::err_lvalue_to_rvalue_ref)
8946 << Args[0]->getSourceRange();
8950 S.
Diag(Kind.getLocation(), diag::err_reference_bind_temporary_addrspace)
8951 << DestType << Args[0]->getSourceRange();
8962 S.
Diag(Kind.getLocation(), diag::err_reference_bind_drops_quals)
8963 << NonRefType << SourceType << 1
8964 << Args[0]->getSourceRange();
8966 S.
Diag(Kind.getLocation(), diag::err_reference_bind_drops_quals)
8967 << NonRefType << SourceType << 0
8973 S.
Diag(Kind.getLocation(), diag::err_reference_bind_drops_quals)
8974 << NonRefType << SourceType << 2
8975 << Args[0]->getSourceRange();
8980 S.
Diag(Kind.getLocation(), diag::err_reference_bind_failed)
8985 << Args[0]->getSourceRange();
8996 << Args[0]->getSourceRange();
8998 S.
Diag(Kind.getLocation(), PDiag);
9010 auto *InitList = dyn_cast<InitListExpr>(Args[0]);
9011 if (InitList && InitList->getNumInits() >= 1) {
9012 R =
SourceRange(InitList->getInit(0)->getEndLoc(), InitList->getEndLoc());
9014 assert(Args.size() > 1 &&
"Expected multiple initializers!");
9015 R =
SourceRange(Args.front()->getEndLoc(), Args.back()->getEndLoc());
9019 if (Kind.isCStyleOrFunctionalCast())
9020 S.
Diag(Kind.getLocation(), diag::err_builtin_func_cast_more_than_one_arg)
9023 S.
Diag(Kind.getLocation(), diag::err_excess_initializers)
9029 S.
Diag(Kind.getLocation(), diag::err_list_init_in_parens)
9030 << 0 << Entity.
getType() << Args[0]->getSourceRange();
9034 S.
Diag(Kind.getLocation(), diag::err_reference_bind_init_list)
9039 S.
Diag(Kind.getLocation(), diag::err_init_list_bad_dest_type)
9040 << (DestType->
isRecordType()) << DestType << Args[0]->getSourceRange();
9048 SourceRange(Args.front()->getBeginLoc(), Args.back()->getEndLoc());
9051 assert(Args.size() == 1 &&
9052 "List construction from other than 1 argument.");
9059 switch (FailedOverloadResult) {
9063 S.
PDiag(diag::err_ovl_ambiguous_init)
9064 << DestType << ArgsRange),
9081 if (
auto Inherited = Constructor->getInheritedConstructor())
9082 InheritedFrom = Inherited.getShadowDecl()->getNominatedBaseClass();
9084 S.
Diag(Kind.getLocation(), diag::err_missing_default_ctor)
9085 << (InheritedFrom ? 2 : Constructor->isImplicit() ? 1 : 0)
9097 S.
Diag(Kind.getLocation(), diag::err_missing_default_ctor)
9098 << (InheritedFrom ? 2 : Constructor->isImplicit() ? 1 : 0)
9104 diag::note_member_declared_at);
9109 diag::note_previous_decl)
9118 S.
PDiag(diag::err_ovl_no_viable_function_in_init)
9119 << DestType << ArgsRange),
9128 S.
Diag(Kind.getLocation(), diag::err_ovl_deleted_init)
9129 << DestType << ArgsRange;
9130 llvm_unreachable(
"Inconsistent overload resolution?");
9138 S.
Diag(Kind.getLocation(), diag::err_ovl_deleted_special_init)
9139 << llvm::to_underlying(
9141 << DestType << ArgsRange;
9144 S.
Diag(Kind.getLocation(), diag::err_ovl_deleted_init)
9145 << DestType << (Msg !=
nullptr)
9146 << (Msg ? Msg->
getString() : StringRef()) << ArgsRange;
9154 llvm_unreachable(
"Conversion did not fail!");
9166 S.
Diag(Kind.getLocation(), diag::err_uninitialized_member_in_ctor)
9167 << (Constructor->getInheritedConstructor() ? 2 :
9168 Constructor->isImplicit() ? 1 : 0)
9174 }
else if (
const auto *VD = dyn_cast_if_present<VarDecl>(Entity.
getDecl());
9175 VD && VD->isConstexpr()) {
9176 S.
Diag(Kind.getLocation(), diag::err_constexpr_var_requires_const_init)
9179 S.
Diag(Kind.getLocation(), diag::err_default_init_const)
9186 diag::err_init_incomplete_type);
9202 S.
Diag(Kind.getLocation(), diag::err_selected_explicit_constructor)
9203 << Args[0]->getSourceRange();
9208 assert(Ovl ==
OR_Success &&
"Inconsistent overload resolution");
9211 diag::note_explicit_ctor_deduction_guide_here) <<
false;
9222 S.
Diag(Kind.getLocation(), diag::err_designated_init_for_non_aggregate)
9227 PrintInitLocationNote(S, Entity);
9234 OS <<
"Failed sequence: ";
9237 OS <<
"too many initializers for reference";
9241 OS <<
"parenthesized list init for reference";
9245 OS <<
"array requires initializer list";
9249 OS <<
"address of unaddressable function was taken";
9253 OS <<
"array requires initializer list or string literal";
9257 OS <<
"array requires initializer list or wide string literal";
9261 OS <<
"narrow string into wide char array";
9265 OS <<
"wide string into char array";
9269 OS <<
"incompatible wide string into wide char array";
9273 OS <<
"plain string literal into char8_t array";
9277 OS <<
"u8 string literal into char array";
9281 OS <<
"array type mismatch";
9285 OS <<
"non-constant array initializer";
9289 OS <<
"address of overloaded function failed";
9293 OS <<
"overload resolution for reference initialization failed";
9297 OS <<
"non-const lvalue reference bound to temporary";
9301 OS <<
"non-const lvalue reference bound to bit-field";
9305 OS <<
"non-const lvalue reference bound to vector element";
9309 OS <<
"non-const lvalue reference bound to matrix element";
9313 OS <<
"non-const lvalue reference bound to unrelated type";
9317 OS <<
"rvalue reference bound to an lvalue";
9321 OS <<
"reference initialization drops qualifiers";
9325 OS <<
"reference with mismatching address space bound to temporary";
9329 OS <<
"reference initialization failed";
9333 OS <<
"conversion failed";
9337 OS <<
"conversion from property failed";
9341 OS <<
"too many initializers for scalar";
9345 OS <<
"parenthesized list init for reference";
9349 OS <<
"referencing binding to initializer list";
9353 OS <<
"initializer list for non-aggregate, non-scalar type";
9357 OS <<
"overloading failed for user-defined conversion";
9361 OS <<
"constructor overloading failed";
9365 OS <<
"default initialization of a const variable";
9369 OS <<
"initialization of incomplete type";
9373 OS <<
"list initialization checker failure";
9377 OS <<
"variable length array has an initializer";
9381 OS <<
"initializer expression isn't contextually valid";
9385 OS <<
"list constructor overloading failed";
9389 OS <<
"list copy initialization chose explicit constructor";
9393 OS <<
"parenthesized list initialization failed";
9397 OS <<
"designated initializer for non-aggregate type";
9405 OS <<
"Dependent sequence\n";
9409 OS <<
"Normal sequence: ";
9420 OS <<
"resolve address of overloaded function";
9424 OS <<
"derived-to-base (prvalue)";
9428 OS <<
"derived-to-base (xvalue)";
9432 OS <<
"derived-to-base (lvalue)";
9436 OS <<
"bind reference to lvalue";
9440 OS <<
"bind reference to a temporary";
9444 OS <<
"final copy in class direct-initialization";
9448 OS <<
"extraneous C++03 copy to temporary";
9452 OS <<
"user-defined conversion via " << *S->Function.Function;
9456 OS <<
"qualification conversion (prvalue)";
9460 OS <<
"qualification conversion (xvalue)";
9464 OS <<
"qualification conversion (lvalue)";
9468 OS <<
"function reference conversion";
9472 OS <<
"non-atomic-to-atomic conversion";
9476 OS <<
"implicit conversion sequence (";
9482 OS <<
"implicit conversion sequence with narrowing prohibited (";
9488 OS <<
"list aggregate initialization";
9492 OS <<
"unwrap reference initializer list";
9496 OS <<
"rewrap reference initializer list";
9500 OS <<
"constructor initialization";
9504 OS <<
"list initialization via constructor";
9508 OS <<
"zero initialization";
9512 OS <<
"C assignment";
9516 OS <<
"string initialization";
9520 OS <<
"Objective-C object conversion";
9524 OS <<
"indexing for array initialization loop";
9528 OS <<
"array initialization loop";
9532 OS <<
"array initialization";
9536 OS <<
"array initialization (GNU extension)";
9540 OS <<
"parenthesized array initialization";
9544 OS <<
"pass by indirect copy and restore";
9548 OS <<
"pass by indirect restore";
9552 OS <<
"Objective-C object retension";
9556 OS <<
"std::initializer_list from initializer list";
9560 OS <<
"list initialization from std::initializer_list";
9564 OS <<
"OpenCL sampler_t from integer constant";
9568 OS <<
"OpenCL opaque type from zero";
9571 OS <<
"initialization from a parenthesized list of values";
9575 OS <<
" [" << S->Type <<
']';
9589 const Expr *PostInit) {
9605 auto MakeDiag = [&](
bool IsConstRef,
unsigned DefaultDiagID,
9606 unsigned ConstRefDiagID,
unsigned WarnDiagID) {
9609 if (L.CPlusPlus11 && !L.HLSL &&
9611 DiagID = IsConstRef ? ConstRefDiagID : DefaultDiagID;
9613 DiagID = WarnDiagID;
9633 MakeDiag(
T != EntityType, diag::ext_init_list_type_narrowing,
9634 diag::ext_init_list_type_narrowing_const_reference,
9635 diag::warn_init_list_type_narrowing)
9637 <<
T.getLocalUnqualifiedType();
9644 diag::ext_init_list_constant_narrowing,
9645 diag::ext_init_list_constant_narrowing_const_reference,
9646 diag::warn_init_list_constant_narrowing)
9655 diag::ext_init_list_variable_narrowing,
9656 diag::ext_init_list_variable_narrowing_const_reference,
9657 diag::warn_init_list_variable_narrowing)
9665 llvm::raw_svector_ostream OS(StaticCast);
9666 OS <<
"static_cast<";
9673 OS << *TT->getDecl();
9682 S.
Diag(PostInit->
getBeginLoc(), diag::note_init_list_narrowing_silence)
9693 Init->IgnoreParenImpCasts(), ToType,
false,
9694 Sema::AllowedExplicit::None,
9710 S.
Diag(
Init->getBeginLoc(), diag::err_c23_constexpr_init_not_representable)
9711 <<
Value.getAsString(S.
Context, PreNarrowingType) << ToType;
9716 S.
Diag(
Init->getBeginLoc(), diag::err_c23_constexpr_init_type_mismatch)
9717 << ToType << FromType;
9727 llvm_unreachable(
"unhandled case in switch");
9739 for (
unsigned I = 0, N = SE->
getLength(); I != N; ++I) {
9744 diag::err_c23_constexpr_init_not_representable)
9758 if (
Init.isInvalid())
9762 assert(InitE &&
"No initialization expression");
9767 return !
Seq.Failed();
9774 bool TopLevelOfInitList,
9775 bool AllowExplicit) {
9776 if (
Init.isInvalid())
9780 assert(InitE &&
"No initialization expression?");
9790 const bool ShouldTrackCopy =
9792 if (ShouldTrackCopy) {
9794 Seq.SetOverloadFailure(
9800 const auto LastStep =
Seq.step_end() - 1;
9801 assert(LastStep->Kind ==
9805 llvm::find_if(
Seq.getFailedCandidateSet(),
9807 return Candidate.Viable &&
9808 Candidate.Function == Function &&
9809 Candidate.Conversions.size() > 0;
9811 if (Candidate !=
Seq.getFailedCandidateSet().end() &&
9813 Candidate->
Viable =
false;
9817 Function->getParamDecl(0)->getType());
9825 if (ShouldTrackCopy)
9834 auto NotSpecialization = [&] (
const CXXRecordDecl *Candidate) {
9835 auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(Candidate);
9838 return !(NotSpecialization(RD) && RD->
forallBases(NotSpecialization));
9844 auto *DeducedTST = dyn_cast<DeducedTemplateSpecializationType>(
9846 assert(DeducedTST &&
"not a deduced template specialization type");
9857 if (
auto *
AliasTemplate = dyn_cast_or_null<TypeAliasTemplateDecl>(
9859 Diag(Kind.getLocation(),
9860 diag::warn_cxx17_compat_ctad_for_alias_templates);
9863 ->getUnderlyingType()
9864 .getCanonicalType();
9868 if (
const auto *TST =
9870 Template = dyn_cast_or_null<ClassTemplateDecl>(
9871 TST->getTemplateName().getAsTemplateDecl());
9872 }
else if (
const auto *RT = UnderlyingType->getAs<
RecordType>()) {
9876 if (
const auto *CTSD = llvm::dyn_cast<ClassTemplateSpecializationDecl>(
9877 RT->getAsCXXRecordDecl()))
9878 Template = CTSD->getSpecializedTemplate();
9883 Diag(Kind.getLocation(),
9884 diag::err_deduced_non_class_or_alias_template_specialization_type)
9894 diag::warn_cxx14_compat_class_template_argument_deduction)
9922 ? dyn_cast<InitListExpr>(Inits[0])
9938 bool AllowExplicit = !Kind.isCopyInit() ||
ListInit;
9944 bool OnlyListConstructors,
9945 bool AllowAggregateDeductionCandidate) {
9951 if (!AllowExplicit) {
9958 if (GD->getMinRequiredArguments() > 1 ||
9959 (GD->getNumParams() == 0 && !GD->isVariadic()))
9969 if (!AllowAggregateDeductionCandidate &&
9984 for (
Expr *
E : Inits)
9985 if (
auto *DI = dyn_cast<DesignatedInitExpr>(
E))
9986 TmpInits.push_back(DI->getInit());
9988 TmpInits.push_back(
E);
9990 TD, FoundDecl,
nullptr, TmpInits, Candidates,
9992 false, AllowExplicit, ADLCallKind::NotADL,
9993 {}, AllowAggregateDeductionCandidate);
9997 false, AllowExplicit);
10001 bool FoundDeductionGuide =
false;
10003 auto TryToResolveOverload =
10006 bool HasAnyDeductionGuide =
false;
10009 auto *Pattern = Template;
10010 while (Pattern->getInstantiatedFromMemberTemplate()) {
10011 if (Pattern->isMemberSpecialization())
10013 Pattern = Pattern->getInstantiatedFromMemberTemplate();
10016 auto *RD = cast<CXXRecordDecl>(Pattern->getTemplatedDecl());
10022 InitListChecker CheckInitList(*
this, Entity,
ListInit, Ty, ElementTypes);
10023 if (!CheckInitList.HadError()) {
10032 for (
int I = 0,
E =
ListInit->getNumInits();
10033 I <
E && !isa<PackExpansionType>(ElementTypes[I]); ++I)
10034 if (ElementTypes[I]->isArrayType()) {
10035 if (isa<InitListExpr, DesignatedInitExpr>(
ListInit->getInit(I)))
10037 else if (isa<StringLiteral>(
10038 ListInit->getInit(I)->IgnoreParenImpCasts()))
10045 LookupTemplateDecl, ElementTypes,
10049 OnlyListConstructors,
10051 HasAnyDeductionGuide =
true;
10056 for (
auto I = Guides.
begin(),
E = Guides.
end(); I !=
E; ++I) {
10061 auto *TD = dyn_cast<FunctionTemplateDecl>(
D);
10062 auto *GD = dyn_cast_if_present<CXXDeductionGuideDecl>(
10067 if (!GD->isImplicit())
10068 HasAnyDeductionGuide =
true;
10070 addDeductionCandidate(TD, GD, I.getPair(), OnlyListConstructors,
10085 }
else if (Inits.size()) {
10090 Inits, Inits.back()->getEndLoc());
10091 SynthesizeAggrGuide(&TempListInit);
10095 FoundDeductionGuide = FoundDeductionGuide || HasAnyDeductionGuide;
10105 bool TryListConstructors =
true;
10111 auto *FD = dyn_cast<FunctionDecl>(
D->getUnderlyingDecl());
10112 if (FD && FD->getMinRequiredArguments() == 0) {
10113 TryListConstructors =
false;
10117 }
else if (
ListInit->getNumInits() == 1) {
10125 if (!isa<InitListExpr>(
E) && RD &&
10128 TryListConstructors =
false;
10131 if (TryListConstructors)
10132 Result = TryToResolveOverload(
true);
10141 Result = TryToResolveOverload(
false);
10150 Kind.getLocation(),
10151 PDiag(diag::err_deduced_class_template_ctor_ambiguous)
10158 cast<ClassTemplateDecl>(Template)->getTemplatedDecl();
10163 Kind.getLocation(),
10164 PDiag(
Complete ? diag::err_deduced_class_template_ctor_no_viable
10165 : diag::err_deduced_class_template_incomplete)
10175 Diag(Kind.getLocation(), diag::err_deduced_class_template_deleted)
10185 if (Kind.isCopyInit() &&
ListInit &&
10186 cast<CXXDeductionGuideDecl>(Best->Function)->isExplicit()) {
10187 bool IsDeductionGuide = !Best->Function->isImplicit();
10188 Diag(Kind.getLocation(), diag::err_deduced_class_template_explicit)
10190 Diag(Best->Function->getLocation(),
10191 diag::note_explicit_ctor_deduction_guide_here)
10192 << IsDeductionGuide;
10209 diag::warn_cxx14_compat_class_template_argument_deduction)
10214 if (!FoundDeductionGuide) {
10216 diag::warn_ctad_maybe_unsupported)
10218 Diag(Template->getLocation(), diag::note_suppress_ctad_maybe_unsupported);
Defines the clang::ASTContext interface.
static bool isUnsigned(SValBuilder &SVB, NonLoc Value)
static bool isRValueRef(QualType ParamType)
Defines the clang::Expr interface and subclasses for C++ expressions.
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
static std::string toString(const clang::SanitizerSet &Sanitizers)
Produce a string containing comma-separated names of sanitizers in Sanitizers set.
static void CheckForNullPointerDereference(Sema &S, Expr *E)
static bool isExprAnUnaddressableFunction(Sema &S, const Expr *E)
Tries to get a FunctionDecl out of E.
static void updateStringLiteralType(Expr *E, QualType Ty)
Update the type of a string literal, including any surrounding parentheses, to match the type of the ...
static void updateGNUCompoundLiteralRValue(Expr *E)
Fix a compound literal initializing an array so it's correctly marked as an rvalue.
static bool initializingConstexprVariable(const InitializedEntity &Entity)
static void warnBracedScalarInit(Sema &S, const InitializedEntity &Entity, SourceRange Braces)
Warn that Entity was of scalar type and was initialized by a single-element braced initializer list.
static bool shouldDestroyEntity(const InitializedEntity &Entity)
Whether the given entity, when initialized with an object created for that initialization,...
static SourceLocation getInitializationLoc(const InitializedEntity &Entity, Expr *Initializer)
Get the location at which initialization diagnostics should appear.
static bool hasAnyDesignatedInits(const InitListExpr *IL)
static bool tryObjCWritebackConversion(Sema &S, InitializationSequence &Sequence, const InitializedEntity &Entity, Expr *Initializer)
static DesignatedInitExpr * CloneDesignatedInitExpr(Sema &SemaRef, DesignatedInitExpr *DIE)
static ExprResult CopyObject(Sema &S, QualType T, const InitializedEntity &Entity, ExprResult CurInit, bool IsExtraneousCopy)
Make a (potentially elidable) temporary copy of the object provided by the given initializer by calli...
static void TryOrBuildParenListInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, ArrayRef< Expr * > Args, InitializationSequence &Sequence, bool VerifyOnly, ExprResult *Result=nullptr)
static void CheckMoveOnConstruction(Sema &S, const Expr *InitExpr, bool IsReturnStmt)
Provide warnings when std::move is used on construction.
static void CheckC23ConstexprInitStringLiteral(const StringLiteral *SE, Sema &SemaRef, QualType &TT)
static void CheckCXX98CompatAccessibleCopy(Sema &S, const InitializedEntity &Entity, Expr *CurInitExpr)
Check whether elidable copy construction for binding a reference to a temporary would have succeeded ...
static bool isOrIsDerivedFromSpecializationOf(CXXRecordDecl *RD, ClassTemplateDecl *CTD)
Determine whether RD is, or is derived from, a specialization of CTD.
static bool canInitializeArrayWithEmbedDataString(ArrayRef< Expr * > ExprList, const InitializedEntity &Entity, ASTContext &Context)
static bool TryInitializerListConstruction(Sema &S, InitListExpr *List, QualType DestType, InitializationSequence &Sequence, bool TreatUnavailableAsInvalid)
When initializing from init list via constructor, handle initialization of an object of type std::ini...
static StringInitFailureKind IsStringInit(Expr *Init, const ArrayType *AT, ASTContext &Context)
Check whether the array of type AT can be initialized by the Init expression by means of string initi...
static void TryArrayCopy(Sema &S, const InitializationKind &Kind, const InitializedEntity &Entity, Expr *Initializer, QualType DestType, InitializationSequence &Sequence, bool TreatUnavailableAsInvalid)
Initialize an array from another array.
static bool isInitializedStructuredList(const InitListExpr *StructuredList)
@ SIF_PlainStringIntoUTF8Char
@ SIF_IncompatWideStringIntoWideChar
@ SIF_UTF8StringIntoPlainChar
@ SIF_NarrowStringIntoWideChar
static void TryDefaultInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, InitializationSequence &Sequence)
Attempt default initialization (C++ [dcl.init]p6).
static bool TryOCLSamplerInitialization(Sema &S, InitializationSequence &Sequence, QualType DestType, Expr *Initializer)
static bool maybeRecoverWithZeroInitialization(Sema &S, InitializationSequence &Sequence, const InitializedEntity &Entity)
Tries to add a zero initializer. Returns true if that worked.
static ExprResult CheckArrayDesignatorExpr(Sema &S, Expr *Index, llvm::APSInt &Value)
Check that the given Index expression is a valid array designator value.
static bool canPerformArrayCopy(const InitializedEntity &Entity)
Determine whether we can perform an elementwise array copy for this kind of entity.
static bool IsZeroInitializer(Expr *Initializer, Sema &S)
static void TryReferenceInitializationCore(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, Expr *Initializer, QualType cv1T1, QualType T1, Qualifiers T1Quals, QualType cv2T2, QualType T2, Qualifiers T2Quals, InitializationSequence &Sequence, bool TopLevelOfInitList)
Reference initialization without resolving overloaded functions.
static void CheckC23ConstexprInitConversion(Sema &S, QualType FromType, QualType ToType, Expr *Init)
static void ExpandAnonymousFieldDesignator(Sema &SemaRef, DesignatedInitExpr *DIE, unsigned DesigIdx, IndirectFieldDecl *IndirectField)
Expand a field designator that refers to a member of an anonymous struct or union into a series of fi...
static void TryValueInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, InitializationSequence &Sequence, InitListExpr *InitList=nullptr)
Attempt value initialization (C++ [dcl.init]p7).
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...
static OverloadingResult ResolveConstructorOverload(Sema &S, SourceLocation DeclLoc, MultiExprArg Args, OverloadCandidateSet &CandidateSet, QualType DestType, DeclContext::lookup_result Ctors, OverloadCandidateSet::iterator &Best, bool CopyInitializing, bool AllowExplicit, bool OnlyListConstructors, bool IsListInit, bool RequireActualConstructor, bool SecondStepOfCopyInit=false)
static AssignmentAction getAssignmentAction(const InitializedEntity &Entity, bool Diagnose=false)
static void TryListInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, InitListExpr *InitList, InitializationSequence &Sequence, bool TreatUnavailableAsInvalid)
Attempt list initialization (C++0x [dcl.init.list])
static void TryStringLiteralInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, Expr *Initializer, InitializationSequence &Sequence)
Attempt character array initialization from a string literal (C++ [dcl.init.string],...
static bool checkDestructorReference(QualType ElementType, SourceLocation Loc, Sema &SemaRef)
Check if the type of a class element has an accessible destructor, and marks it referenced.
static void TryReferenceInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, Expr *Initializer, InitializationSequence &Sequence, bool TopLevelOfInitList)
Attempt reference initialization (C++0x [dcl.init.ref])
static void DiagnoseNarrowingInInitList(Sema &S, const ImplicitConversionSequence &ICS, QualType PreNarrowingType, QualType EntityType, const Expr *PostInit)
static bool hasCompatibleArrayTypes(ASTContext &Context, const ArrayType *Dest, const ArrayType *Source)
Determine whether we have compatible array types for the purposes of GNU by-copy array initialization...
static void CheckStringInit(Expr *Str, QualType &DeclT, const ArrayType *AT, Sema &S, bool CheckC23ConstexprInit=false)
static bool isExplicitTemporary(const InitializedEntity &Entity, const InitializationKind &Kind, unsigned NumArgs)
Returns true if the parameters describe a constructor initialization of an explicit temporary object,...
static bool isNonReferenceableGLValue(Expr *E)
Determine whether an expression is a non-referenceable glvalue (one to which a reference can never bi...
static bool TryOCLZeroOpaqueTypeInitialization(Sema &S, InitializationSequence &Sequence, QualType DestType, Expr *Initializer)
static bool IsWideCharCompatible(QualType T, ASTContext &Context)
Check whether T is compatible with a wide character type (wchar_t, char16_t or char32_t).
static void diagnoseListInit(Sema &S, const InitializedEntity &Entity, InitListExpr *InitList)
static OverloadingResult TryRefInitWithConversionFunction(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, Expr *Initializer, bool AllowRValues, bool IsLValueRef, InitializationSequence &Sequence)
Try a reference initialization that involves calling a conversion function.
void emitUninitializedExplicitInitFields(Sema &S, const RecordDecl *R)
static void TryConstructorInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Args, QualType DestType, QualType DestArrayType, InitializationSequence &Sequence, bool IsListInit=false, bool IsInitListCopy=false)
Attempt initialization by constructor (C++ [dcl.init]), which enumerates the constructors of the init...
static void emitBadConversionNotes(Sema &S, const InitializedEntity &entity, Expr *op)
Emit notes associated with an initialization that failed due to a "simple" conversion failure.
static bool isIdiomaticBraceElisionEntity(const InitializedEntity &Entity)
Determine whether Entity is an entity for which it is idiomatic to elide the braces in aggregate init...
static void MaybeProduceObjCObject(Sema &S, InitializationSequence &Sequence, const InitializedEntity &Entity)
static void checkIndirectCopyRestoreSource(Sema &S, Expr *src)
Check whether the given expression is a valid operand for an indirect copy/restore.
static bool shouldBindAsTemporary(const InitializedEntity &Entity)
Whether we should bind a created object as a temporary when initializing the given entity.
static bool ResolveOverloadedFunctionForReferenceBinding(Sema &S, Expr *Initializer, QualType &SourceType, QualType &UnqualifiedSourceType, QualType UnqualifiedTargetType, InitializationSequence &Sequence)
InvalidICRKind
The non-zero enum values here are indexes into diagnostic alternatives.
static ExprResult PerformConstructorInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Args, const InitializationSequence::Step &Step, bool &ConstructorInitRequiresZeroInit, bool IsListInitialization, bool IsStdInitListInitialization, SourceLocation LBraceLoc, SourceLocation RBraceLoc)
static void TryReferenceListInitialization(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, InitListExpr *InitList, InitializationSequence &Sequence, bool TreatUnavailableAsInvalid)
Attempt list initialization of a reference.
static bool isLibstdcxxPointerReturnFalseHack(Sema &S, const InitializedEntity &Entity, const Expr *Init)
An egregious hack for compatibility with libstdc++-4.2: in <tr1/hashtable>, a function with a pointer...
static bool hasCopyOrMoveCtorParam(ASTContext &Ctx, const ConstructorInfo &Info)
Determine if the constructor has the signature of a copy or move constructor for the type T of the cl...
static bool DiagnoseUninitializedReference(Sema &S, SourceLocation Loc, QualType T)
Somewhere within T there is an uninitialized reference subobject.
static InvalidICRKind isInvalidICRSource(ASTContext &C, Expr *e, bool isAddressOf, bool &isWeakAccess)
Determines whether this expression is an acceptable ICR source.
This file declares semantic analysis for Objective-C.
Defines the SourceManager interface.
Defines various enumerations that describe declaration and type specifiers.
static QualType getPointeeType(const MemRegion *R)
Defines the clang::TypeLoc interface and its subclasses.
__device__ __2f16 float __ockl_bool s
APValue - This class implements a discriminated union of [uninitialized] [APSInt] [APFloat],...
std::string getAsString(const ASTContext &Ctx, QualType Ty) const
bool isNullPointer() 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 getRValueReferenceType(QualType T) const
Return the uniqued reference to the type for an rvalue reference to the specified type.
unsigned getIntWidth(QualType T) const
QualType getTagDeclType(const TagDecl *Decl) const
Return the unique reference to the type for the specified TagDecl (struct/union/class/enum) decl.
DeclarationNameTable DeclarationNames
QualType getRecordType(const RecordDecl *Decl) const
void getObjCEncodingForType(QualType T, std::string &S, const FieldDecl *Field=nullptr, QualType *NotEncodedT=nullptr) const
Emit the Objective-CC type encoding for the given type T into S.
CanQualType getCanonicalType(QualType T) const
Return the canonical (structural) type corresponding to the specified potentially non-canonical type ...
bool hasSameType(QualType T1, QualType T2) const
Determine whether the given types T1 and T2 are equivalent.
QualType getVectorType(QualType VectorType, unsigned NumElts, VectorKind VecKind) const
Return the unique reference to a vector type of the specified element type and size.
QualType getPointerType(QualType T) const
Return the uniqued reference to the type for a pointer to the specified type.
const IncompleteArrayType * getAsIncompleteArrayType(QualType T) const
QualType getLValueReferenceType(QualType T, bool SpelledAsLValue=true) const
Return the uniqued reference to the type for an lvalue reference to the specified type.
QualType getTypeDeclType(const TypeDecl *Decl, const TypeDecl *PrevDecl=nullptr) const
Return the unique reference to the type for the specified type declaration.
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
QualType getBaseElementType(const ArrayType *VAT) const
Return the innermost element type of an array type.
TypeSourceInfo * getTrivialTypeSourceInfo(QualType T, SourceLocation Loc=SourceLocation()) const
Allocate a TypeSourceInfo where all locations have been initialized to a given location,...
CanQualType getSizeType() const
Return the unique type for "size_t" (C99 7.17), defined in <stddef.h>.
QualType getQualifiedType(SplitQualType split) const
Un-split a SplitQualType.
QualType getPackExpansionType(QualType Pattern, std::optional< unsigned > NumExpansions, bool ExpectPackInType=true) const
Form a pack expansion type with the given pattern.
QualType getDependentSizedArrayType(QualType EltTy, Expr *NumElts, ArraySizeModifier ASM, unsigned IndexTypeQuals, SourceRange Brackets) const
Return a non-unique reference to the type for a dependently-sized array of the specified element type...
bool hasSameUnqualifiedType(QualType T1, QualType T2) const
Determine whether the given types are equivalent after cvr-qualifiers have been removed.
const ArrayType * getAsArrayType(QualType T) const
Type Query functions.
uint64_t getTypeSize(QualType T) const
Return the size of the specified (complete) type T, in bits.
QualType getPromotedIntegerType(QualType PromotableType) const
Return the type that PromotableType will promote to: C99 6.3.1.1p2, assuming that PromotableType is a...
const VariableArrayType * getAsVariableArrayType(QualType T) const
QualType getExtVectorType(QualType VectorType, unsigned NumElts) const
Return the unique reference to an extended vector type of the specified element type and size.
const TargetInfo & getTargetInfo() const
bool typesAreCompatible(QualType T1, QualType T2, bool CompareUnqualified=false)
Compatibility predicates used to check assignment expressions.
QualType getWideCharType() const
Return the type of wide characters.
bool isPromotableIntegerType(QualType T) const
More type predicates useful for type checking/promotion.
QualType getUnqualifiedArrayType(QualType T, Qualifiers &Quals) const
Return this type as a completely-unqualified array type, capturing the qualifiers in Quals.
uint64_t getCharWidth() const
Return the size of the character type, in bits.
Represents the index of the current element of an array being initialized by an ArrayInitLoopExpr.
Represents a loop initializing the elements of an array.
ArraySubscriptExpr - [C99 6.5.2.1] Array Subscripting.
Represents an array type, per C99 6.7.5.2 - Array Declarators.
QualType getElementType() const
This class is used for builtin types like 'int'.
Represents a base class of a C++ class.
bool isVirtual() const
Determines whether the base class is a virtual base class (or not).
QualType getType() const
Retrieves the type of the base class.
Represents a call to a C++ constructor.
Expr * getArg(unsigned Arg)
Return the specified argument.
CXXConstructorDecl * getConstructor() const
Get the constructor that this expression will (ultimately) call.
unsigned getNumArgs() const
Return the number of arguments to the constructor call.
Represents a C++ constructor within a class.
CXXConstructorDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
bool isExplicit() const
Return true if the declaration is already resolved to be explicit.
bool isCopyOrMoveConstructor(unsigned &TypeQuals) const
Determine whether this is a copy or move constructor.
Represents a C++ conversion function within a class.
QualType getConversionType() const
Returns the type that this conversion function is converting to.
Represents a C++ deduction guide declaration.
Represents a C++ destructor within a class.
const CXXRecordDecl * getParent() const
Return the parent of this method declaration, which is the class in which this method is defined.
static CXXParenListInitExpr * Create(ASTContext &C, ArrayRef< Expr * > Args, QualType T, unsigned NumUserSpecifiedExprs, SourceLocation InitLoc, SourceLocation LParenLoc, SourceLocation RParenLoc)
Represents a C++ struct/union/class.
bool isAggregate() const
Determine whether this class is an aggregate (C++ [dcl.init.aggr]), which is a class with no user-dec...
bool hasUninitializedReferenceMember() const
Whether this class or any of its subobjects has any members of reference type which would make value-...
bool allowConstDefaultInit() const
Determine whether declaring a const variable with this type is ok per core issue 253.
CXXRecordDecl * getDefinition() const
llvm::iterator_range< conversion_iterator > getVisibleConversionFunctions() const
Get all conversion functions visible in current class, including conversion function templates.
unsigned getNumBases() const
Retrieves the number of base classes of this class.
llvm::iterator_range< base_class_iterator > base_class_range
llvm::iterator_range< base_class_const_iterator > base_class_const_range
bool forallBases(ForallBasesCallback BaseMatches) const
Determines if the given callback holds for all the direct or indirect base classes of this type.
An expression "T()" which creates an rvalue of a non-class type T.
Implicit construction of a std::initializer_list<T> object from an array temporary within list-initia...
static CXXTemporaryObjectExpr * Create(const ASTContext &Ctx, CXXConstructorDecl *Cons, QualType Ty, TypeSourceInfo *TSI, ArrayRef< Expr * > Args, SourceRange ParenOrBraceRange, bool HadMultipleCandidates, bool ListInitialization, bool StdInitListInitialization, bool ZeroInitialization)
CallExpr - Represents a function call (C99 6.5.2.2, C++ [expr.call]).
Expr * getArg(unsigned Arg)
getArg - Return the specified argument.
SourceLocation getBeginLoc() const LLVM_READONLY
bool isCallToStdMove() const
SourceLocation getRParenLoc() const
CanQual< T > getUnqualifiedType() const
Retrieve the unqualified form of this type.
CastExpr - Base class for type casts, including both implicit casts (ImplicitCastExpr) and explicit c...
SourceLocation getBegin() const
Declaration of a class template.
void setExprNeedsCleanups(bool SideEffects)
Complex values, per C99 6.2.5p11.
QualType getElementType() const
ConditionalOperator - The ?: ternary operator.
Represents the canonical version of C arrays with a specified constant size.
static unsigned getMaxSizeBits(const ASTContext &Context)
Determine the maximum number of active bits that an array's size can require, which limits the maximu...
uint64_t getZExtSize() const
Return the size zero-extended as a uint64_t.
Base class for callback objects used by Sema::CorrectTypo to check the validity of a potential typo c...
virtual bool ValidateCandidate(const TypoCorrection &candidate)
Simple predicate used by the default RankCandidate to determine whether to return an edit distance of...
virtual std::unique_ptr< CorrectionCandidateCallback > clone()=0
Clone this CorrectionCandidateCallback.
A POD class for pairing a NamedDecl* with an access specifier.
static DeclAccessPair make(NamedDecl *D, AccessSpecifier AS)
NamedDecl * getDecl() const
The results of name lookup within a DeclContext.
decl_iterator - Iterates through the declarations stored within this context.
specific_decl_iterator - Iterates over a subrange of declarations stored in a DeclContext,...
bool Equals(const DeclContext *DC) const
Determine whether this declaration context is equivalent to the declaration context DC.
bool InEnclosingNamespaceSetOf(const DeclContext *NS) const
Test if this context is part of the enclosing namespace set of the context NS, as defined in C++0x [n...
lookup_result lookup(DeclarationName Name) const
lookup - Find the declarations (if any) with the given Name in this context.
DeclContext * getRedeclContext()
getRedeclContext - Retrieve the context in which an entity conflicts with other entities of the same ...
decl_range decls() const
decls_begin/decls_end - Iterate over the declarations stored in this context.
A reference to a declared variable, function, enum, etc.
bool refersToEnclosingVariableOrCapture() const
Does this DeclRefExpr refer to an enclosing local or a captured variable?
Decl - This represents one declaration (or definition), e.g.
SourceLocation getEndLoc() const LLVM_READONLY
bool isInvalidDecl() const
SourceLocation getLocation() const
DeclContext * getDeclContext()
SourceLocation getBeginLoc() const LLVM_READONLY
The name of a declaration.
SourceLocation getBeginLoc() const LLVM_READONLY
Common base class for placeholders for types that get replaced by placeholder type deduction: C++11 a...
Represents a single C99 designator.
SourceLocation getBeginLoc() const LLVM_READONLY
SourceLocation getFieldLoc() const
SourceLocation getDotLoc() const
Represents a C99 designated initializer expression.
bool isDirectInit() const
Whether this designated initializer should result in direct-initialization of the designated subobjec...
Expr * getArrayRangeEnd(const Designator &D) const
Expr * getSubExpr(unsigned Idx) const
llvm::MutableArrayRef< Designator > designators()
bool usesGNUSyntax() const
Determines whether this designated initializer used the deprecated GNU syntax for designated initiali...
Expr * getArrayRangeStart(const Designator &D) const
void ExpandDesignator(const ASTContext &C, unsigned Idx, const Designator *First, const Designator *Last)
Replaces the designator at index Idx with the series of designators in [First, Last).
static DesignatedInitExpr * Create(const ASTContext &C, llvm::ArrayRef< Designator > Designators, ArrayRef< Expr * > IndexExprs, SourceLocation EqualOrColonLoc, bool GNUSyntax, Expr *Init)
Expr * getArrayIndex(const Designator &D) const
Designator * getDesignator(unsigned Idx)
Expr * getInit() const
Retrieve the initializer value.
unsigned size() const
Returns the number of designators in this initializer.
SourceLocation getBeginLoc() const LLVM_READONLY
SourceLocation getEndLoc() const LLVM_READONLY
SourceLocation getEqualOrColonLoc() const
Retrieve the location of the '=' that precedes the initializer value itself, if present.
unsigned getNumSubExprs() const
Retrieve the total number of subexpressions in this designated initializer expression,...
InitListExpr * getUpdater() const
Designation - Represent a full designation, which is a sequence of designators.
const Designator & getDesignator(unsigned Idx) const
unsigned getNumDesignators() const
Designator - A designator in a C99 designated initializer.
static Designator CreateFieldDesignator(const IdentifierInfo *FieldName, SourceLocation DotLoc, SourceLocation FieldLoc)
Creates a field designator.
bool isIgnored(unsigned DiagID, SourceLocation Loc) const
Determine whether the diagnostic is known to be ignored.
Represents a reference to #emded data.
StringLiteral * getDataStringLiteral() const
EmbedDataStorage * getData() const
SourceLocation getLocation() const
size_t getDataElementCount() const
RAII object that enters a new expression evaluation context.
A helper class that allows the use of isa/cast/dyncast to detect TagType objects of enums.
The return type of classify().
This represents one expression.
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 refersToVectorElement() const
Returns whether this expression refers to a vector element.
bool isTypeDependent() const
Determines whether the type of this expression depends on.
llvm::APSInt EvaluateKnownConstInt(const ASTContext &Ctx, SmallVectorImpl< PartialDiagnosticAt > *Diag=nullptr) const
EvaluateKnownConstInt - Call EvaluateAsRValue and return the folded integer.
Expr * IgnoreParenImpCasts() LLVM_READONLY
Skip past any parentheses and implicit casts which might surround this expression until reaching a fi...
Expr * IgnoreImplicit() LLVM_READONLY
Skip past any implicit AST nodes which might surround this expression until reaching a fixed point.
Expr * IgnoreParens() LLVM_READONLY
Skip past any parentheses which might surround this expression until reaching a fixed point.
bool isLValue() const
isLValue - True if this expression is an "l-value" according to the rules of the current language.
static bool hasAnyTypeDependentArguments(ArrayRef< Expr * > Exprs)
hasAnyTypeDependentArguments - Determines if any of the expressions in Exprs is type-dependent.
@ 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 EvaluateAsRValue(EvalResult &Result, const ASTContext &Ctx, bool InConstantContext=false) const
EvaluateAsRValue - Return true if this is a constant which we can fold to an rvalue using any crazy t...
bool HasSideEffects(const ASTContext &Ctx, bool IncludePossibleEffects=true) const
HasSideEffects - This routine returns true for all those expressions which have any effect other than...
Expr * IgnoreImpCasts() LLVM_READONLY
Skip past any implicit casts which might surround this expression until reaching a fixed point.
bool isTemporaryObject(ASTContext &Ctx, const CXXRecordDecl *TempTy) const
Determine whether the result of this expression is a temporary object of the given class type.
NullPointerConstantKind isNullPointerConstant(ASTContext &Ctx, NullPointerConstantValueDependence NPC) const
isNullPointerConstant - C99 6.3.2.3p3 - Test if this reduces down to a Null pointer constant.
void setValueKind(ExprValueKind Cat)
setValueKind - Set the value kind produced by this expression.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
bool refersToMatrixElement() const
Returns whether this expression refers to a matrix element.
bool refersToBitField() const
Returns true if this expression is a gl-value that potentially refers to a bit-field.
ExtVectorType - Extended vector type.
Represents difference between two FPOptions values.
Represents a member of a struct/union/class.
bool hasInClassInitializer() const
Determine whether this member has a C++11 default member initializer.
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
unsigned getFieldIndex() const
Returns the index of this field within its record, as appropriate for passing to ASTRecordLayout::get...
bool isUnnamedBitField() const
Determines whether this is an unnamed bitfield.
static FixItHint CreateRemoval(CharSourceRange RemoveRange)
Create a code modification hint that removes the given source range.
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.
const ParmVarDecl * getParamDecl(unsigned i) const
unsigned getMinRequiredArguments() const
Returns the minimum number of arguments needed to call this function.
QualType getReturnType() const
bool isDeleted() const
Whether this function has been deleted.
bool isDefaulted() const
Whether this function is defaulted.
unsigned getNumParams() const
Return the number of parameters this function must have based on its FunctionType.
Declaration of a template function.
FunctionDecl * getTemplatedDecl() const
Get the underlying function declaration of the template.
One of these records is kept for each identifier that is lexed.
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...
@ StaticObjectArgumentConversion
StandardConversionSequence Standard
When ConversionKind == StandardConversion, provides the details of the standard conversion sequence.
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 ...
Represents an implicitly-generated value initialization of an object of a given type.
Represents a C array with an unspecified size.
Represents a field injected from an anonymous union/struct into the parent scope.
chain_iterator chain_end() const
chain_iterator chain_begin() const
ArrayRef< NamedDecl * >::const_iterator chain_iterator
Describes an C or C++ initializer list.
bool hasArrayFiller() const
Return true if this is an array initializer and its array "filler" has been set.
void setSyntacticForm(InitListExpr *Init)
void markError()
Mark the semantic form of the InitListExpr as error when the semantic analysis fails.
bool hasDesignatedInit() const
Determine whether this initializer list contains a designated initializer.
bool isTransparent() const
Is this a transparent initializer list (that is, an InitListExpr that is purely syntactic,...
void resizeInits(const ASTContext &Context, unsigned NumInits)
Specify the number of initializers.
FieldDecl * getInitializedFieldInUnion()
If this initializes a union, specifies which field in the union to initialize.
unsigned getNumInits() const
SourceLocation getBeginLoc() const LLVM_READONLY
void setInit(unsigned Init, Expr *expr)
SourceLocation getLBraceLoc() const
Expr * updateInit(const ASTContext &C, unsigned Init, Expr *expr)
Updates the initializer at index Init with the new expression expr, and returns the old expression at...
void setArrayFiller(Expr *filler)
InitListExpr * getSyntacticForm() const
Expr * getArrayFiller()
If this initializer list initializes an array with more elements than there are initializers in the l...
SourceLocation getRBraceLoc() const
const Expr * getInit(unsigned Init) const
bool isIdiomaticZeroInitializer(const LangOptions &LangOpts) const
Is this the zero initializer {0} in a language which considers it idiomatic?
SourceLocation getEndLoc() const LLVM_READONLY
void setInitializedFieldInUnion(FieldDecl *FD)
bool isSyntacticForm() const
ArrayRef< Expr * > inits()
void setRBraceLoc(SourceLocation Loc)
void sawArrayRangeDesignator(bool ARD=true)
Expr ** getInits()
Retrieve the set of initializers.
Describes the kind of initialization being performed, along with location information for tokens rela...
@ IK_DirectList
Direct list-initialization.
@ IK_Value
Value initialization.
@ IK_Direct
Direct initialization.
@ IK_Copy
Copy initialization.
@ IK_Default
Default initialization.
static InitializationKind CreateDirect(SourceLocation InitLoc, SourceLocation LParenLoc, SourceLocation RParenLoc)
Create a direct initialization.
static InitializationKind CreateForInit(SourceLocation Loc, bool DirectInit, Expr *Init)
Create an initialization from an initializer (which, for direct initialization from a parenthesized l...
static InitializationKind CreateCopy(SourceLocation InitLoc, SourceLocation EqualLoc, bool AllowExplicitConvs=false)
Create a copy initialization.
static InitializationKind CreateDirectList(SourceLocation InitLoc)
static InitializationKind CreateValue(SourceLocation InitLoc, SourceLocation LParenLoc, SourceLocation RParenLoc, bool isImplicit=false)
Create a value initialization.
A single step in the initialization sequence.
StepKind Kind
The kind of conversion or initialization step we are taking.
InitListExpr * WrappingSyntacticList
When Kind = SK_RewrapInitList, the syntactic form of the wrapping list.
ImplicitConversionSequence * ICS
When Kind = SK_ConversionSequence, the implicit conversion sequence.
struct F Function
When Kind == SK_ResolvedOverloadedFunction or Kind == SK_UserConversion, the function that the expres...
Describes the sequence of initializations required to initialize a given object or reference with a s...
step_iterator step_begin() const
void AddListInitializationStep(QualType T)
Add a list-initialization step.
ExprResult Perform(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Args, QualType *ResultType=nullptr)
Perform the actual initialization of the given entity based on the computed initialization sequence.
void AddStringInitStep(QualType T)
Add a string init step.
void AddStdInitializerListConstructionStep(QualType T)
Add a step to construct a std::initializer_list object from an initializer list.
void AddConstructorInitializationStep(DeclAccessPair FoundDecl, CXXConstructorDecl *Constructor, QualType T, bool HadMultipleCandidates, bool FromInitList, bool AsInitList)
Add a constructor-initialization step.
@ SK_StdInitializerListConstructorCall
Perform initialization via a constructor taking a single std::initializer_list argument.
@ SK_AtomicConversion
Perform a conversion adding _Atomic to a type.
@ SK_ObjCObjectConversion
An initialization that "converts" an Objective-C object (not a point to an object) to another Objecti...
@ SK_GNUArrayInit
Array initialization (from an array rvalue) as a GNU extension.
@ SK_CastDerivedToBaseLValue
Perform a derived-to-base cast, producing an lvalue.
@ SK_ProduceObjCObject
Produce an Objective-C object pointer.
@ SK_FunctionReferenceConversion
Perform a function reference conversion, see [dcl.init.ref]p4.
@ SK_BindReference
Reference binding to an lvalue.
@ SK_ArrayLoopInit
Array initialization by elementwise copy.
@ SK_ConstructorInitialization
Perform initialization via a constructor.
@ SK_OCLSamplerInit
Initialize an OpenCL sampler from an integer.
@ SK_StringInit
Initialization by string.
@ SK_ZeroInitialization
Zero-initialize the object.
@ SK_CastDerivedToBaseXValue
Perform a derived-to-base cast, producing an xvalue.
@ SK_QualificationConversionXValue
Perform a qualification conversion, producing an xvalue.
@ SK_UserConversion
Perform a user-defined conversion, either via a conversion function or via a constructor.
@ SK_CastDerivedToBasePRValue
Perform a derived-to-base cast, producing an rvalue.
@ SK_BindReferenceToTemporary
Reference binding to a temporary.
@ SK_PassByIndirectRestore
Pass an object by indirect restore.
@ SK_ParenthesizedArrayInit
Array initialization from a parenthesized initializer list.
@ SK_ParenthesizedListInit
Initialize an aggreagate with parenthesized list of values.
@ SK_ArrayInit
Array initialization (from an array rvalue).
@ SK_ExtraneousCopyToTemporary
An optional copy of a temporary object to another temporary object, which is permitted (but not requi...
@ SK_ArrayLoopIndex
Array indexing for initialization by elementwise copy.
@ SK_ConversionSequenceNoNarrowing
Perform an implicit conversion sequence without narrowing.
@ SK_RewrapInitList
Rewrap the single-element initializer list for a reference.
@ SK_CAssignment
C assignment.
@ SK_ConstructorInitializationFromList
Perform initialization via a constructor, taking arguments from a single InitListExpr.
@ SK_PassByIndirectCopyRestore
Pass an object by indirect copy-and-restore.
@ SK_ResolveAddressOfOverloadedFunction
Resolve the address of an overloaded function to a specific function declaration.
@ SK_UnwrapInitList
Unwrap the single-element initializer list for a reference.
@ SK_FinalCopy
Direct-initialization from a reference-related object in the final stage of class copy-initialization...
@ SK_QualificationConversionLValue
Perform a qualification conversion, producing an lvalue.
@ SK_StdInitializerList
Construct a std::initializer_list from an initializer list.
@ SK_QualificationConversionPRValue
Perform a qualification conversion, producing a prvalue.
@ SK_ConversionSequence
Perform an implicit conversion sequence.
@ SK_ListInitialization
Perform list-initialization without a constructor.
@ SK_OCLZeroOpaqueType
Initialize an opaque OpenCL type (event_t, queue_t, etc.) with zero.
void AddUserConversionStep(FunctionDecl *Function, DeclAccessPair FoundDecl, QualType T, bool HadMultipleCandidates)
Add a new step invoking a conversion function, which is either a constructor or a conversion function...
void SetZeroInitializationFixit(const std::string &Fixit, SourceLocation L)
Call for initializations are invalid but that would be valid zero initialzations if Fixit was applied...
InitializationSequence(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Args, bool TopLevelOfInitList=false, bool TreatUnavailableAsInvalid=true)
Try to perform initialization of the given entity, creating a record of the steps required to perform...
void AddQualificationConversionStep(QualType Ty, ExprValueKind Category)
Add a new step that performs a qualification conversion to the given type.
void AddFunctionReferenceConversionStep(QualType Ty)
Add a new step that performs a function reference conversion to the given type.
~InitializationSequence()
void AddDerivedToBaseCastStep(QualType BaseType, ExprValueKind Category)
Add a new step in the initialization that performs a derived-to- base cast.
FailureKind getFailureKind() const
Determine why initialization failed.
void InitializeFrom(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Args, bool TopLevelOfInitList, bool TreatUnavailableAsInvalid)
void AddParenthesizedListInitStep(QualType T)
void SetFailed(FailureKind Failure)
Note that this initialization sequence failed.
bool isAmbiguous() const
Determine whether this initialization failed due to an ambiguity.
void AddUnwrapInitListInitStep(InitListExpr *Syntactic)
Only used when initializing structured bindings from an array with direct-list-initialization.
void AddOCLZeroOpaqueTypeStep(QualType T)
Add a step to initialzie an OpenCL opaque type (event_t, queue_t, etc.) from a zero constant.
void AddFinalCopy(QualType T)
Add a new step that makes a copy of the input to an object of the given type, as the final step in cl...
void setSequenceKind(enum SequenceKind SK)
Set the kind of sequence computed.
void AddObjCObjectConversionStep(QualType T)
Add an Objective-C object conversion step, which is always a no-op.
void SetOverloadFailure(FailureKind Failure, OverloadingResult Result)
Note that this initialization sequence failed due to failed overload resolution.
step_iterator step_end() const
void AddParenthesizedArrayInitStep(QualType T)
Add a parenthesized array initialization step.
void AddExtraneousCopyToTemporary(QualType T)
Add a new step that makes an extraneous copy of the input to a temporary of the same class type.
void setIncompleteTypeFailure(QualType IncompleteType)
Note that this initialization sequence failed due to an incomplete type.
void AddOCLSamplerInitStep(QualType T)
Add a step to initialize an OpenCL sampler from an integer constant.
void AddCAssignmentStep(QualType T)
Add a C assignment step.
void AddPassByIndirectCopyRestoreStep(QualType T, bool shouldCopy)
Add a step to pass an object by indirect copy-restore.
void RewrapReferenceInitList(QualType T, InitListExpr *Syntactic)
Add steps to unwrap a initializer list for a reference around a single element and rewrap it at the e...
bool Diagnose(Sema &S, const InitializedEntity &Entity, const InitializationKind &Kind, ArrayRef< Expr * > Args)
Diagnose an potentially-invalid initialization sequence.
bool Failed() const
Determine whether the initialization sequence is invalid.
void AddAtomicConversionStep(QualType Ty)
Add a new step that performs conversion from non-atomic to atomic type.
void dump() const
Dump a representation of this initialization sequence to standard error, for debugging purposes.
void AddConversionSequenceStep(const ImplicitConversionSequence &ICS, QualType T, bool TopLevelOfInitList=false)
Add a new step that applies an implicit conversion sequence.
void AddZeroInitializationStep(QualType T)
Add a zero-initialization step.
void AddProduceObjCObjectStep(QualType T)
Add a step to "produce" an Objective-C object (by retaining it).
enum SequenceKind getKind() const
Determine the kind of initialization sequence computed.
SequenceKind
Describes the kind of initialization sequence computed.
@ NormalSequence
A normal sequence.
@ FailedSequence
A failed initialization sequence.
@ DependentSequence
A dependent initialization, which could not be type-checked due to the presence of dependent types or...
void AddReferenceBindingStep(QualType T, bool BindingTemporary)
Add a new step binding a reference to an object.
FailureKind
Describes why initialization failed.
@ FK_UserConversionOverloadFailed
Overloading for a user-defined conversion failed.
@ FK_NarrowStringIntoWideCharArray
Initializing a wide char array with narrow string literal.
@ FK_ArrayTypeMismatch
Array type mismatch.
@ FK_ParenthesizedListInitForReference
Reference initialized from a parenthesized initializer list.
@ FK_NonConstLValueReferenceBindingToVectorElement
Non-const lvalue reference binding to a vector element.
@ FK_ReferenceInitDropsQualifiers
Reference binding drops qualifiers.
@ FK_InitListBadDestinationType
Initialization of some unused destination type with an initializer list.
@ FK_ConversionFromPropertyFailed
Implicit conversion failed.
@ FK_NonConstLValueReferenceBindingToUnrelated
Non-const lvalue reference binding to an lvalue of unrelated type.
@ FK_ListConstructorOverloadFailed
Overloading for list-initialization by constructor failed.
@ FK_ReferenceInitFailed
Reference binding failed.
@ FK_DesignatedInitForNonAggregate
@ FK_ArrayNeedsInitList
Array must be initialized with an initializer list.
@ FK_PlainStringIntoUTF8Char
Initializing char8_t array with plain string literal.
@ FK_NonConstantArrayInit
Non-constant array initializer.
@ FK_NonConstLValueReferenceBindingToTemporary
Non-const lvalue reference binding to a temporary.
@ FK_ConversionFailed
Implicit conversion failed.
@ FK_ArrayNeedsInitListOrStringLiteral
Array must be initialized with an initializer list or a string literal.
@ FK_ParenthesizedListInitForScalar
Scalar initialized from a parenthesized initializer list.
@ FK_PlaceholderType
Initializer has a placeholder type which cannot be resolved by initialization.
@ FK_IncompatWideStringIntoWideChar
Initializing wide char array with incompatible wide string literal.
@ FK_NonConstLValueReferenceBindingToMatrixElement
Non-const lvalue reference binding to a matrix element.
@ FK_TooManyInitsForReference
Too many initializers provided for a reference.
@ FK_NonConstLValueReferenceBindingToBitfield
Non-const lvalue reference binding to a bit-field.
@ FK_ReferenceAddrspaceMismatchTemporary
Reference with mismatching address space binding to temporary.
@ FK_ListInitializationFailed
List initialization failed at some point.
@ FK_TooManyInitsForScalar
Too many initializers for scalar.
@ FK_AddressOfOverloadFailed
Cannot resolve the address of an overloaded function.
@ FK_VariableLengthArrayHasInitializer
Variable-length array must not have an initializer.
@ FK_ArrayNeedsInitListOrWideStringLiteral
Array must be initialized with an initializer list or a wide string literal.
@ FK_RValueReferenceBindingToLValue
Rvalue reference binding to an lvalue.
@ FK_Incomplete
Initialization of an incomplete type.
@ FK_WideStringIntoCharArray
Initializing char array with wide string literal.
@ FK_ExplicitConstructor
List-copy-initialization chose an explicit constructor.
@ FK_ReferenceInitOverloadFailed
Overloading due to reference initialization failed.
@ FK_ConstructorOverloadFailed
Overloading for initialization by constructor failed.
@ FK_ReferenceBindingToInitList
Reference initialization from an initializer list.
@ FK_DefaultInitOfConst
Default-initialization of a 'const' object.
@ FK_ParenthesizedListInitFailed
Parenthesized list initialization failed at some point.
@ FK_AddressOfUnaddressableFunction
Trying to take the address of a function that doesn't support having its address taken.
@ FK_UTF8StringIntoPlainChar
Initializing char array with UTF-8 string literal.
bool isDirectReferenceBinding() const
Determine whether this initialization is a direct reference binding (C++ [dcl.init....
void AddArrayInitLoopStep(QualType T, QualType EltTy)
Add an array initialization loop step.
void AddAddressOverloadResolutionStep(FunctionDecl *Function, DeclAccessPair Found, bool HadMultipleCandidates)
Add a new step in the initialization that resolves the address of an overloaded function to a specifi...
void AddArrayInitStep(QualType T, bool IsGNUExtension)
Add an array initialization step.
bool isConstructorInitialization() const
Determine whether this initialization is direct call to a constructor.
SmallVectorImpl< Step >::const_iterator step_iterator
OverloadCandidateSet & getFailedCandidateSet()
Retrieve a reference to the candidate set when overload resolution fails.
Describes an entity that is being initialized.
static InitializedEntity InitializeBase(ASTContext &Context, const CXXBaseSpecifier *Base, bool IsInheritedVirtualBase, const InitializedEntity *Parent=nullptr)
Create the initialization entity for a base class subobject.
static InitializedEntity InitializeMember(FieldDecl *Member, const InitializedEntity *Parent=nullptr, bool Implicit=false)
Create the initialization entity for a member subobject.
VD Variable
When Kind == EK_Variable, EK_Member, EK_Binding, or EK_TemplateParameter, the variable,...
EntityKind getKind() const
Determine the kind of initialization.
DeclarationName getName() const
Retrieve the name of the entity being initialized.
QualType getType() const
Retrieve type being initialized.
ValueDecl * getDecl() const
Retrieve the variable, parameter, or field being initialized.
bool isImplicitMemberInitializer() const
Is this the implicit initialization of a member of a class from a defaulted constructor?
const InitializedEntity * getParent() const
Retrieve the parent of the entity being initialized, when the initialization itself is occurring with...
static InitializedEntity InitializeTemporary(QualType Type)
Create the initialization entity for a temporary.
bool isParameterConsumed() const
Determine whether this initialization consumes the parameter.
static InitializedEntity InitializeElement(ASTContext &Context, unsigned Index, const InitializedEntity &Parent)
Create the initialization entity for an array element.
unsigned getElementIndex() const
If this is an array, vector, or complex number element, get the element's index.
void setElementIndex(unsigned Index)
If this is already the initializer for an array or vector element, sets the element index.
SourceLocation getCaptureLoc() const
Determine the location of the capture when initializing field from a captured variable in a lambda.
bool isParamOrTemplateParamKind() const
llvm::PointerIntPair< const CXXBaseSpecifier *, 1 > Base
When Kind == EK_Base, the base specifier that provides the base class.
bool allowsNRVO() const
Determine whether this initialization allows the named return value optimization, which also applies ...
bool isParameterKind() const
void dump() const
Dump a representation of the initialized entity to standard error, for debugging purposes.
EntityKind
Specifies the kind of entity being initialized.
@ EK_Variable
The entity being initialized is a variable.
@ EK_Temporary
The entity being initialized is a temporary object.
@ EK_Binding
The entity being initialized is a structured binding of a decomposition declaration.
@ EK_BlockElement
The entity being initialized is a field of block descriptor for the copied-in c++ object.
@ EK_Parameter_CF_Audited
The entity being initialized is a function parameter; function is member of group of audited CF APIs.
@ EK_LambdaToBlockConversionBlockElement
The entity being initialized is a field of block descriptor for the copied-in lambda object that's us...
@ EK_Member
The entity being initialized is a non-static data member subobject.
@ EK_Base
The entity being initialized is a base member subobject.
@ EK_Result
The entity being initialized is the result of a function call.
@ EK_TemplateParameter
The entity being initialized is a non-type template parameter.
@ EK_StmtExprResult
The entity being initialized is the result of a statement expression.
@ EK_ParenAggInitMember
The entity being initialized is a non-static data member subobject of an object initialized via paren...
@ EK_VectorElement
The entity being initialized is an element of a vector.
@ EK_New
The entity being initialized is an object (or array of objects) allocated via new.
@ EK_CompoundLiteralInit
The entity being initialized is the initializer for a compound literal.
@ EK_Parameter
The entity being initialized is a function parameter.
@ EK_Delegating
The initialization is being done by a delegating constructor.
@ EK_ComplexElement
The entity being initialized is the real or imaginary part of a complex number.
@ EK_ArrayElement
The entity being initialized is an element of an array.
@ EK_LambdaCapture
The entity being initialized is the field that captures a variable in a lambda.
@ EK_Exception
The entity being initialized is an exception object that is being thrown.
@ EK_RelatedResult
The entity being implicitly initialized back to the formal result type.
static InitializedEntity InitializeMemberFromParenAggInit(FieldDecl *Member)
Create the initialization entity for a member subobject initialized via parenthesized aggregate init.
SourceLocation getThrowLoc() const
Determine the location of the 'throw' keyword when initializing an exception object.
unsigned Index
When Kind == EK_ArrayElement, EK_VectorElement, or EK_ComplexElement, the index of the array or vecto...
bool isVariableLengthArrayNew() const
Determine whether this is an array new with an unknown bound.
llvm::PointerIntPair< ParmVarDecl *, 1 > Parameter
When Kind == EK_Parameter, the ParmVarDecl, with the integer indicating whether the parameter is "con...
const CXXBaseSpecifier * getBaseSpecifier() const
Retrieve the base specifier.
SourceLocation getReturnLoc() const
Determine the location of the 'return' keyword when initializing the result of a function call.
TypeSourceInfo * getTypeSourceInfo() const
Retrieve complete type-source information for the object being constructed, if known.
ObjCMethodDecl * getMethodDecl() const
Retrieve the ObjectiveC method being initialized.
The injected class name of a C++ class template or class template partial specialization.
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].
Represents the results of name lookup.
bool empty() const
Return true if no decls were found.
void suppressDiagnostics()
Suppress the diagnostics that would normally fire because of this lookup.
Represents a prvalue temporary that is written into memory so that a reference can bind to it.
StorageDuration getStorageDuration() const
Retrieve the storage duration for the materialized temporary.
This represents a decl that may have a name.
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.
Represent a C++ namespace.
Represents a place-holder for an object not to be initialized by anything.
ObjCEncodeExpr, used for @encode in Objective-C.
ObjCIndirectCopyRestoreExpr - Represents the passing of a function argument by indirect copy-restore ...
OpaqueValueExpr - An expression referring to an opaque object of a fixed type and value class.
bool isAvailableOption(llvm::StringRef Ext, const LangOptions &LO) const
OverloadCandidateSet - A set of overload candidates, used in C++ overload resolution (C++ 13....
void clear(CandidateSetKind CSK)
Clear out all of the candidates.
void setDestAS(LangAS AS)
@ 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.
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...
OverloadingResult BestViableFunction(Sema &S, SourceLocation Loc, OverloadCandidateSet::iterator &Best)
Find the best viable function on this overload set, if it exists.
SmallVector< OverloadCandidate *, 32 > CompleteCandidates(Sema &S, OverloadCandidateDisplayKind OCD, ArrayRef< Expr * > Args, SourceLocation OpLoc=SourceLocation(), llvm::function_ref< bool(OverloadCandidate &)> Filter=[](OverloadCandidate &) { return true;})
Represents a parameter to a function.
PointerType - C99 6.7.5.1 - Pointer Declarators.
A (possibly-)qualified type.
bool isVolatileQualified() const
Determine whether this type is volatile-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 withConst() const
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.
Qualifiers::ObjCLifetime getObjCLifetime() const
Returns lifetime attribute of this type.
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.
bool isConstQualified() const
Determine whether this type is const-qualified.
bool hasAddressSpace() const
Check if this type has any address space qualifier.
DestructionKind isDestructedType() const
Returns a nonzero value if objects of this type require non-trivial work to clean up after.
The collection of all-type qualifiers we support.
unsigned getCVRQualifiers() const
void addAddressSpace(LangAS space)
@ OCL_Weak
Reading or writing from this object requires a barrier call.
bool hasQualifiers() const
Return true if the set contains any qualifiers.
bool compatiblyIncludes(Qualifiers other, const ASTContext &Ctx) const
Determines if these qualifiers compatibly include another set.
bool hasAddressSpace() const
static bool isAddressSpaceSupersetOf(LangAS A, LangAS B, const ASTContext &Ctx)
Returns true if address space A is equal to or a superset of B.
Qualifiers withoutAddressSpace() const
void removeAddressSpace()
static Qualifiers fromCVRMask(unsigned CVR)
bool hasObjCLifetime() const
LangAS getAddressSpace() const
An rvalue reference type, per C++11 [dcl.ref].
Represents a struct/union/class.
bool hasFlexibleArrayMember() const
field_iterator field_end() const
field_range fields() const
bool isRandomized() const
RecordDecl * getDefinition() const
Returns the RecordDecl that actually defines this struct/union/class.
bool hasUninitializedExplicitInitFields() const
specific_decl_iterator< FieldDecl > field_iterator
field_iterator field_begin() const
A helper class that allows the use of isa/cast/dyncast to detect TagType objects of structs/unions/cl...
RecordDecl * getDecl() const
Base for LValueReferenceType and RValueReferenceType.
bool isSpelledAsLValue() const
SemaDiagnosticBuilder Diag(SourceLocation Loc, unsigned DiagID, bool DeferHint=false)
Emit a diagnostic.
PartialDiagnostic PDiag(unsigned DiagID=0)
Build a partial diagnostic.
bool CheckObjCBridgeRelatedConversions(SourceLocation Loc, QualType DestType, QualType SrcType, Expr *&SrcExpr, bool Diagnose=true)
bool isObjCWritebackConversion(QualType FromType, QualType ToType, QualType &ConvertedType)
Determine whether this is an Objective-C writeback conversion, used for parameter passing when perfor...
bool CheckConversionToObjCLiteral(QualType DstType, Expr *&SrcExpr, bool Diagnose=true)
void EmitRelatedResultTypeNote(const Expr *E)
If the given expression involves a message send to a method with a related result type,...
void EmitRelatedResultTypeNoteForReturn(QualType destType)
Given that we had incompatible pointer types in a return statement, check whether we're in a method w...
Sema - This implements semantic analysis and AST building for C.
QualType SubstAutoType(QualType TypeWithAuto, QualType Replacement)
Substitute Replacement for auto in TypeWithAuto.
CXXSpecialMemberKind getSpecialMember(const CXXMethodDecl *MD)
@ LookupOrdinaryName
Ordinary name lookup, which finds ordinary names (functions, variables, typedefs, etc....
@ LookupMemberName
Member name lookup, which finds the names of class/struct/union members.
bool DiagRedefinedPlaceholderFieldDecl(SourceLocation Loc, RecordDecl *ClassDecl, const IdentifierInfo *Name)
ImplicitConversionSequence TryImplicitConversion(Expr *From, QualType ToType, bool SuppressUserConversions, AllowedExplicit AllowExplicit, bool InOverloadResolution, bool CStyle, bool AllowObjCWritebackConversion)
bool IsStringInit(Expr *Init, const ArrayType *AT)
bool isImplicitlyDeleted(FunctionDecl *FD)
Determine whether the given function is an implicitly-deleted special member function.
bool CompleteConstructorCall(CXXConstructorDecl *Constructor, QualType DeclInitType, MultiExprArg ArgsPtr, SourceLocation Loc, SmallVectorImpl< Expr * > &ConvertedArgs, bool AllowExplicit=false, bool IsListInitialization=false)
Given a constructor and the set of arguments provided for the constructor, convert the arguments and ...
void AddConversionCandidate(CXXConversionDecl *Conversion, DeclAccessPair FoundDecl, CXXRecordDecl *ActingContext, Expr *From, QualType ToType, OverloadCandidateSet &CandidateSet, bool AllowObjCConversionOnExplicit, bool AllowExplicit, bool AllowResultConversion=true)
AddConversionCandidate - Add a C++ conversion function as a candidate in the candidate set (C++ [over...
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...
const ExpressionEvaluationContextRecord & currentEvaluationContext() const
FunctionTemplateDecl * DeclareAggregateDeductionGuideFromInitList(TemplateDecl *Template, MutableArrayRef< QualType > ParamTypes, SourceLocation Loc)
ExprResult MaybeBindToTemporary(Expr *E)
MaybeBindToTemporary - If the passed in expression has a record type with a non-trivial destructor,...
ExprResult VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result, VerifyICEDiagnoser &Diagnoser, AllowFoldKind CanFold=NoFold)
VerifyIntegerConstantExpression - Verifies that an expression is an ICE, and reports the appropriate ...
ExprResult ActOnDesignatedInitializer(Designation &Desig, SourceLocation EqualOrColonLoc, bool GNUSyntax, ExprResult Init)
FPOptionsOverride CurFPFeatureOverrides()
ExpressionEvaluationContextRecord & parentEvaluationContext()
void diagnoseNullableToNonnullConversion(QualType DstType, QualType SrcType, SourceLocation Loc)
Warn if we're implicitly casting from a _Nullable pointer type to a _Nonnull one.
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...
AccessResult CheckDestructorAccess(SourceLocation Loc, CXXDestructorDecl *Dtor, const PartialDiagnostic &PDiag, QualType objectType=QualType())
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....
ExprResult DefaultFunctionArrayLvalueConversion(Expr *E, bool Diagnose=true)
ASTContext & getASTContext() const
CXXDestructorDecl * LookupDestructor(CXXRecordDecl *Class)
Look for the destructor of the given class.
AssignConvertType CheckTransparentUnionArgumentConstraints(QualType ArgType, ExprResult &RHS)
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 isInitListConstructor(const FunctionDecl *Ctor)
Determine whether Ctor is an initializer-list constructor, as defined in [dcl.init....
AccessResult CheckMemberOperatorAccess(SourceLocation Loc, Expr *ObjectExpr, const SourceRange &, DeclAccessPair FoundDecl)
ExprResult ActOnParenListExpr(SourceLocation L, SourceLocation R, MultiExprArg Val)
llvm::SmallVector< QualType, 4 > CurrentParameterCopyTypes
Stack of types that correspond to the parameter entities that are currently being copy-initialized.
std::string getFixItZeroInitializerForType(QualType T, SourceLocation Loc) const
Get a string to suggest for zero-initialization of a type.
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...
SourceLocation getLocForEndOfToken(SourceLocation Loc, unsigned Offset=0)
Calls Lexer::getLocForEndOfToken()
CXXConstructorDecl * LookupDefaultConstructor(CXXRecordDecl *Class)
Look up the default constructor for the given class.
const LangOptions & getLangOpts() const
TypoCorrection CorrectTypo(const DeclarationNameInfo &Typo, Sema::LookupNameKind LookupKind, Scope *S, CXXScopeSpec *SS, CorrectionCandidateCallback &CCC, CorrectTypoKind Mode, DeclContext *MemberContext=nullptr, bool EnteringContext=false, const ObjCObjectPointerType *OPT=nullptr, bool RecordFailure=true)
Try to "correct" a typo in the source code by finding visible declarations whose names are similar to...
void NoteTemplateLocation(const NamedDecl &Decl, std::optional< SourceRange > ParamRange={})
bool RequireNonAbstractType(SourceLocation Loc, QualType T, TypeDiagnoser &Diagnoser)
ExprResult PerformQualificationConversion(Expr *E, QualType Ty, ExprValueKind VK=VK_PRValue, CheckedConversionKind CCK=CheckedConversionKind::Implicit)
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.
ExprResult TemporaryMaterializationConversion(Expr *E)
If E is a prvalue denoting an unmaterialized temporary, materialize it as an xvalue.
bool CanUseDecl(NamedDecl *D, bool TreatUnavailableAsInvalid)
Determine whether the use of this declaration is valid, without emitting diagnostics.
CleanupInfo Cleanup
Used to control the generation of ExprWithCleanups.
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.
std::optional< sema::TemplateDeductionInfo * > isSFINAEContext() const
Determines whether we are currently in a context where template argument substitution failures are no...
QualType DeduceTemplateSpecializationFromInitializer(TypeSourceInfo *TInfo, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Init)
void DefineImplicitDefaultConstructor(SourceLocation CurrentLocation, CXXConstructorDecl *Constructor)
DefineImplicitDefaultConstructor - Checks for feasibility of defining this constructor as the default...
SourceLocation getLocationOfStringLiteralByte(const StringLiteral *SL, unsigned ByteNo) const
bool CheckDerivedToBaseConversion(QualType Derived, QualType Base, SourceLocation Loc, SourceRange Range, CXXCastPath *BasePath=nullptr, bool IgnoreAccess=false)
bool isInLifetimeExtendingContext() const
DeclContext * CurContext
CurContext - This is the current declaration context of parsing.
MaterializeTemporaryExpr * CreateMaterializeTemporaryExpr(QualType T, Expr *Temporary, bool BoundToLvalueReference)
AccessResult CheckConstructorAccess(SourceLocation Loc, CXXConstructorDecl *D, DeclAccessPair FoundDecl, const InitializedEntity &Entity, bool IsCopyBindingRefToTemp=false)
Checks access to a constructor.
AccessResult CheckAddressOfMemberAccess(Expr *OvlExpr, DeclAccessPair FoundDecl)
AssignConvertType
AssignConvertType - All of the 'assignment' semantic checks return this enum to indicate whether the ...
@ Compatible
Compatible - the types are compatible according to the standard.
@ Incompatible
Incompatible - We reject this conversion outright, it is invalid to represent it in the AST.
TemplateNameKindForDiagnostics getTemplateNameKindForDiagnostics(TemplateName Name)
ExprResult CheckPlaceholderExpr(Expr *E)
Check for operands with placeholder types and complain if found.
ExprResult BuildCXXConstructExpr(SourceLocation ConstructLoc, QualType DeclInitType, NamedDecl *FoundDecl, CXXConstructorDecl *Constructor, MultiExprArg Exprs, bool HadMultipleCandidates, bool IsListInitialization, bool IsStdInitListInitialization, bool RequiresZeroInit, CXXConstructionKind ConstructKind, SourceRange ParenRange)
BuildCXXConstructExpr - Creates a complete call to a constructor, including handling of its default a...
bool inTemplateInstantiation() const
Determine whether we are currently performing template instantiation.
SourceManager & getSourceManager() const
ExprResult FixOverloadedFunctionReference(Expr *E, DeclAccessPair FoundDecl, FunctionDecl *Fn)
FixOverloadedFunctionReference - E is an expression that refers to a C++ overloaded function (possibl...
void DiscardMisalignedMemberAddress(const Type *T, Expr *E)
This function checks if the expression is in the sef of potentially misaligned members and it is conv...
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.
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 DiagnoseUseOfDecl(NamedDecl *D, ArrayRef< SourceLocation > Locs, const ObjCInterfaceDecl *UnknownObjCClass=nullptr, bool ObjCPropertyAccess=false, bool AvoidPartialAvailabilityChecks=false, ObjCInterfaceDecl *ClassReciever=nullptr, bool SkipTrailingRequiresClause=false)
Determine whether the use of this declaration is valid, and emit any corresponding diagnostics.
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 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 NoteDeletedFunction(FunctionDecl *FD)
Emit a note explaining that this function is deleted.
ExprResult CreateBuiltinArraySubscriptExpr(Expr *Base, SourceLocation LLoc, Expr *Idx, SourceLocation RLoc)
@ PotentiallyEvaluated
The current expression is potentially evaluated at run time, which means that code may be generated t...
void diagnoseTypo(const TypoCorrection &Correction, const PartialDiagnostic &TypoDiag, bool ErrorRecovery=true)
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.
void checkInitializerLifetime(const InitializedEntity &Entity, Expr *Init)
Check that the lifetime of the initializer (and its subobjects) is sufficient for initializing the en...
QualType getCompletedType(Expr *E)
Get the type of expression E, triggering instantiation to complete the type if necessary – that is,...
SourceManager & SourceMgr
DiagnosticsEngine & Diags
OpenCLOptions & getOpenCLOptions()
NamespaceDecl * getStdNamespace() const
ExprResult PerformCopyInitialization(const InitializedEntity &Entity, SourceLocation EqualLoc, ExprResult Init, bool TopLevelOfInitList=false, bool AllowExplicit=false)
ExprResult BuildCXXDefaultInitExpr(SourceLocation Loc, FieldDecl *Field)
QualType SubstAutoTypeDependent(QualType TypeWithAuto)
void runWithSufficientStackSpace(SourceLocation Loc, llvm::function_ref< void()> Fn)
Run some code with "sufficient" stack space.
bool DiagnoseAssignmentResult(AssignConvertType ConvTy, SourceLocation Loc, QualType DstType, QualType SrcType, Expr *SrcExpr, AssignmentAction Action, bool *Complained=nullptr)
DiagnoseAssignmentResult - Emit a diagnostic, if required, for the assignment conversion type specifi...
void MarkFunctionReferenced(SourceLocation Loc, FunctionDecl *Func, bool MightBeOdrUse=true)
Mark a function referenced, and check whether it is odr-used (C++ [basic.def.odr]p2,...
bool IsDerivedFrom(SourceLocation Loc, QualType Derived, QualType Base)
Determine whether the type Derived is a C++ class that is derived from the type Base.
bool CanPerformCopyInitialization(const InitializedEntity &Entity, ExprResult Init)
bool CheckExceptionSpecCompatibility(Expr *From, QualType ToType)
void HandleFunctionTypeMismatch(PartialDiagnostic &PDiag, QualType FromType, QualType ToType)
HandleFunctionTypeMismatch - Gives diagnostic information for differeing function types.
DeclContextLookupResult LookupConstructors(CXXRecordDecl *Class)
Look up the constructors for the given class.
CXXConstructorDecl * findInheritingConstructor(SourceLocation Loc, CXXConstructorDecl *BaseCtor, ConstructorUsingShadowDecl *DerivedShadow)
Given a derived-class using shadow declaration for a constructor and the correspnding base class cons...
ValueDecl * tryLookupUnambiguousFieldDecl(RecordDecl *ClassDecl, const IdentifierInfo *MemberOrBase)
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)
AddOverloadCandidate - Adds the given function to the set of candidate functions, using the given fun...
Encodes a location in the source.
SourceLocation getLocWithOffset(IntTy Offset) const
Return a source location with the specified offset from this SourceLocation.
CharSourceRange getImmediateExpansionRange(SourceLocation Loc) const
Return the start/end of the expansion information for an expansion location.
bool isInSystemHeader(SourceLocation Loc) const
Returns if a SourceLocation is in a system header.
bool isAtStartOfImmediateMacroExpansion(SourceLocation Loc, SourceLocation *MacroBegin=nullptr) const
Returns true if the given MacroID location points at the beginning of the immediate macro expansion.
A trivial tuple used to represent a source range.
void setBegin(SourceLocation b)
SourceLocation getEnd() const
SourceLocation getBegin() const
StandardConversionSequence - represents a standard conversion sequence (C++ 13.3.3....
void setFromType(QualType T)
ImplicitConversionKind Second
Second - The second conversion can be an integral promotion, floating point promotion,...
ImplicitConversionKind First
First – The first conversion can be an lvalue-to-rvalue conversion, array-to-pointer conversion,...
void setAsIdentityConversion()
StandardConversionSequence - Set the standard conversion sequence to the identity conversion.
void setToType(unsigned Idx, QualType T)
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...
void setAllToTypes(QualType T)
QualType getToType(unsigned Idx) const
Stmt - This represents one statement.
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.
unsigned getLength() const
StringLiteralKind getKind() const
int64_t getCodeUnitS(size_t I, uint64_t BitWidth) const
StringRef getString() const
The base class of all kinds of template declarations (e.g., class, function, etc.).
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.
bool isDependent() const
Determines whether this is a dependent template name.
Represents a type template specialization; the template must be a class template, a type alias templa...
Base wrapper for a particular "section" of type source info.
T getAs() const
Convert to the specified TypeLoc type, returning a null TypeLoc if this TypeLoc is not of the desired...
SourceRange getSourceRange() const LLVM_READONLY
Get the full source range.
SourceLocation getEndLoc() const
Get the end source location.
SourceLocation getBeginLoc() const
Get the begin source location.
A container of type source information.
TypeLoc getTypeLoc() const
Return the TypeLoc wrapper for the type source info.
QualType getType() const
Return the type wrapped by this type source info.
The base class of the type hierarchy.
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
bool isBooleanType() const
const Type * getPointeeOrArrayElementType() const
If this is a pointer type, return the pointee type.
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 isIntegralOrUnscopedEnumerationType() const
Determine whether this type is an integral or unscoped enumeration type.
bool isRValueReferenceType() const
bool isConstantArrayType() const
bool isPointerType() const
bool isArrayParameterType() const
bool isIntegerType() const
isIntegerType() does not include complex integers (a GCC extension).
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
bool isScalarType() const
const CXXRecordDecl * getPointeeCXXRecordDecl() const
If this is a pointer or reference to a RecordType, return the CXXRecordDecl that the type refers to.
bool isSizelessBuiltinType() const
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
bool isExtVectorType() const
bool isOCLIntelSubgroupAVCType() const
bool isLValueReferenceType() const
bool isOpenCLSpecificType() 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
DeducedType * getContainedDeducedType() const
Get the DeducedType whose type will be deduced for a variable with an initializer of this type.
const Type * getBaseElementTypeUnsafe() const
Get the base element type of this type, potentially discarding type qualifiers.
bool isAtomicType() const
bool isFunctionProtoType() const
bool isObjCObjectType() const
const ArrayType * getAsArrayTypeUnsafe() const
A variant of getAs<> for array types which silently discards qualifiers from the outermost type.
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 isFloatingType() const
bool isUnsignedIntegerType() const
Return true if this is an integer type that is unsigned, according to C99 6.2.5p6 [which returns true...
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
bool isObjCRetainableType() const
RecordDecl * getAsRecordDecl() const
Retrieves the RecordDecl this type refers to.
Simple class containing the result of Sema::CorrectTypo.
DeclClass * getCorrectionDeclAs() const
UnaryOperator - This represents the unary-expression's (except sizeof and alignof),...
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
Represents a variable declaration or definition.
const Expr * getInit() const
bool hasLocalStorage() const
Returns true if a variable with function scope is a non-static local variable.
Represents a C array with a specified size that is not an integer-constant-expression.
Represents a GCC generic vector type.
unsigned getNumElements() const
VectorKind getVectorKind() const
QualType getElementType() const
Defines the clang::TargetInfo interface.
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
const AstTypeMatcher< ArrayType > arrayType
Matches all kinds of arrays.
const internal::VariadicDynCastAllOfMatcher< Stmt, Expr > expr
Matches expressions.
bool Zero(InterpState &S, CodePtr OpPC)
void checkInitLifetime(Sema &SemaRef, const InitializedEntity &Entity, Expr *Init)
Check that the lifetime of the given expr (and its subobjects) is sufficient for initializing the ent...
The JSON file list parser is used to communicate input to InstallAPI.
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.
@ ovl_fail_bad_conversion
@ OCD_AmbiguousCandidates
Requests that only tied-for-best candidates be shown.
@ OCD_AllCandidates
Requests that all candidates be shown.
@ Seq
'seq' clause, allowed on 'loop' and 'routine' directives.
@ SD_Automatic
Automatic storage duration (most local variables).
@ Result
The result type of a method or function.
@ ICK_Integral_Conversion
Integral conversions (C++ [conv.integral])
@ ICK_Floating_Integral
Floating-integral conversions (C++ [conv.fpint])
@ ICK_Array_To_Pointer
Array-to-pointer conversion (C++ [conv.array])
@ ICK_Lvalue_To_Rvalue
Lvalue-to-rvalue conversion (C++ [conv.lval])
@ ICK_Writeback_Conversion
Objective-C ARC writeback conversion.
ActionResult< Expr * > ExprResult
CastKind
CastKind - The kind of operation required for a conversion.
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.
Expr * IgnoreParensSingleStep(Expr *E)
const FunctionProtoType * T
@ 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.
bool declaresSameEntity(const Decl *D1, const Decl *D2)
Determine whether two declarations declare the same entity.
std::pair< SourceLocation, PartialDiagnostic > PartialDiagnosticAt
A partial diagnostic along with the source location where this diagnostic occurs.
ConstructorInfo getConstructorInfo(NamedDecl *ND)
@ Class
The "class" keyword introduces the elaborated-type-specifier.
@ Braces
New-expression has a C++11 list-initializer.
CheckedConversionKind
The kind of conversion being performed.
@ Implicit
An implicit conversion.
@ CStyleCast
A C-style cast.
@ OtherCast
A cast other than a C-style cast.
@ FunctionalCast
A functional-style cast.
MutableArrayRef< Expr * > MultiExprArg
CXXConstructorDecl * Constructor
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
EvalResult is a struct with detailed info about an evaluated expression.
APValue Val
Val - This is the value the expression can be folded to.
bool HadMultipleCandidates
OverloadCandidate - A single candidate in an overload set (C++ 13.3).
bool Viable
Viable - True to indicate that this overload candidate is viable.
unsigned char FailureKind
FailureKind - The reason why this candidate is not viable.
ConversionSequenceList Conversions
The conversion sequences used to convert the function arguments to the function parameters.
bool InLifetimeExtendingContext
Whether we are currently in a context in which all temporaries must be lifetime-extended,...
SmallVector< MaterializeTemporaryExpr *, 8 > ForRangeLifetimeExtendTemps
P2718R0 - Lifetime extension in range-based for loops.
bool RebuildDefaultArgOrDefaultInit
Whether we should rebuild CXXDefaultArgExpr and CXXDefaultInitExpr.
std::optional< InitializationContext > DelayedDefaultInitializationContext
ReferenceConversions
The conversions that would be performed on an lvalue of type T2 when binding a reference of type T1 t...
StandardConversionSequence After
After - Represents the standard conversion that occurs after the actual user-defined conversion.