40#include "llvm/ADT/SmallPtrSet.h"
41#include "llvm/ADT/SmallVector.h"
42#include "llvm/ADT/iterator_range.h"
43#include "llvm/Support/Casting.h"
44#include "llvm/Support/ErrorHandling.h"
45#include "llvm/Support/Format.h"
46#include "llvm/Support/raw_ostream.h"
58void AccessSpecDecl::anchor() {}
65void LazyASTUnresolvedSet::getFromExternalSource(
ASTContext &
C)
const {
67 assert(Impl.Decls.isLazy() &&
"getFromExternalSource for non-lazy set");
68 assert(Source &&
"getFromExternalSource with no external source");
73 Impl.Decls.setLazy(
false);
77 : UserDeclaredConstructor(
false), UserDeclaredSpecialMembers(0),
79 Abstract(
false), IsStandardLayout(
true), IsCXX11StandardLayout(
true),
80 HasBasesWithFields(
false), HasBasesWithNonStaticDataMembers(
false),
81 HasPrivateFields(
false), HasProtectedFields(
false),
82 HasPublicFields(
false), HasMutableFields(
false), HasVariantMembers(
false),
83 HasOnlyCMembers(
true), HasInitMethod(
false), HasInClassInitializer(
false),
84 HasUninitializedReferenceMember(
false), HasUninitializedFields(
false),
85 HasInheritedConstructor(
false), HasInheritedDefaultConstructor(
false),
86 HasInheritedAssignment(
false),
87 NeedOverloadResolutionForCopyConstructor(
false),
88 NeedOverloadResolutionForMoveConstructor(
false),
89 NeedOverloadResolutionForCopyAssignment(
false),
90 NeedOverloadResolutionForMoveAssignment(
false),
91 NeedOverloadResolutionForDestructor(
false),
92 DefaultedCopyConstructorIsDeleted(
false),
93 DefaultedMoveConstructorIsDeleted(
false),
94 DefaultedCopyAssignmentIsDeleted(
false),
95 DefaultedMoveAssignmentIsDeleted(
false),
96 DefaultedDestructorIsDeleted(
false), HasTrivialSpecialMembers(SMF_All),
97 HasTrivialSpecialMembersForCall(SMF_All),
98 DeclaredNonTrivialSpecialMembers(0),
99 DeclaredNonTrivialSpecialMembersForCall(0), HasIrrelevantDestructor(
true),
100 HasConstexprNonCopyMoveConstructor(
false),
101 HasDefaultedDefaultConstructor(
false),
102 DefaultedDefaultConstructorIsConstexpr(
true),
103 HasConstexprDefaultConstructor(
false),
104 DefaultedDestructorIsConstexpr(
true),
105 HasNonLiteralTypeFieldsOrBases(
false), StructuralIfLiteral(
true),
106 UserProvidedDefaultConstructor(
false), DeclaredSpecialMembers(0),
107 ImplicitCopyConstructorCanHaveConstParamForVBase(
true),
108 ImplicitCopyConstructorCanHaveConstParamForNonVBase(
true),
109 ImplicitCopyAssignmentHasConstParam(
true),
110 HasDeclaredCopyConstructorWithConstParam(
false),
111 HasDeclaredCopyAssignmentWithConstParam(
false),
112 IsAnyDestructorNoReturn(
false), IsHLSLIntangible(
false), IsLambda(
false),
113 IsParsingBaseSpecifiers(
false), ComputedVisibleConversions(
false),
117 return Bases.get(
Definition->getASTContext().getExternalSource());
121 return VBases.get(
Definition->getASTContext().getExternalSource());
129 DefinitionData(PrevDecl ? PrevDecl->DefinitionData
136 bool DelayTypeCreation) {
142 if (!DelayTypeCreation)
143 C.getTypeDeclType(R, PrevDecl);
150 unsigned DependencyKind,
bool IsGeneric,
153 Loc,
nullptr,
nullptr);
155 R->DefinitionData =
new (
C)
struct LambdaDefinitionData(
156 R, Info, DependencyKind, IsGeneric, CaptureDefault);
157 R->setMayHaveOutOfDateDef(
false);
158 R->setImplicit(
true);
160 C.getTypeDeclType(R,
nullptr);
166 auto *R =
new (
C, ID)
179 while (!WorkList.empty()) {
184 if (
const CXXRecordDecl *B = BaseSpec.getType()->getAsCXXRecordDecl()) {
185 if (!SeenBaseTypes.insert(B).second)
187 WorkList.push_back(B);
199 if (!data().Bases.isOffset() && data().NumBases > 0)
200 C.Deallocate(data().getBases());
203 if (!
C.getLangOpts().CPlusPlus17) {
206 data().Aggregate =
false;
211 data().PlainOldData =
false;
221 data().NumBases = NumBases;
222 for (
unsigned i = 0; i < NumBases; ++i) {
223 data().getBases()[i] = *Bases[i];
230 auto *BaseClassDecl =
238 if (BaseClassDecl->data().HasBasesWithFields ||
239 !BaseClassDecl->field_empty()) {
240 if (data().HasBasesWithFields)
242 data().IsStandardLayout =
false;
243 data().HasBasesWithFields =
true;
250 if (BaseClassDecl->data().HasBasesWithNonStaticDataMembers ||
251 BaseClassDecl->hasDirectFields()) {
252 if (data().HasBasesWithNonStaticDataMembers)
253 data().IsCXX11StandardLayout =
false;
254 data().HasBasesWithNonStaticDataMembers =
true;
257 if (!BaseClassDecl->isEmpty()) {
261 data().Empty =
false;
267 data().Aggregate =
false;
272 data().StructuralIfLiteral =
false;
278 if (BaseClassDecl->isPolymorphic()) {
279 data().Polymorphic =
true;
282 data().Aggregate =
false;
288 if (!BaseClassDecl->isStandardLayout())
289 data().IsStandardLayout =
false;
290 if (!BaseClassDecl->isCXX11StandardLayout())
291 data().IsCXX11StandardLayout =
false;
295 data().HasNonLiteralTypeFieldsOrBases =
true;
298 for (
const auto &VBase : BaseClassDecl->vbases()) {
300 if (SeenVBaseTypes.insert(
C.getCanonicalType(VBase.getType())).second) {
301 VBases.push_back(&VBase);
308 if (
CXXRecordDecl *VBaseDecl = VBase.getType()->getAsCXXRecordDecl())
309 if (!VBaseDecl->hasCopyConstructorWithConstParam())
310 data().ImplicitCopyConstructorCanHaveConstParamForVBase =
false;
314 data().Aggregate =
false;
318 if (
Base->isVirtual()) {
320 if (SeenVBaseTypes.insert(
C.getCanonicalType(BaseType)).second)
321 VBases.push_back(
Base);
326 data().Empty =
false;
330 data().Aggregate =
false;
336 data().HasTrivialSpecialMembers &= SMF_Destructor;
337 data().HasTrivialSpecialMembersForCall &= SMF_Destructor;
342 data().IsStandardLayout =
false;
343 data().IsCXX11StandardLayout =
false;
349 data().DefaultedDefaultConstructorIsConstexpr =
false;
350 data().DefaultedDestructorIsConstexpr =
false;
357 if (!BaseClassDecl->hasCopyConstructorWithConstParam())
358 data().ImplicitCopyConstructorCanHaveConstParamForVBase =
false;
364 if (!BaseClassDecl->hasTrivialDefaultConstructor())
365 data().HasTrivialSpecialMembers &= ~SMF_DefaultConstructor;
372 if (!BaseClassDecl->hasTrivialCopyConstructor())
373 data().HasTrivialSpecialMembers &= ~SMF_CopyConstructor;
375 if (!BaseClassDecl->hasTrivialCopyConstructorForCall())
376 data().HasTrivialSpecialMembersForCall &= ~SMF_CopyConstructor;
382 if (!BaseClassDecl->hasTrivialMoveConstructor())
383 data().HasTrivialSpecialMembers &= ~SMF_MoveConstructor;
385 if (!BaseClassDecl->hasTrivialMoveConstructorForCall())
386 data().HasTrivialSpecialMembersForCall &= ~SMF_MoveConstructor;
393 if (!BaseClassDecl->hasTrivialCopyAssignment())
394 data().HasTrivialSpecialMembers &= ~SMF_CopyAssignment;
399 if (!BaseClassDecl->hasTrivialMoveAssignment())
400 data().HasTrivialSpecialMembers &= ~SMF_MoveAssignment;
406 if (!BaseClassDecl->hasConstexprDefaultConstructor())
407 data().DefaultedDefaultConstructorIsConstexpr =
408 C.getLangOpts().CPlusPlus23;
415 if (!BaseClassDecl->hasCopyConstructorWithConstParam())
416 data().ImplicitCopyConstructorCanHaveConstParamForNonVBase =
false;
422 if (!BaseClassDecl->hasTrivialDestructor())
423 data().HasTrivialSpecialMembers &= ~SMF_Destructor;
425 if (!BaseClassDecl->hasTrivialDestructorForCall())
426 data().HasTrivialSpecialMembersForCall &= ~SMF_Destructor;
428 if (!BaseClassDecl->hasIrrelevantDestructor())
429 data().HasIrrelevantDestructor =
false;
431 if (BaseClassDecl->isAnyDestructorNoReturn())
432 data().IsAnyDestructorNoReturn =
true;
434 if (BaseClassDecl->isHLSLIntangible())
435 data().IsHLSLIntangible =
true;
442 if (!BaseClassDecl->hasCopyAssignmentWithConstParam())
443 data().ImplicitCopyAssignmentHasConstParam =
false;
447 if (BaseClassDecl->hasObjectMember())
450 if (BaseClassDecl->hasVolatileMember())
453 if (BaseClassDecl->getArgPassingRestrictions() ==
458 if (BaseClassDecl->hasMutableFields())
459 data().HasMutableFields =
true;
461 if (BaseClassDecl->hasUninitializedExplicitInitFields() &&
462 BaseClassDecl->isAggregate())
465 if (BaseClassDecl->hasUninitializedReferenceMember())
466 data().HasUninitializedReferenceMember =
true;
468 if (!BaseClassDecl->allowConstDefaultInit())
469 data().HasUninitializedFields =
true;
471 addedClassSubobject(BaseClassDecl);
482 data().IsStandardLayout =
false;
484 if (VBases.empty()) {
485 data().IsParsingBaseSpecifiers =
false;
491 data().NumVBases = VBases.size();
492 for (
int I = 0,
E = VBases.size(); I !=
E; ++I) {
496 data().getVBases()[I] = *VBases[I];
499 data().IsParsingBaseSpecifiers =
false;
503 assert(
hasDefinition() &&
"ODRHash only for records with definitions");
506 if (DefinitionData->HasODRHash)
507 return DefinitionData->ODRHash;
512 DefinitionData->HasODRHash =
true;
515 return DefinitionData->ODRHash;
518void CXXRecordDecl::addedClassSubobject(
CXXRecordDecl *Subobj) {
526 data().NeedOverloadResolutionForCopyConstructor =
true;
528 data().NeedOverloadResolutionForMoveConstructor =
true;
537 data().NeedOverloadResolutionForCopyAssignment =
true;
539 data().NeedOverloadResolutionForMoveAssignment =
true;
549 data().NeedOverloadResolutionForCopyConstructor =
true;
550 data().NeedOverloadResolutionForMoveConstructor =
true;
551 data().NeedOverloadResolutionForDestructor =
true;
560 data().DefaultedDestructorIsConstexpr =
567 if (!Subobj->data().StructuralIfLiteral)
568 data().StructuralIfLiteral =
false;
574 "getStandardLayoutBaseWithFields called on a non-standard-layout type");
575#ifdef EXPENSIVE_CHECKS
577 unsigned NumberOfBasesWithFields = 0;
579 ++NumberOfBasesWithFields;
582 if (!
Base->field_empty())
583 ++NumberOfBasesWithFields;
585 UniqueBases.insert(
Base->getCanonicalDecl()).second &&
586 "Standard layout struct has multiple base classes of the same type");
589 assert(NumberOfBasesWithFields <= 1 &&
590 "Standard layout struct has fields declared in more than one class");
597 if (!
Base->field_empty()) {
649void CXXRecordDecl::markedVirtualFunctionPure() {
652 data().Abstract =
true;
655bool CXXRecordDecl::hasSubobjectAtOffsetZeroOfEmptyBaseType(
666 RD = RD->getCanonicalDecl();
674 if (!RD->data().HasBasesWithFields) {
693 if (M.insert(RD).second)
694 WorkList.push_back(RD);
701 while (!WorkList.empty()) {
711 bool IsFirstField =
true;
712 for (
auto *FD :
X->fields()) {
715 if (FD->isUnnamedBitField())
718 if (!IsFirstField && !FD->isZeroSize(Ctx))
721 if (FD->isInvalidDecl())
731 IsFirstField =
false;
739 assert(
isLambda() &&
"not a lambda");
756void CXXRecordDecl::addedMember(
Decl *
D) {
757 if (!
D->
isImplicit() && !isa<FieldDecl>(
D) && !isa<IndirectFieldDecl>(
D) &&
761 data().HasOnlyCMembers =
false;
767 auto *FunTmpl = dyn_cast<FunctionTemplateDecl>(
D);
769 D = FunTmpl->getTemplatedDecl();
772 Decl *DUnderlying =
D;
773 if (
auto *ND = dyn_cast<NamedDecl>(DUnderlying)) {
774 DUnderlying = ND->getUnderlyingDecl();
775 if (
auto *UnderlyingFunTmpl = dyn_cast<FunctionTemplateDecl>(DUnderlying))
776 DUnderlying = UnderlyingFunTmpl->getTemplatedDecl();
779 if (
const auto *Method = dyn_cast<CXXMethodDecl>(
D)) {
780 if (Method->isVirtual()) {
783 data().Aggregate =
false;
787 data().PlainOldData =
false;
791 data().Empty =
false;
796 data().Polymorphic =
true;
802 data().HasTrivialSpecialMembers &= SMF_Destructor;
803 data().HasTrivialSpecialMembersForCall &= SMF_Destructor;
808 data().IsStandardLayout =
false;
809 data().IsCXX11StandardLayout =
false;
823 if (
const auto *Constructor = dyn_cast<CXXConstructorDecl>(
D)) {
830 data().UserDeclaredConstructor =
true;
840 data().PlainOldData =
false;
845 SMKind |= SMF_DefaultConstructor;
848 data().UserProvidedDefaultConstructor =
true;
850 data().HasConstexprDefaultConstructor =
true;
852 data().HasDefaultedDefaultConstructor =
true;
858 SMKind |= SMF_CopyConstructor;
861 data().HasDeclaredCopyConstructorWithConstParam =
true;
863 SMKind |= SMF_MoveConstructor;
875 data().Aggregate =
false;
880 if (
const auto *Constructor = dyn_cast<CXXConstructorDecl>(DUnderlying)) {
888 data().HasConstexprNonCopyMoveConstructor =
true;
889 if (!isa<CXXConstructorDecl>(
D) &&
Constructor->isDefaultConstructor())
890 data().HasInheritedDefaultConstructor =
true;
894 if (
const auto *Method = dyn_cast<CXXMethodDecl>(
D)) {
895 if (isa<CXXDestructorDecl>(
D))
896 SMKind |= SMF_Destructor;
898 if (Method->isCopyAssignmentOperator()) {
899 SMKind |= SMF_CopyAssignment;
901 const auto *ParamTy =
902 Method->getNonObjectParameter(0)->getType()->getAs<
ReferenceType>();
903 if (!ParamTy || ParamTy->getPointeeType().isConstQualified())
904 data().HasDeclaredCopyAssignmentWithConstParam =
true;
907 if (Method->isMoveAssignmentOperator())
908 SMKind |= SMF_MoveAssignment;
911 if (
auto *Conversion = dyn_cast<CXXConversionDecl>(
D)) {
920 if (Conversion->getPrimaryTemplate()) {
926 FunTmpl ? cast<NamedDecl>(FunTmpl) :
cast<
NamedDecl>(Conversion);
931 Conversions.
addDecl(Ctx, Primary, AS);
938 data().HasTrivialSpecialMembers &=
939 data().DeclaredSpecialMembers | ~SMKind;
940 data().HasTrivialSpecialMembersForCall &=
941 data().DeclaredSpecialMembers | ~SMKind;
945 data().DeclaredSpecialMembers |= SMKind;
946 if (!Method->isImplicit()) {
947 data().UserDeclaredSpecialMembers |= SMKind;
950 if ((!Method->isDeleted() && !Method->isDefaulted() &&
951 SMKind != SMF_MoveAssignment) ||
965 data().PlainOldData =
false;
973 if (!Method->isIneligibleOrNotSelected()) {
982 if (
const auto *Field = dyn_cast<FieldDecl>(
D)) {
990 if (data().HasBasesWithFields)
991 data().IsStandardLayout =
false;
997 if (
Field->isUnnamedBitField()) {
1001 if (data().
Empty && !
Field->isZeroLengthBitField() &&
1004 data().Empty =
false;
1012 if (data().HasBasesWithNonStaticDataMembers)
1013 data().IsCXX11StandardLayout =
false;
1021 data().Aggregate =
false;
1022 data().PlainOldData =
false;
1027 data().StructuralIfLiteral =
false;
1032 bool IsFirstField = !data().HasPrivateFields &&
1033 !data().HasProtectedFields && !data().HasPublicFields;
1040 case AS_private: data().HasPrivateFields =
true;
break;
1041 case AS_protected: data().HasProtectedFields =
true;
break;
1042 case AS_public: data().HasPublicFields =
true;
break;
1043 case AS_none: llvm_unreachable(
"Invalid access specifier");
1045 if ((data().HasPrivateFields + data().HasProtectedFields +
1046 data().HasPublicFields) > 1) {
1047 data().IsStandardLayout =
false;
1048 data().IsCXX11StandardLayout =
false;
1052 if (
Field->isMutable()) {
1053 data().HasMutableFields =
true;
1058 data().StructuralIfLiteral =
false;
1065 data().HasVariantMembers =
true;
1067 if (
isUnion() && IsFirstField)
1068 data().HasUninitializedFields =
true;
1079 if (
T.hasNonTrivialObjCLifetime()) {
1087 struct DefinitionData &
Data = data();
1088 Data.PlainOldData =
false;
1089 Data.HasTrivialSpecialMembers = 0;
1095 data().HasTrivialSpecialMembersForCall = 0;
1101 Data.HasIrrelevantDestructor =
false;
1104 data().DefaultedCopyConstructorIsDeleted =
true;
1105 data().DefaultedMoveConstructorIsDeleted =
true;
1106 data().DefaultedCopyAssignmentIsDeleted =
true;
1107 data().DefaultedMoveAssignmentIsDeleted =
true;
1108 data().DefaultedDestructorIsDeleted =
true;
1109 data().NeedOverloadResolutionForCopyConstructor =
true;
1110 data().NeedOverloadResolutionForMoveConstructor =
true;
1111 data().NeedOverloadResolutionForCopyAssignment =
true;
1112 data().NeedOverloadResolutionForMoveAssignment =
true;
1113 data().NeedOverloadResolutionForDestructor =
true;
1115 }
else if (!Context.
getLangOpts().ObjCAutoRefCount) {
1118 }
else if (!
T.isCXX98PODType(Context))
1119 data().PlainOldData =
false;
1121 if (
Field->hasAttr<ExplicitInitAttr>())
1125 if (!
Field->hasInClassInitializer())
1126 data().HasUninitializedReferenceMember =
true;
1131 data().IsStandardLayout =
false;
1132 data().IsCXX11StandardLayout =
false;
1138 data().DefaultedCopyConstructorIsDeleted =
true;
1142 if (
Field->hasInClassInitializer())
1143 data().HasUninitializedFields =
false;
1144 }
else if (!
Field->hasInClassInitializer() && !
Field->isMutable()) {
1146 if (FieldType->hasDefinition() && !FieldType->allowConstDefaultInit())
1147 data().HasUninitializedFields =
true;
1149 data().HasUninitializedFields =
true;
1155 data().HasNonLiteralTypeFieldsOrBases =
true;
1157 if (
Field->hasInClassInitializer() ||
1158 (
Field->isAnonymousStructOrUnion() &&
1159 Field->getType()->getAsCXXRecordDecl()->hasInClassInitializer())) {
1160 data().HasInClassInitializer =
true;
1165 data().HasTrivialSpecialMembers &= ~SMF_DefaultConstructor;
1173 data().Aggregate =
false;
1177 data().PlainOldData =
false;
1185 data().DefaultedCopyAssignmentIsDeleted =
true;
1186 data().DefaultedMoveAssignmentIsDeleted =
true;
1191 bool IsZeroSize =
Field->isZeroSize(Context);
1194 auto *FieldRec = cast<CXXRecordDecl>(RecordTy->getDecl());
1195 if (FieldRec->getDefinition()) {
1196 addedClassSubobject(FieldRec);
1204 data().NeedOverloadResolutionForCopyConstructor =
true;
1205 data().NeedOverloadResolutionForMoveConstructor =
true;
1206 data().NeedOverloadResolutionForCopyAssignment =
true;
1207 data().NeedOverloadResolutionForMoveAssignment =
true;
1216 if (FieldRec->hasNonTrivialCopyConstructor())
1217 data().DefaultedCopyConstructorIsDeleted =
true;
1218 if (FieldRec->hasNonTrivialMoveConstructor())
1219 data().DefaultedMoveConstructorIsDeleted =
true;
1220 if (FieldRec->hasNonTrivialCopyAssignment())
1221 data().DefaultedCopyAssignmentIsDeleted =
true;
1222 if (FieldRec->hasNonTrivialMoveAssignment())
1223 data().DefaultedMoveAssignmentIsDeleted =
true;
1224 if (FieldRec->hasNonTrivialDestructor()) {
1225 data().DefaultedDestructorIsDeleted =
true;
1229 data().DefaultedDestructorIsConstexpr =
true;
1235 if (
Field->isAnonymousStructOrUnion()) {
1236 data().NeedOverloadResolutionForCopyConstructor |=
1237 FieldRec->data().NeedOverloadResolutionForCopyConstructor;
1238 data().NeedOverloadResolutionForMoveConstructor |=
1239 FieldRec->data().NeedOverloadResolutionForMoveConstructor;
1240 data().NeedOverloadResolutionForCopyAssignment |=
1241 FieldRec->data().NeedOverloadResolutionForCopyAssignment;
1242 data().NeedOverloadResolutionForMoveAssignment |=
1243 FieldRec->data().NeedOverloadResolutionForMoveAssignment;
1244 data().NeedOverloadResolutionForDestructor |=
1245 FieldRec->data().NeedOverloadResolutionForDestructor;
1253 if (!FieldRec->hasTrivialDefaultConstructor())
1254 data().HasTrivialSpecialMembers &= ~SMF_DefaultConstructor;
1262 if (!FieldRec->hasTrivialCopyConstructor())
1263 data().HasTrivialSpecialMembers &= ~SMF_CopyConstructor;
1265 if (!FieldRec->hasTrivialCopyConstructorForCall())
1266 data().HasTrivialSpecialMembersForCall &= ~SMF_CopyConstructor;
1271 if (!FieldRec->hasTrivialMoveConstructor())
1272 data().HasTrivialSpecialMembers &= ~SMF_MoveConstructor;
1274 if (!FieldRec->hasTrivialMoveConstructorForCall())
1275 data().HasTrivialSpecialMembersForCall &= ~SMF_MoveConstructor;
1283 if (!FieldRec->hasTrivialCopyAssignment())
1284 data().HasTrivialSpecialMembers &= ~SMF_CopyAssignment;
1288 if (!FieldRec->hasTrivialMoveAssignment())
1289 data().HasTrivialSpecialMembers &= ~SMF_MoveAssignment;
1291 if (!FieldRec->hasTrivialDestructor())
1292 data().HasTrivialSpecialMembers &= ~SMF_Destructor;
1293 if (!FieldRec->hasTrivialDestructorForCall())
1294 data().HasTrivialSpecialMembersForCall &= ~SMF_Destructor;
1295 if (!FieldRec->hasIrrelevantDestructor())
1296 data().HasIrrelevantDestructor =
false;
1297 if (FieldRec->isAnyDestructorNoReturn())
1298 data().IsAnyDestructorNoReturn =
true;
1299 if (FieldRec->hasObjectMember())
1301 if (FieldRec->hasVolatileMember())
1303 if (FieldRec->getArgPassingRestrictions() ==
1311 if (!FieldRec->isStandardLayout())
1312 data().IsStandardLayout =
false;
1313 if (!FieldRec->isCXX11StandardLayout())
1314 data().IsCXX11StandardLayout =
false;
1320 if (data().IsStandardLayout &&
1321 (
isUnion() || IsFirstField || IsZeroSize) &&
1322 hasSubobjectAtOffsetZeroOfEmptyBaseType(Context, FieldRec))
1323 data().IsStandardLayout =
false;
1329 if (data().IsCXX11StandardLayout && IsFirstField) {
1332 for (
const auto &BI :
bases()) {
1334 data().IsCXX11StandardLayout =
false;
1341 if (FieldRec->hasMutableFields())
1342 data().HasMutableFields =
true;
1344 if (
Field->isMutable()) {
1348 data().NeedOverloadResolutionForCopyConstructor =
true;
1349 data().NeedOverloadResolutionForCopyAssignment =
true;
1359 if (!
Field->hasInClassInitializer() &&
1360 !FieldRec->hasConstexprDefaultConstructor() && !
isUnion())
1363 data().DefaultedDefaultConstructorIsConstexpr =
1371 if (!FieldRec->hasCopyConstructorWithConstParam())
1372 data().ImplicitCopyConstructorCanHaveConstParamForNonVBase =
false;
1380 if (!FieldRec->hasCopyAssignmentWithConstParam())
1381 data().ImplicitCopyAssignmentHasConstParam =
false;
1383 if (FieldRec->hasUninitializedExplicitInitFields() &&
1384 FieldRec->isAggregate())
1387 if (FieldRec->hasUninitializedReferenceMember() &&
1388 !
Field->hasInClassInitializer())
1389 data().HasUninitializedReferenceMember =
true;
1394 if (FieldRec->hasVariantMembers() &&
1395 Field->isAnonymousStructOrUnion())
1396 data().HasVariantMembers =
true;
1403 data().DefaultedDefaultConstructorIsConstexpr =
false;
1410 if (
T.isConstQualified()) {
1411 data().DefaultedCopyAssignmentIsDeleted =
true;
1412 data().DefaultedMoveAssignmentIsDeleted =
true;
1421 data().StructuralIfLiteral =
false;
1427 if (data().
Empty && !IsZeroSize)
1428 data().Empty =
false;
1431 const Type *Ty =
Field->getType()->getUnqualifiedDesugaredType();
1432 while (isa<ConstantArrayType>(Ty))
1436 if (
const RecordType *RT = dyn_cast<RecordType>(Ty))
1437 data().IsHLSLIntangible |= RT->getAsCXXRecordDecl()->isHLSLIntangible();
1445 if (
auto *Shadow = dyn_cast<UsingShadowDecl>(
D)) {
1446 if (Shadow->getDeclName().getNameKind()
1449 data().Conversions.get(Ctx).addDecl(Ctx, Shadow, Shadow->getAccess());
1453 if (
const auto *Using = dyn_cast<UsingDecl>(
D)) {
1454 if (
Using->getDeclName().getNameKind() ==
1456 data().HasInheritedConstructor =
true;
1459 data().Aggregate =
false;
1462 if (
Using->getDeclName().getCXXOverloadedOperator() == OO_Equal)
1463 data().HasInheritedAssignment =
true;
1479 bool HasAtLeastOneLiteralMember =
1481 return !
D->getType().isVolatileQualified() &&
1484 if (!HasAtLeastOneLiteralMember)
1503 if (
const auto *DD = dyn_cast<CXXDestructorDecl>(MD)) {
1504 if (DD->isUserProvided())
1505 data().HasIrrelevantDestructor =
false;
1512 if (DD->isVirtual()) {
1513 data().HasTrivialSpecialMembers &= ~SMF_Destructor;
1514 data().HasTrivialSpecialMembersForCall &= ~SMF_Destructor;
1517 if (DD->isNoReturn())
1518 data().IsAnyDestructorNoReturn =
true;
1527 data().HasTrivialSpecialMembers |= SMKind;
1528 data().HasTrivialSpecialMembersForCall |= SMKind;
1530 data().HasTrivialSpecialMembersForCall |= SMKind;
1531 data().DeclaredNonTrivialSpecialMembers |= SMKind;
1533 data().DeclaredNonTrivialSpecialMembers |= SMKind;
1540 data().DeclaredNonTrivialSpecialMembersForCall |= SMKind;
1548 unsigned SMKind = 0;
1550 if (
const auto *Constructor = dyn_cast<CXXConstructorDecl>(
D)) {
1551 if (Constructor->isDefaultConstructor()) {
1552 SMKind |= SMF_DefaultConstructor;
1553 if (Constructor->isConstexpr())
1554 data().HasConstexprDefaultConstructor =
true;
1556 if (Constructor->isCopyConstructor())
1557 SMKind |= SMF_CopyConstructor;
1558 else if (Constructor->isMoveConstructor())
1559 SMKind |= SMF_MoveConstructor;
1560 else if (Constructor->isConstexpr())
1562 data().HasConstexprNonCopyMoveConstructor =
true;
1563 }
else if (isa<CXXDestructorDecl>(
D)) {
1564 SMKind |= SMF_Destructor;
1566 data().HasIrrelevantDestructor =
false;
1567 }
else if (
D->isCopyAssignmentOperator())
1568 SMKind |= SMF_CopyAssignment;
1569 else if (
D->isMoveAssignmentOperator())
1570 SMKind |= SMF_MoveAssignment;
1574 if (!
D->isIneligibleOrNotSelected()) {
1576 data().HasTrivialSpecialMembers |= SMKind;
1578 data().DeclaredNonTrivialSpecialMembers |= SMKind;
1582void CXXRecordDecl::LambdaDefinitionData::AddCaptureList(
ASTContext &Ctx,
1584 Captures.push_back(CaptureList);
1585 if (Captures.size() == 2) {
1593 CXXRecordDecl::LambdaDefinitionData &
Data = getLambdaData();
1596 Data.NumCaptures = Captures.size();
1597 Data.NumExplicitCaptures = 0;
1600 Data.AddCaptureList(Context, ToCapture);
1603 ++
Data.NumExplicitCaptures;
1610 Data.DefaultedCopyAssignmentIsDeleted =
true;
1614 unsigned SMKind = 0;
1616 if (
const auto *Constructor = dyn_cast<CXXConstructorDecl>(
D)) {
1617 if (Constructor->isCopyConstructor())
1618 SMKind = SMF_CopyConstructor;
1619 else if (Constructor->isMoveConstructor())
1620 SMKind = SMF_MoveConstructor;
1621 }
else if (isa<CXXDestructorDecl>(
D))
1622 SMKind = SMF_Destructor;
1624 if (
D->isTrivialForCall())
1625 data().HasTrivialSpecialMembersForCall |= SMKind;
1627 data().DeclaredNonTrivialSpecialMembersForCall |= SMKind;
1633 !TemplateOrInstantiation.isNull())
1638 return isPOD() && data().HasOnlyCMembers;
1643 return getLambdaData().IsGenericLambda;
1655 if (!RD.
isLambda())
return nullptr;
1660 assert(!Calls.
empty() &&
"Missing lambda call operator!");
1662 "More than one lambda call operator!");
1687 auto *MD = cast<NamedDecl>(
D);
1688 if (MD->getOwningModule() == M)
1692 llvm_unreachable(
"Couldn't find our call operator!");
1697 return dyn_cast_or_null<FunctionTemplateDecl>(CallOp);
1703 if (CallOp ==
nullptr)
1706 if (
const auto *CallOpTmpl = dyn_cast<FunctionTemplateDecl>(CallOp))
1707 return cast<CXXMethodDecl>(CallOpTmpl->getTemplatedDecl());
1709 return cast<CXXMethodDecl>(CallOp);
1720 assert(RD.
isLambda() &&
"Must be a lambda");
1727 if (
const auto *InvokerTemplate = dyn_cast<FunctionTemplateDecl>(ND))
1728 return cast<CXXMethodDecl>(InvokerTemplate->getTemplatedDecl());
1729 return cast<CXXMethodDecl>(ND);
1739 cast<ValueDecl>(ND->getAsFunction())->getType()->castAs<
FunctionType>();
1740 if (FTy->getCallConv() == CC)
1748 llvm::DenseMap<const ValueDecl *, FieldDecl *> &Captures,
1751 ThisCapture =
nullptr;
1753 LambdaDefinitionData &Lambda = getLambdaData();
1757 C != CEnd; ++
C, ++Field) {
1758 if (
C->capturesThis())
1759 ThisCapture = *Field;
1760 else if (
C->capturesVariable())
1761 Captures[
C->getCapturedVar()] = *Field;
1772 return Tmpl->getTemplateParameters();
1782 assert(std::is_partitioned(List->begin(), List->end(),
1783 [](
const NamedDecl *
D) { return !D->isImplicit(); })
1784 &&
"Explicit template params should be ordered before implicit ones");
1786 const auto ExplicitEnd = llvm::partition_point(
1792 assert(
isLambda() &&
"Not a lambda closure type!");
1794 return getLambdaData().ContextDecl.get(Source);
1798 assert(
isLambda() &&
"Not a lambda closure type!");
1804 getLambdaData().ContextDecl = Numbering.
ContextDecl;
1809 assert(
isLambda() &&
"Not a lambda closure type!");
1810 return getASTContext().DeviceLambdaManglingNumbers.lookup(
this);
1816 ->getConversionType();
1848 if (ConvI != ConvE) {
1849 HiddenTypesBuffer = ParentHiddenTypes;
1850 HiddenTypes = &HiddenTypesBuffer;
1854 bool Hidden = ParentHiddenTypes.count(ConvType);
1856 HiddenTypesBuffer.insert(ConvType);
1860 if (Hidden && InVirtual)
1861 HiddenVBaseCs.insert(cast<NamedDecl>(I.getDecl()->getCanonicalDecl()));
1869 VOutput.
addDecl(I.getDecl(), IAccess);
1871 Output.
addDecl(Context, I.getDecl(), IAccess);
1877 for (
const auto &I :
Record->bases()) {
1878 const auto *RT = I.getType()->getAs<
RecordType>();
1883 bool BaseInVirtual = InVirtual || I.isVirtual();
1885 auto *
Base = cast<CXXRecordDecl>(RT->getDecl());
1887 *HiddenTypes, Output, VOutput, HiddenVBaseCs);
1914 Output.
append(Context, ConvI, ConvE);
1915 for (; ConvI != ConvE; ++ConvI)
1919 for (
const auto &I :
Record->bases()) {
1920 const auto *RT = I.getType()->getAs<
RecordType>();
1924 I.isVirtual(), I.getAccessSpecifier(),
1925 HiddenTypes, Output, VBaseCs, HiddenVBaseCs);
1931 if (!HiddenVBaseCs.count(cast<NamedDecl>(I.getDecl()->getCanonicalDecl())))
1932 Output.
addDecl(Context, I.getDecl(), I.getAccess());
1938llvm::iterator_range<CXXRecordDecl::conversion_iterator>
1945 Set = &data().Conversions.get(Ctx);
1947 Set = &data().VisibleConversions.get(Ctx);
1949 if (!data().ComputedVisibleConversions) {
1951 data().ComputedVisibleConversions =
true;
1954 return llvm::make_range(
Set->begin(),
Set->end());
1970 for (
unsigned I = 0,
E = Convs.
size(); I !=
E; ++I) {
1971 if (Convs[I].getDecl() == ConvDecl) {
1973 assert(!llvm::is_contained(Convs, ConvDecl) &&
1974 "conversion was found multiple times in unresolved set");
1979 llvm_unreachable(
"conversion not found in set!");
1984 return cast<CXXRecordDecl>(MSInfo->getInstantiatedFrom());
1996 assert(TemplateOrInstantiation.isNull() &&
1997 "Previous template or instantiation?");
1998 assert(!isa<ClassTemplatePartialSpecializationDecl>(
this));
1999 TemplateOrInstantiation
2008 TemplateOrInstantiation = Template;
2012 if (
const auto *Spec = dyn_cast<ClassTemplateSpecializationDecl>(
this))
2013 return Spec->getSpecializationKind();
2016 return MSInfo->getTemplateSpecializationKind();
2023 if (
auto *Spec = dyn_cast<ClassTemplateSpecializationDecl>(
this)) {
2024 Spec->setSpecializationKind(TSK);
2029 MSInfo->setTemplateSpecializationKind(TSK);
2033 llvm_unreachable(
"Not a class template or member class specialization");
2037 auto GetDefinitionOrSelf =
2039 if (
auto *Def =
D->getDefinition())
2046 if (
auto *TD = dyn_cast<ClassTemplateSpecializationDecl>(
this)) {
2047 auto From = TD->getInstantiatedFrom();
2049 while (
auto *NewCTD = CTD->getInstantiatedFromMemberTemplate()) {
2050 if (NewCTD->isMemberSpecialization())
2054 return GetDefinitionOrSelf(CTD->getTemplatedDecl());
2058 while (
auto *NewCTPSD = CTPSD->getInstantiatedFromMember()) {
2059 if (NewCTPSD->isMemberSpecialization())
2063 return GetDefinitionOrSelf(CTPSD);
2072 return GetDefinitionOrSelf(RD);
2077 "couldn't find pattern for class template instantiation");
2093 for (
auto *
Decl : R) {
2094 auto* DD = dyn_cast<CXXDestructorDecl>(
Decl);
2095 if (DD && !DD->isIneligibleOrNotSelected())
2111 assert(
hasDefinition() &&
"checking for interface-like without a definition");
2125 for (
const auto *
const Method :
methods())
2126 if (Method->isDefined() && !Method->isImplicit())
2130 const auto *Uuid = getAttr<UuidAttr>();
2137 Uuid->getGuid() ==
"00000000-0000-0000-C000-000000000046") ||
2139 Uuid->getGuid() ==
"00020400-0000-0000-C000-000000000046"))) {
2153 if (BaseSpec.isVirtual() || BaseSpec.getAccessSpecifier() !=
AS_public)
2155 const auto *
Base = BaseSpec.getType()->getAsCXXRecordDecl();
2156 if (
Base->isInterface() || !
Base->isInterfaceLike())
2167 if (!FinalOverriders) {
2173 for (
const CXXFinalOverriderMap::value_type &
2174 OverridingMethodsEntry : *FinalOverriders) {
2175 for (
const auto &[_, SubobjOverrides] : OverridingMethodsEntry.second) {
2176 assert(SubobjOverrides.size() > 0 &&
2177 "All virtual functions have overriding virtual functions");
2179 if (SubobjOverrides.front().Method->isPureVirtual())
2202 I.setAccess((*I)->getAccess());
2210 if (
const auto *AT = FD->getAttr<ExplicitInitAttr>())
2213 diag::warn_cxx20_compat_requires_explicit_init_non_aggregate)
2223 if (
const auto *AT = FD->getAttr<ExplicitInitAttr>())
2225 diag::warn_attribute_needs_aggregate)
2233 if (data().Abstract ||
isInvalidDecl() || !data().Polymorphic ||
2237 for (
const auto &B :
bases()) {
2238 const auto *BaseDecl =
2240 if (BaseDecl->isAbstract())
2251 if (Def->hasAttr<FinalAttr>())
2253 if (
const auto *Dtor = Def->getDestructor())
2254 if (Dtor->hasAttr<FinalAttr>())
2259void CXXDeductionGuideDecl::anchor() {}
2278 case Decl::Kind::CXXConstructor:
2279 return cast<CXXConstructorDecl>(
Function)->getExplicitSpecifier();
2280 case Decl::Kind::CXXConversion:
2281 return cast<CXXConversionDecl>(
Function)->getExplicitSpecifier();
2282 case Decl::Kind::CXXDeductionGuide:
2283 return cast<CXXDeductionGuideDecl>(
Function)->getExplicitSpecifier();
2296 EndLocation, Ctor,
Kind, TrailingRequiresClause);
2317void CXXMethodDecl::anchor() {}
2347 if (isa<CXXDestructorDecl>(
this)) {
2359 auto *MD = dyn_cast<CXXMethodDecl>(ND);
2387 llvm::erase_if(FinalOverriders, [&](
CXXMethodDecl *OtherD) {
2391 FinalOverriders.push_back(
D);
2394 for (
const auto &I : RD->
bases()) {
2398 const auto *
Base = cast<CXXRecordDecl>(RT->
getDecl());
2400 AddFinalOverrider(
D);
2403 return FinalOverriders.size() == 1 ? FinalOverriders.front() :
nullptr;
2412 Expr *TrailingRequiresClause) {
2414 CXXMethod,
C, RD, StartLoc, NameInfo,
T, TInfo, SC,
UsesFPIntrin,
2415 isInline, ConstexprKind, EndLocation, TrailingRequiresClause);
2428 assert(
isVirtual() &&
"this method is expected to be virtual");
2437 if (hasAttr<FinalAttr>())
2446 Base =
Base->getBestDynamicClassTypeExpr();
2447 if (
Base->isPRValue() &&
Base->getType()->isRecordType())
2452 if (!BestDynamicDecl)
2461 if (!DevirtualizedMethod)
2471 if (DevirtualizedMethod->
hasAttr<FinalAttr>())
2472 return DevirtualizedMethod;
2478 return DevirtualizedMethod;
2480 if (
const auto *DRE = dyn_cast<DeclRefExpr>(
Base)) {
2481 if (
const auto *VD = dyn_cast<VarDecl>(DRE->getDecl()))
2482 if (VD->getType()->isRecordType())
2484 return DevirtualizedMethod;
2492 if (
const auto *ME = dyn_cast<MemberExpr>(
Base)) {
2493 const ValueDecl *VD = ME->getMemberDecl();
2499 if (
auto *BO = dyn_cast<BinaryOperator>(
Base)) {
2500 if (BO->isPtrMemOp()) {
2502 if (MPT->getPointeeType()->isRecordType())
2503 return DevirtualizedMethod;
2513 assert(PreventedBy.empty() &&
"PreventedBy is expected to be empty");
2530 unsigned UsualParams = 1;
2577 for (
const auto *
D : R) {
2578 if (
const auto *FD = dyn_cast<FunctionDecl>(
D)) {
2579 if (FD->getNumParams() == 1) {
2580 PreventedBy.push_back(FD);
2644 assert(MD->
isVirtual() &&
"Method is not virtual!");
2650 if (isa<CXXConstructorDecl>(
this))
return nullptr;
2655 if (isa<CXXConstructorDecl>(
this))
return nullptr;
2660 if (isa<CXXConstructorDecl>(
this))
return 0;
2666 if (isa<CXXConstructorDecl>(
this))
2688 ObjectTy =
C.getLangOpts().HLSL ?
C.getLValueReferenceType(ObjectTy)
2689 :
C.getPointerType(ObjectTy);
2702 assert(
isInstance() &&
"No 'this' for static methods!");
2716 return C.getRValueReferenceType(
Type);
2717 return C.getLValueReferenceType(
Type);
2743 : Initializee(TInfo),
Init(
Init), MemberOrEllipsisLocation(EllipsisLoc),
2744 LParenLoc(L), RParenLoc(R), IsDelegating(
false), IsVirtual(IsVirtual),
2745 IsWritten(
false), SourceOrder(0) {}
2751 : Initializee(
Member),
Init(
Init), MemberOrEllipsisLocation(MemberLoc),
2752 LParenLoc(L), RParenLoc(R), IsDelegating(
false), IsVirtual(
false),
2753 IsWritten(
false), SourceOrder(0) {}
2760 : Initializee(
Member),
Init(
Init), MemberOrEllipsisLocation(MemberLoc),
2761 LParenLoc(L), RParenLoc(R), IsDelegating(
false), IsVirtual(
false),
2762 IsWritten(
false), SourceOrder(0) {}
2768 : Initializee(TInfo),
Init(
Init), LParenLoc(L), RParenLoc(R),
2769 IsDelegating(
true), IsVirtual(
false), IsWritten(
false), SourceOrder(0) {}
2778 return cast<TypeSourceInfo *>(Initializee)->getTypeLoc();
2785 return cast<TypeSourceInfo *>(Initializee)->getType().getTypePtr();
2797 if (
const auto *TSInfo = cast<TypeSourceInfo *>(Initializee))
2798 return TSInfo->getTypeLoc().getBeginLoc();
2806 if (
Expr *I =
D->getInClassInitializer())
2807 return I->getSourceRange();
2814CXXConstructorDecl::CXXConstructorDecl(
2821 SC_None, UsesFPIntrin, isInline, ConstexprKind,
2823 setNumCtorInitializers(0);
2824 setInheritingConstructor(
static_cast<bool>(Inherited));
2825 setImplicit(isImplicitlyDeclared);
2826 CXXConstructorDeclBits.HasTrailingExplicitSpecifier = ES.
getExpr() ? 1 : 0;
2828 *getTrailingObjects<InheritedConstructor>() = Inherited;
2829 setExplicitSpecifier(ES);
2832void CXXConstructorDecl::anchor() {}
2836 uint64_t AllocKind) {
2837 bool hasTrailingExplicit =
static_cast<bool>(AllocKind & TAKHasTailExplicit);
2839 static_cast<bool>(AllocKind & TAKInheritsConstructor);
2841 additionalSizeToAlloc<InheritedConstructor, ExplicitSpecifier>(
2848 Result->CXXConstructorDeclBits.HasTrailingExplicitSpecifier =
2849 hasTrailingExplicit;
2862 "Name must refer to a constructor");
2864 additionalSizeToAlloc<InheritedConstructor, ExplicitSpecifier>(
2865 Inherited ? 1 : 0, ES.
getExpr() ? 1 : 0);
2868 isImplicitlyDeclared, ConstexprKind, Inherited, TrailingRequiresClause);
2878 if (
const auto *Construct = dyn_cast<CXXConstructExpr>(
E))
2879 return Construct->getConstructor();
2979void CXXDestructorDecl::anchor() {}
2991 bool UsesFPIntrin,
bool isInline,
bool isImplicitlyDeclared,
2995 "Name must refer to a destructor");
2998 isImplicitlyDeclared, ConstexprKind, TrailingRequiresClause);
3003 if (OD && !
First->OperatorDelete) {
3004 First->OperatorDelete = OD;
3005 First->OperatorDeleteThisArg = ThisArg;
3007 L->ResolvedOperatorDelete(
First, OD, ThisArg);
3022 const FunctionDecl *SelectedOperatorDelete = OpDel ? OpDel : OperatorDelete;
3023 if (!SelectedOperatorDelete)
3033void CXXConversionDecl::anchor() {}
3048 Expr *TrailingRequiresClause) {
3051 "Name must refer to a conversion function");
3054 ConstexprKind, EndLocation, TrailingRequiresClause);
3071void LinkageSpecDecl::anchor() {}
3078 return new (
C, DC)
LinkageSpecDecl(DC, ExternLoc, LangLoc, Lang, HasBraces);
3088void UsingDirectiveDecl::anchor() {}
3097 if (
auto *NS = dyn_cast_or_null<NamespaceDecl>(
Used))
3098 Used = NS->getFirstDecl();
3100 IdentLoc,
Used, CommonAncestor);
3112 if (
auto *NA = dyn_cast_or_null<NamespaceAliasDecl>(NominatedNamespace))
3113 return NA->getNamespace();
3114 return cast_or_null<NamespaceDecl>(NominatedNamespace);
3122 redeclarable_base(
C), LocStart(StartLoc) {
3125 setPreviousDecl(PrevDecl);
3154void NamespaceAliasDecl::anchor() {}
3176 if (
auto *NS = dyn_cast_or_null<NamespaceDecl>(Namespace))
3177 Namespace = NS->getFirstDecl();
3179 QualifierLoc, IdentLoc, Namespace);
3190void LifetimeExtendedTemporaryDecl::anchor() {}
3199 if (isa<FieldDecl>(ExtendingDecl))
3203 if (isa<BindingDecl>(ExtendingDecl))
3206 return cast<VarDecl>(ExtendingDecl)->getStorageDuration();
3211 "don't need to cache the computed value for this temporary");
3212 if (MayCreate && !
Value) {
3216 assert(
Value &&
"may not be null");
3220void UsingShadowDecl::anchor() {}
3226 UsingOrNextShadow(Introducer) {
3228 assert(!isa<UsingShadowDecl>(
Target));
3245 while (
const auto *NextShadow =
3246 dyn_cast<UsingShadowDecl>(Shadow->UsingOrNextShadow))
3247 Shadow = NextShadow;
3248 return cast<BaseUsingDecl>(Shadow->UsingOrNextShadow);
3251void ConstructorUsingShadowDecl::anchor() {}
3270void BaseUsingDecl::anchor() {}
3273 assert(!llvm::is_contained(
shadows(), S) &&
"declaration already in set");
3274 assert(S->getIntroducer() ==
this);
3276 if (FirstUsingShadow.getPointer())
3277 S->UsingOrNextShadow = FirstUsingShadow.getPointer();
3278 FirstUsingShadow.setPointer(S);
3282 assert(llvm::is_contained(
shadows(), S) &&
"declaration not in set");
3283 assert(S->getIntroducer() ==
this);
3287 if (FirstUsingShadow.getPointer() == S) {
3288 FirstUsingShadow.setPointer(
3289 dyn_cast<UsingShadowDecl>(S->UsingOrNextShadow));
3290 S->UsingOrNextShadow =
this;
3295 while (Prev->UsingOrNextShadow != S)
3296 Prev = cast<UsingShadowDecl>(Prev->UsingOrNextShadow);
3297 Prev->UsingOrNextShadow = S->UsingOrNextShadow;
3298 S->UsingOrNextShadow =
this;
3301void UsingDecl::anchor() {}
3307 return new (
C, DC)
UsingDecl(DC, UL, QualifierLoc, NameInfo, HasTypename);
3322void UsingEnumDecl::anchor() {}
3345void UsingPackDecl::anchor() {}
3350 size_t Extra = additionalSizeToAlloc<NamedDecl *>(UsingDecls.size());
3351 return new (
C, DC, Extra)
UsingPackDecl(DC, InstantiatedFrom, UsingDecls);
3355 unsigned NumExpansions) {
3356 size_t Extra = additionalSizeToAlloc<NamedDecl *>(NumExpansions);
3358 Result->NumExpansions = NumExpansions;
3360 for (
unsigned I = 0; I != NumExpansions; ++I)
3365void UnresolvedUsingValueDecl::anchor() {}
3374 QualifierLoc, NameInfo,
3393void UnresolvedUsingTypenameDecl::anchor() {}
3404 DC, UsingLoc, TypenameLoc, QualifierLoc, TargetNameLoc,
3425 return new (Ctx,
ID)
3429UnresolvedUsingIfExistsDecl::UnresolvedUsingIfExistsDecl(
DeclContext *DC,
3434void UnresolvedUsingIfExistsDecl::anchor() {}
3436void StaticAssertDecl::anchor() {}
3454 assert((isa<VarDecl, BindingDecl>(
this)) &&
3455 "expected a VarDecl or a BindingDecl");
3456 if (
auto *Var = llvm::dyn_cast<VarDecl>(
this))
3458 if (
auto *BD = llvm::dyn_cast<BindingDecl>(
this))
3459 return llvm::dyn_cast<VarDecl>(BD->getDecomposedDecl());
3463void BindingDecl::anchor() {}
3482 auto *VD = cast<VarDecl>(DRE->getDecl());
3483 assert(VD->isImplicit() &&
"holding var for binding decl not implicit");
3487void DecompositionDecl::anchor() {}
3495 size_t Extra = additionalSizeToAlloc<BindingDecl *>(
Bindings.size());
3496 return new (
C, DC, Extra)
3502 unsigned NumBindings) {
3503 size_t Extra = additionalSizeToAlloc<BindingDecl *>(NumBindings);
3508 Result->NumBindings = NumBindings;
3510 for (
unsigned I = 0; I != NumBindings; ++I)
3522 B->printName(OS, Policy);
3528void MSPropertyDecl::anchor() {}
3536 return new (
C, DC)
MSPropertyDecl(DC, L, N,
T, TInfo, StartL, Getter, Setter);
3546void MSGuidDecl::anchor() {}
3563 OS << llvm::format(
"GUID{%08" PRIx32
"-%04" PRIx16
"-%04" PRIx16
"-",
3566 for (uint8_t Byte : PartVal.
Part4And5) {
3567 OS << llvm::format(
"%02" PRIx8, Byte);
3580 auto IsInt = [&Ctx](
unsigned N) {
3587 auto IsArray = [&Ctx](MatcherRef Elem,
unsigned N) {
3594 auto IsStruct = [](std::initializer_list<MatcherRef> Fields) {
3602 if (
auto *CXXRD = dyn_cast<CXXRecordDecl>(RD))
3603 if (CXXRD->getNumBases())
3605 auto MatcherIt = Fields.begin();
3607 if (FD->isUnnamedBitField())
3609 if (FD->isBitField() || MatcherIt == Fields.end() ||
3610 !(*MatcherIt)(FD->getType()))
3614 return MatcherIt == Fields.end();
3619 return IsStruct({IsInt(32), IsInt(16), IsInt(16), IsArray(IsInt(8), 8)})(
T);
3632 for (
unsigned I = 0; I != 8; ++I) {
3644void UnnamedGlobalConstantDecl::anchor() {}
3646UnnamedGlobalConstantDecl::UnnamedGlobalConstantDecl(
const ASTContext &
C,
3655 if (
Value.needsCleanup())
3656 C.addDestruction(&
Value);
3674 OS <<
"unnamed-global-constant";
3680 llvm_unreachable(
"Invalid access specifier!");
3688 llvm_unreachable(
"Invalid access specifier!");
Defines the clang::ASTContext interface.
ASTImporterLookupTable & LT
This file provides some common utility functions for processing Lambda related AST Constructs.
Defines the Diagnostic-related interfaces.
enum clang::sema::@1724::IndirectLocalPathEntry::EntryKind Kind
static void CollectVisibleConversions(ASTContext &Context, const CXXRecordDecl *Record, bool InVirtual, AccessSpecifier Access, const llvm::SmallPtrSet< CanQualType, 8 > &ParentHiddenTypes, ASTUnresolvedSet &Output, UnresolvedSetImpl &VOutput, llvm::SmallPtrSet< NamedDecl *, 8 > &HiddenVBaseCs)
Collect the visible conversions of a base class.
static const char * getAccessName(AccessSpecifier AS)
static bool recursivelyOverrides(const CXXMethodDecl *DerivedMD, const CXXMethodDecl *BaseMD)
static bool isValidStructGUID(ASTContext &Ctx, QualType T)
Determine if T is a valid 'struct _GUID' of the shape that we expect.
static DeclContext::lookup_result getLambdaStaticInvokers(const CXXRecordDecl &RD)
static NamedDecl * getLambdaCallOperatorHelper(const CXXRecordDecl &RD)
static QualType getThisObjectType(ASTContext &C, const FunctionProtoType *FPT, const CXXRecordDecl *Decl)
static bool hasPureVirtualFinalOverrider(const CXXRecordDecl &RD, const CXXFinalOverriderMap *FinalOverriders)
static bool allLookupResultsAreTheSame(const DeclContext::lookup_result &R)
static bool isDeclContextInNamespace(const DeclContext *DC)
static bool hasRepeatedBaseClass(const CXXRecordDecl *StartRD)
Determine whether a class has a repeated base class.
static CanQualType GetConversionType(ASTContext &Context, NamedDecl *Conv)
static CXXMethodDecl * getInvokerAsMethod(NamedDecl *ND)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
Defines the C++ template declaration subclasses.
Defines the clang::Expr interface and subclasses for C++ expressions.
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
Defines the LambdaCapture class.
Defines the clang::LangOptions interface.
llvm::MachO::Target Target
llvm::MachO::Record Record
This file contains the declaration of the ODRHash class, which calculates a hash based on AST nodes,...
Defines an enumeration for C++ overloaded operators.
Defines the clang::SourceLocation class and associated facilities.
Defines various enumerations that describe declaration and type specifiers.
Defines the clang::TypeLoc interface and its subclasses.
C Language Family Type Representation.
APValue - This class implements a discriminated union of [uninitialized] [APSInt] [APFloat],...
APValue & getArrayInitializedElt(unsigned I)
APValue & getStructField(unsigned i)
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
const ConstantArrayType * getAsConstantArrayType(QualType T) const
unsigned getIntWidth(QualType T) const
QualType getTagDeclType(const TagDecl *Decl) const
Return the unique reference to the type for the specified TagDecl (struct/union/class/enum) decl.
DeclarationNameTable DeclarationNames
QualType getRecordType(const RecordDecl *Decl) const
CanQualType getCanonicalType(QualType T) const
Return the canonical (structural) type corresponding to the specified potentially non-canonical type ...
overridden_method_range overridden_methods(const CXXMethodDecl *Method) const
QualType getTypeDeclType(const TypeDecl *Decl, const TypeDecl *PrevDecl=nullptr) const
Return the unique reference to the type for the specified type declaration.
const LangOptions & getLangOpts() const
QualType getBaseElementType(const ArrayType *VAT) const
Return the innermost element type of an array type.
overridden_cxx_method_iterator overridden_methods_end(const CXXMethodDecl *Method) const
llvm::BumpPtrAllocator & getAllocator() const
void addOverriddenMethod(const CXXMethodDecl *Method, const CXXMethodDecl *Overridden)
Note that the given C++ Method overrides the given Overridden method.
CanQualType getSizeType() const
Return the unique type for "size_t" (C99 7.17), defined in <stddef.h>.
bool hasSameUnqualifiedType(QualType T1, QualType T2) const
Determine whether the given types are equivalent after cvr-qualifiers have been removed.
void * Allocate(size_t Size, unsigned Align=8) const
unsigned overridden_methods_size(const CXXMethodDecl *Method) const
overridden_cxx_method_iterator overridden_methods_begin(const CXXMethodDecl *Method) const
DiagnosticsEngine & getDiagnostics() const
const TargetInfo & getTargetInfo() const
void addDestruction(T *Ptr) const
If T isn't trivially destructible, calls AddDeallocation to register it for destruction.
ExternalASTSource * getExternalSource() const
Retrieve a pointer to the external AST source associated with this AST context, if any.
An abstract interface that should be implemented by listeners that want to be notified when an AST en...
An UnresolvedSet-like class which uses the ASTContext's allocator.
void append(ASTContext &C, iterator I, iterator E)
bool replace(const NamedDecl *Old, NamedDecl *New, AccessSpecifier AS)
Replaces the given declaration with the new one, once.
void addDecl(ASTContext &C, NamedDecl *D, AccessSpecifier AS)
Represents an access specifier followed by colon ':'.
static AccessSpecDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
QualType getElementType() const
Represents a C++ declaration that introduces decls from somewhere else.
void addShadowDecl(UsingShadowDecl *S)
shadow_range shadows() const
void removeShadowDecl(UsingShadowDecl *S)
A binding in a decomposition declaration.
VarDecl * getHoldingVar() const
Get the variable (if any) that holds the value of evaluating the binding.
Expr * getBinding() const
Get the expression to which this declaration is bound.
static BindingDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
static BindingDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation IdLoc, IdentifierInfo *Id)
Represents a base class of a C++ class.
Represents a C++ constructor within a class.
bool isExplicit() const
Return true if the declaration is already resolved to be explicit.
init_iterator init_begin()
Retrieve an iterator to the first initializer.
CXXConstructorDecl * getTargetConstructor() const
When this constructor delegates to another, retrieve the target.
static CXXConstructorDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, uint64_t AllocKind)
bool isDefaultConstructor() const
Whether this constructor is a default constructor (C++ [class.ctor]p5), which can be used to default-...
bool isDelegatingConstructor() const
Determine whether this constructor is a delegating constructor.
bool isSpecializationCopyingObject() const
Determine whether this is a member template specialization that would copy the object to itself.
bool isMoveConstructor() const
Determine whether this constructor is a move constructor (C++11 [class.copy]p3), which can be used to...
bool isCopyOrMoveConstructor() const
Determine whether this a copy or move constructor.
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(), Expr *TrailingRequiresClause=nullptr)
bool isInheritingConstructor() const
Determine whether this is an implicit constructor synthesized to model a call to a constructor inheri...
CXXCtorInitializer *const * init_const_iterator
Iterates through the member/base initializer list.
bool isConvertingConstructor(bool AllowExplicit) const
Whether this constructor is a converting constructor (C++ [class.conv.ctor]), which can be used for u...
bool isCopyConstructor() const
Whether this constructor is a copy constructor (C++ [class.copy]p2, which can be used to copy the cla...
Represents a C++ conversion function within a class.
bool isLambdaToBlockPointerConversion() const
Determine whether this conversion function is a conversion from a lambda closure type to a block poin...
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, Expr *TrailingRequiresClause=nullptr)
QualType getConversionType() const
Returns the type that this conversion function is converting to.
static CXXConversionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a C++ base or member initializer.
SourceLocation getRParenLoc() const
SourceRange getSourceRange() const LLVM_READONLY
Determine the source range covering the entire initializer.
SourceLocation getSourceLocation() const
Determine the source location of the initializer.
bool isAnyMemberInitializer() const
bool isBaseInitializer() const
Determine whether this initializer is initializing a base class.
int64_t getID(const ASTContext &Context) const
bool isInClassMemberInitializer() const
Determine whether this initializer is an implicit initializer generated for a field with an initializ...
const Type * getBaseClass() const
If this is a base class initializer, returns the type of the base class.
SourceLocation getMemberLocation() const
FieldDecl * getAnyMember() const
TypeLoc getBaseClassLoc() const
If this is a base class initializer, returns the type of the base class with location information.
CXXCtorInitializer(ASTContext &Context, TypeSourceInfo *TInfo, bool IsVirtual, SourceLocation L, Expr *Init, SourceLocation R, SourceLocation EllipsisLoc)
Creates a new base-class initializer.
Represents a C++ deduction guide declaration.
static CXXDeductionGuideDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
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, Expr *TrailingRequiresClause=nullptr)
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, Expr *TrailingRequiresClause=nullptr)
static CXXDestructorDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setOperatorDelete(FunctionDecl *OD, Expr *ThisArg)
bool isCalledByDelete(const FunctionDecl *OpDel=nullptr) const
Will this destructor ever be called when considering which deallocation function is associated with t...
A mapping from each virtual member function to its set of final overriders.
Represents a static or instance method of a struct/union/class.
bool isExplicitObjectMemberFunction() const
[C++2b][dcl.fct]/p7 An explicit object member function is a non-static member function with an explic...
CXXMethodDecl * getCorrespondingMethodDeclaredInClass(const CXXRecordDecl *RD, bool MayBeBase=false)
Find if RD declares a function that overrides this function, and if so, return it.
bool isImplicitObjectMemberFunction() const
[C++2b][dcl.fct]/p7 An implicit object member function is a non-static member function without an exp...
void addOverriddenMethod(const CXXMethodDecl *MD)
bool hasInlineBody() const
bool isUsualDeallocationFunction(SmallVectorImpl< const FunctionDecl * > &PreventedBy) const
Determine whether this is a usual deallocation function (C++ [basic.stc.dynamic.deallocation]p2),...
unsigned getNumExplicitParams() const
overridden_method_range overridden_methods() const
unsigned size_overridden_methods() const
const CXXMethodDecl *const * method_iterator
QualType getFunctionObjectParameterReferenceType() const
Return the type of the object pointed by this.
method_iterator begin_overridden_methods() const
const CXXRecordDecl * getParent() const
Return the parent of this method declaration, which is the class in which this method is defined.
QualType getThisType() const
Return the type of the this pointer.
bool isMoveAssignmentOperator() const
Determine whether this is a move assignment operator.
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, Expr *TrailingRequiresClause=nullptr)
CXXMethodDecl * getDevirtualizedMethod(const Expr *Base, bool IsAppleKext)
If it's possible to devirtualize a call to this method, return the called function.
static bool isStaticOverloadedOperator(OverloadedOperatorKind OOK)
Returns true if the given operator is implicitly static in a record context.
CXXMethodDecl * getCorrespondingMethodInClass(const CXXRecordDecl *RD, bool MayBeBase=false)
Find the method in RD that corresponds to this one.
llvm::iterator_range< llvm::TinyPtrVector< const CXXMethodDecl * >::const_iterator > overridden_method_range
bool isCopyAssignmentOperator() const
Determine whether this is a copy-assignment operator, regardless of whether it was declared implicitl...
static CXXMethodDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
method_iterator end_overridden_methods() const
CXXMethodDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
bool isLambdaStaticInvoker() const
Determine whether this is a lambda closure type's static member function that is used for the result ...
Represents a C++ struct/union/class.
Decl * getLambdaContextDecl() const
Retrieve the declaration that provides additional context for a lambda, when the normal declaration c...
bool mayBeAbstract() const
Determine whether this class may end up being abstract, even though it is not yet known to be abstrac...
bool isTriviallyCopyable() const
Determine whether this class is considered trivially copyable per (C++11 [class]p6).
bool hasNonTrivialCopyAssignment() const
Determine whether this class has a non-trivial copy assignment operator (C++ [class....
TemplateParameterList * getGenericLambdaTemplateParameterList() const
Retrieve the generic lambda's template parameter list.
bool isEffectivelyFinal() const
Determine whether it's impossible for a class to be derived from this class.
bool hasSimpleMoveConstructor() const
true if we know for sure that this class has a single, accessible, unambiguous move constructor that ...
bool isAggregate() const
Determine whether this class is an aggregate (C++ [dcl.init.aggr]), which is a class with no user-dec...
bool hasTrivialDefaultConstructor() const
Determine whether this class has a trivial default constructor (C++11 [class.ctor]p5).
void setBases(CXXBaseSpecifier const *const *Bases, unsigned NumBases)
Sets the base classes of this struct or class.
bool isGenericLambda() const
Determine whether this class describes a generic lambda function object (i.e.
base_class_iterator bases_end()
bool hasTrivialDestructor() const
Determine whether this class has a trivial destructor (C++ [class.dtor]p3)
bool hasUserDeclaredDestructor() const
Determine whether this class has a user-declared destructor.
CXXRecordDecl * getInstantiatedFromMemberClass() const
If this record is an instantiation of a member class, retrieves the member class from which it was in...
void completeDefinition() override
Indicates that the definition of this class is now complete.
bool isLiteral() const
Determine whether this class is a literal type.
bool defaultedDestructorIsConstexpr() const
Determine whether a defaulted default constructor for this class would be constexpr.
bool isStandardLayout() const
Determine whether this class is standard-layout per C++ [class]p7.
void setCaptures(ASTContext &Context, ArrayRef< LambdaCapture > Captures)
Set the captures for this lambda closure type.
unsigned getDeviceLambdaManglingNumber() const
Retrieve the device side mangling number.
bool hasAnyDependentBases() const
Determine whether this class has any dependent base classes which are not the current instantiation.
void setTrivialForCallFlags(CXXMethodDecl *MD)
bool isLambda() const
Determine whether this class describes a lambda function object.
void addedSelectedDestructor(CXXDestructorDecl *DD)
Notify the class that this destructor is now selected.
bool hasFriends() const
Determines whether this record has any friends.
method_range methods() const
CXXRecordDecl * getDefinition() const
static AccessSpecifier MergeAccess(AccessSpecifier PathAccess, AccessSpecifier DeclAccess)
Calculates the access of a decl that is reached along a path.
void getCaptureFields(llvm::DenseMap< const ValueDecl *, FieldDecl * > &Captures, FieldDecl *&ThisCapture) const
For a closure type, retrieve the mapping from captured variables and this to the non-static data memb...
bool hasConstexprNonCopyMoveConstructor() const
Determine whether this class has at least one constexpr constructor other than the copy or move const...
static CXXRecordDecl * CreateLambda(const ASTContext &C, DeclContext *DC, TypeSourceInfo *Info, SourceLocation Loc, unsigned DependencyKind, bool IsGeneric, LambdaCaptureDefault CaptureDefault)
llvm::iterator_range< conversion_iterator > getVisibleConversionFunctions() const
Get all conversion functions visible in current class, including conversion function templates.
bool hasConstexprDestructor() const
Determine whether this class has a constexpr destructor.
unsigned getNumBases() const
Retrieves the number of base classes of this class.
bool hasNonLiteralTypeFieldsOrBases() const
Determine whether this class has a non-literal or/ volatile type non-static data member or base class...
static CXXRecordDecl * Create(const ASTContext &C, TagKind TK, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, CXXRecordDecl *PrevDecl=nullptr, bool DelayTypeCreation=false)
bool isTriviallyCopyConstructible() const
Determine whether this class is considered trivially copyable per.
bool isCapturelessLambda() const
const CXXRecordDecl * getTemplateInstantiationPattern() const
Retrieve the record declaration from which this record could be instantiated.
bool lambdaIsDefaultConstructibleAndAssignable() const
Determine whether this lambda should have an implicit default constructor and copy and move assignmen...
TemplateSpecializationKind getTemplateSpecializationKind() const
Determine whether this particular class is a specialization or instantiation of a class template or m...
base_class_iterator bases_begin()
FunctionTemplateDecl * getDependentLambdaCallOperator() const
Retrieve the dependent lambda call operator of the closure type if this is a templated closure type.
void addedEligibleSpecialMemberFunction(const CXXMethodDecl *MD, unsigned SMKind)
Notify the class that an eligible SMF has been added.
conversion_iterator conversion_end() const
void finishedDefaultedOrDeletedMember(CXXMethodDecl *MD)
Indicates that the declaration of a defaulted or deleted special member function is now complete.
CXXRecordDecl(Kind K, TagKind TK, const ASTContext &C, DeclContext *DC, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, CXXRecordDecl *PrevDecl)
bool isCLike() const
True if this class is C-like, without C++-specific features, e.g.
void setInstantiationOfMemberClass(CXXRecordDecl *RD, TemplateSpecializationKind TSK)
Specify that this record is an instantiation of the member class RD.
static CXXRecordDecl * CreateDeserialized(const ASTContext &C, GlobalDeclID ID)
bool hasSimpleMoveAssignment() const
true if we know for sure that this class has a single, accessible, unambiguous move assignment operat...
bool hasNonTrivialMoveConstructor() const
Determine whether this class has a non-trivial move constructor (C++11 [class.copy]p12)
bool hasUserDeclaredConstructor() const
Determine whether this class has any user-declared constructors.
unsigned getODRHash() const
bool hasDefinition() const
ArrayRef< NamedDecl * > getLambdaExplicitTemplateParameters() const
Retrieve the lambda template parameters that were specified explicitly.
ClassTemplateDecl * getDescribedClassTemplate() const
Retrieves the class template that is described by this class declaration.
bool isPOD() const
Whether this class is a POD-type (C++ [class]p4)
void getFinalOverriders(CXXFinalOverriderMap &FinaOverriders) const
Retrieve the final overriders for each virtual member function in the class hierarchy where this clas...
void removeConversion(const NamedDecl *Old)
Removes a conversion function from this class.
bool hasSimpleCopyConstructor() const
true if we know for sure that this class has a single, accessible, unambiguous copy constructor that ...
CXXDestructorDecl * getDestructor() const
Returns the destructor decl for this class.
bool hasNonTrivialMoveAssignment() const
Determine whether this class has a non-trivial move assignment operator (C++11 [class....
CXXMethodDecl * getLambdaStaticInvoker() const
Retrieve the lambda static invoker, the address of which is returned by the conversion operator,...
bool hasSimpleDestructor() const
true if we know for sure that this class has an accessible destructor that is not deleted.
void setDescribedClassTemplate(ClassTemplateDecl *Template)
bool isInterfaceLike() const
void setLambdaNumbering(LambdaNumbering Numbering)
Set the mangling numbers and context declaration for a lambda class.
bool forallBases(ForallBasesCallback BaseMatches) const
Determines if the given callback holds for all the direct or indirect base classes of this type.
MemberSpecializationInfo * getMemberSpecializationInfo() const
If this class is an instantiation of a member class of a class template specialization,...
bool hasNonTrivialCopyConstructor() const
Determine whether this class has a non-trivial copy constructor (C++ [class.copy]p6,...
CXXMethodDecl * getLambdaCallOperator() const
Retrieve the lambda call operator of the closure type if this is a closure type.
const CXXRecordDecl * getStandardLayoutBaseWithFields() const
If this is a standard-layout class or union, any and all data members will be declared in the same ty...
bool hasSimpleCopyAssignment() const
true if we know for sure that this class has a single, accessible, unambiguous copy assignment operat...
CXXRecordDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
void setTemplateSpecializationKind(TemplateSpecializationKind TSK)
Set the kind of specialization or template instantiation this is.
unsigned getNumVBases() const
Retrieves the number of virtual base classes of this class.
conversion_iterator conversion_begin() const
unsigned getCVRQualifiers() const
Retrieve the const/volatile/restrict qualifiers.
CanQual< T > getUnqualifiedType() const
Retrieve the unqualified form of this type.
Declaration of a class template.
Represents the canonical version of C arrays with a specified constant size.
llvm::APInt getSize() const
Return the constant array size as an APInt.
Represents a shadow constructor declaration introduced into a class by a C++11 using-declaration that...
static ConstructorUsingShadowDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
UsingDecl * getIntroducer() const
Override the UsingShadowDecl's getIntroducer, returning the UsingDecl that introduced this.
static ConstructorUsingShadowDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation Loc, UsingDecl *Using, NamedDecl *Target, bool IsVirtual)
CXXRecordDecl * getNominatedBaseClass() const
Get the base class that was named in the using declaration.
The results of name lookup within a DeclContext.
specific_decl_iterator - Iterates over a subrange of declarations stored in a DeclContext,...
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.
ASTContext & getParentASTContext() const
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.
bool isTranslationUnit() const
bool isFunctionOrMethod() const
bool isExternCContext() const
Determines whether this context or some of its ancestors is a linkage specification context that spec...
LinkageSpecDeclBitfields LinkageSpecDeclBits
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,...
ASTContext & getASTContext() const LLVM_READONLY
bool isImplicit() const
isImplicit - Indicates whether the declaration was implicitly generated by the implementation.
ASTMutationListener * getASTMutationListener() const
Kind
Lists the kind of concrete classes of Decl.
bool isCanonicalDecl() const
Whether this particular Decl is a canonical one.
Module * getOwningModule() const
Get the module that owns this declaration (for visibility purposes).
FunctionDecl * getAsFunction() LLVM_READONLY
Returns the function itself, or the templated function if this is a function template.
bool isInvalidDecl() const
SourceLocation getLocation() const
void setImplicit(bool I=true)
redecl_range redecls() const
Returns an iterator range for all the redeclarations of the same decl.
DeclContext * getDeclContext()
AccessSpecifier getAccess() const
const LangOptions & getLangOpts() const LLVM_READONLY
Helper to get the language options from the ASTContext.
The name of a declaration.
IdentifierInfo * getAsIdentifierInfo() const
Retrieve the IdentifierInfo * stored in this declaration name, or null if this declaration name isn't...
OverloadedOperatorKind getCXXOverloadedOperator() const
If this name is the name of an overloadable operator in C++ (e.g., operator+), retrieve the kind of o...
@ CXXConversionFunctionName
NameKind getNameKind() const
Determine what kind of name this is.
bool isIdentifier() const
Predicate functions for querying what type of name this is.
A decomposition declaration.
void printName(raw_ostream &OS, const PrintingPolicy &Policy) const override
Pretty-print the unqualified name of this 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)
static DecompositionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumBindings)
DiagnosticBuilder Report(SourceLocation Loc, unsigned DiagID)
Issue the message to the client.
A helper class that allows the use of isa/cast/dyncast to detect TagType objects of enums.
Store information needed for an explicit specifier.
ExplicitSpecKind getKind() const
const Expr * getExpr() const
static ExplicitSpecifier getFromDecl(FunctionDecl *Function)
bool isEquivalent(const ExplicitSpecifier Other) const
Check for equivalence of explicit specifiers.
This represents one expression.
Expr * IgnoreImplicit() LLVM_READONLY
Skip past any implicit AST nodes which might surround this expression until reaching a fixed point.
Abstract interface for external sources of AST nodes.
virtual Decl * GetExternalDecl(GlobalDeclID ID)
Resolve a declaration ID into a declaration, potentially building a new declaration.
Represents a member of a struct/union/class.
Represents a function declaration or definition.
const ParmVarDecl * getParamDecl(unsigned i) const
bool isTrivialForCall() const
unsigned getMinRequiredArguments() const
Returns the minimum number of arguments needed to call this function.
FunctionTemplateDecl * getDescribedFunctionTemplate() const
Retrieves the function template that is described by this function declaration.
bool isDestroyingOperatorDelete() const
Determine whether this is a destroying operator delete.
bool hasCXXExplicitFunctionObjectParameter() const
bool UsesFPIntrin() const
Determine whether the function was declared in source context that requires constrained FP intrinsics...
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 isTrivial() const
Whether this function is "trivial" in some specialized C++ senses.
FunctionTemplateDecl * getPrimaryTemplate() const
Retrieve the primary template that this function template specialization either specializes or was in...
const ParmVarDecl * getNonObjectParameter(unsigned I) const
bool isVariadic() const
Whether this function is variadic.
bool doesThisDeclarationHaveABody() const
Returns whether this specific declaration of the function has a body.
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 isPureVirtual() const
Whether this virtual function is pure, i.e.
void setIneligibleOrNotSelected(bool II)
OverloadedOperatorKind getOverloadedOperator() const
getOverloadedOperator - Which C++ overloaded operator this function represents, if any.
bool isUserProvided() const
True if this method is user-declared and was not deleted or defaulted on its first declaration.
bool hasOneParamOrDefaultArgs() const
Determine whether this function has a single parameter, or multiple parameters where all but the firs...
unsigned getNumParams() const
Return the number of parameters this function must have based on its FunctionType.
bool isDefined(const FunctionDecl *&Definition, bool CheckForPendingFriendDefinition=false) const
Returns true if the function has a definition that does not need to be instantiated.
bool willHaveBody() const
True if this function will eventually have a body, once it's fully parsed.
Represents a prototype with parameter type info, e.g.
Qualifiers getMethodQuals() const
RefQualifierKind getRefQualifier() const
Retrieve the ref-qualifier associated with this function type.
Declaration of a template function.
FunctionType - C99 6.7.5.3 - Function Declarators.
One of these records is kept for each identifier that is lexed.
IdentifierInfo & get(StringRef Name)
Return the identifier token info for the specified named identifier.
Represents a field injected from an anonymous union/struct into the parent scope.
Description of a constructor that was inherited from a base class.
An lvalue reference type, per C++11 [dcl.ref].
Describes the capture of a variable or of this, or of a C++1y init-capture.
@ Ver6
Attempt to be ABI-compatible with code generated by Clang 6.0.x (SVN r321711).
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
APValue * getOrCreateValue(bool MayCreate) const
Get the storage for the constant value of a materialized temporary of static storage duration.
StorageDuration getStorageDuration() const
Retrieve the storage duration for the materialized temporary.
ValueDecl * getExtendingDecl()
Represents a linkage specification.
static LinkageSpecDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation ExternLoc, SourceLocation LangLoc, LinkageSpecLanguageIDs Lang, bool HasBraces)
static LinkageSpecDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
APValue & getAsAPValue() const
Get the value of this MSGuidDecl as an APValue.
void printName(llvm::raw_ostream &OS, const PrintingPolicy &Policy) const override
Print this UUID in a human-readable format.
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)
static MSPropertyDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
A pointer to member type per C++ 8.3.3 - Pointers to members.
Provides information a specialization of a member of a class template, which may be a member function...
Describes a module or submodule.
This represents a decl that may have a name.
NamedDecl * getUnderlyingDecl()
Looks through UsingDecls and ObjCCompatibleAliasDecls for the underlying named decl.
StringRef getName() const
Get the name of identifier for this declaration as a StringRef.
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
NamedDecl * getMostRecentDecl()
Represents a C++ namespace alias.
static NamespaceAliasDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
static NamespaceAliasDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation NamespaceLoc, SourceLocation AliasLoc, IdentifierInfo *Alias, NestedNameSpecifierLoc QualifierLoc, SourceLocation IdentLoc, NamedDecl *Namespace)
Represent a C++ namespace.
static NamespaceDecl * Create(ASTContext &C, DeclContext *DC, bool Inline, SourceLocation StartLoc, SourceLocation IdLoc, IdentifierInfo *Id, NamespaceDecl *PrevDecl, bool Nested)
static NamespaceDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
A C++ nested-name-specifier augmented with source location information.
SourceLocation getBeginLoc() const
Retrieve the location of the beginning of this nested-name-specifier.
CXXRecordDecl * getAsRecordDecl() const
Retrieve the record declaration stored in this nested name specifier.
void AddStmt(const Stmt *S)
void AddCXXRecordDecl(const CXXRecordDecl *Record)
Represents a parameter to a function.
A (possibly-)qualified type.
void addRestrict()
Add the restrict qualifier to this QualType.
void removeLocalRestrict()
@ OCL_Strong
Assigning into this object requires the old value to be released and the new value to be retained.
@ OCL_Weak
Reading or writing from this object requires a barrier call.
Represents a struct/union/class.
void setArgPassingRestrictions(RecordArgPassingKind Kind)
field_iterator field_end() const
field_range fields() const
void setHasObjectMember(bool val)
void setHasVolatileMember(bool val)
virtual void completeDefinition()
Note that the definition of this type is now complete.
RecordDecl * getDefinition() const
Returns the RecordDecl that actually defines this struct/union/class.
bool hasUninitializedExplicitInitFields() const
void setHasUninitializedExplicitInitFields(bool V)
field_iterator field_begin() const
A helper class that allows the use of isa/cast/dyncast to detect TagType objects of structs/unions/cl...
RecordDecl * getDecl() const
FunctionDecl * getFirstDecl()
Return the first declaration of this declaration or itself if this is the only declaration.
NamespaceDecl * getNextRedeclaration() const
NamespaceDecl * getPreviousDecl()
Return the previous declaration of this declaration or NULL if this is the first declaration.
Base for LValueReferenceType and RValueReferenceType.
Represents the body of a requires-expression.
static RequiresExprBodyDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StartLoc)
static RequiresExprBodyDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Encodes a location in the source.
A trivial tuple used to represent a source range.
Represents a C++11 static_assert declaration.
static StaticAssertDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation StaticAssertLoc, Expr *AssertExpr, Expr *Message, SourceLocation RParenLoc, bool Failed)
static StaticAssertDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
The streaming interface shared between DiagnosticBuilder and PartialDiagnostic.
bool isBeingDefined() const
Return true if this decl is currently being defined.
void setMayHaveOutOfDateDef(bool V=true)
Indicates whether it is possible for declarations of this kind to have an out-of-date definition.
void setBeingDefined(bool V=true)
True if this decl is currently being defined.
TagKind getTagKind() const
Exposes information about the current target.
virtual bool areDefaultedSMFStillPOD(const LangOptions &) const
Controls whether explicitly defaulted (= default) special member functions disqualify something from ...
Stores a list of template parameters for a TemplateDecl and its derived classes.
const Type * getTypeForDecl() const
Base wrapper for a particular "section" of type source info.
A container of type source information.
The base class of the type hierarchy.
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
bool isBlockPointerType() const
bool isLiteralType(const ASTContext &Ctx) const
Return true if this is a literal type (C++11 [basic.types]p10)
bool isUnsignedIntegerOrEnumerationType() const
Determines whether this is an integer type that is unsigned or an enumeration types whose underlying ...
bool isRValueReferenceType() const
bool isHLSLBuiltinIntangibleType() const
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
const Type * getArrayElementTypeNoTypeQual() const
If this is an array type, return the element type of the array, potentially with type qualifiers miss...
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
bool isLValueReferenceType() const
bool isStructuralType() const
Determine if this type is a structural type, per C++20 [temp.param]p7.
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
bool isHLSLAttributedResourceType() const
const T * getAs() const
Member-template getAs<specific type>'.
const Type * getUnqualifiedDesugaredType() const
Return the specified type with any "sugar" removed from the type, removing any typedefs,...
bool isRecordType() const
bool isObjCRetainableType() const
TagDecl * getAsTagDecl() const
Retrieves the TagDecl that this type refers to, either because the type is a TagType or because it is...
RecordDecl * getAsRecordDecl() const
Retrieves the RecordDecl this type refers to.
An artificial decl, representing a global anonymous constant value which is uniquified by value withi...
void printName(llvm::raw_ostream &OS, const PrintingPolicy &Policy) const override
Print this in a human-readable format.
A set of unresolved declarations.
void addDecl(NamedDecl *D)
The iterator over UnresolvedSets.
NamedDecl * getDecl() const
A set of unresolved declarations.
This node is generated when a using-declaration that was annotated with attribute((using_if_exists)) ...
static UnresolvedUsingIfExistsDecl * CreateDeserialized(ASTContext &Ctx, GlobalDeclID ID)
static UnresolvedUsingIfExistsDecl * Create(ASTContext &Ctx, DeclContext *DC, SourceLocation Loc, DeclarationName Name)
Represents a dependent using declaration which was marked with typename.
static UnresolvedUsingTypenameDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingLoc, SourceLocation TypenameLoc, NestedNameSpecifierLoc QualifierLoc, SourceLocation TargetNameLoc, DeclarationName TargetName, SourceLocation EllipsisLoc)
static UnresolvedUsingTypenameDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a dependent using declaration which was not marked with typename.
bool isAccessDeclaration() const
Return true if it is a C++03 access declaration (no 'using').
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier that qualifies the name, with source-location information.
DeclarationNameInfo getNameInfo() const
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
static UnresolvedUsingValueDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingLoc, NestedNameSpecifierLoc QualifierLoc, const DeclarationNameInfo &NameInfo, SourceLocation EllipsisLoc)
static UnresolvedUsingValueDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a C++ using-declaration.
bool isAccessDeclaration() const
Return true if it is a C++03 access declaration (no 'using').
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier that qualifies the name, with source-location information.
static UsingDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
DeclarationNameInfo getNameInfo() const
static UsingDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingL, NestedNameSpecifierLoc QualifierLoc, const DeclarationNameInfo &NameInfo, bool HasTypenameKeyword)
NestedNameSpecifier * getQualifier() const
Retrieve the nested-name-specifier that qualifies the name.
Represents C++ using-directive.
static UsingDirectiveDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
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.
Represents a C++ using-enum-declaration.
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
static UsingEnumDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
static UsingEnumDecl * Create(ASTContext &C, DeclContext *DC, SourceLocation UsingL, SourceLocation EnumL, SourceLocation NameL, TypeSourceInfo *EnumType)
Represents a pack of using declarations that a single using-declarator pack-expanded into.
static UsingPackDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumExpansions)
static UsingPackDecl * Create(ASTContext &C, DeclContext *DC, NamedDecl *InstantiatedFrom, ArrayRef< NamedDecl * > UsingDecls)
Represents a shadow declaration implicitly introduced into a scope by a (resolved) using-declaration ...
void setTargetDecl(NamedDecl *ND)
Sets the underlying declaration which has been brought into the local scope.
UsingShadowDecl(Kind K, ASTContext &C, DeclContext *DC, SourceLocation Loc, DeclarationName Name, BaseUsingDecl *Introducer, NamedDecl *Target)
static UsingShadowDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
BaseUsingDecl * getIntroducer() const
Gets the (written or instantiated) using declaration that introduced this declaration.
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
VarDecl * getPotentiallyDecomposedVarDecl()
Represents a variable declaration or definition.
Defines the clang::TargetInfo interface.
The JSON file list parser is used to communicate input to InstallAPI.
OverloadedOperatorKind
Enumeration specifying the different kinds of C++ overloaded operators.
bool isTemplateInstantiation(TemplateSpecializationKind Kind)
Determine whether this template specialization kind refers to an instantiation of an entity (as oppos...
ConstexprSpecKind
Define the kind of constexpr specifier.
LinkageSpecLanguageIDs
Represents the language in a linkage specification.
RefQualifierKind
The kind of C++11 ref-qualifier associated with a function type.
@ RQ_RValue
An rvalue ref-qualifier was provided (&&).
StorageClass
Storage classes.
const StreamingDiagnostic & operator<<(const StreamingDiagnostic &DB, const ASTContext::SectionInfo &Section)
Insertion operator for diagnostics.
StorageDuration
The storage duration for an object (per C++ [basic.stc]).
@ SD_Static
Static storage duration.
@ SD_FullExpression
Full-expression storage duration (for temporaries).
@ SD_Automatic
Automatic storage duration (most local variables).
@ Result
The result type of a method or function.
TagTypeKind
The kind of a tag type.
@ Interface
The "__interface" keyword.
@ Struct
The "struct" keyword.
@ Class
The "class" keyword.
@ CanNeverPassInRegs
The argument of this type cannot be passed directly in registers.
LambdaCaptureDefault
The default, if any, capture method for a lambda expression.
StringRef getLambdaStaticInvokerName()
const FunctionProtoType * T
DeductionCandidate
Only used by CXXDeductionGuideDecl.
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_Undeclared
This template specialization was formed from a template-id but has not yet been declared,...
CallingConv
CallingConv - Specifies the calling convention that a function uses.
U cast(CodeGen::Address addr)
@ Other
Other implicit parameter.
AccessSpecifier
A C++ access specifier (public, private, protected), plus the special value "none" which means differ...
Information about how a lambda is numbered within its context.
unsigned DeviceManglingNumber
bool HasKnownInternalLinkage
A placeholder type used to construct an empty shell of a decl-derived type that will be filled in lat...
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
DeclarationName getName() const
getName - Returns the embedded declaration name.
T * get(ExternalASTSource *Source) const
Retrieve the pointer to the AST node that this lazy pointer points to.
uint16_t Part2
...-89ab-...
uint32_t Part1
{01234567-...
uint16_t Part3
...-cdef-...
uint8_t Part4And5[8]
...-0123-456789abcdef}
Describes how types, statements, expressions, and declarations should be printed.