57#include "llvm/ADT/DenseMap.h"
58#include "llvm/ADT/FoldingSet.h"
59#include "llvm/ADT/SmallPtrSet.h"
60#include "llvm/ADT/SmallVector.h"
61#include "llvm/ADT/iterator_range.h"
62#include "llvm/Bitstream/BitstreamReader.h"
63#include "llvm/Support/ErrorHandling.h"
64#include "llvm/Support/SaveAndRestore.h"
81class RedeclarableResult {
87 RedeclarableResult(Decl *MergeWith, GlobalDeclID FirstID,
bool IsKeyDecl)
88 : MergeWith(MergeWith), FirstID(FirstID), IsKeyDecl(IsKeyDecl) {}
91 GlobalDeclID getFirstID()
const {
return FirstID; }
94 bool isKeyDecl()
const {
return IsKeyDecl; }
98 Decl *getKnownMergeTarget()
const {
return MergeWith; }
116 template <
typename T>
120 template <
typename T>
122 RedeclarableResult &Redecl) {
124 D, Existing, Redecl.isKeyDecl() ? Redecl.getFirstID() :
GlobalDeclID());
131 struct CXXRecordDecl::DefinitionData &&NewDD);
133 struct ObjCInterfaceDecl::DefinitionData &&NewDD);
135 struct ObjCProtocolDecl::DefinitionData &&NewDD);
148 ASTReader::RecordLocation Loc;
154 TypeID DeferredTypeID = 0;
155 unsigned AnonymousDeclNumber = 0;
162 bool IsDeclMarkedUsed =
false;
164 uint64_t GetCurrentCursorOffset();
166 uint64_t ReadLocalOffset() {
167 uint64_t LocalOffset = Record.readInt();
168 assert(LocalOffset < Loc.Offset &&
"offset point after current record");
169 return LocalOffset ? Loc.Offset - LocalOffset : 0;
172 uint64_t ReadGlobalOffset() {
173 uint64_t Local = ReadLocalOffset();
174 return Local ? Record.getGlobalBitOffset(Local) : 0;
177 SourceLocation readSourceLocation() {
return Record.readSourceLocation(); }
179 SourceRange readSourceRange() {
return Record.readSourceRange(); }
181 TypeSourceInfo *readTypeSourceInfo() {
return Record.readTypeSourceInfo(); }
183 GlobalDeclID readDeclID() {
return Record.readDeclID(); }
185 std::string readString() {
return Record.readString(); }
187 Decl *readDecl() {
return Record.readDecl(); }
189 template <
typename T>
T *readDeclAs() {
return Record.readDeclAs<
T>(); }
192 if (Record.getIdx() == Record.size())
195 return Record.getGlobalSubmoduleID(Record.readInt());
198 Module *readModule() {
return Record.getSubmodule(readSubmoduleID()); }
201 Decl *LambdaContext =
nullptr,
202 unsigned IndexInLambdaContext = 0);
203 void ReadCXXDefinitionData(
struct CXXRecordDecl::DefinitionData &
Data,
205 unsigned IndexInLambdaContext);
206 void ReadObjCDefinitionData(
struct ObjCInterfaceDecl::DefinitionData &
Data);
207 void ReadObjCDefinitionData(
struct ObjCProtocolDecl::DefinitionData &
Data);
228 class FindExistingResult {
232 bool AddResult =
false;
233 unsigned AnonymousDeclNumber = 0;
237 FindExistingResult(
ASTReader &Reader) : Reader(Reader) {}
240 unsigned AnonymousDeclNumber,
242 : Reader(Reader),
New(
New), Existing(Existing), AddResult(
true),
243 AnonymousDeclNumber(AnonymousDeclNumber),
244 TypedefNameForLinkage(TypedefNameForLinkage) {}
246 FindExistingResult(FindExistingResult &&
Other)
248 AddResult(
Other.AddResult),
249 AnonymousDeclNumber(
Other.AnonymousDeclNumber),
250 TypedefNameForLinkage(
Other.TypedefNameForLinkage) {
251 Other.AddResult =
false;
254 FindExistingResult &operator=(FindExistingResult &&) =
delete;
255 ~FindExistingResult();
259 void suppress() { AddResult =
false; }
261 operator NamedDecl *()
const {
return Existing; }
263 template <
typename T>
operator T *()
const {
264 return dyn_cast_or_null<T>(Existing);
270 FindExistingResult findExisting(
NamedDecl *D);
276 : Reader(Reader), MergeImpl(Reader), Record(Record), Loc(Loc),
277 ThisDeclID(thisDeclID), ThisDeclLoc(ThisDeclLoc) {}
279 template <
typename DeclT>
284 template <
typename DeclT>
294 template <
typename DeclT>
299 template <
typename DeclT>
304 llvm::BitstreamCursor &DeclsCursor,
bool IsPartial);
313 Cat->NextClassCategory =
Next;
419 template <
typename T>
422 template <
typename T>
426 RedeclarableResult &Redecl);
462template <
typename DeclT>
class MergedRedeclIterator {
463 DeclT *Start =
nullptr;
464 DeclT *Canonical =
nullptr;
465 DeclT *Current =
nullptr;
468 MergedRedeclIterator() =
default;
469 MergedRedeclIterator(DeclT *Start) : Start(Start), Current(Start) {}
473 MergedRedeclIterator &operator++() {
474 if (Current->isFirstDecl()) {
476 Current = Current->getMostRecentDecl();
478 Current = Current->getPreviousDecl();
484 if (Current == Start || Current == Canonical)
489 friend bool operator!=(
const MergedRedeclIterator &A,
490 const MergedRedeclIterator &B) {
491 return A.Current != B.Current;
497template <
typename DeclT>
498static llvm::iterator_range<MergedRedeclIterator<DeclT>>
500 return llvm::make_range(MergedRedeclIterator<DeclT>(D),
501 MergedRedeclIterator<DeclT>());
504uint64_t ASTDeclReader::GetCurrentCursorOffset() {
505 return Loc.F->DeclsCursor.GetCurrentBitNo() + Loc.F->GlobalBitOffset;
509 if (Record.readInt()) {
510 Reader.DefinitionSource[FD] =
512 Reader.getContext().getLangOpts().BuildingPCHWithObjectFile;
514 if (
auto *CD = dyn_cast<CXXConstructorDecl>(FD)) {
515 CD->setNumCtorInitializers(Record.readInt());
516 if (CD->getNumCtorInitializers())
517 CD->CtorInitializers = ReadGlobalOffset();
520 Reader.PendingBodies[FD] = GetCurrentCursorOffset();
523 Reader.ThisDeclarationWasADefinitionSet.insert(FD);
532 IsDeclMarkedUsed =
false;
534 if (
auto *DD = dyn_cast<DeclaratorDecl>(D)) {
535 if (
auto *TInfo = DD->getTypeSourceInfo())
536 Record.readTypeLoc(TInfo->getTypeLoc());
539 if (
auto *TD = dyn_cast<TypeDecl>(D)) {
542 assert(DeferredTypeID == 0 &&
543 "Deferred type not used for TagDecls and Typedefs");
545 TD->setTypeForDecl(Reader.GetType(DeferredTypeID).getTypePtrOrNull());
549 if (NamedDeclForTagDecl.isValid())
552 }
else if (
auto *ID = dyn_cast<ObjCInterfaceDecl>(D)) {
554 ID->TypeForDecl = Reader.GetType(DeferredTypeID).getTypePtrOrNull();
555 }
else if (
auto *FD = dyn_cast<FunctionDecl>(D)) {
557 if (Record.readInt())
559 }
else if (
auto *VD = dyn_cast<VarDecl>(D)) {
561 }
else if (
auto *FD = dyn_cast<FieldDecl>(D)) {
562 if (FD->hasInClassInitializer() && Record.readInt()) {
563 FD->setLazyInClassInitializer(
LazyDeclStmtPtr(GetCurrentCursorOffset()));
570 auto ModuleOwnership =
574 IsDeclMarkedUsed |= D->Used;
577 bool HasStandaloneLexicalDC = DeclBits.
getNextBit();
591 GlobalDeclID SemaDCIDForTemplateParmDecl = readDeclID();
594 if (LexicalDCIDForTemplateParmDecl.
isInvalid())
595 LexicalDCIDForTemplateParmDecl = SemaDCIDForTemplateParmDecl;
596 Reader.addPendingDeclContextInfo(D,
597 SemaDCIDForTemplateParmDecl,
598 LexicalDCIDForTemplateParmDecl);
601 auto *SemaDC = readDeclAs<DeclContext>();
603 HasStandaloneLexicalDC ? readDeclAs<DeclContext>() :
nullptr;
609 if (
auto *RD = dyn_cast<CXXRecordDecl>(SemaDC))
610 MergedSemaDC = getOrFakePrimaryClassDefinition(Reader, RD);
612 MergedSemaDC = Reader.MergedDeclContexts.
lookup(SemaDC);
615 D->setDeclContextsImpl(MergedSemaDC ? MergedSemaDC : SemaDC, LexicalDC,
616 Reader.getContext());
622 Record.readAttributes(Attrs);
625 D->setAttrsImpl(Attrs, Reader.getContext());
633 switch (ModuleOwnership) {
651 }
else if (Reader.getContext().getLangOpts().ModulesLocalVisibility) {
659 Reader.HiddenNamesMap[Owner].push_back(D);
661 }
else if (ModulePrivate) {
670 std::string Arg = readString();
671 memcpy(D->getTrailingObjects(), Arg.data(), Arg.size());
672 D->getTrailingObjects()[Arg.size()] =
'\0';
678 std::string Name = readString();
679 memcpy(D->getTrailingObjects(), Name.data(), Name.size());
680 D->getTrailingObjects()[Name.size()] =
'\0';
682 D->ValueStart = Name.size() + 1;
683 std::string
Value = readString();
684 memcpy(D->getTrailingObjects() + D->ValueStart,
Value.data(),
Value.size());
685 D->getTrailingObjects()[D->ValueStart +
Value.size()] =
'\0';
689 llvm_unreachable(
"Translation units are not serialized");
695 AnonymousDeclNumber = Record.readInt();
703 DeferredTypeID = Record.getGlobalTypeID(Record.readInt());
710 if (Record.readInt()) {
711 QualType modedT = Record.readType();
730 if (
auto *
Template = readDeclAs<TypeAliasTemplateDecl>())
756 auto *Info =
new (Reader.getContext()) TagDecl::ExtInfo();
757 Record.readQualifierInfo(*Info);
758 TD->TypedefNameDeclOrQualifier = Info;
762 NamedDeclForTagDecl = readDeclID();
763 TypedefNameForLinkage = Record.readIdentifier();
766 llvm_unreachable(
"unexpected tag info kind");
783 ED->setNumPositiveBits(EnumDeclBits.
getNextBits(8));
784 ED->setNumNegativeBits(EnumDeclBits.
getNextBits(8));
789 ED->setHasODRHash(
true);
790 ED->ODRHash = Record.readInt();
800 if (!D->isFromASTFile() && D->isCompleteDefinition()) {
807 Reader.MergedDeclContexts.insert(std::make_pair(ED, OldDef));
809 Reader.mergeDefinitionVisibility(OldDef, ED);
814 Reader.PendingEnumOdrMergeFailures[OldDef].push_back(ED);
820 if (
auto *InstED = readDeclAs<EnumDecl>()) {
823 ED->setInstantiationOfMemberEnum(Reader.getContext(), InstED, TSK);
852 RD->setODRHash(Record.readInt());
858 RecordDecl *&OldDef = Reader.RecordDefinitions[Canon];
863 if (!D->isFromASTFile() && D->isCompleteDefinition()) {
870 Reader.MergedDeclContexts.insert(std::make_pair(RD, OldDef));
872 Reader.mergeDefinitionVisibility(OldDef, RD);
874 Reader.PendingRecordOdrMergeFailures[OldDef].push_back(RD);
887 DeferredTypeID = Record.getGlobalTypeID(Record.readInt());
889 VD->
setType(Record.readType());
894 if (Record.readInt())
896 ECD->
setInitVal(Reader.getContext(), Record.readAPSInt());
903 if (Record.readInt()) {
904 auto *Info =
new (Reader.getContext()) DeclaratorDecl::ExtInfo();
905 Record.readQualifierInfo(*Info);
911 QualType TSIType = Record.readType();
913 TSIType.
isNull() ?
nullptr
914 : Reader.getContext().CreateTypeSourceInfo(TSIType));
929 auto *
Template = readDeclAs<FunctionTemplateDecl>();
935 auto *InstFD = readDeclAs<FunctionDecl>();
938 FD->setInstantiationOfMemberFunction(Reader.getContext(), InstFD, TSK);
943 auto *
Template = readDeclAs<FunctionTemplateDecl>();
948 Record.readTemplateArgumentList(TemplArgs,
true);
952 bool HasTemplateArgumentsAsWritten = Record.readBool();
953 if (HasTemplateArgumentsAsWritten)
954 Record.readTemplateArgumentListInfo(TemplArgsWritten);
963 if (Record.readInt()) {
964 auto *FD = readDeclAs<FunctionDecl>();
975 HasTemplateArgumentsAsWritten ? &TemplArgsWritten :
nullptr, POI,
977 FD->TemplateOrSpecialization = FTInfo;
982 auto *CanonTemplate = readDeclAs<FunctionTemplateDecl>();
988 llvm::FoldingSetNodeID ID;
990 void *InsertPos =
nullptr;
997 assert(Reader.getContext().getLangOpts().Modules &&
998 "already deserialized this template specialization");
1007 unsigned NumCandidates = Record.readInt();
1008 while (NumCandidates--)
1009 Candidates.
addDecl(readDeclAs<NamedDecl>());
1013 bool HasTemplateArgumentsAsWritten = Record.readBool();
1014 if (HasTemplateArgumentsAsWritten)
1015 Record.readTemplateArgumentListInfo(TemplArgsWritten);
1018 Reader.getContext(), Candidates,
1019 HasTemplateArgumentsAsWritten ? &TemplArgsWritten :
nullptr);
1038 Reader.PendingDeducedFunctionTypes.push_back({FD, DeferredTypeID});
1040 FD->
setType(Reader.GetType(DeferredTypeID));
1044 FD->DNLoc = Record.readDeclarationNameLoc(FD->
getDeclName());
1060 const bool Pure = FunctionDeclBits.
getNextBit();
1081 FD->EndRangeLoc = readSourceLocation();
1085 FD->ODRHash = Record.readInt();
1086 FD->setHasODRHash(
true);
1092 if (
auto Info = Record.readInt()) {
1093 bool HasMessage = Info & 2;
1097 unsigned NumLookups = Record.readInt();
1099 for (
unsigned I = 0; I != NumLookups; ++I) {
1107 Reader.getContext(), Lookups, DeletedMessage));
1112 MergeImpl.mergeRedeclarable(FD, Existing, Redecl);
1118 auto merge = [
this, &Redecl, FD](
auto &&F) {
1119 auto *Existing = cast_or_null<FunctionDecl>(Redecl.getKnownMergeTarget());
1120 RedeclarableResult NewRedecl(Existing ? F(Existing) :
nullptr,
1121 Redecl.getFirstID(), Redecl.isKeyDecl());
1139 unsigned NumParams = Record.readInt();
1141 Params.reserve(NumParams);
1142 for (
unsigned I = 0; I != NumParams; ++I)
1143 Params.push_back(readDeclAs<ParmVarDecl>());
1144 FD->setParams(Reader.getContext(), Params);
1149 if (FD->
hasAttr<SYCLKernelEntryPointAttr>()) {
1150 auto *SKEPAttr = FD->
getAttr<SYCLKernelEntryPointAttr>();
1152 const SYCLKernelInfo *SKI =
C.findSYCLKernelInfo(SKEPAttr->getKernelName());
1155 Reader.Diag(FD->
getLocation(), diag::err_sycl_kernel_name_conflict)
1158 diag::note_previous_declaration);
1159 SKEPAttr->setInvalidAttr();
1162 C.registerSYCLEntryPointFunction(FD);
1169 if (Record.readInt()) {
1172 Reader.PendingBodies[MD] = GetCurrentCursorOffset();
1175 MD->
setCmdDecl(readDeclAs<ImplicitParamDecl>());
1187 Reader.getContext().setObjCMethodRedeclaration(MD,
1188 readDeclAs<ObjCMethodDecl>());
1196 MD->DeclEndLoc = readSourceLocation();
1197 unsigned NumParams = Record.readInt();
1199 Params.reserve(NumParams);
1200 for (
unsigned I = 0; I != NumParams; ++I)
1201 Params.push_back(readDeclAs<ParmVarDecl>());
1204 unsigned NumStoredSelLocs = Record.readInt();
1206 SelLocs.reserve(NumStoredSelLocs);
1207 for (
unsigned i = 0; i != NumStoredSelLocs; ++i)
1208 SelLocs.push_back(readSourceLocation());
1210 MD->setParamsAndSelLocs(Reader.getContext(), Params, SelLocs);
1216 D->Variance = Record.readInt();
1217 D->Index = Record.readInt();
1218 D->VarianceLoc = readSourceLocation();
1219 D->ColonLoc = readSourceLocation();
1229 unsigned numParams = Record.readInt();
1234 typeParams.reserve(numParams);
1235 for (
unsigned i = 0; i != numParams; ++i) {
1236 auto *typeParam = readDeclAs<ObjCTypeParamDecl>();
1240 typeParams.push_back(typeParam);
1247 typeParams, rAngleLoc);
1250void ASTDeclReader::ReadObjCDefinitionData(
1251 struct ObjCInterfaceDecl::DefinitionData &
Data) {
1253 Data.SuperClassTInfo = readTypeSourceInfo();
1255 Data.EndLoc = readSourceLocation();
1256 Data.HasDesignatedInitializers =
Record.readInt();
1258 Data.HasODRHash =
true;
1261 unsigned NumProtocols =
Record.readInt();
1263 Protocols.reserve(NumProtocols);
1264 for (
unsigned I = 0; I != NumProtocols; ++I)
1265 Protocols.push_back(readDeclAs<ObjCProtocolDecl>());
1267 ProtoLocs.reserve(NumProtocols);
1268 for (
unsigned I = 0; I != NumProtocols; ++I)
1269 ProtoLocs.push_back(readSourceLocation());
1270 Data.ReferencedProtocols.set(Protocols.data(), NumProtocols, ProtoLocs.data(),
1274 NumProtocols =
Record.readInt();
1276 Protocols.reserve(NumProtocols);
1277 for (
unsigned I = 0; I != NumProtocols; ++I)
1278 Protocols.push_back(readDeclAs<ObjCProtocolDecl>());
1279 Data.AllReferencedProtocols.set(Protocols.data(), NumProtocols,
1285 struct ObjCInterfaceDecl::DefinitionData &DD = D->data();
1286 if (DD.Definition == NewDD.Definition)
1289 Reader.MergedDeclContexts.insert(
1290 std::make_pair(NewDD.Definition, DD.Definition));
1291 Reader.mergeDefinitionVisibility(DD.Definition, NewDD.Definition);
1294 Reader.PendingObjCInterfaceOdrMergeFailures[DD.Definition].push_back(
1295 {NewDD.Definition, &NewDD});
1301 DeferredTypeID = Record.getGlobalTypeID(Record.readInt());
1305 if (Record.readInt()) {
1307 ID->allocateDefinitionData();
1309 ReadObjCDefinitionData(ID->data());
1311 if (Canon->Data.getPointer()) {
1314 MergeImpl.MergeDefinitionData(Canon, std::move(ID->data()));
1315 ID->Data = Canon->Data;
1319 ID->getCanonicalDecl()->Data = ID->Data;
1322 ID->setIvarList(
nullptr);
1326 Reader.PendingDefinitions.insert(ID);
1329 Reader.ObjCClassesLoaded.push_back(ID);
1331 ID->Data = ID->getCanonicalDecl()->Data;
1340 bool synth = Record.readInt();
1355 if (PrevIvar && PrevIvar != IVD) {
1356 auto *ParentExt = dyn_cast<ObjCCategoryDecl>(IVD->
getDeclContext());
1357 auto *PrevParentExt =
1359 if (ParentExt && PrevParentExt) {
1363 .PendingObjCExtensionIvarRedeclarations[std::make_pair(ParentExt,
1365 .push_back(std::make_pair(IVD, PrevIvar));
1366 }
else if (ParentExt || PrevParentExt) {
1370 Reader.Diag(IVD->
getLocation(), diag::err_duplicate_ivar_declaration)
1372 Reader.Diag(PrevIvar->
getLocation(), diag::note_previous_definition);
1377void ASTDeclReader::ReadObjCDefinitionData(
1378 struct ObjCProtocolDecl::DefinitionData &
Data) {
1379 unsigned NumProtoRefs =
Record.readInt();
1381 ProtoRefs.reserve(NumProtoRefs);
1382 for (
unsigned I = 0; I != NumProtoRefs; ++I)
1383 ProtoRefs.push_back(readDeclAs<ObjCProtocolDecl>());
1385 ProtoLocs.reserve(NumProtoRefs);
1386 for (
unsigned I = 0; I != NumProtoRefs; ++I)
1387 ProtoLocs.push_back(readSourceLocation());
1388 Data.ReferencedProtocols.set(ProtoRefs.data(), NumProtoRefs,
1391 Data.HasODRHash =
true;
1396 struct ObjCProtocolDecl::DefinitionData &DD = D->data();
1397 if (DD.Definition == NewDD.Definition)
1400 Reader.MergedDeclContexts.insert(
1401 std::make_pair(NewDD.Definition, DD.Definition));
1402 Reader.mergeDefinitionVisibility(DD.Definition, NewDD.Definition);
1405 Reader.PendingObjCProtocolOdrMergeFailures[DD.Definition].push_back(
1406 {NewDD.Definition, &NewDD});
1414 if (Record.readInt()) {
1416 PD->allocateDefinitionData();
1418 ReadObjCDefinitionData(PD->data());
1421 if (Canon->Data.getPointer()) {
1424 MergeImpl.MergeDefinitionData(Canon, std::move(PD->data()));
1425 PD->Data = Canon->Data;
1432 Reader.PendingDefinitions.insert(PD);
1451 Reader.CategoriesDeserialized.insert(CD);
1453 CD->ClassInterface = readDeclAs<ObjCInterfaceDecl>();
1455 unsigned NumProtoRefs = Record.readInt();
1457 ProtoRefs.reserve(NumProtoRefs);
1458 for (
unsigned I = 0; I != NumProtoRefs; ++I)
1459 ProtoRefs.push_back(readDeclAs<ObjCProtocolDecl>());
1461 ProtoLocs.reserve(NumProtoRefs);
1462 for (
unsigned I = 0; I != NumProtoRefs; ++I)
1463 ProtoLocs.push_back(readSourceLocation());
1465 Reader.getContext());
1471 Reader.getContext());
1509 D->CategoryNameLoc = readSourceLocation();
1515 D->SuperLoc = readSourceLocation();
1520 D->NumIvarInitializers = Record.readInt();
1521 if (D->NumIvarInitializers)
1522 D->IvarInitializers = ReadGlobalOffset();
1529 D->PropertyIvarDecl = readDeclAs<ObjCIvarDecl>();
1530 D->IvarLoc = readSourceLocation();
1539 FD->Mutable = Record.readInt();
1541 unsigned Bits = Record.readInt();
1542 FD->StorageKind = Bits >> 1;
1543 if (FD->StorageKind == FieldDecl::ISK_CapturedVLAType)
1551 if (
auto *Tmpl = readDeclAs<FieldDecl>())
1552 Reader.getContext().setInstantiatedFromUnnamedFieldDecl(FD, Tmpl);
1559 PD->GetterId = Record.readIdentifier();
1560 PD->SetterId = Record.readIdentifier();
1565 D->PartVal.
Part1 = Record.readInt();
1566 D->PartVal.
Part2 = Record.readInt();
1567 D->PartVal.
Part3 = Record.readInt();
1569 C = Record.readInt();
1572 if (
MSGuidDecl *Existing = Reader.getContext().MSGuidDecls.GetOrInsertNode(D))
1579 D->Value = Record.readAPValue();
1583 Reader.getContext().UnnamedGlobalConstantDecls.GetOrInsertNode(D))
1589 D->Value = Record.readAPValue();
1594 Reader.getContext().TemplateParamObjectDecls.GetOrInsertNode(D))
1601 FD->ChainingSize = Record.readInt();
1602 assert(FD->ChainingSize >= 2 &&
"Anonymous chaining must be >= 2");
1603 FD->Chaining =
new (Reader.getContext())
NamedDecl*[FD->ChainingSize];
1605 for (
unsigned I = 0; I != FD->ChainingSize; ++I)
1606 FD->Chaining[I] = readDeclAs<NamedDecl>();
1617 bool DefGeneratedInModule = VarDeclBits.
getNextBit();
1622 bool HasDeducedType =
false;
1650 Reader.PendingDeducedVarTypes.push_back({VD, DeferredTypeID});
1652 VD->
setType(Reader.GetType(DeferredTypeID));
1662 if (DefGeneratedInModule) {
1663 Reader.DefinitionSource[VD] =
1665 Reader.getContext().getLangOpts().BuildingPCHWithObjectFile;
1668 if (VD->
hasAttr<BlocksAttr>()) {
1669 Expr *CopyExpr = Record.readExpr();
1671 Reader.getContext().setBlockVarCopyInit(VD, CopyExpr, Record.readInt());
1675 VarNotTemplate = 0,
VarTemplate, StaticDataMemberSpecialization
1677 switch ((VarKind)Record.readInt()) {
1678 case VarNotTemplate:
1689 case StaticDataMemberSpecialization: {
1690 auto *Tmpl = readDeclAs<VarDecl>();
1693 Reader.getContext().setInstantiatedFromStaticDataMember(VD, Tmpl, TSK,POI);
1703 if (uint64_t Val = Record.readInt()) {
1713 Reader.getContext().addDestruction(&Eval->
Evaluated);
1719 Eval->
Value = GetCurrentCursorOffset();
1730 unsigned scopeIndex = Record.readInt();
1732 unsigned isObjCMethodParam = ParmVarDeclBits.
getNextBit();
1733 unsigned scopeDepth = ParmVarDeclBits.
getNextBits(7);
1734 unsigned declQualifier = ParmVarDeclBits.
getNextBits(7);
1735 if (isObjCMethodParam) {
1736 assert(scopeDepth == 0);
1749 PD->ExplicitObjectParameterIntroducerLoc = Record.readSourceLocation();
1757 auto **BDs = DD->getTrailingObjects();
1758 for (
unsigned I = 0; I != DD->NumBindings; ++I) {
1759 BDs[I] = readDeclAs<BindingDecl>();
1760 BDs[I]->setDecomposedDecl(DD);
1766 BD->Binding = Record.readExpr();
1777 D->Statement = Record.readStmt();
1782 BD->
setBody(cast_or_null<CompoundStmt>(Record.readStmt()));
1784 unsigned NumParams = Record.readInt();
1786 Params.reserve(NumParams);
1787 for (
unsigned I = 0; I != NumParams; ++I)
1788 Params.push_back(readDeclAs<ParmVarDecl>());
1797 bool capturesCXXThis = Record.readInt();
1798 unsigned numCaptures = Record.readInt();
1800 captures.reserve(numCaptures);
1801 for (
unsigned i = 0; i != numCaptures; ++i) {
1802 auto *
decl = readDeclAs<VarDecl>();
1803 unsigned flags = Record.readInt();
1804 bool byRef = (flags & 1);
1805 bool nested = (flags & 2);
1806 Expr *copyExpr = ((flags & 4) ? Record.readExpr() :
nullptr);
1810 BD->
setCaptures(Reader.getContext(), captures, capturesCXXThis);
1816 for (
unsigned I = 0; I < D->NumParams; ++I)
1817 D->
setParam(I, readDeclAs<ImplicitParamDecl>());
1819 D->
setBody(cast_or_null<Stmt>(Record.readStmt()));
1824 unsigned ContextParamPos = Record.readInt();
1827 for (
unsigned I = 0; I < CD->NumParams; ++I) {
1828 if (I != ContextParamPos)
1829 CD->
setParam(I, readDeclAs<ImplicitParamDecl>());
1844 D->RBraceLoc = readSourceLocation();
1859 D->LocStart = readSourceLocation();
1860 D->RBraceLoc = readSourceLocation();
1867 if (Redecl.getFirstID() == ThisDeclID)
1868 AnonNamespace = readDeclID();
1872 if (AnonNamespace.
isValid()) {
1877 if (!Record.isModule())
1886 D->IsCBuffer = Record.readBool();
1887 D->KwLoc = readSourceLocation();
1888 D->LBraceLoc = readSourceLocation();
1889 D->RBraceLoc = readSourceLocation();
1895 D->NamespaceLoc = readSourceLocation();
1896 D->IdentLoc = readSourceLocation();
1897 D->QualifierLoc = Record.readNestedNameSpecifierLoc();
1898 D->Namespace = readDeclAs<NamespaceBaseDecl>();
1905 D->QualifierLoc = Record.readNestedNameSpecifierLoc();
1906 D->DNLoc = Record.readDeclarationNameLoc(D->
getDeclName());
1907 D->FirstUsingShadow.setPointer(readDeclAs<UsingShadowDecl>());
1909 if (
auto *Pattern = readDeclAs<NamedDecl>())
1910 Reader.getContext().setInstantiatedFromUsingDecl(D, Pattern);
1919 D->FirstUsingShadow.setPointer(readDeclAs<UsingShadowDecl>());
1920 if (
auto *Pattern = readDeclAs<UsingEnumDecl>())
1921 Reader.getContext().setInstantiatedFromUsingEnumDecl(D, Pattern);
1927 D->InstantiatedFrom = readDeclAs<NamedDecl>();
1928 auto **Expansions = D->getTrailingObjects();
1929 for (
unsigned I = 0; I != D->NumExpansions; ++I)
1930 Expansions[I] = readDeclAs<NamedDecl>();
1937 D->Underlying = readDeclAs<NamedDecl>();
1939 D->UsingOrNextShadow = readDeclAs<NamedDecl>();
1940 auto *Pattern = readDeclAs<UsingShadowDecl>();
1942 Reader.getContext().setInstantiatedFromUsingShadowDecl(D, Pattern);
1949 D->NominatedBaseClassShadowDecl = readDeclAs<ConstructorUsingShadowDecl>();
1950 D->ConstructedBaseClassShadowDecl = readDeclAs<ConstructorUsingShadowDecl>();
1951 D->IsVirtual = Record.readInt();
1956 D->UsingLoc = readSourceLocation();
1957 D->NamespaceLoc = readSourceLocation();
1958 D->QualifierLoc = Record.readNestedNameSpecifierLoc();
1959 D->NominatedNamespace = readDeclAs<NamedDecl>();
1960 D->CommonAncestor = readDeclAs<DeclContext>();
1966 D->QualifierLoc = Record.readNestedNameSpecifierLoc();
1967 D->DNLoc = Record.readDeclarationNameLoc(D->
getDeclName());
1968 D->EllipsisLoc = readSourceLocation();
1975 D->TypenameLocation = readSourceLocation();
1976 D->QualifierLoc = Record.readNestedNameSpecifierLoc();
1977 D->EllipsisLoc = readSourceLocation();
1986void ASTDeclReader::ReadCXXDefinitionData(
1988 Decl *LambdaContext,
unsigned IndexInLambdaContext) {
1992#define FIELD(Name, Width, Merge) \
1993 if (!CXXRecordDeclBits.canGetNextNBits(Width)) \
1994 CXXRecordDeclBits.updateValue(Record.readInt()); \
1995 Data.Name = CXXRecordDeclBits.getNextBits(Width);
1997#include "clang/AST/CXXRecordDeclDefinitionBits.def"
2002 Data.HasODRHash =
true;
2005 Reader.DefinitionSource[D] =
2006 Loc.F->
Kind == ModuleKind::MK_MainFile ||
2011 Data.ComputedVisibleConversions =
Record.readInt();
2012 if (
Data.ComputedVisibleConversions)
2013 Record.readUnresolvedSet(
Data.VisibleConversions);
2014 assert(
Data.Definition &&
"Data.Definition should be already set!");
2016 if (!
Data.IsLambda) {
2017 assert(!LambdaContext && !IndexInLambdaContext &&
2018 "given lambda context for non-lambda");
2022 Data.Bases = ReadGlobalOffset();
2026 Data.VBases = ReadGlobalOffset();
2030 using Capture = LambdaCapture;
2032 auto &Lambda =
static_cast<CXXRecordDecl::LambdaDefinitionData &
>(
Data);
2034 BitsUnpacker LambdaBits(Record.readInt());
2035 Lambda.DependencyKind = LambdaBits.getNextBits(2);
2036 Lambda.IsGenericLambda = LambdaBits.getNextBit();
2037 Lambda.CaptureDefault = LambdaBits.getNextBits(2);
2038 Lambda.NumCaptures = LambdaBits.getNextBits(15);
2039 Lambda.HasKnownInternalLinkage = LambdaBits.getNextBit();
2041 Lambda.NumExplicitCaptures = Record.readInt();
2042 Lambda.ManglingNumber = Record.readInt();
2043 if (
unsigned DeviceManglingNumber = Record.readInt())
2044 Reader.getContext().DeviceLambdaManglingNumbers[D] = DeviceManglingNumber;
2045 Lambda.IndexInContext = IndexInLambdaContext;
2046 Lambda.ContextDecl = LambdaContext;
2048 if (Lambda.NumCaptures) {
2049 ToCapture = (
Capture *)Reader.getContext().Allocate(
sizeof(
Capture) *
2050 Lambda.NumCaptures);
2051 Lambda.AddCaptureList(Reader.getContext(), ToCapture);
2053 Lambda.MethodTyInfo = readTypeSourceInfo();
2054 for (
unsigned I = 0, N = Lambda.NumCaptures; I != N; ++I) {
2055 SourceLocation Loc = readSourceLocation();
2056 BitsUnpacker CaptureBits(Record.readInt());
2057 bool IsImplicit = CaptureBits.getNextBit();
2065 Capture(Loc, IsImplicit, Kind,
nullptr, SourceLocation());
2070 auto *Var = readDeclAs<ValueDecl>();
2071 SourceLocation EllipsisLoc = readSourceLocation();
2072 new (ToCapture)
Capture(Loc, IsImplicit, Kind, Var, EllipsisLoc);
2081 CXXRecordDecl *D,
struct CXXRecordDecl::DefinitionData &&MergeDD) {
2082 assert(D->DefinitionData &&
2083 "merging class definition into non-definition");
2084 auto &DD = *D->DefinitionData;
2086 if (DD.Definition != MergeDD.Definition) {
2088 Reader.MergedDeclContexts.insert(std::make_pair(MergeDD.Definition,
2090 Reader.PendingDefinitions.erase(MergeDD.Definition);
2091 MergeDD.Definition->demoteThisDefinitionToDeclaration();
2092 Reader.mergeDefinitionVisibility(DD.Definition, MergeDD.Definition);
2093 assert(!Reader.Lookups.contains(MergeDD.Definition) &&
2094 "already loaded pending lookups for merged definition");
2097 auto PFDI = Reader.PendingFakeDefinitionData.find(&DD);
2098 if (PFDI != Reader.PendingFakeDefinitionData.end() &&
2099 PFDI->second == ASTReader::PendingFakeDefinitionKind::Fake) {
2102 assert(!DD.IsLambda && !MergeDD.IsLambda &&
"faked up lambda definition?");
2103 PFDI->second = ASTReader::PendingFakeDefinitionKind::FakeLoaded;
2107 auto *Def = DD.Definition;
2108 DD = std::move(MergeDD);
2109 DD.Definition = Def;
2110 for (
auto *R = Reader.getMostRecentExistingDecl(Def); R;
2111 R = R->getPreviousDecl())
2116 bool DetectedOdrViolation =
false;
2118 #define FIELD(Name, Width, Merge) Merge(Name)
2119 #define MERGE_OR(Field) DD.Field |= MergeDD.Field;
2120 #define NO_MERGE(Field) \
2121 DetectedOdrViolation |= DD.Field != MergeDD.Field; \
2123 #include "clang/AST/CXXRecordDeclDefinitionBits.def"
2128 if (DD.NumBases != MergeDD.NumBases || DD.NumVBases != MergeDD.NumVBases)
2129 DetectedOdrViolation =
true;
2135 if (MergeDD.ComputedVisibleConversions && !DD.ComputedVisibleConversions) {
2136 DD.VisibleConversions = std::move(MergeDD.VisibleConversions);
2137 DD.ComputedVisibleConversions =
true;
2144 auto &Lambda1 =
static_cast<CXXRecordDecl::LambdaDefinitionData &
>(DD);
2145 auto &Lambda2 =
static_cast<CXXRecordDecl::LambdaDefinitionData &
>(MergeDD);
2146 DetectedOdrViolation |= Lambda1.DependencyKind != Lambda2.DependencyKind;
2147 DetectedOdrViolation |= Lambda1.IsGenericLambda != Lambda2.IsGenericLambda;
2148 DetectedOdrViolation |= Lambda1.CaptureDefault != Lambda2.CaptureDefault;
2149 DetectedOdrViolation |= Lambda1.NumCaptures != Lambda2.NumCaptures;
2150 DetectedOdrViolation |=
2151 Lambda1.NumExplicitCaptures != Lambda2.NumExplicitCaptures;
2152 DetectedOdrViolation |=
2153 Lambda1.HasKnownInternalLinkage != Lambda2.HasKnownInternalLinkage;
2154 DetectedOdrViolation |= Lambda1.ManglingNumber != Lambda2.ManglingNumber;
2156 if (Lambda1.NumCaptures && Lambda1.NumCaptures == Lambda2.NumCaptures) {
2157 for (
unsigned I = 0, N = Lambda1.NumCaptures; I != N; ++I) {
2162 Lambda1.AddCaptureList(Reader.getContext(), Lambda2.Captures.front());
2171 DetectedOdrViolation =
true;
2174 if (DetectedOdrViolation)
2175 Reader.PendingOdrMergeFailures[DD.Definition].push_back(
2176 {MergeDD.Definition, &MergeDD});
2180 Decl *LambdaContext,
2181 unsigned IndexInLambdaContext) {
2182 struct CXXRecordDecl::DefinitionData *DD;
2187 bool IsLambda =
Record.readInt();
2188 assert(!(IsLambda &&
Update) &&
2189 "lambda definition should not be added by update record");
2191 DD =
new (
C) CXXRecordDecl::LambdaDefinitionData(
2194 DD =
new (
C)
struct CXXRecordDecl::DefinitionData(D);
2200 if (!Canon->DefinitionData)
2201 Canon->DefinitionData = DD;
2202 D->DefinitionData = Canon->DefinitionData;
2203 ReadCXXDefinitionData(*DD, D, LambdaContext, IndexInLambdaContext);
2211 if (Canon->DefinitionData != DD) {
2219 if (
Update || Canon != D)
2220 Reader.PendingDefinitions.insert(D);
2229 CXXRecNotTemplate = 0,
2231 CXXRecMemberSpecialization,
2235 Decl *LambdaContext =
nullptr;
2236 unsigned IndexInLambdaContext = 0;
2238 switch ((CXXRecKind)Record.readInt()) {
2239 case CXXRecNotTemplate:
2244 case CXXRecTemplate: {
2246 auto *
Template = readDeclAs<ClassTemplateDecl>();
2247 D->TemplateOrInstantiation =
Template;
2250 case CXXRecMemberSpecialization: {
2251 auto *RD = readDeclAs<CXXRecordDecl>();
2256 D->TemplateOrInstantiation = MSI;
2261 LambdaContext = readDecl();
2263 IndexInLambdaContext = Record.readInt();
2265 MergeImpl.mergeLambda(D, Redecl, *LambdaContext, IndexInLambdaContext);
2274 bool WasDefinition = Record.readInt();
2276 ReadCXXRecordDefinition(D,
false, LambdaContext,
2277 IndexInLambdaContext);
2284 if (WasDefinition) {
2297 D->setExplicitSpecifier(Record.readExplicitSpec());
2298 D->Ctor = readDeclAs<CXXConstructorDecl>();
2311 unsigned NumOverridenMethods = Record.readInt();
2313 while (NumOverridenMethods--) {
2316 if (
auto *MD = readDeclAs<CXXMethodDecl>())
2322 Record.skipInts(NumOverridenMethods);
2331 auto *Shadow = readDeclAs<ConstructorUsingShadowDecl>();
2332 auto *Ctor = readDeclAs<CXXConstructorDecl>();
2345 if (
auto *OperatorDelete = readDeclAs<FunctionDecl>()) {
2346 auto *ThisArg = Record.readExpr();
2349 C.addOperatorDeleteForVDtor(D, OperatorDelete,
2351 Canon->OperatorDeleteThisArg = ThisArg;
2354 if (
auto *OperatorGlobDelete = readDeclAs<FunctionDecl>()) {
2355 if (!
C.dtorHasOperatorDelete(D,
2357 C.addOperatorDeleteForVDtor(
2360 if (
auto *OperatorArrayDelete = readDeclAs<FunctionDecl>()) {
2362 C.addOperatorDeleteForVDtor(D, OperatorArrayDelete,
2365 if (
auto *OperatorGlobArrayDelete = readDeclAs<FunctionDecl>()) {
2366 if (!
C.dtorHasOperatorDelete(D,
2368 C.addOperatorDeleteForVDtor(D, OperatorGlobArrayDelete,
2380 D->ImportedModule = readModule();
2381 D->setImportComplete(Record.readInt());
2382 auto *StoredLocs = D->getTrailingObjects();
2383 for (
unsigned I = 0, N = Record.back(); I != N; ++I)
2384 StoredLocs[I] = readSourceLocation();
2395 if (Record.readInt())
2396 D->Friend = readDeclAs<NamedDecl>();
2398 D->Friend = readTypeSourceInfo();
2399 for (
unsigned i = 0; i != D->NumTPLists; ++i)
2400 D->getTrailingObjects()[i] = Record.readTemplateParameterList();
2401 D->NextFriend = readDeclID().getRawValue();
2402 D->UnsupportedFriend = (Record.readInt() != 0);
2403 D->FriendLoc = readSourceLocation();
2404 D->EllipsisLoc = readSourceLocation();
2409 unsigned NumParams = Record.readInt();
2410 D->NumParams = NumParams;
2412 for (
unsigned i = 0; i != NumParams; ++i)
2413 D->Params[i] = Record.readTemplateParameterList();
2414 if (Record.readInt())
2415 D->Friend = readDeclAs<NamedDecl>();
2417 D->Friend = readTypeSourceInfo();
2418 D->FriendLoc = readSourceLocation();
2426 D->
init(readDeclAs<NamedDecl>());
2441 for (
unsigned I = 0; I < D->NumTemplateArgs; ++I)
2442 Args.push_back(Record.readTemplateArgument(
false));
2450 llvm::BitstreamCursor &DeclsCursor,
2452 uint64_t Offset = ReadLocalOffset();
2454 Reader.ReadSpecializations(M, DeclsCursor, Offset, D, IsPartial);
2468 Reader.PendingDefinitions.insert(CanonD);
2474 if (ThisDeclID == Redecl.getFirstID()) {
2475 if (
auto *RTD = readDeclAs<RedeclarableTemplateDecl>()) {
2476 assert(RTD->getKind() == D->
getKind() &&
2477 "InstantiatedFromMemberTemplate kind mismatch");
2479 if (Record.readInt())
2494 if (ThisDeclID == Redecl.getFirstID()) {
2503 llvm_unreachable(
"BuiltinTemplates are not serialized");
2513 if (ThisDeclID == Redecl.getFirstID()) {
2526 if (
Decl *InstD = readDecl()) {
2527 if (
auto *CTD = dyn_cast<ClassTemplateDecl>(InstD)) {
2528 D->SpecializedTemplate = CTD;
2531 Record.readTemplateArgumentList(TemplArgs);
2536 SpecializedPartialSpecialization();
2537 PS->PartialSpecialization
2539 PS->TemplateArgs = ArgList;
2540 D->SpecializedTemplate = PS;
2545 Record.readTemplateArgumentList(TemplArgs,
true);
2547 D->PointOfInstantiation = readSourceLocation();
2549 D->StrictPackMatch = Record.readBool();
2551 bool writtenAsCanonicalDecl = Record.readInt();
2552 if (writtenAsCanonicalDecl) {
2553 auto *CanonPattern = readDeclAs<ClassTemplateDecl>();
2557 if (
auto *Partial = dyn_cast<ClassTemplatePartialSpecializationDecl>(D)) {
2558 CanonSpec = CanonPattern->getCommonPtr()->PartialSpecializations
2559 .GetOrInsertNode(Partial);
2562 CanonPattern->getCommonPtr()->Specializations.GetOrInsertNode(D);
2565 if (CanonSpec != D) {
2566 MergeImpl.mergeRedeclarable<
TagDecl>(D, CanonSpec, Redecl);
2570 if (
auto *DDD = D->DefinitionData) {
2571 if (CanonSpec->DefinitionData)
2572 MergeImpl.MergeDefinitionData(CanonSpec, std::move(*DDD));
2574 CanonSpec->DefinitionData = D->DefinitionData;
2576 D->DefinitionData = CanonSpec->DefinitionData;
2582 if (Record.readBool()) {
2585 ExplicitInfo->TemplateKeywordLoc = readSourceLocation();
2586 D->ExplicitInfo = ExplicitInfo;
2589 if (Record.readBool())
2600 D->TemplateParams = Params;
2605 if (ThisDeclID == Redecl.getFirstID()) {
2606 D->InstantiatedFromMember.setPointer(
2607 readDeclAs<ClassTemplatePartialSpecializationDecl>());
2608 D->InstantiatedFromMember.setInt(Record.readInt());
2615 if (ThisDeclID == Redecl.getFirstID()) {
2629 if (
Decl *InstD = readDecl()) {
2630 if (
auto *VTD = dyn_cast<VarTemplateDecl>(InstD)) {
2631 D->SpecializedTemplate = VTD;
2634 Record.readTemplateArgumentList(TemplArgs);
2639 VarTemplateSpecializationDecl::SpecializedPartialSpecialization();
2640 PS->PartialSpecialization =
2642 PS->TemplateArgs = ArgList;
2643 D->SpecializedTemplate = PS;
2648 if (Record.readBool()) {
2651 ExplicitInfo->TemplateKeywordLoc = readSourceLocation();
2652 D->ExplicitInfo = ExplicitInfo;
2655 if (Record.readBool())
2659 Record.readTemplateArgumentList(TemplArgs,
true);
2661 D->PointOfInstantiation = readSourceLocation();
2663 D->IsCompleteDefinition = Record.readInt();
2667 bool writtenAsCanonicalDecl = Record.readInt();
2668 if (writtenAsCanonicalDecl) {
2669 auto *CanonPattern = readDeclAs<VarTemplateDecl>();
2672 if (
auto *Partial = dyn_cast<VarTemplatePartialSpecializationDecl>(D)) {
2673 CanonSpec = CanonPattern->getCommonPtr()
2674 ->PartialSpecializations.GetOrInsertNode(Partial);
2677 CanonPattern->getCommonPtr()->Specializations.GetOrInsertNode(D);
2681 MergeImpl.mergeRedeclarable<
VarDecl>(D, CanonSpec, Redecl);
2696 D->TemplateParams = Params;
2701 if (ThisDeclID == Redecl.getFirstID()) {
2702 D->InstantiatedFromMember.setPointer(
2703 readDeclAs<VarTemplatePartialSpecializationDecl>());
2704 D->InstantiatedFromMember.setInt(Record.readInt());
2714 if (TypeConstraintInitialized) {
2716 if (Record.readBool())
2717 CR = Record.readConceptReference();
2718 Expr *ImmediatelyDeclaredConstraint = Record.readExpr();
2722 D->NumExpanded = Record.readUnsignedOrNone();
2725 if (Record.readInt())
2727 Record.readTemplateArgumentLoc());
2738 auto TypesAndInfos =
2739 D->getTrailingObjects<std::pair<QualType, TypeSourceInfo *>>();
2741 new (&TypesAndInfos[I].first)
QualType(Record.readType());
2742 TypesAndInfos[I].second = readTypeSourceInfo();
2746 D->ParameterPack = Record.readInt();
2747 if (Record.readInt())
2749 Record.readTemplateArgumentLoc());
2761 auto **
Data = D->getTrailingObjects();
2764 Data[I] = Record.readTemplateParameterList();
2767 D->ParameterPack = Record.readInt();
2768 if (Record.readInt())
2770 Record.readTemplateArgumentLoc());
2781 D->AssertExprAndFailed.setPointer(Record.readExpr());
2782 D->AssertExprAndFailed.setInt(Record.readInt());
2783 D->Message = cast_or_null<StringLiteral>(Record.readExpr());
2784 D->RParenLoc = readSourceLocation();
2794 D->ExtendingDecl = readDeclAs<ValueDecl>();
2795 D->ExprWithTemporary = Record.readStmt();
2796 if (Record.readInt()) {
2800 D->ManglingNumber = Record.readInt();
2812template <
typename T>
2815 Decl *MergeWith =
nullptr;
2817 bool IsKeyDecl = ThisDeclID == FirstDeclID;
2818 bool IsFirstLocalDecl =
false;
2820 uint64_t RedeclOffset = 0;
2825 FirstDeclID = ThisDeclID;
2827 IsFirstLocalDecl =
true;
2828 }
else if (
unsigned N = Record.readInt()) {
2832 IsFirstLocalDecl =
true;
2839 for (
unsigned I = 0; I != N - 1; ++I)
2840 MergeWith = readDecl();
2842 RedeclOffset = ReadLocalOffset();
2849 auto *FirstDecl = cast_or_null<T>(Reader.GetDecl(FirstDeclID));
2850 if (FirstDecl != D) {
2856 D->
First = FirstDecl->getCanonicalDecl();
2859 auto *DAsT =
static_cast<T *
>(D);
2865 if (IsFirstLocalDecl)
2866 Reader.PendingDeclChains.push_back(std::make_pair(DAsT, RedeclOffset));
2868 return RedeclarableResult(MergeWith, FirstDeclID, IsKeyDecl);
2873template <
typename T>
2875 RedeclarableResult &Redecl) {
2877 if (!Reader.getContext().getLangOpts().Modules)
2884 auto *D =
static_cast<T *
>(DBase);
2886 if (
auto *Existing = Redecl.getKnownMergeTarget())
2888 MergeImpl.mergeRedeclarable(D,
cast<T>(Existing), Redecl);
2889 else if (FindExistingResult ExistingRes = findExisting(D))
2890 if (
T *Existing = ExistingRes)
2891 MergeImpl.mergeRedeclarable(D, Existing, Redecl);
2901 Decl &Context,
unsigned IndexInContext) {
2903 if (!Reader.getContext().getLangOpts().Modules)
2910 if (
auto *Existing = Redecl.getKnownMergeTarget())
2916 NamedDecl *&Slot = Reader.LambdaDeclarationsForMerging[{
2917 Context.getCanonicalDecl(), IndexInContext}];
2925 RedeclarableResult &Redecl) {
2938 llvm_unreachable(
"bad assert_cast");
2948 RedeclarableResult
Result(
2950 DPattern->getCanonicalDecl()->getGlobalID(), IsKeyDecl);
2952 if (
auto *DClass = dyn_cast<CXXRecordDecl>(DPattern)) {
2955 auto *ExistingClass =
2957 if (
auto *DDD = DClass->DefinitionData) {
2958 if (ExistingClass->DefinitionData) {
2961 ExistingClass->DefinitionData = DClass->DefinitionData;
2964 Reader.PendingDefinitions.insert(DClass);
2967 DClass->DefinitionData = ExistingClass->DefinitionData;
2972 if (
auto *DFunction = dyn_cast<FunctionDecl>(DPattern))
2975 if (
auto *DVar = dyn_cast<VarDecl>(DPattern))
2977 if (
auto *DAlias = dyn_cast<TypeAliasDecl>(DPattern))
2980 llvm_unreachable(
"merged an unknown kind of redeclarable template");
2985template <
typename T>
2988 auto *D =
static_cast<T *
>(DBase);
2989 T *ExistingCanon = Existing->getCanonicalDecl();
2991 if (ExistingCanon != DCanon) {
2996 D->
First = ExistingCanon;
2997 ExistingCanon->Used |= D->Used;
3000 bool IsKeyDecl = KeyDeclID.
isValid();
3003 if (
auto *DTemplate = dyn_cast<RedeclarableTemplateDecl>(D))
3010 Reader.KeyDecls[ExistingCanon].push_back(KeyDeclID);
3032 if (!Reader.getContext().getLangOpts().Modules)
3038 Reader.LETemporaryForMerging[std::make_pair(
3041 Reader.getContext().setPrimaryMergedDecl(LETDecl,
3054 if (!Reader.getContext().getLangOpts().Modules)
3061 if (!Reader.getContext().getLangOpts().CPlusPlus &&
3065 if (FindExistingResult ExistingRes = findExisting(
static_cast<T*
>(D)))
3066 if (
T *Existing = ExistingRes)
3067 Reader.getContext().setPrimaryMergedDecl(
static_cast<T *
>(D),
3068 Existing->getCanonicalDecl());
3072 Record.readOMPChildren(D->
Data);
3077 Record.readOMPChildren(D->
Data);
3082 Record.readOMPChildren(D->
Data);
3089 Expr *In = Record.readExpr();
3090 Expr *Out = Record.readExpr();
3092 Expr *Combiner = Record.readExpr();
3094 Expr *Orig = Record.readExpr();
3095 Expr *Priv = Record.readExpr();
3100 D->PrevDeclInScope = readDeclID().getRawValue();
3104 Record.readOMPChildren(D->
Data);
3106 D->VarName = Record.readDeclarationName();
3107 D->PrevDeclInScope = readDeclID().getRawValue();
3117 D->DirectiveLoc = Record.readSourceLocation();
3118 D->EndLoc = Record.readSourceLocation();
3119 Record.readOpenACCClauseList(D->Clauses);
3124 D->DirectiveLoc = Record.readSourceLocation();
3125 D->EndLoc = Record.readSourceLocation();
3126 D->ParensLoc = Record.readSourceRange();
3127 D->FuncRef = Record.readExpr();
3128 Record.readOpenACCClauseList(D->Clauses);
3142 uint64_t readInt() {
3146 bool readBool() {
return Reader.
readBool(); }
3148 SourceRange readSourceRange() {
3152 SourceLocation readSourceLocation() {
3156 Expr *readExpr() {
return Reader.
readExpr(); }
3158 Attr *readAttr() {
return Reader.
readAttr(); }
3160 std::string readString() {
3164 TypeSourceInfo *readTypeSourceInfo() {
3168 IdentifierInfo *readIdentifier() {
3172 VersionTuple readVersionTuple() {
3178 template <
typename T>
T *readDeclAs() {
return Reader.
readDeclAs<
T>(); }
3183 AttrReader
Record(*
this);
3184 auto V = Record.readInt();
3198 unsigned ParsedKind = Record.readInt();
3199 unsigned Syntax = Record.readInt();
3200 unsigned SpellingIndex = Record.readInt();
3201 bool IsAlignas = (ParsedKind == AttributeCommonInfo::AT_Aligned &&
3203 SpellingIndex == AlignedAttr::Keyword_alignas);
3204 bool IsRegularKeywordAttribute = Record.readBool();
3209 IsAlignas, IsRegularKeywordAttribute});
3211#include "clang/Serialization/AttrPCHRead.inc"
3213 assert(
New &&
"Unable to decode attribute?");
3219 for (
unsigned I = 0, E =
readInt(); I != E; ++I)
3234inline void ASTReader::LoadedDecl(
unsigned Index,
Decl *D) {
3235 assert(!DeclsLoaded[Index] &&
"Decl loaded twice?");
3236 DeclsLoaded[Index] = D;
3245bool ASTReader::isConsumerInterestedIn(
Decl *D) {
3258 if (
isa<FileScopeAsmDecl, TopLevelStmtDecl, ObjCProtocolDecl, ObjCImplDecl,
3259 ImportDecl, PragmaCommentDecl, PragmaDetectMismatchDecl>(D))
3261 if (
isa<OMPThreadPrivateDecl, OMPDeclareReductionDecl, OMPDeclareMapperDecl,
3262 OMPAllocateDecl, OMPRequiresDecl>(D))
3264 if (
const auto *Var = dyn_cast<VarDecl>(D))
3265 return Var->isFileVarDecl() &&
3267 OMPDeclareTargetDeclAttr::isDeclareTargetDeclaration(Var));
3268 if (
const auto *
Func = dyn_cast<FunctionDecl>(D))
3269 return Func->doesThisDeclarationHaveABody() || PendingBodies.count(D);
3279ASTReader::RecordLocation ASTReader::DeclCursorForID(
GlobalDeclID ID,
3283 unsigned LocalDeclIndex = ID.getLocalDeclIndex();
3284 const DeclOffset &DOffs = M->
DeclOffsets[LocalDeclIndex];
3289ASTReader::RecordLocation ASTReader::getLocalBitOffset(uint64_t GlobalOffset) {
3290 auto I = GlobalBitOffsetsMap.find(GlobalOffset);
3292 assert(I != GlobalBitOffsetsMap.end() &&
"Corrupted global bit offsets map");
3293 return RecordLocation(I->second, GlobalOffset - I->second->GlobalBitOffset);
3296uint64_t ASTReader::getGlobalBitOffset(ModuleFile &M, uint64_t LocalOffset) {
3301ASTDeclReader::getOrFakePrimaryClassDefinition(
ASTReader &Reader,
3304 auto *DD = RD->DefinitionData;
3313 DD =
new (Reader.getContext())
struct CXXRecordDecl::DefinitionData(RD);
3315 RD->DefinitionData = DD;
3319 Reader.PendingFakeDefinitionData.insert(
3320 std::make_pair(DD, ASTReader::PendingFakeDefinitionKind::Fake));
3323 return DD->Definition;
3330 if (
auto *ND = dyn_cast<NamespaceDecl>(DC))
3331 return ND->getFirstDecl();
3333 if (
auto *RD = dyn_cast<CXXRecordDecl>(DC))
3334 return getOrFakePrimaryClassDefinition(Reader, RD);
3336 if (
auto *RD = dyn_cast<RecordDecl>(DC))
3339 if (
auto *ED = dyn_cast<EnumDecl>(DC))
3342 if (
auto *OID = dyn_cast<ObjCInterfaceDecl>(DC))
3347 if (
auto *TU = dyn_cast<TranslationUnitDecl>(DC))
3353ASTDeclReader::FindExistingResult::~FindExistingResult() {
3356 if (TypedefNameForLinkage) {
3358 Reader.ImportedTypedefNamesForLinkage.insert(
3359 std::make_pair(std::make_pair(DC, TypedefNameForLinkage), New));
3363 if (!AddResult || Existing)
3366 DeclarationName Name = New->getDeclName();
3369 setAnonymousDeclForMerging(Reader, New->getLexicalDeclContext(),
3370 AnonymousDeclNumber, New);
3372 !Reader.getContext().getLangOpts().CPlusPlus) {
3373 if (Reader.getIdResolver().tryAddTopLevelDecl(New, Name))
3376 }
else if (DeclContext *MergeDC = getPrimaryContextForMerging(Reader, DC)) {
3379 MergeDC->makeDeclVisibleInContextImpl(New,
true);
3387 bool IsTypedefNameForLinkage) {
3388 if (!IsTypedefNameForLinkage)
3394 if (
Found->isFromASTFile())
3397 if (
auto *TND = dyn_cast<TypedefNameDecl>(
Found))
3398 return TND->getAnonDeclWithTypedefName(
true);
3407ASTDeclReader::getPrimaryDCForAnonymousDecl(DeclContext *LexicalDC) {
3409 if (
auto *RD = dyn_cast<CXXRecordDecl>(LexicalDC)) {
3411 return DD ? DD->Definition :
nullptr;
3412 }
else if (
auto *OID = dyn_cast<ObjCInterfaceDecl>(LexicalDC)) {
3413 return OID->getCanonicalDecl()->getDefinition();
3420 if (
auto *FD = dyn_cast<FunctionDecl>(D))
3421 if (FD->isThisDeclarationADefinition())
3423 if (
auto *MD = dyn_cast<ObjCMethodDecl>(D))
3424 if (MD->isThisDeclarationADefinition())
3426 if (
auto *RD = dyn_cast<RecordDecl>(D))
3435NamedDecl *ASTDeclReader::getAnonymousDeclForMerging(ASTReader &Reader,
3440 auto *CanonDC =
cast<Decl>(DC)->getCanonicalDecl();
3443 auto &
Previous = Reader.AnonymousDeclarationsForMerging[CanonDC];
3449 auto *PrimaryDC = getPrimaryDCForAnonymousDecl(DC);
3450 auto needToNumberAnonymousDeclsWithin = [](
Decl *D) {
3458 auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(D);
3459 return CTSD && !CTSD->noload_field_empty() &&
3460 !CTSD->hasLoadedFieldsFromExternalStorage();
3462 if (PrimaryDC && needToNumberAnonymousDeclsWithin(
cast<Decl>(PrimaryDC))) {
3474void ASTDeclReader::setAnonymousDeclForMerging(ASTReader &Reader,
3475 DeclContext *DC,
unsigned Index,
3477 auto *CanonDC =
cast<Decl>(DC)->getCanonicalDecl();
3479 auto &
Previous = Reader.AnonymousDeclarationsForMerging[CanonDC];
3486ASTDeclReader::FindExistingResult ASTDeclReader::findExisting(NamedDecl *D) {
3487 DeclarationName Name = TypedefNameForLinkage ? TypedefNameForLinkage
3493 FindExistingResult
Result(Reader, D,
nullptr,
3494 AnonymousDeclNumber, TypedefNameForLinkage);
3499 ASTContext &
C = Reader.getContext();
3501 if (TypedefNameForLinkage) {
3502 auto It = Reader.ImportedTypedefNamesForLinkage.find(
3503 std::make_pair(DC, TypedefNameForLinkage));
3504 if (It != Reader.ImportedTypedefNamesForLinkage.end())
3505 if (
C.isSameEntity(It->second, D))
3506 return FindExistingResult(Reader, D, It->second, AnonymousDeclNumber,
3507 TypedefNameForLinkage);
3515 if (
auto *Existing = getAnonymousDeclForMerging(
3517 if (
C.isSameEntity(Existing, D))
3518 return FindExistingResult(Reader, D, Existing, AnonymousDeclNumber,
3519 TypedefNameForLinkage);
3521 !Reader.getContext().getLangOpts().CPlusPlus) {
3522 IdentifierResolver &IdResolver = Reader.getIdResolver();
3526 class UpToDateIdentifierRAII {
3528 bool WasOutToDate =
false;
3531 explicit UpToDateIdentifierRAII(IdentifierInfo *II) : II(II) {
3539 ~UpToDateIdentifierRAII() {
3545 for (IdentifierResolver::iterator I = IdResolver.
begin(Name),
3546 IEnd = IdResolver.
end();
3549 if (
C.isSameEntity(Existing, D))
3550 return FindExistingResult(Reader, D, Existing, AnonymousDeclNumber,
3551 TypedefNameForLinkage);
3553 }
else if (DeclContext *MergeDC = getPrimaryContextForMerging(Reader, DC)) {
3557 if (
C.isSameEntity(Existing, D))
3558 return FindExistingResult(Reader, D, Existing, AnonymousDeclNumber,
3559 TypedefNameForLinkage);
3563 return FindExistingResult(Reader);
3575 if (MergedDCIt != Reader.MergedDeclContexts.end() &&
3578 Reader.PendingOdrMergeChecks.push_back(D);
3580 return FindExistingResult(Reader, D,
nullptr,
3581 AnonymousDeclNumber, TypedefNameForLinkage);
3584template<
typename DeclT>
3590 llvm_unreachable(
"getMostRecentDecl on non-redeclarable declaration");
3597#define ABSTRACT_DECL(TYPE)
3598#define DECL(TYPE, BASE) \
3600 return getMostRecentDeclImpl(cast<TYPE##Decl>(D));
3601#include "clang/AST/DeclNodes.inc"
3603 llvm_unreachable(
"unknown decl kind");
3606Decl *ASTReader::getMostRecentExistingDecl(
Decl *D) {
3614 const auto *IA =
Previous->getAttr<MSInheritanceAttr>();
3616 if (IA && !D->
hasAttr<MSInheritanceAttr>()) {
3622 const auto *AA =
Previous->getAttr<AvailabilityAttr>();
3623 if (AA && !D->
hasAttr<AvailabilityAttr>()) {
3624 NewAttr = AA->
clone(Context);
3631template<
typename DeclT>
3645 auto *VD =
static_cast<VarDecl *
>(D);
3648 D->
First = PrevVD->First;
3656 Reader.mergeDefinitionVisibility(CurD, VD);
3657 VD->demoteThisDefinitionToDeclaration();
3665 auto *DT =
T->getContainedDeducedType();
3666 return DT && !DT->isDeduced();
3676 FD->RedeclLink.setPrevious(PrevFD);
3677 FD->First = PrevFD->First;
3681 if (PrevFD->isInlined() != FD->isInlined()) {
3697 FD->setImplicitlyInline(
true);
3702 if (FPT && PrevFPT) {
3706 bool WasUnresolved =
3708 if (IsUnresolved != WasUnresolved)
3709 Reader.PendingExceptionSpecUpdates.insert(
3710 {Canon, IsUnresolved ? PrevFD : FD});
3716 if (IsUndeduced != WasUndeduced)
3717 Reader.PendingDeducedTypeUpdates.insert(
3719 (IsUndeduced ? PrevFPT : FPT)->getReturnType()});
3726 llvm_unreachable(
"attachPreviousDecl on non-redeclarable declaration");
3731template <
typename ParmDecl>
3735 if (!From->hasDefaultArgument())
3737 To->setInheritedDefaultArgument(Context, From);
3746 assert(FromTP->size() == ToTP->size() &&
"merged mismatched templates?");
3748 for (
unsigned I = 0, N = FromTP->size(); I != N; ++I) {
3749 NamedDecl *FromParam = FromTP->getParam(I);
3752 if (
auto *FTTP = dyn_cast<TemplateTypeParmDecl>(FromParam))
3754 else if (
auto *FNTTP = dyn_cast<NonTypeTemplateParmDecl>(FromParam))
3789 Func &&
Func->getTemplateSpecializationInfo())
3798 if (!
Previous->getLexicalDeclContext()
3799 ->getNonTransparentContext()
3800 ->isFileContext() ||
3818 Reader.PendingWarningForDuplicatedDefsInModuleUnits.push_back(
3827 Reader.Diag(
Previous->getLocation(),
3828 diag::err_multiple_decl_in_different_modules)
3830 Reader.Diag(D->
getLocation(), diag::note_also_found);
3838#define ABSTRACT_DECL(TYPE)
3839#define DECL(TYPE, BASE) \
3841 attachPreviousDeclImpl(Reader, cast<TYPE##Decl>(D), Previous, Canon); \
3843#include "clang/AST/DeclNodes.inc"
3859 if (
auto *TD = dyn_cast<TemplateDecl>(D))
3867 mergeInheritableAttributes(Reader, D,
Previous);
3870template<
typename DeclT>
3876 llvm_unreachable(
"attachLatestDecl on non-redeclarable declaration");
3880 assert(D && Latest);
3883#define ABSTRACT_DECL(TYPE)
3884#define DECL(TYPE, BASE) \
3886 attachLatestDeclImpl(cast<TYPE##Decl>(D), Latest); \
3888#include "clang/AST/DeclNodes.inc"
3892template<
typename DeclT>
3898 llvm_unreachable(
"markIncompleteDeclChain on non-redeclarable declaration");
3901void ASTReader::markIncompleteDeclChain(
Decl *D) {
3903#define ABSTRACT_DECL(TYPE)
3904#define DECL(TYPE, BASE) \
3906 ASTDeclReader::markIncompleteDeclChainImpl(cast<TYPE##Decl>(D)); \
3908#include "clang/AST/DeclNodes.inc"
3914 SourceLocation DeclLoc;
3915 RecordLocation Loc = DeclCursorForID(ID, DeclLoc);
3916 llvm::BitstreamCursor &DeclsCursor = Loc.F->DeclsCursor;
3919 SavedStreamPosition SavedPosition(DeclsCursor);
3921 ReadingKindTracker ReadingKind(Read_Decl, *
this);
3926 auto Fail = [](
const char *what, llvm::Error &&Err) {
3927 llvm::report_fatal_error(Twine(
"ASTReader::readDeclRecord failed ") + what +
3931 if (llvm::Error JumpFailed = DeclsCursor.JumpToBit(Loc.Offset))
3932 Fail(
"jumping", std::move(JumpFailed));
3935 Expected<unsigned> MaybeCode = DeclsCursor.ReadCode();
3937 Fail(
"reading code", MaybeCode.takeError());
3938 unsigned Code = MaybeCode.get();
3942 Expected<unsigned> MaybeDeclCode =
Record.readRecord(DeclsCursor, Code);
3944 llvm::report_fatal_error(
3945 Twine(
"ASTReader::readDeclRecord failed reading decl code: ") +
3946 toString(MaybeDeclCode.takeError()));
3948 switch ((
DeclCode)MaybeDeclCode.get()) {
3955 llvm_unreachable(
"Record cannot be de-serialized with readDeclRecord");
4065 bool HasTypeConstraint =
Record.readInt();
4071 bool HasTypeConstraint =
Record.readInt();
4077 bool HasTypeConstraint =
Record.readInt();
4079 Context, ID,
Record.readInt(), HasTypeConstraint);
4168 D = MSGuidDecl::CreateDeserialized(Context, ID);
4171 D = UnnamedGlobalConstantDecl::CreateDeserialized(Context, ID);
4174 D = TemplateParamObjectDecl::CreateDeserialized(Context, ID);
4183 Error(
"attempt to read a C++ base-specifier record as a declaration");
4186 Error(
"attempt to read a C++ ctor initializer record as a declaration");
4195 unsigned NumChildren =
Record.readInt();
4201 unsigned NumClauses =
Record.readInt();
4202 unsigned NumVars =
Record.readInt();
4208 unsigned NumClauses =
Record.readInt();
4217 unsigned NumClauses =
Record.readInt();
4256 assert(D &&
"Unknown declaration reading AST file");
4257 LoadedDecl(translateGlobalDeclIDToIndex(ID), D);
4268 if (
auto *DC = dyn_cast<DeclContext>(D)) {
4269 LookupBlockOffsets Offsets;
4271 Reader.VisitDeclContext(DC, Offsets);
4277 if (
auto Iter = DelayedNamespaceOffsetMap.find(ID);
4278 Iter != DelayedNamespaceOffsetMap.end())
4279 Offsets = Iter->second;
4282 ReadVisibleDeclContextStorage(
4284 VisibleDeclContextStorageKind::GenerallyVisible))
4287 ReadVisibleDeclContextStorage(
4289 VisibleDeclContextStorageKind::ModuleLocalVisible))
4292 ReadVisibleDeclContextStorage(
4294 VisibleDeclContextStorageKind::TULocalVisible))
4298 ReadLexicalDeclContextStorage(*Loc.F, DeclsCursor,
4305 PendingUpdateRecords.push_back(
4306 PendingUpdateRecord(ID, D,
true));
4309 if (
auto *
Class = dyn_cast<ObjCInterfaceDecl>(D))
4312 if (
Class->isThisDeclarationADefinition() ||
4313 PendingDefinitions.count(
Class))
4314 loadObjCCategories(ID,
Class);
4320 PotentiallyInterestingDecls.push_back(D);
4325void ASTReader::PassInterestingDeclsToConsumer() {
4328 if (!CanPassDeclsToConsumer)
4333 SaveAndRestore GuardPassingDeclsToConsumer(CanPassDeclsToConsumer,
4338 for (
auto ID : EagerlyDeserializedDecls)
4340 EagerlyDeserializedDecls.clear();
4342 auto ConsumingPotentialInterestingDecls = [
this]() {
4343 while (!PotentiallyInterestingDecls.empty()) {
4344 Decl *D = PotentiallyInterestingDecls.front();
4345 PotentiallyInterestingDecls.pop_front();
4346 if (isConsumerInterestedIn(D))
4347 PassInterestingDeclToConsumer(D);
4350 std::deque<Decl *> MaybeInterestingDecls =
4351 std::move(PotentiallyInterestingDecls);
4352 PotentiallyInterestingDecls.clear();
4353 assert(PotentiallyInterestingDecls.empty());
4354 while (!MaybeInterestingDecls.empty()) {
4355 Decl *D = MaybeInterestingDecls.front();
4356 MaybeInterestingDecls.pop_front();
4362 if (
auto *VD = dyn_cast<VarDecl>(D);
4363 VD && VD->isFileVarDecl() && !VD->isExternallyVisible())
4365 ConsumingPotentialInterestingDecls();
4366 if (isConsumerInterestedIn(D))
4367 PassInterestingDeclToConsumer(D);
4371 ConsumingPotentialInterestingDecls();
4373 for (GlobalDeclID ID : VTablesToEmit) {
4376 PassVTableToConsumer(RD);
4378 VTablesToEmit.clear();
4381void ASTReader::loadDeclUpdateRecords(PendingUpdateRecord &
Record) {
4385 GlobalDeclID ID =
Record.ID;
4387 ProcessingUpdatesRAIIObj ProcessingUpdates(*
this);
4388 DeclUpdateOffsetsMap::iterator UpdI = DeclUpdateOffsets.find(ID);
4390 if (UpdI != DeclUpdateOffsets.end()) {
4391 auto UpdateOffsets = std::move(UpdI->second);
4392 DeclUpdateOffsets.erase(UpdI);
4398 bool WasInteresting =
Record.JustLoaded || isConsumerInterestedIn(D);
4399 for (
auto &FileAndOffset : UpdateOffsets) {
4401 uint64_t Offset = FileAndOffset.second;
4403 SavedStreamPosition SavedPosition(Cursor);
4404 if (llvm::Error JumpFailed =
Cursor.JumpToBit(Offset))
4406 llvm::report_fatal_error(
4407 Twine(
"ASTReader::loadDeclUpdateRecords failed jumping: ") +
4409 Expected<unsigned> MaybeCode =
Cursor.ReadCode();
4411 llvm::report_fatal_error(
4412 Twine(
"ASTReader::loadDeclUpdateRecords failed reading code: ") +
4414 unsigned Code = MaybeCode.get();
4416 if (Expected<unsigned> MaybeRecCode =
Record.readRecord(Cursor, Code))
4418 "Expected DECL_UPDATES record!");
4420 llvm::report_fatal_error(
4421 Twine(
"ASTReader::loadDeclUpdateRecords failed reading rec code: ") +
4426 Reader.UpdateDecl(D);
4430 if (!WasInteresting && isConsumerInterestedIn(D)) {
4431 PotentiallyInterestingDecls.push_back(D);
4432 WasInteresting =
true;
4438 if (
auto I = PendingVisibleUpdates.find(ID);
4439 I != PendingVisibleUpdates.end()) {
4440 auto VisibleUpdates = std::move(I->second);
4441 PendingVisibleUpdates.erase(I);
4444 for (
const auto &
Update : VisibleUpdates)
4445 Lookups[DC].Table.add(
4447 reader::ASTDeclContextNameLookupTrait(*
this, *
Update.Mod));
4451 if (
auto I = PendingModuleLocalVisibleUpdates.find(ID);
4452 I != PendingModuleLocalVisibleUpdates.end()) {
4453 auto ModuleLocalVisibleUpdates = std::move(I->second);
4454 PendingModuleLocalVisibleUpdates.erase(I);
4457 for (
const auto &
Update : ModuleLocalVisibleUpdates)
4458 ModuleLocalLookups[DC].Table.add(
4460 reader::ModuleLocalNameLookupTrait(*
this, *
Update.Mod));
4466 if (
auto I = TULocalUpdates.find(ID); I != TULocalUpdates.end()) {
4467 auto Updates = std::move(I->second);
4468 TULocalUpdates.erase(I);
4471 for (
const auto &
Update : Updates)
4472 TULocalLookups[DC].Table.add(
4474 reader::ASTDeclContextNameLookupTrait(*
this, *
Update.Mod));
4480 if (
auto IT = RelatedDeclsMap.find(ID); IT != RelatedDeclsMap.end()) {
4481 for (
auto LID : IT->second)
4483 RelatedDeclsMap.erase(IT);
4488 if (
auto I = PendingSpecializationsUpdates.find(ID);
4489 I != PendingSpecializationsUpdates.end()) {
4490 auto SpecializationUpdates = std::move(I->second);
4491 PendingSpecializationsUpdates.erase(I);
4493 for (
const auto &
Update : SpecializationUpdates)
4494 AddSpecializations(D,
Update.Data, *
Update.Mod,
false);
4498 if (
auto I = PendingPartialSpecializationsUpdates.find(ID);
4499 I != PendingPartialSpecializationsUpdates.end()) {
4500 auto SpecializationUpdates = std::move(I->second);
4501 PendingPartialSpecializationsUpdates.erase(I);
4503 for (
const auto &
Update : SpecializationUpdates)
4508void ASTReader::loadPendingDeclChain(
Decl *FirstLocal, uint64_t LocalOffset) {
4511 if (FirstLocal != CanonDecl) {
4514 *
this, FirstLocal, PrevMostRecent ? PrevMostRecent : CanonDecl,
4525 assert(M &&
"imported decl from no module file");
4528 SavedStreamPosition SavedPosition(Cursor);
4529 if (llvm::Error JumpFailed =
Cursor.JumpToBit(LocalOffset))
4530 llvm::report_fatal_error(
4531 Twine(
"ASTReader::loadPendingDeclChain failed jumping: ") +
4535 Expected<unsigned> MaybeCode =
Cursor.ReadCode();
4537 llvm::report_fatal_error(
4538 Twine(
"ASTReader::loadPendingDeclChain failed reading code: ") +
4540 unsigned Code = MaybeCode.get();
4541 if (Expected<unsigned> MaybeRecCode =
Cursor.readRecord(Code,
Record))
4543 "expected LOCAL_REDECLARATIONS record!");
4545 llvm::report_fatal_error(
4546 Twine(
"ASTReader::loadPendingDeclChain failed reading rec code: ") +
4551 Decl *MostRecent = FirstLocal;
4552 for (
unsigned I = 0, N =
Record.size(); I != N; ++I) {
4553 unsigned Idx = N - I - 1;
4565 class ObjCCategoriesVisitor {
4568 llvm::SmallPtrSetImpl<ObjCCategoryDecl *> &Deserialized;
4569 ObjCCategoryDecl *Tail =
nullptr;
4570 llvm::DenseMap<DeclarationName, ObjCCategoryDecl *> NameCategoryMap;
4571 GlobalDeclID InterfaceID;
4572 unsigned PreviousGeneration;
4574 void add(ObjCCategoryDecl *Cat) {
4576 if (!Deserialized.erase(Cat))
4581 ObjCCategoryDecl *&Existing = NameCategoryMap[Cat->
getDeclName()];
4585 StructuralEquivalenceContext Ctx(
4588 StructuralEquivalenceKind::Default,
4592 if (!Ctx.IsEquivalent(Cat, Existing)) {
4597 diag::note_previous_definition);
4599 }
else if (!Existing) {
4614 ObjCCategoriesVisitor(
4615 ASTReader &Reader, ObjCInterfaceDecl *
Interface,
4616 llvm::SmallPtrSetImpl<ObjCCategoryDecl *> &Deserialized,
4617 GlobalDeclID InterfaceID,
unsigned PreviousGeneration)
4619 InterfaceID(InterfaceID), PreviousGeneration(PreviousGeneration) {
4621 for (
auto *Cat :
Interface->known_categories()) {
4622 if (Cat->getDeclName())
4623 NameCategoryMap[Cat->getDeclName()] = Cat;
4630 bool operator()(ModuleFile &M) {
4639 LocalDeclID LocalID =
4646 const ObjCCategoriesInfo
Compare = {LocalID, 0};
4647 const ObjCCategoriesInfo *
Result = std::lower_bound(
4651 LocalID !=
Result->getDefinitionID()) {
4659 unsigned Offset =
Result->Offset;
4662 for (
unsigned I = 0; I != N; ++I)
4671 unsigned PreviousGeneration) {
4672 ObjCCategoriesVisitor Visitor(*
this, D, CategoriesDeserialized, ID,
4673 PreviousGeneration);
4674 ModuleMgr.visit(Visitor);
4677template<
typename DeclT,
typename Fn>
4686 for (
auto *Redecl = MostRecent; Redecl && !
Found;
4687 Redecl = Redecl->getPreviousDecl())
4688 Found = (Redecl == D);
4692 for (
auto *Redecl = MostRecent; Redecl != D;
4699 while (Record.getIdx() < Record.size()) {
4703 Decl *MD = Record.readDecl();
4704 assert(MD &&
"couldn't read decl from update record");
4705 Reader.PendingAddedClassMembers.push_back({RD, MD});
4710 auto *Anon = readDeclAs<NamespaceDecl>();
4715 if (!Record.isModule()) {
4716 if (
auto *TU = dyn_cast<TranslationUnitDecl>(D))
4717 TU->setAnonymousNamespace(Anon);
4726 VD->NonParmVarDeclBits.IsInline = Record.readInt();
4727 VD->NonParmVarDeclBits.IsInlineSpecified = Record.readInt();
4734 if (
auto *VTSD = dyn_cast<VarTemplateSpecializationDecl>(D)) {
4735 VTSD->setPointOfInstantiation(POI);
4736 }
else if (
auto *VD = dyn_cast<VarDecl>(D)) {
4738 assert(MSInfo &&
"No member specialization information");
4742 if (
auto *FTSInfo = dyn_cast<FunctionTemplateSpecializationInfo *>(
4743 FD->TemplateOrSpecialization))
4744 FTSInfo->setPointOfInstantiation(POI);
4747 ->setPointOfInstantiation(POI);
4758 auto *DefaultArg = Record.readExpr();
4762 if (Param->hasUninstantiatedDefaultArg())
4763 Param->setDefaultArg(DefaultArg);
4769 auto *DefaultInit = Record.readExpr();
4773 if (FD->hasInClassInitializer() && !FD->hasNonNullInClassInitializer()) {
4775 FD->setInClassInitializer(DefaultInit);
4779 FD->removeInClassInitializer();
4786 if (Reader.PendingBodies[FD]) {
4792 if (Record.readInt()) {
4800 FD->setInnerLocStart(readSourceLocation());
4802 assert(Record.getIdx() == Record.size() &&
"lazy body must be last");
4809 bool HadRealDefinition =
4810 OldDD && (OldDD->Definition != RD ||
4811 !Reader.PendingFakeDefinitionData.count(OldDD));
4815 ReadCXXRecordDefinition(RD,
true);
4818 uint64_t LexicalOffset = ReadLocalOffset();
4819 if (!HadRealDefinition && LexicalOffset) {
4820 Record.readLexicalDeclContextStorage(LexicalOffset, RD);
4821 Reader.PendingFakeDefinitionData.erase(OldDD);
4828 MSInfo->setTemplateSpecializationKind(TSK);
4829 MSInfo->setPointOfInstantiation(POI);
4832 Spec->setTemplateSpecializationKind(TSK);
4833 Spec->setPointOfInstantiation(POI);
4835 if (Record.readInt()) {
4837 readDeclAs<ClassTemplatePartialSpecializationDecl>();
4839 Record.readTemplateArgumentList(TemplArgs);
4841 Reader.getContext(), TemplArgs);
4846 Spec->getSpecializedTemplateOrPartial()))
4847 Spec->setInstantiationOf(PartialSpec, TemplArgList);
4856 if (Record.readInt()) {
4858 Record.readAttributes(Attrs);
4862 D->setAttrsImpl(Attrs, Reader.getContext());
4872 auto *Del = readDeclAs<FunctionDecl>();
4873 auto *ThisArg = Record.readExpr();
4876 if (!
C.dtorHasOperatorDelete(Dtor,
4878 C.addOperatorDeleteForVDtor(Dtor, Del,
4880 Canon->OperatorDeleteThisArg = ThisArg;
4886 auto *Del = readDeclAs<FunctionDecl>();
4889 if (!
C.dtorHasOperatorDelete(
4891 C.addOperatorDeleteForVDtor(
4896 auto *Del = readDeclAs<FunctionDecl>();
4900 C.addOperatorDeleteForVDtor(Dtor, Del,
4905 auto *Del = readDeclAs<FunctionDecl>();
4908 if (!
C.dtorHasOperatorDelete(Dtor,
4910 C.addOperatorDeleteForVDtor(
4917 auto ESI = Record.readExceptionSpecInfo(ExceptionStorage);
4925 FD->setType(Reader.getContext().getFunctionType(
4926 FPT->getReturnType(), FPT->getParamTypes(),
4927 FPT->getExtProtoInfo().withExceptionSpec(ESI)));
4931 Reader.PendingExceptionSpecUpdates.insert(
4932 std::make_pair(FD->getCanonicalDecl(), FD));
4939 QualType DeducedResultType = Record.readType();
4940 Reader.PendingDeducedTypeUpdates.insert(
4941 {FD->getCanonicalDecl(), DeducedResultType});
4961 D->
addAttr(OMPThreadPrivateDeclAttr::CreateImplicit(Reader.getContext(),
4962 readSourceRange()));
4966 auto AllocatorKind =
4967 static_cast<OMPAllocateDeclAttr::AllocatorTypeTy
>(Record.readInt());
4968 Expr *Allocator = Record.readExpr();
4969 Expr *Alignment = Record.readExpr();
4971 D->
addAttr(OMPAllocateDeclAttr::CreateImplicit(
4972 Reader.getContext(), AllocatorKind, Allocator, Alignment, SR));
4980 Reader.getContext().mergeDefinitionIntoModule(Exported, Owner);
4981 Reader.PendingMergedDefinitionsToDeduplicate.insert(Exported);
4986 auto MapType = Record.readEnum<OMPDeclareTargetDeclAttr::MapTypeTy>();
4987 auto DevType = Record.readEnum<OMPDeclareTargetDeclAttr::DevTypeTy>();
4988 Expr *IndirectE = Record.readExpr();
4989 bool Indirect = Record.readBool();
4990 unsigned Level = Record.readInt();
4991 D->
addAttr(OMPDeclareTargetDeclAttr::CreateImplicit(
4992 Reader.getContext(), MapType, DevType, IndirectE, Indirect, Level,
4993 readSourceRange()));
4999 Record.readAttributes(Attrs);
5000 assert(Attrs.size() == 1);
This file provides AST data structures related to concepts.
Defines the clang::ASTContext interface.
static T assert_cast(T t)
"Cast" to type T, asserting if we don't have an implicit conversion.
static bool allowODRLikeMergeInC(NamedDecl *ND)
ODR-like semantics for C/ObjC allow us to merge tag types and a structural check in Sema guarantees t...
static NamedDecl * getDeclForMerging(NamedDecl *Found, bool IsTypedefNameForLinkage)
Find the declaration that should be merged into, given the declaration found by name lookup.
static bool inheritDefaultTemplateArgument(ASTContext &Context, ParmDecl *From, Decl *ToD)
Inherit the default template argument from From to To.
static void inheritDefaultTemplateArguments(ASTContext &Context, TemplateDecl *From, TemplateDecl *To)
static void forAllLaterRedecls(DeclT *D, Fn F)
static llvm::iterator_range< MergedRedeclIterator< DeclT > > merged_redecls(DeclT *D)
Defines the clang::attr::Kind enum.
clang::CharUnits operator*(clang::CharUnits::QuantityType Scale, const clang::CharUnits &CU)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
This file defines OpenMP nodes for declarative directives.
Defines the C++ template declaration subclasses.
Defines the ExceptionSpecificationType enumeration and various utility functions.
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 several types used to describe C++ lambda expressions that are shared between the parser and ...
Defines the clang::LangOptions interface.
llvm::MachO::Record Record
Defines the clang::Module class, which describes a module in the source code.
This file defines OpenMP AST classes for clauses.
static std::string toString(const clang::SanitizerSet &Sanitizers)
Produce a string containing comma-separated names of sanitizers in Sanitizers set.
Defines the clang::SourceLocation class and associated facilities.
Defines various enumerations that describe declaration and type specifiers.
C Language Family Type Representation.
__DEVICE__ void * memcpy(void *__a, const void *__b, size_t __c)
bool needsCleanup() const
Returns whether the object performed allocations.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
TranslationUnitDecl * getTranslationUnitDecl() const
const LangOptions & getLangOpts() 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.
void mergeTemplatePattern(RedeclarableTemplateDecl *D, RedeclarableTemplateDecl *Existing, bool IsKeyDecl)
Merge together the pattern declarations from two template declarations.
ASTDeclMerger(ASTReader &Reader)
void mergeRedeclarable(Redeclarable< T > *D, T *Existing, RedeclarableResult &Redecl)
void mergeLambda(CXXRecordDecl *D, RedeclarableResult &Redecl, Decl &Context, unsigned Number)
Attempt to merge D with a previous declaration of the same lambda, which is found by its index within...
void MergeDefinitionData(CXXRecordDecl *D, struct CXXRecordDecl::DefinitionData &&NewDD)
void mergeRedeclarableImpl(Redeclarable< T > *D, T *Existing, GlobalDeclID KeyDeclID)
Attempts to merge the given declaration (D) with another declaration of the same entity.
void VisitTemplateParamObjectDecl(TemplateParamObjectDecl *D)
void VisitObjCImplementationDecl(ObjCImplementationDecl *D)
void mergeRedeclarableTemplate(RedeclarableTemplateDecl *D, RedeclarableResult &Redecl)
void VisitImportDecl(ImportDecl *D)
void VisitBindingDecl(BindingDecl *BD)
void VisitNamespaceDecl(NamespaceDecl *D)
void VisitTopLevelStmtDecl(TopLevelStmtDecl *D)
RedeclarableResult VisitRedeclarableTemplateDecl(RedeclarableTemplateDecl *D)
void VisitTemplateTypeParmDecl(TemplateTypeParmDecl *D)
void VisitUnresolvedUsingIfExistsDecl(UnresolvedUsingIfExistsDecl *D)
void ReadFunctionDefinition(FunctionDecl *FD)
void VisitLabelDecl(LabelDecl *LD)
void VisitObjCCategoryDecl(ObjCCategoryDecl *D)
void VisitUsingDirectiveDecl(UsingDirectiveDecl *D)
RedeclarableResult VisitClassTemplateSpecializationDeclImpl(ClassTemplateSpecializationDecl *D)
void VisitFunctionDecl(FunctionDecl *FD)
void VisitObjCMethodDecl(ObjCMethodDecl *D)
void VisitUsingShadowDecl(UsingShadowDecl *D)
void VisitVarTemplateSpecializationDecl(VarTemplateSpecializationDecl *D)
void VisitVarDecl(VarDecl *VD)
RedeclarableResult VisitRedeclarable(Redeclarable< T > *D)
void VisitDeclContext(DeclContext *DC, LookupBlockOffsets &Offsets)
void VisitMSGuidDecl(MSGuidDecl *D)
void VisitPragmaCommentDecl(PragmaCommentDecl *D)
void VisitRecordDecl(RecordDecl *RD)
void VisitLifetimeExtendedTemporaryDecl(LifetimeExtendedTemporaryDecl *D)
void VisitTypeAliasTemplateDecl(TypeAliasTemplateDecl *D)
void VisitRequiresExprBodyDecl(RequiresExprBodyDecl *D)
void ReadVarDeclInit(VarDecl *VD)
static Decl * getMostRecentDeclImpl(Redeclarable< DeclT > *D)
void VisitNamespaceAliasDecl(NamespaceAliasDecl *D)
void VisitIndirectFieldDecl(IndirectFieldDecl *FD)
void VisitObjCContainerDecl(ObjCContainerDecl *D)
void VisitBlockDecl(BlockDecl *BD)
void VisitOpenACCRoutineDecl(OpenACCRoutineDecl *D)
void VisitExportDecl(ExportDecl *D)
static void attachLatestDecl(Decl *D, Decl *latest)
void VisitStaticAssertDecl(StaticAssertDecl *D)
void VisitEmptyDecl(EmptyDecl *D)
void VisitOMPCapturedExprDecl(OMPCapturedExprDecl *D)
void VisitValueDecl(ValueDecl *VD)
void VisitEnumDecl(EnumDecl *ED)
void mergeRedeclarable(Redeclarable< T > *D, RedeclarableResult &Redecl)
Attempts to merge the given declaration (D) with another declaration of the same entity.
void VisitUnresolvedUsingTypenameDecl(UnresolvedUsingTypenameDecl *D)
void VisitFriendTemplateDecl(FriendTemplateDecl *D)
void VisitObjCProtocolDecl(ObjCProtocolDecl *D)
void VisitClassTemplatePartialSpecializationDecl(ClassTemplatePartialSpecializationDecl *D)
void VisitObjCTypeParamDecl(ObjCTypeParamDecl *D)
void VisitDeclaratorDecl(DeclaratorDecl *DD)
RedeclarableResult VisitTypedefNameDecl(TypedefNameDecl *TD)
void VisitFriendDecl(FriendDecl *D)
void VisitLinkageSpecDecl(LinkageSpecDecl *D)
void VisitCXXRecordDecl(CXXRecordDecl *D)
ASTDeclReader(ASTReader &Reader, ASTRecordReader &Record, ASTReader::RecordLocation Loc, GlobalDeclID thisDeclID, SourceLocation ThisDeclLoc)
void VisitFileScopeAsmDecl(FileScopeAsmDecl *AD)
void VisitImplicitConceptSpecializationDecl(ImplicitConceptSpecializationDecl *D)
void VisitNamedDecl(NamedDecl *ND)
void mergeMergeable(Mergeable< T > *D)
Attempts to merge the given declaration (D) with another declaration of the same entity,...
void VisitBuiltinTemplateDecl(BuiltinTemplateDecl *D)
static Decl * getMostRecentDecl(Decl *D)
void VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *D)
void VisitCXXConstructorDecl(CXXConstructorDecl *D)
void VisitPragmaDetectMismatchDecl(PragmaDetectMismatchDecl *D)
void VisitImplicitParamDecl(ImplicitParamDecl *PD)
void VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D)
static void setNextObjCCategory(ObjCCategoryDecl *Cat, ObjCCategoryDecl *Next)
void VisitMSPropertyDecl(MSPropertyDecl *FD)
void VisitClassTemplateSpecializationDecl(ClassTemplateSpecializationDecl *D)
void VisitFieldDecl(FieldDecl *FD)
RedeclarableResult VisitVarDeclImpl(VarDecl *D)
void VisitOMPDeclareMapperDecl(OMPDeclareMapperDecl *D)
void VisitCapturedDecl(CapturedDecl *CD)
void VisitNonTypeTemplateParmDecl(NonTypeTemplateParmDecl *D)
void VisitObjCInterfaceDecl(ObjCInterfaceDecl *D)
RedeclarableResult VisitCXXRecordDeclImpl(CXXRecordDecl *D)
void VisitAccessSpecDecl(AccessSpecDecl *D)
void VisitCXXMethodDecl(CXXMethodDecl *D)
void VisitOpenACCDeclareDecl(OpenACCDeclareDecl *D)
void VisitOMPAllocateDecl(OMPAllocateDecl *D)
void VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D)
static void attachLatestDeclImpl(Redeclarable< DeclT > *D, Decl *Latest)
static void markIncompleteDeclChainImpl(Redeclarable< DeclT > *D)
RedeclarableResult VisitTagDecl(TagDecl *TD)
ObjCTypeParamList * ReadObjCTypeParamList()
void VisitHLSLBufferDecl(HLSLBufferDecl *D)
void VisitOMPThreadPrivateDecl(OMPThreadPrivateDecl *D)
void VisitCXXDeductionGuideDecl(CXXDeductionGuideDecl *GD)
void VisitConstructorUsingShadowDecl(ConstructorUsingShadowDecl *D)
void VisitTemplateTemplateParmDecl(TemplateTemplateParmDecl *D)
static void checkMultipleDefinitionInNamedModules(ASTReader &Reader, Decl *D, Decl *Previous)
void VisitUsingEnumDecl(UsingEnumDecl *D)
void VisitObjCImplDecl(ObjCImplDecl *D)
void VisitTranslationUnitDecl(TranslationUnitDecl *TU)
void VisitUnnamedGlobalConstantDecl(UnnamedGlobalConstantDecl *D)
void VisitTypeDecl(TypeDecl *TD)
void VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D)
void VisitEnumConstantDecl(EnumConstantDecl *ECD)
void VisitTypeAliasDecl(TypeAliasDecl *TD)
static void attachPreviousDeclImpl(ASTReader &Reader, Redeclarable< DeclT > *D, Decl *Previous, Decl *Canon)
void VisitConceptDecl(ConceptDecl *D)
void VisitObjCPropertyDecl(ObjCPropertyDecl *D)
void VisitOutlinedFunctionDecl(OutlinedFunctionDecl *D)
void VisitObjCIvarDecl(ObjCIvarDecl *D)
void VisitUsingPackDecl(UsingPackDecl *D)
void VisitFunctionTemplateDecl(FunctionTemplateDecl *D)
void VisitOMPDeclareReductionDecl(OMPDeclareReductionDecl *D)
RedeclarableResult VisitVarTemplateSpecializationDeclImpl(VarTemplateSpecializationDecl *D)
TODO: Unify with ClassTemplateSpecializationDecl version?
void VisitUsingDecl(UsingDecl *D)
void VisitObjCAtDefsFieldDecl(ObjCAtDefsFieldDecl *D)
void VisitVarTemplatePartialSpecializationDecl(VarTemplatePartialSpecializationDecl *D)
TODO: Unify with ClassTemplatePartialSpecializationDecl version?
void VisitParmVarDecl(ParmVarDecl *PD)
void VisitVarTemplateDecl(VarTemplateDecl *D)
TODO: Unify with ClassTemplateDecl version?
static void attachPreviousDecl(ASTReader &Reader, Decl *D, Decl *Previous, Decl *Canon)
void VisitClassTemplateDecl(ClassTemplateDecl *D)
void VisitCXXDestructorDecl(CXXDestructorDecl *D)
void VisitTemplateDecl(TemplateDecl *D)
void VisitCXXConversionDecl(CXXConversionDecl *D)
void VisitTypedefDecl(TypedefDecl *TD)
void VisitOMPRequiresDecl(OMPRequiresDecl *D)
RedeclarableResult VisitRecordDeclImpl(RecordDecl *RD)
void VisitDecompositionDecl(DecompositionDecl *DD)
void ReadSpecializations(ModuleFile &M, Decl *D, llvm::BitstreamCursor &DeclsCursor, bool IsPartial)
Reads an AST files chain containing the contents of a translation unit.
bool isDeclIDFromModule(GlobalDeclID ID, ModuleFile &M) const
Returns true if global DeclID ID originated from module M.
DiagnosticBuilder Diag(unsigned DiagID) const
Report a diagnostic.
ASTContext & getContext()
Retrieve the AST context that this AST reader supplements.
Decl * ReadDecl(ModuleFile &F, const RecordDataImpl &R, unsigned &I)
Reads a declaration from the given position in a record in the given module.
ModuleFile * getOwningModuleFile(const Decl *D) const
Retrieve the module file that owns the given declaration, or NULL if the declaration is not from a mo...
T * ReadDeclAs(ModuleFile &F, const RecordDataImpl &R, unsigned &I)
Reads a declaration from the given position in a record in the given module.
LocalDeclID mapGlobalIDToModuleFileGlobalID(ModuleFile &M, GlobalDeclID GlobalID)
Map a global declaration ID into the declaration ID used to refer to this declaration within the give...
friend class ASTDeclReader
Decl * GetDecl(GlobalDeclID ID)
Resolve a declaration ID into a declaration, potentially building a new declaration.
SourceLocation ReadSourceLocation(ModuleFile &MF, RawLocEncoding Raw) const
Read a source location from raw form.
void runWithSufficientStackSpace(SourceLocation Loc, llvm::function_ref< void()> Fn)
friend class ASTRecordReader
SmallVector< uint64_t, 64 > RecordData
serialization::ModuleFile ModuleFile
An object for streaming information from a record.
bool readBool()
Read a boolean value, advancing Idx.
std::string readString()
Read a string, advancing Idx.
SourceRange readSourceRange()
Read a source range, advancing Idx.
SourceLocation readSourceLocation()
Read a source location, advancing Idx.
void readAttributes(AttrVec &Attrs)
Reads attributes from the current stream position, advancing Idx.
T * readDeclAs()
Reads a declaration from the given position in the record, advancing Idx.
IdentifierInfo * readIdentifier()
ASTContext & getContext()
Retrieve the AST context that this AST reader supplements.
TypeSourceInfo * readTypeSourceInfo()
Reads a declarator info from the given record, advancing Idx.
OMPTraitInfo * readOMPTraitInfo()
Read an OMPTraitInfo object, advancing Idx.
VersionTuple readVersionTuple()
Read a version tuple, advancing Idx.
uint64_t readInt()
Returns the current value in this record, and advances to the next value.
Attr * readAttr()
Reads one attribute from the current stream position, advancing Idx.
Expr * readExpr()
Reads an expression.
Represents an access specifier followed by colon ':'.
static AccessSpecDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setColonLoc(SourceLocation CLoc)
Sets the location of the colon.
Attr - This represents one attribute.
Attr * clone(ASTContext &C) const
Syntax
The style used to specify an attribute.
@ AS_Keyword
__ptr16, alignas(...), etc.
A binding in a decomposition declaration.
static BindingDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
A simple helper class to unpack an integer to bits and consuming the bits in order.
uint32_t getNextBits(uint32_t Width)
A class which contains all the information about a particular captured value.
Represents a block literal declaration, which is like an unnamed FunctionDecl.
void setParams(ArrayRef< ParmVarDecl * > NewParamInfo)
void setDoesNotEscape(bool B=true)
void setSignatureAsWritten(TypeSourceInfo *Sig)
void setCanAvoidCopyToHeap(bool B=true)
void setIsConversionFromLambda(bool val=true)
void setBlockMissingReturnType(bool val=true)
static BlockDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setIsVariadic(bool value)
void setBody(CompoundStmt *B)
void setCaptures(ASTContext &Context, ArrayRef< Capture > Captures, bool CapturesCXXThis)
Represents the builtin template declaration which is used to implement __make_integer_seq and other b...
Represents a C++ constructor within a class.
static CXXConstructorDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, uint64_t AllocKind)
void setExplicitSpecifier(ExplicitSpecifier ES)
bool isInheritingConstructor() const
Determine whether this is an implicit constructor synthesized to model a call to a constructor inheri...
Represents a C++ conversion function within a class.
void setExplicitSpecifier(ExplicitSpecifier ES)
static CXXConversionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a C++ deduction guide declaration.
void setDeductionCandidateKind(DeductionCandidate K)
void setSourceDeductionGuide(CXXDeductionGuideDecl *DG)
static CXXDeductionGuideDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setSourceDeductionGuideKind(SourceDeductionGuideKind SK)
Represents a C++ destructor within a class.
static CXXDestructorDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
CXXDestructorDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
Represents a static or instance method of a struct/union/class.
static CXXMethodDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
CXXMethodDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
Represents a C++ struct/union/class.
CXXRecordDecl * getDefinition() const
static CXXRecordDecl * CreateDeserialized(const ASTContext &C, GlobalDeclID ID)
unsigned getODRHash() const
MemberSpecializationInfo * getMemberSpecializationInfo() const
If this class is an instantiation of a member class of a class template specialization,...
CXXRecordDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
Represents the body of a CapturedStmt, and serves as its DeclContext.
static CapturedDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumParams)
void setContextParam(unsigned i, ImplicitParamDecl *P)
void setNothrow(bool Nothrow=true)
void setParam(unsigned i, ImplicitParamDecl *P)
Declaration of a class template.
static ClassTemplateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Create an empty class template node.
static ClassTemplatePartialSpecializationDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a class template specialization, which refers to a class template with a given set of temp...
static ClassTemplateSpecializationDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setTemplateArgsAsWritten(const ASTTemplateArgumentListInfo *ArgsWritten)
Set the template argument list as written in the sources.
Declaration of a C++20 concept.
static ConceptDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
A reference to a concept and its template args, as it appears in the code.
Represents a shadow constructor declaration introduced into a class by a C++11 using-declaration that...
static ConstructorUsingShadowDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
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...
lookup_result::iterator lookup_iterator
bool isFileContext() const
void setHasExternalVisibleStorage(bool ES=true) const
State whether this DeclContext has external storage for declarations visible in this context.
DeclContextLookupResult lookup_result
lookup_result lookup(DeclarationName Name) const
lookup - Find the declarations (if any) with the given Name in this context.
bool isTranslationUnit() const
DeclContext * getRedeclContext()
getRedeclContext - Retrieve the context in which an entity conflicts with other entities of the same ...
DeclContext * getPrimaryContext()
getPrimaryContext - There may be many different declarations of the same entity (including forward de...
bool isFunctionOrMethod() const
DeclContext * getNonTransparentContext()
DeclID getRawValue() const
A simple visitor class that helps create declaration visitors.
Decl - This represents one declaration (or definition), e.g.
Decl * getPreviousDecl()
Retrieve the previous declaration that declares the same entity as this declaration,...
Decl * getMostRecentDecl()
Retrieve the most recent declaration that declares the same entity as this declaration (which may be ...
FriendObjectKind getFriendObjectKind() const
Determines whether this declaration is the object of a friend declaration and, if so,...
ASTContext & getASTContext() const LLVM_READONLY
void setOwningModuleID(unsigned ID)
Set the owning module ID.
void setLocalExternDecl()
Changes the namespace of this declaration to reflect that it's a function-local extern declaration.
void setTopLevelDeclInObjCContainer(bool V=true)
void markUsed(ASTContext &C)
Mark the declaration used, in the sense of odr-use.
bool isCanonicalDecl() const
Whether this particular Decl is a canonical one.
Module * getOwningModule() const
Get the module that owns this declaration (for visibility purposes).
Module * getImportedOwningModule() const
Get the imported owning module, if this decl is from an imported (non-local) module.
ObjCDeclQualifier
ObjCDeclQualifier - 'Qualifiers' written next to the return and parameter types in method declaration...
bool isFromASTFile() const
Determine whether this declaration came from an AST file (such as a precompiled header or module) rat...
bool isTemplateParameter() const
isTemplateParameter - Determines whether this declaration is a template parameter.
bool isInvalidDecl() const
unsigned FromASTFile
Whether this declaration was loaded from an AST file.
void setAccess(AccessSpecifier AS)
SourceLocation getLocation() const
IdentifierNamespace
IdentifierNamespace - The different namespaces in which declarations may appear.
@ IDNS_Ordinary
Ordinary names.
@ IDNS_Type
Types, declared with 'struct foo', typedefs, etc.
@ IDNS_Tag
Tags, declared with 'struct foo;' and referenced with 'struct foo'.
bool isTemplateParameterPack() const
isTemplateParameter - Determines whether this declaration is a template parameter pack.
void setImplicit(bool I=true)
void setReferenced(bool R=true)
void setLocation(SourceLocation L)
DeclContext * getDeclContext()
void setCachedLinkage(Linkage L) const
void setDeclContext(DeclContext *DC)
setDeclContext - Set both the semantic and lexical DeclContext to DC.
DeclContext * getLexicalDeclContext()
getLexicalDeclContext - The declaration context where this Decl was lexically declared (LexicalDC).
virtual Decl * getCanonicalDecl()
Retrieves the "canonical" declaration of the given declaration.
ModuleOwnershipKind
The kind of ownership a declaration has, for visibility purposes.
@ VisibleWhenImported
This declaration has an owning module, and is visible when that module is imported.
@ Unowned
This declaration is not owned by a module.
@ ReachableWhenImported
This declaration has an owning module, and is visible to lookups that occurs within that module.
@ ModulePrivate
This declaration has an owning module, but is only visible to lookups that occur within that module.
@ Visible
This declaration has an owning module, but is globally visible (typically because its owning module i...
void setModuleOwnershipKind(ModuleOwnershipKind MOK)
Set whether this declaration is hidden from name lookup.
bool shouldEmitInExternalSource() const
Whether the definition of the declaration should be emitted in external sources.
void setVisibleDespiteOwningModule()
Set that this declaration is globally visible, even if it came from a module that is not visible.
The name of a declaration.
IdentifierInfo * getAsIdentifierInfo() const
Retrieve the IdentifierInfo * stored in this declaration name, or null if this declaration name isn't...
Selector getObjCSelector() const
Get the Objective-C selector stored in this declaration name.
Represents a ValueDecl that came out of a declarator.
void setInnerLocStart(SourceLocation L)
void setTypeSourceInfo(TypeSourceInfo *TI)
TypeSourceInfo * getTypeSourceInfo() const
A decomposition declaration.
static DecompositionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumBindings)
Represents an empty-declaration.
static EmptyDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
An instance of this object exists for each enum constant that is defined.
static EnumConstantDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setInitExpr(Expr *E)
void setInitVal(const ASTContext &C, const llvm::APSInt &V)
MemberSpecializationInfo * getMemberSpecializationInfo() const
If this enumeration is an instantiation of a member enumeration of a class template specialization,...
void setFixed(bool Fixed=true)
True if this is an Objective-C, C++11, or Microsoft-style enumeration with a fixed underlying type.
void setIntegerType(QualType T)
Set the underlying integer type.
void setIntegerTypeSourceInfo(TypeSourceInfo *TInfo)
Set the underlying integer type source info.
static EnumDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setScoped(bool Scoped=true)
True if this tag declaration is a scoped enumeration.
void setPromotionType(QualType T)
Set the promotion type.
EnumDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
void setScopedUsingClassTag(bool ScopedUCT=true)
If this tag declaration is a scoped enum, then this is true if the scoped enum was declared using the...
Represents a standard C++ module export declaration.
static ExportDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
This represents one expression.
RAII class for safely pairing a StartedDeserializing call with FinishedDeserializing.
Represents a member of a struct/union/class.
void setBitWidth(Expr *Width)
Set the bit-field width for this member.
static FieldDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
const VariableArrayType * CapturedVLAType
void setRParenLoc(SourceLocation L)
void setAsmString(Expr *Asm)
static FileScopeAsmDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
FriendDecl - Represents the declaration of a friend entity, which can be a function,...
static FriendDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned FriendTypeNumTPLists)
Declaration of a friend template.
static FriendTemplateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
static DefaultedOrDeletedFunctionInfo * Create(ASTContext &Context, ArrayRef< DeclAccessPair > Lookups, StringLiteral *DeletedMessage=nullptr)
Represents a function declaration or definition.
void setDescribedFunctionTemplate(FunctionTemplateDecl *Template)
FunctionTemplateDecl * getDescribedFunctionTemplate() const
Retrieves the function template that is described by this function declaration.
void setIsPureVirtual(bool P=true)
void setDefaultedOrDeletedInfo(DefaultedOrDeletedFunctionInfo *Info)
void setFriendConstraintRefersToEnclosingTemplate(bool V=true)
void setHasSkippedBody(bool Skipped=true)
static FunctionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setUsesSEHTry(bool UST)
void setIsMultiVersion(bool V=true)
Sets the multiversion state for this declaration and all of its redeclarations.
void setHasWrittenPrototype(bool P=true)
State that this function has a written prototype.
bool isExplicitlyDefaulted() const
Whether this function is explicitly defaulted.
MemberSpecializationInfo * getMemberSpecializationInfo() const
If this function is an instantiation of a member function of a class template specialization,...
FunctionTemplateSpecializationInfo * getTemplateSpecializationInfo() const
If this function is actually a function template specialization, retrieve information about this func...
void setDefaultLoc(SourceLocation NewLoc)
void setInstantiatedFromMemberTemplate(bool Val=true)
void setInlineSpecified(bool I)
Set whether the "inline" keyword was specified for this function.
TemplatedKind
The kind of templated function a FunctionDecl can be.
@ TK_MemberSpecialization
@ TK_DependentNonTemplate
@ TK_FunctionTemplateSpecialization
@ TK_DependentFunctionTemplateSpecialization
TemplatedKind getTemplatedKind() const
What kind of templated function this is.
void setInstantiatedFromDecl(FunctionDecl *FD)
Specify that this function declaration was instantiated from a FunctionDecl FD.
bool isDeletedAsWritten() const
void setHasInheritedPrototype(bool P=true)
State that this function inherited its prototype from a previous declaration.
void setDependentTemplateSpecialization(ASTContext &Context, const UnresolvedSetImpl &Templates, const TemplateArgumentListInfo *TemplateArgs)
Specifies that this function declaration is actually a dependent function template specialization.
void setVirtualAsWritten(bool V)
State that this function is marked as virtual explicitly.
void setIsDestroyingOperatorDelete(bool IsDestroyingDelete)
void setLateTemplateParsed(bool ILT=true)
State that this templated function will be late parsed.
void setImplicitlyInline(bool I=true)
Flag that this function is implicitly inline.
void setTrivialForCall(bool IT)
void setIsTypeAwareOperatorNewOrDelete(bool IsTypeAwareOperator=true)
bool isDefaulted() const
Whether this function is defaulted.
void setIneligibleOrNotSelected(bool II)
void setConstexprKind(ConstexprSpecKind CSK)
void setDefaulted(bool D=true)
void setStorageClass(StorageClass SClass)
Sets the storage class as written in the source.
void setDeletedAsWritten(bool D=true, StringLiteral *Message=nullptr)
void setExplicitlyDefaulted(bool ED=true)
State that this function is explicitly defaulted.
void setHasImplicitReturnZero(bool IRZ)
State that falling off this function implicitly returns null/zero.
Represents a prototype with parameter type info, e.g.
ExceptionSpecificationType getExceptionSpecType() const
Get the kind of exception specification on this function.
Declaration of a template function.
static FunctionTemplateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Create an empty function template node.
Provides information about a function template specialization, which is a FunctionDecl that has been ...
FunctionTemplateDecl * getTemplate() const
Retrieve the template from which this function was specialized.
static FunctionTemplateSpecializationInfo * Create(ASTContext &C, FunctionDecl *FD, FunctionTemplateDecl *Template, TemplateSpecializationKind TSK, TemplateArgumentList *TemplateArgs, const TemplateArgumentListInfo *TemplateArgsAsWritten, SourceLocation POI, MemberSpecializationInfo *MSInfo)
void Profile(llvm::FoldingSetNodeID &ID)
FunctionDecl * getFunction() const
Retrieve the declaration of the function template specialization.
FunctionType - C99 6.7.5.3 - Function Declarators.
QualType getReturnType() const
HLSLBufferDecl - Represent a cbuffer or tbuffer declaration.
static HLSLBufferDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
One of these records is kept for each identifier that is lexed.
void setOutOfDate(bool OOD)
Set whether the information for this identifier is out of date with respect to the external source.
bool isOutOfDate() const
Determine whether the information for this identifier is out of date with respect to the external sou...
iterator begin(DeclarationName Name)
Returns an iterator over decls with the name 'Name'.
iterator end()
Returns the end iterator.
void setTemplateArguments(ArrayRef< TemplateArgument > Converted)
static ImplicitConceptSpecializationDecl * CreateDeserialized(const ASTContext &C, GlobalDeclID ID, unsigned NumTemplateArgs)
static ImplicitParamDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Describes a module import declaration, which makes the contents of the named module visible in the cu...
static ImportDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumLocations)
Create a new, deserialized module import declaration.
Represents a field injected from an anonymous union/struct into the parent scope.
static IndirectFieldDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setInherited(bool I)
Description of a constructor that was inherited from a base class.
Represents the declaration of a label.
void setLocStart(SourceLocation L)
static LabelDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Describes the capture of a variable or of this, or of a C++1y init-capture.
LambdaCaptureKind getCaptureKind() const
Determine the kind of capture.
Implicit declaration of a temporary that was materialized by a MaterializeTemporaryExpr and lifetime-...
unsigned getManglingNumber() const
static LifetimeExtendedTemporaryDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
ValueDecl * getExtendingDecl()
Represents a linkage specification.
void setExternLoc(SourceLocation L)
void setLanguage(LinkageSpecLanguageIDs L)
Set the language specified by this linkage specification.
void setRBraceLoc(SourceLocation L)
static LinkageSpecDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents the results of name lookup.
An instance of this class represents the declaration of a property member.
static MSPropertyDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Provides information a specialization of a member of a class template, which may be a member function...
void setPointOfInstantiation(SourceLocation POI)
Set the first point of instantiation.
Provides common interface for the Decls that cannot be redeclared, but can be merged if the same decl...
Describes a module or submodule.
@ AllVisible
All of the names in this module are visible.
std::string Name
The name of this module.
bool isGlobalModule() const
Does this Module scope describe a fragment of the global module within some C++ module.
@ ModuleMapModule
This is a module that was defined by a module map and built out of header files.
bool isNamedModule() const
Does this Module is a named module of a standard named module?
Module * getTopLevelModule()
Retrieve the top-level module for this (sub)module, which may be this module.
This represents a decl that may have a name.
IdentifierInfo * getIdentifier() const
Get the identifier that names this declaration, if there is one.
bool isPlaceholderVar(const LangOptions &LangOpts) const
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
void setDeclName(DeclarationName N)
Set the name of this declaration.
Represents a C++ namespace alias.
static NamespaceAliasDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represent a C++ namespace.
void setAnonymousNamespace(NamespaceDecl *D)
void setNested(bool Nested)
Set whether this is a nested namespace declaration.
void setInline(bool Inline)
Set whether this is an inline namespace declaration.
static NamespaceDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
NonTypeTemplateParmDecl - Declares a non-type template parameter, e.g., "Size" in.
static NonTypeTemplateParmDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, bool HasTypeConstraint)
unsigned getNumExpansionTypes() const
Retrieves the number of expansion types in an expanded parameter pack.
bool isExpandedParameterPack() const
Whether this parameter is a non-type template parameter pack that has a known list of different types...
void setPosition(unsigned P)
void setDepth(unsigned D)
bool hasPlaceholderTypeConstraint() const
Determine whether this non-type template parameter's type has a placeholder with a type-constraint.
void setPlaceholderTypeConstraint(Expr *E)
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.
static OMPAllocateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NVars, unsigned NClauses)
Pseudo declaration for capturing expressions.
static OMPCapturedExprDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
OMPChildren * Data
Data, associated with the directive.
This represents 'pragma omp declare mapper ...' directive.
static OMPDeclareMapperDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned N)
Creates deserialized declare mapper node.
This represents 'pragma omp declare reduction ...' directive.
void setInitializerData(Expr *OrigE, Expr *PrivE)
Set initializer Orig and Priv vars.
void setInitializer(Expr *E, OMPDeclareReductionInitKind IK)
Set initializer expression for the declare reduction construct.
void setCombiner(Expr *E)
Set combiner expression for the declare reduction construct.
void setCombinerData(Expr *InE, Expr *OutE)
Set combiner In and Out vars.
static OMPDeclareReductionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Create deserialized declare reduction node.
This represents 'pragma omp requires...' directive.
static OMPRequiresDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned N)
Create deserialized requires node.
This represents 'pragma omp threadprivate ...' directive.
static OMPThreadPrivateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned N)
Represents a field declaration created by an @defs(...).
static ObjCAtDefsFieldDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
ObjCCategoryDecl - Represents a category declaration.
void setProtocolList(ObjCProtocolDecl *const *List, unsigned Num, const SourceLocation *Locs, ASTContext &C)
setProtocolList - Set the list of protocols that this interface implements.
static ObjCCategoryDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setIvarLBraceLoc(SourceLocation Loc)
void setCategoryNameLoc(SourceLocation Loc)
void setIvarRBraceLoc(SourceLocation Loc)
bool IsClassExtension() const
ObjCCategoryImplDecl - An object of this class encapsulates a category @implementation declaration.
static ObjCCategoryImplDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
ObjCCompatibleAliasDecl - Represents alias of a class.
static ObjCCompatibleAliasDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setClassInterface(ObjCInterfaceDecl *D)
ObjCContainerDecl - Represents a container for method declarations.
void setAtStartLoc(SourceLocation Loc)
void setAtEndRange(SourceRange atEnd)
void setClassInterface(ObjCInterfaceDecl *IFace)
ObjCImplementationDecl - Represents a class definition - this is where method definitions are specifi...
static ObjCImplementationDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setIvarLBraceLoc(SourceLocation Loc)
void setSuperClass(ObjCInterfaceDecl *superCls)
void setIvarRBraceLoc(SourceLocation Loc)
void setHasDestructors(bool val)
void setHasNonZeroConstructors(bool val)
Represents an ObjC class declaration.
void mergeClassExtensionProtocolList(ObjCProtocolDecl *const *List, unsigned Num, ASTContext &C)
mergeClassExtensionProtocolList - Merge class extension's protocol list into the protocol list for th...
ObjCIvarDecl * lookupInstanceVariable(IdentifierInfo *IVarName, ObjCInterfaceDecl *&ClassDeclared)
unsigned getODRHash()
Get precomputed ODRHash or add a new one.
static ObjCInterfaceDecl * CreateDeserialized(const ASTContext &C, GlobalDeclID ID)
ObjCInterfaceDecl * getCanonicalDecl() override
Retrieves the canonical declaration of this Objective-C class.
ObjCIvarDecl - Represents an ObjC instance variable.
void setAccessControl(AccessControl ac)
void setNextIvar(ObjCIvarDecl *ivar)
ObjCInterfaceDecl * getContainingInterface()
Return the class interface that this ivar is logically contained in; this is either the interface whe...
void setSynthesize(bool synth)
static ObjCIvarDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
ObjCMethodDecl - Represents an instance or class method declaration.
void setSynthesizedAccessorStub(bool isSynthesizedAccessorStub)
void setObjCDeclQualifier(ObjCDeclQualifier QV)
void setDefined(bool isDefined)
void setSelfDecl(ImplicitParamDecl *SD)
void setReturnTypeSourceInfo(TypeSourceInfo *TInfo)
void setHasRedeclaration(bool HRD) const
void setIsRedeclaration(bool RD)
void setCmdDecl(ImplicitParamDecl *CD)
bool hasRedeclaration() const
True if redeclared in the same interface.
void setRelatedResultType(bool RRT=true)
Note whether this method has a related result type.
void setOverriding(bool IsOver)
void setPropertyAccessor(bool isAccessor)
void setDeclImplementation(ObjCImplementationControl ic)
void setReturnType(QualType T)
static ObjCMethodDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setHasSkippedBody(bool Skipped=true)
void setInstanceMethod(bool isInst)
void setVariadic(bool isVar)
Represents one property declaration in an Objective-C interface.
void setAtLoc(SourceLocation L)
void setPropertyImplementation(PropertyControl pc)
void setSetterName(Selector Sel, SourceLocation Loc=SourceLocation())
void setPropertyAttributes(ObjCPropertyAttribute::Kind PRVal)
static ObjCPropertyDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setPropertyAttributesAsWritten(ObjCPropertyAttribute::Kind PRVal)
void setLParenLoc(SourceLocation L)
void setPropertyIvarDecl(ObjCIvarDecl *Ivar)
void setSetterMethodDecl(ObjCMethodDecl *gDecl)
void setType(QualType T, TypeSourceInfo *TSI)
void setGetterName(Selector Sel, SourceLocation Loc=SourceLocation())
void setGetterMethodDecl(ObjCMethodDecl *gDecl)
ObjCPropertyImplDecl - Represents implementation declaration of a property in a class or category imp...
void setSetterMethodDecl(ObjCMethodDecl *MD)
void setSetterCXXAssignment(Expr *setterCXXAssignment)
static ObjCPropertyImplDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setGetterMethodDecl(ObjCMethodDecl *MD)
void setAtLoc(SourceLocation Loc)
void setPropertyDecl(ObjCPropertyDecl *Prop)
void setGetterCXXConstructor(Expr *getterCXXConstructor)
Represents an Objective-C protocol declaration.
static ObjCProtocolDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
ObjCProtocolDecl * getCanonicalDecl() override
Retrieves the canonical declaration of this Objective-C protocol.
unsigned getODRHash()
Get precomputed ODRHash or add a new one.
Represents the declaration of an Objective-C type parameter.
static ObjCTypeParamDecl * CreateDeserialized(ASTContext &ctx, GlobalDeclID ID)
Stores a list of Objective-C type parameters for a parameterized class or a category/extension thereo...
static ObjCTypeParamList * create(ASTContext &ctx, SourceLocation lAngleLoc, ArrayRef< ObjCTypeParamDecl * > typeParams, SourceLocation rAngleLoc)
Create a new Objective-C type parameter list.
static OpenACCDeclareDecl * CreateDeserialized(ASTContext &Ctx, GlobalDeclID ID, unsigned NumClauses)
static OpenACCRoutineDecl * CreateDeserialized(ASTContext &Ctx, GlobalDeclID ID, unsigned NumClauses)
Represents a partial function definition.
void setNothrow(bool Nothrow=true)
static OutlinedFunctionDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumParams)
void setParam(unsigned i, ImplicitParamDecl *P)
Represents a parameter to a function.
static ParmVarDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setUninstantiatedDefaultArg(Expr *arg)
void setScopeInfo(unsigned scopeDepth, unsigned parameterIndex)
void setObjCMethodScopeInfo(unsigned parameterIndex)
Represents a #pragma detect_mismatch line.
static PragmaDetectMismatchDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NameValueSize)
A (possibly-)qualified type.
bool isNull() const
Return true if this QualType doesn't point to a type yet.
Represents a struct/union/class.
unsigned getODRHash()
Get precomputed ODRHash or add a new one.
void setAnonymousStructOrUnion(bool Anon)
void setArgPassingRestrictions(RecordArgPassingKind Kind)
void setNonTrivialToPrimitiveCopy(bool V)
void setHasNonTrivialToPrimitiveCopyCUnion(bool V)
void setHasNonTrivialToPrimitiveDestructCUnion(bool V)
void setHasFlexibleArrayMember(bool V)
void setParamDestroyedInCallee(bool V)
void setNonTrivialToPrimitiveDestroy(bool V)
void setHasObjectMember(bool val)
void setHasVolatileMember(bool val)
void setHasNonTrivialToPrimitiveDefaultInitializeCUnion(bool V)
static RecordDecl * CreateDeserialized(const ASTContext &C, GlobalDeclID ID)
void setHasUninitializedExplicitInitFields(bool V)
void setNonTrivialToPrimitiveDefaultInitialize(bool V)
Declaration of a redeclarable template.
CommonBase * Common
Pointer to the common data shared by all declarations of this template.
virtual CommonBase * newCommon(ASTContext &C) const =0
RedeclarableTemplateDecl * getCanonicalDecl() override
Retrieves the canonical declaration of this template.
void setMemberSpecialization()
Note that this member template is a specialization.
void setInstantiatedFromMemberTemplate(RedeclarableTemplateDecl *TD)
void setPrevious(decl_type *D)
Decl * getLatestNotUpdated() const
void setLatest(decl_type *D)
Provides common interface for the Decls that can be redeclared.
DeclLink RedeclLink
Points to the next redeclaration in the chain.
bool isFirstDecl() const
True if this is the first declaration in its redeclaration chain.
static DeclLink PreviousDeclLink(decl_type *D)
Represents the body of a requires-expression.
static RequiresExprBodyDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
const FunctionDecl * getKernelEntryPointDecl() const
Encodes a location in the source.
A trivial tuple used to represent a source range.
Represents a C++11 static_assert declaration.
static StaticAssertDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
StringLiteral - This represents a string literal expression, e.g.
Represents the declaration of a struct/union/class/enum.
void setTagKind(TagKind TK)
void setCompleteDefinitionRequired(bool V=true)
True if this complete decl is required to be complete for some existing use.
void demoteThisDefinitionToDeclaration()
Mark a definition as a declaration and maintain information it was a definition.
bool isThisDeclarationADefinition() const
Return true if this declaration is a completion definition of the type.
void setEmbeddedInDeclarator(bool isInDeclarator)
True if this tag declaration is "embedded" (i.e., defined or declared for the very first time) in the...
bool isCompleteDefinition() const
Return true if this decl has its body fully specified.
bool isFirstDecl() const
True if this is the first declaration in its redeclaration chain.
TagDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
void setFreeStanding(bool isFreeStanding=true)
True if this tag is free standing, e.g. "struct foo;".
void setBraceRange(SourceRange R)
void setCompleteDefinition(bool V=true)
True if this decl has its body fully specified.
A convenient class for passing around template argument information.
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.
The base class of all kinds of template declarations (e.g., class, function, etc.).
TemplateParameterList * TemplateParams
void init(NamedDecl *NewTemplatedDecl)
Initialize the underlying templated declaration.
NamedDecl * getTemplatedDecl() const
Get the underlying, templated declaration.
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
A template parameter object.
TemplateParamObjectDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
Stores a list of template parameters for a TemplateDecl and its derived classes.
TemplateTemplateParmDecl - Declares a template template parameter, e.g., "T" in.
unsigned getNumExpansionTemplateParameters() const
Retrieves the number of expansion template parameters in an expanded parameter pack.
static TemplateTemplateParmDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setPosition(unsigned P)
void setDepth(unsigned D)
void setDeclaredWithTypename(bool withTypename)
Set whether this template template parameter was declared with the 'typename' or 'class' keyword.
void setDefaultArgument(const ASTContext &C, const TemplateArgumentLoc &DefArg)
Set the default argument for this template parameter, and whether that default argument was inherited...
bool isExpandedParameterPack() const
Whether this parameter is a template template parameter pack that has a known list of different templ...
Declaration of a template type parameter.
void setTypeConstraint(ConceptReference *CR, Expr *ImmediatelyDeclaredConstraint, UnsignedOrNone ArgPackSubstIndex)
static TemplateTypeParmDecl * CreateDeserialized(const ASTContext &C, GlobalDeclID ID)
bool hasTypeConstraint() const
Determine whether this template parameter has a type-constraint.
void setDefaultArgument(const ASTContext &C, const TemplateArgumentLoc &DefArg)
Set the default argument for this template parameter.
void setDeclaredWithTypename(bool withTypename)
Set whether this template type parameter was declared with the 'typename' or 'class' keyword.
A declaration that models statements at global scope.
static TopLevelStmtDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
The top declaration context.
Represents the declaration of a typedef-name via a C++11 alias-declaration.
static TypeAliasDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
void setDescribedAliasTemplate(TypeAliasTemplateDecl *TAT)
Declaration of an alias template.
static TypeAliasTemplateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Create an empty alias template node.
Represents a declaration of a type.
void setLocStart(SourceLocation L)
A container of type source information.
QualType getType() const
Return the type wrapped by this type source info.
const T * castAs() const
Member-template castAs<specific type>.
AutoType * getContainedAutoType() const
Get the AutoType whose type will be deduced for a variable with an initializer of this type.
const T * getAs() const
Member-template getAs<specific type>'.
Represents the declaration of a typedef-name via the 'typedef' type specifier.
static TypedefDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Base class for declarations which introduce a typedef-name.
void setModedTypeSourceInfo(TypeSourceInfo *unmodedTSI, QualType modedTy)
void setTypeSourceInfo(TypeSourceInfo *newType)
An artificial decl, representing a global anonymous constant value which is uniquified by value withi...
void addDecl(NamedDecl *D)
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)
Represents a dependent using declaration which was marked with typename.
static UnresolvedUsingTypenameDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a dependent using declaration which was not marked with typename.
void setUsingLoc(SourceLocation L)
Set the source location of the 'using' keyword.
static UnresolvedUsingValueDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a C++ using-declaration.
void setTypename(bool TN)
Sets whether the using declaration has 'typename'.
void setUsingLoc(SourceLocation L)
Set the source location of the 'using' keyword.
static UsingDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents C++ using-directive.
static UsingDirectiveDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a C++ using-enum-declaration.
void setEnumType(TypeSourceInfo *TSI)
void setEnumLoc(SourceLocation L)
void setUsingLoc(SourceLocation L)
static UsingEnumDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a pack of using declarations that a single using-declarator pack-expanded into.
static UsingPackDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID, unsigned NumExpansions)
Represents a shadow declaration implicitly introduced into a scope by a (resolved) using-declaration ...
static UsingShadowDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
void setType(QualType newType)
Represents a variable declaration or definition.
ParmVarDeclBitfields ParmVarDeclBits
static VarDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
VarDeclBitfields VarDeclBits
EvaluatedStmt * ensureEvaluatedStmt() const
Convert the initializer for this declaration to the elaborated EvaluatedStmt form,...
NonParmVarDeclBitfields NonParmVarDeclBits
@ Definition
This declaration is definitely a definition.
void setDescribedVarTemplate(VarTemplateDecl *Template)
StorageClass getStorageClass() const
Returns the storage class as written in the source.
VarDecl * getPreviousDecl()
Return the previous declaration of this declaration or NULL if this is the first declaration.
Declaration of a variable template.
static VarTemplateDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Create an empty variable template node.
static VarTemplatePartialSpecializationDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
Represents a variable template specialization, which refers to a variable template with a given set o...
void setTemplateArgsAsWritten(const ASTTemplateArgumentListInfo *ArgsWritten)
Set the template argument list as written in the sources.
static VarTemplateSpecializationDecl * CreateDeserialized(ASTContext &C, GlobalDeclID ID)
RawLocEncoding getRawLoc() const
uint64_t getBitOffset(const uint64_t DeclTypesBlockStartOffset) const
Information about a module that has been loaded by the ASTReader.
const serialization::ObjCCategoriesInfo * ObjCCategoriesMap
Array of category list location information within this module file, sorted by the definition ID.
unsigned LocalNumObjCCategoriesInMap
The number of redeclaration info entries in ObjCCategoriesMap.
llvm::BitstreamCursor DeclsCursor
DeclsCursor - This is a cursor to the start of the DECLTYPES_BLOCK block.
uint64_t GlobalBitOffset
The global bit offset (or base) of this module.
const DeclOffset * DeclOffsets
Offset of each declaration within the bitstream, indexed by the declaration ID (-1).
unsigned Generation
The generation of which this module file is a part.
uint64_t DeclsBlockStartOffset
The offset to the start of the DECLTYPES_BLOCK block.
ModuleKind Kind
The type of this module.
SmallVector< uint64_t, 1 > ObjCCategories
The Objective-C category lists for categories known to this module.
const unsigned int LOCAL_REDECLARATIONS
Record code for a list of local redeclarations of a declaration.
DeclCode
Record codes for each kind of declaration.
const unsigned int DECL_UPDATES
Record of updates for a declaration that was modified after being deserialized.
@ DECL_EMPTY
An EmptyDecl record.
@ DECL_CAPTURED
A CapturedDecl record.
@ DECL_CXX_BASE_SPECIFIERS
A record containing CXXBaseSpecifiers.
@ DECL_CXX_RECORD
A CXXRecordDecl record.
@ DECL_VAR_TEMPLATE_PARTIAL_SPECIALIZATION
A VarTemplatePartialSpecializationDecl record.
@ DECL_OMP_ALLOCATE
An OMPAllocateDcl record.
@ DECL_MS_PROPERTY
A MSPropertyDecl record.
@ DECL_OMP_DECLARE_MAPPER
An OMPDeclareMapperDecl record.
@ DECL_TOP_LEVEL_STMT_DECL
A TopLevelStmtDecl record.
@ DECL_REQUIRES_EXPR_BODY
A RequiresExprBodyDecl record.
@ DECL_STATIC_ASSERT
A StaticAssertDecl record.
@ DECL_INDIRECTFIELD
A IndirectFieldDecl record.
@ DECL_TEMPLATE_TEMPLATE_PARM
A TemplateTemplateParmDecl record.
@ DECL_IMPORT
An ImportDecl recording a module import.
@ DECL_UNNAMED_GLOBAL_CONSTANT
A UnnamedGlobalConstantDecl record.
@ DECL_ACCESS_SPEC
An AccessSpecDecl record.
@ DECL_OBJC_TYPE_PARAM
An ObjCTypeParamDecl record.
@ DECL_OBJC_CATEGORY_IMPL
A ObjCCategoryImplDecl record.
@ DECL_ENUM_CONSTANT
An EnumConstantDecl record.
@ DECL_PARM_VAR
A ParmVarDecl record.
@ DECL_TYPEDEF
A TypedefDecl record.
@ DECL_EXPANDED_TEMPLATE_TEMPLATE_PARM_PACK
A TemplateTemplateParmDecl record that stores an expanded template template parameter pack.
@ DECL_HLSL_BUFFER
A HLSLBufferDecl record.
@ DECL_NAMESPACE_ALIAS
A NamespaceAliasDecl record.
@ DECL_TYPEALIAS
A TypeAliasDecl record.
@ DECL_FUNCTION_TEMPLATE
A FunctionTemplateDecl record.
@ DECL_MS_GUID
A MSGuidDecl record.
@ DECL_UNRESOLVED_USING_TYPENAME
An UnresolvedUsingTypenameDecl record.
@ DECL_CLASS_TEMPLATE_SPECIALIZATION
A ClassTemplateSpecializationDecl record.
@ DECL_FILE_SCOPE_ASM
A FileScopeAsmDecl record.
@ DECL_PARTIAL_SPECIALIZATIONS
@ DECL_CXX_CONSTRUCTOR
A CXXConstructorDecl record.
@ DECL_CXX_CONVERSION
A CXXConversionDecl record.
@ DECL_FIELD
A FieldDecl record.
@ DECL_LINKAGE_SPEC
A LinkageSpecDecl record.
@ DECL_CONTEXT_TU_LOCAL_VISIBLE
A record that stores the set of declarations that are only visible to the TU.
@ DECL_NAMESPACE
A NamespaceDecl record.
@ DECL_NON_TYPE_TEMPLATE_PARM
A NonTypeTemplateParmDecl record.
@ DECL_USING_PACK
A UsingPackDecl record.
@ DECL_FUNCTION
A FunctionDecl record.
@ DECL_USING_DIRECTIVE
A UsingDirecitveDecl record.
@ DECL_RECORD
A RecordDecl record.
@ DECL_CONTEXT_LEXICAL
A record that stores the set of declarations that are lexically stored within a given DeclContext.
@ DECL_OUTLINEDFUNCTION
A OutlinedFunctionDecl record.
@ DECL_BLOCK
A BlockDecl record.
@ DECL_UNRESOLVED_USING_VALUE
An UnresolvedUsingValueDecl record.
@ DECL_TYPE_ALIAS_TEMPLATE
A TypeAliasTemplateDecl record.
@ DECL_CXX_CTOR_INITIALIZERS
A record containing CXXCtorInitializers.
@ DECL_OBJC_CATEGORY
A ObjCCategoryDecl record.
@ DECL_VAR
A VarDecl record.
@ DECL_UNRESOLVED_USING_IF_EXISTS
An UnresolvedUsingIfExistsDecl record.
@ DECL_USING
A UsingDecl record.
@ DECL_OBJC_PROTOCOL
A ObjCProtocolDecl record.
@ DECL_TEMPLATE_TYPE_PARM
A TemplateTypeParmDecl record.
@ DECL_VAR_TEMPLATE_SPECIALIZATION
A VarTemplateSpecializationDecl record.
@ DECL_OBJC_IMPLEMENTATION
A ObjCImplementationDecl record.
@ DECL_LABEL
A LabelDecl record.
@ DECL_OBJC_COMPATIBLE_ALIAS
A ObjCCompatibleAliasDecl record.
@ DECL_CONSTRUCTOR_USING_SHADOW
A ConstructorUsingShadowDecl record.
@ DECL_USING_ENUM
A UsingEnumDecl record.
@ DECL_FRIEND_TEMPLATE
A FriendTemplateDecl record.
@ DECL_PRAGMA_DETECT_MISMATCH
A PragmaDetectMismatchDecl record.
@ DECL_EXPANDED_NON_TYPE_TEMPLATE_PARM_PACK
A NonTypeTemplateParmDecl record that stores an expanded non-type template parameter pack.
@ DECL_OBJC_AT_DEFS_FIELD
A ObjCAtDefsFieldDecl record.
@ DECL_IMPLICIT_PARAM
An ImplicitParamDecl record.
@ DECL_FRIEND
A FriendDecl record.
@ DECL_CXX_METHOD
A CXXMethodDecl record.
@ DECL_EXPORT
An ExportDecl record.
@ DECL_BINDING
A BindingDecl record.
@ DECL_PRAGMA_COMMENT
A PragmaCommentDecl record.
@ DECL_ENUM
An EnumDecl record.
@ DECL_CONTEXT_MODULE_LOCAL_VISIBLE
A record containing the set of declarations that are only visible from DeclContext in the same module...
@ DECL_DECOMPOSITION
A DecompositionDecl record.
@ DECL_OMP_DECLARE_REDUCTION
An OMPDeclareReductionDecl record.
@ DECL_OMP_THREADPRIVATE
An OMPThreadPrivateDecl record.
@ DECL_OBJC_METHOD
A ObjCMethodDecl record.
@ DECL_CXX_DESTRUCTOR
A CXXDestructorDecl record.
@ DECL_OMP_CAPTUREDEXPR
An OMPCapturedExprDecl record.
@ DECL_CLASS_TEMPLATE
A ClassTemplateDecl record.
@ DECL_USING_SHADOW
A UsingShadowDecl record.
@ DECL_CONCEPT
A ConceptDecl record.
@ DECL_CXX_DEDUCTION_GUIDE
A CXXDeductionGuideDecl record.
@ DECL_OMP_REQUIRES
An OMPRequiresDecl record.
@ DECL_OBJC_IVAR
A ObjCIvarDecl record.
@ DECL_OBJC_PROPERTY
A ObjCPropertyDecl record.
@ DECL_TEMPLATE_PARAM_OBJECT
A TemplateParamObjectDecl record.
@ DECL_OBJC_INTERFACE
A ObjCInterfaceDecl record.
@ DECL_VAR_TEMPLATE
A VarTemplateDecl record.
@ DECL_LIFETIME_EXTENDED_TEMPORARY
An LifetimeExtendedTemporaryDecl record.
@ DECL_CLASS_TEMPLATE_PARTIAL_SPECIALIZATION
A ClassTemplatePartialSpecializationDecl record.
@ DECL_IMPLICIT_CONCEPT_SPECIALIZATION
An ImplicitConceptSpecializationDecl record.
@ DECL_CONTEXT_VISIBLE
A record that stores the set of declarations that are visible from a given DeclContext.
@ DECL_OBJC_PROPERTY_IMPL
A ObjCPropertyImplDecl record.
Defines the Linkage enumeration and various utility functions.
const internal::VariadicAllOfMatcher< Decl > decl
Matches declarations.
ComparisonCategoryResult Compare(const T &X, const T &Y)
Helper to compare two comparable types.
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.
bool needsAnonymousDeclarationNumber(const NamedDecl *D)
Determine whether the given declaration needs an anonymous declaration number.
void numberAnonymousDeclsWithin(const DeclContext *DC, Fn Visit)
Visit each declaration within DC that needs an anonymous declaration number and call Visit with the d...
uint64_t TypeID
An ID number that refers to a type in an AST file.
@ MK_MainFile
File is a PCH file treated as the actual main file.
uint32_t SubmoduleID
An ID number that refers to a submodule in a module file.
bool isPartOfPerModuleInitializer(const Decl *D)
Determine whether the given declaration will be included in the per-module initializer if it needs to...
@ DeclMarkedOpenMPThreadPrivate
@ CXXResolvedDtorGlobArrayDelete
@ CXXInstantiatedClassDefinition
@ CXXResolvedExceptionSpec
@ CXXResolvedDtorArrayDelete
@ CXXInstantiatedDefaultArgument
@ CXXInstantiatedDefaultMemberInitializer
@ CXXAddedAnonymousNamespace
@ CXXResolvedDtorGlobDelete
@ CXXAddedFunctionDefinition
@ CXXPointOfInstantiation
@ DeclMarkedOpenMPDeclareTarget
@ DeclMarkedOpenMPAllocate
The JSON file list parser is used to communicate input to InstallAPI.
bool isa(CodeGen::Address addr)
SelectorLocationsKind
Whether all locations of the selector identifiers are in a "standard" position.
LazyOffsetPtr< Stmt, uint64_t, &ExternalASTSource::GetExternalDeclStmt > LazyDeclStmtPtr
A lazy pointer to a statement.
bool isUnresolvedExceptionSpec(ExceptionSpecificationType ESpecType)
ConstexprSpecKind
Define the kind of constexpr specifier.
LinkageSpecLanguageIDs
Represents the language in a linkage specification.
LambdaCaptureKind
The different capture forms in a lambda introducer.
@ LCK_ByCopy
Capturing by copy (a.k.a., by value)
@ LCK_ByRef
Capturing by reference.
@ LCK_VLAType
Capturing variable-length array type.
@ LCK_StarThis
Capturing the *this object by copy.
@ LCK_This
Capturing the *this object by reference.
AccessSpecifier
A C++ access specifier (public, private, protected), plus the special value "none" which means differ...
SmallVector< Attr *, 4 > AttrVec
AttrVec - A vector of Attr, which is how they are stored on the AST.
OMPDeclareReductionInitKind
StorageClass
Storage classes.
Linkage
Describes the different kinds of linkage (C++ [basic.link], C99 6.2.2) that an entity may have.
@ None
No linkage, which means that the entity is unique and can only be referred to from within its scope.
@ Result
The result type of a method or function.
const FunctionProtoType * T
@ Template
We are parsing a template declaration.
TagTypeKind
The kind of a tag type.
@ VarTemplate
The name was classified as a variable template name.
ObjCImplementationControl
RecordArgPassingKind
Enum that represents the different ways arguments are passed to and returned from function calls.
static bool isUndeducedReturnType(QualType T)
bool operator!=(CanQual< T > x, CanQual< U > y)
TemplateNameKind
Specifies the kind of template name that an identifier refers to.
DeductionCandidate
Only used by CXXDeductionGuideDecl.
bool shouldSkipCheckingODR(const Decl *D)
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...
U cast(CodeGen::Address addr)
@ Interface
The "__interface" keyword introduces the elaborated-type-specifier.
@ Class
The "class" keyword introduces the elaborated-type-specifier.
@ Other
Other implicit parameter.
Structure used to store a statement, the constant value to which it was evaluated (if any),...
bool HasConstantDestruction
Whether this variable is known to have constant destruction.
bool WasEvaluated
Whether this statement was already evaluated.
bool CheckedForSideEffects
bool HasConstantInitialization
Whether this variable is known to have constant initialization.
Provides information about an explicit instantiation of a variable or class template.
SourceLocation ExternKeywordLoc
The location of the extern keyword.
Data that is common to all of the declarations of a given function template.
llvm::FoldingSetVector< FunctionTemplateSpecializationInfo > Specializations
The function template specializations for this function template, including explicit specializations ...
uint16_t Part2
...-89ab-...
uint32_t Part1
{01234567-...
uint16_t Part3
...-cdef-...
uint8_t Part4And5[8]
...-0123-456789abcdef}
llvm::DenseSet< std::tuple< Decl *, Decl *, int > > NonEquivalentDeclSet
Store declaration pairs already found to be non-equivalent.
static constexpr UnsignedOrNone fromInternalRepresentation(unsigned Rep)
uint64_t ModuleLocalOffset