36#include "llvm/Support/TimeProfiler.h"
52template<
typename DeclT>
55 if (!OldDecl->getQualifierLoc())
58 assert((NewDecl->getFriendObjectKind() ||
59 !OldDecl->getLexicalDeclContext()->isDependentContext()) &&
60 "non-friend with qualified name defined in dependent context");
63 const_cast<DeclContext *
>(NewDecl->getFriendObjectKind()
64 ? NewDecl->getLexicalDeclContext()
65 : OldDecl->getLexicalDeclContext()));
74 NewDecl->setQualifierInfo(NewQualifierLoc);
80 return ::SubstQualifier(SemaRef, OldDecl, NewDecl, TemplateArgs);
85 return ::SubstQualifier(SemaRef, OldDecl, NewDecl, TemplateArgs);
89#include "clang/Sema/AttrTemplateInstantiate.inc"
93 const AlignedAttr *Aligned,
Decl *
New,
bool IsPackExpansion) {
94 if (Aligned->isAlignmentExpr()) {
99 if (!Result.isInvalid())
103 S.
SubstType(Aligned->getAlignmentType(), TemplateArgs,
106 Aligned->getLocation(),
107 Result->getTypeLoc().getSourceRange()))
115 const AlignedAttr *Aligned,
Decl *
New) {
116 if (!Aligned->isPackExpansion()) {
122 if (Aligned->isAlignmentExpr())
128 assert(!Unexpanded.empty() &&
"Pack expansion without parameter packs?");
131 bool Expand =
true, RetainExpansion =
false;
136 Unexpanded, TemplateArgs,
138 Expand, RetainExpansion, NumExpansions))
145 for (
unsigned I = 0; I != *NumExpansions; ++I) {
154 const AssumeAlignedAttr *Aligned,
Decl *
New) {
159 Expr *E, *OE =
nullptr;
161 if (Result.isInvalid())
163 E = Result.getAs<
Expr>();
165 if (Aligned->getOffset()) {
166 Result = S.
SubstExpr(Aligned->getOffset(), TemplateArgs);
167 if (Result.isInvalid())
169 OE = Result.getAs<
Expr>();
177 const AlignValueAttr *Aligned,
Decl *
New) {
182 if (!Result.isInvalid())
188 const AllocAlignAttr *Align,
Decl *
New) {
191 llvm::APInt(64, Align->getParamIndex().getSourceIndex()),
204 bool HasDelayedArgs =
Attr->delayedArgs_size();
213 false, TemplateArgs, Args))
216 StringRef Str =
Attr->getAnnotation();
217 if (HasDelayedArgs) {
218 if (Args.size() < 1) {
228 ActualArgs.insert(ActualArgs.begin(), Args.begin() + 1, Args.end());
229 std::swap(Args, ActualArgs);
237template <
typename Attr>
241 Expr *tempInstPriority =
nullptr;
246 if (Result.isInvalid())
248 tempInstPriority = Result.get();
249 if (std::optional<llvm::APSInt> CE =
253 if (!CE->isIntN(32)) {
255 <<
toString(*CE, 10,
false) << 32 << 1;
260 New->addAttr(Attr::Create(
C, tempInstPriority, *A));
272 if (Result.isInvalid())
276 if (!
Cond->isTypeDependent()) {
286 S.
Diag(A->
getLocation(), diag::err_attr_cond_never_constant_expr) << A;
287 for (
const auto &P : Diags)
288 S.
Diag(P.first, P.second);
298 S, TemplateArgs, EIA, EIA->getCond(), Tmpl,
New);
302 Cond, EIA->getMessage()));
309 S, TemplateArgs, DIA, DIA->getCond(), Tmpl,
New);
314 DIA->getDefaultSeverity(), DIA->getWarningGroup(),
315 DIA->getArgDependent(),
New));
328 if (Result.isInvalid())
330 Expr *MaxThreads = Result.getAs<
Expr>();
332 Expr *MinBlocks =
nullptr;
333 if (
Attr.getMinBlocks()) {
335 if (Result.isInvalid())
340 Expr *MaxBlocks =
nullptr;
341 if (
Attr.getMaxBlocks()) {
343 if (Result.isInvalid())
345 MaxBlocks = Result.getAs<
Expr>();
364 if (
auto *FTD = dyn_cast<FunctionTemplateDecl>(
New))
365 New = FTD->getTemplatedDecl();
367 auto *ThisContext = dyn_cast_or_null<CXXRecordDecl>(FD->getDeclContext());
372 if (
auto *DRE = dyn_cast<DeclRefExpr>(E->IgnoreParenImpCasts()))
373 if (
auto *PVD = dyn_cast<ParmVarDecl>(DRE->getDecl())) {
376 if (FD->getNumParams() > PVD->getFunctionScopeIndex())
377 Local.InstantiatedLocal(
378 PVD, FD->getParamDecl(PVD->getFunctionScopeIndex()));
382 FD->isCXXInstanceMember());
398 if (
auto *E =
Attr.getSimdlen())
401 if (
Attr.uniforms_size() > 0) {
402 for(
auto *E :
Attr.uniforms()) {
406 Uniforms.push_back(Inst.
get());
410 auto AI =
Attr.alignments_begin();
411 for (
auto *E :
Attr.aligneds()) {
415 Aligneds.push_back(Inst.
get());
419 Alignments.push_back(Inst.
get());
423 auto SI =
Attr.steps_begin();
424 for (
auto *E :
Attr.linears()) {
428 Linears.push_back(Inst.
get());
432 Steps.push_back(Inst.
get());
435 LinModifiers.append(
Attr.modifiers_begin(),
Attr.modifiers_end());
438 Uniforms, Aligneds, Alignments, Linears, LinModifiers, Steps,
447 if (
auto *FTD = dyn_cast<FunctionTemplateDecl>(
New))
448 New = FTD->getTemplatedDecl();
450 auto *ThisContext = dyn_cast_or_null<CXXRecordDecl>(FD->getDeclContext());
452 auto &&SubstExpr = [FD, ThisContext, &S, &TemplateArgs](
Expr *E) {
453 if (
auto *DRE = dyn_cast<DeclRefExpr>(E->IgnoreParenImpCasts()))
454 if (
auto *PVD = dyn_cast<ParmVarDecl>(DRE->getDecl())) {
457 if (FD->getNumParams() > PVD->getFunctionScopeIndex())
458 Local.InstantiatedLocal(
459 PVD, FD->getParamDecl(PVD->getFunctionScopeIndex()));
463 FD->isCXXInstanceMember());
469 auto &&Subst = [&SubstExpr, &S](
Expr *E) {
479 if (
Expr *E =
Attr.getVariantFuncRef()) {
484 VariantFuncRef = Subst(E);
490 TI = *
Attr.getTraitInfos();
493 auto SubstScoreOrConditionExpr = [&S, Subst](
Expr *&E,
bool) {
508 Expr *E = VariantFuncRef.
get();
512 std::optional<std::pair<FunctionDecl *, Expr *>> DeclVarData =
520 E = DeclVarData->second;
521 FD = DeclVarData->first;
523 if (
auto *VariantDRE = dyn_cast<DeclRefExpr>(E->IgnoreParenImpCasts())) {
524 if (
auto *VariantFD = dyn_cast<FunctionDecl>(VariantDRE->getDecl())) {
525 if (
auto *VariantFTD = VariantFD->getDescribedFunctionTemplate()) {
526 if (!VariantFTD->isThisDeclarationADefinition())
537 SubstFD->getType(), FD->getType(),
543 New->getLocation(), SubstFD,
true,
545 SubstFD->setInstantiationIsPending(!SubstFD->isDefined());
549 SubstFD->getLocation(),
560 for (
Expr *E :
Attr.adjustArgsNothing()) {
564 NothingExprs.push_back(ER.
get());
566 for (
Expr *E :
Attr.adjustArgsNeedDevicePtr()) {
570 NeedDevicePtrExprs.push_back(ER.
get());
572 for (
Expr *E :
Attr.adjustArgsNeedDeviceAddr()) {
576 NeedDeviceAddrExprs.push_back(ER.
get());
580 AppendArgs.emplace_back(II.IsTarget, II.IsTargetSync);
584 FD, E, TI, NothingExprs, NeedDevicePtrExprs, NeedDeviceAddrExprs,
590 const AMDGPUFlatWorkGroupSizeAttr &
Attr,
Decl *
New) {
596 if (Result.isInvalid())
598 Expr *MinExpr = Result.getAs<
Expr>();
601 if (Result.isInvalid())
603 Expr *MaxExpr = Result.getAs<
Expr>();
616 if (Result.isInvalid())
621 if (Result.isInvalid())
626 if (Result.isInvalid())
631 New->addAttr(::new (Context) ReqdWorkGroupSizeAttr(Context,
Attr,
X, Y, Z));
650 if (!
Cond->isTypeDependent())
663 if (Result.isInvalid())
665 Expr *MinExpr = Result.getAs<
Expr>();
667 Expr *MaxExpr =
nullptr;
668 if (
auto Max =
Attr.getMax()) {
670 if (Result.isInvalid())
680 const AMDGPUMaxNumWorkGroupsAttr &
Attr,
Decl *
New) {
684 Expr *XExpr =
nullptr;
685 Expr *YExpr =
nullptr;
686 Expr *ZExpr =
nullptr;
688 if (
Attr.getMaxNumWorkGroupsX()) {
694 if (
Attr.getMaxNumWorkGroupsY()) {
700 if (
Attr.getMaxNumWorkGroupsZ()) {
716 auto SubstElt = [&S, &TemplateArgs](
Expr *E) {
717 return E ? S.
SubstExpr(E, TemplateArgs).
get() :
nullptr;
720 Expr *XExpr = SubstElt(
Attr.getX());
721 Expr *YExpr = SubstElt(
Attr.getY());
722 Expr *ZExpr = SubstElt(
Attr.getZ());
742 if (
const auto *PNA = dyn_cast<PreferredNameAttr>(A)) {
745 if (!
T->isDependentType() && !RD->isDependentContext() &&
748 for (
const auto *ExistingPNA : D->
specific_attrs<PreferredNameAttr>())
750 PNA->getTypedefType()))
755 if (
const auto *BA = dyn_cast<BuiltinAttr>(A)) {
757 switch (BA->getID()) {
758 case Builtin::BIforward:
768 case Builtin::BImove:
769 case Builtin::BImove_if_noexcept:
796 "out or inout parameter type must be a reference and restrict qualified");
800 const MallocSpanAttr *
Attr,
815 for (
const auto *TmplAttr : Tmpl->
attrs()) {
822 *
this, dyn_cast_or_null<CXXRecordDecl>(ND->getDeclContext()),
826 TmplAttr,
Context, *
this, TemplateArgs);
828 New->addAttr(NewAttr);
836 case clang::attr::CFConsumed:
838 case clang::attr::OSConsumed:
840 case clang::attr::NSConsumed:
843 llvm_unreachable(
"Wrong argument supplied");
850 const OpenACCRoutineDeclAttr *OldAttr,
const Decl *Old,
Decl *
New);
856 for (
const auto *TmplAttr : Tmpl->
attrs()) {
861 const AlignedAttr *Aligned = dyn_cast<AlignedAttr>(TmplAttr);
862 if (Aligned && Aligned->isAlignmentDependent()) {
867 if (
const auto *AssumeAligned = dyn_cast<AssumeAlignedAttr>(TmplAttr)) {
872 if (
const auto *AlignValue = dyn_cast<AlignValueAttr>(TmplAttr)) {
877 if (
const auto *AllocAlign = dyn_cast<AllocAlignAttr>(TmplAttr)) {
882 if (
const auto *Annotate = dyn_cast<AnnotateAttr>(TmplAttr)) {
887 if (
auto *
Constructor = dyn_cast<ConstructorAttr>(TmplAttr)) {
893 if (
auto *
Destructor = dyn_cast<DestructorAttr>(TmplAttr)) {
899 if (
const auto *EnableIf = dyn_cast<EnableIfAttr>(TmplAttr)) {
905 if (
const auto *DiagnoseIf = dyn_cast<DiagnoseIfAttr>(TmplAttr)) {
911 if (
const auto *CUDALaunchBounds =
912 dyn_cast<CUDALaunchBoundsAttr>(TmplAttr)) {
914 *CUDALaunchBounds,
New);
918 if (
const auto *Mode = dyn_cast<ModeAttr>(TmplAttr)) {
923 if (
const auto *OMPAttr = dyn_cast<OMPDeclareSimdDeclAttr>(TmplAttr)) {
928 if (
const auto *OMPAttr = dyn_cast<OMPDeclareVariantAttr>(TmplAttr)) {
933 if (
const auto *ReqdWorkGroupSize =
934 dyn_cast<ReqdWorkGroupSizeAttr>(TmplAttr)) {
936 *ReqdWorkGroupSize,
New);
939 if (
const auto *AMDGPUFlatWorkGroupSize =
940 dyn_cast<AMDGPUFlatWorkGroupSizeAttr>(TmplAttr)) {
942 *
this, TemplateArgs, *AMDGPUFlatWorkGroupSize,
New);
945 if (
const auto *AMDGPUFlatWorkGroupSize =
946 dyn_cast<AMDGPUWavesPerEUAttr>(TmplAttr)) {
948 *AMDGPUFlatWorkGroupSize,
New);
951 if (
const auto *AMDGPUMaxNumWorkGroups =
952 dyn_cast<AMDGPUMaxNumWorkGroupsAttr>(TmplAttr)) {
954 *
this, TemplateArgs, *AMDGPUMaxNumWorkGroups,
New);
957 if (
const auto *CUDAClusterDims = dyn_cast<CUDAClusterDimsAttr>(TmplAttr)) {
959 *CUDAClusterDims,
New);
962 if (
const auto *ParamAttr = dyn_cast<HLSLParamModifierAttr>(TmplAttr)) {
968 if (
const auto *RoutineAttr = dyn_cast<OpenACCRoutineDeclAttr>(TmplAttr)) {
970 RoutineAttr, Tmpl,
New);
975 if (TmplAttr->getKind() == attr::DLLExport ||
976 TmplAttr->getKind() == attr::DLLImport) {
977 if (
New->hasAttr<DLLExportAttr>() ||
New->hasAttr<DLLImportAttr>()) {
982 if (
const auto *ABIAttr = dyn_cast<ParameterABIAttr>(TmplAttr)) {
995 if (
auto *A = dyn_cast<PointerAttr>(TmplAttr)) {
996 if (!
New->hasAttr<PointerAttr>())
1001 if (
auto *A = dyn_cast<OwnerAttr>(TmplAttr)) {
1002 if (!
New->hasAttr<OwnerAttr>())
1007 if (
auto *A = dyn_cast<SYCLKernelAttr>(TmplAttr)) {
1012 if (
auto *A = dyn_cast<CUDAGridConstantAttr>(TmplAttr)) {
1013 if (!
New->hasAttr<CUDAGridConstantAttr>())
1018 if (
auto *A = dyn_cast<MallocSpanAttr>(TmplAttr)) {
1023 if (
auto *A = dyn_cast<CleanupAttr>(TmplAttr)) {
1024 if (!
New->hasAttr<CleanupAttr>()) {
1025 auto *NewAttr = A->clone(
Context);
1026 NewAttr->setArgLoc(A->getArgLoc());
1027 New->addAttr(NewAttr);
1032 assert(!TmplAttr->isPackExpansion());
1033 if (TmplAttr->isLateParsed() && LateAttrs) {
1043 auto *ThisContext = dyn_cast_or_null<CXXRecordDecl>(ND->getDeclContext());
1045 ND->isCXXInstanceMember());
1048 *
this, TemplateArgs);
1050 New->addAttr(NewAttr);
1056 for (
const auto *
Attr : Pattern->
attrs()) {
1057 if (
auto *A = dyn_cast<StrictFPAttr>(
Attr)) {
1058 if (!Inst->
hasAttr<StrictFPAttr>())
1066 assert(
Context.getTargetInfo().getCXXABI().isMicrosoft() &&
1071 DLLExportAttr *
Attr = Ctor->
getAttr<DLLExportAttr>();
1074 for (
unsigned I = 0; I != NumParams; ++I) {
1085template<
typename DeclT>
1087 DeclT *Result = D->getPreviousDecl();
1093 D->getLexicalDeclContext() != Result->getLexicalDeclContext())
1101 llvm_unreachable(
"Translation units cannot be instantiated");
1105 llvm_unreachable(
"HLSL buffer declarations cannot be instantiated");
1108Decl *TemplateDeclInstantiator::VisitHLSLRootSignatureDecl(
1110 llvm_unreachable(
"HLSL root signature declarations cannot be instantiated");
1115 llvm_unreachable(
"pragma comment cannot be instantiated");
1118Decl *TemplateDeclInstantiator::VisitPragmaDetectMismatchDecl(
1120 llvm_unreachable(
"pragma comment cannot be instantiated");
1125 llvm_unreachable(
"extern \"C\" context cannot be instantiated");
1129 llvm_unreachable(
"GUID declaration cannot be instantiated");
1132Decl *TemplateDeclInstantiator::VisitUnnamedGlobalConstantDecl(
1134 llvm_unreachable(
"UnnamedGlobalConstantDecl cannot be instantiated");
1137Decl *TemplateDeclInstantiator::VisitTemplateParamObjectDecl(
1139 llvm_unreachable(
"template parameter objects cannot be instantiated");
1143TemplateDeclInstantiator::VisitLabelDecl(
LabelDecl *D) {
1146 SemaRef.InstantiateAttrs(TemplateArgs, D, Inst, LateAttrs, StartingScope);
1147 Owner->addDecl(Inst);
1152TemplateDeclInstantiator::VisitNamespaceDecl(
NamespaceDecl *D) {
1153 llvm_unreachable(
"Namespaces cannot be instantiated");
1157class OpenACCDeclClauseInstantiator final
1160 const MultiLevelTemplateArgumentList &MLTAL;
1161 ArrayRef<OpenACCClause *> ExistingClauses;
1162 SemaOpenACC::OpenACCParsedClause &ParsedClause;
1163 OpenACCClause *NewClause =
nullptr;
1166 OpenACCDeclClauseInstantiator(Sema &S,
1167 const MultiLevelTemplateArgumentList &MLTAL,
1168 ArrayRef<OpenACCClause *> ExistingClauses,
1169 SemaOpenACC::OpenACCParsedClause &ParsedClause)
1170 : SemaRef(S), MLTAL(MLTAL), ExistingClauses(ExistingClauses),
1171 ParsedClause(ParsedClause) {}
1173 OpenACCClause *CreatedClause() {
return NewClause; }
1174#define VISIT_CLAUSE(CLAUSE_NAME) \
1175 void Visit##CLAUSE_NAME##Clause(const OpenACC##CLAUSE_NAME##Clause &Clause);
1176#include "clang/Basic/OpenACCClauses.def"
1180 for (
Expr *CurVar : VarList) {
1181 ExprResult Res = SemaRef.SubstExpr(CurVar, MLTAL);
1190 InstantiatedVarList.push_back(Res.
get());
1192 return InstantiatedVarList;
1196#define CLAUSE_NOT_ON_DECLS(CLAUSE_NAME) \
1197 void OpenACCDeclClauseInstantiator::Visit##CLAUSE_NAME##Clause( \
1198 const OpenACC##CLAUSE_NAME##Clause &) { \
1199 llvm_unreachable("Clause type invalid on declaration construct, or " \
1200 "instantiation not implemented"); \
1229#undef CLAUSE_NOT_ON_DECLS
1231void OpenACCDeclClauseInstantiator::VisitGangClause(
1235 assert(
C.getNumExprs() <= 1 &&
1236 "Only 1 expression allowed on gang clause in routine");
1238 if (
C.getNumExprs() > 0) {
1240 "Only dim allowed on routine");
1242 SemaRef.SubstExpr(
const_cast<Expr *
>(
C.getExpr(0).second), MLTAL);
1244 ER = SemaRef.OpenACC().CheckGangExpr(ExistingClauses,
1245 ParsedClause.getDirectiveKind(),
1246 C.getExpr(0).first, ER.
get());
1249 TransformedIntExprs.push_back(ER.
get());
1254 NewClause = SemaRef.OpenACC().CheckGangClause(
1255 ParsedClause.getDirectiveKind(), ExistingClauses,
1256 ParsedClause.getBeginLoc(), ParsedClause.getLParenLoc(),
1257 TransformedGangKinds, TransformedIntExprs, ParsedClause.getEndLoc());
1262 ParsedClause.getBeginLoc(),
1263 ParsedClause.getEndLoc());
1265void OpenACCDeclClauseInstantiator::VisitNoHostClause(
1268 ParsedClause.getBeginLoc(),
1269 ParsedClause.getEndLoc());
1272void OpenACCDeclClauseInstantiator::VisitDeviceTypeClause(
1276 SemaRef.getASTContext(),
C.getClauseKind(), ParsedClause.getBeginLoc(),
1277 ParsedClause.getLParenLoc(),
C.getArchitectures(),
1278 ParsedClause.getEndLoc());
1281void OpenACCDeclClauseInstantiator::VisitWorkerClause(
1283 assert(!
C.hasIntExpr() &&
"Int Expr not allowed on routine 'worker' clause");
1285 ParsedClause.getBeginLoc(), {},
1286 nullptr, ParsedClause.getEndLoc());
1289void OpenACCDeclClauseInstantiator::VisitVectorClause(
1291 assert(!
C.hasIntExpr() &&
"Int Expr not allowed on routine 'vector' clause");
1293 ParsedClause.getBeginLoc(), {},
1294 nullptr, ParsedClause.getEndLoc());
1297void OpenACCDeclClauseInstantiator::VisitCopyClause(
1299 ParsedClause.setVarListDetails(VisitVarList(
C.getVarList()),
1300 C.getModifierList());
1301 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
C.getModifierList()))
1304 SemaRef.getASTContext(), ParsedClause.getClauseKind(),
1305 ParsedClause.getBeginLoc(), ParsedClause.getLParenLoc(),
1306 ParsedClause.getModifierList(), ParsedClause.getVarList(),
1307 ParsedClause.getEndLoc());
1310void OpenACCDeclClauseInstantiator::VisitLinkClause(
1312 ParsedClause.setVarListDetails(
1313 SemaRef.OpenACC().CheckLinkClauseVarList(VisitVarList(
C.getVarList())),
1316 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
1321 SemaRef.getASTContext(), ParsedClause.getBeginLoc(),
1322 ParsedClause.getLParenLoc(), ParsedClause.getVarList(),
1323 ParsedClause.getEndLoc());
1326void OpenACCDeclClauseInstantiator::VisitDeviceResidentClause(
1328 ParsedClause.setVarListDetails(VisitVarList(
C.getVarList()),
1330 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
1334 SemaRef.getASTContext(), ParsedClause.getBeginLoc(),
1335 ParsedClause.getLParenLoc(), ParsedClause.getVarList(),
1336 ParsedClause.getEndLoc());
1339void OpenACCDeclClauseInstantiator::VisitCopyInClause(
1341 ParsedClause.setVarListDetails(VisitVarList(
C.getVarList()),
1342 C.getModifierList());
1344 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
C.getModifierList()))
1347 SemaRef.getASTContext(), ParsedClause.getClauseKind(),
1348 ParsedClause.getBeginLoc(), ParsedClause.getLParenLoc(),
1349 ParsedClause.getModifierList(), ParsedClause.getVarList(),
1350 ParsedClause.getEndLoc());
1352void OpenACCDeclClauseInstantiator::VisitCopyOutClause(
1354 ParsedClause.setVarListDetails(VisitVarList(
C.getVarList()),
1355 C.getModifierList());
1357 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
C.getModifierList()))
1360 SemaRef.getASTContext(), ParsedClause.getClauseKind(),
1361 ParsedClause.getBeginLoc(), ParsedClause.getLParenLoc(),
1362 ParsedClause.getModifierList(), ParsedClause.getVarList(),
1363 ParsedClause.getEndLoc());
1365void OpenACCDeclClauseInstantiator::VisitCreateClause(
1367 ParsedClause.setVarListDetails(VisitVarList(
C.getVarList()),
1368 C.getModifierList());
1370 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
C.getModifierList()))
1373 SemaRef.getASTContext(), ParsedClause.getClauseKind(),
1374 ParsedClause.getBeginLoc(), ParsedClause.getLParenLoc(),
1375 ParsedClause.getModifierList(), ParsedClause.getVarList(),
1376 ParsedClause.getEndLoc());
1378void OpenACCDeclClauseInstantiator::VisitPresentClause(
1380 ParsedClause.setVarListDetails(VisitVarList(
C.getVarList()),
1382 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
1386 SemaRef.getASTContext(), ParsedClause.getBeginLoc(),
1387 ParsedClause.getLParenLoc(), ParsedClause.getVarList(),
1388 ParsedClause.getEndLoc());
1390void OpenACCDeclClauseInstantiator::VisitDevicePtrClause(
1394 llvm::erase_if(VarList, [&](
Expr *E) {
1399 if (SemaRef.OpenACC().CheckDeclareClause(ParsedClause,
1403 SemaRef.getASTContext(), ParsedClause.getBeginLoc(),
1404 ParsedClause.getLParenLoc(), ParsedClause.getVarList(),
1405 ParsedClause.getEndLoc());
1408void OpenACCDeclClauseInstantiator::VisitBindClause(
1411 if (
C.isStringArgument())
1413 SemaRef.getASTContext(), ParsedClause.getBeginLoc(),
1414 ParsedClause.getLParenLoc(),
C.getStringArgument(),
1415 ParsedClause.getEndLoc());
1418 SemaRef.getASTContext(), ParsedClause.getBeginLoc(),
1419 ParsedClause.getLParenLoc(),
C.getIdentifierArgument(),
1420 ParsedClause.getEndLoc());
1428 for (
const auto *Clause : ClauseList) {
1430 Clause->getBeginLoc());
1431 ParsedClause.setEndLoc(Clause->getEndLoc());
1432 if (
const auto *WithParms = dyn_cast<OpenACCClauseWithParams>(Clause))
1433 ParsedClause.setLParenLoc(WithParms->getLParenLoc());
1435 OpenACCDeclClauseInstantiator Instantiator{S, MLTAL, TransformedClauses,
1437 Instantiator.Visit(Clause);
1438 if (Instantiator.CreatedClause())
1439 TransformedClauses.push_back(Instantiator.CreatedClause());
1441 return TransformedClauses;
1448 const OpenACCRoutineDeclAttr *OldAttr,
const Decl *OldDecl,
Decl *NewDecl) {
1449 OpenACCRoutineDeclAttr *A =
1450 OpenACCRoutineDeclAttr::Create(S.
getASTContext(), OldAttr->getLocation());
1452 if (!OldAttr->Clauses.empty()) {
1454 InstantiateOpenACCClauseList(
1456 A->Clauses.assign(TransformedClauses.begin(), TransformedClauses.end());
1467 llvm::SmallVector<OpenACCClause *> TransformedClauses =
1471 if (SemaRef.OpenACC().ActOnStartDeclDirective(
1475 DeclGroupRef Res = SemaRef.OpenACC().ActOnEndDeclDirective(
1487 llvm::SmallVector<OpenACCClause *> TransformedClauses =
1495 FuncRef = SemaRef.OpenACC().ActOnRoutineName(FuncRef.
get());
1500 if (SemaRef.OpenACC().ActOnStartDeclDirective(
1504 DeclGroupRef Res = SemaRef.OpenACC().ActOnEndRoutineDeclDirective(
1516 NamespaceAliasDecl *Inst
1524 Owner->addDecl(Inst);
1534 TSI = SemaRef.SubstType(TSI, TemplateArgs, D->
getLocation(),
1538 TSI = SemaRef.Context.getTrivialTypeSourceInfo(SemaRef.Context.IntTy);
1549 if (SemaRef.getPreprocessor().NeedsStdLibCxxWorkaroundBefore(2014'04'22)) {
1550 const DecltypeType *DT = TSI->
getType()->
getAs<DecltypeType>();
1553 DT->isReferenceType() &&
1554 RD->getEnclosingNamespaceContext() == SemaRef.getStdNamespace() &&
1555 RD->getIdentifier() && RD->getIdentifier()->isStr(
"common_type") &&
1557 SemaRef.getSourceManager().isInSystemHeader(D->
getBeginLoc()))
1559 TSI = SemaRef.Context.getTrivialTypeSourceInfo(
1577 TagDecl *oldTag = oldTagType->getDecl();
1594 SemaRef.isIncompatibleTypedef(InstPrevTypedef,
Typedef);
1596 Typedef->setPreviousDecl(InstPrevTypedef);
1599 SemaRef.InstantiateAttrs(TemplateArgs, D,
Typedef);
1602 SemaRef.inferGslPointerAttribute(
Typedef);
1651 if (!
Found.empty()) {
1652 PrevAliasTemplate = dyn_cast<TypeAliasTemplateDecl>(
Found.front());
1665 if (PrevAliasTemplate)
1670 if (!PrevAliasTemplate)
1697 SmallVector<BindingDecl*, 16> NewBindings;
1698 BindingDecl *OldBindingPack =
nullptr;
1699 for (
auto *OldBD : D->
bindings()) {
1700 Expr *BindingExpr = OldBD->getBinding();
1701 if (isa_and_present<FunctionParmPackExpr>(BindingExpr)) {
1703 assert(!OldBindingPack &&
"no more than one pack is allowed");
1704 OldBindingPack = OldBD;
1708 ArrayRef<BindingDecl*> NewBindingArray = NewBindings;
1710 auto *NewDD = cast_if_present<DecompositionDecl>(
1713 if (!NewDD || NewDD->isInvalidDecl()) {
1714 for (
auto *NewBD : NewBindings)
1715 NewBD->setInvalidDecl();
1716 }
else if (OldBindingPack) {
1719 BindingDecl *NewBindingPack = *llvm::find_if(
1721 assert(NewBindingPack !=
nullptr &&
"new bindings should also have a pack");
1722 llvm::ArrayRef<BindingDecl *> OldDecls =
1724 llvm::ArrayRef<BindingDecl *> NewDecls =
1726 assert(OldDecls.size() == NewDecls.size());
1727 for (
unsigned I = 0; I < OldDecls.size(); I++)
1728 SemaRef.CurrentInstantiationScope->InstantiatedLocal(OldDecls[I],
1740 bool InstantiatingVarTemplate,
1751 SemaRef.
Diag(D->
getLocation(), diag::err_variable_instantiates_to_function)
1784 StartingScope, InstantiatingVarTemplate);
1787 if (
auto *F = dyn_cast<FunctionDecl>(DC))
1788 RT = F->getReturnType();
1793 llvm_unreachable(
"Unknown context type");
1814 SemaRef.CheckStaticLocalForDllExport(Var);
1817 SemaRef.CheckThreadLocalForLargeAlignment(Var);
1819 if (SemaRef.getLangOpts().OpenACC)
1820 SemaRef.OpenACC().ActOnVariableDeclarator(Var);
1829 Owner->addHiddenDecl(AD);
1833Decl *TemplateDeclInstantiator::VisitFieldDecl(
FieldDecl *D) {
1838 TSI = SemaRef.SubstType(TSI, TemplateArgs, D->
getLocation(),
1850 SemaRef.Diag(D->
getLocation(), diag::err_field_instantiates_to_function)
1861 else if (BitWidth) {
1867 = SemaRef.SubstExpr(BitWidth, TemplateArgs);
1872 BitWidth = InstantiatedBitWidth.
getAs<Expr>();
1875 FieldDecl *
Field = SemaRef.CheckFieldDecl(
1884 SemaRef.InstantiateAttrs(TemplateArgs, D, Field, LateAttrs, StartingScope);
1886 if (
Field->hasAttrs())
1887 SemaRef.CheckAlignasUnderalignment(Field);
1890 Field->setInvalidDecl();
1892 if (!
Field->getDeclName() ||
Field->isPlaceholderVar(SemaRef.getLangOpts())) {
1894 SemaRef.Context.setInstantiatedFromUnnamedFieldDecl(Field, D);
1896 if (CXXRecordDecl *Parent= dyn_cast<CXXRecordDecl>(
Field->getDeclContext())) {
1897 if (Parent->isAnonymousStructOrUnion() &&
1898 Parent->getRedeclContext()->isFunctionOrMethod())
1899 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Field);
1904 Owner->addDecl(Field);
1914 SemaRef.Diag(D->
getLocation(), diag::err_property_is_variably_modified)
1918 TSI = SemaRef.SubstType(TSI, TemplateArgs, D->
getLocation(),
1930 SemaRef.Diag(D->
getLocation(), diag::err_field_instantiates_to_function)
1943 SemaRef.InstantiateAttrs(TemplateArgs, D,
Property, LateAttrs,
1956 NamedDecl **NamedChain =
1960 for (
auto *PI : D->
chain()) {
1966 NamedChain[i++] =
Next;
1972 {NamedChain, D->getChainingSize()});
1974 for (
const auto *Attr : D->
attrs())
1975 IndirectField->
addAttr(Attr->clone(SemaRef.Context));
1979 Owner->addDecl(IndirectField);
1980 return IndirectField;
1987 TypeSourceInfo *InstTy;
1996 SmallVector<UnexpandedParameterPack, 2> Unexpanded;
1997 SemaRef.collectUnexpandedParameterPacks(Ty->getTypeLoc(), Unexpanded);
1998 assert(!Unexpanded.empty() &&
"Pack expansion without packs");
2000 bool ShouldExpand =
true;
2001 bool RetainExpansion =
false;
2002 UnsignedOrNone NumExpansions = std::nullopt;
2003 if (SemaRef.CheckParameterPacksForExpansion(
2006 ShouldExpand, RetainExpansion, NumExpansions))
2009 assert(!RetainExpansion &&
2010 "should never retain an expansion for a variadic friend decl");
2013 SmallVector<FriendDecl *> Decls;
2014 for (
unsigned I = 0; I != *NumExpansions; I++) {
2015 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, I);
2016 TypeSourceInfo *TSI = SemaRef.SubstType(
2027 Decls.push_back(FD);
2035 InstTy = SemaRef.SubstType(Ty, TemplateArgs, D->
getLocation(),
2050 assert(ND &&
"friend decl must be a decl or a type!");
2057 if (!NewND)
return nullptr;
2076 = SemaRef.SubstExpr(AssertExpr, TemplateArgs);
2081 SemaRef.SubstExpr(D->
getMessage(), TemplateArgs);
2082 if (InstantiatedMessageExpr.
isInvalid())
2085 return SemaRef.BuildStaticAssertDeclaration(
2090Decl *TemplateDeclInstantiator::VisitEnumDecl(
EnumDecl *D) {
2091 EnumDecl *PrevDecl =
nullptr;
2093 NamedDecl *Prev = SemaRef.FindInstantiatedDecl(D->
getLocation(),
2096 if (!Prev)
return nullptr;
2109 SourceLocation UnderlyingLoc = TI->getTypeLoc().getBeginLoc();
2110 TypeSourceInfo *NewTI = SemaRef.SubstType(TI, TemplateArgs, UnderlyingLoc,
2112 if (!NewTI || SemaRef.CheckEnumUnderlyingType(NewTI))
2113 Enum->setIntegerType(SemaRef.Context.IntTy);
2123 Enum->setIntegerTypeSourceInfo(NewTI);
2133 QualType UnderlyingType =
Enum->getIntegerType();
2134 Enum->setPromotionType(
2135 SemaRef.Context.isPromotableIntegerType(UnderlyingType)
2136 ? SemaRef.Context.getPromotedIntegerType(UnderlyingType)
2140 &&
"Dependent type without type source info");
2145 SemaRef.InstantiateAttrs(TemplateArgs, D,
Enum);
2150 SemaRef.Context.setManglingNumber(
Enum, SemaRef.Context.getManglingNumber(D));
2153 if (DeclaratorDecl *DD = SemaRef.Context.getDeclaratorForUnnamedTagDecl(D))
2154 SemaRef.Context.addDeclaratorForUnnamedTagDecl(
Enum, DD);
2157 if (TypedefNameDecl *TND = SemaRef.Context.getTypedefNameForUnnamedTagDecl(D))
2158 SemaRef.Context.addTypedefNameForUnnamedTagDecl(
Enum, TND);
2160 Owner->addDecl(
Enum);
2163 if (Def && Def != D) {
2168 SourceLocation UnderlyingLoc = TI->getTypeLoc().getBeginLoc();
2169 QualType DefnUnderlying =
2170 SemaRef.SubstType(TI->getType(), TemplateArgs,
2171 UnderlyingLoc, DeclarationName());
2173 DefnUnderlying,
true,
Enum);
2188 if (PrevDecl ==
nullptr) {
2189 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D,
Enum);
2199 Enum->startDefinition();
2210 if (
Expr *UninstValue = EC->getInitExpr()) {
2215 Value = SemaRef.SubstExpr(UninstValue, TemplateArgs);
2220 if (
Value.isInvalid()) {
2226 = SemaRef.CheckEnumConstant(
Enum, LastEnumConst,
2233 Enum->setInvalidDecl();
2237 SemaRef.InstantiateAttrs(TemplateArgs, EC, EnumConst);
2240 Enum->addDecl(EnumConst);
2241 Enumerators.push_back(EnumConst);
2242 LastEnumConst = EnumConst;
2245 !
Enum->isScoped()) {
2248 SemaRef.CurrentInstantiationScope->InstantiatedLocal(EC, EnumConst);
2253 SemaRef.ActOnEnumBody(
Enum->getLocation(),
Enum->getBraceRange(),
Enum,
2258 llvm_unreachable(
"EnumConstantDecls can only occur within EnumDecls.");
2263 llvm_unreachable(
"BuiltinTemplateDecls cannot be instantiated.");
2271 LocalInstantiationScope Scope(SemaRef);
2284 QualifierLoc = SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc,
2290 CXXRecordDecl *PrevDecl =
nullptr;
2291 ClassTemplateDecl *PrevClassTemplate =
nullptr;
2295 if (!
Found.empty()) {
2296 PrevClassTemplate = dyn_cast<ClassTemplateDecl>(
Found.front());
2297 if (PrevClassTemplate)
2306 DeclContext *DC = Owner;
2310 SS.
Adopt(QualifierLoc);
2311 DC = SemaRef.computeDeclContext(SS);
2312 if (!DC)
return nullptr;
2314 DC = SemaRef.FindInstantiatedContext(Pattern->
getLocation(),
2323 SemaRef.forRedeclarationInCurContext());
2324 SemaRef.LookupQualifiedName(R, DC);
2326 if (R.isSingleResult()) {
2327 PrevClassTemplate = R.getAsSingle<ClassTemplateDecl>();
2328 if (PrevClassTemplate)
2332 if (!PrevClassTemplate && QualifierLoc) {
2333 SemaRef.Diag(Pattern->
getLocation(), diag::err_not_tag_in_scope)
2346 SemaRef.InstantiateAttrsForDecl(TemplateArgs, Pattern, RecordInst, LateAttrs,
2349 ClassTemplateDecl *Inst
2355 assert(!Owner->isDependentContext());
2360 if (PrevClassTemplate) {
2362 const ClassTemplateDecl *MostRecentPrevCT =
2364 TemplateParameterList *PrevParams =
2368 if (!SemaRef.TemplateParameterListsAreEqual(
2375 if (SemaRef.CheckTemplateParameterList(InstParams, PrevParams,
2389 if (!PrevClassTemplate)
2406 Owner->addDecl(Inst);
2408 if (!PrevClassTemplate) {
2412 SmallVector<ClassTemplatePartialSpecializationDecl *, 4> PartialSpecs;
2414 for (
unsigned I = 0, N = PartialSpecs.size(); I != N; ++I)
2415 if (PartialSpecs[I]->getFirstDecl()->isOutOfLine())
2416 OutOfLinePartialSpecs.push_back(std::make_pair(Inst, PartialSpecs[I]));
2423TemplateDeclInstantiator::VisitClassTemplatePartialSpecializationDecl(
2434 ClassTemplateDecl *InstClassTemplate
2435 = dyn_cast<ClassTemplateDecl>(
Found.front());
2436 if (!InstClassTemplate)
2439 if (ClassTemplatePartialSpecializationDecl *
Result
2448 "Only static data member templates are allowed.");
2452 LocalInstantiationScope Scope(SemaRef);
2459 VarTemplateDecl *PrevVarTemplate =
nullptr;
2464 PrevVarTemplate = dyn_cast<VarTemplateDecl>(
Found.front());
2470 if (!VarInst)
return nullptr;
2472 DeclContext *DC = Owner;
2481 if (!PrevVarTemplate)
2489 Owner->addDecl(Inst);
2491 if (!PrevVarTemplate) {
2495 SmallVector<VarTemplatePartialSpecializationDecl *, 1> PartialSpecs;
2497 for (
unsigned I = 0, N = PartialSpecs.size(); I != N; ++I)
2498 if (PartialSpecs[I]->getFirstDecl()->isOutOfLine())
2499 OutOfLineVarPartialSpecs.push_back(
2500 std::make_pair(Inst, PartialSpecs[I]));
2506Decl *TemplateDeclInstantiator::VisitVarTemplatePartialSpecializationDecl(
2509 "Only static data member templates are allowed.");
2515 assert(!
Found.empty() &&
"Instantiation found nothing?");
2517 VarTemplateDecl *InstVarTemplate = dyn_cast<VarTemplateDecl>(
Found.front());
2518 assert(InstVarTemplate &&
"Instantiation did not find a variable template?");
2520 if (VarTemplatePartialSpecializationDecl *
Result =
2533 LocalInstantiationScope Scope(SemaRef);
2534 Sema::ConstraintEvalRAII<TemplateDeclInstantiator> RAII(*
this);
2541 FunctionDecl *Instantiated =
nullptr;
2542 if (CXXMethodDecl *DMethod = dyn_cast<CXXMethodDecl>(D->
getTemplatedDecl()))
2555 FunctionTemplateDecl *InstTemplate
2558 assert(InstTemplate &&
2559 "VisitFunctionDecl/CXXMethodDecl didn't create a template!");
2571 Owner->addDecl(InstTemplate);
2574 SemaRef.CheckFriendAccess(InstTemplate);
2577 return InstTemplate;
2581 CXXRecordDecl *PrevDecl =
nullptr;
2583 NamedDecl *Prev = SemaRef.FindInstantiatedDecl(D->
getLocation(),
2586 if (!Prev)
return nullptr;
2590 CXXRecordDecl *
Record =
nullptr;
2608 SemaRef.InstantiateAttrsForDecl(TemplateArgs, D,
Record, LateAttrs,
2616 if (!IsInjectedClassName)
2622 Record->setObjectOfFriendDecl();
2626 Record->setAnonymousStructOrUnion(
true);
2629 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D,
Record);
2632 SemaRef.Context.setManglingNumber(
Record,
2633 SemaRef.Context.getManglingNumber(D));
2637 if (DeclaratorDecl *DD = SemaRef.Context.getDeclaratorForUnnamedTagDecl(D))
2638 SemaRef.Context.addDeclaratorForUnnamedTagDecl(
Record, DD);
2642 if (TypedefNameDecl *TND = SemaRef.Context.getTypedefNameForUnnamedTagDecl(D))
2643 SemaRef.Context.addTypedefNameForUnnamedTagDecl(
Record, TND);
2650 Sema::LocalEagerInstantiationScope LocalInstantiations(SemaRef,
2665 LocalInstantiations.perform();
2668 SemaRef.DiagnoseUnusedNestedTypedefs(
Record);
2670 if (IsInjectedClassName)
2671 assert(
Record->isInjectedClassName() &&
"Broken injected-class-name");
2689 if (OrigFunc->
getExtInfo() == NewFunc->getExtInfo())
2694 return Context.getFunctionType(NewFunc->getReturnType(),
2695 NewFunc->getParamTypes(), NewEPI);
2719 if (isFriend && Source->wasThisDeclarationADefinition(D)) {
2731 void *InsertPos =
nullptr;
2740 bool MergeWithParentScope = (TemplateParams !=
nullptr) ||
2741 Owner->isFunctionOrMethod() ||
2743 cast<Decl>(Owner)->isDefinedOutsideFunctionOrMethod());
2747 if (
auto *DGuide = dyn_cast<CXXDeductionGuideDecl>(D)) {
2748 InstantiatedExplicitSpecifier = SemaRef.instantiateExplicitSpecifier(
2749 TemplateArgs, DGuide->getExplicitSpecifier());
2750 if (InstantiatedExplicitSpecifier.
isInvalid())
2760 if (TemplateParams && TemplateParams->
size()) {
2762 dyn_cast<TemplateTypeParmDecl>(TemplateParams->
asArray().back());
2763 if (LastParam && LastParam->isImplicit() &&
2764 LastParam->hasTypeConstraint()) {
2779 QualifierLoc = SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc,
2793 SemaRef.adjustContextForLocalExternDecl(DC);
2794 }
else if (isFriend && QualifierLoc) {
2796 SS.
Adopt(QualifierLoc);
2797 DC = SemaRef.computeDeclContext(SS);
2798 if (!DC)
return nullptr;
2805 = SemaRef.SubstDeclarationNameInfo(D->
getNameInfo(), TemplateArgs);
2811 if (
auto *DGuide = dyn_cast<CXXDeductionGuideDecl>(D)) {
2814 InstantiatedExplicitSpecifier, NameInfo,
T, TInfo,
2816 DGuide->getDeductionCandidateKind(), TrailingRequiresClause,
2817 DGuide->getSourceDeductionGuide(),
2818 DGuide->getSourceDeductionGuideKind());
2825 TrailingRequiresClause);
2826 Function->setFriendConstraintRefersToEnclosingTemplate(
2835 Function->setQualifierInfo(QualifierLoc);
2846 LexicalDC = SemaRef.CurContext;
2850 Function->setIsTypeAwareOperatorNewOrDelete(
2852 Function->setLexicalDeclContext(LexicalDC);
2855 for (
unsigned P = 0; P < Params.size(); ++P)
2857 Params[P]->setOwningFunction(
Function);
2860 if (TrailingRequiresClause)
2861 Function->setTrailingRequiresClause(TrailingRequiresClause);
2863 if (TemplateParams) {
2891 SemaRef.CodeSynthesisContexts.back().Kind !=
2905 }
else if (!isFriend) {
2909 Function->setInstantiatedFromDecl(D);
2916 FT->setObjectOfFriendDecl();
2922 bool IsExplicitSpecialization =
false;
2929 : SemaRef.forRedeclarationInCurContext());
2933 assert(isFriend &&
"dependent specialization info on "
2934 "non-member non-friend function?");
2938 if (
const auto *ArgsWritten = DFTSI->TemplateArgumentsAsWritten) {
2939 ExplicitArgs.
setLAngleLoc(ArgsWritten->getLAngleLoc());
2940 ExplicitArgs.
setRAngleLoc(ArgsWritten->getRAngleLoc());
2941 if (SemaRef.SubstTemplateArguments(ArgsWritten->arguments(), TemplateArgs,
2949 SemaRef.FindInstantiatedDecl(D->
getLocation(), FTD, TemplateArgs))
2955 if (SemaRef.CheckFunctionTemplateSpecialization(
2957 DFTSI->TemplateArgumentsAsWritten ? &ExplicitArgs :
nullptr,
2961 IsExplicitSpecialization =
true;
2965 SemaRef.LookupQualifiedName(
Previous, DC);
2969 ArgsWritten->getRAngleLoc());
2970 if (SemaRef.SubstTemplateArguments(ArgsWritten->arguments(), TemplateArgs,
2974 if (SemaRef.CheckFunctionTemplateSpecialization(
Function,
2979 IsExplicitSpecialization =
true;
2996 if (isFriend && !QualifierLoc) {
2997 SemaRef.FilterLookupForScope(
Previous, DC,
nullptr,
3016 if (
Function->isLocalExternDecl()) {
3018 if (!PVD->hasDefaultArg())
3020 if (SemaRef.SubstDefaultArgument(D->
getInnerLocStart(), PVD, TemplateArgs)) {
3024 Expr *UninstExpr = PVD->getUninstantiatedDefaultArg();
3025 ExprResult ErrorResult = SemaRef.CreateRecoveryExpr(
3027 { UninstExpr }, UninstExpr->
getType());
3029 PVD->setDefaultArg(ErrorResult.
get());
3035 IsExplicitSpecialization,
3036 Function->isThisDeclarationADefinition());
3043 SemaRef.CheckTemplateParameterList(
3046 Function->isThisDeclarationADefinition()
3057 Function->getMemberSpecializationInfo()) {
3058 if (MSInfo->getPointOfInstantiation().isInvalid()) {
3060 MSInfo->setPointOfInstantiation(Loc);
3061 SemaRef.PendingLocalImplicitInstantiations.emplace_back(
Function, Loc);
3099 void *InsertPos =
nullptr;
3114 bool MergeWithParentScope = (TemplateParams !=
nullptr) ||
3116 cast<Decl>(Owner)->isDefinedOutsideFunctionOrMethod());
3120 SemaRef, D, TemplateArgs,
Scope);
3124 unsigned NumTempParamLists = 0;
3126 TempParamLists.resize(NumTempParamLists);
3127 for (
unsigned I = 0; I != NumTempParamLists; ++I) {
3132 TempParamLists[I] = InstParams;
3138 const bool CouldInstantiate =
3139 InstantiatedExplicitSpecifier.getExpr() ==
nullptr ||
3140 !InstantiatedExplicitSpecifier.getExpr()->isValueDependent();
3144 if (CouldInstantiate ||
3145 SemaRef.CodeSynthesisContexts.back().Kind !=
3147 InstantiatedExplicitSpecifier = SemaRef.instantiateExplicitSpecifier(
3148 TemplateArgs, InstantiatedExplicitSpecifier);
3150 if (InstantiatedExplicitSpecifier.isInvalid())
3165 SemaRef.Context.getTrivialTypeSourceInfo(D->
getType());
3175 if (TemplateParams && TemplateParams->
size()) {
3177 dyn_cast<TemplateTypeParmDecl>(TemplateParams->
asArray().back());
3178 if (LastParam && LastParam->isImplicit() &&
3179 LastParam->hasTypeConstraint()) {
3194 QualifierLoc = SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc,
3204 SS.
Adopt(QualifierLoc);
3205 DC = SemaRef.computeDeclContext(SS);
3207 if (DC && SemaRef.RequireCompleteDeclContext(SS, DC))
3210 DC = SemaRef.FindInstantiatedContext(D->
getLocation(),
3214 if (!DC)
return nullptr;
3221 = SemaRef.SubstDeclarationNameInfo(D->
getNameInfo(), TemplateArgs);
3232 SemaRef.Context,
Record, StartLoc, NameInfo,
T, TInfo,
3233 InstantiatedExplicitSpecifier,
Constructor->UsesFPIntrin(),
3236 TrailingRequiresClause);
3240 SemaRef.Context,
Record, StartLoc, NameInfo,
T, TInfo,
3242 Destructor->getConstexprKind(), TrailingRequiresClause);
3243 Method->setIneligibleOrNotSelected(
true);
3245 Method->setDeclName(SemaRef.Context.DeclarationNames.getCXXDestructorName(
3247 SemaRef.Context.getCanonicalTagType(
Record)));
3250 SemaRef.Context,
Record, StartLoc, NameInfo,
T, TInfo,
3251 Conversion->UsesFPIntrin(), Conversion->isInlineSpecified(),
3252 InstantiatedExplicitSpecifier, Conversion->getConstexprKind(),
3253 Conversion->getEndLoc(), TrailingRequiresClause);
3257 SemaRef.Context,
Record, StartLoc, NameInfo,
T, TInfo, SC,
3259 D->
getEndLoc(), TrailingRequiresClause);
3263 Method->setImplicitlyInline();
3266 Method->setQualifierInfo(QualifierLoc);
3268 if (TemplateParams) {
3308 if (NumTempParamLists)
3309 Method->setTemplateParameterListsInfo(
3313 Method->setLexicalDeclContext(Owner);
3314 Method->setObjectOfFriendDecl();
3319 for (
unsigned P = 0; P < Params.size(); ++P)
3320 Params[P]->setOwningFunction(
Method);
3321 Method->setParams(Params);
3324 Method->setInvalidDecl();
3329 bool IsExplicitSpecialization =
false;
3337 if (
const auto *ArgsWritten = DFTSI->TemplateArgumentsAsWritten) {
3338 ExplicitArgs.
setLAngleLoc(ArgsWritten->getLAngleLoc());
3339 ExplicitArgs.
setRAngleLoc(ArgsWritten->getRAngleLoc());
3340 if (SemaRef.SubstTemplateArguments(ArgsWritten->arguments(), TemplateArgs,
3348 SemaRef.FindInstantiatedDecl(D->
getLocation(), FTD, TemplateArgs))
3354 if (SemaRef.CheckFunctionTemplateSpecialization(
3355 Method, DFTSI->TemplateArgumentsAsWritten ? &ExplicitArgs :
nullptr,
3357 Method->setInvalidDecl();
3359 IsExplicitSpecialization =
true;
3362 SemaRef.LookupQualifiedName(
Previous, DC);
3365 ArgsWritten->getRAngleLoc());
3367 if (SemaRef.SubstTemplateArguments(ArgsWritten->arguments(), TemplateArgs,
3371 if (SemaRef.CheckFunctionTemplateSpecialization(
Method,
3374 Method->setInvalidDecl();
3376 IsExplicitSpecialization =
true;
3404 for (
unsigned P = 0; P < Params.size(); ++P) {
3405 if (!Params[P]->hasDefaultArg())
3407 if (SemaRef.SubstDefaultArgument(StartLoc, Params[P], TemplateArgs)) {
3411 Expr *UninstExpr = Params[P]->getUninstantiatedDefaultArg();
3412 ExprResult ErrorResult = SemaRef.CreateRecoveryExpr(
3414 { UninstExpr }, UninstExpr->
getType());
3416 Params[P]->setDefaultArg(ErrorResult.
get());
3422 IsExplicitSpecialization,
3423 Method->isThisDeclarationADefinition());
3431 if (isFriend &&
Method->getPreviousDecl())
3432 Method->setAccess(
Method->getPreviousDecl()->getAccess());
3438 SemaRef.CheckOverrideControl(
Method);
3452 if (IsExplicitSpecialization && !isFriend)
3465 Method->setIneligibleOrNotSelected(
true);
3466 }
else if (
Method->isCopyAssignmentOperator() ||
3467 Method->isMoveAssignmentOperator()) {
3468 Method->setIneligibleOrNotSelected(
true);
3480 }
else if (isFriend) {
3484 SemaRef.CheckFriendAccess(
Method);
3497 if (
Method->hasAttr<UsedAttr>()) {
3498 if (
const auto *A = dyn_cast<CXXRecordDecl>(Owner)) {
3501 A->getMemberSpecializationInfo())
3502 Loc = MSInfo->getPointOfInstantiation();
3503 else if (
const auto *Spec = dyn_cast<ClassTemplateSpecializationDecl>(A))
3504 Loc = Spec->getPointOfInstantiation();
3505 SemaRef.MarkFunctionReferenced(Loc,
Method);
3525 return SemaRef.SubstParmVarDecl(D, TemplateArgs, 0,
3530Decl *TemplateDeclInstantiator::VisitTemplateTypeParmDecl(
3534 UnsignedOrNone NumExpanded = std::nullopt;
3538 assert(TC->getTemplateArgsAsWritten() &&
3539 "type parameter can only be an expansion when explicit arguments "
3544 SmallVector<UnexpandedParameterPack, 2> Unexpanded;
3545 for (
auto &ArgLoc : TC->getTemplateArgsAsWritten()->arguments())
3546 SemaRef.collectUnexpandedParameterPacks(ArgLoc, Unexpanded);
3551 bool RetainExpansion =
false;
3552 if (SemaRef.CheckParameterPacksForExpansion(
3555 SourceRange(TC->getConceptNameLoc(),
3556 TC->hasExplicitTemplateArgs()
3557 ? TC->getTemplateArgsAsWritten()->getRAngleLoc()
3558 : TC->getConceptNameInfo().getEndLoc()),
3559 Unexpanded, TemplateArgs,
true,
3560 Expand, RetainExpansion, NumExpanded))
3578 if (SemaRef.SubstTypeConstraint(Inst, TC, TemplateArgs,
3579 EvaluateConstraints))
3584 TemplateArgumentLoc Output;
3592 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Inst);
3597Decl *TemplateDeclInstantiator::VisitNonTypeTemplateParmDecl(
3601 SmallVector<TypeSourceInfo *, 4> ExpandedParameterPackTypesAsWritten;
3602 SmallVector<QualType, 4> ExpandedParameterPackTypes;
3603 bool IsExpandedParameterPack =
false;
3604 TypeSourceInfo *TSI;
3614 TypeSourceInfo *NewTSI =
3621 SemaRef.CheckNonTypeTemplateParameterType(NewTSI, D->
getLocation());
3625 ExpandedParameterPackTypesAsWritten.push_back(NewTSI);
3626 ExpandedParameterPackTypes.push_back(NewT);
3629 IsExpandedParameterPack =
true;
3636 PackExpansionTypeLoc Expansion = TL.
castAs<PackExpansionTypeLoc>();
3638 SmallVector<UnexpandedParameterPack, 2> Unexpanded;
3639 SemaRef.collectUnexpandedParameterPacks(Pattern, Unexpanded);
3644 bool RetainExpansion =
false;
3645 UnsignedOrNone OrigNumExpansions =
3647 UnsignedOrNone NumExpansions = OrigNumExpansions;
3648 if (SemaRef.CheckParameterPacksForExpansion(
3649 Expansion.
getEllipsisLoc(), Pattern.getSourceRange(), Unexpanded,
3650 TemplateArgs,
true, Expand,
3651 RetainExpansion, NumExpansions))
3655 for (
unsigned I = 0; I != *NumExpansions; ++I) {
3656 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, I);
3657 TypeSourceInfo *NewTSI = SemaRef.SubstType(
3663 SemaRef.CheckNonTypeTemplateParameterType(NewTSI, D->
getLocation());
3667 ExpandedParameterPackTypesAsWritten.push_back(NewTSI);
3668 ExpandedParameterPackTypes.push_back(NewT);
3674 IsExpandedParameterPack =
true;
3680 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, std::nullopt);
3681 TypeSourceInfo *NewPattern = SemaRef.SubstType(Pattern, TemplateArgs,
3687 SemaRef.CheckNonTypeTemplateParameterType(NewPattern, D->
getLocation());
3688 TSI = SemaRef.CheckPackExpansion(NewPattern, Expansion.
getEllipsisLoc(),
3703 T = SemaRef.CheckNonTypeTemplateParameterType(TSI, D->
getLocation());
3705 T = SemaRef.Context.IntTy;
3710 NonTypeTemplateParmDecl *Param;
3711 if (IsExpandedParameterPack)
3714 D->
getDepth() - TemplateArgs.getNumSubstitutedLevels(),
3716 ExpandedParameterPackTypes, ExpandedParameterPackTypesAsWritten);
3720 D->
getDepth() - TemplateArgs.getNumSubstitutedLevels(),
3724 if (AutoLoc.isConstrained()) {
3725 SourceLocation EllipsisLoc;
3726 if (IsExpandedParameterPack)
3729 else if (
auto *Constraint = dyn_cast_if_present<CXXFoldExpr>(
3731 EllipsisLoc = Constraint->getEllipsisLoc();
3735 if (SemaRef.AttachTypeConstraint(AutoLoc, Param,
3746 EnterExpressionEvaluationContext ConstantEvaluated(
3748 TemplateArgumentLoc
Result;
3756 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Param);
3764 for (
const auto &P : *Params) {
3765 if (P->isTemplateParameterPack())
3777TemplateDeclInstantiator::VisitTemplateTemplateParmDecl(
3781 TemplateParameterList *InstParams;
3782 SmallVector<TemplateParameterList*, 8> ExpandedParams;
3784 bool IsExpandedParameterPack =
false;
3793 LocalInstantiationScope Scope(SemaRef,
true);
3794 TemplateParameterList *Expansion =
3798 ExpandedParams.push_back(Expansion);
3801 IsExpandedParameterPack =
true;
3802 InstParams = TempParams;
3807 SmallVector<UnexpandedParameterPack, 2> Unexpanded;
3814 bool RetainExpansion =
false;
3815 UnsignedOrNone NumExpansions = std::nullopt;
3816 if (SemaRef.CheckParameterPacksForExpansion(
3818 TemplateArgs,
true, Expand,
3819 RetainExpansion, NumExpansions))
3823 for (
unsigned I = 0; I != *NumExpansions; ++I) {
3824 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, I);
3825 LocalInstantiationScope Scope(SemaRef,
true);
3829 ExpandedParams.push_back(Expansion);
3835 IsExpandedParameterPack =
true;
3838 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, std::nullopt);
3840 LocalInstantiationScope Scope(SemaRef,
true);
3847 LocalInstantiationScope Scope(SemaRef,
true);
3854 TemplateTemplateParmDecl *Param;
3855 if (IsExpandedParameterPack)
3858 D->
getDepth() - TemplateArgs.getNumSubstitutedLevels(),
3864 D->
getDepth() - TemplateArgs.getNumSubstitutedLevels(),
3877 TemplateArgumentLoc(SemaRef.Context, TemplateArgument(TName),
3886 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Param);
3895 UsingDirectiveDecl *Inst
3905 if (!Owner->isFunctionOrMethod())
3906 Owner->addDecl(Inst);
3915 bool isFunctionScope = Owner->isFunctionOrMethod();
3917 for (
auto *Shadow : D->
shadows()) {
3921 NamedDecl *OldTarget = Shadow->getTargetDecl();
3922 if (
auto *CUSD = dyn_cast<ConstructorUsingShadowDecl>(Shadow))
3923 if (
auto *BaseShadow = CUSD->getNominatedBaseClassShadowDecl())
3924 OldTarget = BaseShadow;
3928 dyn_cast<UnresolvedUsingIfExistsDecl>(Shadow->getTargetDecl())) {
3930 SemaRef.Context, Owner, EmptyD->getLocation(), EmptyD->getDeclName());
3932 InstTarget = cast_or_null<NamedDecl>(SemaRef.FindInstantiatedDecl(
3933 Shadow->getLocation(), OldTarget, TemplateArgs));
3940 SemaRef.CheckUsingShadowDecl(Inst, InstTarget, *Lookup, PrevDecl))
3944 PrevDecl = cast_or_null<UsingShadowDecl>(SemaRef.FindInstantiatedDecl(
3945 Shadow->getLocation(), OldPrev, TemplateArgs));
3948 nullptr, Inst, InstTarget, PrevDecl);
3949 SemaRef.Context.setInstantiatedFromUsingShadowDecl(InstShadow, Shadow);
3951 if (isFunctionScope)
3952 SemaRef.CurrentInstantiationScope->InstantiatedLocal(Shadow, InstShadow);
3958Decl *TemplateDeclInstantiator::VisitUsingDecl(
UsingDecl *D) {
3979 if (
auto *RD = dyn_cast<CXXRecordDecl>(SemaRef.
CurContext))
3985 bool CheckRedeclaration = Owner->
isRecord();
3996 SS.
Adopt(QualifierLoc);
3997 if (CheckRedeclaration) {
3998 Prev.setHideTags(
false);
4031 EnumDecl *EnumD = cast_or_null<EnumDecl>(SemaRef.FindInstantiatedDecl(
4034 if (SemaRef.RequireCompleteEnumDecl(EnumD, EnumD->
getLocation()))
4037 TypeSourceInfo *TSI = SemaRef.SubstType(D->
getEnumType(), TemplateArgs,
4043 UsingEnumDecl *NewUD =
4047 SemaRef.Context.setInstantiatedFromUsingEnumDecl(NewUD, D);
4049 Owner->addDecl(NewUD);
4067Decl *TemplateDeclInstantiator::VisitConstructorUsingShadowDecl(
4073template <
typename T>
4074Decl *TemplateDeclInstantiator::instantiateUnresolvedUsingDecl(
4075 T *D,
bool InstantiatingPackElement) {
4077 if (D->isPackExpansion() && !InstantiatingPackElement) {
4078 SmallVector<UnexpandedParameterPack, 2> Unexpanded;
4079 SemaRef.collectUnexpandedParameterPacks(D->getQualifierLoc(), Unexpanded);
4080 SemaRef.collectUnexpandedParameterPacks(D->getNameInfo(), Unexpanded);
4085 bool RetainExpansion =
false;
4086 UnsignedOrNone NumExpansions = std::nullopt;
4087 if (SemaRef.CheckParameterPacksForExpansion(
4088 D->getEllipsisLoc(), D->getSourceRange(), Unexpanded, TemplateArgs,
4089 true, Expand, RetainExpansion,
4095 assert(!RetainExpansion &&
4096 "should never need to retain an expansion for UsingPackDecl");
4101 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, std::nullopt);
4102 return instantiateUnresolvedUsingDecl(D,
true);
4112 if (D->getDeclContext()->isFunctionOrMethod() && *NumExpansions > 1) {
4113 SemaRef.Diag(D->getEllipsisLoc(),
4114 diag::err_using_decl_redeclaration_expansion);
4119 SmallVector<NamedDecl*, 8> Expansions;
4120 for (
unsigned I = 0; I != *NumExpansions; ++I) {
4121 Sema::ArgPackSubstIndexRAII SubstIndex(SemaRef, I);
4122 Decl *Slice = instantiateUnresolvedUsingDecl(D,
true);
4132 auto *NewD = SemaRef.BuildUsingPackDecl(D, Expansions);
4134 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, NewD);
4138 UnresolvedUsingTypenameDecl *TD = dyn_cast<UnresolvedUsingTypenameDecl>(D);
4139 SourceLocation TypenameLoc = TD ? TD->
getTypenameLoc() : SourceLocation();
4141 NestedNameSpecifierLoc QualifierLoc
4142 = SemaRef.SubstNestedNameSpecifierLoc(D->getQualifierLoc(),
4148 SS.
Adopt(QualifierLoc);
4150 DeclarationNameInfo NameInfo
4151 = SemaRef.SubstDeclarationNameInfo(D->getNameInfo(), TemplateArgs);
4155 bool InstantiatingSlice =
4156 D->getEllipsisLoc().isValid() && SemaRef.ArgPackSubstIndex;
4157 SourceLocation EllipsisLoc =
4158 InstantiatingSlice ? SourceLocation() : D->getEllipsisLoc();
4161 NamedDecl *UD = SemaRef.BuildUsingDeclaration(
4162 nullptr, D->getAccess(), D->getUsingLoc(),
4163 TD, TypenameLoc, SS, NameInfo, EllipsisLoc,
4164 ParsedAttributesView(),
4165 true, IsUsingIfExists);
4167 SemaRef.InstantiateAttrs(TemplateArgs, D, UD);
4168 SemaRef.Context.setInstantiatedFromUsingDecl(UD, D);
4174Decl *TemplateDeclInstantiator::VisitUnresolvedUsingTypenameDecl(
4176 return instantiateUnresolvedUsingDecl(D);
4179Decl *TemplateDeclInstantiator::VisitUnresolvedUsingValueDecl(
4181 return instantiateUnresolvedUsingDecl(D);
4184Decl *TemplateDeclInstantiator::VisitUnresolvedUsingIfExistsDecl(
4186 llvm_unreachable(
"referring to unresolved decl out of UsingShadowDecl");
4190 SmallVector<NamedDecl*, 8> Expansions;
4192 if (NamedDecl *NewUD =
4193 SemaRef.FindInstantiatedDecl(D->
getLocation(), UD, TemplateArgs))
4194 Expansions.push_back(NewUD);
4199 auto *NewD = SemaRef.BuildUsingPackDecl(D, Expansions);
4201 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, NewD);
4205Decl *TemplateDeclInstantiator::VisitOMPThreadPrivateDecl(
4207 SmallVector<Expr *, 5> Vars;
4208 for (
auto *I : D->
varlist()) {
4209 Expr *Var = SemaRef.SubstExpr(I, TemplateArgs).get();
4211 Vars.push_back(Var);
4214 OMPThreadPrivateDecl *TD =
4215 SemaRef.OpenMP().CheckOMPThreadPrivateDecl(D->
getLocation(), Vars);
4225 SmallVector<Expr *, 5> Vars;
4226 for (
auto *I : D->
varlist()) {
4227 Expr *Var = SemaRef.SubstExpr(I, TemplateArgs).get();
4229 Vars.push_back(Var);
4232 OMPGroupPrivateDecl *TD =
4233 SemaRef.OpenMP().CheckOMPGroupPrivateDecl(D->
getLocation(), Vars);
4242 SmallVector<Expr *, 5> Vars;
4243 for (
auto *I : D->
varlist()) {
4244 Expr *Var = SemaRef.SubstExpr(I, TemplateArgs).get();
4246 Vars.push_back(Var);
4248 SmallVector<OMPClause *, 4> Clauses;
4251 OMPClause *IC =
nullptr;
4252 if (
auto *AC = dyn_cast<OMPAllocatorClause>(
C)) {
4253 ExprResult NewE = SemaRef.SubstExpr(AC->getAllocator(), TemplateArgs);
4256 IC = SemaRef.OpenMP().ActOnOpenMPAllocatorClause(
4257 NewE.
get(), AC->
getBeginLoc(), AC->getLParenLoc(), AC->getEndLoc());
4258 }
else if (
auto *AC = dyn_cast<OMPAlignClause>(
C)) {
4259 ExprResult NewE = SemaRef.SubstExpr(AC->getAlignment(), TemplateArgs);
4262 IC = SemaRef.OpenMP().ActOnOpenMPAlignClause(
4263 NewE.
get(), AC->
getBeginLoc(), AC->getLParenLoc(), AC->getEndLoc());
4268 Clauses.push_back(IC);
4280 "Requires directive cannot be instantiated within a dependent context");
4283Decl *TemplateDeclInstantiator::VisitOMPDeclareReductionDecl(
4286 const bool RequiresInstantiation =
4290 QualType SubstReductionType;
4291 if (RequiresInstantiation) {
4292 SubstReductionType = SemaRef.OpenMP().ActOnOpenMPDeclareReductionType(
4297 SubstReductionType = D->
getType();
4299 if (SubstReductionType.
isNull())
4303 bool IsCorrect =
true;
4305 std::pair<QualType, SourceLocation> ReductionTypes[] = {
4306 std::make_pair(SubstReductionType, D->
getLocation())};
4308 if (PrevDeclInScope && !PrevDeclInScope->isInvalidDecl()) {
4310 cast<Decl *>(*SemaRef.CurrentInstantiationScope->findInstantiationOf(
4313 auto DRD = SemaRef.OpenMP().ActOnOpenMPDeclareReductionDirectiveStart(
4317 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, NewDRD);
4318 Expr *SubstCombiner =
nullptr;
4319 Expr *SubstInitializer =
nullptr;
4322 SemaRef.OpenMP().ActOnOpenMPDeclareReductionCombinerStart(
4324 SemaRef.CurrentInstantiationScope->InstantiatedLocal(
4327 SemaRef.CurrentInstantiationScope->InstantiatedLocal(
4330 auto *ThisContext = dyn_cast_or_null<CXXRecordDecl>(Owner);
4331 Sema::CXXThisScopeRAII ThisScope(SemaRef, ThisContext, Qualifiers(),
4333 SubstCombiner = SemaRef.SubstExpr(Combiner, TemplateArgs).get();
4334 SemaRef.OpenMP().ActOnOpenMPDeclareReductionCombinerEnd(NewDRD,
4339 VarDecl *OmpPrivParm =
4340 SemaRef.OpenMP().ActOnOpenMPDeclareReductionInitializerStart(
4342 SemaRef.CurrentInstantiationScope->InstantiatedLocal(
4345 SemaRef.CurrentInstantiationScope->InstantiatedLocal(
4349 SubstInitializer = SemaRef.SubstExpr(
Init, TemplateArgs).get();
4353 IsCorrect = IsCorrect && OldPrivParm->hasInit();
4355 SemaRef.InstantiateVariableInitializer(OmpPrivParm, OldPrivParm,
4358 SemaRef.OpenMP().ActOnOpenMPDeclareReductionInitializerEnd(
4359 NewDRD, SubstInitializer, OmpPrivParm);
4361 IsCorrect = IsCorrect && SubstCombiner &&
4364 SubstInitializer) ||
4366 !SubstInitializer));
4368 (void)SemaRef.OpenMP().ActOnOpenMPDeclareReductionDirectiveEnd(
4377 const bool RequiresInstantiation =
4381 QualType SubstMapperTy;
4383 if (RequiresInstantiation) {
4384 SubstMapperTy = SemaRef.OpenMP().ActOnOpenMPDeclareMapperType(
4391 if (SubstMapperTy.
isNull())
4395 if (PrevDeclInScope && !PrevDeclInScope->isInvalidDecl()) {
4397 cast<Decl *>(*SemaRef.CurrentInstantiationScope->findInstantiationOf(
4400 bool IsCorrect =
true;
4401 SmallVector<OMPClause *, 6> Clauses;
4403 DeclarationNameInfo DirName;
4404 SemaRef.OpenMP().StartOpenMPDSABlock(llvm::omp::OMPD_declare_mapper, DirName,
4408 SemaRef.OpenMP().ActOnOpenMPDeclareMapperDirectiveVarDecl(
4410 SemaRef.CurrentInstantiationScope->InstantiatedLocal(
4413 auto *ThisContext = dyn_cast_or_null<CXXRecordDecl>(Owner);
4414 Sema::CXXThisScopeRAII ThisScope(SemaRef, ThisContext, Qualifiers(),
4419 SmallVector<Expr *, 4> NewVars;
4420 for (Expr *OE : OldC->varlist()) {
4421 Expr *
NE = SemaRef.SubstExpr(OE, TemplateArgs).get();
4426 NewVars.push_back(NE);
4430 NestedNameSpecifierLoc NewQualifierLoc =
4431 SemaRef.SubstNestedNameSpecifierLoc(OldC->getMapperQualifierLoc(),
4434 SS.
Adopt(NewQualifierLoc);
4435 DeclarationNameInfo NewNameInfo =
4436 SemaRef.SubstDeclarationNameInfo(OldC->getMapperIdInfo(), TemplateArgs);
4437 OMPVarListLocTy Locs(OldC->getBeginLoc(), OldC->getLParenLoc(),
4439 OMPClause *NewC = SemaRef.OpenMP().ActOnOpenMPMapClause(
4440 OldC->getIteratorModifier(), OldC->getMapTypeModifiers(),
4441 OldC->getMapTypeModifiersLoc(), SS, NewNameInfo, OldC->getMapType(),
4442 OldC->isImplicitMapType(), OldC->getMapLoc(), OldC->getColonLoc(),
4444 Clauses.push_back(NewC);
4446 SemaRef.OpenMP().EndOpenMPDSABlock(
nullptr);
4451 VN, D->
getAccess(), MapperVarRef.
get(), Clauses, PrevDeclInScope);
4453 SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, NewDMD);
4457Decl *TemplateDeclInstantiator::VisitOMPCapturedExprDecl(
4459 llvm_unreachable(
"Should not be met in templates");
4470 Owner->addDecl(Inst);
4479 llvm_unreachable(
"There are only CXXRecordDecls in C++");
4483TemplateDeclInstantiator::VisitClassTemplateSpecializationDecl(
4490 "can only instantiate an explicit specialization "
4491 "for a member class template");
4495 ClassTemplateDecl *InstClassTemplate =
4496 cast_or_null<ClassTemplateDecl>(SemaRef.FindInstantiatedDecl(
4498 if (!InstClassTemplate)
4503 TemplateArgumentListInfo InstTemplateArgs;
4504 if (
const ASTTemplateArgumentListInfo *TemplateArgsInfo =
4506 InstTemplateArgs.
setLAngleLoc(TemplateArgsInfo->getLAngleLoc());
4507 InstTemplateArgs.
setRAngleLoc(TemplateArgsInfo->getRAngleLoc());
4509 if (SemaRef.SubstTemplateArguments(TemplateArgsInfo->arguments(),
4510 TemplateArgs, InstTemplateArgs))
4516 Sema::CheckTemplateArgumentInfo CTAI;
4517 if (SemaRef.CheckTemplateArgumentList(
4518 InstClassTemplate, D->
getLocation(), InstTemplateArgs,
4525 void *InsertPos =
nullptr;
4526 ClassTemplateSpecializationDecl *PrevDecl =
4533 SemaRef.CheckSpecializationInstantiationRedecl(D->
getLocation(),
4555 SemaRef.Diag(D->
getLocation(), diag::err_redefinition) << PrevDecl;
4557 diag::note_previous_definition);
4562 ClassTemplateSpecializationDecl *InstD =
4584 Owner->addDecl(InstD);
4591 SemaRef.InstantiateClass(D->
getLocation(), InstD, D, TemplateArgs,
4605 "A template specialization without specialized template?");
4608 cast_or_null<VarTemplateDecl>(SemaRef.FindInstantiatedDecl(
4610 if (!InstVarTemplate)
4616 VarTemplateArgsInfo.
setLAngleLoc(TemplateArgsInfo->getLAngleLoc());
4617 VarTemplateArgsInfo.
setRAngleLoc(TemplateArgsInfo->getRAngleLoc());
4619 if (SemaRef.SubstTemplateArguments(TemplateArgsInfo->arguments(),
4620 TemplateArgs, VarTemplateArgsInfo))
4626 if (SemaRef.CheckTemplateArgumentList(
4627 InstVarTemplate, D->
getLocation(), VarTemplateArgsInfo,
4633 void *InsertPos =
nullptr;
4640 if (PrevDecl && SemaRef.CheckSpecializationInstantiationRedecl(
4648 VTSD->setTemplateArgsAsWritten(VarTemplateArgsInfo);
4668 SemaRef.
Diag(D->
getLocation(), diag::err_variable_instantiates_to_function)
4678 void *InsertPos =
nullptr;
4679 VarTemplate->findSpecialization(Converted, InsertPos);
4683 if (SemaRef.getLangOpts().OpenCL)
4684 SemaRef.deduceOpenCLAddressSpace(Var);
4690 SemaRef.BuildVariableInstantiation(Var, D, TemplateArgs, LateAttrs, Owner,
4691 StartingScope,
false, PrevDecl);
4697 llvm_unreachable(
"@defs is not supported in Objective-C++");
4702 unsigned DiagID = SemaRef.getDiagnostics().getCustomDiagID(
4704 "cannot instantiate %0 yet");
4712 llvm_unreachable(
"Concept definitions cannot reside inside a template");
4715Decl *TemplateDeclInstantiator::VisitImplicitConceptSpecializationDecl(
4717 llvm_unreachable(
"Concept specializations cannot reside inside a template");
4727 llvm_unreachable(
"Unexpected decl");
4738 SubstD = Instantiator.Visit(D);
4752 T = SemaRef.Context.getFunctionType(
4753 SemaRef.Context.BoolTy, FPT->getParamTypes(), FPT->getExtProtoInfo());
4762 SemaRef.Context.getTrivialTypeSourceInfo(
T, Orig->
getEndLoc());
4764 assert(OldLoc &&
"type of function is not a function type?");
4766 for (
unsigned I = 0, N = OldLoc.getNumParams(); I != N; ++I)
4767 NewLoc.
setParam(I, OldLoc.getParam(I));
4772 SemaRef.Context.DeclarationNames.getCXXOperatorName(OO_EqualEqual));
4777 if (Spaceship->isInvalidDecl())
4789 if (
auto *MD = dyn_cast<CXXMethodDecl>(Spaceship)) {
4794 assert(Spaceship->getFriendObjectKind() &&
4795 "defaulted spaceship is neither a member nor a friend");
4809 return cast_or_null<FunctionDecl>(R);
4823 unsigned N = L->
size();
4827 for (
auto &P : *L) {
4829 Params.push_back(D);
4849 bool EvaluateConstraints) {
4888 if (SemaRef.SubstTemplateArguments(TemplArgInfo->
arguments(), TemplateArgs,
4895 if (SemaRef.CheckTemplateArgumentList(
4896 ClassTemplate, PartialSpec->
getLocation(), InstTemplateArgs,
4902 if (SemaRef.CheckTemplatePartialSpecializationArgs(
4909 void *InsertPos =
nullptr;
4912 InstParams, InsertPos);
4917 SemaRef.Context, PartialSpec->
getTagKind(), Owner,
4948 diag::err_partial_spec_redeclared)
4950 SemaRef.Diag(PrevDecl->
getLocation(), diag::note_prev_partial_spec_here)
4951 << SemaRef.Context.getCanonicalTagType(PrevDecl);
4956 SemaRef.CheckTemplatePartialSpecialization(InstPartialSpec);
4962 return InstPartialSpec;
4998 if (SemaRef.SubstTemplateArguments(TemplArgInfo->
arguments(), TemplateArgs,
5006 InstTemplateArgs, {},
5011 if (SemaRef.CheckTemplatePartialSpecializationArgs(
5018 void *InsertPos =
nullptr;
5021 InstParams, InsertPos);
5032 diag::err_variable_instantiates_to_function)
5069 diag::err_var_partial_spec_redeclared)
5072 diag::note_var_prev_partial_spec_here);
5076 SemaRef.CheckTemplatePartialSpecialization(InstPartialSpec);
5080 VarTemplate->AddPartialSpecialization(InstPartialSpec,
nullptr);
5082 SemaRef.BuildVariableInstantiation(InstPartialSpec, PartialSpec, TemplateArgs,
5083 LateAttrs, Owner, StartingScope);
5085 return InstPartialSpec;
5092 assert(OldTInfo &&
"substituting function without type source info");
5093 assert(Params.empty() &&
"parameter vector is non-empty at start");
5099 ThisTypeQuals =
Method->getFunctionObjectParameterType().getQualifiers();
5104 ThisContext, ThisTypeQuals, EvaluateConstraints);
5110 if (NewTInfo != OldTInfo) {
5114 unsigned NewIdx = 0;
5115 for (
unsigned OldIdx = 0, NumOldParams = OldProtoLoc.getNumParams();
5116 OldIdx != NumOldParams; ++OldIdx) {
5117 ParmVarDecl *OldParam = OldProtoLoc.getParam(OldIdx);
5125 NumArgumentsInExpansion =
5126 SemaRef.getNumArgumentsInExpansion(OldParam->
getType(),
5128 if (!NumArgumentsInExpansion) {
5132 Params.push_back(NewParam);
5133 Scope->InstantiatedLocal(OldParam, NewParam);
5136 Scope->MakeInstantiatedLocalArgPack(OldParam);
5137 for (
unsigned I = 0; I != *NumArgumentsInExpansion; ++I) {
5139 Params.push_back(NewParam);
5140 Scope->InstantiatedLocalPackArg(OldParam, NewParam);
5150 for (
unsigned i = 0, i_end = OldProtoLoc.getNumParams(); i != i_end;
5154 Params.push_back(SemaRef.BuildParmVarDeclForTypedef(
5160 cast_or_null<ParmVarDecl>(VisitParmVarDecl(OldParam));
5163 Params.push_back(Parm);
5180 TemplateArgs, ParamTypes, &Params,
5193 for (
auto *
decl : PatternDecl->
decls()) {
5200 auto it = llvm::find_if(
Function->decls(), [&](
Decl *inst) {
5201 VarDecl *InstVD = dyn_cast<VarDecl>(inst);
5202 return InstVD && InstVD->isLocalVarDecl() &&
5203 InstVD->getIdentifier() == II;
5209 Scope.InstantiatedLocal(VD, *it);
5216bool Sema::addInstantiatedParametersToScope(
5220 unsigned FParamIdx = 0;
5221 for (
unsigned I = 0, N = PatternDecl->
getNumParams(); I != N; ++I) {
5222 const ParmVarDecl *PatternParam = PatternDecl->
getParamDecl(I);
5225 assert(FParamIdx < Function->getNumParams());
5250 UnsignedOrNone NumArgumentsInExpansion =
5252 if (NumArgumentsInExpansion) {
5253 QualType PatternType =
5254 PatternParam->
getType()->
castAs<PackExpansionType>()->getPattern();
5255 for (
unsigned Arg = 0; Arg < *NumArgumentsInExpansion; ++Arg) {
5259 Sema::ArgPackSubstIndexRAII SubstIndex(*
this, Arg);
5279 assert(Param->hasUninstantiatedDefaultArg());
5311 false, std::nullopt,
5320 L->DefaultArgumentInstantiated(Param);
5333 if (AlreadyInstantiating) {
5336 Diag(PointOfInstantiation, diag::err_exception_spec_cycle) <<
Decl;
5358 false, std::nullopt,
5391 SemaRef.Context.setManglingNumber(
New,
5392 SemaRef.Context.getManglingNumber(Tmpl));
5405 ActiveInstType &ActiveInst = SemaRef.CodeSynthesisContexts.back();
5406 if (ActiveInst.Kind == ActiveInstType::ExplicitTemplateArgumentSubstitution ||
5407 ActiveInst.Kind == ActiveInstType::DeducedTemplateArgumentSubstitution) {
5409 SemaRef.CurrentSFINAEContext =
nullptr;
5410 atTemplateEnd(SemaRef.TemplateInstCallbacks, SemaRef, ActiveInst);
5411 ActiveInst.Kind = ActiveInstType::TemplateInstantiation;
5412 ActiveInst.Entity =
New;
5418 assert(Proto &&
"Function template without prototype?");
5427 if (SemaRef.getLangOpts().CPlusPlus11 &&
5442 assert(NewProto &&
"Template instantiation without function prototype?");
5447 New->setType(SemaRef.Context.getFunctionType(
5451 SemaRef.SubstExceptionSpec(
New, Proto, TemplateArgs);
5460 LateAttrs, StartingScope);
5481 New->setVirtualAsWritten(
true);
5492 Lookups.reserve(DFI->getUnqualifiedLookups().size());
5493 bool AnyChanged =
false;
5495 NamedDecl *D = SemaRef.FindInstantiatedDecl(
New->getLocation(),
5496 DA.getDecl(), TemplateArgs);
5499 AnyChanged |= (D != DA.getDecl());
5505 New->setDefaultedOrDeletedInfo(
5507 SemaRef.Context, Lookups)
5534 bool DefinitionRequired,
5542 Function->getTemplateSpecializationKindForInstantiation();
5549 !DefinitionRequired)
5554 if (
Function->isDefined(ExistingDefn,
5569 assert(!AlreadyInstantiating &&
"should have been caught by caller");
5574 assert(PatternDecl &&
"instantiating a non-template");
5577 Stmt *Pattern =
nullptr;
5579 Pattern = PatternDef->
getBody(PatternDef);
5580 PatternDecl = PatternDef;
5582 PatternDef =
nullptr;
5586 bool Unreachable =
false;
5591 Function->getInstantiatedFromMemberFunction(), PatternDecl,
5593 DefinitionRequired, &Unreachable)) {
5594 if (DefinitionRequired)
5597 (
Function->isConstexpr() && !Recursive)) {
5601 Function->setInstantiationIsPending(
true);
5604 if (llvm::isTimeTraceVerbose()) {
5605 llvm::timeTraceAddInstantEvent(
"DeferInstantiation", [&] {
5607 llvm::raw_string_ostream
OS(Name);
5616 Diag(PointOfInstantiation, diag::warn_func_template_missing)
5622 diag::note_unreachable_template_decl);
5626 Diag(PointOfInstantiation, diag::note_inst_declaration_hint)
5638 Function->setInstantiationIsPending(
true);
5640 std::make_pair(
Function, PointOfInstantiation));
5644 llvm::TimeTraceScope TimeScope(
"InstantiateFunction", [&]() {
5645 llvm::TimeTraceMetadata M;
5646 llvm::raw_string_ostream
OS(M.Detail);
5649 if (llvm::isTimeTraceVerbose()) {
5652 M.Line =
SourceMgr.getExpansionLineNumber(Loc);
5678 "missing LateParsedTemplate");
5680 Pattern = PatternDecl->
getBody(PatternDecl);
5687 "unexpected kind of function template definition");
5702 for (
auto *D =
Function->getMostRecentDecl(); ;
5704 D->setImplicitlyInline();
5715 "instantiating function definition");
5719 Function->setVisibleDespiteOwningModule();
5745 auto NameLocPointsToPattern = [&] {
5756 return PatternNameLoc;
5766 return PatternNameLoc;
5774 assert(PatternTSI &&
"Pattern is supposed to have an associated TSI");
5782 Function->setDeclarationNameLoc(NameLocPointsToPattern());
5790 ThisContext =
Method->getParent();
5791 ThisTypeQuals =
Method->getMethodQualifiers();
5801 bool MergeWithParentScope =
false;
5803 MergeWithParentScope =
5804 Rec->isLocalClass() && !
Function->isFunctionTemplateSpecialization();
5807 auto RebuildTypeSourceInfoForDefaultSpecialMembers = [&]() {
5813 "Special member needs to be defaulted");
5821 auto *NewRec = dyn_cast<CXXRecordDecl>(
Function->getDeclContext());
5822 const auto *PatternRec =
5824 if (!NewRec || !PatternRec)
5826 if (!PatternRec->isLambda())
5829 struct SpecialMemberTypeInfoRebuilder
5849 getDerived().TransformDecl(TL.
getNameLoc(),
T->getDecl()));
5851 return Base::TransformRecordType(TLB, TL);
5865 } IR{*
this, PatternRec, NewRec};
5868 assert(NewSI &&
"Type Transform failed?");
5870 Function->setTypeSourceInfo(NewSI);
5874 assert(NewParmSI &&
"Type transformation failed.");
5880 RebuildTypeSourceInfoForDefaultSpecialMembers();
5884 std::optional<ArrayRef<TemplateArgument>> Innermost;
5885 if (
auto *Primary =
Function->getPrimaryTemplate();
5888 Function->getTemplateSpecializationKind() !=
5890 auto It = llvm::find_if(Primary->redecls(),
5892 return cast<FunctionTemplateDecl>(RTD)
5893 ->isCompatibleWithDefinition();
5895 assert(It != Primary->redecls().end() &&
5896 "Should't get here without a definition");
5898 ->getTemplatedDecl()
5902 DC = (*It)->getLexicalDeclContext();
5903 Innermost.emplace(
Function->getTemplateSpecializationArgs()->asArray());
5906 Function, DC,
false, Innermost,
false, PatternDecl);
5924 if (addInstantiatedParametersToScope(
Function, PatternDecl,
Scope,
5940 if (
Context.getTargetInfo().getCXXABI().isMicrosoft() &&
5941 Ctor->isDefaultConstructor()) {
5947 Body =
SubstStmt(Pattern, TemplateArgs);
5956 checkReferenceToTULocalFromOtherTU(
Function, PointOfInstantiation);
5961 Listener->FunctionDefinitionInstantiated(
Function);
5971 bool ShouldSkipCG = [&] {
5972 auto *RD = dyn_cast<CXXRecordDecl>(
Function->getParent());
5973 if (!RD || !RD->isLambda())
5977 return Context.isUnevaluated() ||
Context.isImmediateFunctionContext();
5980 if (!ShouldSkipCG) {
5987 LocalInstantiations.
perform();
5989 GlobalInstantiations.perform();
6015 bool IsMemberSpec =
false;
6017 if (
auto *PartialSpec =
6018 dyn_cast<VarTemplatePartialSpecializationDecl>(FromVar)) {
6019 assert(PartialSpecArgs);
6020 IsMemberSpec = PartialSpec->isMemberSpecialization();
6022 PartialSpec, PartialSpecArgs->
asArray(),
false);
6025 IsMemberSpec =
VarTemplate->isMemberSpecialization();
6045 "don't have a definition to instantiate from");
6074 bool InstantiatingVarTemplate,
6078 bool InstantiatingVarTemplatePartialSpec =
6083 bool InstantiatingSpecFromTemplate =
6109 if (OldVar->
isUsed(
false))
6134 }
else if (PrevDeclForVarTemplateSpecialization) {
6135 Previous.addDecl(PrevDeclForVarTemplateSpecialization);
6139 if (!InstantiatingVarTemplate) {
6157 !InstantiatingSpecFromTemplate)
6164 dyn_cast<VarTemplateSpecializationDecl>(OldVar)) {
6172 Context.setManglingNumber(NewVar,
Context.getManglingNumber(OldVar));
6173 Context.setStaticLocalNumber(NewVar,
Context.getStaticLocalNumber(OldVar));
6176 if (InstantiatingVarTemplate || InstantiatingVarTemplatePartialSpec) {
6181 }
else if (InstantiatingSpecFromTemplate ||
6203 L->VariableDefinitionInstantiated(Var);
6233 if (!
Init.isInvalid()) {
6236 if (Var->
hasAttr<DLLImportAttr>() &&
6240 }
else if (InitExpr) {
6276 bool DefinitionRequired,
bool AtEndOfTU) {
6288 if (AlreadyInstantiating)
6293 assert(PatternDecl &&
"no pattern for templated variable");
6298 dyn_cast<VarTemplateSpecializationDecl>(Var);
6309 (PatternDecl = PatternDecl->
getFirstDecl())->hasInit() &&
6318 "instantiating variable initializer");
6329 Recursive, AtEndOfTU);
6338 PreviousContext.
pop();
6342 LocalInstantiations.
perform();
6344 GlobalInstantiations.
perform();
6348 "not a static data member?");
6357 if (!Def && !DefinitionRequired) {
6364 Diag(PointOfInstantiation, diag::warn_var_template_missing)
6368 Diag(PointOfInstantiation, diag::note_inst_declaration_hint) << Var;
6379 PatternDecl, Def, TSK,
6380 DefinitionRequired))
6397 struct PassToConsumerRAII {
6404 ~PassToConsumerRAII() {
6405 Consumer.HandleCXXStaticMemberVarInstantiation(Var);
6407 } PassToConsumerRAII(
Consumer, Var);
6414 PointOfInstantiation);
6423 "instantiating variable definition");
6445 }
else if (!VarSpec) {
6490 PreviousContext.
pop();
6493 PassToConsumerRAII.Var = Var;
6502 LocalInstantiations.
perform();
6504 GlobalInstantiations.
perform();
6516 for (
const auto *
Init : Tmpl->
inits()) {
6519 if (!
Init->isWritten())
6524 if (
Init->isPackExpansion()) {
6526 TypeLoc BaseTL =
Init->getTypeSourceInfo()->getTypeLoc();
6530 bool ShouldExpand =
false;
6531 bool RetainExpansion =
false;
6535 TemplateArgs,
true, ShouldExpand,
6536 RetainExpansion, NumExpansions)) {
6538 New->setInvalidDecl();
6541 assert(ShouldExpand &&
"Partial instantiation of base initializer?");
6544 for (
unsigned I = 0; I != *NumExpansions; ++I) {
6558 Init->getSourceLocation(),
6559 New->getDeclName());
6567 BaseTInfo, TempInit.
get(),
6575 NewInits.push_back(NewInit.
get());
6590 if (
Init->isDelegatingInitializer() ||
Init->isBaseInitializer()) {
6593 Init->getSourceLocation(),
6594 New->getDeclName());
6597 New->setInvalidDecl();
6601 if (
Init->isBaseInitializer())
6603 New->getParent(), EllipsisLoc);
6607 }
else if (
Init->isMemberInitializer()) {
6609 Init->getMemberLocation(),
6614 New->setInvalidDecl();
6619 Init->getSourceLocation());
6620 }
else if (
Init->isIndirectMemberInitializer()) {
6623 Init->getMemberLocation(),
6624 Init->getIndirectMember(), TemplateArgs));
6626 if (!IndirectMember) {
6628 New->setInvalidDecl();
6633 Init->getSourceLocation());
6638 New->setInvalidDecl();
6640 NewInits.push_back(NewInit.
get());
6659 Instance = Instance->getCanonicalDecl();
6660 if (Pattern == Instance)
return true;
6661 Instance = Instance->getInstantiatedFromMemberTemplate();
6672 Instance = Instance->getCanonicalDecl();
6673 if (Pattern == Instance)
return true;
6674 Instance = Instance->getInstantiatedFromMemberTemplate();
6687 Instance->getCanonicalDecl());
6688 if (Pattern == Instance)
6690 Instance = Instance->getInstantiatedFromMember();
6701 Instance = Instance->getCanonicalDecl();
6702 if (Pattern == Instance)
return true;
6703 Instance = Instance->getInstantiatedFromMemberClass();
6714 Instance = Instance->getCanonicalDecl();
6715 if (Pattern == Instance)
return true;
6716 Instance = Instance->getInstantiatedFromMemberFunction();
6727 Instance = Instance->getCanonicalDecl();
6728 if (Pattern == Instance)
return true;
6729 Instance = Instance->getInstantiatedFromMemberEnum();
6756 bool OtherIsPackExpansion;
6758 if (
auto *OtherUUD = dyn_cast<T>(
Other)) {
6759 OtherIsPackExpansion = OtherUUD->isPackExpansion();
6761 }
else if (
auto *OtherUPD = dyn_cast<UsingPackDecl>(
Other)) {
6762 OtherIsPackExpansion =
true;
6763 OtherFrom = OtherUPD->getInstantiatedFromUsingDecl();
6764 }
else if (
auto *OtherUD = dyn_cast<UsingDecl>(
Other)) {
6765 OtherIsPackExpansion =
false;
6770 return Pattern->isPackExpansion() == OtherIsPackExpansion &&
6776 assert(Instance->isStaticDataMember());
6781 Instance = Instance->getCanonicalDecl();
6782 if (Pattern == Instance)
return true;
6783 Instance = Instance->getInstantiatedFromStaticDataMember();
6792 if (
auto *UUD = dyn_cast<UnresolvedUsingTypenameDecl>(D))
6795 if (
auto *UUD = dyn_cast<UnresolvedUsingValueDecl>(D))
6801 if (
auto *
Record = dyn_cast<CXXRecordDecl>(
Other))
6804 if (
auto *Function = dyn_cast<FunctionDecl>(
Other))
6807 if (
auto *
Enum = dyn_cast<EnumDecl>(
Other))
6810 if (
auto *Var = dyn_cast<VarDecl>(
Other))
6814 if (
auto *Temp = dyn_cast<ClassTemplateDecl>(
Other))
6817 if (
auto *Temp = dyn_cast<FunctionTemplateDecl>(
Other))
6820 if (
auto *PartialSpec =
6821 dyn_cast<ClassTemplatePartialSpecializationDecl>(
Other))
6825 if (
auto *Field = dyn_cast<FieldDecl>(
Other)) {
6826 if (!Field->getDeclName()) {
6833 if (
auto *Using = dyn_cast<UsingDecl>(
Other))
6836 if (
auto *Shadow = dyn_cast<UsingShadowDecl>(
Other))
6843template<
typename ForwardIterator>
6846 ForwardIterator first,
6847 ForwardIterator last) {
6848 for (; first != last; ++first)
6857 if (
NamedDecl *D = dyn_cast<NamedDecl>(DC)) {
6859 return cast_or_null<DeclContext>(ID);
6874 return cast<Decl>(DC)->getTemplateDepth() > Level;
6879 bool FindingInstantiatedContext) {
6917 if (
auto *BD = dyn_cast<BindingDecl>(FD);
6925 "found declaration pack but not pack expanding");
6955 bool NeedInstantiate =
false;
6957 NeedInstantiate = RD->isLocalClass();
6960 NeedInstantiate =
true;
6963 if (NeedInstantiate) {
6974 assert(Inst &&
"Failed to instantiate label??");
6981 if (!
Record->isDependentContext())
6990 dyn_cast<ClassTemplateSpecializationDecl>(
Record))
6991 ClassTemplate = Spec->getSpecializedTemplate()->getCanonicalDecl();
7002 if (
CXXRecordDecl *InstRecord = dyn_cast<CXXRecordDecl>(DC)) {
7006 = dyn_cast<ClassTemplateSpecializationDecl>(InstRecord)){
7026 auto *Guide = dyn_cast<CXXDeductionGuideDecl>(FD);
7027 if (Guide && Guide->isImplicit()) {
7035 Unpacked = Arg.pack_elements();
7048 if (
T.isNull() ||
T->containsErrors())
7058 assert(
SemaRef.RebuildingImmediateInvocation ||
7071 if (FindingInstantiatedContext &&
7074 Diag(Loc, diag::err_specialization_not_primary_template)
7091 if (!ParentDependsOnArgs)
7105 bool IsBeingInstantiated =
false;
7106 if (
auto *Spec = dyn_cast<CXXRecordDecl>(ParentDC)) {
7107 if (!Spec->isDependentContext()) {
7108 if (Spec->isEntityBeingDefined())
7109 IsBeingInstantiated =
true;
7111 diag::err_incomplete_type))
7114 ParentDC = Spec->getDefinitionOrSelf();
7153 }
else if (IsBeingInstantiated) {
7159 Diag(Loc, diag::err_member_not_yet_instantiated)
7172 Diag(Loc, diag::err_enumerator_does_not_exist)
7176 <<
Context.getCanonicalTagType(Spec);
7179 llvm_unreachable(
"Unable to find instantiation of declaration!");
7190 std::deque<PendingImplicitInstantiation> DelayedImplicitInstantiations;
7195 bool LocalInstantiation =
false;
7202 LocalInstantiation =
true;
7207 bool DefinitionRequired =
Function->getTemplateSpecializationKind() ==
7212 [
this, Inst, DefinitionRequired, AtEndOfTU](
FunctionDecl *CurFD) {
7214 DefinitionRequired, AtEndOfTU);
7220 DefinitionRequired, AtEndOfTU);
7222 Function->setInstantiationIsPending(
false);
7225 if (!LocalOnly &&
LangOpts.PCHInstantiateTemplates &&
7227 DelayedImplicitInstantiations.push_back(Inst);
7228 else if (!AtEndOfTU &&
Function->instantiationIsPending() &&
7229 !LocalInstantiation)
7230 DelayedImplicitInstantiations.push_back(Inst);
7239 "Not a static data member, nor a variable template"
7240 " specialization?");
7252 llvm_unreachable(
"Cannot instantitiate an undeclared specialization.");
7267 "instantiating variable definition");
7274 DefinitionRequired, AtEndOfTU);
7277 if (!DelayedImplicitInstantiations.empty())
7283 for (
auto *DD : Pattern->
ddiags()) {
7284 switch (DD->getKind()) {
Defines the clang::ASTContext interface.
Defines the C++ template declaration subclasses.
Defines the clang::Expr interface and subclasses for C++ expressions.
llvm::MachO::Record Record
@ ForExternalRedeclaration
The lookup results will be used for redeclaration of a name with external linkage; non-visible lookup...
@ ForVisibleRedeclaration
The lookup results will be used for redeclaration of a name, if an entity by that name already exists...
llvm::SmallVector< std::pair< const MemRegion *, SVal >, 4 > Bindings
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 functions specific to AMDGPU.
static bool hasAttr(const Decl *D, bool IgnoreImplicitAttr)
This file declares semantic analysis for CUDA constructs.
static const NamedDecl * getDefinition(const Decl *D)
This file declares semantic analysis for HLSL constructs.
This file declares semantic analysis for Objective-C.
This file declares semantic analysis for OpenMP constructs and clauses.
This file declares semantic analysis functions specific to Swift.
static void instantiateDependentAMDGPUWavesPerEUAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AMDGPUWavesPerEUAttr &Attr, Decl *New)
static NamedDecl * findInstantiationOf(ASTContext &Ctx, NamedDecl *D, ForwardIterator first, ForwardIterator last)
static void instantiateDependentAMDGPUMaxNumWorkGroupsAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AMDGPUMaxNumWorkGroupsAttr &Attr, Decl *New)
static void instantiateDependentAMDGPUFlatWorkGroupSizeAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AMDGPUFlatWorkGroupSizeAttr &Attr, Decl *New)
static void instantiateDependentCUDAClusterDimsAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const CUDAClusterDimsAttr &Attr, Decl *New)
static void sharedInstantiateConstructorDestructorAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const Attr *A, Decl *New, ASTContext &C)
static void instantiateDependentDiagnoseIfAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const DiagnoseIfAttr *DIA, const Decl *Tmpl, FunctionDecl *New)
static QualType adjustFunctionTypeForInstantiation(ASTContext &Context, FunctionDecl *D, TypeSourceInfo *TInfo)
Adjust the given function type for an instantiation of the given declaration, to cope with modificati...
static bool isRelevantAttr(Sema &S, const Decl *D, const Attr *A)
Determine whether the attribute A might be relevant to the declaration D.
static void instantiateDependentReqdWorkGroupSizeAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const ReqdWorkGroupSizeAttr &Attr, Decl *New)
#define CLAUSE_NOT_ON_DECLS(CLAUSE_NAME)
static void instantiateDependentMallocSpanAttr(Sema &S, const MallocSpanAttr *Attr, Decl *New)
static bool isDependentContextAtLevel(DeclContext *DC, unsigned Level)
Determine whether the given context is dependent on template parameters at level Level or below.
static void instantiateDependentModeAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const ModeAttr &Attr, Decl *New)
static void instantiateDependentCUDALaunchBoundsAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const CUDALaunchBoundsAttr &Attr, Decl *New)
static bool isDeclWithinFunction(const Decl *D)
static void instantiateDependentAssumeAlignedAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AssumeAlignedAttr *Aligned, Decl *New)
static bool SubstQualifier(Sema &SemaRef, const DeclT *OldDecl, DeclT *NewDecl, const MultiLevelTemplateArgumentList &TemplateArgs)
static void collectUnexpandedParameterPacks(Sema &S, TemplateParameterList *Params, SmallVectorImpl< UnexpandedParameterPack > &Unexpanded)
static void instantiateDependentHLSLParamModifierAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const HLSLParamModifierAttr *Attr, const Decl *Old, Decl *New)
static DeclT * getPreviousDeclForInstantiation(DeclT *D)
Get the previous declaration of a declaration for the purposes of template instantiation.
static Expr * instantiateDependentFunctionAttrCondition(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const Attr *A, Expr *OldCond, const Decl *Tmpl, FunctionDecl *New)
static bool isInstantiationOf(ClassTemplateDecl *Pattern, ClassTemplateDecl *Instance)
static void instantiateDependentAllocAlignAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AllocAlignAttr *Align, Decl *New)
static bool isInstantiationOfStaticDataMember(VarDecl *Pattern, VarDecl *Instance)
static void instantiateOMPDeclareSimdDeclAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const OMPDeclareSimdDeclAttr &Attr, Decl *New)
Instantiation of 'declare simd' attribute and its arguments.
static void instantiateDependentSYCLKernelAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const SYCLKernelAttr &Attr, Decl *New)
static void instantiateDependentAlignValueAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AlignValueAttr *Aligned, Decl *New)
static void instantiateDependentAlignedAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AlignedAttr *Aligned, Decl *New, bool IsPackExpansion)
static void instantiateOMPDeclareVariantAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const OMPDeclareVariantAttr &Attr, Decl *New)
Instantiation of 'declare variant' attribute and its arguments.
static void instantiateDependentEnableIfAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const EnableIfAttr *EIA, const Decl *Tmpl, FunctionDecl *New)
static void instantiateDependentAnnotationAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const AnnotateAttr *Attr, Decl *New)
static Sema::RetainOwnershipKind attrToRetainOwnershipKind(const Attr *A)
static void instantiateDependentOpenACCRoutineDeclAttr(Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs, const OpenACCRoutineDeclAttr *OldAttr, const Decl *Old, Decl *New)
static bool isInstantiationOfUnresolvedUsingDecl(T *Pattern, Decl *Other, ASTContext &Ctx)
static bool isInvalid(LocType Loc, bool *Invalid)
Defines the SourceManager interface.
Defines the clang::TypeLoc interface and its subclasses.
ASTConsumer - This is an abstract interface that should be implemented by clients that read ASTs.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
void setInstantiatedFromUsingDecl(NamedDecl *Inst, NamedDecl *Pattern)
Remember that the using decl Inst is an instantiation of the using decl Pattern of a class template.
QualType mergeFunctionTypes(QualType, QualType, bool OfBlockPointer=false, bool Unqualified=false, bool AllowCXX=false, bool IsConditionalOperator=false)
NamedDecl * getInstantiatedFromUsingDecl(NamedDecl *Inst)
If the given using decl Inst is an instantiation of another (possibly unresolved) using decl,...
DeclarationNameTable DeclarationNames
void forEachMultiversionedFunctionVersion(const FunctionDecl *FD, llvm::function_ref< void(FunctionDecl *)> Pred) const
Visits all versions of a multiversioned function with the passed predicate.
OMPTraitInfo & getNewOMPTraitInfo()
Return a new OMPTraitInfo object owned by this context.
FieldDecl * getInstantiatedFromUnnamedFieldDecl(FieldDecl *Field) const
CanQualType UnsignedLongLongTy
static bool hasSameType(QualType T1, QualType T2)
Determine whether the given types T1 and T2 are equivalent.
CanQualType getCanonicalTagType(const TagDecl *TD) const
An abstract interface that should be implemented by listeners that want to be notified when an AST en...
Represents an access specifier followed by colon ':'.
static AccessSpecDecl * Create(ASTContext &C, AccessSpecifier AS, DeclContext *DC, SourceLocation ASLoc, SourceLocation ColonLoc)
SourceLocation getColonLoc() const
The location of the colon following the access specifier.
SourceLocation getAccessSpecifierLoc() const
The location of the access specifier.
Attr - This represents one attribute.
attr::Kind getKind() const
Attr * clone(ASTContext &C) const
SourceLocation getLocation() const
SourceRange getRange() const
SourceLocation getLoc() const
Represents a C++ declaration that introduces decls from somewhere else.
shadow_range shadows() const
A binding in a decomposition declaration.
static BindingDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation IdLoc, IdentifierInfo *Id, QualType T)
ArrayRef< BindingDecl * > getBindingPackDecls() const
Represents the builtin template declaration which is used to implement __make_integer_seq and other b...
Represents a C++ constructor within a class.
bool isDefaultConstructor() const
Whether this constructor is a default constructor (C++ [class.ctor]p5), which can be used to default-...
static CXXConstructorDecl * Create(ASTContext &C, CXXRecordDecl *RD, SourceLocation StartLoc, const DeclarationNameInfo &NameInfo, QualType T, TypeSourceInfo *TInfo, ExplicitSpecifier ES, bool UsesFPIntrin, bool isInline, bool isImplicitlyDeclared, ConstexprSpecKind ConstexprKind, InheritedConstructor Inherited=InheritedConstructor(), const AssociatedConstraint &TrailingRequiresClause={})
Represents a C++ conversion function within a class.
static CXXConversionDecl * Create(ASTContext &C, CXXRecordDecl *RD, SourceLocation StartLoc, const DeclarationNameInfo &NameInfo, QualType T, TypeSourceInfo *TInfo, bool UsesFPIntrin, bool isInline, ExplicitSpecifier ES, ConstexprSpecKind ConstexprKind, SourceLocation EndLocation, const AssociatedConstraint &TrailingRequiresClause={})
Represents a C++ deduction guide declaration.
static CXXDeductionGuideDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, ExplicitSpecifier ES, const DeclarationNameInfo &NameInfo, QualType T, TypeSourceInfo *TInfo, SourceLocation EndLocation, CXXConstructorDecl *Ctor=nullptr, DeductionCandidate Kind=DeductionCandidate::Normal, const AssociatedConstraint &TrailingRequiresClause={}, const CXXDeductionGuideDecl *SourceDG=nullptr, SourceDeductionGuideKind SK=SourceDeductionGuideKind::None)
Represents a C++ destructor within a class.
static CXXDestructorDecl * Create(ASTContext &C, CXXRecordDecl *RD, SourceLocation StartLoc, const DeclarationNameInfo &NameInfo, QualType T, TypeSourceInfo *TInfo, bool UsesFPIntrin, bool isInline, bool isImplicitlyDeclared, ConstexprSpecKind ConstexprKind, const AssociatedConstraint &TrailingRequiresClause={})
Represents a static or instance method of a struct/union/class.
static CXXMethodDecl * Create(ASTContext &C, CXXRecordDecl *RD, SourceLocation StartLoc, const DeclarationNameInfo &NameInfo, QualType T, TypeSourceInfo *TInfo, StorageClass SC, bool UsesFPIntrin, bool isInline, ConstexprSpecKind ConstexprKind, SourceLocation EndLocation, const AssociatedConstraint &TrailingRequiresClause={})
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 isGenericLambda() const
Determine whether this class describes a generic lambda function object (i.e.
unsigned getLambdaDependencyKind() const
const FunctionDecl * isLocalClass() const
If the class is a local class [class.local], returns the enclosing function declaration.
bool isLambda() const
Determine whether this class describes a lambda function object.
CXXRecordDecl * getDefinition() const
static CXXRecordDecl * CreateLambda(const ASTContext &C, DeclContext *DC, TypeSourceInfo *Info, SourceLocation Loc, unsigned DependencyKind, bool IsGeneric, LambdaCaptureDefault CaptureDefault)
TemplateSpecializationKind getTemplateSpecializationKind() const
Determine whether this particular class is a specialization or instantiation of a class template or m...
TypeSourceInfo * getLambdaTypeInfo() const
void setInstantiationOfMemberClass(CXXRecordDecl *RD, TemplateSpecializationKind TSK)
Specify that this record is an instantiation of the member class RD.
bool isInjectedClassName() const
Determines whether this declaration represents the injected class name.
LambdaCaptureDefault getLambdaCaptureDefault() const
void setDescribedClassTemplate(ClassTemplateDecl *Template)
CXXRecordDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
Represents a C++ nested-name-specifier or a global scope specifier.
void Adopt(NestedNameSpecifierLoc Other)
Adopt an existing nested-name-specifier (with source-range information).
Declaration of a class template.
void AddPartialSpecialization(ClassTemplatePartialSpecializationDecl *D, void *InsertPos)
Insert the specified partial specialization knowing that it is not already in.
ClassTemplateDecl * getMostRecentDecl()
CXXRecordDecl * getTemplatedDecl() const
Get the underlying class declarations of the template.
llvm::FoldingSetVector< ClassTemplatePartialSpecializationDecl > & getPartialSpecializations() const
Retrieve the set of partial specializations of this class template.
ClassTemplatePartialSpecializationDecl * findPartialSpecialization(ArrayRef< TemplateArgument > Args, TemplateParameterList *TPL, void *&InsertPos)
Return the partial specialization with the provided arguments if it exists, otherwise return the inse...
static ClassTemplateDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name, TemplateParameterList *Params, NamedDecl *Decl)
Create a class template node.
ClassTemplateDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
ClassTemplatePartialSpecializationDecl * findPartialSpecInstantiatedFromMember(ClassTemplatePartialSpecializationDecl *D)
Find a class template partial specialization which was instantiated from the given member partial spe...
void AddSpecialization(ClassTemplateSpecializationDecl *D, void *InsertPos)
Insert the specified specialization knowing that it is not already in.
void setCommonPtr(Common *C)
Common * getCommonPtr() const
ClassTemplateSpecializationDecl * findSpecialization(ArrayRef< TemplateArgument > Args, void *&InsertPos)
Return the specialization with the provided arguments if it exists, otherwise return the insertion po...
void setInstantiatedFromMember(ClassTemplatePartialSpecializationDecl *PartialSpec)
static ClassTemplatePartialSpecializationDecl * Create(ASTContext &Context, TagKind TK, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, TemplateParameterList *Params, ClassTemplateDecl *SpecializedTemplate, ArrayRef< TemplateArgument > Args, CanQualType CanonInjectedTST, ClassTemplatePartialSpecializationDecl *PrevDecl)
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
Represents a class template specialization, which refers to a class template with a given set of temp...
TemplateSpecializationKind getSpecializationKind() const
Determine the kind of specialization that this declaration represents.
const ASTTemplateArgumentListInfo * getTemplateArgsAsWritten() const
Retrieve the template argument list as written in the sources, if any.
ClassTemplateDecl * getSpecializedTemplate() const
Retrieve the template that this specialization specializes.
static ClassTemplateSpecializationDecl * Create(ASTContext &Context, TagKind TK, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, ClassTemplateDecl *SpecializedTemplate, ArrayRef< TemplateArgument > Args, bool StrictPackMatch, ClassTemplateSpecializationDecl *PrevDecl)
SourceLocation getPointOfInstantiation() const
Get the point of instantiation (if any), or null if none.
void setExternKeywordLoc(SourceLocation Loc)
Sets the location of the extern keyword.
void setSpecializationKind(TemplateSpecializationKind TSK)
SourceLocation getExternKeywordLoc() const
Gets the location of the extern keyword, if present.
SourceLocation getTemplateKeywordLoc() const
Gets the location of the template keyword, if present.
void setTemplateKeywordLoc(SourceLocation Loc)
Sets the location of the template keyword.
void setTemplateArgsAsWritten(const ASTTemplateArgumentListInfo *ArgsWritten)
Set the template argument list as written in the sources.
Declaration of a C++20 concept.
const TypeClass * getTypePtr() const
Represents a shadow constructor declaration introduced into a class by a C++11 using-declaration that...
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.
bool Equals(const DeclContext *DC) const
Determine whether this declaration context is equivalent to the declaration context DC.
bool isFileContext() const
void makeDeclVisibleInContext(NamedDecl *D)
Makes a declaration visible within this context.
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.
DeclContext * getRedeclContext()
getRedeclContext - Retrieve the context in which an entity conflicts with other entities of the same ...
void addDecl(Decl *D)
Add the declaration D into this context.
decl_iterator decls_end() const
ddiag_range ddiags() const
decl_range decls() const
decls_begin/decls_end - Iterate over the declarations stored in this context.
bool isFunctionOrMethod() const
void addHiddenDecl(Decl *D)
Add the declaration D to this context without modifying any lookup tables.
decl_iterator decls_begin() const
static DeclRefExpr * Create(const ASTContext &Context, NestedNameSpecifierLoc QualifierLoc, SourceLocation TemplateKWLoc, ValueDecl *D, bool RefersToEnclosingVariableOrCapture, SourceLocation NameLoc, QualType T, ExprValueKind VK, NamedDecl *FoundD=nullptr, const TemplateArgumentListInfo *TemplateArgs=nullptr, NonOdrUseReason NOUR=NOUR_None)
Decl - This represents one declaration (or definition), e.g.
Decl * getPreviousDecl()
Retrieve the previous declaration that declares the same entity as this declaration,...
SourceLocation getEndLoc() const LLVM_READONLY
FriendObjectKind getFriendObjectKind() const
Determines whether this declaration is the object of a friend declaration and, if so,...
bool isImplicit() const
isImplicit - Indicates whether the declaration was implicitly generated by the implementation.
void setLocalExternDecl()
Changes the namespace of this declaration to reflect that it's a function-local extern declaration.
virtual bool isOutOfLine() const
Determine whether this declaration is declared out of line (outside its semantic context).
void setInvalidDecl(bool Invalid=true)
setInvalidDecl - Indicates the Decl had a semantic error.
bool isInIdentifierNamespace(unsigned NS) const
@ FOK_None
Not a friend object.
bool isReferenced() const
Whether any declaration of this entity was referenced.
unsigned getTemplateDepth() const
Determine the number of levels of template parameter surrounding this declaration.
void setObjectOfFriendDecl(bool PerformFriendInjection=false)
Changes the namespace of this declaration to reflect that it's the object of a friend declaration.
bool isFromASTFile() const
Determine whether this declaration came from an AST file (such as a precompiled header or module) rat...
bool isInLocalScopeForInstantiation() const
Determine whether a substitution into this declaration would occur as part of a substitution into a d...
DeclContext * getNonTransparentDeclContext()
Return the non transparent context.
bool isInvalidDecl() const
bool isLocalExternDecl() const
Determine whether this is a block-scope declaration with linkage.
llvm::iterator_range< specific_attr_iterator< T > > specific_attrs() const
void setAccess(AccessSpecifier AS)
SourceLocation getLocation() const
const char * getDeclKindName() const
@ IDNS_Ordinary
Ordinary names.
void setImplicit(bool I=true)
void setReferenced(bool R=true)
void setIsUsed()
Set whether the declaration is used, in the sense of odr-use.
bool isUsed(bool CheckUsedAttr=true) const
Whether any (re-)declaration of the entity was used, meaning that a definition is required.
DeclContext * getDeclContext()
AccessSpecifier getAccess() const
SourceLocation getBeginLoc() const LLVM_READONLY
DeclContext * getLexicalDeclContext()
getLexicalDeclContext - The declaration context where this Decl was lexically declared (LexicalDC).
void setNonMemberOperator()
Specifies that this declaration is a C++ overloaded non-member.
void setLexicalDeclContext(DeclContext *DC)
void setVisibleDespiteOwningModule()
Set that this declaration is globally visible, even if it came from a module that is not visible.
DeclarationNameLoc - Additional source/type location info for a declaration name.
static DeclarationNameLoc makeNamedTypeLoc(TypeSourceInfo *TInfo)
Construct location information for a constructor, destructor or conversion operator.
The name of a declaration.
@ CXXConversionFunctionName
NameKind getNameKind() const
Determine what kind of name this is.
Represents a ValueDecl that came out of a declarator.
SourceLocation getInnerLocStart() const
Return start of source range ignoring outer template declarations.
TemplateParameterList * getTemplateParameterList(unsigned index) const
SourceLocation getTypeSpecStartLoc() const
SourceLocation getBeginLoc() const LLVM_READONLY
const AssociatedConstraint & getTrailingRequiresClause() const
Get the constraint-expression introduced by the trailing requires-clause in the function/member decla...
unsigned getNumTemplateParameterLists() const
void setTypeSourceInfo(TypeSourceInfo *TI)
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier (with source-location information) that qualifies the name of this...
TypeSourceInfo * getTypeSourceInfo() const
A decomposition declaration.
ArrayRef< BindingDecl * > bindings() const
static DecompositionDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation LSquareLoc, QualType T, TypeSourceInfo *TInfo, StorageClass S, ArrayRef< BindingDecl * > Bindings)
Provides information about a dependent function-template specialization declaration.
RAII object that enters a new function expression evaluation context.
RAII object that enters a new expression evaluation context.
An instance of this object exists for each enum constant that is defined.
enumerator_range enumerators() const
bool isScoped() const
Returns true if this is a C++11 scoped enumeration.
bool isScopedUsingClassTag() const
Returns true if this is a C++11 scoped enumeration.
static EnumDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, EnumDecl *PrevDecl, bool IsScoped, bool IsScopedUsingClassTag, bool IsFixed)
TypeSourceInfo * getIntegerTypeSourceInfo() const
Return the type source info for the underlying integer type, if no type source info exists,...
bool isFixed() const
Returns true if this is an Objective-C, C++11, or Microsoft-style enumeration with a fixed underlying...
EnumDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
QualType getIntegerType() const
Return the integer type this enum decl corresponds to.
EnumDecl * getDefinition() const
TemplateSpecializationKind getTemplateSpecializationKind() const
If this enumeration is a member of a specialization of a templated class, determine what kind of temp...
Store information needed for an explicit specifier.
ExplicitSpecKind getKind() const
bool isInvalid() const
Determine if the explicit specifier is invalid.
static ExplicitSpecifier Invalid()
const Expr * getExpr() const
static ExplicitSpecifier getFromDecl(FunctionDecl *Function)
This represents one expression.
static bool isPotentialConstantExprUnevaluated(Expr *E, const FunctionDecl *FD, SmallVectorImpl< PartialDiagnosticAt > &Diags)
isPotentialConstantExprUnevaluated - Return true if this expression might be usable in a constant exp...
bool isValueDependent() const
Determines whether the value of this expression depends on.
std::optional< llvm::APSInt > getIntegerConstantExpr(const ASTContext &Ctx) const
isIntegerConstantExpr - Return the value if this expression is a valid integer constant expression.
bool isConstantInitializer(ASTContext &Ctx, bool ForRef, const Expr **Culprit=nullptr) const
isConstantInitializer - Returns true if this expression can be emitted to IR as a constant,...
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
Declaration context for names declared as extern "C" in C++.
Abstract interface for external sources of AST nodes.
Represents difference between two FPOptions values.
Represents a member of a struct/union/class.
bool isMutable() const
Determines whether this field is mutable (C++ only).
InClassInitStyle getInClassInitStyle() const
Get the kind of (C++11) default member initializer that this field has.
Expr * getBitWidth() const
Returns the expression that represents the bit width, if this field is a bit field.
FriendDecl - Represents the declaration of a friend entity, which can be a function,...
bool isUnsupportedFriend() const
Determines if this friend kind is unsupported.
static FriendDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, FriendUnion Friend_, SourceLocation FriendL, SourceLocation EllipsisLoc={}, ArrayRef< TemplateParameterList * > FriendTypeTPLists={})
SourceLocation getFriendLoc() const
Retrieves the location of the 'friend' keyword.
void setUnsupportedFriend(bool Unsupported)
SourceRange getSourceRange() const override LLVM_READONLY
Retrieves the source range for the friend declaration.
SourceLocation getEllipsisLoc() const
Retrieves the location of the '...', if present.
NamedDecl * getFriendDecl() const
If this friend declaration doesn't name a type, return the inner declaration.
TypeSourceInfo * getFriendType() const
If this friend declaration names an (untemplated but possibly dependent) type, return the type; other...
bool isPackExpansion() const
Declaration of a friend template.
static DefaultedOrDeletedFunctionInfo * Create(ASTContext &Context, ArrayRef< DeclAccessPair > Lookups, StringLiteral *DeletedMessage=nullptr)
Represents a function declaration or definition.
void setInstantiationIsPending(bool IC)
State that the instantiation of this function is pending.
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
Stmt * getBody(const FunctionDecl *&Definition) const
Retrieve the body (definition) of the function.
ConstexprSpecKind getConstexprKind() const
DefaultedOrDeletedFunctionInfo * getDefaultedOrDeletedInfo() const
FunctionTemplateDecl * getDescribedFunctionTemplate() const
Retrieves the function template that is described by this function declaration.
bool isThisDeclarationADefinition() const
Returns whether this specific declaration of the function is also a definition that does not contain ...
bool isDestroyingOperatorDelete() const
Determine whether this is a destroying operator delete.
StringLiteral * getDeletedMessage() const
Get the message that indicates why this function was deleted.
bool isInlined() const
Determine whether this function should be inlined, because it is either marked "inline" or "constexpr...
bool UsesFPIntrin() const
Determine whether the function was declared in source context that requires constrained FP intrinsics...
QualType getReturnType() const
ArrayRef< ParmVarDecl * > parameters() const
FunctionDecl * getTemplateInstantiationPattern(bool ForDefinition=true) const
Retrieve the function declaration from which this function could be instantiated, if it is an instant...
bool isExplicitlyDefaulted() const
Whether this function is explicitly defaulted.
bool hasWrittenPrototype() const
Whether this function has a written prototype.
FunctionDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
DependentFunctionTemplateSpecializationInfo * getDependentSpecializationInfo() const
bool isDeleted() const
Whether this function has been deleted.
StorageClass getStorageClass() const
Returns the storage class as written in the source.
bool isOutOfLine() const override
Determine whether this is or was instantiated from an out-of-line definition of a member function.
bool FriendConstraintRefersToEnclosingTemplate() const
bool isDeletedAsWritten() const
bool isPureVirtual() const
Whether this virtual function is pure, i.e.
bool isLateTemplateParsed() const
Whether this templated function will be late parsed.
bool hasSkippedBody() const
True if the function was a definition but its body was skipped.
FunctionDecl * getDefinition()
Get the definition for this declaration.
bool isTypeAwareOperatorNewOrDelete() const
Determine whether this is a type aware operator new or delete.
bool isThisDeclarationInstantiatedFromAFriendDefinition() const
Determine whether this specific declaration of the function is a friend declaration that was instanti...
bool isDefaulted() const
Whether this function is defaulted.
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
bool isVirtualAsWritten() const
Whether this function is marked as virtual explicitly.
unsigned getNumParams() const
Return the number of parameters this function must have based on its FunctionType.
DeclarationNameInfo getNameInfo() const
bool hasBody(const FunctionDecl *&Definition) const
Returns true if the function has a body.
bool isDefined(const FunctionDecl *&Definition, bool CheckForPendingFriendDefinition=false) const
Returns true if the function has a definition that does not need to be instantiated.
FunctionDecl * getPreviousDecl()
Return the previous declaration of this declaration or NULL if this is the first declaration.
bool isInlineSpecified() const
Determine whether the "inline" keyword was specified for this function.
bool willHaveBody() const
True if this function will eventually have a body, once it's fully parsed.
const ASTTemplateArgumentListInfo * getTemplateSpecializationArgsAsWritten() const
Retrieve the template argument list as written in the sources, if any.
Represents a prototype with parameter type info, e.g.
ExceptionSpecificationType getExceptionSpecType() const
Get the kind of exception specification on this function.
QualType getParamType(unsigned i) const
bool hasExceptionSpec() const
Return whether this function has any kind of exception spec.
ExtProtoInfo getExtProtoInfo() const
FunctionDecl * getExceptionSpecTemplate() const
If this function type has an uninstantiated exception specification, this is the function whose excep...
ArrayRef< QualType > getParamTypes() const
Declaration of a template function.
FunctionTemplateDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
FunctionDecl * getTemplatedDecl() const
Get the underlying function declaration of the template.
FunctionTemplateDecl * getInstantiatedFromMemberTemplate() const
void setInstantiatedFromMemberTemplate(FunctionTemplateDecl *D)
static FunctionTemplateDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name, TemplateParameterList *Params, NamedDecl *Decl)
Create a function template node.
ParmVarDecl * getParam(unsigned i) const
void setParam(unsigned i, ParmVarDecl *VD)
ExtInfo getExtInfo() const
bool getNoReturnAttr() const
Determine whether this function type includes the GNU noreturn attribute.
QualType getReturnType() const
HLSLBufferDecl - Represent a cbuffer or tbuffer declaration.
One of these records is kept for each identifier that is lexed.
bool isStr(const char(&Str)[StrLen]) const
Return true if this is the identifier for the specified string.
Represents a field injected from an anonymous union/struct into the parent scope.
unsigned getChainingSize() const
static IndirectFieldDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, const IdentifierInfo *Id, QualType T, MutableArrayRef< NamedDecl * > CH)
ArrayRef< NamedDecl * > chain() const
Description of a constructor that was inherited from a base class.
const TypeClass * getTypePtr() const
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'.
Represents the declaration of a label.
static LabelDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation IdentL, IdentifierInfo *II)
A stack-allocated class that identifies which local variable declaration instantiations are present i...
SmallVector< ValueDecl *, 4 > DeclArgumentPack
A set of declarations.
void InstantiatedLocal(const Decl *D, Decl *Inst)
void InstantiatedLocalPackArg(const Decl *D, VarDecl *Inst)
void MakeInstantiatedLocalArgPack(const Decl *D)
Represents the results of name lookup.
An instance of this class represents the declaration of a property member.
static MSPropertyDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName N, QualType T, TypeSourceInfo *TInfo, SourceLocation StartL, IdentifierInfo *Getter, IdentifierInfo *Setter)
IdentifierInfo * getGetterId() const
IdentifierInfo * getSetterId() const
Provides information a specialization of a member of a class template, which may be a member function...
Data structure that captures multiple levels of template argument lists for use in template instantia...
const ArgList & getInnermost() const
Retrieve the innermost template argument list.
void addOuterTemplateArguments(Decl *AssociatedDecl, ArgList Args, bool Final)
Add a new outmost level to the multi-level template argument list.
void setKind(TemplateSubstitutionKind K)
void addOuterRetainedLevels(unsigned Num)
unsigned getNumRetainedOuterLevels() const
This represents a decl that may have a name.
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.
bool hasLinkage() const
Determine whether this declaration has linkage.
bool isCXXClassMember() const
Determine whether this declaration is a C++ class member.
Represents a C++ namespace alias.
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier that qualifies the name of the namespace, with source-location inf...
SourceLocation getAliasLoc() const
Returns the location of the alias name, i.e.
static NamespaceAliasDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation NamespaceLoc, SourceLocation AliasLoc, IdentifierInfo *Alias, NestedNameSpecifierLoc QualifierLoc, SourceLocation IdentLoc, NamespaceBaseDecl *Namespace)
SourceLocation getNamespaceLoc() const
Returns the location of the namespace keyword.
SourceLocation getTargetNameLoc() const
Returns the location of the identifier in the named namespace.
NamespaceDecl * getNamespace()
Retrieve the namespace declaration aliased by this directive.
Represent a C++ namespace.
A C++ nested-name-specifier augmented with source location information.
SourceRange getSourceRange() const LLVM_READONLY
Retrieve the source range covering the entirety of this nested-name-specifier.
bool hasQualifier() const
Evaluates true when this nested-name-specifier location is non-empty.
NonTypeTemplateParmDecl - Declares a non-type template parameter, e.g., "Size" in.
bool isPackExpansion() const
Whether this parameter pack is a pack expansion.
bool hasDefaultArgument() const
Determine whether this template parameter has a default argument.
unsigned getPosition() const
Get the position of the template parameter within its parameter list.
bool defaultArgumentWasInherited() const
Determines whether the default argument was inherited from a previous declaration of this template.
TypeSourceInfo * getExpansionTypeSourceInfo(unsigned I) const
Retrieve a particular expansion type source info within an expanded parameter pack.
unsigned getNumExpansionTypes() const
Retrieves the number of expansion types in an expanded parameter pack.
const TemplateArgumentLoc & getDefaultArgument() const
Retrieve the default argument, if any.
bool isExpandedParameterPack() const
Whether this parameter is a non-type template parameter pack that has a known list of different types...
static NonTypeTemplateParmDecl * Create(const ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, unsigned D, unsigned P, const IdentifierInfo *Id, QualType T, bool ParameterPack, TypeSourceInfo *TInfo)
bool isParameterPack() const
Whether this parameter is a non-type template parameter pack.
unsigned getDepth() const
Get the nesting depth of the template parameter.
Expr * getPlaceholderTypeConstraint() const
Return the constraint introduced by the placeholder type of this non-type template parameter (if any)...
void setDefaultArgument(const ASTContext &C, const TemplateArgumentLoc &DefArg)
Set the default argument for this template parameter, and whether that default argument was inherited...
This represents 'pragma omp allocate ...' directive.
clauselist_range clauselists()
Pseudo declaration for capturing expressions.
This represents 'pragma omp declare mapper ...' directive.
OMPDeclareMapperDecl * getPrevDeclInScope()
Get reference to previous declare mapper construct in the same scope with the same name.
clauselist_iterator clauselist_begin()
clauselist_range clauselists()
DeclarationName getVarName()
Get the name of the variable declared in the mapper.
Expr * getMapperVarRef()
Get the variable declared in the mapper.
This represents 'pragma omp declare reduction ...' directive.
Expr * getInitializer()
Get initializer expression (if specified) of the declare reduction construct.
Expr * getInitPriv()
Get Priv variable of the initializer.
Expr * getCombinerOut()
Get Out variable of the combiner.
Expr * getCombinerIn()
Get In variable of the combiner.
Expr * getCombiner()
Get combiner expression of the declare reduction construct.
OMPDeclareReductionDecl * getPrevDeclInScope()
Get reference to previous declare reduction construct in the same scope with the same name.
Expr * getInitOrig()
Get Orig variable of the initializer.
OMPDeclareReductionInitKind getInitializerKind() const
Get initializer kind.
This represents 'pragma omp groupprivate ...' directive.
This represents 'pragma omp requires...' directive.
This represents 'pragma omp threadprivate ...' directive.
Helper data structure representing the traits in a match clause of an declare variant or metadirectiv...
bool anyScoreOrCondition(llvm::function_ref< bool(Expr *&, bool)> Cond)
Represents a field declaration created by an @defs(...).
static OpaquePtr make(QualType P)
static OpenACCBindClause * Create(const ASTContext &C, SourceLocation BeginLoc, SourceLocation LParenLoc, const IdentifierInfo *ID, SourceLocation EndLoc)
OpenACCDirectiveKind getDirectiveKind() const
ArrayRef< const OpenACCClause * > clauses() const
SourceLocation getDirectiveLoc() const
static OpenACCCopyClause * Create(const ASTContext &C, OpenACCClauseKind Spelling, SourceLocation BeginLoc, SourceLocation LParenLoc, OpenACCModifierKind Mods, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
static OpenACCCopyInClause * Create(const ASTContext &C, OpenACCClauseKind Spelling, SourceLocation BeginLoc, SourceLocation LParenLoc, OpenACCModifierKind Mods, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
static OpenACCCopyOutClause * Create(const ASTContext &C, OpenACCClauseKind Spelling, SourceLocation BeginLoc, SourceLocation LParenLoc, OpenACCModifierKind Mods, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
static OpenACCCreateClause * Create(const ASTContext &C, OpenACCClauseKind Spelling, SourceLocation BeginLoc, SourceLocation LParenLoc, OpenACCModifierKind Mods, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
static OpenACCDevicePtrClause * Create(const ASTContext &C, SourceLocation BeginLoc, SourceLocation LParenLoc, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
static OpenACCDeviceResidentClause * Create(const ASTContext &C, SourceLocation BeginLoc, SourceLocation LParenLoc, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
A 'device_type' or 'dtype' clause, takes a list of either an 'asterisk' or an identifier.
static OpenACCDeviceTypeClause * Create(const ASTContext &C, OpenACCClauseKind K, SourceLocation BeginLoc, SourceLocation LParenLoc, ArrayRef< DeviceTypeArgument > Archs, SourceLocation EndLoc)
static OpenACCLinkClause * Create(const ASTContext &C, SourceLocation BeginLoc, SourceLocation LParenLoc, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
static OpenACCNoHostClause * Create(const ASTContext &Ctx, SourceLocation BeginLoc, SourceLocation EndLoc)
static OpenACCPresentClause * Create(const ASTContext &C, SourceLocation BeginLoc, SourceLocation LParenLoc, ArrayRef< Expr * > VarList, SourceLocation EndLoc)
SourceLocation getRParenLoc() const
const Expr * getFunctionReference() const
SourceLocation getLParenLoc() const
static OpenACCSeqClause * Create(const ASTContext &Ctx, SourceLocation BeginLoc, SourceLocation EndLoc)
static OpenACCVectorClause * Create(const ASTContext &Ctx, SourceLocation BeginLoc, SourceLocation LParenLoc, Expr *IntExpr, SourceLocation EndLoc)
static OpenACCWorkerClause * Create(const ASTContext &Ctx, SourceLocation BeginLoc, SourceLocation LParenLoc, Expr *IntExpr, SourceLocation EndLoc)
SourceLocation getEllipsisLoc() const
TypeLoc getPatternLoc() const
Represents a parameter to a function.
Represents a #pragma detect_mismatch line.
PrettyDeclStackTraceEntry - If a crash occurs in the parser while parsing something related to a decl...
A (possibly-)qualified type.
bool isRestrictQualified() const
Determine whether this type is restrict-qualified.
bool isNull() const
Return true if this QualType doesn't point to a type yet.
QualType getNonReferenceType() const
If Type is a reference type (e.g., const int&), returns the type that the reference refers to ("const...
QualType getAtomicUnqualifiedType() const
Remove all qualifiers including _Atomic.
The collection of all-type qualifiers we support.
Represents a struct/union/class.
bool isAnonymousStructOrUnion() const
Whether this is an anonymous struct or union.
Wrapper for source info for record types.
Declaration of a redeclarable template.
void setInstantiatedFromMemberTemplate(RedeclarableTemplateDecl *TD)
decl_type * getFirstDecl()
Return the first declaration of this declaration or itself if this is the only declaration.
void setPreviousDecl(decl_type *PrevDecl)
Set the previous declaration.
Represents the body of a requires-expression.
static RequiresExprBodyDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc)
Scope - A scope is a transient data structure that is used while parsing the program.
void addAMDGPUFlatWorkGroupSizeAttr(Decl *D, const AttributeCommonInfo &CI, Expr *Min, Expr *Max)
addAMDGPUFlatWorkGroupSizeAttr - Adds an amdgpu_flat_work_group_size attribute to a particular declar...
void addAMDGPUWavesPerEUAttr(Decl *D, const AttributeCommonInfo &CI, Expr *Min, Expr *Max)
addAMDGPUWavePersEUAttr - Adds an amdgpu_waves_per_eu attribute to a particular declaration.
void addAMDGPUMaxNumWorkGroupsAttr(Decl *D, const AttributeCommonInfo &CI, Expr *XExpr, Expr *YExpr, Expr *ZExpr)
addAMDGPUMaxNumWorkGroupsAttr - Adds an amdgpu_max_num_work_groups attribute to a particular declarat...
SemaDiagnosticBuilder Diag(SourceLocation Loc, unsigned DiagID)
Emit a diagnostic.
void checkAllowedInitializer(VarDecl *VD)
QualType getInoutParameterType(QualType Ty)
bool inferObjCARCLifetime(ValueDecl *decl)
void AddXConsumedAttr(Decl *D, const AttributeCommonInfo &CI, Sema::RetainOwnershipKind K, bool IsTemplateInstantiation)
A type to represent all the data for an OpenACC Clause that has been parsed, but not yet created/sema...
OpenACCDirectiveKind getDirectiveKind() const
OpenACCClauseKind getClauseKind() const
void ActOnOpenMPDeclareVariantDirective(FunctionDecl *FD, Expr *VariantRef, OMPTraitInfo &TI, ArrayRef< Expr * > AdjustArgsNothing, ArrayRef< Expr * > AdjustArgsNeedDevicePtr, ArrayRef< Expr * > AdjustArgsNeedDeviceAddr, ArrayRef< OMPInteropInfo > AppendArgs, SourceLocation AdjustArgsLoc, SourceLocation AppendArgsLoc, SourceRange SR)
Called on well-formed '#pragma omp declare variant' after parsing of the associated method/function.
std::optional< std::pair< FunctionDecl *, Expr * > > checkOpenMPDeclareVariantFunction(DeclGroupPtrTy DG, Expr *VariantRef, OMPTraitInfo &TI, unsigned NumAppendArgs, SourceRange SR)
Checks '#pragma omp declare variant' variant function and original functions after parsing of the ass...
DeclGroupPtrTy ActOnOpenMPDeclareSimdDirective(DeclGroupPtrTy DG, OMPDeclareSimdDeclAttr::BranchStateTy BS, Expr *Simdlen, ArrayRef< Expr * > Uniforms, ArrayRef< Expr * > Aligneds, ArrayRef< Expr * > Alignments, ArrayRef< Expr * > Linears, ArrayRef< unsigned > LinModifiers, ArrayRef< Expr * > Steps, SourceRange SR)
Called on well-formed '#pragma omp declare simd' after parsing of the associated method/function.
void AddParameterABIAttr(Decl *D, const AttributeCommonInfo &CI, ParameterABI abi)
RAII object used to change the argument pack substitution index within a Sema object.
RAII object used to temporarily allow the C++ 'this' expression to be used, with the given qualifiers...
CXXSpecialMemberKind asSpecialMember() const
A helper class for building up ExtParameterInfos.
Records and restores the CurFPFeatures state on entry/exit of compound statements.
RAII class used to indicate that we are performing provisional semantic analysis to determine the val...
Sema - This implements semantic analysis and AST building for C.
MemInitResult BuildDelegatingInitializer(TypeSourceInfo *TInfo, Expr *Init, CXXRecordDecl *ClassDecl)
SmallVector< CodeSynthesisContext, 16 > CodeSynthesisContexts
List of active code synthesis contexts.
LocalInstantiationScope * CurrentInstantiationScope
The current instantiation scope used to store local variables.
TemplateArgumentLoc getTrivialTemplateArgumentLoc(const TemplateArgument &Arg, QualType NTTPType, SourceLocation Loc, NamedDecl *TemplateParam=nullptr)
Allocate a TemplateArgumentLoc where all locations have been initialized to the given location.
bool CheckUsingDeclQualifier(SourceLocation UsingLoc, bool HasTypename, const CXXScopeSpec &SS, const DeclarationNameInfo &NameInfo, SourceLocation NameLoc, const LookupResult *R=nullptr, const UsingDecl *UD=nullptr)
Checks that the given nested-name qualifier used in a using decl in the current context is appropriat...
DefaultedFunctionKind getDefaultedFunctionKind(const FunctionDecl *FD)
Determine the kind of defaulting that would be done for a given function.
@ LookupOrdinaryName
Ordinary name lookup, which finds ordinary names (functions, variables, typedefs, etc....
@ LookupUsingDeclName
Look up all declarations in a scope with the given name, including resolved using declarations.
@ LookupRedeclarationWithLinkage
Look up an ordinary name that is going to be redeclared as a name with linkage.
Decl * ActOnSkippedFunctionBody(Decl *Decl)
NamedDecl * FindInstantiatedDecl(SourceLocation Loc, NamedDecl *D, const MultiLevelTemplateArgumentList &TemplateArgs, bool FindingInstantiatedContext=false)
Find the instantiation of the given declaration within the current instantiation.
MemInitResult BuildBaseInitializer(QualType BaseType, TypeSourceInfo *BaseTInfo, Expr *Init, CXXRecordDecl *ClassDecl, SourceLocation EllipsisLoc)
bool InstantiateDefaultArgument(SourceLocation CallLoc, FunctionDecl *FD, ParmVarDecl *Param)
void AddAlignedAttr(Decl *D, const AttributeCommonInfo &CI, Expr *E, bool IsPackExpansion)
AddAlignedAttr - Adds an aligned attribute to a particular declaration.
const TranslationUnitKind TUKind
The kind of translation unit we are processing.
void InstantiateExceptionSpec(SourceLocation PointOfInstantiation, FunctionDecl *Function)
void AddAssumeAlignedAttr(Decl *D, const AttributeCommonInfo &CI, Expr *E, Expr *OE)
AddAssumeAlignedAttr - Adds an assume_aligned attribute to a particular declaration.
const ExpressionEvaluationContextRecord & currentEvaluationContext() const
void deduceOpenCLAddressSpace(ValueDecl *decl)
PragmaStack< FPOptionsOverride > FpPragmaStack
FunctionDecl * InstantiateFunctionDeclaration(FunctionTemplateDecl *FTD, const TemplateArgumentList *Args, SourceLocation Loc, CodeSynthesisContext::SynthesisKind CSC=CodeSynthesisContext::ExplicitTemplateArgumentSubstitution)
Instantiate (or find existing instantiation of) a function template with a given set of template argu...
bool tryResolveExplicitSpecifier(ExplicitSpecifier &ExplicitSpec)
tryResolveExplicitSpecifier - Attempt to resolve the explict specifier.
ExprResult SubstInitializer(Expr *E, const MultiLevelTemplateArgumentList &TemplateArgs, bool CXXDirectInit)
MemInitResult BuildMemberInitializer(ValueDecl *Member, Expr *Init, SourceLocation IdLoc)
VarTemplateSpecializationDecl * BuildVarTemplateInstantiation(VarTemplateDecl *VarTemplate, VarDecl *FromVar, const TemplateArgumentList *PartialSpecArgs, SmallVectorImpl< TemplateArgument > &Converted, SourceLocation PointOfInstantiation, LateInstantiatedAttrVec *LateAttrs=nullptr, LocalInstantiationScope *StartingScope=nullptr)
Decl * ActOnFinishFunctionBody(Decl *Decl, Stmt *Body, bool IsInstantiation=false, bool RetainFunctionScopeInfo=false)
Performs semantic analysis at the end of a function body.
void SubstExceptionSpec(FunctionDecl *New, const FunctionProtoType *Proto, const MultiLevelTemplateArgumentList &Args)
ExpressionEvaluationContextRecord & parentEvaluationContext()
LateParsedTemplateMapT LateParsedTemplateMap
bool SubstExprs(ArrayRef< Expr * > Exprs, bool IsCall, const MultiLevelTemplateArgumentList &TemplateArgs, SmallVectorImpl< Expr * > &Outputs)
Substitute the given template arguments into a list of expressions, expanding pack expansions if requ...
StmtResult SubstStmt(Stmt *S, const MultiLevelTemplateArgumentList &TemplateArgs)
ExprResult SubstExpr(Expr *E, const MultiLevelTemplateArgumentList &TemplateArgs)
DiagnosticsEngine & getDiagnostics() const
bool CheckParameterPacksForExpansion(SourceLocation EllipsisLoc, SourceRange PatternRange, ArrayRef< UnexpandedParameterPack > Unexpanded, const MultiLevelTemplateArgumentList &TemplateArgs, bool FailOnPackProducingTemplates, bool &ShouldExpand, bool &RetainExpansion, UnsignedOrNone &NumExpansions, bool Diagnose=true)
Determine whether we could expand a pack expansion with the given set of parameter packs into separat...
DeclGroupPtrTy ConvertDeclToDeclGroup(Decl *Ptr, Decl *OwnedType=nullptr)
void InstantiateMemInitializers(CXXConstructorDecl *New, const CXXConstructorDecl *Tmpl, const MultiLevelTemplateArgumentList &TemplateArgs)
void CleanupVarDeclMarking()
ASTContext & getASTContext() const
TypeSourceInfo * SubstType(TypeSourceInfo *T, const MultiLevelTemplateArgumentList &TemplateArgs, SourceLocation Loc, DeclarationName Entity, bool AllowDeducedTST=false)
Perform substitution on the type T with a given set of template arguments.
void InstantiateVariableDefinition(SourceLocation PointOfInstantiation, VarDecl *Var, bool Recursive=false, bool DefinitionRequired=false, bool AtEndOfTU=false)
Instantiate the definition of the given variable from its template.
SmallVector< LateInstantiatedAttribute, 1 > LateInstantiatedAttrVec
PrintingPolicy getPrintingPolicy() const
Retrieve a suitable printing policy for diagnostics.
void HandleDependentAccessCheck(const DependentDiagnostic &DD, const MultiLevelTemplateArgumentList &TemplateArgs)
@ TPL_TemplateMatch
We are matching the template parameter lists of two templates that might be redeclarations.
void SetDeclDefaulted(Decl *dcl, SourceLocation DefaultLoc)
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...
Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer, TranslationUnitKind TUKind=TU_Complete, CodeCompleteConsumer *CompletionConsumer=nullptr)
void InstantiateAttrs(const MultiLevelTemplateArgumentList &TemplateArgs, const Decl *Pattern, Decl *Inst, LateInstantiatedAttrVec *LateAttrs=nullptr, LocalInstantiationScope *OuterMostScope=nullptr)
const LangOptions & getLangOpts() const
void AddModeAttr(Decl *D, const AttributeCommonInfo &CI, IdentifierInfo *Name, bool InInstantiation=false)
AddModeAttr - Adds a mode attribute to a particular declaration.
void collectUnexpandedParameterPacks(TemplateArgument Arg, SmallVectorImpl< UnexpandedParameterPack > &Unexpanded)
Collect the set of unexpanded parameter packs within the given template argument.
const LangOptions & LangOpts
Decl * ActOnStartOfFunctionDef(Scope *S, Declarator &D, MultiTemplateParamsArg TemplateParamLists, SkipBodyInfo *SkipBody=nullptr, FnBodyKind BodyKind=FnBodyKind::Other)
VarTemplateSpecializationDecl * CompleteVarTemplateSpecializationDecl(VarTemplateSpecializationDecl *VarSpec, VarDecl *PatternDecl, const MultiLevelTemplateArgumentList &TemplateArgs)
Instantiates a variable template specialization by completing it with appropriate type information an...
void updateAttrsForLateParsedTemplate(const Decl *Pattern, Decl *Inst)
Update instantiation attributes after template was late parsed.
void InstantiateVariableInitializer(VarDecl *Var, VarDecl *OldVar, const MultiLevelTemplateArgumentList &TemplateArgs)
Instantiate the initializer of a variable.
SmallVector< PendingImplicitInstantiation, 1 > LateParsedInstantiations
Queue of implicit template instantiations that cannot be performed eagerly.
DeclarationNameInfo SubstDeclarationNameInfo(const DeclarationNameInfo &NameInfo, const MultiLevelTemplateArgumentList &TemplateArgs)
Do template substitution on declaration name info.
const VarDecl * getCopyElisionCandidate(NamedReturnInfo &Info, QualType ReturnType)
Updates given NamedReturnInfo's move-eligible and copy-elidable statuses, considering the function re...
void AddAllocAlignAttr(Decl *D, const AttributeCommonInfo &CI, Expr *ParamExpr)
AddAllocAlignAttr - Adds an alloc_align attribute to a particular declaration.
UnsignedOrNone getNumArgumentsInExpansion(QualType T, const MultiLevelTemplateArgumentList &TemplateArgs)
Determine the number of arguments in the given pack expansion type.
bool usesPartialOrExplicitSpecialization(SourceLocation Loc, ClassTemplateSpecializationDecl *ClassTemplateSpec)
ExplicitSpecifier instantiateExplicitSpecifier(const MultiLevelTemplateArgumentList &TemplateArgs, ExplicitSpecifier ES)
bool CheckVariableDeclaration(VarDecl *NewVD, LookupResult &Previous)
Perform semantic checking on a newly-created variable declaration.
sema::BlockScopeInfo * getCurBlock()
Retrieve the current block, if any.
DeclContext * CurContext
CurContext - This is the current declaration context of parsing.
MultiLevelTemplateArgumentList getTemplateInstantiationArgs(const NamedDecl *D, const DeclContext *DC=nullptr, bool Final=false, std::optional< ArrayRef< TemplateArgument > > Innermost=std::nullopt, bool RelativeToPrimary=false, const FunctionDecl *Pattern=nullptr, bool ForConstraintInstantiation=false, bool SkipForSpecialization=false, bool ForDefaultArgumentSubstitution=false)
Retrieve the template argument list(s) that should be used to instantiate the definition of the given...
std::deque< PendingImplicitInstantiation > PendingLocalImplicitInstantiations
The queue of implicit template instantiations that are required and must be performed within the curr...
ExprResult PerformContextuallyConvertToBool(Expr *From)
PerformContextuallyConvertToBool - Perform a contextual conversion of the expression From to bool (C+...
SourceManager & getSourceManager() const
FunctionDecl * SubstSpaceshipAsEqualEqual(CXXRecordDecl *RD, FunctionDecl *Spaceship)
Substitute the name and return type of a defaulted 'operator<=>' to form an implicit 'operator=='.
void PerformPendingInstantiations(bool LocalOnly=false, bool AtEndOfTU=true)
Performs template instantiation for all implicit template instantiations we have seen until this poin...
Decl * SubstDecl(Decl *D, DeclContext *Owner, const MultiLevelTemplateArgumentList &TemplateArgs)
void ActOnMemInitializers(Decl *ConstructorDecl, SourceLocation ColonLoc, ArrayRef< CXXCtorInitializer * > MemInits, bool AnyErrors)
ActOnMemInitializers - Handle the member initializers for a constructor.
TemplateParameterList * SubstTemplateParams(TemplateParameterList *Params, DeclContext *Owner, const MultiLevelTemplateArgumentList &TemplateArgs, bool EvaluateConstraints=true)
void AddLaunchBoundsAttr(Decl *D, const AttributeCommonInfo &CI, Expr *MaxThreads, Expr *MinBlocks, Expr *MaxBlocks)
AddLaunchBoundsAttr - Adds a launch_bounds attribute to a particular declaration.
UnsignedOrNone ArgPackSubstIndex
The current index into pack expansion arguments that will be used for substitution of parameter packs...
void InstantiateDefaultCtorDefaultArgs(CXXConstructorDecl *Ctor)
In the MS ABI, we need to instantiate default arguments of dllexported default constructors along wit...
QualType CheckTemplateIdType(ElaboratedTypeKeyword Keyword, TemplateName Template, SourceLocation TemplateLoc, TemplateArgumentListInfo &TemplateArgs, Scope *Scope, bool ForNestedNameSpecifier)
RedeclarationKind forRedeclarationInCurContext() const
void InstantiateFunctionDefinition(SourceLocation PointOfInstantiation, FunctionDecl *Function, bool Recursive=false, bool DefinitionRequired=false, bool AtEndOfTU=false)
Instantiate the definition of the given function from its template.
bool CheckUsingDeclRedeclaration(SourceLocation UsingLoc, bool HasTypenameKeyword, const CXXScopeSpec &SS, SourceLocation NameLoc, const LookupResult &Previous)
Checks that the given using declaration is not an invalid redeclaration.
bool SubstDefaultArgument(SourceLocation Loc, ParmVarDecl *Param, const MultiLevelTemplateArgumentList &TemplateArgs, bool ForCallExpr=false)
Substitute the given template arguments into the default argument.
void InstantiateAttrsForDecl(const MultiLevelTemplateArgumentList &TemplateArgs, const Decl *Pattern, Decl *Inst, LateInstantiatedAttrVec *LateAttrs=nullptr, LocalInstantiationScope *OuterMostScope=nullptr)
IntrusiveRefCntPtr< ExternalSemaSource > ExternalSource
Source of additional semantic information.
sema::AnalysisBasedWarnings AnalysisWarnings
Worker object for performing CFG-based warnings.
bool hasUncompilableErrorOccurred() const
Whether uncompilable error has occurred.
std::deque< PendingImplicitInstantiation > PendingInstantiations
The queue of implicit template instantiations that are required but have not yet been performed.
bool CheckInheritingConstructorUsingDecl(UsingDecl *UD)
Additional checks for a using declaration referring to a constructor name.
void addClusterDimsAttr(Decl *D, const AttributeCommonInfo &CI, Expr *X, Expr *Y, Expr *Z)
@ ConstantEvaluated
The current context is "potentially evaluated" in C++11 terms, but the expression is evaluated at com...
@ PotentiallyEvaluated
The current expression is potentially evaluated at run time, which means that code may be generated t...
@ Unevaluated
The current expression and its subexpressions occur within an unevaluated operand (C++11 [expr]p7),...
NestedNameSpecifierLoc SubstNestedNameSpecifierLoc(NestedNameSpecifierLoc NNS, const MultiLevelTemplateArgumentList &TemplateArgs)
bool RequireCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind, TypeDiagnoser &Diagnoser)
Ensure that the type T is a complete type.
LateTemplateParserCB * LateTemplateParser
bool LookupQualifiedName(LookupResult &R, DeclContext *LookupCtx, bool InUnqualifiedLookup=false)
Perform qualified name lookup into a given context.
SmallVector< ExpressionEvaluationContextRecord, 8 > ExprEvalContexts
A stack of expression evaluation contexts.
bool DiagnoseUninstantiableTemplate(SourceLocation PointOfInstantiation, NamedDecl *Instantiation, bool InstantiatedFromMember, const NamedDecl *Pattern, const NamedDecl *PatternDef, TemplateSpecializationKind TSK, bool Complain=true, bool *Unreachable=nullptr)
Determine whether we would be unable to instantiate this template (because it either has no definitio...
SourceManager & SourceMgr
bool CheckAlignasTypeArgument(StringRef KWName, TypeSourceInfo *TInfo, SourceLocation OpLoc, SourceRange R)
static bool adjustContextForLocalExternDecl(DeclContext *&DC)
Adjust the DeclContext for a function or variable that might be a function-local external declaration...
Attr * CreateAnnotationAttr(const AttributeCommonInfo &CI, StringRef Annot, MutableArrayRef< Expr * > Args)
CreateAnnotationAttr - Creates an annotation Annot with Args arguments.
@ TPC_FriendFunctionTemplate
@ TPC_FriendFunctionTemplateDefinition
void DiagnoseUnusedDecl(const NamedDecl *ND)
void ActOnUninitializedDecl(Decl *dcl)
void AddInitializerToDecl(Decl *dcl, Expr *init, bool DirectInit)
AddInitializerToDecl - Adds the initializer Init to the declaration dcl.
void runWithSufficientStackSpace(SourceLocation Loc, llvm::function_ref< void()> Fn)
Run some code with "sufficient" stack space.
bool CheckSpanLikeType(const AttributeCommonInfo &CI, const QualType &Ty)
Check that the type is a plain record with one field being a pointer type and the other field being a...
void BuildVariableInstantiation(VarDecl *NewVar, VarDecl *OldVar, const MultiLevelTemplateArgumentList &TemplateArgs, LateInstantiatedAttrVec *LateAttrs, DeclContext *Owner, LocalInstantiationScope *StartingScope, bool InstantiatingVarTemplate=false, VarTemplateSpecializationDecl *PrevVTSD=nullptr)
BuildVariableInstantiation - Used after a new variable has been created.
void UpdateExceptionSpec(FunctionDecl *FD, const FunctionProtoType::ExceptionSpecInfo &ESI)
std::pair< ValueDecl *, SourceLocation > PendingImplicitInstantiation
An entity for which implicit template instantiation is required.
DeclContext * FindInstantiatedContext(SourceLocation Loc, DeclContext *DC, const MultiLevelTemplateArgumentList &TemplateArgs)
Finds the instantiation of the given declaration context within the current instantiation.
void AddAlignValueAttr(Decl *D, const AttributeCommonInfo &CI, Expr *E)
AddAlignValueAttr - Adds an align_value attribute to a particular declaration.
ArrayRef< sema::FunctionScopeInfo * > getFunctionScopes() const
void PerformDependentDiagnostics(const DeclContext *Pattern, const MultiLevelTemplateArgumentList &TemplateArgs)
OpaquePtr< DeclGroupRef > DeclGroupPtrTy
bool checkStringLiteralArgumentAttr(const AttributeCommonInfo &CI, const Expr *E, StringRef &Str, SourceLocation *ArgLocation=nullptr)
Check if the argument E is a ASCII string literal.
bool CheckCXXDefaultArgExpr(SourceLocation CallLoc, FunctionDecl *FD, ParmVarDecl *Param, Expr *Init=nullptr, bool SkipImmediateInvocations=true)
Instantiate or parse a C++ default argument expression as necessary.
ASTMutationListener * getASTMutationListener() const
ExprResult ActOnFinishFullExpr(Expr *Expr, bool DiscardedValue)
Encodes a location in the source.
A trivial tuple used to represent a source range.
SourceLocation getEnd() const
Represents a C++11 static_assert declaration.
SourceLocation getRParenLoc() const
Stmt - This represents one statement.
SourceLocation getEndLoc() const LLVM_READONLY
SourceLocation getBeginLoc() const LLVM_READONLY
Represents the declaration of a struct/union/class/enum.
bool isThisDeclarationADefinition() const
Return true if this declaration is a completion definition of the type.
bool isCompleteDefinition() const
Return true if this decl has its body fully specified.
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier (with source-location information) that qualifies the name of this...
TypedefNameDecl * getTypedefNameForAnonDecl() const
void setTypedefNameForAnonDecl(TypedefNameDecl *TDD)
void setQualifierInfo(NestedNameSpecifierLoc QualifierLoc)
bool hasNameForLinkage() const
Is this tag type named, either directly or via being defined in a typedef of this type?
TagKind getTagKind() const
SourceLocation getNameLoc() const
void setQualifierLoc(NestedNameSpecifierLoc QualifierLoc)
void setNameLoc(SourceLocation Loc)
void setElaboratedKeywordLoc(SourceLocation Loc)
A convenient class for passing around template argument information.
void setLAngleLoc(SourceLocation Loc)
void setRAngleLoc(SourceLocation Loc)
void addArgument(const TemplateArgumentLoc &Loc)
A template argument list.
static TemplateArgumentList * CreateCopy(ASTContext &Context, ArrayRef< TemplateArgument > Args)
Create a new template argument list that copies the given set of template arguments.
ArrayRef< TemplateArgument > asArray() const
Produce this as an array ref.
Location wrapper for a TemplateArgument.
const TemplateArgument & getArgument() const
SourceLocation getTemplateNameLoc() const
SourceLocation getTemplateKWLoc() const
NestedNameSpecifierLoc getTemplateQualifierLoc() const
Represents a template argument.
TemplateName getAsTemplate() const
Retrieve the template name for a template name argument.
@ Pack
The template argument is actually a parameter pack.
@ RewriteSpaceshipAsEqualEqual
void setEvaluateConstraints(bool B)
Decl * VisitDecl(Decl *D)
VarTemplateSpecializationDecl * VisitVarTemplateSpecializationDecl(VarTemplateDecl *VarTemplate, VarDecl *FromVar, ArrayRef< TemplateArgument > Converted, VarTemplateSpecializationDecl *PrevDecl=nullptr)
Decl * VisitVarDecl(VarDecl *D, bool InstantiatingVarTemplate, ArrayRef< BindingDecl * > *Bindings=nullptr)
bool InitMethodInstantiation(CXXMethodDecl *New, CXXMethodDecl *Tmpl)
Initializes common fields of an instantiated method declaration (New) from the corresponding fields o...
bool InitFunctionInstantiation(FunctionDecl *New, FunctionDecl *Tmpl)
Initializes the common fields of an instantiation function declaration (New) from the corresponding f...
VarTemplatePartialSpecializationDecl * InstantiateVarTemplatePartialSpecialization(VarTemplateDecl *VarTemplate, VarTemplatePartialSpecializationDecl *PartialSpec)
Instantiate the declaration of a variable template partial specialization.
void adjustForRewrite(RewriteKind RK, FunctionDecl *Orig, QualType &T, TypeSourceInfo *&TInfo, DeclarationNameInfo &NameInfo)
TypeSourceInfo * SubstFunctionType(FunctionDecl *D, SmallVectorImpl< ParmVarDecl * > &Params)
void InstantiateEnumDefinition(EnumDecl *Enum, EnumDecl *Pattern)
Decl * VisitFunctionDecl(FunctionDecl *D, TemplateParameterList *TemplateParams, RewriteKind RK=RewriteKind::None)
Normal class members are of more specific types and therefore don't make it here.
Decl * VisitCXXMethodDecl(CXXMethodDecl *D, TemplateParameterList *TemplateParams, RewriteKind RK=RewriteKind::None)
Decl * InstantiateTypeAliasTemplateDecl(TypeAliasTemplateDecl *D)
Decl * VisitBaseUsingDecls(BaseUsingDecl *D, BaseUsingDecl *Inst, LookupResult *Lookup)
bool SubstQualifier(const DeclaratorDecl *OldDecl, DeclaratorDecl *NewDecl)
TemplateParameterList * SubstTemplateParams(TemplateParameterList *List)
Instantiates a nested template parameter list in the current instantiation context.
Decl * InstantiateTypedefNameDecl(TypedefNameDecl *D, bool IsTypeAlias)
ClassTemplatePartialSpecializationDecl * InstantiateClassTemplatePartialSpecialization(ClassTemplateDecl *ClassTemplate, ClassTemplatePartialSpecializationDecl *PartialSpec)
Instantiate the declaration of a class template partial specialization.
bool SubstDefaultedFunction(FunctionDecl *New, FunctionDecl *Tmpl)
The base class of all kinds of template declarations (e.g., class, function, etc.).
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
bool isNull() const
Determine whether this template name is NULL.
A template parameter object.
Stores a list of template parameters for a TemplateDecl and its derived classes.
SourceRange getSourceRange() const LLVM_READONLY
static TemplateParameterList * Create(const ASTContext &C, SourceLocation TemplateLoc, SourceLocation LAngleLoc, ArrayRef< NamedDecl * > Params, SourceLocation RAngleLoc, Expr *RequiresClause)
Expr * getRequiresClause()
The constraint-expression of the associated requires-clause.
SourceLocation getRAngleLoc() const
SourceLocation getLAngleLoc() const
ArrayRef< NamedDecl * > asArray()
SourceLocation getTemplateLoc() const
TemplateTemplateParmDecl - Declares a template template parameter, e.g., "T" in.
bool wasDeclaredWithTypename() const
Whether this template template parameter was declared with the 'typename' keyword.
TemplateParameterList * getExpansionTemplateParameters(unsigned I) const
Retrieve a particular expansion type within an expanded parameter pack.
bool isPackExpansion() const
Whether this parameter pack is a pack expansion.
unsigned getNumExpansionTemplateParameters() const
Retrieves the number of expansion template parameters in an expanded parameter pack.
TemplateNameKind templateParameterKind() const
const TemplateArgumentLoc & getDefaultArgument() const
Retrieve the default argument, if any.
unsigned getPosition() const
Get the position of the template parameter within its parameter list.
static TemplateTemplateParmDecl * Create(const ASTContext &C, DeclContext *DC, SourceLocation L, unsigned D, unsigned P, bool ParameterPack, IdentifierInfo *Id, TemplateNameKind ParameterKind, bool Typename, TemplateParameterList *Params)
bool isParameterPack() const
Whether this template template parameter is a template parameter pack.
bool defaultArgumentWasInherited() const
Determines whether the default argument was inherited from a previous declaration of this template.
void setDefaultArgument(const ASTContext &C, const TemplateArgumentLoc &DefArg)
Set the default argument for this template parameter, and whether that default argument was inherited...
unsigned getDepth() const
Get the nesting depth of the template parameter.
bool isExpandedParameterPack() const
Whether this parameter is a template template parameter pack that has a known list of different templ...
bool hasDefaultArgument() const
Determine whether this template parameter has a default argument.
Declaration of a template type parameter.
bool wasDeclaredWithTypename() const
Whether this template type parameter was declared with the 'typename' keyword.
const TemplateArgumentLoc & getDefaultArgument() const
Retrieve the default argument, if any.
unsigned getIndex() const
Retrieve the index of the template parameter.
bool hasTypeConstraint() const
Determine whether this template parameter has a type-constraint.
const TypeConstraint * getTypeConstraint() const
Returns the type constraint associated with this template parameter (if any).
UnsignedOrNone getNumExpansionParameters() const
Whether this parameter is a template type parameter pack that has a known list of different type-cons...
bool hasDefaultArgument() const
Determine whether this template parameter has a default argument.
bool defaultArgumentWasInherited() const
Determines whether the default argument was inherited from a previous declaration of this template.
bool isParameterPack() const
Returns whether this is a parameter pack.
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)
unsigned getDepth() const
Retrieve the depth of the template parameter.
void setDefaultArgument(const ASTContext &C, const TemplateArgumentLoc &DefArg)
Set the default argument for this template parameter.
bool isPackExpansion() const
Whether this parameter pack is a pack expansion.
The top declaration context.
Represents the declaration of a typedef-name via a C++11 alias-declaration.
static TypeAliasDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, const IdentifierInfo *Id, TypeSourceInfo *TInfo)
void setDescribedAliasTemplate(TypeAliasTemplateDecl *TAT)
Declaration of an alias template.
static TypeAliasTemplateDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name, TemplateParameterList *Params, NamedDecl *Decl)
Create a function template node.
TypeAliasDecl * getTemplatedDecl() const
Get the underlying function declaration of the template.
const Type * getTypeForDecl() const
SourceLocation getBeginLoc() const LLVM_READONLY
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'.
Base wrapper for a particular "section" of type source info.
T getAs() const
Convert to the specified TypeLoc type, returning a null TypeLoc if this TypeLoc is not of the desired...
TypeLoc IgnoreParens() const
T castAs() const
Convert to the specified TypeLoc type, asserting that this TypeLoc is of the desired type.
SourceRange getSourceRange() const LLVM_READONLY
Get the full source range.
AutoTypeLoc getContainedAutoTypeLoc() const
Get the typeloc of an AutoType whose type will be deduced for a variable with an initializer of this ...
T getAsAdjusted() const
Convert to the specified TypeLoc type, returning a null TypeLoc if this TypeLoc is not of the desired...
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 isRValueReferenceType() const
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
AutoType * getContainedAutoType() const
Get the AutoType whose type will be deduced for a variable with an initializer of this type.
bool isInstantiationDependentType() const
Determine whether this type is an instantiation-dependent type, meaning that the type involves a temp...
bool isLValueReferenceType() const
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
bool containsUnexpandedParameterPack() const
Whether this type is or contains an unexpanded parameter pack, used to support C++0x variadic templat...
bool isTemplateTypeParmType() const
bool isAtomicType() const
bool isVariablyModifiedType() const
Whether this type is a variably-modified type (C99 6.7.5).
bool isUndeducedType() const
Determine whether this type is an undeduced type, meaning that it somehow involves a C++11 'auto' typ...
bool isFunctionType() const
const T * getAs() const
Member-template getAs<specific type>'.
Represents the declaration of a typedef-name via the 'typedef' type specifier.
static TypedefDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, const IdentifierInfo *Id, TypeSourceInfo *TInfo)
Base class for declarations which introduce a typedef-name.
TypeSourceInfo * getTypeSourceInfo() const
QualType getUnderlyingType() const
An artificial decl, representing a global anonymous constant value which is uniquified by value withi...
This node is generated when a using-declaration that was annotated with attribute((using_if_exists)) ...
static UnresolvedUsingIfExistsDecl * Create(ASTContext &Ctx, DeclContext *DC, SourceLocation Loc, DeclarationName Name)
Represents a dependent using declaration which was marked with typename.
SourceLocation getTypenameLoc() const
Returns the source location of the 'typename' keyword.
Represents a dependent using declaration which was not marked with typename.
Represents a C++ using-declaration.
bool hasTypename() const
Return true if the using declaration has 'typename'.
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier that qualifies the name, with source-location information.
DeclarationNameInfo getNameInfo() const
static UsingDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingL, NestedNameSpecifierLoc QualifierLoc, const DeclarationNameInfo &NameInfo, bool HasTypenameKeyword)
SourceLocation getUsingLoc() const
Return the source location of the 'using' keyword.
Represents C++ using-directive.
static UsingDirectiveDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingLoc, SourceLocation NamespaceLoc, NestedNameSpecifierLoc QualifierLoc, SourceLocation IdentLoc, NamedDecl *Nominated, DeclContext *CommonAncestor)
NamespaceDecl * getNominatedNamespace()
Returns the namespace nominated by this using-directive.
DeclContext * getCommonAncestor()
Returns the common ancestor context of this using-directive and its nominated namespace.
SourceLocation getNamespaceKeyLocation() const
Returns the location of the namespace keyword.
SourceLocation getIdentLocation() const
Returns the location of this using declaration's identifier.
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier that qualifies the name of the namespace, with source-location inf...
Represents a C++ using-enum-declaration.
SourceLocation getEnumLoc() const
The source location of the 'enum' keyword.
EnumDecl * getEnumDecl() const
TypeSourceInfo * getEnumType() const
static UsingEnumDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingL, SourceLocation EnumL, SourceLocation NameL, TypeSourceInfo *EnumType)
SourceLocation getUsingLoc() const
The source location of the 'using' keyword.
Represents a pack of using declarations that a single using-declarator pack-expanded into.
ArrayRef< NamedDecl * > expansions() const
Get the set of using declarations that this pack expanded into.
Represents a shadow declaration implicitly introduced into a scope by a (resolved) using-declaration ...
void setType(QualType newType)
bool isParameterPack() const
Determine whether this value is actually a function parameter pack, init-capture pack,...
Represents a variable declaration or definition.
VarTemplateDecl * getDescribedVarTemplate() const
Retrieves the variable template that is described by this variable declaration.
void setObjCForDecl(bool FRD)
static VarDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, const IdentifierInfo *Id, QualType T, TypeSourceInfo *TInfo, StorageClass S)
void setCXXForRangeDecl(bool FRD)
bool isConstexpr() const
Whether this variable is (C++11) constexpr.
void setInstantiationOfStaticDataMember(VarDecl *VD, TemplateSpecializationKind TSK)
Specify that this variable is an instantiation of the static data member VD.
TLSKind getTLSKind() const
void setInitStyle(InitializationStyle Style)
VarDecl * getMostRecentDecl()
Returns the most recent (re)declaration of this declaration.
InitializationStyle getInitStyle() const
The style of initialization for this declaration.
void setInitCapture(bool IC)
DefinitionKind isThisDeclarationADefinition(ASTContext &) const
Check whether this declaration is a definition.
bool isOutOfLine() const override
Determine whether this is or was instantiated from an out-of-line definition of a static data member.
VarDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
bool isInitCapture() const
Whether this variable is the implicit variable for a lambda init-capture.
@ CallInit
Call-style initialization (C++98)
bool isObjCForDecl() const
Determine whether this variable is a for-loop declaration for a for-in statement in Objective-C.
void setPreviousDeclInSameBlockScope(bool Same)
bool isInlineSpecified() const
bool isStaticDataMember() const
Determines whether this is a static data member.
VarDecl * getTemplateInstantiationPattern() const
Retrieve the variable declaration from which this variable could be instantiated, if it is an instant...
bool isCXXForRangeDecl() const
Determine whether this variable is the for-range-declaration in a C++0x for-range statement.
VarDecl * getDefinition(ASTContext &)
Get the real (not just tentative) definition for this declaration.
bool mightBeUsableInConstantExpressions(const ASTContext &C) const
Determine whether this variable's value might be usable in a constant expression, according to the re...
bool isNRVOVariable() const
Determine whether this local variable can be used with the named return value optimization (NRVO).
void setInlineSpecified()
bool isStaticLocal() const
Returns true if a variable with function scope is a static local variable.
void setTemplateSpecializationKind(TemplateSpecializationKind TSK, SourceLocation PointOfInstantiation=SourceLocation())
For a static data member that was instantiated from a static data member of a class template,...
void setTSCSpec(ThreadStorageClassSpecifier TSC)
void setNRVOVariable(bool NRVO)
bool isInline() const
Whether this variable is (C++1z) inline.
ThreadStorageClassSpecifier getTSCSpec() const
const Expr * getInit() const
void setConstexpr(bool IC)
void setDescribedVarTemplate(VarTemplateDecl *Template)
bool isDirectInit() const
Whether the initializer is a direct-initializer (list or call).
StorageClass getStorageClass() const
Returns the storage class as written in the source.
void setImplicitlyInline()
bool isPreviousDeclInSameBlockScope() const
Whether this local extern variable declaration's previous declaration was declared in the same block ...
VarDecl * getPreviousDecl()
Return the previous declaration of this declaration or NULL if this is the first declaration.
SourceLocation getPointOfInstantiation() const
If this variable is an instantiation of a variable template or a static data member of a class templa...
TemplateSpecializationKind getTemplateSpecializationKindForInstantiation() const
Get the template specialization kind of this variable for the purposes of template instantiation.
TemplateSpecializationKind getTemplateSpecializationKind() const
If this variable is an instantiation of a variable template or a static data member of a class templa...
Declaration of a variable template.
VarDecl * getTemplatedDecl() const
Get the underlying variable declarations of the template.
static VarTemplateDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name, TemplateParameterList *Params, VarDecl *Decl)
Create a variable template node.
llvm::FoldingSetVector< VarTemplatePartialSpecializationDecl > & getPartialSpecializations() const
Retrieve the set of partial specializations of this class template.
VarTemplateSpecializationDecl * findSpecialization(ArrayRef< TemplateArgument > Args, void *&InsertPos)
Return the specialization with the provided arguments if it exists, otherwise return the insertion po...
VarTemplatePartialSpecializationDecl * findPartialSpecInstantiatedFromMember(VarTemplatePartialSpecializationDecl *D)
Find a variable template partial specialization which was instantiated from the given member partial ...
static VarTemplatePartialSpecializationDecl * Create(ASTContext &Context, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, TemplateParameterList *Params, VarTemplateDecl *SpecializedTemplate, QualType T, TypeSourceInfo *TInfo, StorageClass S, ArrayRef< TemplateArgument > Args)
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
void setInstantiatedFromMember(VarTemplatePartialSpecializationDecl *PartialSpec)
Represents a variable template specialization, which refers to a variable template with a given set o...
SourceLocation getPointOfInstantiation() const
Get the point of instantiation (if any), or null if none.
void setTemplateArgsAsWritten(const ASTTemplateArgumentListInfo *ArgsWritten)
Set the template argument list as written in the sources.
const ASTTemplateArgumentListInfo * getTemplateArgsAsWritten() const
Retrieve the template argument list as written in the sources, if any.
const TemplateArgumentList & getTemplateArgs() const
Retrieve the template arguments of the variable template specialization.
const TemplateArgumentList & getTemplateInstantiationArgs() const
Retrieve the set of template arguments that should be used to instantiate the initializer of the vari...
static VarTemplateSpecializationDecl * Create(ASTContext &Context, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, VarTemplateDecl *SpecializedTemplate, QualType T, TypeSourceInfo *TInfo, StorageClass S, ArrayRef< TemplateArgument > Args)
llvm::PointerUnion< VarTemplateDecl *, VarTemplatePartialSpecializationDecl * > getSpecializedTemplateOrPartial() const
Retrieve the variable template or variable template partial specialization which was specialized by t...
TemplateSpecializationKind getSpecializationKind() const
Determine the kind of specialization that this declaration represents.
VarTemplateDecl * getSpecializedTemplate() const
Retrieve the template that this specialization specializes.
void setCompleteDefinition()
Decl * Visit(PTR(Decl) D)
QualType FunctionType
BlockType - The function type of the block, if one was given.
void addCapture(ValueDecl *Var, bool isBlock, bool isByref, bool isNested, SourceLocation Loc, SourceLocation EllipsisLoc, QualType CaptureType, bool Invalid)
Defines the clang::TargetInfo interface.
const internal::VariadicAllOfMatcher< Decl > decl
Matches declarations.
bool NE(InterpState &S, CodePtr OpPC)
std::variant< struct RequiresDecl, struct HeaderDecl, struct UmbrellaDirDecl, struct ModuleDecl, struct ExcludeDecl, struct ExportDecl, struct ExportAsDecl, struct ExternModuleDecl, struct UseDecl, struct LinkDecl, struct ConfigMacrosDecl, struct ConflictDecl > Decl
All declarations that can appear in a module declaration.
Attr * instantiateTemplateAttribute(const Attr *At, ASTContext &C, Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs)
Attr * instantiateTemplateAttributeForDecl(const Attr *At, ASTContext &C, Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs)
The JSON file list parser is used to communicate input to InstallAPI.
CanQual< Type > CanQualType
Represents a canonical, potentially-qualified type.
void atTemplateEnd(TemplateInstantiationCallbackPtrs &Callbacks, const Sema &TheSema, const Sema::CodeSynthesisContext &Inst)
bool isa(CodeGen::Address addr)
void atTemplateBegin(TemplateInstantiationCallbackPtrs &Callbacks, const Sema &TheSema, const Sema::CodeSynthesisContext &Inst)
@ Rewrite
We are substituting template parameters for (typically) other template parameters in order to rewrite...
QualType getFunctionOrMethodResultType(const Decl *D)
@ TemplateName
The identifier is a template name. FIXME: Add an annotation for that.
@ DevicePtr
'deviceptr' clause, allowed on Compute and Combined Constructs, plus 'data' and 'declare'.
@ VectorLength
'vector_length' clause, allowed on 'parallel', 'kernels', 'parallel loop', and 'kernels loop' constru...
@ Async
'async' clause, allowed on Compute, Data, 'update', 'wait', and Combined constructs.
@ Collapse
'collapse' clause, allowed on 'loop' and Combined constructs.
@ DeviceNum
'device_num' clause, allowed on 'init', 'shutdown', and 'set' constructs.
@ DefaultAsync
'default_async' clause, allowed on 'set' construct.
@ Attach
'attach' clause, allowed on Compute and Combined constructs, plus 'data' and 'enter data'.
@ NumGangs
'num_gangs' clause, allowed on 'parallel', 'kernels', parallel loop', and 'kernels loop' constructs.
@ If
'if' clause, allowed on all the Compute Constructs, Data Constructs, Executable Constructs,...
@ UseDevice
'use_device' clause, allowed on 'host_data' construct.
@ NoCreate
'no_create' clause, allowed on allowed on Compute and Combined constructs, plus 'data'.
@ Reduction
'reduction' clause, allowed on Parallel, Serial, Loop, and the combined constructs.
@ Self
'self' clause, allowed on Compute and Combined Constructs, plus 'update'.
@ FirstPrivate
'firstprivate' clause, allowed on 'parallel', 'serial', 'parallel loop', and 'serial loop' constructs...
@ Tile
'tile' clause, allowed on 'loop' and Combined constructs.
@ Independent
'independent' clause, allowed on 'loop' directives.
@ NumWorkers
'num_workers' clause, allowed on 'parallel', 'kernels', parallel loop', and 'kernels loop' constructs...
@ IfPresent
'if_present' clause, allowed on 'host_data' and 'update' directives.
@ Detach
'detach' clause, allowed on the 'exit data' construct.
@ Delete
'delete' clause, allowed on the 'exit data' construct.
@ Finalize
'finalize' clause, allowed on 'exit data' directive.
StorageClass
Storage classes.
bool isGenericLambdaCallOperatorOrStaticInvokerSpecialization(const DeclContext *DC)
@ Property
The type of a property.
@ Result
The result type of a method or function.
ActionResult< CXXCtorInitializer * > MemInitResult
const FunctionProtoType * T
@ Template
We are parsing a template declaration.
@ FunctionTemplate
The name was classified as a function template name.
@ VarTemplate
The name was classified as a variable template name.
@ TU_Prefix
The translation unit is a prefix to a translation unit, and is not complete.
@ VK_PRValue
A pr-value expression (in the C++11 taxonomy) produces a temporary value.
bool declaresSameEntity(const Decl *D1, const Decl *D2)
Determine whether two declarations declare the same entity.
TemplateSpecializationKind
Describes the kind of template specialization that a particular template specialization declaration r...
@ TSK_ExplicitInstantiationDefinition
This template specialization was instantiated from a template due to an explicit instantiation defini...
@ TSK_ExplicitInstantiationDeclaration
This template specialization was instantiated from a template due to an explicit instantiation declar...
@ TSK_ExplicitSpecialization
This template specialization was declared or defined by an explicit specialization (C++ [temp....
@ TSK_ImplicitInstantiation
This template specialization was implicitly instantiated from a template.
@ TSK_Undeclared
This template specialization was formed from a template-id but has not yet been declared,...
U cast(CodeGen::Address addr)
@ None
No keyword precedes the qualified type name.
@ Enum
The "enum" keyword introduces the elaborated-type-specifier.
bool isLambdaMethod(const DeclContext *DC)
ActionResult< Expr * > ExprResult
@ Other
Other implicit parameter.
ExceptionSpecificationType
The various types of exception specifications that exist in C++11.
@ EST_Uninstantiated
not instantiated yet
@ EST_None
no exception specification
@ EST_BasicNoexcept
noexcept
@ EST_Unevaluated
not evaluated yet, for special member function
ActionResult< Stmt * > StmtResult
Represents an explicit template argument list in C++, e.g., the "<int>" in "sort<int>".
SourceLocation RAngleLoc
The source location of the right angle bracket ('>').
SourceLocation LAngleLoc
The source location of the left angle bracket ('<').
ArrayRef< TemplateArgumentLoc > arguments() const
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
DeclarationName getName() const
getName - Returns the embedded declaration name.
void setName(DeclarationName N)
setName - Sets the embedded declaration name.
const DeclarationNameLoc & getInfo() const
TypeSourceInfo * getNamedTypeInfo() const
getNamedTypeInfo - Returns the source type info associated to the name.
Holds information about the various types of exception specification.
FunctionDecl * SourceDecl
The function whose exception specification this is, for EST_Unevaluated and EST_Uninstantiated.
FunctionDecl * SourceTemplate
The function template whose exception specification this is instantiated from, for EST_Uninstantiated...
ExceptionSpecificationType Type
The kind of exception specification this is.
Extra information about a function prototype.
ExceptionSpecInfo ExceptionSpec
FunctionType::ExtInfo ExtInfo
bool StrictPackMatch
Is set to true when, in the context of TTP matching, a pack parameter matches non-pack arguments.
SmallVector< TemplateArgument, 4 > CanonicalConverted
A context in which code is being synthesized (where a source location alone is not sufficient to iden...
SynthesisKind
The kind of template instantiation we are performing.
@ BuildingDeductionGuides
We are building deduction guides for a class.
@ DeducedTemplateArgumentSubstitution
We are substituting template argument determined as part of template argument deduction for either a ...
bool InLifetimeExtendingContext
Whether we are currently in a context in which all temporaries must be lifetime-extended,...
bool RebuildDefaultArgOrDefaultInit
Whether we should rebuild CXXDefaultArgExpr and CXXDefaultInitExpr.
VarDecl * DeclForInitializer
Declaration for initializer if one is currently being parsed.
A stack object to be created when performing template instantiation.
bool isInvalid() const
Determines whether we have exceeded the maximum recursive template instantiations.