48#include "llvm/ADT/APInt.h"
49#include "llvm/ADT/STLExtras.h"
50#include "llvm/ADT/StringExtras.h"
51#include "llvm/Support/ErrorHandling.h"
52#include "llvm/Support/TypeSize.h"
62 if ([[maybe_unused]]
const auto *DNT = dyn_cast<DependentNameType>(
Type))
63 assert(DNT->getIdentifier() == &Name &&
"not a constructor name");
76 "not a constructor name");
98 auto *RD = dyn_cast<CXXRecordDecl>(ND);
99 if (RD && RD->isInjectedClassName()) {
100 InjectedClassName = RD;
104 if (!InjectedClassName) {
109 diag::err_incomplete_nested_name_spec) << CurClass << SS.
getRange();
115 InjectedClassName,
false);
122 bool EnteringContext) {
168 auto IsAcceptableResult = [&](
NamedDecl *D) ->
bool {
169 auto *
Type = dyn_cast<TypeDecl>(D->getUnderlyingDecl());
177 return Context.hasSameUnqualifiedType(T, SearchType);
180 unsigned NumAcceptableResults = 0;
182 if (IsAcceptableResult(D))
183 ++NumAcceptableResults;
188 if (
auto *RD = dyn_cast<CXXRecordDecl>(D))
189 if (RD->isInjectedClassName())
192 if (FoundDeclSet.insert(D).second)
193 FoundDecls.push_back(D);
201 if (
Found.isAmbiguous() && NumAcceptableResults == 1) {
202 Diag(NameLoc, diag::ext_dtor_name_ambiguous);
213 if (!IsAcceptableResult(D))
219 if (
Found.isAmbiguous())
223 if (IsAcceptableResult(
Type)) {
228 Context.getTrivialTypeSourceInfo(T, NameLoc));
235 bool IsDependent =
false;
237 auto LookupInObjectType = [&]() ->
ParsedType {
238 if (Failed || SearchType.
isNull())
248 return CheckLookupResult(
Found);
266 return CheckLookupResult(
Found);
275 return CheckLookupResult(
Found);
318 return TL.getPrefix();
329 PrefixSS.
Adopt(Prefix);
330 if (
ParsedType T = LookupInNestedNameSpec(PrefixSS))
364 unsigned NumNonExtensionDecls = FoundDecls.size();
372 if (
ParsedType T = LookupInNestedNameSpec(SS)) {
388 Diag(SS.
getEndLoc(), diag::ext_qualified_dtor_named_in_lexical_scope)
390 Diag(FoundDecls.back()->getLocation(), diag::note_destructor_type_here)
401 FoundDecls.resize(NumNonExtensionDecls);
410 auto MakeFixItHint = [&]{
416 Destroyed = dyn_cast_or_null<CXXRecordDecl>(S->
getEntity());
423 if (FoundDecls.empty()) {
425 Diag(NameLoc, diag::err_undeclared_destructor_name)
426 << &II << MakeFixItHint();
427 }
else if (!SearchType.
isNull() && FoundDecls.size() == 1) {
428 if (
auto *TD = dyn_cast<TypeDecl>(FoundDecls[0]->getUnderlyingDecl())) {
429 assert(!SearchType.
isNull() &&
430 "should only reject a type result if we have a search type");
431 Diag(NameLoc, diag::err_destructor_expr_type_mismatch)
434 << SearchType << MakeFixItHint();
436 Diag(NameLoc, diag::err_destructor_expr_nontype)
437 << &II << MakeFixItHint();
440 Diag(NameLoc, SearchType.
isNull() ? diag::err_destructor_name_nontype
441 : diag::err_destructor_expr_mismatch)
442 << &II << SearchType << MakeFixItHint();
446 if (
auto *TD = dyn_cast<TypeDecl>(FoundD->getUnderlyingDecl()))
447 Diag(FoundD->getLocation(), diag::note_destructor_type_here)
451 Diag(FoundD->getLocation(), diag::note_destructor_nontype_here)
469 "unexpected type in getDestructorType");
476 !
Context.hasSameUnqualifiedType(T, SearchType)) {
499 (StringRef(
"operator\"\"") + II->
getName()).str());
508 Diag(Loc, diag::warn_deprecated_literal_operator_id) << II << Hint;
511 Diag(Loc, diag::warn_reserved_extern_symbol)
512 << II << static_cast<int>(Status) << Hint;
521 Diag(Name.
getBeginLoc(), diag::err_literal_operator_id_outside_namespace)
532 llvm_unreachable(
"unknown nested name specifier kind");
546 =
Context.getUnqualifiedArrayType(Operand->getType().getNonReferenceType(),
548 if (T->isRecordType() &&
552 if (T->isVariablyModifiedType())
553 return ExprError(
Diag(TypeidLoc, diag::err_variably_modified_typeid) << T);
566 bool WasEvaluated =
false;
575 if (
auto *RecordD = T->getAsCXXRecordDecl()) {
586 if (RecordD->isPolymorphic() && E->
isGLValue()) {
614 if (!
Context.hasSameType(T, UnqualT)) {
621 return ExprError(
Diag(TypeidLoc, diag::err_variably_modified_typeid)
628 ? diag::warn_side_effects_typeid
629 : diag::warn_side_effects_unevaluated_context);
642 return ExprError(
Diag(OpLoc, diag::err_openclcxx_not_supported)
648 return ExprError(
Diag(OpLoc, diag::err_need_header_before_typeid)
664 return ExprError(
Diag(OpLoc, diag::err_need_header_before_typeid)
669 return ExprError(
Diag(OpLoc, diag::err_no_typeid_with_fno_rtti));
683 TInfo =
Context.getTrivialTypeSourceInfo(T, OpLoc);
693 if (
auto *CTE = dyn_cast<CXXTypeidExpr>(
Result.get()))
694 if (CTE->isPotentiallyEvaluated() && !CTE->isMostDerived(
Context))
695 Diag(OpLoc, diag::warn_no_typeid_with_rtti_disabled)
717 if (
const auto *Uuid = TD->getMostRecentDecl()->getAttr<UuidAttr>()) {
718 UuidAttrs.insert(Uuid);
723 if (
const auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(TD)) {
726 const UuidAttr *UuidForTA =
nullptr;
733 UuidAttrs.insert(UuidForTA);
743 if (!Operand->getType()->isDependentType()) {
746 if (UuidAttrs.empty())
747 return ExprError(
Diag(TypeidLoc, diag::err_uuidof_without_guid));
748 if (UuidAttrs.size() > 1)
749 return ExprError(
Diag(TypeidLoc, diag::err_uuidof_with_multiple_guids));
750 Guid = UuidAttrs.back()->getGuidDecl();
767 if (UuidAttrs.empty())
768 return ExprError(
Diag(TypeidLoc, diag::err_uuidof_without_guid));
769 if (UuidAttrs.size() > 1)
770 return ExprError(
Diag(TypeidLoc, diag::err_uuidof_with_multiple_guids));
771 Guid = UuidAttrs.back()->getGuidDecl();
795 TInfo =
Context.getTrivialTypeSourceInfo(T, OpLoc);
806 assert((Kind == tok::kw_true || Kind == tok::kw_false) &&
807 "Unknown C++ Boolean value!");
819 bool IsThrownVarInScope =
false;
832 if (
const auto *DRE = dyn_cast<DeclRefExpr>(Ex->
IgnoreParens()))
833 if (
const auto *Var = dyn_cast<VarDecl>(DRE->getDecl());
834 Var && Var->hasLocalStorage() &&
835 !Var->getType().isVolatileQualified()) {
838 IsThrownVarInScope =
true;
855 bool IsThrownVarInScope) {
856 const llvm::Triple &T =
Context.getTargetInfo().getTriple();
857 const bool IsOpenMPGPUTarget =
863 if (IsOpenMPGPUTarget)
864 targetDiag(OpLoc, diag::warn_throw_not_valid_on_target) << T.str();
872 Diag(OpLoc, diag::err_omp_simd_region_cannot_use_stmt) <<
"throw";
877 Diag(OpLoc, diag::err_acc_branch_in_out_compute_construct)
912 if (Ex &&
Context.getTargetInfo().getTriple().isPPC64())
921 llvm::DenseMap<CXXRecordDecl *, unsigned> &SubobjectsSeen,
922 llvm::SmallPtrSetImpl<CXXRecordDecl *> &VBases,
923 llvm::SetVector<CXXRecordDecl *> &PublicSubobjectsSeen,
924 bool ParentIsPublic) {
926 CXXRecordDecl *BaseDecl = BS.getType()->getAsCXXRecordDecl();
931 NewSubobject = VBases.insert(BaseDecl).second;
936 ++SubobjectsSeen[BaseDecl];
939 bool PublicPath = ParentIsPublic && BS.getAccessSpecifier() ==
AS_public;
941 PublicSubobjectsSeen.insert(BaseDecl);
951 llvm::DenseMap<CXXRecordDecl *, unsigned> SubobjectsSeen;
953 llvm::SetVector<CXXRecordDecl *> PublicSubobjectsSeen;
954 SubobjectsSeen[RD] = 1;
955 PublicSubobjectsSeen.insert(RD);
959 for (
CXXRecordDecl *PublicSubobject : PublicSubobjectsSeen) {
961 if (SubobjectsSeen[PublicSubobject] > 1)
964 Objects.push_back(PublicSubobject);
973 bool isPointer =
false;
993 isPointer ? diag::err_throw_incomplete_ptr
994 : diag::err_throw_incomplete,
1004 diag::err_throw_abstract_type, E))
1026 PDiag(diag::err_access_dtor_exception) << Ty);
1035 if (
Context.getTargetInfo().getCXXABI().isMicrosoft()) {
1042 for (
CXXRecordDecl *Subobject : UnambiguousPublicSubobjects) {
1065 Context.addCopyConstructorForExceptionObject(Subobject, CD);
1069 for (
unsigned I = 1, E = CD->
getNumParams(); I != E; ++I) {
1080 if (
Context.getTargetInfo().getCXXABI().isItaniumFamily()) {
1083 if (ExnObjAlign < TypeAlign) {
1084 Diag(ThrowLoc, diag::warn_throw_underaligned_obj);
1085 Diag(ThrowLoc, diag::note_throw_underaligned_obj)
1090 if (!isPointer &&
getLangOpts().AssumeNothrowExceptionDtor) {
1092 auto Ty = Dtor->getType();
1096 Diag(ThrowLoc, diag::err_throw_object_throwing_dtor) << RD;
1148 for (
int I = FunctionScopes.size();
1160 if (
C.isCopyCapture()) {
1172 "While computing 'this' capture-type for a generic lambda, when we "
1173 "run out of enclosing LSI's, yet the enclosing DC is a "
1174 "lambda-call-operator we must be (i.e. Current LSI) in a generic "
1175 "lambda call oeprator");
1178 auto IsThisCaptured =
1183 if (
C.capturesThis()) {
1194 bool IsByCopyCapture =
false;
1195 bool IsConstCapture =
false;
1198 IsThisCaptured(Closure, IsByCopyCapture, IsConstCapture)) {
1199 if (IsByCopyCapture) {
1217 if (method && method->isImplicitObjectMemberFunction())
1218 ThisTy = method->getThisType().getNonReferenceType();
1230 ThisTy =
Context.getPointerType(ClassTy);
1248 if (!Enabled || !ContextDecl)
1262 T = S.getASTContext().getQualifiedType(T, CXXThisTypeQuals);
1264 S.CXXThisTypeOverride =
1265 S.Context.getLangOpts().HLSL ? T : S.Context.getPointerType(T);
1267 this->Enabled =
true;
1273 S.CXXThisTypeOverride = OldCXXThisTypeOverride;
1284 Sema.
Diag(DiagLoc, diag::note_lambda_this_capture_fixit)
1290 bool BuildAndDiagnose,
const unsigned *
const FunctionScopeIndexToStopAt,
1291 const bool ByCopy) {
1296 assert((!ByCopy ||
Explicit) &&
"cannot implicitly capture *this by value");
1298 const int MaxFunctionScopesIndex = FunctionScopeIndexToStopAt
1299 ? *FunctionScopeIndexToStopAt
1325 unsigned NumCapturingClosures = 0;
1326 for (
int idx = MaxFunctionScopesIndex; idx >= 0; idx--) {
1329 if (CSI->CXXThisCaptureIndex != 0) {
1331 CSI->Captures[CSI->CXXThisCaptureIndex - 1].markUsed(BuildAndDiagnose);
1337 if (BuildAndDiagnose) {
1339 Diag(Loc, diag::err_this_capture)
1340 << (
Explicit && idx == MaxFunctionScopesIndex);
1350 (
Explicit && idx == MaxFunctionScopesIndex)) {
1356 NumCapturingClosures++;
1360 if (BuildAndDiagnose) {
1362 Diag(Loc, diag::err_this_capture)
1363 << (
Explicit && idx == MaxFunctionScopesIndex);
1371 if (!BuildAndDiagnose)
return false;
1384 "Only a lambda can capture the enclosing object (referred to by "
1387 for (
int idx = MaxFunctionScopesIndex; NumCapturingClosures;
1388 --idx, --NumCapturingClosures) {
1395 bool isNested = NumCapturingClosures > 1;
1429 const auto *
Method = dyn_cast<CXXMethodDecl>(DC);
1430 if (
Method &&
Method->isExplicitObjectMemberFunction()) {
1431 Diag(Loc, diag::err_invalid_this_use) << 1;
1433 Diag(Loc, diag::err_invalid_this_use) << 1;
1435 Diag(Loc, diag::err_invalid_this_use) << 0;
1449 if (
This->isTypeDependent())
1454 auto IsDependent = [&]() {
1456 auto *LSI = dyn_cast<sema::LambdaScopeInfo>(
Scope);
1460 if (LSI->Lambda && !LSI->Lambda->Encloses(
CurContext) &&
1461 LSI->AfterParameterList)
1468 if (LSI->isCXXThisCaptured()) {
1469 if (!LSI->getCXXThisCapture().isCopyCapture())
1472 const auto *MD = LSI->CallOperator;
1473 if (MD->getType().isNull())
1477 return Ty && MD->isExplicitObjectMemberFunction() &&
1484 This->setCapturedByCopyInLambdaWithExplicitObjectParameter(IsDependent);
1504 bool ListInitialization) {
1514 RParenOrBraceLoc, ListInitialization);
1517 RParenOrBraceLoc, exprs, Ty);
1526 bool ListInitialization) {
1535 ? ListInitialization
1537 TyBeginLoc, LParenOrBraceLoc, RParenOrBraceLoc)
1559 if (ListInitialization) {
1565 return ExprError(
Diag(TyBeginLoc, diag::err_auto_expr_init_no_expression)
1566 << Ty << FullRange);
1567 if (
Inits.size() > 1) {
1570 diag::err_auto_expr_init_multiple_expressions)
1571 << Ty << FullRange);
1574 if (Ty->
getAs<AutoType>())
1575 Diag(TyBeginLoc, diag::warn_cxx20_compat_auto_expr) << FullRange;
1581 << ListInitialization << Ty << FullRange);
1588 return ExprError(
Diag(TyBeginLoc, diag::err_auto_expr_deduction_failure)
1589 << Ty << Deduce->
getType() << FullRange
1591 if (DeducedType.
isNull()) {
1603 RParenOrBraceLoc, ListInitialization);
1609 if (Exprs.size() == 1 && !ListInitialization &&
1611 Expr *Arg = Exprs[0];
1619 if (!ListInitialization)
1620 return ExprError(
Diag(TyBeginLoc, diag::err_value_init_for_array_type)
1622 ElemTy =
Context.getBaseElementType(Ty);
1630 return ExprError(
Diag(TyBeginLoc, diag::err_init_for_function_type)
1631 << Ty << FullRange);
1640 if (ListInitialization &&
1645 Exprs[0]->getBeginLoc(), Exprs[0]->getEndLoc());
1648 diag::err_invalid_incomplete_type_use,
1662 Inner = BTE->getSubExpr();
1663 if (
auto *CE = dyn_cast<ConstantExpr>(Inner);
1664 CE && CE->isImmediateInvocation())
1665 Inner = CE->getSubExpr();
1679 :
SourceRange(LParenOrBraceLoc, RParenOrBraceLoc);
1700 Method->getDeclContext()->lookup(
Method->getDeclName());
1701 for (
const auto *D : R) {
1702 if (
const auto *FD = dyn_cast<FunctionDecl>(D)) {
1712 bool Result =
Method->isUsualDeallocationFunction(PreventedBy);
1719 return llvm::none_of(PreventedBy, [&](
const FunctionDecl *FD) {
1721 "Only single-operand functions should be in PreventedBy");
1739 unsigned UsualParams = 1;
1740 if (S.
getLangOpts().SizedDeallocation && UsualParams < FD->getNumParams() &&
1746 if (S.
getLangOpts().AlignedAllocation && UsualParams < FD->getNumParams() &&
1756 struct UsualDeallocFnInfo {
1757 UsualDeallocFnInfo()
1760 UsualDeallocFnInfo(Sema &S, DeclAccessPair
Found, QualType AllocType,
1762 :
Found(
Found), FD(dyn_cast<FunctionDecl>(
Found->getUnderlyingDecl())),
1764 IDP({AllocType, TypeAwareAllocationMode::No,
1765 AlignedAllocationMode::No, SizedDeallocationMode::No}),
1770 if (AllocType.isNull())
1772 auto *FTD = dyn_cast<FunctionTemplateDecl>(
Found->getUnderlyingDecl());
1775 FunctionDecl *InstantiatedDecl =
1776 S.BuildTypeAwareUsualDelete(FTD, AllocType, Loc);
1777 if (!InstantiatedDecl)
1779 FD = InstantiatedDecl;
1781 unsigned NumBaseParams = 1;
1782 if (FD->isTypeAwareOperatorNewOrDelete()) {
1788 if (AllocType.isNull()) {
1792 QualType TypeIdentityTag = FD->getParamDecl(0)->getType();
1793 QualType ExpectedTypeIdentityTag =
1794 S.tryBuildStdTypeIdentity(AllocType, Loc);
1795 if (ExpectedTypeIdentityTag.
isNull()) {
1799 if (!S.Context.hasSameType(TypeIdentityTag, ExpectedTypeIdentityTag)) {
1803 IDP.PassTypeIdentity = TypeAwareAllocationMode::Yes;
1807 if (FD->isDestroyingOperatorDelete()) {
1812 if (NumBaseParams < FD->getNumParams() &&
1813 S.Context.hasSameUnqualifiedType(
1814 FD->getParamDecl(NumBaseParams)->getType(),
1815 S.Context.getSizeType())) {
1817 IDP.PassSize = SizedDeallocationMode::Yes;
1820 if (NumBaseParams < FD->getNumParams() &&
1821 FD->getParamDecl(NumBaseParams)->getType()->isAlignValT()) {
1823 IDP.PassAlignment = AlignedAllocationMode::Yes;
1827 if (S.getLangOpts().CUDA)
1828 CUDAPref = S.CUDA().IdentifyPreference(
1829 S.getCurFunctionDecl(
true), FD);
1832 explicit operator bool()
const {
return FD; }
1835 ImplicitDeallocationParameters TargetIDP)
const {
1842 if (Destroying !=
Other.Destroying)
1843 return Destroying ? 1 : -1;
1845 const ImplicitDeallocationParameters &OtherIDP =
Other.IDP;
1855 return IDP.PassAlignment == TargetIDP.
PassAlignment ? 1 : -1;
1857 if (IDP.PassSize != OtherIDP.
PassSize)
1858 return IDP.PassSize == TargetIDP.
PassSize ? 1 : -1;
1863 FunctionTemplateDecl *PrimaryTemplate = FD->getPrimaryTemplate();
1864 FunctionTemplateDecl *OtherPrimaryTemplate =
1865 Other.FD->getPrimaryTemplate();
1866 if ((!PrimaryTemplate) != (!OtherPrimaryTemplate))
1867 return OtherPrimaryTemplate ? 1 : -1;
1869 if (PrimaryTemplate && OtherPrimaryTemplate) {
1870 const auto *DC = dyn_cast<CXXRecordDecl>(
Found->getDeclContext());
1871 const auto *OtherDC =
1872 dyn_cast<CXXRecordDecl>(
Other.Found->getDeclContext());
1873 unsigned ImplicitArgCount = Destroying + IDP.getNumImplicitArgs();
1875 PrimaryTemplate, OtherPrimaryTemplate, SourceLocation(),
1880 return Best == PrimaryTemplate ? 1 : -1;
1886 if (CUDAPref >
Other.CUDAPref)
1888 if (CUDAPref ==
Other.CUDAPref)
1893 DeclAccessPair
Found;
1896 ImplicitDeallocationParameters IDP;
1916 QualType SelectedTypeIdentityParameter =
1919 diag::err_incomplete_type))
1927 S.
Diag(StartLoc, diag::err_deleted_function_use)
1928 << (Msg !=
nullptr) << (Msg ? Msg->
getString() : StringRef());
1945 UsualDeallocFnInfo Best;
1946 for (
auto I = R.begin(), E = R.end(); I != E; ++I) {
1947 UsualDeallocFnInfo Info(S, I.getPair(), IDP.
Type, Loc);
1958 BestFns->push_back(Info);
1961 int ComparisonResult = Best.Compare(S, Info, IDP);
1962 if (ComparisonResult > 0)
1967 if (BestFns && ComparisonResult < 0)
1972 BestFns->push_back(Info);
1985 const auto *record =
1987 if (!record)
return false;
2000 if (ops.
empty())
return false;
2010 allocType, PassType,
2022 std::optional<Expr *> ArraySize;
2048 if (
Expr *NumElts = Array.NumElts) {
2049 if (!NumElts->isTypeDependent() && !NumElts->isValueDependent()) {
2063 NumElts,
nullptr, diag::err_new_array_nonconst,
2081 DirectInitRange = List->getSourceRange();
2084 PlacementLParen, PlacementArgs, PlacementRParen,
2085 TypeIdParens, AllocType, TInfo, ArraySize, DirectInitRange,
2094 return IsCPlusPlus20 || PLE->getNumExprs() == 0;
2098 return !CCE->isListInitialization() &&
2099 CCE->getConstructor()->isDefaultConstructor();
2102 "Shouldn't create list CXXConstructExprs for arrays.");
2127 StringRef OSName = AvailabilityAttr::getPlatformNameSourceSpelling(
2132 Diag(Loc, diag::err_aligned_allocation_unavailable)
2134 << OSVersion.getAsString() << OSVersion.empty();
2135 Diag(Loc, diag::note_silence_aligned_allocation_unavailable);
2145 std::optional<Expr *> ArraySize,
2151 if (DirectInitRange.
isValid()) {
2152 assert(
Initializer &&
"Have parens but no initializer.");
2154 }
else if (isa_and_nonnull<InitListExpr>(
Initializer))
2159 "Initializer expression that cannot have been implicitly created.");
2166 "paren init for non-call init");
2167 Exprs =
MultiExprArg(List->getExprs(), List->getNumExprs());
2168 }
else if (
auto *List = dyn_cast_or_null<CXXParenListInitExpr>(
Initializer)) {
2170 "paren init for non-call init");
2171 Exprs = List->getInitExprs();
2178 switch (InitStyle) {
2189 DirectInitRange.
getEnd());
2195 llvm_unreachable(
"Unknown initialization kind");
2204 Diag(*ArraySize ? (*ArraySize)->getExprLoc() : TypeRange.
getBegin(),
2205 diag::err_deduced_class_template_compound_type)
2207 << (*ArraySize ? (*ArraySize)->getSourceRange() : TypeRange));
2213 AllocTypeInfo, Entity, Kind, Exprs);
2225 return ExprError(
Diag(StartLoc, diag::err_auto_new_requires_ctor_arg)
2226 << AllocType << TypeRange);
2227 if (
Inits.size() > 1) {
2230 diag::err_auto_new_ctor_multiple_expressions)
2231 << AllocType << TypeRange);
2235 << AllocType << TypeRange;
2240 << Braced << AllocType << TypeRange);
2247 return ExprError(
Diag(StartLoc, diag::err_auto_new_deduction_failure)
2248 << AllocType << Deduce->
getType() << TypeRange
2250 if (DeducedType.
isNull()) {
2254 AllocType = DeducedType;
2262 =
Context.getAsConstantArrayType(AllocType)) {
2266 AllocType = Array->getElementType();
2280 AllocType =
Context.getLifetimeQualifiedType(AllocType,
2286 if (ArraySize && *ArraySize &&
2287 (*ArraySize)->getType()->isNonOverloadPlaceholderType()) {
2290 ArraySize = result.
get();
2299 std::optional<uint64_t> KnownArraySize;
2300 if (ArraySize && *ArraySize && !(*ArraySize)->isTypeDependent()) {
2303 assert(
Context.getTargetInfo().getIntWidth() &&
"Builtin type of size 0?");
2308 if (!ConvertedSize.
isInvalid() && (*ArraySize)->getType()->isRecordType())
2310 Diag(StartLoc, diag::warn_cxx98_compat_array_size_conversion)
2311 << (*ArraySize)->getType() << 0 <<
"'size_t'";
2318 SizeConvertDiagnoser(
Expr *ArraySize)
2320 ArraySize(ArraySize) {}
2324 return S.
Diag(Loc, diag::err_array_size_not_integral)
2330 return S.
Diag(Loc, diag::err_array_size_incomplete_type)
2336 return S.
Diag(Loc, diag::err_array_size_explicit_conversion) << T << ConvTy;
2347 return S.
Diag(Loc, diag::err_array_size_ambiguous_conversion) << T;
2361 ? diag::warn_cxx98_compat_array_size_conversion
2362 : diag::ext_array_size_conversion)
2365 } SizeDiagnoser(*ArraySize);
2373 ArraySize = ConvertedSize.
get();
2374 QualType SizeType = (*ArraySize)->getType();
2392 if (std::optional<llvm::APSInt>
Value =
2393 (*ArraySize)->getIntegerConstantExpr(
Context)) {
2394 if (
Value->isSigned() &&
Value->isNegative()) {
2396 diag::err_typecheck_negative_array_size)
2397 << (*ArraySize)->getSourceRange());
2401 unsigned ActiveSizeBits =
2405 Diag((*ArraySize)->getBeginLoc(), diag::err_array_too_large)
2409 << (*ArraySize)->getSourceRange());
2412 KnownArraySize =
Value->getZExtValue();
2413 }
else if (TypeIdParens.
isValid()) {
2415 Diag((*ArraySize)->getBeginLoc(), diag::ext_new_paren_array_nonconst)
2416 << (*ArraySize)->getSourceRange()
2429 unsigned Alignment =
2431 unsigned NewAlignment =
Context.getTargetInfo().getNewAlign();
2435 Alignment > NewAlignment)};
2444 AllocationParameterRange =
SourceRange(PlacementLParen, PlacementRParen);
2448 AllocType, ArraySize.has_value(), IAP,
2449 PlacementArgs, OperatorNew, OperatorDelete))
2454 bool UsualArrayDeleteWantsSize =
false;
2470 unsigned NumImplicitArgs = 1;
2472 assert(OperatorNew->isTypeAwareOperatorNewOrDelete());
2478 Proto, NumImplicitArgs, PlacementArgs,
2479 AllPlaceArgs, CallType))
2482 if (!AllPlaceArgs.empty())
2483 PlacementArgs = AllPlaceArgs;
2491 unsigned SizeTyWidth =
Context.getTypeSize(SizeTy);
2493 llvm::APInt SingleEltSize(
2494 SizeTyWidth,
Context.getTypeSizeInChars(AllocType).getQuantity());
2497 std::optional<llvm::APInt> AllocationSize;
2500 AllocationSize = SingleEltSize;
2504 AllocationSize = llvm::APInt(SizeTyWidth, *KnownArraySize)
2505 .umul_ov(SingleEltSize, Overflow);
2509 "Expected that all the overflows would have been handled already.");
2513 Context, AllocationSize.value_or(llvm::APInt::getZero(SizeTyWidth)),
2528 llvm::APInt(
Context.getTypeSize(SizeTy),
2529 Alignment /
Context.getCharWidth()),
2532 CK_IntegralCast, &AlignmentLiteral,
2537 CallArgs.reserve(NumImplicitArgs + PlacementArgs.size());
2538 CallArgs.emplace_back(AllocationSize
2539 ?
static_cast<Expr *
>(&AllocationSizeLiteral)
2540 : &OpaqueAllocationSize);
2542 CallArgs.emplace_back(&DesiredAlignment);
2543 llvm::append_range(CallArgs, PlacementArgs);
2547 checkCall(OperatorNew, Proto,
nullptr, CallArgs,
2548 false, StartLoc, Range, CallType);
2553 (OperatorNew->isImplicit() ||
2554 (OperatorNew->getBeginLoc().isValid() &&
2556 if (Alignment > NewAlignment)
2557 Diag(StartLoc, diag::warn_overaligned_type)
2569 SourceRange InitRange(Exprs.front()->getBeginLoc(),
2570 Exprs.back()->getEndLoc());
2571 Diag(StartLoc, diag::err_new_array_init_args) << InitRange;
2582 InitType =
Context.getConstantArrayType(
2588 InitType =
Context.getIncompleteArrayType(AllocType,
2591 InitType = AllocType;
2593 bool VariableLengthArrayNew = ArraySize && *ArraySize && !KnownArraySize;
2595 StartLoc, InitType, VariableLengthArrayNew);
2605 dyn_cast_or_null<CXXBindTemporaryExpr>(FullInit.
get()))
2606 FullInit = Binder->getSubExpr();
2613 if (ArraySize && !*ArraySize) {
2621 Diag(TypeRange.
getEnd(), diag::err_new_array_size_unknown_from_init)
2633 if (OperatorDelete) {
2641 if (
Context.getTargetInfo().emitVectorDeletingDtors(
Context.getLangOpts())) {
2648 if (!
Context.classMaybeNeedsVectorDeletingDestructor(ClassDecl)) {
2650 if (Dtor && Dtor->isVirtual() && !Dtor->isDeleted()) {
2651 Context.setClassMaybeNeedsVectorDeletingDestructor(ClassDecl);
2652 if (!Dtor->isDefined() && !Dtor->isInvalidDecl()) {
2667 IAP, UsualArrayDeleteWantsSize, PlacementArgs,
2669 ResultType, AllocTypeInfo, Range, DirectInitRange);
2677 return Diag(Loc, diag::err_bad_new_type)
2678 << AllocType << 0 << R;
2680 return Diag(Loc, diag::err_bad_new_type)
2681 << AllocType << 1 << R;
2684 Loc, AllocType, diag::err_new_incomplete_or_sizeless_type, R))
2687 diag::err_allocation_of_abstract_type))
2690 return Diag(Loc, diag::err_variably_modified_new_type)
2694 return Diag(Loc, diag::err_address_space_qualified_new)
2703 return Diag(Loc, diag::err_arc_new_array_without_ownership)
2717 unsigned NonTypeArgumentOffset = 0;
2719 ++NonTypeArgumentOffset;
2725 Alloc != AllocEnd; ++Alloc) {
2767 AlignArg = Args[NonTypeArgumentOffset + 1];
2768 Args.erase(Args.begin() + NonTypeArgumentOffset + 1);
2770 PassAlignment, Operator,
2780 if (R.getLookupName().getCXXOverloadedOperator() == OO_Array_New &&
2787 PassAlignment, Operator,
2801 if (!R.isClassLookup() && Args.size() == 2 &&
2802 (Args[1]->getType()->isObjectPointerType() ||
2803 Args[1]->getType()->isArrayType())) {
2804 const QualType Arg1Type = Args[1]->getType();
2809 S.
Diag(Args[1]->getExprLoc(),
2810 diag::err_placement_new_into_const_qualified_storage)
2811 << Arg1Type << Args[1]->getSourceRange();
2814 S.
Diag(R.getNameLoc(), diag::err_need_header_before_placement_new)
2815 << R.getLookupName() << Range;
2829 if (AlignedCandidates) {
2831 auto AlignArgOffset = NonTypeArgumentOffset + 1;
2832 return C.Function->getNumParams() > AlignArgOffset &&
2833 C.Function->getParamDecl(AlignArgOffset)
2839 AlignedArgs.reserve(Args.size() + NonTypeArgumentOffset + 1);
2840 for (
unsigned Idx = 0; Idx < NonTypeArgumentOffset + 1; ++Idx)
2841 AlignedArgs.push_back(Args[Idx]);
2842 AlignedArgs.push_back(AlignArg);
2843 AlignedArgs.append(Args.begin() + NonTypeArgumentOffset + 1,
2849 R.getNameLoc(), IsUnaligned);
2855 S.
Diag(R.getNameLoc(), diag::err_ovl_no_viable_function_in_call)
2856 << R.getLookupName() << Range;
2857 if (AlignedCandidates)
2858 AlignedCandidates->
NoteCandidates(S, AlignedArgs, AlignedCands,
"",
2868 S.
PDiag(diag::err_ovl_ambiguous_call)
2869 << R.getLookupName() << Range),
2877 Candidates, Best->Function, Args);
2881 llvm_unreachable(
"Unreachable, bad result from BestViableFunction");
2895 while (Filter.hasNext()) {
2896 FunctionDecl *FD = Filter.next()->getUnderlyingDecl()->getAsFunction();
2916 UntypedParameters.reserve(Args.size() - 1);
2917 UntypedParameters.push_back(Args[1]);
2922 UntypedParameters.push_back(Args[2]);
2923 UntypedParameters.append(Args.begin() + 3, Args.end());
2929 AlignedCandidates, AlignArg,
Diagnose))
2939 Args = std::move(UntypedParameters);
2944 AlignedCandidates, AlignArg,
Diagnose);
2975 IsArray ? OO_Array_New : OO_New);
2990 if (!SpecializedTypeIdentity.
isNull()) {
2991 TypeIdentity = SpecializedTypeIdentity;
2993 diag::err_incomplete_type))
3002 AllocArgs.push_back(&TypeIdentityParam);
3005 unsigned SizeTyWidth =
Context.getTypeSize(SizeTy);
3008 AllocArgs.push_back(&Size);
3013 if (IncludeAlignParam) {
3018 if (IncludeAlignParam)
3019 AllocArgs.push_back(&Align);
3021 llvm::append_range(AllocArgs, PlaceArgs);
3038 if (R.isAmbiguous())
3052 if (PlaceArgs.empty()) {
3053 Diag(StartLoc, diag::err_openclcxx_not_supported) <<
"default new";
3055 Diag(StartLoc, diag::err_openclcxx_placement_new);
3060 assert(!R.empty() &&
"implicitly declared allocation functions not found");
3061 assert(!R.isAmbiguous() &&
"global allocation functions are ambiguous");
3064 R.suppressDiagnostics();
3074 OperatorDelete =
nullptr;
3081 OperatorNew->getDeclName().getCXXOverloadedOperator() == OO_Array_New
3109 while (Filter.hasNext()) {
3110 auto *FD = dyn_cast<FunctionDecl>(Filter.next()->getUnderlyingDecl());
3111 if (FD && FD->isDestroyingOperatorDelete())
3117 auto GetRedeclContext = [](
Decl *D) {
3118 return D->getDeclContext()->getRedeclContext();
3121 DeclContext *OperatorNewContext = GetRedeclContext(OperatorNew);
3123 bool FoundGlobalDelete = FoundDelete.
empty();
3124 bool IsClassScopedTypeAwareNew =
3127 auto DiagnoseMissingTypeAwareCleanupOperator = [&](
bool IsPlacementOperator) {
3130 Diag(StartLoc, diag::err_mismatching_type_aware_cleanup_deallocator)
3131 << OperatorNew->getDeclName() << IsPlacementOperator << DeleteName;
3132 Diag(OperatorNew->getLocation(), diag::note_type_aware_operator_declared)
3133 << OperatorNew->isTypeAwareOperatorNewOrDelete()
3134 << OperatorNew->getDeclName() << OperatorNewContext;
3137 if (IsClassScopedTypeAwareNew && FoundDelete.
empty()) {
3138 DiagnoseMissingTypeAwareCleanupOperator(
false);
3141 if (FoundDelete.
empty()) {
3173 unsigned NonPlacementNewArgCount = 1;
3175 NonPlacementNewArgCount =
3177 bool isPlacementNew = !PlaceArgs.empty() ||
3178 OperatorNew->param_size() != NonPlacementNewArgCount ||
3179 OperatorNew->isVariadic();
3181 if (isPlacementNew) {
3197 int InitialParamOffset = 0;
3199 ArgTypes.push_back(TypeIdentity);
3200 InitialParamOffset = 1;
3202 ArgTypes.push_back(
Context.VoidPtrTy);
3203 for (
unsigned I = ArgTypes.size() - InitialParamOffset,
3204 N = Proto->getNumParams();
3206 ArgTypes.push_back(Proto->getParamType(I));
3210 EPI.
Variadic = Proto->isVariadic();
3212 ExpectedFunctionType
3217 DEnd = FoundDelete.
end();
3221 dyn_cast<FunctionTemplateDecl>((*D)->getUnderlyingDecl())) {
3232 ExpectedFunctionType,
3234 ExpectedFunctionType))
3235 Matches.push_back(std::make_pair(D.getPair(), Fn));
3242 DiagnoseMissingTypeAwareCleanupOperator(isPlacementNew);
3255 AllocElemType, OriginalTypeAwareState,
3260 *
this, FoundDelete, IDP, StartLoc, &BestDeallocFns);
3261 if (Selected && BestDeallocFns.empty())
3262 Matches.push_back(std::make_pair(Selected.Found, Selected.FD));
3266 for (
auto Fn : BestDeallocFns)
3267 Matches.push_back(std::make_pair(Fn.Found, Fn.FD));
3275 if (Matches.size() == 1) {
3276 OperatorDelete = Matches[0].second;
3277 DeclContext *OperatorDeleteContext = GetRedeclContext(OperatorDelete);
3278 bool FoundTypeAwareOperator =
3279 OperatorDelete->isTypeAwareOperatorNewOrDelete() ||
3280 OperatorNew->isTypeAwareOperatorNewOrDelete();
3281 if (
Diagnose && FoundTypeAwareOperator) {
3282 bool MismatchedTypeAwareness =
3283 OperatorDelete->isTypeAwareOperatorNewOrDelete() !=
3284 OperatorNew->isTypeAwareOperatorNewOrDelete();
3285 bool MismatchedContext = OperatorDeleteContext != OperatorNewContext;
3286 if (MismatchedTypeAwareness || MismatchedContext) {
3287 FunctionDecl *Operators[] = {OperatorDelete, OperatorNew};
3288 bool TypeAwareOperatorIndex =
3290 Diag(StartLoc, diag::err_mismatching_type_aware_cleanup_deallocator)
3291 << Operators[TypeAwareOperatorIndex]->
getDeclName()
3293 << Operators[!TypeAwareOperatorIndex]->
getDeclName()
3294 << GetRedeclContext(Operators[TypeAwareOperatorIndex]);
3295 Diag(OperatorNew->getLocation(),
3296 diag::note_type_aware_operator_declared)
3297 << OperatorNew->isTypeAwareOperatorNewOrDelete()
3298 << OperatorNew->getDeclName() << OperatorNewContext;
3299 Diag(OperatorDelete->getLocation(),
3300 diag::note_type_aware_operator_declared)
3301 << OperatorDelete->isTypeAwareOperatorNewOrDelete()
3302 << OperatorDelete->getDeclName() << OperatorDeleteContext;
3314 UsualDeallocFnInfo Info(*
this,
3316 AllocElemType, StartLoc);
3322 if (IsSizedDelete && !FoundGlobalDelete) {
3327 *
this, FoundDelete, SizeTestingIDP, StartLoc);
3328 if (NonSizedDelete &&
3331 IsSizedDelete =
false;
3338 PlaceArgs.back()->getEndLoc());
3339 Diag(StartLoc, diag::err_placement_new_non_placement_delete) << R;
3340 if (!OperatorDelete->isImplicit())
3341 Diag(OperatorDelete->getLocation(), diag::note_previous_decl)
3350 }
else if (!Matches.empty()) {
3354 Diag(StartLoc, diag::warn_ambiguous_suitable_delete_function_found)
3355 << DeleteName << AllocElemType;
3357 for (
auto &
Match : Matches)
3359 diag::note_member_declared_here) << DeleteName;
3418 &
PP.getIdentifierTable().get(
"bad_alloc"),
nullptr);
3423 if (TheGlobalModuleFragment) {
3434 &
PP.getIdentifierTable().get(
"align_val_t"),
nullptr,
true,
true,
true);
3438 if (TheGlobalModuleFragment) {
3439 AlignValT->setModuleOwnershipKind(
3441 AlignValT->setLocalOwningModule(TheGlobalModuleFragment);
3444 AlignValT->setIntegerType(
Context.getSizeType());
3445 AlignValT->setPromotionType(
Context.getSizeType());
3446 AlignValT->setImplicit(
true);
3466 Params.push_back(Param);
3469 bool HasSizedVariant =
getLangOpts().SizedDeallocation &&
3470 (Kind == OO_Delete || Kind == OO_Array_Delete);
3471 bool HasAlignedVariant =
getLangOpts().AlignedAllocation;
3473 int NumSizeVariants = (HasSizedVariant ? 2 : 1);
3474 int NumAlignVariants = (HasAlignedVariant ? 2 : 1);
3475 for (
int Sized = 0; Sized < NumSizeVariants; ++Sized) {
3477 Params.push_back(
SizeT);
3479 for (
int Aligned = 0; Aligned < NumAlignVariants; ++Aligned) {
3484 Context.DeclarationNames.getCXXOperatorName(Kind), Return, Params);
3492 DeclareGlobalAllocationFunctions(OO_New, VoidPtr,
SizeT);
3493 DeclareGlobalAllocationFunctions(OO_Array_New, VoidPtr,
SizeT);
3494 DeclareGlobalAllocationFunctions(OO_Delete,
Context.VoidTy, VoidPtr);
3495 DeclareGlobalAllocationFunctions(OO_Array_Delete,
Context.VoidTy, VoidPtr);
3498 PopGlobalModuleFragment();
3511 Alloc != AllocEnd; ++Alloc) {
3515 if (
Func->getNumParams() == Params.size()) {
3516 if (std::equal(
Func->param_begin(),
Func->param_end(), Params.begin(),
3518 return Context.hasSameUnqualifiedType(D->getType(),
3524 Func->setVisibleDespiteOwningModule();
3532 Context.getTargetInfo().getDefaultCallingConv());
3536 if (HasBadAllocExceptionSpec) {
3539 assert(
StdBadAlloc &&
"Must have std::bad_alloc declared");
3551 auto CreateAllocationFunctionDecl = [&](
Attr *ExtraAttr) {
3559 Context.getTargetInfo().getTriple().isSPIRV()) {
3560 if (
auto *ATI =
Context.getAuxTargetInfo())
3570 Alloc->setImplicit();
3572 Alloc->setVisibleDespiteOwningModule();
3574 if (HasBadAllocExceptionSpec &&
getLangOpts().NewInfallible &&
3577 ReturnsNonNullAttr::CreateImplicit(
Context, Alloc->getLocation()));
3589 if (TheGlobalModuleFragment) {
3590 Alloc->setModuleOwnershipKind(
3592 Alloc->setLocalOwningModule(TheGlobalModuleFragment);
3595 if (
LangOpts.hasGlobalAllocationFunctionVisibility())
3596 Alloc->addAttr(VisibilityAttr::CreateImplicit(
3598 ? VisibilityAttr::Hidden
3599 :
LangOpts.hasProtectedGlobalAllocationFunctionVisibility()
3600 ? VisibilityAttr::Protected
3601 : VisibilityAttr::Default));
3608 ParamDecls.back()->setImplicit();
3610 Alloc->setParams(ParamDecls);
3612 Alloc->addAttr(ExtraAttr);
3614 Context.getTranslationUnitDecl()->addDecl(Alloc);
3619 CreateAllocationFunctionDecl(
nullptr);
3623 CreateAllocationFunctionDecl(CUDAHostAttr::CreateImplicit(
Context));
3624 CreateAllocationFunctionDecl(CUDADeviceAttr::CreateImplicit(
Context));
3651 assert(
Result.FD &&
"operator delete missing from global scope?");
3665 if (!LookForGlobal) {
3670 return OperatorDelete;
3690 if (
Found.isAmbiguous()) {
3692 Found.suppressDiagnostics();
3696 Found.suppressDiagnostics();
3709 if (Matches.size() == 1) {
3712 Found.getNamingClass(), Matches[0].Found,
3719 if (!Matches.empty()) {
3721 Diag(StartLoc, diag::err_ambiguous_suitable_delete_member_function_found)
3723 for (
auto &
Match : Matches)
3724 Diag(
Match.FD->getLocation(), diag::note_member_declared_here) << Name;
3731 if (!
Found.empty()) {
3733 Diag(StartLoc, diag::err_no_suitable_delete_member_function_found)
3737 Diag(D->getUnderlyingDecl()->getLocation(),
3738 diag::note_member_declared_here) << Name;
3750class MismatchingNewDeleteDetector {
3752 enum MismatchResult {
3758 MemberInitMismatches,
3767 explicit MismatchingNewDeleteDetector(
bool EndOfTU)
3768 : Field(
nullptr), IsArrayForm(
false), EndOfTU(EndOfTU),
3769 HasUndefinedConstructors(
false) {}
3781 MismatchResult analyzeDeleteExpr(
const CXXDeleteExpr *DE);
3786 MismatchResult analyzeField(FieldDecl *Field,
bool DeleteWasArrayForm);
3789 llvm::SmallVector<const CXXNewExpr *, 4> NewExprs;
3796 bool HasUndefinedConstructors;
3800 const CXXNewExpr *getNewExprFromInitListOrExpr(
const Expr *E);
3808 MismatchResult analyzeMemberExpr(
const MemberExpr *ME);
3816 bool hasMatchingVarInit(
const DeclRefExpr *D);
3825 bool hasMatchingNewInCtor(
const CXXConstructorDecl *CD);
3828 bool hasMatchingNewInCtorInit(
const CXXCtorInitializer *CI);
3831 MismatchResult analyzeInClassInitializer();
3835MismatchingNewDeleteDetector::MismatchResult
3836MismatchingNewDeleteDetector::analyzeDeleteExpr(
const CXXDeleteExpr *DE) {
3838 assert(DE &&
"Expected delete-expression");
3841 if (
const MemberExpr *ME = dyn_cast<const MemberExpr>(E)) {
3842 return analyzeMemberExpr(ME);
3843 }
else if (
const DeclRefExpr *D = dyn_cast<const DeclRefExpr>(E)) {
3844 if (!hasMatchingVarInit(D))
3845 return VarInitMismatches;
3851MismatchingNewDeleteDetector::getNewExprFromInitListOrExpr(
const Expr *E) {
3852 assert(E !=
nullptr &&
"Expected a valid initializer expression");
3854 if (
const InitListExpr *ILE = dyn_cast<const InitListExpr>(E)) {
3855 if (ILE->getNumInits() == 1)
3856 E = dyn_cast<const CXXNewExpr>(ILE->getInit(0)->IgnoreParenImpCasts());
3859 return dyn_cast_or_null<const CXXNewExpr>(E);
3862bool MismatchingNewDeleteDetector::hasMatchingNewInCtorInit(
3863 const CXXCtorInitializer *CI) {
3864 const CXXNewExpr *
NE =
nullptr;
3866 (NE = getNewExprFromInitListOrExpr(CI->
getInit()))) {
3867 if (
NE->isArray() == IsArrayForm)
3870 NewExprs.push_back(NE);
3875bool MismatchingNewDeleteDetector::hasMatchingNewInCtor(
3876 const CXXConstructorDecl *CD) {
3881 HasUndefinedConstructors =
true;
3885 if (hasMatchingNewInCtorInit(CI))
3891MismatchingNewDeleteDetector::MismatchResult
3892MismatchingNewDeleteDetector::analyzeInClassInitializer() {
3893 assert(Field !=
nullptr &&
"This should be called only for members");
3894 const Expr *InitExpr =
Field->getInClassInitializer();
3896 return EndOfTU ? NoMismatch : AnalyzeLater;
3897 if (
const CXXNewExpr *NE = getNewExprFromInitListOrExpr(InitExpr)) {
3898 if (
NE->isArray() != IsArrayForm) {
3899 NewExprs.push_back(NE);
3900 return MemberInitMismatches;
3906MismatchingNewDeleteDetector::MismatchResult
3907MismatchingNewDeleteDetector::analyzeField(FieldDecl *Field,
3908 bool DeleteWasArrayForm) {
3909 assert(Field !=
nullptr &&
"Analysis requires a valid class member.");
3911 IsArrayForm = DeleteWasArrayForm;
3913 for (
const auto *CD : RD->
ctors()) {
3914 if (hasMatchingNewInCtor(CD))
3917 if (HasUndefinedConstructors)
3918 return EndOfTU ? NoMismatch : AnalyzeLater;
3919 if (!NewExprs.empty())
3920 return MemberInitMismatches;
3921 return Field->hasInClassInitializer() ? analyzeInClassInitializer()
3925MismatchingNewDeleteDetector::MismatchResult
3926MismatchingNewDeleteDetector::analyzeMemberExpr(
const MemberExpr *ME) {
3927 assert(ME !=
nullptr &&
"Expected a member expression");
3928 if (FieldDecl *F = dyn_cast<FieldDecl>(ME->
getMemberDecl()))
3929 return analyzeField(F, IsArrayForm);
3933bool MismatchingNewDeleteDetector::hasMatchingVarInit(
const DeclRefExpr *D) {
3934 const CXXNewExpr *
NE =
nullptr;
3935 if (
const VarDecl *VD = dyn_cast<const VarDecl>(D->
getDecl())) {
3936 if (VD->hasInit() && (NE = getNewExprFromInitListOrExpr(VD->getInit())) &&
3937 NE->isArray() != IsArrayForm) {
3938 NewExprs.push_back(NE);
3941 return NewExprs.empty();
3946 const MismatchingNewDeleteDetector &Detector) {
3949 if (!Detector.IsArrayForm)
3958 SemaRef.
Diag(DeleteLoc, diag::warn_mismatched_delete_new)
3959 << Detector.IsArrayForm << H;
3961 for (
const auto *NE : Detector.NewExprs)
3962 SemaRef.
Diag(NE->getExprLoc(), diag::note_allocated_here)
3963 << Detector.IsArrayForm;
3966void Sema::AnalyzeDeleteExprMismatch(
const CXXDeleteExpr *DE) {
3967 if (
Diags.isIgnored(diag::warn_mismatched_delete_new, SourceLocation()))
3969 MismatchingNewDeleteDetector Detector(
false);
3970 switch (Detector.analyzeDeleteExpr(DE)) {
3971 case MismatchingNewDeleteDetector::VarInitMismatches:
3972 case MismatchingNewDeleteDetector::MemberInitMismatches: {
3976 case MismatchingNewDeleteDetector::AnalyzeLater: {
3981 case MismatchingNewDeleteDetector::NoMismatch:
3986void Sema::AnalyzeDeleteExprMismatch(FieldDecl *Field, SourceLocation DeleteLoc,
3987 bool DeleteWasArrayForm) {
3988 MismatchingNewDeleteDetector Detector(
true);
3989 switch (Detector.analyzeField(Field, DeleteWasArrayForm)) {
3990 case MismatchingNewDeleteDetector::VarInitMismatches:
3991 llvm_unreachable(
"This analysis should have been done for class members.");
3992 case MismatchingNewDeleteDetector::AnalyzeLater:
3993 llvm_unreachable(
"Analysis cannot be postponed any point beyond end of "
3994 "translation unit.");
3995 case MismatchingNewDeleteDetector::MemberInitMismatches:
3998 case MismatchingNewDeleteDetector::NoMismatch:
4005 bool ArrayForm,
Expr *ExE) {
4015 bool ArrayFormAsWritten = ArrayForm;
4016 bool UsualArrayDeleteWantsSize =
false;
4034 if (ConvPtrType->getPointeeType()->isIncompleteOrObjectType())
4041 return S.
Diag(Loc, diag::err_delete_operand) << T;
4046 return S.
Diag(Loc, diag::err_delete_incomplete_class_type) << T;
4052 return S.
Diag(Loc, diag::err_delete_explicit_conversion) << T << ConvTy;
4063 return S.
Diag(Loc, diag::err_ambiguous_delete_operand) << T;
4075 llvm_unreachable(
"conversion functions are permitted");
4083 if (!Converter.match(
Type))
4094 diag::err_address_space_qualified_delete)
4104 Diag(StartLoc,
LangOpts.CPlusPlus26 ? diag::err_delete_incomplete
4105 : diag::ext_delete_void_ptr_operand)
4118 ? diag::err_delete_incomplete
4119 : diag::warn_delete_incomplete,
4126 Diag(StartLoc, diag::warn_delete_array_type)
4133 ArrayForm ? OO_Array_Delete : OO_Delete);
4141 OperatorDelete, IDP))
4155 else if (isa_and_nonnull<CXXMethodDecl>(OperatorDelete)) {
4156 UsualDeallocFnInfo UDFI(
4165 if (Dtor->isCalledByDelete(OperatorDelete)) {
4179 if (!OperatorDelete) {
4181 Diag(StartLoc, diag::err_openclcxx_not_supported) <<
"default delete";
4186 bool CanProvideSize =
4187 IsComplete && (!ArrayForm || UsualArrayDeleteWantsSize ||
4197 if (!OperatorDelete)
4201 if (OperatorDelete->isInvalidDecl())
4208 bool IsVirtualDelete =
false;
4211 if (Dtor->isCalledByDelete(OperatorDelete))
4213 PDiag(diag::err_access_dtor) << PointeeElem);
4214 IsVirtualDelete = Dtor->isVirtual();
4220 unsigned AddressParamIdx = 0;
4221 if (OperatorDelete->isTypeAwareOperatorNewOrDelete()) {
4222 QualType TypeIdentity = OperatorDelete->getParamDecl(0)->getType();
4224 diag::err_incomplete_type))
4226 AddressParamIdx = 1;
4234 OperatorDelete->getParamDecl(AddressParamIdx)->getType();
4253 Context.VoidTy, UseGlobal, ArrayForm, ArrayFormAsWritten,
4254 UsualArrayDeleteWantsSize, OperatorDelete, Ex.
get(), StartLoc);
4255 AnalyzeDeleteExprMismatch(
Result);
4264 IsDelete ? OO_Delete : OO_New);
4268 assert(!R.empty() &&
"implicitly declared allocation functions not found");
4269 assert(!R.isAmbiguous() &&
"global allocation functions are ambiguous");
4272 R.suppressDiagnostics();
4278 FnOvl != FnOvlEnd; ++FnOvl) {
4281 NamedDecl *D = (*FnOvl)->getUnderlyingDecl();
4304 assert(R.getNamingClass() ==
nullptr &&
4305 "class members should not be considered");
4308 S.
Diag(R.getNameLoc(), diag::err_builtin_operator_new_delete_not_usual)
4309 << (IsDelete ? 1 : 0) << Range;
4310 S.
Diag(FnDecl->
getLocation(), diag::note_non_usual_function_declared_here)
4322 S.
PDiag(diag::err_ovl_no_viable_function_in_call)
4323 << R.getLookupName() << Range),
4330 S.
PDiag(diag::err_ovl_ambiguous_call)
4331 << R.getLookupName() << Range),
4337 Candidates, Best->Function, Args);
4340 llvm_unreachable(
"Unreachable, bad result from BestViableFunction");
4348 << (IsDelete ?
"__builtin_operator_delete" :
"__builtin_operator_new")
4356 FunctionDecl *OperatorNewOrDelete =
nullptr;
4358 OperatorNewOrDelete))
4360 assert(OperatorNewOrDelete &&
"should be found");
4366 for (
unsigned i = 0; i != TheCall->
getNumArgs(); ++i) {
4368 InitializedEntity Entity =
4377 assert(Callee &&
Callee->getCastKind() == CK_BuiltinFnToFnPtr &&
4378 "Callee expected to be implicit cast to a builtin function pointer");
4381 return TheCallResult;
4385 bool IsDelete,
bool CallCanBeVirtual,
4386 bool WarnOnNonAbstractTypes,
4413 Diag(Loc, diag::warn_delete_abstract_non_virtual_dtor) << (IsDelete ? 0 : 1)
4415 }
else if (WarnOnNonAbstractTypes) {
4418 Diag(Loc, diag::warn_delete_non_virtual_dtor) << (IsDelete ? 0 : 1)
4422 std::string TypeStr;
4424 Diag(DtorLoc, diag::note_delete_non_virtual)
4451 if (T->isFunctionType())
4453 diag::err_invalid_use_of_function_type)
4455 else if (T->isArrayType())
4457 diag::err_invalid_use_of_array_type)
4475 llvm_unreachable(
"unexpected condition kind");
4507 diag::err_constexpr_if_condition_expression_is_not_constant);
4515 From = Cast->getSubExpr();
4527 if (!ToPtrType->getPointeeType().hasQualifiers()) {
4528 switch (StrLit->getKind()) {
4536 return (ToPointeeType->getKind() == BuiltinType::Char_U ||
4537 ToPointeeType->getKind() == BuiltinType::Char_S);
4542 assert(
false &&
"Unevaluated string literal in expression");
4557 bool HadMultipleCandidates,
4560 default: llvm_unreachable(
"Unhandled cast kind!");
4561 case CK_ConstructorConversion: {
4566 diag::err_allocation_of_abstract_type))
4580 ConstructorArgs, HadMultipleCandidates,
4581 false,
false,
false,
4583 if (Result.isInvalid())
4589 case CK_UserDefinedConversion: {
4599 HadMultipleCandidates);
4600 if (Result.isInvalid())
4604 CK_UserDefinedConversion, Result.get(),
4605 nullptr, Result.get()->getValueKind(),
4638 assert(FD &&
"no conversion function for user-defined conversion seq");
4640 CastKind = CK_UserDefinedConversion;
4645 BeforeToType =
Context.getCanonicalTagType(Conv->getParent());
4648 CastKind = CK_ConstructorConversion;
4675 From = CastArg.
get();
4689 PDiag(diag::err_typecheck_ambiguous_condition)
4695 llvm_unreachable(
"bad conversion");
4705 assert(Diagnosed &&
"failed to diagnose bad conversion"); (void)Diagnosed;
4722 ElType = ToVec->getElementType();
4724 ElType = ToMat->getElementType();
4730 return Context.getExtVectorType(ElType, FromVec->getNumElements());
4734 return Context.getConstantMatrixType(ElType, FromMat->getNumRows(),
4735 FromMat->getNumColumns());
4744 const auto *FromOBT = FromType->
getAs<OverflowBehaviorType>();
4745 const auto *ToOBT = ToType->
getAs<OverflowBehaviorType>();
4747 if (FromOBT && ToOBT &&
4748 FromOBT->getBehaviorKind() != ToOBT->getBehaviorKind()) {
4749 S.
Diag(From->
getExprLoc(), diag::err_incompatible_obt_kinds_assignment)
4750 << ToType << FromType
4751 << (ToOBT->getBehaviorKind() ==
4752 OverflowBehaviorType::OverflowBehaviorKind::Trap
4755 << (FromOBT->getBehaviorKind() ==
4756 OverflowBehaviorType::OverflowBehaviorKind::Trap
4791 false,
false,
false,
4798 false,
false,
false,
4831 ToAtomicType = ToType;
4832 ToType = ToAtomic->getValueType();
4835 QualType InitialFromType = FromType;
4837 switch (SCS.
First) {
4840 FromType = FromAtomic->getValueType().getUnqualifiedType();
4853 From = FromRes.
get();
4859 FromType =
Context.getArrayDecayedType(FromType);
4867 FromType =
Context.getArrayParameterType(FromType);
4878 FromType =
Context.getPointerType(FromType);
4885 llvm_unreachable(
"Improper first standard conversion");
4933 "only enums with fixed underlying type can promote to bool");
4964 CK = CK_FloatingComplexCast;
4966 CK = CK_FloatingComplexToIntegralComplex;
4968 CK = CK_IntegralComplexToFloatingComplex;
4970 CK = CK_IntegralComplexCast;
4998 "Attempting implicit fixed point conversion without a fixed "
5003 nullptr, CCK).
get();
5007 nullptr, CCK).
get();
5011 nullptr, CCK).
get();
5015 nullptr, CCK).
get();
5019 nullptr, CCK).
get();
5023 nullptr, CCK).
get();
5028 nullptr, CCK).
get();
5038 diag::ext_typecheck_convert_incompatible_pointer)
5043 diag::ext_typecheck_convert_incompatible_pointer)
5050 }
else if (
getLangOpts().allowsNonTrivialObjCLifetimeQualifiers() &&
5051 !
ObjC().CheckObjCARCUnavailableWeakConversion(ToType,
5056 Diag(From->
getBeginLoc(), diag::err_arc_convesion_of_weak_unavailable)
5067 NewToType =
Context.removeAddrSpaceQualType(ToPteeType);
5068 NewToType =
Context.getAddrSpaceQualType(NewToType,
5071 NewToType =
Context.getObjCObjectPointerType(NewToType);
5073 NewToType =
Context.getBlockPointerType(NewToType);
5075 NewToType =
Context.getPointerType(NewToType);
5085 if (Kind == CK_BlockPointerToObjCPointerCast) {
5090 if (
getLangOpts().allowsNonTrivialObjCLifetimeQualifiers())
5105 assert((Kind != CK_NullToMemberPointer ||
5108 "Expr must be null pointer constant!");
5113 llvm_unreachable(
"unexpected result");
5115 llvm_unreachable(
"Should not have been called if derivation isn't OK.");
5162 &BasePath, CCK).
get();
5191 QualType ElType = ToComplex->getElementType();
5199 isFloatingComplex ? CK_FloatingCast : CK_FloatingToIntegral).
get();
5203 isFloatingComplex ? CK_IntegralToFloating : CK_IntegralCast).
get();
5207 isFloatingComplex ? CK_FloatingRealToComplex
5208 : CK_IntegralRealToComplex).
get();
5213 QualType ElType = FromComplex->getElementType();
5218 isFloatingComplex ? CK_FloatingComplexToReal
5219 : CK_IntegralComplexToReal,
5224 if (
Context.hasSameUnqualifiedType(ElType, ToType)) {
5228 isFloatingComplex ? CK_FloatingCast
5229 : CK_IntegralToFloating,
5235 isFloatingComplex ? CK_FloatingToIntegral
5252 AddrSpaceL != AddrSpaceR ? CK_AddressSpaceConversion : CK_BitCast;
5265 From = FromRes.
get();
5267 "Improper transparent union conversion");
5275 CK_ZeroToOCLOpaqueType,
5292 llvm_unreachable(
"Improper second standard conversion");
5301 "Dimension conversion output must be vector, matrix, or scalar type.");
5327 QualType TruncTy = FromVec->getElementType();
5329 TruncTy =
Context.getExtVectorType(TruncTy, ToVec->getNumElements());
5338 QualType TruncTy = FromMat->getElementType();
5340 TruncTy =
Context.getConstantMatrixType(TruncTy, ToMat->getNumRows(),
5341 ToMat->getNumColumns());
5349 llvm_unreachable(
"Improper element standard conversion");
5353 switch (SCS.
Third) {
5376 CK = CK_AddressSpaceConversion;
5381 CK = CK_AddressSpaceConversion;
5387 << InitialFromType << ToType;
5398 ? diag::ext_deprecated_string_literal_conversion
5399 : diag::warn_deprecated_string_literal_conversion)
5407 llvm_unreachable(
"Improper third standard conversion");
5412 if (!ToAtomicType.
isNull()) {
5444 "placeholders should have been weeded out by now");
5459 const char *OpSpelling = isIndirect ?
"->*" :
".*";
5467 Diag(Loc, diag::err_bad_memptr_rhs)
5489 Diag(Loc, diag::err_bad_memptr_lhs)
5490 << OpSpelling << 1 << LHSType
5500 OpSpelling, (
int)isIndirect)) {
5505 Diag(Loc, diag::err_bad_memptr_lhs) << OpSpelling
5514 LHSType, RHSClassType, Loc,
5523 UseType =
Context.getPointerType(UseType);
5532 Diag(Loc, diag::err_pointer_to_member_type) << isIndirect;
5551 switch (Proto->getRefQualifier()) {
5560 if (Proto->isConst() && !Proto->isVolatile())
5562 ? diag::warn_cxx17_compat_pointer_to_const_ref_member_on_rvalue
5563 : diag::ext_pointer_to_const_ref_member_on_rvalue);
5565 Diag(Loc, diag::err_pointer_to_member_oper_value_classify)
5572 Diag(Loc, diag::err_pointer_to_member_oper_value_classify)
5585 if (
Result->isFunctionType()) {
5588 }
else if (isIndirect) {
5606 bool &HaveConversion,
5608 HaveConversion =
false;
5625 QualType T =
Self.Context.getReferenceQualifiedType(To);
5631 HaveConversion =
true;
5646 bool FDerivedFromT = FRec && TRec && FRec != TRec &&
5647 Self.IsDerivedFrom(QuestionLoc, FTy, TTy);
5648 if (FRec && TRec && (FRec == TRec || FDerivedFromT ||
5649 Self.IsDerivedFrom(QuestionLoc, TTy, FTy))) {
5653 if (FRec == TRec || FDerivedFromT) {
5658 HaveConversion =
true;
5681 HaveConversion = !InitSeq.
Failed();
5699 Self.AddBuiltinOperatorCandidates(OO_Conditional, QuestionLoc, Args,
5707 LHS.
get(), Best->BuiltinParamTypes[0], Best->Conversions[0],
5714 RHS.
get(), Best->BuiltinParamTypes[1], Best->Conversions[1],
5720 Self.MarkFunctionReferenced(QuestionLoc, Best->Function);
5729 if (
Self.DiagnoseConditionalForNull(LHS.
get(), RHS.
get(), QuestionLoc))
5732 Self.Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands)
5738 Self.Diag(QuestionLoc, diag::err_conditional_ambiguous_ovl)
5746 llvm_unreachable(
"Conditional operator has only built-in overloads");
5760 if (Result.isInvalid())
5778 assert(!EltTy->
isEnumeralType() &&
"Vectors cant be enum types");
5794 bool LHSIsVector = LHSType->
isVectorType() || LHSSizelessVector;
5795 bool RHSIsVector = RHSType->
isVectorType() || RHSSizelessVector;
5797 auto GetVectorInfo =
5798 [&](
QualType Type) -> std::pair<QualType, llvm::ElementCount> {
5800 return std::make_pair(VT->getElementType(),
5801 llvm::ElementCount::getFixed(VT->getNumElements()));
5804 return std::make_pair(VectorInfo.
ElementType, VectorInfo.
EC);
5807 auto [CondElementTy, CondElementCount] = GetVectorInfo(CondType);
5810 if (LHSIsVector && RHSIsVector) {
5812 Diag(QuestionLoc, diag::err_conditional_vector_cond_result_mismatch)
5818 if (!
Context.hasSameType(LHSType, RHSType)) {
5819 Diag(QuestionLoc, diag::err_conditional_vector_mismatched)
5820 << LHSType << RHSType;
5823 ResultType =
Context.getCommonSugaredType(LHSType, RHSType);
5824 }
else if (LHSIsVector || RHSIsVector) {
5825 bool ResultSizeless = LHSSizelessVector || RHSSizelessVector;
5827 Diag(QuestionLoc, diag::err_conditional_vector_cond_result_mismatch)
5837 LHS, RHS, QuestionLoc,
false,
true,
5848 Context.hasSameType(LHSType, RHSType)
5849 ?
Context.getCommonSugaredType(LHSType, RHSType)
5854 Diag(QuestionLoc, diag::err_conditional_vector_operand_type)
5859 ResultType =
Context.getExtVectorType(ResultElementTy,
5860 CondElementCount.getFixedValue());
5862 ResultType =
Context.getScalableVectorType(
5863 ResultElementTy, CondElementCount.getKnownMinValue());
5865 if (ResultType.
isNull()) {
5866 Diag(QuestionLoc, diag::err_conditional_vector_scalar_type_unsupported)
5867 << ResultElementTy << CondType;
5871 ResultType =
Context.getVectorType(ResultElementTy,
5872 CondElementCount.getFixedValue(),
5879 assert(!ResultType.
isNull() &&
5882 "Result should have been a vector type");
5884 auto [ResultElementTy, ResultElementCount] = GetVectorInfo(ResultType);
5885 if (ResultElementCount != CondElementCount) {
5886 Diag(QuestionLoc, diag::err_conditional_vector_size) << CondType
5892 if (
Context.getTypeSize(ResultElementTy) !=
5893 Context.getTypeSize(CondElementTy) &&
5894 (!CondElementTy->isBooleanType() ||
LangOpts.OpenCL)) {
5895 Diag(QuestionLoc, diag::err_conditional_vector_element_size)
5896 << CondType << ResultType;
5913 bool IsVectorConditional =
5918 if (!
Cond.get()->isTypeDependent()) {
5945 if (LVoid || RVoid) {
5954 if (IsVectorConditional) {
5957 bool IsThrow = LVoid ? LThrow : RThrow;
5958 Diag(DiagLoc.
getBegin(), diag::err_conditional_vector_has_void)
5959 << DiagLoc << IsThrow;
5963 if (LThrow != RThrow) {
5964 Expr *NonThrow = LThrow ? RHS.
get() : LHS.
get();
5975 return Context.getCommonSugaredType(LTy, RTy);
5978 Diag(QuestionLoc, diag::err_conditional_void_nonvoid)
5979 << (LVoid ? RTy : LTy) << (LVoid ? 0 : 1)
5985 if (IsVectorConditional)
5990 Diag(QuestionLoc, diag::err_wasm_table_conditional_expression)
5999 if (!
Context.hasSameType(LTy, RTy) &&
6003 bool HaveL2R, HaveR2L;
6010 if (HaveL2R && HaveR2L) {
6011 Diag(QuestionLoc, diag::err_conditional_ambiguous)
6023 }
else if (HaveR2L) {
6047 ReferenceConversions::Qualification |
6048 ReferenceConversions::NestedQualification |
6049 ReferenceConversions::Function;
6054 !(RefConv & ~AllowedConversions) &&
6062 !(RefConv & ~AllowedConversions) &&
6077 bool Same =
Context.hasSameType(LTy, RTy);
6078 if (Same && LVK == RVK && LVK !=
VK_PRValue &&
6085 return Context.getCommonSugaredType(LTy, RTy);
6115 if (
Context.hasSameType(LTy, RTy)) {
6131 return Context.getCommonSugaredType(LTy, RTy);
6152 diag::err_typecheck_cond_incompatible_operands) << LTy << RTy
6190 Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands)
6210 bool T2IsPointerLike = T2->isAnyPointerType() || T2->isMemberPointerType() ||
6211 T2->isNullPtrType();
6212 if (!T1IsPointerLike && !T2IsPointerLike)
6220 if (T1IsPointerLike &&
6224 ? CK_NullToMemberPointer
6225 : CK_NullToPointer).
get();
6228 if (T2IsPointerLike &&
6232 ? CK_NullToMemberPointer
6233 : CK_NullToPointer).
get();
6238 if (!T1IsPointerLike || !T2IsPointerLike)
6241 "nullptr_t should be a null pointer constant");
6244 enum Kind {
Pointer, ObjCPointer, MemberPointer, Array } K;
6250 const Type *ClassOrBound;
6252 Step(Kind K,
const Type *ClassOrBound =
nullptr)
6253 : K(K), ClassOrBound(ClassOrBound) {}
6265 if (
auto *CAT = cast_or_null<ConstantArrayType>(ClassOrBound))
6271 llvm_unreachable(
"unknown step kind");
6293 unsigned NeedConstBefore = 0;
6298 Composite1 =
Context.getUnqualifiedArrayType(Composite1, Q1);
6299 Composite2 =
Context.getUnqualifiedArrayType(Composite2, Q2);
6302 if (!Steps.empty()) {
6312 }
else if (Steps.size() == 1) {
6315 if (MaybeQ1 == MaybeQ2) {
6334 assert(Steps.size() == 1);
6342 assert(Steps.size() == 1);
6351 Steps.back().Quals = Quals;
6352 if (Q1 != Quals || Q2 != Quals)
6353 NeedConstBefore = Steps.size() - 1;
6359 if ((Arr1 =
Context.getAsArrayType(Composite1)) &&
6360 (Arr2 =
Context.getAsArrayType(Composite2))) {
6361 auto *CAT1 = dyn_cast<ConstantArrayType>(Arr1);
6362 auto *CAT2 = dyn_cast<ConstantArrayType>(Arr2);
6363 if (CAT1 && CAT2 && CAT1->getSize() == CAT2->getSize()) {
6366 Steps.emplace_back(Step::Array, CAT1);
6371 if ((IAT1 && IAT2) ||
6373 ((
bool)CAT1 != (
bool)CAT2) &&
6374 (Steps.empty() || Steps.back().K != Step::Array))) {
6380 Steps.emplace_back(Step::Array);
6382 NeedConstBefore = Steps.size();
6392 Steps.emplace_back(Step::Pointer);
6401 Steps.emplace_back(Step::ObjCPointer);
6425 else if (Steps.empty())
6432 Steps.emplace_back(Step::MemberPointer,
6433 Context.getCanonicalTagType(Cls).getTypePtr());
6445 Steps.emplace_back(Step::Pointer);
6483 if (Steps.size() == 1) {
6495 bool CFIUncheckedCallee =
6506 Composite1 =
Context.getFunctionType(FPT1->getReturnType(),
6507 FPT1->getParamTypes(), EPI1);
6508 Composite2 =
Context.getFunctionType(FPT2->getReturnType(),
6509 FPT2->getParamTypes(), EPI2);
6515 if (Steps.size() == 1 && Steps.front().K == Step::Pointer &&
6516 !
Context.hasSameType(Composite1, Composite2)) {
6521 Composite2 = Composite1;
6523 Composite1 = Composite2;
6532 Composite1 = Composite2;
6534 Composite2 = Composite1;
6539 if (!
Context.hasSameType(Composite1, Composite2))
6544 for (
unsigned I = 0; I != NeedConstBefore; ++I)
6545 Steps[I].Quals.addConst();
6548 QualType Composite =
Context.getCommonSugaredType(Composite1, Composite2);
6549 for (
auto &S : llvm::reverse(Steps))
6550 Composite = S.rebuild(
Context, Composite);
6571 E1 = E1Result.
get();
6576 E2 = E2Result.
get();
6597 bool ReturnsRetained;
6602 Expr *Callee =
Call->getCallee()->IgnoreParens();
6605 if (T ==
Context.BoundMemberTy) {
6608 T = BinOp->getRHS()->getType();
6609 else if (
MemberExpr *Mem = dyn_cast<MemberExpr>(Callee))
6610 T = Mem->getMemberDecl()->getType();
6614 T = Ptr->getPointeeType();
6616 T = Ptr->getPointeeType();
6618 T = MemPtr->getPointeeType();
6621 ReturnsRetained = FTy->getExtInfo().getProducesResult();
6626 ReturnsRetained =
true;
6640 D = Send->getMethodDecl();
6641 }
else if (
auto *OL = dyn_cast<ObjCObjectLiteral>(E);
6642 OL && OL->isGlobalAllocation()) {
6644 }
else if (
ObjCBoxedExpr *BoxedExpr = dyn_cast<ObjCBoxedExpr>(E)) {
6645 D = BoxedExpr->getBoxingMethod();
6649 if (ArrayLit->getNumElements() == 0 &&
6650 Context.getLangOpts().ObjCRuntime.hasEmptyCollections())
6653 D = ArrayLit->getArrayWithObjectsMethod();
6655 dyn_cast<ObjCDictionaryLiteral>(E)) {
6658 if (DictLit->getNumElements() == 0 &&
6659 Context.getLangOpts().ObjCRuntime.hasEmptyCollections())
6662 D = DictLit->getDictWithObjectsMethod();
6665 ReturnsRetained = (D && D->
hasAttr<NSReturnsRetainedAttr>());
6670 if (!ReturnsRetained &&
6679 Cleanup.setExprNeedsCleanups(
true);
6681 CastKind ck = (ReturnsRetained ? CK_ARCConsumeObject
6682 : CK_ARCReclaimReturnedObject);
6688 Cleanup.setExprNeedsCleanups(
true);
6696 const RecordType *RT =
nullptr;
6698 switch (T->getTypeClass()) {
6702 case Type::ConstantArray:
6703 case Type::IncompleteArray:
6704 case Type::VariableArray:
6705 case Type::DependentSizedArray:
6726 PDiag(diag::err_access_dtor_temp)
6736 Cleanup.setExprNeedsCleanups(
true);
6757 assert(SubExpr &&
"subexpression can't be null!");
6763 assert(
Cleanup.exprNeedsCleanups() ||
6765 if (!
Cleanup.exprNeedsCleanups())
6779 assert(SubStmt &&
"sub-statement can't be null!");
6783 if (!
Cleanup.exprNeedsCleanups())
6802 "not in a decltype expression");
6819 if (
ParenExpr *PE = dyn_cast<ParenExpr>(E)) {
6823 if (SubExpr.
get() == PE->getSubExpr())
6828 if (BO->getOpcode() == BO_Comma) {
6832 if (RHS.
get() == BO->getRHS())
6835 BO->
getType(), BO->getValueKind(),
6836 BO->getObjectKind(), BO->getOperatorLoc(),
6837 BO->getFPFeatures());
6864 for (
unsigned I = 0, N =
ExprEvalContexts.back().DelayedDecltypeCalls.size();
6867 if (
Call == TopCall)
6877 for (
unsigned I = 0, N =
ExprEvalContexts.back().DelayedDecltypeBinds.size();
6881 if (
Bind == TopBind)
6887 Bind->getType()->getBaseElementTypeUnsafe()->getAsCXXRecordDecl();
6893 PDiag(diag::err_access_dtor_temp)
6894 <<
Bind->getType());
6899 Cleanup.setExprNeedsCleanups(
true);
6909 unsigned SkipStart = OperatorArrows.size(), SkipCount = 0;
6912 if (OperatorArrows.size() > Limit) {
6914 SkipStart = (Limit - 1) / 2 + (Limit - 1) % 2;
6915 SkipCount = OperatorArrows.size() - (Limit - 1);
6918 for (
unsigned I = 0; I < OperatorArrows.size(); ) {
6919 if (I == SkipStart) {
6920 S.
Diag(OperatorArrows[I]->getLocation(),
6921 diag::note_operator_arrows_suppressed)
6925 S.
Diag(OperatorArrows[I]->getLocation(), diag::note_operator_arrow_here)
6926 << OperatorArrows[I]->getCallResultType();
6936 bool &MayBePseudoDestructor) {
6947 MayBePseudoDestructor =
false;
6948 if (BaseType->isDependentType()) {
6952 if (OpKind == tok::arrow)
6954 BaseType = Ptr->getPointeeType();
6957 MayBePseudoDestructor =
true;
6964 if (OpKind == tok::arrow) {
6966 bool NoArrowOperatorFound =
false;
6967 bool FirstIteration =
true;
6972 CTypes.insert(
Context.getCanonicalType(BaseType));
6974 while (BaseType->isRecordType()) {
6975 if (OperatorArrows.size() >=
getLangOpts().ArrowDepth) {
6976 Diag(OpLoc, diag::err_operator_arrow_depth_exceeded)
6977 << StartingType <<
getLangOpts().ArrowDepth <<
Base->getSourceRange();
6979 Diag(OpLoc, diag::note_operator_arrow_depth)
6992 : &NoArrowOperatorFound);
6993 if (
Result.isInvalid()) {
6994 if (NoArrowOperatorFound) {
6995 if (FirstIteration) {
6996 Diag(OpLoc, diag::err_typecheck_member_reference_suggestion)
6997 << BaseType << 1 <<
Base->getSourceRange()
6999 OpKind = tok::period;
7002 Diag(OpLoc, diag::err_typecheck_member_reference_arrow)
7003 << BaseType <<
Base->getSourceRange();
7007 diag::note_member_reference_arrow_from_operator_arrow);
7014 OperatorArrows.push_back(OpCall->getDirectCallee());
7015 BaseType =
Base->getType();
7017 if (!CTypes.insert(CBaseType).second) {
7018 Diag(OpLoc, diag::err_operator_arrow_circular) << StartingType;
7022 FirstIteration =
false;
7025 if (OpKind == tok::arrow) {
7026 if (BaseType->isPointerType())
7027 BaseType = BaseType->getPointeeType();
7028 else if (
auto *AT =
Context.getAsArrayType(BaseType))
7029 BaseType = AT->getElementType();
7035 if (BaseType->isObjCObjectPointerType())
7036 BaseType = BaseType->getPointeeType();
7049 if (!BaseType->isRecordType()) {
7051 MayBePseudoDestructor =
true;
7060 if (!BaseType->isDependentType() &&
7063 diag::err_incomplete_member_access)) {
7078 if (
Base->hasPlaceholderType()) {
7083 ObjectType =
Base->getType();
7091 if (OpKind == tok::arrow) {
7101 ObjectType =
Base->getType();
7106 }
else if (!
Base->isTypeDependent()) {
7108 S.
Diag(OpLoc, diag::err_typecheck_member_reference_suggestion)
7109 << ObjectType <<
true
7114 OpKind = tok::period;
7156 Diag(OpLoc, diag::ext_pseudo_dtor_on_void) <<
Base->getSourceRange();
7158 Diag(OpLoc, diag::err_pseudo_dtor_base_not_scalar)
7159 << ObjectType <<
Base->getSourceRange();
7167 if (DestructedTypeInfo) {
7172 if (!
Context.hasSameUnqualifiedType(DestructedType, ObjectType)) {
7177 Context.hasSameUnqualifiedType(DestructedType,
7180 Diag(OpLoc, diag::err_typecheck_member_reference_suggestion)
7181 << ObjectType << 0 <<
Base->getSourceRange();
7185 *
this, DestructedType))
7190 ObjectType = DestructedType;
7191 OpKind = tok::arrow;
7193 Diag(DestructedTypeStart, diag::err_pseudo_dtor_type_mismatch)
7194 << ObjectType << DestructedType <<
Base->getSourceRange()
7198 DestructedType = ObjectType;
7199 DestructedTypeInfo =
7200 Context.getTrivialTypeSourceInfo(ObjectType, DestructedTypeStart);
7210 Diag(DestructedTypeStart, diag::err_arc_pseudo_dtor_inconstant_quals)
7211 << ObjectType << DestructedType <<
Base->getSourceRange()
7216 DestructedType = ObjectType;
7217 DestructedTypeInfo =
Context.getTrivialTypeSourceInfo(ObjectType,
7218 DestructedTypeStart);
7231 if (ScopeTypeInfo) {
7233 if (!ScopeType->isDependentType() && !ObjectType->
isDependentType() &&
7234 !
Context.hasSameUnqualifiedType(ScopeType, ObjectType)) {
7237 diag::err_pseudo_dtor_type_mismatch)
7238 << ObjectType << ScopeType <<
Base->getSourceRange()
7242 ScopeTypeInfo =
nullptr;
7248 OpKind == tok::arrow, OpLoc,
7268 "Invalid first type name in pseudo-destructor");
7271 "Invalid second type name in pseudo-destructor");
7295 S, &SS,
true,
false, ObjectTypePtrForLookup,
7308 diag::err_pseudo_dtor_destructor_non_type)
7314 DestructedType = ObjectType;
7329 if (T.isInvalid() || !T.get()) {
7331 DestructedType = ObjectType;
7338 if (!DestructedType.
isNull()) {
7339 if (!DestructedTypeInfo)
7340 DestructedTypeInfo =
Context.getTrivialTypeSourceInfo(DestructedType,
7353 S, &SS,
true,
false, ObjectTypePtrForLookup,
7357 diag::err_pseudo_dtor_destructor_non_type)
7379 if (T.isInvalid() || !T.get()) {
7387 if (!ScopeType.isNull() && !ScopeTypeInfo)
7388 ScopeTypeInfo =
Context.getTrivialTypeSourceInfo(ScopeType,
7393 ScopeTypeInfo, CCLoc, TildeLoc,
7432 llvm_unreachable(
"Unsupported type in pseudo destructor");
7458 Operand->HasSideEffects(
Context,
false)) {
7461 Diag(Operand->getExprLoc(), diag::warn_side_effects_unevaluated_context);
7477 bool IsCompoundAssign =
false;
7478 bool isIncrementDecrementUnaryOp =
false;
7480 if (BO->getLHS()->getType()->isDependentType() ||
7481 BO->getRHS()->getType()->isDependentType()) {
7482 if (BO->getOpcode() != BO_Assign)
7484 }
else if (!BO->isAssignmentOp())
7487 IsCompoundAssign = BO->isCompoundAssignmentOp();
7488 LHS = dyn_cast<DeclRefExpr>(BO->getLHS());
7490 if (COCE->getOperator() != OO_Equal)
7492 LHS = dyn_cast<DeclRefExpr>(COCE->getArg(0));
7493 }
else if (
UnaryOperator *UO = dyn_cast<UnaryOperator>(E)) {
7494 if (!UO->isIncrementDecrementOp())
7496 isIncrementDecrementUnaryOp =
true;
7497 LHS = dyn_cast<DeclRefExpr>(UO->getSubExpr());
7507 if ((IsCompoundAssign || isIncrementDecrementUnaryOp) &&
7513 iter->getSecond()--;
7590 diag::err_incomplete_type);
7617 const VarDecl *DefVD =
nullptr;
7651 while (isa_and_nonnull<CapturedDecl>(DC))
7655 "The current call operator must be synchronized with Sema's CurContext");
7676 !IsFullExprInstantiationDependent)
7689 const bool IsVarNeverAConstantExpression =
7691 if (!IsFullExprInstantiationDependent || IsVarNeverAConstantExpression) {
7703 DeclRefType,
nullptr)) {
7709 DeclRefType,
nullptr);
7721 const unsigned FunctionScopeIndexOfCapturableLambda = *Index;
7724 &FunctionScopeIndexOfCapturableLambda);
7733 bool DiscardedValue,
bool IsConstexpr,
7734 bool IsTemplateArgument) {
7743 if (DiscardedValue) {
7766 CheckCompletedExpr(
FullExpr.get(), CC, IsConstexpr);
7815 while (isa_and_nonnull<CapturedDecl>(DC))
7818 if (IsInLambdaDeclContext && CurrentLSI &&
7846 R.suppressDiagnostics();
7848 switch (R.getResultKind()) {
7862 llvm_unreachable(
"Invalid LookupResult Kind!");
7891 "Exactly one of TypeName and TemplateId must be specified.");
7938 auto &II =
Context.Idents.get(
"expr-type");
7959 E,
false, NoexceptLoc,
7991 assert(TC &&
"Type Constraint cannot be null here");
7993 assert(IDC &&
"ImmediatelyDeclaredConstraint can't be null here.");
7997 SubstitutedConstraintExpr =
8005 [&](llvm::raw_ostream &
OS) {
8006 IDC->printPretty(OS, nullptr,
8007 getPrintingPolicy());
8009 IsSimple, NoexceptLoc, ReturnTypeRequirement);
8015 ReturnTypeRequirement, Status,
8016 SubstitutedConstraintExpr);
8025 IsSimple, NoexceptLoc,
8026 ReturnTypeRequirement);
8062 InvalidConstraintEntity,
8078 if (Param->getType()->isVoidType()) {
8079 if (LocalParameters.size() > 1) {
8080 Diag(Param->getBeginLoc(), diag::err_void_only_param);
8081 Param->setType(
Context.IntTy);
8082 }
else if (Param->getIdentifier()) {
8083 Diag(Param->getBeginLoc(), diag::err_param_with_void_type);
8084 Param->setType(
Context.IntTy);
8085 }
else if (Param->getType().hasQualifiers()) {
8086 Diag(Param->getBeginLoc(), diag::err_void_param_qualified);
8088 }
else if (Param->hasDefaultArg()) {
8092 Diag(Param->getDefaultArgRange().getBegin(),
8093 diag::err_requires_expr_local_parameter_default_argument);
8095 }
else if (Param->isExplicitObjectParameter()) {
8106 Diag(Param->getExplicitObjectParamThisLoc(),
8107 diag::err_requires_expr_explicit_object_parameter);
8111 Param->setDeclContext(Body);
8113 if (Param->getIdentifier()) {
8122 assert(
CurContext &&
"DeclContext imbalance!");
8124 assert(
CurContext &&
"Popped translation unit!");
8133 LocalParameters, RParenLoc, Requirements,
Defines the clang::ASTContext interface.
This file provides some common utility functions for processing Lambda related AST Constructs.
Defines a function that returns the minimum OS versions supporting C++17's aligned allocation functio...
static bool CanThrow(Expr *E, ASTContext &Ctx)
static const char * getPlatformName(Darwin::DarwinPlatformKind Platform, Darwin::DarwinEnvironmentKind Environment)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
This file defines the classes used to store parsed information about declaration-specifiers and decla...
Defines the clang::Expr interface and subclasses for C++ expressions.
Defines Expressions and AST nodes for C++2a concepts.
llvm::MachO::Record Record
Implements a partial diagnostic that can be emitted anwyhere in a DiagnosticBuilder stream.
Defines the clang::Preprocessor interface.
@ NotForRedeclaration
The lookup is a reference to this name that is not for the purpose of redeclaring the name.
static std::string toString(const clang::SanitizerSet &Sanitizers)
Produce a string containing comma-separated names of sanitizers in Sanitizers set.
This file declares semantic analysis for CUDA constructs.
static bool doesUsualArrayDeleteWantSize(Sema &S, SourceLocation loc, TypeAwareAllocationMode PassType, QualType allocType)
Determine whether a given type is a class for which 'delete[]' would call a member 'operator delete[]...
static void collectPublicBases(CXXRecordDecl *RD, llvm::DenseMap< CXXRecordDecl *, unsigned > &SubobjectsSeen, llvm::SmallPtrSetImpl< CXXRecordDecl * > &VBases, llvm::SetVector< CXXRecordDecl * > &PublicSubobjectsSeen, bool ParentIsPublic)
static bool ConvertForConditional(Sema &Self, ExprResult &E, QualType T)
Perform an "extended" implicit conversion as returned by TryClassUnification.
static void MaybeDecrementCount(Expr *E, llvm::DenseMap< const VarDecl *, int > &RefsMinusAssignments)
static bool CheckDeleteOperator(Sema &S, SourceLocation StartLoc, SourceRange Range, bool Diagnose, CXXRecordDecl *NamingClass, DeclAccessPair Decl, FunctionDecl *Operator)
static void DiagnoseMismatchedNewDelete(Sema &SemaRef, SourceLocation DeleteLoc, const MismatchingNewDeleteDetector &Detector)
static void getUnambiguousPublicSubobjects(CXXRecordDecl *RD, llvm::SmallVectorImpl< CXXRecordDecl * > &Objects)
static bool isLegalArrayNewInitializer(CXXNewInitializationStyle Style, Expr *Init, bool IsCPlusPlus20)
static void CheckIfAnyEnclosingLambdasMustCaptureAnyPotentialCaptures(Expr *const FE, LambdaScopeInfo *const CurrentLSI, Sema &S)
Check if the current lambda has any potential captures that must be captured by any of its enclosing ...
static void getUuidAttrOfType(Sema &SemaRef, QualType QT, llvm::SmallSetVector< const UuidAttr *, 1 > &UuidAttrs)
Grabs __declspec(uuid()) off a type, or returns 0 if we cannot resolve to a single GUID.
static QualType adjustVectorOrConstantMatrixType(ASTContext &Context, QualType FromTy, QualType ToType, QualType *ElTy=nullptr)
static QualType adjustCVQualifiersForCXXThisWithinLambda(ArrayRef< FunctionScopeInfo * > FunctionScopes, QualType ThisTy, DeclContext *CurSemaContext, ASTContext &ASTCtx)
static bool resolveAllocationOverloadInterior(Sema &S, LookupResult &R, SourceRange Range, ResolveMode Mode, SmallVectorImpl< Expr * > &Args, AlignedAllocationMode &PassAlignment, FunctionDecl *&Operator, OverloadCandidateSet *AlignedCandidates, Expr *AlignArg, bool Diagnose)
static bool FindConditionalOverload(Sema &Self, ExprResult &LHS, ExprResult &RHS, SourceLocation QuestionLoc)
Try to find a common type for two according to C++0x 5.16p5.
static bool TryClassUnification(Sema &Self, Expr *From, Expr *To, SourceLocation QuestionLoc, bool &HaveConversion, QualType &ToType)
Try to convert a type to another according to C++11 5.16p3.
static bool resolveAllocationOverload(Sema &S, LookupResult &R, SourceRange Range, SmallVectorImpl< Expr * > &Args, ImplicitAllocationParameters &IAP, FunctionDecl *&Operator, OverloadCandidateSet *AlignedCandidates, Expr *AlignArg, bool Diagnose)
static UsualDeallocFnInfo resolveDeallocationOverload(Sema &S, LookupResult &R, const ImplicitDeallocationParameters &IDP, SourceLocation Loc, llvm::SmallVectorImpl< UsualDeallocFnInfo > *BestFns=nullptr)
Select the correct "usual" deallocation function to use from a selection of deallocation functions (e...
static bool hasNewExtendedAlignment(Sema &S, QualType AllocType)
Determine whether a type has new-extended alignment.
static ExprResult BuildCXXCastArgument(Sema &S, SourceLocation CastLoc, QualType Ty, CastKind Kind, CXXMethodDecl *Method, DeclAccessPair FoundDecl, bool HadMultipleCandidates, Expr *From)
static bool VariableCanNeverBeAConstantExpression(VarDecl *Var, ASTContext &Context)
static bool canRecoverDotPseudoDestructorCallsOnPointerObjects(Sema &SemaRef, QualType DestructedType)
Check if it's ok to try and recover dot pseudo destructor calls on pointer objects.
static bool CheckArrow(Sema &S, QualType &ObjectType, Expr *&Base, tok::TokenKind &OpKind, SourceLocation OpLoc)
static bool resolveBuiltinNewDeleteOverload(Sema &S, CallExpr *TheCall, bool IsDelete, FunctionDecl *&Operator)
static bool isValidVectorForConditionalCondition(ASTContext &Ctx, QualType CondTy)
static void LookupGlobalDeallocationFunctions(Sema &S, SourceLocation Loc, LookupResult &FoundDelete, DeallocLookupMode Mode, DeclarationName Name)
static void noteOperatorArrows(Sema &S, ArrayRef< FunctionDecl * > OperatorArrows)
Note a set of 'operator->' functions that were used for a member access.
static void buildLambdaThisCaptureFixit(Sema &Sema, LambdaScopeInfo *LSI)
static bool checkIncompatibleOBTConversion(Sema &S, QualType FromType, QualType ToType, Expr *From)
Check if an integral conversion involves incompatible overflow behavior types.
static bool isNonPlacementDeallocationFunction(Sema &S, FunctionDecl *FD)
Determine whether the given function is a non-placement deallocation function.
This file declares semantic analysis for HLSL constructs.
This file provides some common utility functions for processing Lambdas.
This file declares semantic analysis for Objective-C.
This file declares semantic analysis functions specific to PowerPC.
static QualType getPointeeType(const MemRegion *R)
Defines the clang::TokenKind enum and support functions.
Defines the clang::TypeLoc interface and its subclasses.
C Language Family Type Representation.
a trap message and trap category.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
TranslationUnitDecl * getTranslationUnitDecl() const
DeclarationNameTable DeclarationNames
QualType getPointerType(QualType T) const
Return the uniqued reference to the type for a pointer to the specified type.
QualType getConstantArrayType(QualType EltTy, const llvm::APInt &ArySize, const Expr *SizeExpr, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return the unique reference to the type for a constant array of the specified element type.
const LangOptions & getLangOpts() const
QualType getBaseElementType(const ArrayType *VAT) const
Return the innermost element type of an array type.
QualType getQualifiedType(SplitQualType split) const
Un-split a SplitQualType.
QualType getObjCObjectPointerType(QualType OIT) const
Return a ObjCObjectPointerType type for the given ObjCObjectType.
unsigned getTypeAlignIfKnown(QualType T, bool NeedsPreferredAlignment=false) const
Return the alignment of a type, in bits, or 0 if the type is incomplete and we cannot determine the a...
QualType getMemberPointerType(QualType T, NestedNameSpecifier Qualifier, const CXXRecordDecl *Cls) const
Return the uniqued reference to the type for a member pointer to the specified type in the specified ...
QualType getSizeType() const
Return the unique type for "size_t" (C99 7.17), defined in <stddef.h>.
const TargetInfo & getTargetInfo() const
CanQualType getCanonicalTagType(const TagDecl *TD) const
static bool hasSameUnqualifiedType(QualType T1, QualType T2)
Determine whether the given types are equivalent after cvr-qualifiers have been removed.
QualType getIncompleteArrayType(QualType EltTy, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return a unique reference to the type for an incomplete array of the specified element type.
Represents a constant array type that does not decay to a pointer when used as a function parameter.
QualType getConstantArrayType(const ASTContext &Ctx) const
Represents an array type, per C99 6.7.5.2 - Array Declarators.
QualType getElementType() const
QualType getValueType() const
Gets the type contained by this atomic type, i.e.
Attr - This represents one attribute.
A builtin binary operation expression such as "x + y" or "x <= y".
static BinaryOperator * Create(const ASTContext &C, Expr *lhs, Expr *rhs, Opcode opc, QualType ResTy, ExprValueKind VK, ExprObjectKind OK, SourceLocation opLoc, FPOptionsOverride FPFeatures)
This class is used for builtin types like 'int'.
Represents a base class of a C++ class.
Represents binding an expression to a temporary.
static CXXBindTemporaryExpr * Create(const ASTContext &C, CXXTemporary *Temp, Expr *SubExpr)
const Expr * getSubExpr() const
A boolean literal, per ([C++ lex.bool] Boolean literals).
Represents a call to a C++ constructor.
Represents a C++ constructor within a class.
Represents a C++ conversion function within a class.
FieldDecl * getMember() const
If this is a member initializer, returns the declaration of the non-static data member being initiali...
Expr * getInit() const
Get the initializer.
Represents a delete expression for memory deallocation and destructor calls, e.g.
SourceLocation getBeginLoc() const
Represents a C++ destructor within a class.
static CXXFunctionalCastExpr * Create(const ASTContext &Context, QualType T, ExprValueKind VK, TypeSourceInfo *Written, CastKind Kind, Expr *Op, const CXXCastPath *Path, FPOptionsOverride FPO, SourceLocation LPLoc, SourceLocation RPLoc)
Represents a static or instance method of a struct/union/class.
const CXXRecordDecl * getParent() const
Return the parent of this method declaration, which is the class in which this method is defined.
QualType getFunctionObjectParameterType() const
static CXXNewExpr * Create(const ASTContext &Ctx, bool IsGlobalNew, FunctionDecl *OperatorNew, FunctionDecl *OperatorDelete, const ImplicitAllocationParameters &IAP, bool UsualArrayDeleteWantsSize, ArrayRef< Expr * > PlacementArgs, SourceRange TypeIdParens, std::optional< Expr * > ArraySize, CXXNewInitializationStyle InitializationStyle, Expr *Initializer, QualType Ty, TypeSourceInfo *AllocatedTypeInfo, SourceRange Range, SourceRange DirectInitRange)
Create a c++ new expression.
Represents a C++11 noexcept expression (C++ [expr.unary.noexcept]).
The null pointer literal (C++11 [lex.nullptr])
A call to an overloaded operator written using operator syntax.
Represents a C++ pseudo-destructor (C++ [expr.pseudo]).
Represents a C++ struct/union/class.
static CXXRecordDecl * Create(const ASTContext &C, TagKind TK, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, CXXRecordDecl *PrevDecl=nullptr)
bool isPolymorphic() const
Whether this class is polymorphic (C++ [class.virtual]), which means that the class contains or inher...
capture_const_range captures() const
bool isAbstract() const
Determine whether this class has a pure virtual function.
bool hasIrrelevantDestructor() const
Determine whether this class has a destructor which has no semantic effect.
bool hasDefinition() const
CXXDestructorDecl * getDestructor() const
Returns the destructor decl for this class.
CXXMethodDecl * getLambdaCallOperator() const
Retrieve the lambda call operator of the closure type if this is a closure type.
An expression "T()" which creates an rvalue of a non-class type T.
Represents a C++ nested-name-specifier or a global scope specifier.
bool isNotEmpty() const
A scope specifier is present, but may be valid or invalid.
SourceLocation getLastQualifierNameLoc() const
Retrieve the location of the name in the last qualifier in this nested name specifier.
SourceLocation getEndLoc() const
SourceRange getRange() const
bool isSet() const
Deprecated.
NestedNameSpecifier getScopeRep() const
Retrieve the representation of the nested-name-specifier.
NestedNameSpecifierLoc getWithLocInContext(ASTContext &Context) const
Retrieve a nested-name-specifier with location information, copied into the given AST context.
bool isInvalid() const
An error occurred during parsing of the scope specifier.
void Adopt(NestedNameSpecifierLoc Other)
Adopt an existing nested-name-specifier (with source-range information).
Represents a C++ temporary.
void setDestructor(const CXXDestructorDecl *Dtor)
static CXXTemporary * Create(const ASTContext &C, const CXXDestructorDecl *Destructor)
Represents the this expression in C++.
static CXXThisExpr * Create(const ASTContext &Ctx, SourceLocation L, QualType Ty, bool IsImplicit)
A C++ throw-expression (C++ [except.throw]).
A C++ typeid expression (C++ [expr.typeid]), which gets the type_info that corresponds to the supplie...
static CXXUnresolvedConstructExpr * Create(const ASTContext &Context, QualType T, TypeSourceInfo *TSI, SourceLocation LParenLoc, ArrayRef< Expr * > Args, SourceLocation RParenLoc, bool IsListInit)
A Microsoft C++ __uuidof expression, which gets the _GUID that corresponds to the supplied type or ex...
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
void setArg(unsigned Arg, Expr *ArgExpr)
setArg - Set the specified argument.
unsigned getNumArgs() const
getNumArgs - Return the number of actual arguments to this call.
CharUnits - This is an opaque type for sizes expressed in character units.
QuantityType getQuantity() const
getQuantity - Get the raw integer representation of this quantity.
Declaration of a class template.
Complex values, per C99 6.2.5p11.
CompoundStmt - This represents a group of statements like { stmt stmt }.
static CompoundStmt * Create(const ASTContext &C, ArrayRef< Stmt * > Stmts, FPOptionsOverride FPFeatures, SourceLocation LB, SourceLocation RB)
Represents the specialization of a concept - evaluates to a prvalue of type bool.
bool isSatisfied() const
Whether or not the concept with the given arguments was satisfied when the expression was created.
const ASTConstraintSatisfaction & getSatisfaction() const
Get elaborated satisfaction info about the template arguments' satisfaction of the named concept.
Represents the canonical version of C arrays with a specified constant size.
static unsigned getNumAddressingBits(const ASTContext &Context, QualType ElementType, const llvm::APInt &NumElements)
Determine the number of bits required to address a member of.
static unsigned getMaxSizeBits(const ASTContext &Context)
Determine the maximum number of active bits that an array's size can require, which limits the maximu...
Represents a concrete matrix type with constant number of rows and columns.
The result of a constraint satisfaction check, containing the necessary information to diagnose an un...
A POD class for pairing a NamedDecl* with an access specifier.
static DeclAccessPair make(NamedDecl *D, AccessSpecifier AS)
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
DeclContext * getParent()
getParent - Returns the containing DeclContext.
lookup_result::iterator lookup_iterator
DeclContextLookupResult lookup_result
bool isDependentContext() const
Determines whether this context is dependent on a template parameter.
lookup_result lookup(DeclarationName Name) const
lookup - Find the declarations (if any) with the given Name in this context.
void addDecl(Decl *D)
Add the declaration D into this context.
A reference to a declared variable, function, enum, etc.
Captures information about "declaration specifiers".
bool hasAutoTypeSpec() const
Expr * getPackIndexingExpr() const
TST getTypeSpecType() const
SourceLocation getBeginLoc() const LLVM_READONLY
static const TST TST_typename_pack_indexing
ParsedType getRepAsType() const
SourceLocation getEllipsisLoc() const
Expr * getRepAsExpr() const
static const TST TST_decltype
SourceLocation getTypeSpecTypeLoc() const
static const TST TST_decltype_auto
static const TST TST_error
SourceRange getTypeofParensRange() const
Decl - This represents one declaration (or definition), e.g.
bool isImplicit() const
isImplicit - Indicates whether the declaration was implicitly generated by the implementation.
void setInvalidDecl(bool Invalid=true)
setInvalidDecl - Indicates the Decl had a semantic error.
FunctionDecl * getAsFunction() LLVM_READONLY
Returns the function itself, or the templated function if this is a function template.
bool isInvalidDecl() const
SourceLocation getLocation() const
void setLocalOwningModule(Module *M)
void setImplicit(bool I=true)
DeclContext * getDeclContext()
@ ReachableWhenImported
This declaration has an owning module, and is visible to lookups that occurs within that module.
void setModuleOwnershipKind(ModuleOwnershipKind MOK)
Set whether this declaration is hidden from name lookup.
The name of a declaration.
bool isDependentName() const
Determines whether the name itself is dependent, e.g., because it involves a C++ type that is itself ...
bool isAnyOperatorDelete() const
bool isAnyOperatorNew() const
SourceLocation getBeginLoc() const LLVM_READONLY
Information about one declarator, including the parsed type information and the identifier.
const DeclaratorChunk & getTypeObject(unsigned i) const
Return the specified TypeInfo from this declarator.
const DeclSpec & getDeclSpec() const
getDeclSpec - Return the declaration-specifier that this declarator was declared with.
SourceLocation getEndLoc() const LLVM_READONLY
void DropFirstTypeObject()
unsigned getNumTypeObjects() const
Return the number of types applied to this declarator.
bool isInvalidType() const
SourceRange getSourceRange() const LLVM_READONLY
Get the source range that spans this declarator.
void setRParenLoc(SourceLocation Loc)
void setDecltypeLoc(SourceLocation Loc)
A little helper class (which is basically a smart pointer that forwards info from DiagnosticsEngine a...
DiagnosticOptions & getDiagnosticOptions() const
Retrieve the diagnostic options.
bool isComplete() const
Returns true if this can be considered a complete type.
static EnumDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, EnumDecl *PrevDecl, bool IsScoped, bool IsScopedUsingClassTag, bool IsFixed)
bool isFixed() const
Returns true if this is an Objective-C, C++11, or Microsoft-style enumeration with a fixed underlying...
static ExprWithCleanups * Create(const ASTContext &C, EmptyShell empty, unsigned numObjects)
This represents one expression.
bool isReadIfDiscardedInCPlusPlus11() const
Determine whether an lvalue-to-rvalue conversion should implicitly be applied to this expression if i...
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.
Expr * IgnoreParenImpCasts() LLVM_READONLY
Skip past any parentheses and implicit casts which might surround this expression until reaching a fi...
Expr * IgnoreParens() LLVM_READONLY
Skip past any parentheses which might surround this expression until reaching a fixed point.
static bool hasAnyTypeDependentArguments(ArrayRef< Expr * > Exprs)
hasAnyTypeDependentArguments - Determines if any of the expressions in Exprs is type-dependent.
@ NPC_ValueDependentIsNull
Specifies that a value-dependent expression of integral or dependent type should be considered a null...
ExprObjectKind getObjectKind() const
getObjectKind - The object kind that this expression produces.
bool HasSideEffects(const ASTContext &Ctx, bool IncludePossibleEffects=true) const
HasSideEffects - This routine returns true for all those expressions which have any effect other than...
bool isInstantiationDependent() const
Whether this expression is instantiation-dependent, meaning that it depends in some way on.
NullPointerConstantKind isNullPointerConstant(ASTContext &Ctx, NullPointerConstantValueDependence NPC) const
isNullPointerConstant - C99 6.3.2.3p3 - Test if this reduces down to a Null pointer constant.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
bool refersToBitField() const
Returns true if this expression is a gl-value that potentially refers to a bit-field.
Classification Classify(ASTContext &Ctx) const
Classify - Classify this expression according to the C++11 expression taxonomy.
bool isOrdinaryOrBitFieldObject() const
bool hasPlaceholderType() const
Returns whether this expression has a placeholder type.
static ExprValueKind getValueKindForType(QualType T)
getValueKindForType - Given a formal return or parameter type, give its value kind.
Represents difference between two FPOptions values.
Annotates a diagnostic with some code that should be inserted, removed, or replaced to fix the proble...
static FixItHint CreateReplacement(CharSourceRange RemoveRange, StringRef Code)
Create a code modification hint that replaces the given source range with the given code string.
static FixItHint 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.
FullExpr - Represents a "full-expression" node.
Represents a function declaration or definition.
static constexpr unsigned RequiredTypeAwareDeleteParameterCount
Count of mandatory parameters for type aware operator delete.
static FunctionDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation NLoc, DeclarationName N, QualType T, TypeSourceInfo *TInfo, StorageClass SC, bool UsesFPIntrin=false, bool isInlineSpecified=false, bool hasWrittenPrototype=true, ConstexprSpecKind ConstexprKind=ConstexprSpecKind::Unspecified, const AssociatedConstraint &TrailingRequiresClause={})
const ParmVarDecl * getParamDecl(unsigned i) const
bool isFunctionTemplateSpecialization() const
Determine whether this function is a function template specialization.
bool isThisDeclarationADefinition() const
Returns whether this specific declaration of the function is also a definition that does not contain ...
StringLiteral * getDeletedMessage() const
Get the message that indicates why this function was deleted.
QualType getReturnType() const
bool isTrivial() const
Whether this function is "trivial" in some specialized C++ senses.
bool isReplaceableGlobalAllocationFunction(UnsignedOrNone *AlignmentParam=nullptr, bool *IsNothrow=nullptr) const
Determines whether this function is one of the replaceable global allocation functions: void *operato...
bool isDeleted() const
Whether this function has been deleted.
bool isTypeAwareOperatorNewOrDelete() const
Determine whether this is a type aware operator new or delete.
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
unsigned getNumParams() const
Return the number of parameters this function must have based on its FunctionType.
bool isDefined(const FunctionDecl *&Definition, bool CheckForPendingFriendDefinition=false) const
Returns true if the function has a definition that does not need to be instantiated.
Represents a prototype with parameter type info, e.g.
QualType getParamType(unsigned i) const
Declaration of a template function.
ExtInfo withCallingConv(CallingConv cc) const
ExtInfo withNoReturn(bool noReturn) const
FunctionType - C99 6.7.5.3 - Function Declarators.
One of these records is kept for each identifier that is lexed.
ReservedIdentifierStatus isReserved(const LangOptions &LangOpts) const
Determine whether this is a name reserved for the implementation (C99 7.1.3, C++ [lib....
ReservedLiteralSuffixIdStatus isReservedLiteralSuffixId() const
Determine whether this is a name reserved for future standardization or the implementation (C++ [usrl...
StringRef getName() const
Return the actual identifier string.
ImplicitCastExpr - Allows us to explicitly represent implicit type conversions, which have no direct ...
static ImplicitCastExpr * Create(const ASTContext &Context, QualType T, CastKind Kind, Expr *Operand, const CXXCastPath *BasePath, ExprValueKind Cat, FPOptionsOverride FPO)
ImplicitConversionSequence - Represents an implicit conversion sequence, which may be a standard conv...
@ 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...
void DiagnoseAmbiguousConversion(Sema &S, SourceLocation CaretLoc, const PartialDiagnostic &PDiag) const
Diagnoses an ambiguous conversion.
Describes the kind of initialization being performed, along with location information for tokens rela...
static InitializationKind CreateDefault(SourceLocation InitLoc)
Create a default initialization.
static InitializationKind CreateDirect(SourceLocation InitLoc, SourceLocation LParenLoc, SourceLocation RParenLoc)
Create a direct initialization.
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.
Describes the sequence of initializations required to initialize a given object or reference with a s...
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.
bool isAmbiguous() const
Determine whether this initialization failed due to an ambiguity.
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.
bool isDirectReferenceBinding() const
Determine whether this initialization is a direct reference binding (C++ [dcl.init....
Describes an entity that is being initialized.
static InitializedEntity InitializeException(SourceLocation ThrowLoc, QualType Type)
Create the initialization entity for an exception object.
static InitializedEntity InitializeTemporary(QualType Type)
Create the initialization entity for a temporary.
static InitializedEntity InitializeParameter(ASTContext &Context, ParmVarDecl *Parm)
Create the initialization entity for a parameter.
static InitializedEntity InitializeNew(SourceLocation NewLoc, QualType Type, bool VariableLengthArrayNew)
Create the initialization entity for an object allocated via new.
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'.
static SourceLocation findLocationAfterToken(SourceLocation loc, tok::TokenKind TKind, const SourceManager &SM, const LangOptions &LangOpts, bool SkipTrailingWhitespaceAndNewLine)
Checks that the given token is the first token that occurs after the given location (this excludes co...
A stack-allocated class that identifies which local variable declaration instantiations are present i...
A class for iterating through a result set and possibly filtering out results.
void erase()
Erase the last element returned from this iterator.
Represents the results of name lookup.
LLVM_ATTRIBUTE_REINITIALIZES void clear()
Clears out any current state.
bool empty() const
Return true if no decls were found.
Filter makeFilter()
Create a filter for this result set.
CXXRecordDecl * getNamingClass() const
Returns the 'naming class' for this lookup, i.e.
UnresolvedSetImpl::iterator iterator
void suppressDiagnostics()
Suppress the diagnostics that would normally fire because of this lookup.
MemberExpr - [C99 6.5.2.3] Structure and Union Members.
ValueDecl * getMemberDecl() const
Retrieve the member declaration to which this expression refers.
A pointer to member type per C++ 8.3.3 - Pointers to members.
CXXRecordDecl * getMostRecentCXXRecordDecl() const
Note: this can trigger extra deserialization when external AST sources are used.
QualType getPointeeType() const
Data structure that captures multiple levels of template argument lists for use in template instantia...
void addOuterRetainedLevels(unsigned Num)
This represents a decl that may have a name.
NamedDecl * getUnderlyingDecl()
Looks through UsingDecls and ObjCCompatibleAliasDecls for the underlying named decl.
IdentifierInfo * getIdentifier() const
Get the identifier that names this declaration, if there is one.
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
std::string getNameAsString() const
Get a human-readable name for the declaration, even if it is one of the special kinds of names (C++ c...
A C++ nested-name-specifier augmented with source location information.
NamespaceAndPrefixLoc getAsNamespaceAndPrefix() const
TypeLoc getAsTypeLoc() const
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
const Type * getAsType() const
@ MicrosoftSuper
Microsoft's '__super' specifier, stored as a CXXRecordDecl* of the class it appeared in.
@ Global
The global specifier '::'. There is no stored value.
@ Type
A type, stored as a Type*.
@ Namespace
A namespace-like entity, stored as a NamespaceBaseDecl*.
ObjCArrayLiteral - used for objective-c array containers; as in: @["Hello", NSApp,...
ObjCBoxedExpr - used for generalized expression boxing.
ObjCDictionaryLiteral - AST node to represent objective-c dictionary literals; as in:"name" : NSUserN...
An expression that sends a message to the given Objective-C object or class.
ObjCMethodDecl - Represents an instance or class method declaration.
ObjCMethodFamily getMethodFamily() const
Determines the family of this method.
Represents a pointer to an Objective C object.
QualType getPointeeType() const
Gets the type pointed to by this ObjC pointer.
static OpaquePtr getFromOpaquePtr(void *P)
static OpaquePtr make(QualType P)
OpaqueValueExpr - An expression referring to an opaque object of a fixed type and value class.
OverloadCandidateSet - A set of overload candidates, used in C++ overload resolution (C++ 13....
@ CSK_Normal
Normal lookup.
@ CSK_Operator
C++ [over.match.oper]: Lookup of operator function candidates in a call using operator syntax.
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;})
void setEllipsisLoc(SourceLocation Loc)
ParenExpr - This represents a parenthesized expression, e.g.
Represents a parameter to a function.
static ParmVarDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, const IdentifierInfo *Id, QualType T, TypeSourceInfo *TInfo, StorageClass S, Expr *DefArg)
bool isEquivalent(PointerAuthQualifier Other) const
PointerType - C99 6.7.5.1 - Pointer Declarators.
QualType getPointeeType() const
Stores the type being destroyed by a pseudo-destructor expression.
TypeSourceInfo * getTypeSourceInfo() const
A (possibly-)qualified type.
bool isVolatileQualified() const
Determine whether this type is volatile-qualified.
QualType getNonLValueExprType(const ASTContext &Context) const
Determine the type of a (typically non-lvalue) expression with the specified result type.
QualType withConst() const
void addConst()
Add the const type qualifier to this QualType.
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.
void getAsStringInternal(std::string &Str, const PrintingPolicy &Policy) const
QualType getNonReferenceType() const
If Type is a reference type (e.g., const int&), returns the type that the reference refers to ("const...
QualType getCanonicalType() const
QualType getUnqualifiedType() const
Retrieve the unqualified variant of the given type, removing as little sugar as possible.
bool isWebAssemblyReferenceType() const
Returns true if it is a WebAssembly Reference Type.
bool isConstQualified() const
Determine whether this type is const-qualified.
DestructionKind isDestructedType() const
Returns a nonzero value if objects of this type require non-trivial work to clean up after.
unsigned getCVRQualifiers() const
Retrieve the set of CVR (const-volatile-restrict) qualifiers applied to this type.
static std::string getAsString(SplitQualType split, const PrintingPolicy &Policy)
bool isAtLeastAsQualifiedAs(QualType Other, const ASTContext &Ctx) const
Determine whether this type is at least as qualified as the other given type, requiring exact equalit...
The collection of all-type qualifiers we support.
void removeCVRQualifiers(unsigned mask)
@ OCL_None
There is no lifetime qualification on this type.
bool hasCVRQualifiers() const
bool hasUnaligned() 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.
void setAddressSpace(LangAS space)
unsigned getCVRUQualifiers() const
PointerAuthQualifier getPointerAuth() const
void setObjCGCAttr(GC type)
ObjCLifetime getObjCLifetime() const
static Qualifiers fromCVRUMask(unsigned CVRU)
LangAS getAddressSpace() const
void setPointerAuth(PointerAuthQualifier Q)
static std::string getAddrSpaceAsString(LangAS AS)
void setObjCLifetime(ObjCLifetime type)
Represents a struct/union/class.
Represents the body of a requires-expression.
static RequiresExprBodyDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc)
static RequiresExpr * Create(ASTContext &C, SourceLocation RequiresKWLoc, RequiresExprBodyDecl *Body, SourceLocation LParenLoc, ArrayRef< ParmVarDecl * > LocalParameters, SourceLocation RParenLoc, ArrayRef< concepts::Requirement * > Requirements, SourceLocation RBraceLoc)
Scope - A scope is a transient data structure that is used while parsing the program.
unsigned getFlags() const
getFlags - Return the flags for this scope.
bool isDeclScope(const Decl *D) const
isDeclScope - Return true if this is the scope that the specified decl is declared in.
DeclContext * getEntity() const
Get the entity corresponding to this scope.
const Scope * getParent() const
getParent - Return the scope that this is nested in.
@ BlockScope
This is a scope that corresponds to a block/closure object.
@ ClassScope
The scope of a struct/union/class definition.
@ TryScope
This is the scope of a C++ try statement.
@ FnScope
This indicates that the scope corresponds to a function, which means that labels are set here.
@ ObjCMethodScope
This scope corresponds to an Objective-C method body.
A generic diagnostic builder for errors which may or may not be deferred.
PartialDiagnostic PDiag(unsigned DiagID=0)
Build a partial diagnostic.
SemaDiagnosticBuilder Diag(SourceLocation Loc, unsigned DiagID)
Emit a diagnostic.
CUDAFunctionTarget CurrentTarget()
Gets the CUDA target for the current context.
SemaDiagnosticBuilder DiagIfDeviceCode(SourceLocation Loc, unsigned DiagID)
Creates a SemaDiagnosticBuilder that emits the diagnostic if the current context is "used as device c...
void EraseUnwantedMatches(const FunctionDecl *Caller, llvm::SmallVectorImpl< std::pair< DeclAccessPair, FunctionDecl * > > &Matches)
Finds a function in Matches with highest calling priority from Caller context and erases all function...
CUDAFunctionPreference IdentifyPreference(const FunctionDecl *Caller, const FunctionDecl *Callee)
Identifies relative preference of a given Caller/Callee combination, based on their host/device attri...
QualType FindCompositeObjCPointerType(ExprResult &LHS, ExprResult &RHS, SourceLocation QuestionLoc)
FindCompositeObjCPointerType - Helper method to find composite type of two objective-c pointer types ...
void EmitRelatedResultTypeNote(const Expr *E)
If the given expression involves a message send to a method with a related result type,...
CastKind PrepareCastToObjCObjectPointer(ExprResult &E)
Prepare a conversion of the given expression to an ObjC object pointer type.
ARCConversionResult CheckObjCConversion(SourceRange castRange, QualType castType, Expr *&op, CheckedConversionKind CCK, bool Diagnose=true, bool DiagnoseCFAudited=false, BinaryOperatorKind Opc=BO_PtrMemD, bool IsReinterpretCast=false)
Checks for invalid conversions and casts between retainable pointers and other pointer kinds for ARC ...
bool CheckPPCMMAType(QualType Type, SourceLocation TypeLoc)
CXXThisScopeRAII(Sema &S, Decl *ContextDecl, Qualifiers CXXThisTypeQuals, bool Enabled=true)
Introduce a new scope where 'this' may be allowed (when enabled), using the given declaration (which ...
Abstract base class used to perform a contextual implicit conversion from an expression to any type p...
Sema - This implements semantic analysis and AST building for C.
void DeclareGlobalNewDelete()
DeclareGlobalNewDelete - Declare the global forms of operator new and delete.
IfExistsResult CheckMicrosoftIfExistsSymbol(Scope *S, CXXScopeSpec &SS, const DeclarationNameInfo &TargetNameInfo)
ParsedType CreateParsedType(QualType T, TypeSourceInfo *TInfo)
Package the given type and TSI into a ParsedType.
FunctionDecl * FindUsualDeallocationFunction(SourceLocation StartLoc, ImplicitDeallocationParameters, DeclarationName Name, bool Diagnose=true)
ExprResult ActOnCXXTypeid(SourceLocation OpLoc, SourceLocation LParenLoc, bool isType, void *TyOrExpr, SourceLocation RParenLoc)
ActOnCXXTypeid - Parse typeid( something ).
QualType getCurrentThisType()
Try to retrieve the type of the 'this' pointer.
ExprResult ActOnCXXUuidof(SourceLocation OpLoc, SourceLocation LParenLoc, bool isType, void *TyOrExpr, SourceLocation RParenLoc)
ActOnCXXUuidof - Parse __uuidof( something ).
Scope * getCurScope() const
Retrieve the parser's current scope.
QualType CheckVectorConditionalTypes(ExprResult &Cond, ExprResult &LHS, ExprResult &RHS, SourceLocation QuestionLoc)
bool checkArrayElementAlignment(QualType EltTy, SourceLocation Loc)
ExprResult IgnoredValueConversions(Expr *E)
IgnoredValueConversions - Given that an expression's result is syntactically ignored,...
bool RequireCompleteSizedType(SourceLocation Loc, QualType T, unsigned DiagID, const Ts &...Args)
@ LookupOrdinaryName
Ordinary name lookup, which finds ordinary names (functions, variables, typedefs, etc....
@ LookupDestructorName
Look up a name following ~ in a destructor name.
@ LookupTagName
Tag name lookup, which finds the names of enums, classes, structs, and unions.
@ LookupAnyName
Look up any declaration with any name.
void DiagnoseSentinelCalls(const NamedDecl *D, SourceLocation Loc, ArrayRef< Expr * > Args)
DiagnoseSentinelCalls - This routine checks whether a call or message-send is to a declaration with t...
ExprResult ActOnNoexceptExpr(SourceLocation KeyLoc, SourceLocation LParen, Expr *Operand, SourceLocation RParen)
bool BuildTypeConstraint(const CXXScopeSpec &SS, TemplateIdAnnotation *TypeConstraint, TemplateTypeParmDecl *ConstrainedParameter, SourceLocation EllipsisLoc, bool AllowUnexpandedPack)
bool FindDeallocationFunction(SourceLocation StartLoc, CXXRecordDecl *RD, DeclarationName Name, FunctionDecl *&Operator, ImplicitDeallocationParameters, bool Diagnose=true)
bool CheckCXXThisType(SourceLocation Loc, QualType Type)
Check whether the type of 'this' is valid in the current context.
QualType UsualArithmeticConversions(ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, ArithConvKind ACK)
UsualArithmeticConversions - Performs various conversions that are common to binary operators (C99 6....
QualType tryBuildStdTypeIdentity(QualType Type, SourceLocation Loc)
Looks for the std::type_identity template and instantiates it with Type, or returns a null type if ty...
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 ...
ExprResult CheckBooleanCondition(SourceLocation Loc, Expr *E, bool IsConstexpr=false)
CheckBooleanCondition - Diagnose problems involving the use of the given expression as a boolean cond...
@ Boolean
A boolean condition, from 'if', 'while', 'for', or 'do'.
@ Switch
An integral condition for a 'switch' statement.
@ ConstexprIf
A constant boolean condition from 'if constexpr'.
bool RequireCompleteDeclContext(CXXScopeSpec &SS, DeclContext *DC)
Require that the context specified by SS be complete.
bool GatherArgumentsForCall(SourceLocation CallLoc, FunctionDecl *FDecl, const FunctionProtoType *Proto, unsigned FirstParam, ArrayRef< Expr * > Args, SmallVectorImpl< Expr * > &AllArgs, VariadicCallType CallType=VariadicCallType::DoesNotApply, bool AllowExplicit=false, bool IsListInitialization=false)
GatherArgumentsForCall - Collector argument expressions for various form of call prototypes.
SmallVector< sema::FunctionScopeInfo *, 4 > FunctionScopes
Stack containing information about each of the nested function, block, and method scopes that are cur...
@ Ref_Compatible
Ref_Compatible - The two types are reference-compatible.
ExprResult BuildCXXFunctionalCastExpr(TypeSourceInfo *TInfo, QualType Type, SourceLocation LParenLoc, Expr *CastExpr, SourceLocation RParenLoc)
bool CheckCXXThisCapture(SourceLocation Loc, bool Explicit=false, bool BuildAndDiagnose=true, const unsigned *const FunctionScopeIndexToStopAt=nullptr, bool ByCopy=false)
Make sure the value of 'this' is actually available in the current context, if it is a potentially ev...
ExprResult MaybeBindToTemporary(Expr *E)
MaybeBindToTemporary - If the passed in expression has a record type with a non-trivial destructor,...
void MarkCaptureUsedInEnclosingContext(ValueDecl *Capture, SourceLocation Loc, unsigned CapturingScopeIndex)
ExprResult ActOnStartCXXMemberReference(Scope *S, Expr *Base, SourceLocation OpLoc, tok::TokenKind OpKind, ParsedType &ObjectType, bool &MayBePseudoDestructor)
QualType CheckVectorOperands(ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign, bool AllowBothBool, bool AllowBoolConversion, bool AllowBoolOperation, bool ReportInvalid)
type checking for vector binary operators.
concepts::Requirement * ActOnSimpleRequirement(Expr *E)
FPOptionsOverride CurFPFeatureOverrides()
concepts::Requirement * ActOnCompoundRequirement(Expr *E, SourceLocation NoexceptLoc)
ExprResult BuildOverloadedArrowExpr(Scope *S, Expr *Base, SourceLocation OpLoc, bool *NoArrowOperatorFound=nullptr)
BuildOverloadedArrowExpr - Build a call to an overloaded operator-> (if one exists),...
FunctionDecl * FindDeallocationFunctionForDestructor(SourceLocation StartLoc, CXXRecordDecl *RD, bool Diagnose, bool LookForGlobal, DeclarationName Name)
concepts::Requirement::SubstitutionDiagnostic * createSubstDiagAt(SourceLocation Location, EntityPrinter Printer)
create a Requirement::SubstitutionDiagnostic with only a SubstitutedEntity and DiagLoc using ASTConte...
FunctionDecl * getCurFunctionDecl(bool AllowLambda=false) const
Returns a pointer to the innermost enclosing function, or nullptr if the current context is not insid...
ExprResult PerformContextualImplicitConversion(SourceLocation Loc, Expr *FromE, ContextualImplicitConverter &Converter)
Perform a contextual implicit conversion.
ExprResult CheckUnevaluatedOperand(Expr *E)
ExprResult ActOnCXXDelete(SourceLocation StartLoc, bool UseGlobal, bool ArrayForm, Expr *Operand)
ActOnCXXDelete - Parsed a C++ 'delete' expression (C++ 5.3.5), as in:
void DiagnoseExceptionUse(SourceLocation Loc, bool IsTry)
ExprResult CheckSwitchCondition(SourceLocation SwitchLoc, Expr *Cond)
void diagnoseNullableToNonnullConversion(QualType DstType, QualType SrcType, SourceLocation Loc)
Warn if we're implicitly casting from a _Nullable pointer type to a _Nonnull one.
ExprResult ActOnCXXNullPtrLiteral(SourceLocation Loc)
ActOnCXXNullPtrLiteral - Parse 'nullptr'.
ExprResult BuildCXXTypeId(QualType TypeInfoType, SourceLocation TypeidLoc, TypeSourceInfo *Operand, SourceLocation RParenLoc)
Build a C++ typeid expression with a type operand.
bool DiagnoseUseOfDecl(NamedDecl *D, ArrayRef< SourceLocation > Locs, const ObjCInterfaceDecl *UnknownObjCClass=nullptr, bool ObjCPropertyAccess=false, bool AvoidPartialAvailabilityChecks=false, ObjCInterfaceDecl *ClassReceiver=nullptr, bool SkipTrailingRequiresClause=false)
Determine whether the use of this declaration is valid, and emit any corresponding diagnostics.
ExprResult SubstExpr(Expr *E, const MultiLevelTemplateArgumentList &TemplateArgs)
DiagnosticsEngine & getDiagnostics() const
ExprResult MaybeConvertParenListExprToParenExpr(Scope *S, Expr *ME)
This is not an AltiVec-style cast or or C++ direct-initialization, so turn the ParenListExpr into a s...
concepts::TypeRequirement * BuildTypeRequirement(TypeSourceInfo *Type)
AccessResult CheckDestructorAccess(SourceLocation Loc, CXXDestructorDecl *Dtor, const PartialDiagnostic &PDiag, QualType objectType=QualType())
bool isStdTypeIdentity(QualType Ty, QualType *TypeArgument, const Decl **MalformedDecl=nullptr)
Tests whether Ty is an instance of std::type_identity and, if it is and TypeArgument is not NULL,...
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....
void PushOnScopeChains(NamedDecl *D, Scope *S, bool AddToContext=true)
Add this decl to the scope shadowed decl chains.
ParsedType getDestructorName(const IdentifierInfo &II, SourceLocation NameLoc, Scope *S, CXXScopeSpec &SS, ParsedType ObjectType, bool EnteringContext)
void CleanupVarDeclMarking()
ExprResult DefaultFunctionArrayLvalueConversion(Expr *E, bool Diagnose=true)
ASTContext & getASTContext() const
void DeclareGlobalAllocationFunction(DeclarationName Name, QualType Return, ArrayRef< QualType > Params)
DeclareGlobalAllocationFunction - Declares a single implicit global allocation function if it doesn't...
bool DiagnoseUnexpandedParameterPackInRequiresExpr(RequiresExpr *RE)
If the given requirees-expression contains an unexpanded reference to one of its own parameter packs,...
CXXDestructorDecl * LookupDestructor(CXXRecordDecl *Class)
Look for the destructor of the given class.
bool tryCaptureVariable(ValueDecl *Var, SourceLocation Loc, TryCaptureKind Kind, SourceLocation EllipsisLoc, bool BuildAndDiagnose, QualType &CaptureType, QualType &DeclRefType, const unsigned *const FunctionScopeIndexToStopAt)
Try to capture the given variable.
NamespaceDecl * getOrCreateStdNamespace()
Retrieve the special "std" namespace, which may require us to implicitly define the namespace.
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.
ExprResult ActOnPseudoDestructorExpr(Scope *S, Expr *Base, SourceLocation OpLoc, tok::TokenKind OpKind, CXXScopeSpec &SS, UnqualifiedId &FirstTypeName, SourceLocation CCLoc, SourceLocation TildeLoc, UnqualifiedId &SecondTypeName)
bool CheckArgsForPlaceholders(MultiExprArg args)
Check an argument list for placeholders that we won't try to handle later.
AccessResult CheckAllocationAccess(SourceLocation OperatorLoc, SourceRange PlacementRange, CXXRecordDecl *NamingClass, DeclAccessPair FoundDecl, bool Diagnose=true)
Checks access to an overloaded operator new or delete.
AccessResult CheckMemberOperatorAccess(SourceLocation Loc, Expr *ObjectExpr, const SourceRange &, DeclAccessPair FoundDecl)
void ActOnFinishRequiresExpr()
ExprResult BuildCXXNew(SourceRange Range, bool UseGlobal, SourceLocation PlacementLParen, MultiExprArg PlacementArgs, SourceLocation PlacementRParen, SourceRange TypeIdParens, QualType AllocType, TypeSourceInfo *AllocTypeInfo, std::optional< Expr * > ArraySize, SourceRange DirectInitRange, Expr *Initializer)
void DiagnoseUseOfDeletedFunction(SourceLocation Loc, SourceRange Range, DeclarationName Name, OverloadCandidateSet &CandidateSet, FunctionDecl *Fn, MultiExprArg Args, bool IsMember=false)
PrintingPolicy getPrintingPolicy() const
Retrieve a suitable printing policy for diagnostics.
ExprResult ActOnCXXThrow(Scope *S, SourceLocation OpLoc, Expr *expr)
DeclRefExpr * BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK, SourceLocation Loc, const CXXScopeSpec *SS=nullptr)
ExprResult CheckConvertedConstantExpression(Expr *From, QualType T, llvm::APSInt &Value, CCEKind CCE)
bool CheckConstraintSatisfaction(ConstrainedDeclOrNestedRequirement Entity, ArrayRef< AssociatedConstraint > AssociatedConstraints, const MultiLevelTemplateArgumentList &TemplateArgLists, SourceRange TemplateIDRange, ConstraintSatisfaction &Satisfaction, const ConceptReference *TopLevelConceptId=nullptr, Expr **ConvertedExpr=nullptr)
Check whether the given list of constraint expressions are satisfied (as if in a 'conjunction') given...
EnumDecl * getStdAlignValT() const
LazyDeclPtr StdBadAlloc
The C++ "std::bad_alloc" class, which is defined by the C++ standard library.
NamedReturnInfo getNamedReturnInfo(Expr *&E, SimplerImplicitMoveMode Mode=SimplerImplicitMoveMode::Normal)
Determine whether the given expression might be move-eligible or copy-elidable in either a (co_)retur...
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...
bool checkLiteralOperatorId(const CXXScopeSpec &SS, const UnqualifiedId &Id, bool IsUDSuffix)
void DiagnoseUnusedExprResult(const Stmt *S, unsigned DiagID)
DiagnoseUnusedExprResult - If the statement passed in is an expression whose result is unused,...
FPOptions & getCurFPFeatures()
Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer, TranslationUnitKind TUKind=TU_Complete, CodeCompleteConsumer *CompletionConsumer=nullptr)
SourceLocation getLocForEndOfToken(SourceLocation Loc, unsigned Offset=0)
Calls Lexer::getLocForEndOfToken()
@ UPPC_IfExists
Microsoft __if_exists.
@ UPPC_IfNotExists
Microsoft __if_not_exists.
const LangOptions & getLangOpts() const
StmtResult ActOnFinishFullStmt(Stmt *Stmt)
CastKind PrepareScalarCast(ExprResult &src, QualType destType)
Prepares for a scalar cast, performing all the necessary stages except the final cast and returning t...
void diagnoseUnavailableAlignedAllocation(const FunctionDecl &FD, SourceLocation Loc)
Produce diagnostics if FD is an aligned allocation or deallocation function that is unavailable.
bool LookupParsedName(LookupResult &R, Scope *S, CXXScopeSpec *SS, QualType ObjectType, bool AllowBuiltinCreation=false, bool EnteringContext=false)
Performs name lookup for a name that was parsed in the source code, and may contain a C++ scope speci...
bool DiagnoseUnexpandedParameterPack(SourceLocation Loc, TypeSourceInfo *T, UnexpandedParameterPackContext UPPC)
If the given type contains an unexpanded parameter pack, diagnose the error.
bool RequireNonAbstractType(SourceLocation Loc, QualType T, TypeDiagnoser &Diagnoser)
ExprResult ActOnCXXBoolLiteral(SourceLocation OpLoc, tok::TokenKind Kind)
ActOnCXXBoolLiteral - Parse {true,false} literals.
ExprResult BuildCXXTypeConstructExpr(TypeSourceInfo *Type, SourceLocation LParenLoc, MultiExprArg Exprs, SourceLocation RParenLoc, bool ListInitialization)
AssignConvertType CheckAssignmentConstraints(SourceLocation Loc, QualType LHSType, QualType RHSType)
CheckAssignmentConstraints - Perform type checking for assignment, argument passing,...
void AddOverloadCandidate(FunctionDecl *Function, DeclAccessPair FoundDecl, ArrayRef< Expr * > Args, OverloadCandidateSet &CandidateSet, bool SuppressUserConversions=false, bool PartialOverloading=false, bool AllowExplicit=true, bool AllowExplicitConversion=false, ADLCallKind IsADLCandidate=ADLCallKind::NotADL, ConversionSequenceList EarlyConversions={}, OverloadCandidateParamOrder PO={}, bool AggregateCandidateDeduction=false, bool StrictPackMatch=false)
AddOverloadCandidate - Adds the given function to the set of candidate functions, using the given fun...
const LangOptions & LangOpts
sema::LambdaScopeInfo * getCurLambda(bool IgnoreNonLambdaCapturingScope=false)
Retrieve the current lambda scope info, if any.
ExprResult BuildCXXMemberCallExpr(Expr *Exp, NamedDecl *FoundDecl, CXXConversionDecl *Method, bool HadMultipleCandidates)
ExprResult CheckConditionVariable(VarDecl *ConditionVar, SourceLocation StmtLoc, ConditionKind CK)
Check the use of the given variable as a C++ condition in an if, while, do-while, or switch statement...
ExprResult TemporaryMaterializationConversion(Expr *E)
If E is a prvalue denoting an unmaterialized temporary, materialize it as an xvalue.
CXXRecordDecl * getStdBadAlloc() const
ExprResult ActOnCXXTypeConstructExpr(ParsedType TypeRep, SourceLocation LParenOrBraceLoc, MultiExprArg Exprs, SourceLocation RParenOrBraceLoc, bool ListInitialization)
ActOnCXXTypeConstructExpr - Parse construction of a specified type.
void CheckUnusedVolatileAssignment(Expr *E)
Check whether E, which is either a discarded-value expression or an unevaluated operand,...
QualType CheckTypenameType(ElaboratedTypeKeyword Keyword, SourceLocation KeywordLoc, NestedNameSpecifierLoc QualifierLoc, const IdentifierInfo &II, SourceLocation IILoc, TypeSourceInfo **TSI, bool DeducedTSTContext)
ExprResult prepareMatrixSplat(QualType MatrixTy, Expr *SplattedExpr)
Prepare SplattedExpr for a matrix splat operation, adding implicit casts if necessary.
bool CanUseDecl(NamedDecl *D, bool TreatUnavailableAsInvalid)
Determine whether the use of this declaration is valid, without emitting diagnostics.
ConditionResult ActOnConditionVariable(Decl *ConditionVar, SourceLocation StmtLoc, ConditionKind CK)
void MarkAnyDeclReferenced(SourceLocation Loc, Decl *D, bool MightBeOdrUse)
Perform marking for a reference to an arbitrary declaration.
void MarkVTableUsed(SourceLocation Loc, CXXRecordDecl *Class, bool DefinitionRequired=false)
Note that the vtable for the given class was used at the given location.
bool CheckAllocatedType(QualType AllocType, SourceLocation Loc, SourceRange R)
Checks that a type is suitable as the allocated type in a new-expression.
CleanupInfo Cleanup
Used to control the generation of ExprWithCleanups.
ExprResult ActOnRequiresExpr(SourceLocation RequiresKWLoc, RequiresExprBodyDecl *Body, SourceLocation LParenLoc, ArrayRef< ParmVarDecl * > LocalParameters, SourceLocation RParenLoc, ArrayRef< concepts::Requirement * > Requirements, SourceLocation ClosingBraceLoc)
QualType FindCompositePointerType(SourceLocation Loc, Expr *&E1, Expr *&E2, bool ConvertArgs=true)
Find a merged pointer type and convert the two expressions to it.
static CastKind ScalarTypeToBooleanCastKind(QualType ScalarTy)
ScalarTypeToBooleanCastKind - Returns the cast kind corresponding to the conversion from scalar type ...
ReferenceConversionsScope::ReferenceConversions ReferenceConversions
CXXRecordDecl * getCurrentClass(Scope *S, const CXXScopeSpec *SS)
Get the class that is directly named by the current context.
ExprResult BuildCXXUuidof(QualType TypeInfoType, SourceLocation TypeidLoc, TypeSourceInfo *Operand, SourceLocation RParenLoc)
Build a Microsoft __uuidof expression with a type operand.
MemberPointerConversionResult CheckMemberPointerConversion(QualType FromType, const MemberPointerType *ToPtrType, CastKind &Kind, CXXCastPath &BasePath, SourceLocation CheckLoc, SourceRange OpRange, bool IgnoreBaseAccess, MemberPointerConversionDirection Direction)
CheckMemberPointerConversion - Check the member pointer conversion from the expression From to the ty...
Expr * BuildCXXThisExpr(SourceLocation Loc, QualType Type, bool IsImplicit)
Build a CXXThisExpr and mark it referenced in the current context.
QualType CheckSizelessVectorOperands(ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign, ArithConvKind OperationKind)
llvm::DenseMap< const VarDecl *, int > RefsMinusAssignments
Increment when we find a reference; decrement when we find an ignored assignment.
QualType DeduceTemplateSpecializationFromInitializer(TypeSourceInfo *TInfo, const InitializedEntity &Entity, const InitializationKind &Kind, MultiExprArg Init)
void MarkThisReferenced(CXXThisExpr *This)
ExprResult DefaultLvalueConversion(Expr *E)
bool CheckDerivedToBaseConversion(QualType Derived, QualType Base, SourceLocation Loc, SourceRange Range, CXXCastPath *BasePath=nullptr, bool IgnoreAccess=false)
bool isInLifetimeExtendingContext() const
Module * getCurrentModule() const
Get the module unit whose scope we are currently within.
AssignConvertType CheckTransparentUnionArgumentConstraints(QualType ArgType, ExprResult &RHS)
static bool isCast(CheckedConversionKind CCK)
ExprResult prepareVectorSplat(QualType VectorTy, Expr *SplattedExpr)
Prepare SplattedExpr for a vector splat operation, adding implicit casts if necessary.
DeclContext * CurContext
CurContext - This is the current declaration context of parsing.
bool FindAllocationFunctions(SourceLocation StartLoc, SourceRange Range, AllocationFunctionScope NewScope, AllocationFunctionScope DeleteScope, QualType AllocType, bool IsArray, ImplicitAllocationParameters &IAP, MultiExprArg PlaceArgs, FunctionDecl *&OperatorNew, FunctionDecl *&OperatorDelete, bool Diagnose=true)
Finds the overloads of operator new and delete that are appropriate for the allocation.
DeclarationNameInfo GetNameFromUnqualifiedId(const UnqualifiedId &Name)
Retrieves the declaration name from a parsed unqualified-id.
ExprResult PerformContextuallyConvertToBool(Expr *From)
PerformContextuallyConvertToBool - Perform a contextual conversion of the expression From to bool (C+...
AccessResult CheckConstructorAccess(SourceLocation Loc, CXXConstructorDecl *D, DeclAccessPair FoundDecl, const InitializedEntity &Entity, bool IsCopyBindingRefToTemp=false)
Checks access to a constructor.
bool DiagnoseConditionalForNull(const Expr *LHSExpr, const Expr *RHSExpr, SourceLocation QuestionLoc)
Emit a specialized diagnostic when one expression is a null pointer constant and the other is not a p...
ParsedType getDestructorTypeForDecltype(const DeclSpec &DS, ParsedType ObjectType)
bool IsDerivedFrom(SourceLocation Loc, CXXRecordDecl *Derived, CXXRecordDecl *Base, CXXBasePaths &Paths)
Determine whether the type Derived is a C++ class that is derived from the type Base.
bool isUnevaluatedContext() const
Determines whether we are currently in a context that is not evaluated as per C++ [expr] p5.
DeclContext * getFunctionLevelDeclContext(bool AllowLambda=false) const
If AllowLambda is true, treat lambda as function.
Stmt * MaybeCreateStmtWithCleanups(Stmt *SubStmt)
ExprResult ActOnCXXNew(SourceLocation StartLoc, bool UseGlobal, SourceLocation PlacementLParen, MultiExprArg PlacementArgs, SourceLocation PlacementRParen, SourceRange TypeIdParens, Declarator &D, Expr *Initializer)
Parsed a C++ 'new' expression (C++ 5.3.4).
ExprResult BuildCXXNoexceptExpr(SourceLocation KeyLoc, Expr *Operand, SourceLocation RParen)
bool GlobalNewDeleteDeclared
A flag to remember whether the implicit forms of operator new and delete have been declared.
ExprResult ActOnParenExpr(SourceLocation L, SourceLocation R, Expr *E)
ExprResult CheckPlaceholderExpr(Expr *E)
Check for operands with placeholder types and complain if found.
ExprResult TransformToPotentiallyEvaluated(Expr *E)
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
QualType CXXThisTypeOverride
When non-NULL, the C++ 'this' expression is allowed despite the current context not being a non-stati...
ExprResult FixOverloadedFunctionReference(Expr *E, DeclAccessPair FoundDecl, FunctionDecl *Fn)
FixOverloadedFunctionReference - E is an expression that refers to a C++ overloaded function (possibl...
ExprResult PerformMoveOrCopyInitialization(const InitializedEntity &Entity, const NamedReturnInfo &NRInfo, Expr *Value, bool SupressSimplerImplicitMoves=false)
Perform the initialization of a potentially-movable value, which is the result of return value.
ExprResult CheckCXXBooleanCondition(Expr *CondExpr, bool IsConstexpr=false)
CheckCXXBooleanCondition - Returns true if conversion to bool is invalid.
CanThrowResult canThrow(const Stmt *E)
bool isThisOutsideMemberFunctionBody(QualType BaseType)
Determine whether the given type is the type of *this that is used outside of the body of a member fu...
DeclContext * computeDeclContext(QualType T)
Compute the DeclContext that is associated with the given type.
QualType CheckPointerToMemberOperands(ExprResult &LHS, ExprResult &RHS, ExprValueKind &VK, SourceLocation OpLoc, bool isIndirect)
concepts::ExprRequirement * BuildExprRequirement(Expr *E, bool IsSatisfied, SourceLocation NoexceptLoc, concepts::ExprRequirement::ReturnTypeRequirement ReturnTypeRequirement)
QualType CXXCheckConditionalOperands(ExprResult &cond, ExprResult &lhs, ExprResult &rhs, ExprValueKind &VK, ExprObjectKind &OK, SourceLocation questionLoc)
Check the operands of ?
ExprResult PerformImplicitConversion(Expr *From, QualType ToType, const ImplicitConversionSequence &ICS, AssignmentAction Action, CheckedConversionKind CCK=CheckedConversionKind::Implicit)
PerformImplicitConversion - Perform an implicit conversion of the expression From to the type ToType ...
bool isSFINAEContext() const
concepts::Requirement * ActOnTypeRequirement(SourceLocation TypenameKWLoc, CXXScopeSpec &SS, SourceLocation NameLoc, const IdentifierInfo *TypeName, TemplateIdAnnotation *TemplateId)
void CheckShadow(NamedDecl *D, NamedDecl *ShadowedDecl, const LookupResult &R)
Diagnose variable or built-in function shadowing.
ParsedType getInheritingConstructorName(CXXScopeSpec &SS, SourceLocation NameLoc, const IdentifierInfo &Name)
Handle the result of the special case name lookup for inheriting constructor declarations.
TypeResult ActOnTypenameType(Scope *S, SourceLocation TypenameLoc, const CXXScopeSpec &SS, const IdentifierInfo &II, SourceLocation IdLoc, ImplicitTypenameContext IsImplicitTypename=ImplicitTypenameContext::No)
Called when the parser has parsed a C++ typename specifier, e.g., "typename T::type".
bool isCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind=CompleteTypeKind::Default)
ExprResult BuildPseudoDestructorExpr(Expr *Base, SourceLocation OpLoc, tok::TokenKind OpKind, const CXXScopeSpec &SS, TypeSourceInfo *ScopeType, SourceLocation CCLoc, SourceLocation TildeLoc, PseudoDestructorTypeStorage DestroyedType)
RecordDecl * CXXTypeInfoDecl
The C++ "type_info" declaration, which is defined in <typeinfo>.
CXXConstructorDecl * LookupCopyingConstructor(CXXRecordDecl *Class, unsigned Quals)
Look up the copying constructor for the given class.
ExprResult VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result, VerifyICEDiagnoser &Diagnoser, AllowFoldKind CanFold=AllowFoldKind::No)
VerifyIntegerConstantExpression - Verifies that an expression is an ICE, and reports the appropriate ...
ParsedType getTypeName(const IdentifierInfo &II, SourceLocation NameLoc, Scope *S, CXXScopeSpec *SS=nullptr, bool isClassName=false, bool HasTrailingDot=false, ParsedType ObjectType=nullptr, bool IsCtorOrDtorName=false, bool WantNontrivialTypeSourceInfo=false, bool IsClassTemplateDeductionContext=true, ImplicitTypenameContext AllowImplicitTypename=ImplicitTypenameContext::No, IdentifierInfo **CorrectedII=nullptr)
If the identifier refers to a type name within this scope, return the declaration of that type.
RequiresExprBodyDecl * ActOnStartRequiresExpr(SourceLocation RequiresKWLoc, ArrayRef< ParmVarDecl * > LocalParameters, Scope *BodyScope)
bool CheckPointerConversion(Expr *From, QualType ToType, CastKind &Kind, CXXCastPath &BasePath, bool IgnoreBaseAccess, bool Diagnose=true)
CheckPointerConversion - Check the pointer conversion from the expression From to the type ToType.
SmallVector< ExprWithCleanups::CleanupObject, 8 > ExprCleanupObjects
ExprCleanupObjects - This is the stack of objects requiring cleanup that are created by the current f...
void NoteDeletedFunction(FunctionDecl *FD)
Emit a note explaining that this function is deleted.
void AddKnownFunctionAttributesForReplaceableGlobalAllocationFunction(FunctionDecl *FD)
If this function is a C++ replaceable global allocation function (C++2a [basic.stc....
QualType BuildDecltypeType(Expr *E, bool AsUnevaluated=true)
If AsUnevaluated is false, E is treated as though it were an evaluated context, such as when building...
TypeSourceInfo * GetTypeForDeclarator(Declarator &D)
GetTypeForDeclarator - Convert the type for the specified declarator to Type instances.
bool CheckCallReturnType(QualType ReturnType, SourceLocation Loc, CallExpr *CE, FunctionDecl *FD)
CheckCallReturnType - Checks that a call expression's return type is complete.
bool RequireCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind, TypeDiagnoser &Diagnoser)
Ensure that the type T is a complete type.
ReferenceCompareResult CompareReferenceRelationship(SourceLocation Loc, QualType T1, QualType T2, ReferenceConversions *Conv=nullptr)
CompareReferenceRelationship - Compare the two types T1 and T2 to determine whether they are referenc...
ExprResult forceUnknownAnyToType(Expr *E, QualType ToType)
Force an expression with unknown-type to an expression of the given type.
bool LookupQualifiedName(LookupResult &R, DeclContext *LookupCtx, bool InUnqualifiedLookup=false)
Perform qualified name lookup into a given context.
llvm::MapVector< FieldDecl *, DeleteLocs > DeleteExprs
Delete-expressions to be analyzed at the end of translation unit.
Expr * MaybeCreateExprWithCleanups(Expr *SubExpr)
MaybeCreateExprWithCleanups - If the current full-expression requires any cleanups,...
void DiscardCleanupsInEvaluationContext()
SmallVector< ExpressionEvaluationContextRecord, 8 > ExprEvalContexts
A stack of expression evaluation contexts.
void PushDeclContext(Scope *S, DeclContext *DC)
Set the current declaration context until it gets popped.
bool isDependentScopeSpecifier(const CXXScopeSpec &SS)
bool CheckDestructor(CXXDestructorDecl *Destructor)
CheckDestructor - Checks a fully-formed destructor definition for well-formedness,...
bool isUnavailableAlignedAllocationFunction(const FunctionDecl &FD) const
Determine whether FD is an aligned allocation or deallocation function that is unavailable.
DiagnosticsEngine & Diags
TypeAwareAllocationMode ShouldUseTypeAwareOperatorNewOrDelete() const
NamespaceDecl * getStdNamespace() const
ExprResult BuildCXXThrow(SourceLocation OpLoc, Expr *Ex, bool IsThrownVarInScope)
ExprResult DefaultFunctionArrayConversion(Expr *E, bool Diagnose=true)
DefaultFunctionArrayConversion (C99 6.3.2.1p3, C99 6.3.2.1p4).
ExprResult PerformCopyInitialization(const InitializedEntity &Entity, SourceLocation EqualLoc, ExprResult Init, bool TopLevelOfInitList=false, bool AllowExplicit=false)
bool CheckQualifiedFunctionForTypeId(QualType T, SourceLocation Loc)
friend class InitializationSequence
concepts::NestedRequirement * BuildNestedRequirement(Expr *E)
TemplateDeductionResult DeduceTemplateArguments(ClassTemplatePartialSpecializationDecl *Partial, ArrayRef< TemplateArgument > TemplateArgs, sema::TemplateDeductionInfo &Info)
QualType ActOnPackIndexingType(QualType Pattern, Expr *IndexExpr, SourceLocation Loc, SourceLocation EllipsisLoc)
bool isUsualDeallocationFunction(const CXXMethodDecl *FD)
TypeResult ActOnTemplateIdType(Scope *S, ElaboratedTypeKeyword ElaboratedKeyword, SourceLocation ElaboratedKeywordLoc, CXXScopeSpec &SS, SourceLocation TemplateKWLoc, TemplateTy Template, const IdentifierInfo *TemplateII, SourceLocation TemplateIILoc, SourceLocation LAngleLoc, ASTTemplateArgsPtr TemplateArgs, SourceLocation RAngleLoc, bool IsCtorOrDtorName=false, bool IsClassName=false, ImplicitTypenameContext AllowImplicitTypename=ImplicitTypenameContext::No)
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,...
SemaDiagnosticBuilder targetDiag(SourceLocation Loc, unsigned DiagID, const FunctionDecl *FD=nullptr)
ExprResult CreateRecoveryExpr(SourceLocation Begin, SourceLocation End, ArrayRef< Expr * > SubExprs, QualType T=QualType())
Attempts to produce a RecoveryExpr after some AST node cannot be created.
ParsedType getConstructorName(const IdentifierInfo &II, SourceLocation NameLoc, Scope *S, CXXScopeSpec &SS, bool EnteringContext)
LazyDeclPtr StdAlignValT
The C++ "std::align_val_t" enum class, which is defined by the C++ standard library.
@ Diagnose
Diagnose issues that are non-constant or that are extensions.
bool CheckCXXThrowOperand(SourceLocation ThrowLoc, QualType ThrowTy, Expr *E)
CheckCXXThrowOperand - Validate the operand of a throw.
TemplateDeductionResult DeduceAutoType(TypeLoc AutoTypeLoc, Expr *Initializer, QualType &Result, sema::TemplateDeductionInfo &Info, bool DependentDeduction=false, bool IgnoreConstraints=false, TemplateSpecCandidateSet *FailedTSC=nullptr)
Deduce the type for an auto type-specifier (C++11 [dcl.spec.auto]p6)
bool LookupName(LookupResult &R, Scope *S, bool AllowBuiltinCreation=false, bool ForceNoCPlusPlus=false)
Perform unqualified name lookup starting from a given scope.
static QualType GetTypeFromParser(ParsedType Ty, TypeSourceInfo **TInfo=nullptr)
concepts::Requirement * ActOnNestedRequirement(Expr *Constraint)
QualType adjustCCAndNoReturn(QualType ArgFunctionType, QualType FunctionType, bool AdjustExceptionSpec=false)
Adjust the type ArgFunctionType to match the calling convention, noreturn, and optionally the excepti...
bool IsStringLiteralToNonConstPointerConversion(Expr *From, QualType ToType)
Helper function to determine whether this is the (deprecated) C++ conversion from a string literal to...
bool CheckExceptionSpecCompatibility(Expr *From, QualType ToType)
static ConditionResult ConditionError()
IdentifierResolver IdResolver
FunctionTemplateDecl * getMoreSpecializedTemplate(FunctionTemplateDecl *FT1, FunctionTemplateDecl *FT2, SourceLocation Loc, TemplatePartialOrderingContext TPOC, unsigned NumCallArguments1, QualType RawObj1Ty={}, QualType RawObj2Ty={}, bool Reversed=false, bool PartialOverloading=false)
Returns the more specialized function template according to the rules of function template partial or...
ExprResult ActOnCXXThis(SourceLocation Loc)
ExprResult ActOnDecltypeExpression(Expr *E)
Process the expression contained within a decltype.
bool CheckCXXDefaultArgExpr(SourceLocation CallLoc, FunctionDecl *FD, ParmVarDecl *Param, Expr *Init=nullptr, bool SkipImmediateInvocations=true)
Instantiate or parse a C++ default argument expression as necessary.
void CheckVirtualDtorCall(CXXDestructorDecl *dtor, SourceLocation Loc, bool IsDelete, bool CallCanBeVirtual, bool WarnOnNonAbstractTypes, SourceLocation DtorLoc)
ExprResult ActOnFinishFullExpr(Expr *Expr, bool DiscardedValue)
void checkCall(NamedDecl *FDecl, const FunctionProtoType *Proto, const Expr *ThisArg, ArrayRef< const Expr * > Args, bool IsMemberFunction, SourceLocation Loc, SourceRange Range, VariadicCallType CallType)
Handles the checks for format strings, non-POD arguments to vararg functions, NULL arguments passed t...
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
A trivial tuple used to represent a source range.
SourceLocation getEnd() const
SourceLocation getBegin() const
StandardConversionSequence - represents a standard conversion sequence (C++ 13.3.3....
DeclAccessPair FoundCopyConstructor
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,...
unsigned DeprecatedStringLiteralToCharPtr
Whether this is the deprecated conversion of a string literal to a pointer to non-const character dat...
CXXConstructorDecl * CopyConstructor
CopyConstructor - The copy constructor that is used to perform this conversion, when the conversion i...
unsigned IncompatibleObjC
IncompatibleObjC - Whether this is an Objective-C conversion that we should warn about (if we actuall...
ImplicitConversionKind Third
Third - The third conversion can be a qualification conversion or a function conversion.
ImplicitConversionKind Dimension
Dimension - Between the second and third conversion a vector or matrix dimension conversion may occur...
StmtExpr - This is the GNU Statement Expression extension: ({int X=4; X;}).
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.
StringRef getString() const
unsigned getNewAlign() const
Return the largest alignment for which a suitably-sized allocation with 'operator new(size_t)' is gua...
const llvm::Triple & getTriple() const
Returns the target triple of the primary target.
A template argument list.
ArrayRef< TemplateArgument > asArray() const
Produce this as an array ref.
Represents a template argument.
@ Declaration
The template argument is a declaration that was provided for a pointer, reference,...
@ Type
The template argument is a type.
Stores a list of template parameters for a TemplateDecl and its derived classes.
NamedDecl * getParam(unsigned Idx)
unsigned getDepth() const
Get the depth of this template parameter list in the set of template parameter lists.
static TemplateParameterList * Create(const ASTContext &C, SourceLocation TemplateLoc, SourceLocation LAngleLoc, ArrayRef< NamedDecl * > Params, SourceLocation RAngleLoc, Expr *RequiresClause)
static TemplateTypeParmDecl * Create(const ASTContext &C, DeclContext *DC, SourceLocation KeyLoc, SourceLocation NameLoc, unsigned D, unsigned P, IdentifierInfo *Id, bool Typename, bool ParameterPack, bool HasTypeConstraint=false, UnsignedOrNone NumExpanded=std::nullopt)
Models the abbreviated syntax to constrain a template type parameter: template <convertible_to<string...
Expr * getImmediatelyDeclaredConstraint() const
Get the immediately-declared constraint expression introduced by this type-constraint,...
Represents a declaration of a type.
TyLocType push(QualType T)
Pushes space for a new TypeLoc of the given type.
TypeSourceInfo * getTypeSourceInfo(ASTContext &Context, QualType T)
Creates a TypeSourceInfo for the given type.
void pushTrivial(ASTContext &Context, QualType T, SourceLocation Loc)
Pushes 'T' with all locations pointing to 'Loc'.
SourceRange getSourceRange() const LLVM_READONLY
Get the full source range.
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.
bool isSizelessType() const
As an extension, we classify types as one of "sized" or "sizeless"; every type is one or the other.
bool isBlockPointerType() const
bool isBooleanType() const
bool isPlaceholderType() const
Test for a type which does not represent an actual type-system type but is instead used as a placehol...
bool isIntegralOrUnscopedEnumerationType() const
Determine whether this type is an integral or unscoped enumeration type.
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
bool isVoidPointerType() const
CXXRecordDecl * castAsCXXRecordDecl() const
bool isArithmeticType() const
bool isConstantMatrixType() 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 isEnumeralType() const
bool isScalarType() const
bool isSveVLSBuiltinType() const
Determines if this is a sizeless type supported by the 'arm_sve_vector_bits' type attribute,...
bool isIntegralType(const ASTContext &Ctx) const
Determine whether this type is an integral type.
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
bool isExtVectorType() const
TagDecl * getAsTagDecl() const
Retrieves the TagDecl that this type refers to, either because the type is a TagType or because it is...
bool isBuiltinType() const
Helper methods to distinguish type categories.
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
bool isFixedPointType() const
Return true if this is a fixed point type according to ISO/IEC JTC1 SC22 WG14 N1169.
DeducedType * getContainedDeducedType() const
Get the DeducedType whose type will be deduced for a variable with an initializer of this type.
bool isWebAssemblyTableType() const
Returns true if this is a WebAssembly table type: either an array of reference types,...
const Type * getBaseElementTypeUnsafe() const
Get the base element type of this type, potentially discarding type qualifiers.
bool isMemberPointerType() const
bool isMatrixType() const
EnumDecl * castAsEnumDecl() const
bool isVariablyModifiedType() const
Whether this type is a variably-modified type (C99 6.7.5).
bool isObjCLifetimeType() const
Returns true if objects of this type have lifetime semantics under ARC.
bool isObjectType() const
Determine whether this type is an object type.
EnumDecl * getAsEnumDecl() const
Retrieves the EnumDecl this type refers to.
bool isPointerOrReferenceType() const
Qualifiers::ObjCLifetime getObjCARCImplicitLifetime() const
Return the implicit lifetime for this type, which must not be dependent.
bool isFunctionType() const
bool isObjCObjectPointerType() const
bool isVectorType() const
bool isRealFloatingType() const
Floating point categories.
const T * getAsCanonical() const
If this type is canonically the specified type, return its canonical type cast to that specified type...
bool isFloatingType() const
bool isAnyPointerType() const
const T * getAs() const
Member-template getAs<specific type>'.
bool isObjCARCImplicitlyUnretainedType() const
Determines if this type, which must satisfy isObjCLifetimeType(), is implicitly __unsafe_unretained r...
bool isNullPtrType() const
bool isRecordType() const
bool isObjCRetainableType() const
bool isSizelessVectorType() const
Returns true for all scalable vector types.
UnaryOperator - This represents the unary-expression's (except sizeof and alignof),...
Represents a C++ unqualified-id that has been parsed.
SourceLocation getBeginLoc() const LLVM_READONLY
SourceRange getSourceRange() const LLVM_READONLY
Return the source range that covers this unqualified-id.
SourceLocation getEndLoc() const LLVM_READONLY
SourceLocation StartLocation
The location of the first token that describes this unqualified-id, which will be the location of the...
const IdentifierInfo * Identifier
When Kind == IK_Identifier, the parsed identifier, or when Kind == IK_UserLiteralId,...
UnqualifiedIdKind getKind() const
Determine what kind of name we have.
TemplateIdAnnotation * TemplateId
When Kind == IK_TemplateId or IK_ConstructorTemplateId, the template-id annotation that contains the ...
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
bool isWeak() const
Determine whether this symbol is weakly-imported, or declared with the weak or weak-ref attr.
VarDecl * getPotentiallyDecomposedVarDecl()
Represents a variable declaration or definition.
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
VarDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
bool isUsableInConstantExpressions(const ASTContext &C) const
Determine whether this variable's value can be used in a constant expression, according to the releva...
const Expr * getAnyInitializer() const
Get the initializer for this variable, no matter which declaration it is attached to.
Represents a GCC generic vector type.
bool isTypeConstraint() const
TemplateParameterList * getTypeConstraintTemplateParameterList() const
bool isSubstitutionFailure() const
A requires-expression requirement which queries the validity and properties of an expression ('simple...
@ SS_ConstraintsNotSatisfied
@ SS_TypeRequirementSubstitutionFailure
A requires-expression requirement which is satisfied when a general constraint expression is satisfie...
A static requirement that can be used in a requires-expression to check properties of types and expre...
A requires-expression requirement which queries the existence of a type name or type template special...
ImplicitCaptureStyle ImpCaptureStyle
Capture & getCXXThisCapture()
Retrieve the capture of C++ 'this', if it has been captured.
bool isCXXThisCaptured() const
Determine whether the C++ 'this' is captured.
void addThisCapture(bool isNested, SourceLocation Loc, QualType CaptureType, bool ByCopy)
SourceLocation PotentialThisCaptureLocation
bool hasPotentialThisCapture() const
SourceRange IntroducerRange
Source range covering the lambda introducer [...].
bool lambdaCaptureShouldBeConst() const
void clearPotentialCaptures()
bool hasPotentialCaptures() const
bool isVariableExprMarkedAsNonODRUsed(Expr *CapturingVarExpr) const
CXXRecordDecl * Lambda
The class that describes the lambda.
void visitPotentialCaptures(llvm::function_ref< void(ValueDecl *, Expr *)> Callback) const
unsigned NumExplicitCaptures
The number of captures in the Captures list that are explicit captures.
bool AfterParameterList
Indicate that we parsed the parameter list at which point the mutability of the lambda is known.
CXXMethodDecl * CallOperator
The lambda's compiler-generated operator().
Provides information about an attempted template argument deduction, whose success or failure was des...
Defines the clang::TargetInfo interface.
SmallVector< BoundNodes, 1 > match(MatcherT Matcher, const NodeT &Node, ASTContext &Context)
Returns the results of matching Matcher on Node.
bool NE(InterpState &S, CodePtr OpPC)
ComparisonCategoryResult Compare(const T &X, const T &Y)
Helper to compare two comparable types.
TokenKind
Provides a simple uniform namespace for tokens from all C languages.
The JSON file list parser is used to communicate input to InstallAPI.
CanQual< Type > CanQualType
Represents a canonical, potentially-qualified type.
bool isLambdaCallWithImplicitObjectParameter(const DeclContext *DC)
OverloadedOperatorKind
Enumeration specifying the different kinds of C++ overloaded operators.
@ Match
This is not an overload because the signature exactly matches an existing declaration.
bool isa(CodeGen::Address addr)
if(T->getSizeExpr()) TRY_TO(TraverseStmt(const_cast< Expr * >(T -> getSizeExpr())))
@ 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.
CanThrowResult
Possible results from evaluation of a noexcept expression.
AllocationFunctionScope
The scope in which to find allocation functions.
@ Both
Look for allocation functions in both the global scope and in the scope of the allocated class.
@ Global
Only look for allocation functions in the global scope.
@ Class
Only look for allocation functions in the scope of the allocated class.
DeclContext * getLambdaAwareParentOfDeclContext(DeclContext *DC)
bool isReservedInAllContexts(ReservedIdentifierStatus Status)
Determine whether an identifier is reserved in all contexts.
bool isUnresolvedExceptionSpec(ExceptionSpecificationType ESpecType)
@ Ambiguous
Name lookup results in an ambiguity; use getAmbiguityKind to figure out what kind of ambiguity we hav...
@ NotFound
No entity found met the criteria.
@ FoundOverloaded
Name lookup found a set of overloaded functions that met the criteria.
@ Found
Name lookup found a single declaration that met the criteria.
@ FoundUnresolvedValue
Name lookup found an unresolvable value declaration and cannot yet complete.
@ NotFoundInCurrentInstantiation
No entity found met the criteria within the current instantiation,, but there were dependent base cla...
AlignedAllocationMode alignedAllocationModeFromBool(bool IsAligned)
@ Conditional
A conditional (?:) operator.
@ RQ_None
No ref-qualifier was provided.
@ RQ_LValue
An lvalue ref-qualifier was provided (&).
@ RQ_RValue
An rvalue ref-qualifier was provided (&&).
@ OCD_AmbiguousCandidates
Requests that only tied-for-best candidates be shown.
@ OCD_AllCandidates
Requests that all candidates be shown.
ExprObjectKind
A further classification of the kind of object referenced by an l-value or x-value.
@ OK_ObjCProperty
An Objective-C property is a logical field of an Objective-C object which is read and written via Obj...
@ OK_Ordinary
An ordinary object is located at an address in memory.
@ OK_BitField
A bitfield object is a bitfield on a C or C++ record.
UnsignedOrNone getStackIndexOfNearestEnclosingCaptureCapableLambda(ArrayRef< const sema::FunctionScopeInfo * > FunctionScopes, ValueDecl *VarToCapture, Sema &S)
Examines the FunctionScopeInfo stack to determine the nearest enclosing lambda (to the current lambda...
@ LCK_StarThis
Capturing the *this object by copy.
@ Bind
'bind' clause, allowed on routine constructs.
@ Self
'self' clause, allowed on Compute and Combined Constructs, plus 'update'.
@ IK_TemplateId
A template-id, e.g., f<int>.
@ IK_LiteralOperatorId
A user-defined literal name, e.g., operator "" _i.
@ IK_Identifier
An identifier.
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
bool isLambdaCallWithExplicitObjectParameter(const DeclContext *DC)
bool isAlignedAllocation(AlignedAllocationMode Mode)
MutableArrayRef< Expr * > MultiExprArg
bool isLambdaCallOperator(const CXXMethodDecl *MD)
@ Result
The result type of a method or function.
ActionResult< ParsedType > TypeResult
@ ICK_Complex_Conversion
Complex conversions (C99 6.3.1.6)
@ ICK_Floating_Promotion
Floating point promotions (C++ [conv.fpprom])
@ ICK_Boolean_Conversion
Boolean conversions (C++ [conv.bool])
@ ICK_Integral_Conversion
Integral conversions (C++ [conv.integral])
@ ICK_Fixed_Point_Conversion
Fixed point type conversions according to N1169.
@ ICK_Vector_Conversion
Vector conversions.
@ ICK_Block_Pointer_Conversion
Block Pointer conversions.
@ ICK_Pointer_Member
Pointer-to-member conversions (C++ [conv.mem])
@ ICK_Floating_Integral
Floating-integral conversions (C++ [conv.fpint])
@ ICK_HLSL_Array_RValue
HLSL non-decaying array rvalue cast.
@ ICK_SVE_Vector_Conversion
Arm SVE Vector conversions.
@ ICK_HLSL_Vector_Truncation
HLSL vector truncation.
@ ICK_Incompatible_Pointer_Conversion
C-only conversion between pointers with incompatible types.
@ ICK_Array_To_Pointer
Array-to-pointer conversion (C++ [conv.array])
@ ICK_RVV_Vector_Conversion
RISC-V RVV Vector conversions.
@ ICK_Complex_Promotion
Complex promotions (Clang extension)
@ ICK_Num_Conversion_Kinds
The number of conversion kinds.
@ ICK_HLSL_Matrix_Splat
HLSL matrix splat from scalar or boolean type.
@ ICK_Function_Conversion
Function pointer conversion (C++17 [conv.fctptr])
@ ICK_Vector_Splat
A vector splat from an arithmetic type.
@ ICK_Zero_Queue_Conversion
Zero constant to queue.
@ ICK_Identity
Identity conversion (no conversion)
@ ICK_Derived_To_Base
Derived-to-base (C++ [over.best.ics])
@ ICK_Lvalue_To_Rvalue
Lvalue-to-rvalue conversion (C++ [conv.lval])
@ ICK_Qualification
Qualification conversions (C++ [conv.qual])
@ ICK_Pointer_Conversion
Pointer conversions (C++ [conv.ptr])
@ ICK_TransparentUnionConversion
Transparent Union Conversions.
@ ICK_Integral_Promotion
Integral promotions (C++ [conv.prom])
@ ICK_HLSL_Matrix_Truncation
HLSL Matrix truncation.
@ ICK_Floating_Conversion
Floating point conversions (C++ [conv.double].
@ ICK_Compatible_Conversion
Conversions between compatible types in C99.
@ ICK_C_Only_Conversion
Conversions allowed in C, but not C++.
@ ICK_Writeback_Conversion
Objective-C ARC writeback conversion.
@ ICK_Zero_Event_Conversion
Zero constant to event (OpenCL1.2 6.12.10)
@ ICK_Complex_Real
Complex-real conversions (C99 6.3.1.7)
@ ICK_Function_To_Pointer
Function-to-pointer (C++ [conv.array])
@ Template
We are parsing a template declaration.
ActionResult< CXXBaseSpecifier * > BaseResult
llvm::VersionTuple alignedAllocMinVersion(llvm::Triple::OSType OS)
AssignConvertType
AssignConvertType - All of the 'assignment' semantic checks return this enum to indicate whether the ...
@ Incompatible
Incompatible - We reject this conversion outright, it is invalid to represent it in the AST.
@ Compatible
Compatible - the types are compatible according to the standard.
@ NotStartsWithUnderscore
@ Class
The "class" keyword.
@ Type
The name was classified as a type.
bool isTypeAwareAllocation(TypeAwareAllocationMode Mode)
LangAS
Defines the address space values used by the address space qualifier of QualType.
CastKind
CastKind - The kind of operation required for a conversion.
MutableArrayRef< ParsedTemplateArgument > ASTTemplateArgsPtr
SizedDeallocationMode sizedDeallocationModeFromBool(bool IsSized)
@ Deduced
The normal deduced case.
std::pair< SourceLocation, PartialDiagnostic > PartialDiagnosticAt
A partial diagnostic along with the source location where this diagnostic occurs.
bool isPtrSizeAddressSpace(LangAS AS)
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_LValue
An l-value expression is a reference to an object with independent storage.
SmallVector< CXXBaseSpecifier *, 4 > CXXCastPath
A simple array of base specifiers.
bool isSizedDeallocation(SizedDeallocationMode Mode)
IfExistsResult
Describes the result of an "if-exists" condition check.
@ Dependent
The name is a dependent name, so the results will differ from one instantiation to the next.
@ Exists
The symbol exists.
@ Error
An error occurred.
@ DoesNotExist
The symbol does not exist.
@ TPOC_Call
Partial ordering of function templates for a function call.
bool declaresSameEntity(const Decl *D1, const Decl *D2)
Determine whether two declarations declare the same entity.
TemplateDeductionResult
Describes the result of template argument deduction.
@ Success
Template argument deduction was successful.
@ AlreadyDiagnosed
Some error which was already diagnosed.
@ Generic
not a target-specific vector type
U cast(CodeGen::Address addr)
@ ArrayBound
Array bound in array declarator or new-expression.
OpaquePtr< QualType > ParsedType
An opaque type for threading parsed type information through the parser.
@ None
No keyword precedes the qualified type name.
@ Class
The "class" keyword introduces the elaborated-type-specifier.
@ Typename
The "typename" keyword precedes the qualified type name, e.g., typename T::type.
ActionResult< Expr * > ExprResult
@ Other
Other implicit parameter.
CXXNewInitializationStyle
@ Parens
New-expression has a C++98 paren-delimited initializer.
@ None
New-expression has no initializer as written.
@ Braces
New-expression has a C++11 list-initializer.
@ EST_BasicNoexcept
noexcept
@ EST_Dynamic
throw(T1, T2)
CheckedConversionKind
The kind of conversion being performed.
@ CStyleCast
A C-style cast.
@ ForBuiltinOverloadedOp
A conversion for an operand of a builtin overloaded operator.
@ FunctionalCast
A functional-style cast.
ActionResult< Stmt * > StmtResult
bool isGenericLambdaCallOperatorSpecialization(const CXXMethodDecl *MD)
The result of a constraint satisfaction check, containing the necessary information to diagnose an un...
static ASTConstraintSatisfaction * Rebuild(const ASTContext &C, const ASTConstraintSatisfaction &Satisfaction)
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
DeclarationName getName() const
getName - Returns the embedded declaration name.
unsigned hasStatic
True if this dimension included the 'static' keyword.
Expr * NumElts
This is the size of the array, or null if [] or [*] was specified.
One instance of this struct is used for each type in a declarator that is parsed.
SourceLocation Loc
Loc - The place where this type was defined.
enum clang::DeclaratorChunk::@340323374315200305336204205154073066142310370142 Kind
ExceptionSpecificationType Type
The kind of exception specification this is.
ArrayRef< QualType > Exceptions
Explicitly-specified list of exception types.
Extra information about a function prototype.
ExceptionSpecInfo ExceptionSpec
unsigned CFIUncheckedCallee
FunctionType::ExtInfo ExtInfo
AlignedAllocationMode PassAlignment
TypeAwareAllocationMode PassTypeIdentity
unsigned getNumImplicitArgs() const
TypeAwareAllocationMode PassTypeIdentity
SizedDeallocationMode PassSize
AlignedAllocationMode PassAlignment
NestedNameSpecifierLoc Prefix
OverloadCandidate - A single candidate in an overload set (C++ 13.3).
Information about a template-id annotation token.
const IdentifierInfo * Name
FIXME: Temporarily stores the name of a specialization.
unsigned NumArgs
NumArgs - The number of template arguments.
SourceLocation TemplateNameLoc
TemplateNameLoc - The location of the template name within the source.
ParsedTemplateArgument * getTemplateArgs()
Retrieves a pointer to the template arguments.
SourceLocation RAngleLoc
The location of the '>' after the template argument list.
SourceLocation LAngleLoc
The location of the '<' before the template argument list.
SourceLocation TemplateKWLoc
TemplateKWLoc - The location of the template keyword.
ParsedTemplateTy Template
The declaration of the template corresponding to the template-name.
StandardConversionSequence Before
Represents the standard conversion that occurs before the actual user-defined conversion.
FunctionDecl * ConversionFunction
ConversionFunction - The function that will perform the user-defined conversion.
bool HadMultipleCandidates
HadMultipleCandidates - When this is true, it means that the conversion function was resolved from an...
StandardConversionSequence After
After - Represents the standard conversion that occurs after the actual user-defined conversion.
bool EllipsisConversion
EllipsisConversion - When this is true, it means user-defined conversion sequence starts with a ....
DeclAccessPair FoundConversionFunction
The declaration that we found via name lookup, which might be the same as ConversionFunction or it mi...