1 //===--- ASTReaderDecl.cpp - Decl Deserialization ---------------*- C++ -*-===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This file implements the ASTReader::ReadDeclRecord method, which is the 11 // entrypoint for loading a decl. 12 // 13 //===----------------------------------------------------------------------===// 14 15 #include "ASTCommon.h" 16 #include "ASTReaderInternals.h" 17 #include "clang/AST/ASTContext.h" 18 #include "clang/AST/DeclCXX.h" 19 #include "clang/AST/DeclGroup.h" 20 #include "clang/AST/DeclTemplate.h" 21 #include "clang/AST/DeclVisitor.h" 22 #include "clang/AST/Expr.h" 23 #include "clang/Sema/IdentifierResolver.h" 24 #include "clang/Sema/SemaDiagnostic.h" 25 #include "clang/Serialization/ASTReader.h" 26 #include "llvm/Support/SaveAndRestore.h" 27 28 using namespace clang; 29 using namespace clang::serialization; 30 31 //===----------------------------------------------------------------------===// 32 // Declaration deserialization 33 //===----------------------------------------------------------------------===// 34 35 namespace clang { 36 class ASTDeclReader : public DeclVisitor<ASTDeclReader, void> { 37 ASTReader &Reader; 38 ASTRecordReader &Record; 39 ASTReader::RecordLocation Loc; 40 const DeclID ThisDeclID; 41 const SourceLocation ThisDeclLoc; 42 typedef ASTReader::RecordData RecordData; 43 TypeID TypeIDForTypeDecl; 44 unsigned AnonymousDeclNumber; 45 GlobalDeclID NamedDeclForTagDecl; 46 IdentifierInfo *TypedefNameForLinkage; 47 48 bool HasPendingBody; 49 50 ///\brief A flag to carry the information for a decl from the entity is 51 /// used. We use it to delay the marking of the canonical decl as used until 52 /// the entire declaration is deserialized and merged. 53 bool IsDeclMarkedUsed; 54 55 uint64_t GetCurrentCursorOffset(); 56 57 uint64_t ReadLocalOffset() { 58 uint64_t LocalOffset = Record.readInt(); 59 assert(LocalOffset < Loc.Offset && "offset point after current record"); 60 return LocalOffset ? Loc.Offset - LocalOffset : 0; 61 } 62 63 uint64_t ReadGlobalOffset() { 64 uint64_t Local = ReadLocalOffset(); 65 return Local ? Record.getGlobalBitOffset(Local) : 0; 66 } 67 68 SourceLocation ReadSourceLocation() { 69 return Record.readSourceLocation(); 70 } 71 72 SourceRange ReadSourceRange() { 73 return Record.readSourceRange(); 74 } 75 76 TypeSourceInfo *GetTypeSourceInfo() { 77 return Record.getTypeSourceInfo(); 78 } 79 80 serialization::DeclID ReadDeclID() { 81 return Record.readDeclID(); 82 } 83 84 std::string ReadString() { 85 return Record.readString(); 86 } 87 88 void ReadDeclIDList(SmallVectorImpl<DeclID> &IDs) { 89 for (unsigned I = 0, Size = Record.readInt(); I != Size; ++I) 90 IDs.push_back(ReadDeclID()); 91 } 92 93 Decl *ReadDecl() { 94 return Record.readDecl(); 95 } 96 97 template<typename T> 98 T *ReadDeclAs() { 99 return Record.readDeclAs<T>(); 100 } 101 102 void ReadQualifierInfo(QualifierInfo &Info) { 103 Record.readQualifierInfo(Info); 104 } 105 106 void ReadDeclarationNameLoc(DeclarationNameLoc &DNLoc, DeclarationName Name) { 107 Record.readDeclarationNameLoc(DNLoc, Name); 108 } 109 110 serialization::SubmoduleID readSubmoduleID() { 111 if (Record.getIdx() == Record.size()) 112 return 0; 113 114 return Record.getGlobalSubmoduleID(Record.readInt()); 115 } 116 117 Module *readModule() { 118 return Record.getSubmodule(readSubmoduleID()); 119 } 120 121 void ReadCXXRecordDefinition(CXXRecordDecl *D, bool Update); 122 void ReadCXXDefinitionData(struct CXXRecordDecl::DefinitionData &Data, 123 const CXXRecordDecl *D); 124 void MergeDefinitionData(CXXRecordDecl *D, 125 struct CXXRecordDecl::DefinitionData &&NewDD); 126 void ReadObjCDefinitionData(struct ObjCInterfaceDecl::DefinitionData &Data); 127 void MergeDefinitionData(ObjCInterfaceDecl *D, 128 struct ObjCInterfaceDecl::DefinitionData &&NewDD); 129 void ReadObjCDefinitionData(struct ObjCProtocolDecl::DefinitionData &Data); 130 void MergeDefinitionData(ObjCProtocolDecl *D, 131 struct ObjCProtocolDecl::DefinitionData &&NewDD); 132 133 static NamedDecl *getAnonymousDeclForMerging(ASTReader &Reader, 134 DeclContext *DC, 135 unsigned Index); 136 static void setAnonymousDeclForMerging(ASTReader &Reader, DeclContext *DC, 137 unsigned Index, NamedDecl *D); 138 139 /// Results from loading a RedeclarableDecl. 140 class RedeclarableResult { 141 Decl *MergeWith; 142 GlobalDeclID FirstID; 143 bool IsKeyDecl; 144 145 public: 146 RedeclarableResult(Decl *MergeWith, GlobalDeclID FirstID, bool IsKeyDecl) 147 : MergeWith(MergeWith), FirstID(FirstID), IsKeyDecl(IsKeyDecl) {} 148 149 /// \brief Retrieve the first ID. 150 GlobalDeclID getFirstID() const { return FirstID; } 151 152 /// \brief Is this declaration a key declaration? 153 bool isKeyDecl() const { return IsKeyDecl; } 154 155 /// \brief Get a known declaration that this should be merged with, if 156 /// any. 157 Decl *getKnownMergeTarget() const { return MergeWith; } 158 }; 159 160 /// \brief Class used to capture the result of searching for an existing 161 /// declaration of a specific kind and name, along with the ability 162 /// to update the place where this result was found (the declaration 163 /// chain hanging off an identifier or the DeclContext we searched in) 164 /// if requested. 165 class FindExistingResult { 166 ASTReader &Reader; 167 NamedDecl *New; 168 NamedDecl *Existing; 169 bool AddResult; 170 171 unsigned AnonymousDeclNumber; 172 IdentifierInfo *TypedefNameForLinkage; 173 174 void operator=(FindExistingResult &&) = delete; 175 176 public: 177 FindExistingResult(ASTReader &Reader) 178 : Reader(Reader), New(nullptr), Existing(nullptr), AddResult(false), 179 AnonymousDeclNumber(0), TypedefNameForLinkage(nullptr) {} 180 181 FindExistingResult(ASTReader &Reader, NamedDecl *New, NamedDecl *Existing, 182 unsigned AnonymousDeclNumber, 183 IdentifierInfo *TypedefNameForLinkage) 184 : Reader(Reader), New(New), Existing(Existing), AddResult(true), 185 AnonymousDeclNumber(AnonymousDeclNumber), 186 TypedefNameForLinkage(TypedefNameForLinkage) {} 187 188 FindExistingResult(FindExistingResult &&Other) 189 : Reader(Other.Reader), New(Other.New), Existing(Other.Existing), 190 AddResult(Other.AddResult), 191 AnonymousDeclNumber(Other.AnonymousDeclNumber), 192 TypedefNameForLinkage(Other.TypedefNameForLinkage) { 193 Other.AddResult = false; 194 } 195 196 ~FindExistingResult(); 197 198 /// \brief Suppress the addition of this result into the known set of 199 /// names. 200 void suppress() { AddResult = false; } 201 202 operator NamedDecl*() const { return Existing; } 203 204 template<typename T> 205 operator T*() const { return dyn_cast_or_null<T>(Existing); } 206 }; 207 208 static DeclContext *getPrimaryContextForMerging(ASTReader &Reader, 209 DeclContext *DC); 210 FindExistingResult findExisting(NamedDecl *D); 211 212 public: 213 ASTDeclReader(ASTReader &Reader, ASTRecordReader &Record, 214 ASTReader::RecordLocation Loc, 215 DeclID thisDeclID, SourceLocation ThisDeclLoc) 216 : Reader(Reader), Record(Record), Loc(Loc), 217 ThisDeclID(thisDeclID), ThisDeclLoc(ThisDeclLoc), 218 TypeIDForTypeDecl(0), NamedDeclForTagDecl(0), 219 TypedefNameForLinkage(nullptr), HasPendingBody(false), 220 IsDeclMarkedUsed(false) {} 221 222 template <typename T> static 223 void AddLazySpecializations(T *D, 224 SmallVectorImpl<serialization::DeclID>& IDs) { 225 if (IDs.empty()) 226 return; 227 228 // FIXME: We should avoid this pattern of getting the ASTContext. 229 ASTContext &C = D->getASTContext(); 230 231 auto *&LazySpecializations = D->getCommonPtr()->LazySpecializations; 232 233 if (auto &Old = LazySpecializations) { 234 IDs.insert(IDs.end(), Old + 1, Old + 1 + Old[0]); 235 std::sort(IDs.begin(), IDs.end()); 236 IDs.erase(std::unique(IDs.begin(), IDs.end()), IDs.end()); 237 } 238 239 auto *Result = new (C) serialization::DeclID[1 + IDs.size()]; 240 *Result = IDs.size(); 241 std::copy(IDs.begin(), IDs.end(), Result + 1); 242 243 LazySpecializations = Result; 244 } 245 246 template <typename DeclT> 247 static Decl *getMostRecentDeclImpl(Redeclarable<DeclT> *D); 248 static Decl *getMostRecentDeclImpl(...); 249 static Decl *getMostRecentDecl(Decl *D); 250 251 template <typename DeclT> 252 static void attachPreviousDeclImpl(ASTReader &Reader, 253 Redeclarable<DeclT> *D, Decl *Previous, 254 Decl *Canon); 255 static void attachPreviousDeclImpl(ASTReader &Reader, ...); 256 static void attachPreviousDecl(ASTReader &Reader, Decl *D, Decl *Previous, 257 Decl *Canon); 258 259 template <typename DeclT> 260 static void attachLatestDeclImpl(Redeclarable<DeclT> *D, Decl *Latest); 261 static void attachLatestDeclImpl(...); 262 static void attachLatestDecl(Decl *D, Decl *latest); 263 264 template <typename DeclT> 265 static void markIncompleteDeclChainImpl(Redeclarable<DeclT> *D); 266 static void markIncompleteDeclChainImpl(...); 267 268 /// \brief Determine whether this declaration has a pending body. 269 bool hasPendingBody() const { return HasPendingBody; } 270 271 void ReadFunctionDefinition(FunctionDecl *FD); 272 void Visit(Decl *D); 273 274 void UpdateDecl(Decl *D, llvm::SmallVectorImpl<serialization::DeclID>&); 275 276 static void setNextObjCCategory(ObjCCategoryDecl *Cat, 277 ObjCCategoryDecl *Next) { 278 Cat->NextClassCategory = Next; 279 } 280 281 void VisitDecl(Decl *D); 282 void VisitPragmaCommentDecl(PragmaCommentDecl *D); 283 void VisitPragmaDetectMismatchDecl(PragmaDetectMismatchDecl *D); 284 void VisitTranslationUnitDecl(TranslationUnitDecl *TU); 285 void VisitNamedDecl(NamedDecl *ND); 286 void VisitLabelDecl(LabelDecl *LD); 287 void VisitNamespaceDecl(NamespaceDecl *D); 288 void VisitUsingDirectiveDecl(UsingDirectiveDecl *D); 289 void VisitNamespaceAliasDecl(NamespaceAliasDecl *D); 290 void VisitTypeDecl(TypeDecl *TD); 291 RedeclarableResult VisitTypedefNameDecl(TypedefNameDecl *TD); 292 void VisitTypedefDecl(TypedefDecl *TD); 293 void VisitTypeAliasDecl(TypeAliasDecl *TD); 294 void VisitUnresolvedUsingTypenameDecl(UnresolvedUsingTypenameDecl *D); 295 RedeclarableResult VisitTagDecl(TagDecl *TD); 296 void VisitEnumDecl(EnumDecl *ED); 297 RedeclarableResult VisitRecordDeclImpl(RecordDecl *RD); 298 void VisitRecordDecl(RecordDecl *RD) { VisitRecordDeclImpl(RD); } 299 RedeclarableResult VisitCXXRecordDeclImpl(CXXRecordDecl *D); 300 void VisitCXXRecordDecl(CXXRecordDecl *D) { VisitCXXRecordDeclImpl(D); } 301 RedeclarableResult VisitClassTemplateSpecializationDeclImpl( 302 ClassTemplateSpecializationDecl *D); 303 void VisitClassTemplateSpecializationDecl( 304 ClassTemplateSpecializationDecl *D) { 305 VisitClassTemplateSpecializationDeclImpl(D); 306 } 307 void VisitClassTemplatePartialSpecializationDecl( 308 ClassTemplatePartialSpecializationDecl *D); 309 void VisitClassScopeFunctionSpecializationDecl( 310 ClassScopeFunctionSpecializationDecl *D); 311 RedeclarableResult 312 VisitVarTemplateSpecializationDeclImpl(VarTemplateSpecializationDecl *D); 313 void VisitVarTemplateSpecializationDecl(VarTemplateSpecializationDecl *D) { 314 VisitVarTemplateSpecializationDeclImpl(D); 315 } 316 void VisitVarTemplatePartialSpecializationDecl( 317 VarTemplatePartialSpecializationDecl *D); 318 void VisitTemplateTypeParmDecl(TemplateTypeParmDecl *D); 319 void VisitValueDecl(ValueDecl *VD); 320 void VisitEnumConstantDecl(EnumConstantDecl *ECD); 321 void VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D); 322 void VisitDeclaratorDecl(DeclaratorDecl *DD); 323 void VisitFunctionDecl(FunctionDecl *FD); 324 void VisitCXXDeductionGuideDecl(CXXDeductionGuideDecl *GD); 325 void VisitCXXMethodDecl(CXXMethodDecl *D); 326 void VisitCXXConstructorDecl(CXXConstructorDecl *D); 327 void VisitCXXDestructorDecl(CXXDestructorDecl *D); 328 void VisitCXXConversionDecl(CXXConversionDecl *D); 329 void VisitFieldDecl(FieldDecl *FD); 330 void VisitMSPropertyDecl(MSPropertyDecl *FD); 331 void VisitIndirectFieldDecl(IndirectFieldDecl *FD); 332 RedeclarableResult VisitVarDeclImpl(VarDecl *D); 333 void VisitVarDecl(VarDecl *VD) { VisitVarDeclImpl(VD); } 334 void VisitImplicitParamDecl(ImplicitParamDecl *PD); 335 void VisitParmVarDecl(ParmVarDecl *PD); 336 void VisitDecompositionDecl(DecompositionDecl *DD); 337 void VisitBindingDecl(BindingDecl *BD); 338 void VisitNonTypeTemplateParmDecl(NonTypeTemplateParmDecl *D); 339 DeclID VisitTemplateDecl(TemplateDecl *D); 340 RedeclarableResult VisitRedeclarableTemplateDecl(RedeclarableTemplateDecl *D); 341 void VisitClassTemplateDecl(ClassTemplateDecl *D); 342 void VisitBuiltinTemplateDecl(BuiltinTemplateDecl *D); 343 void VisitVarTemplateDecl(VarTemplateDecl *D); 344 void VisitFunctionTemplateDecl(FunctionTemplateDecl *D); 345 void VisitTemplateTemplateParmDecl(TemplateTemplateParmDecl *D); 346 void VisitTypeAliasTemplateDecl(TypeAliasTemplateDecl *D); 347 void VisitUsingDecl(UsingDecl *D); 348 void VisitUsingPackDecl(UsingPackDecl *D); 349 void VisitUsingShadowDecl(UsingShadowDecl *D); 350 void VisitConstructorUsingShadowDecl(ConstructorUsingShadowDecl *D); 351 void VisitLinkageSpecDecl(LinkageSpecDecl *D); 352 void VisitExportDecl(ExportDecl *D); 353 void VisitFileScopeAsmDecl(FileScopeAsmDecl *AD); 354 void VisitImportDecl(ImportDecl *D); 355 void VisitAccessSpecDecl(AccessSpecDecl *D); 356 void VisitFriendDecl(FriendDecl *D); 357 void VisitFriendTemplateDecl(FriendTemplateDecl *D); 358 void VisitStaticAssertDecl(StaticAssertDecl *D); 359 void VisitBlockDecl(BlockDecl *BD); 360 void VisitCapturedDecl(CapturedDecl *CD); 361 void VisitEmptyDecl(EmptyDecl *D); 362 363 std::pair<uint64_t, uint64_t> VisitDeclContext(DeclContext *DC); 364 365 template<typename T> 366 RedeclarableResult VisitRedeclarable(Redeclarable<T> *D); 367 368 template<typename T> 369 void mergeRedeclarable(Redeclarable<T> *D, RedeclarableResult &Redecl, 370 DeclID TemplatePatternID = 0); 371 372 template<typename T> 373 void mergeRedeclarable(Redeclarable<T> *D, T *Existing, 374 RedeclarableResult &Redecl, 375 DeclID TemplatePatternID = 0); 376 377 template<typename T> 378 void mergeMergeable(Mergeable<T> *D); 379 380 void mergeTemplatePattern(RedeclarableTemplateDecl *D, 381 RedeclarableTemplateDecl *Existing, 382 DeclID DsID, bool IsKeyDecl); 383 384 ObjCTypeParamList *ReadObjCTypeParamList(); 385 386 // FIXME: Reorder according to DeclNodes.td? 387 void VisitObjCMethodDecl(ObjCMethodDecl *D); 388 void VisitObjCTypeParamDecl(ObjCTypeParamDecl *D); 389 void VisitObjCContainerDecl(ObjCContainerDecl *D); 390 void VisitObjCInterfaceDecl(ObjCInterfaceDecl *D); 391 void VisitObjCIvarDecl(ObjCIvarDecl *D); 392 void VisitObjCProtocolDecl(ObjCProtocolDecl *D); 393 void VisitObjCAtDefsFieldDecl(ObjCAtDefsFieldDecl *D); 394 void VisitObjCCategoryDecl(ObjCCategoryDecl *D); 395 void VisitObjCImplDecl(ObjCImplDecl *D); 396 void VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D); 397 void VisitObjCImplementationDecl(ObjCImplementationDecl *D); 398 void VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *D); 399 void VisitObjCPropertyDecl(ObjCPropertyDecl *D); 400 void VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D); 401 void VisitOMPThreadPrivateDecl(OMPThreadPrivateDecl *D); 402 void VisitOMPDeclareReductionDecl(OMPDeclareReductionDecl *D); 403 void VisitOMPCapturedExprDecl(OMPCapturedExprDecl *D); 404 }; 405 } // end namespace clang 406 407 namespace { 408 /// Iterator over the redeclarations of a declaration that have already 409 /// been merged into the same redeclaration chain. 410 template<typename DeclT> 411 class MergedRedeclIterator { 412 DeclT *Start, *Canonical, *Current; 413 public: 414 MergedRedeclIterator() : Current(nullptr) {} 415 MergedRedeclIterator(DeclT *Start) 416 : Start(Start), Canonical(nullptr), Current(Start) {} 417 418 DeclT *operator*() { return Current; } 419 420 MergedRedeclIterator &operator++() { 421 if (Current->isFirstDecl()) { 422 Canonical = Current; 423 Current = Current->getMostRecentDecl(); 424 } else 425 Current = Current->getPreviousDecl(); 426 427 // If we started in the merged portion, we'll reach our start position 428 // eventually. Otherwise, we'll never reach it, but the second declaration 429 // we reached was the canonical declaration, so stop when we see that one 430 // again. 431 if (Current == Start || Current == Canonical) 432 Current = nullptr; 433 return *this; 434 } 435 436 friend bool operator!=(const MergedRedeclIterator &A, 437 const MergedRedeclIterator &B) { 438 return A.Current != B.Current; 439 } 440 }; 441 } // end anonymous namespace 442 443 template <typename DeclT> 444 static llvm::iterator_range<MergedRedeclIterator<DeclT>> 445 merged_redecls(DeclT *D) { 446 return llvm::make_range(MergedRedeclIterator<DeclT>(D), 447 MergedRedeclIterator<DeclT>()); 448 } 449 450 uint64_t ASTDeclReader::GetCurrentCursorOffset() { 451 return Loc.F->DeclsCursor.GetCurrentBitNo() + Loc.F->GlobalBitOffset; 452 } 453 454 void ASTDeclReader::ReadFunctionDefinition(FunctionDecl *FD) { 455 if (Record.readInt()) 456 Reader.DefinitionSource[FD] = Loc.F->Kind == ModuleKind::MK_MainFile; 457 if (auto *CD = dyn_cast<CXXConstructorDecl>(FD)) { 458 CD->NumCtorInitializers = Record.readInt(); 459 if (CD->NumCtorInitializers) 460 CD->CtorInitializers = ReadGlobalOffset(); 461 } 462 // Store the offset of the body so we can lazily load it later. 463 Reader.PendingBodies[FD] = GetCurrentCursorOffset(); 464 HasPendingBody = true; 465 } 466 467 void ASTDeclReader::Visit(Decl *D) { 468 DeclVisitor<ASTDeclReader, void>::Visit(D); 469 470 // At this point we have deserialized and merged the decl and it is safe to 471 // update its canonical decl to signal that the entire entity is used. 472 D->getCanonicalDecl()->Used |= IsDeclMarkedUsed; 473 IsDeclMarkedUsed = false; 474 475 if (DeclaratorDecl *DD = dyn_cast<DeclaratorDecl>(D)) { 476 if (DD->DeclInfo) { 477 DeclaratorDecl::ExtInfo *Info = 478 DD->DeclInfo.get<DeclaratorDecl::ExtInfo *>(); 479 Info->TInfo = GetTypeSourceInfo(); 480 } 481 else { 482 DD->DeclInfo = GetTypeSourceInfo(); 483 } 484 } 485 486 if (TypeDecl *TD = dyn_cast<TypeDecl>(D)) { 487 // We have a fully initialized TypeDecl. Read its type now. 488 TD->setTypeForDecl(Reader.GetType(TypeIDForTypeDecl).getTypePtrOrNull()); 489 490 // If this is a tag declaration with a typedef name for linkage, it's safe 491 // to load that typedef now. 492 if (NamedDeclForTagDecl) 493 cast<TagDecl>(D)->TypedefNameDeclOrQualifier = 494 cast<TypedefNameDecl>(Reader.GetDecl(NamedDeclForTagDecl)); 495 } else if (ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(D)) { 496 // if we have a fully initialized TypeDecl, we can safely read its type now. 497 ID->TypeForDecl = Reader.GetType(TypeIDForTypeDecl).getTypePtrOrNull(); 498 } else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 499 // FunctionDecl's body was written last after all other Stmts/Exprs. 500 // We only read it if FD doesn't already have a body (e.g., from another 501 // module). 502 // FIXME: Can we diagnose ODR violations somehow? 503 if (Record.readInt()) 504 ReadFunctionDefinition(FD); 505 } 506 } 507 508 void ASTDeclReader::VisitDecl(Decl *D) { 509 if (D->isTemplateParameter() || D->isTemplateParameterPack() || 510 isa<ParmVarDecl>(D)) { 511 // We don't want to deserialize the DeclContext of a template 512 // parameter or of a parameter of a function template immediately. These 513 // entities might be used in the formulation of its DeclContext (for 514 // example, a function parameter can be used in decltype() in trailing 515 // return type of the function). Use the translation unit DeclContext as a 516 // placeholder. 517 GlobalDeclID SemaDCIDForTemplateParmDecl = ReadDeclID(); 518 GlobalDeclID LexicalDCIDForTemplateParmDecl = ReadDeclID(); 519 if (!LexicalDCIDForTemplateParmDecl) 520 LexicalDCIDForTemplateParmDecl = SemaDCIDForTemplateParmDecl; 521 Reader.addPendingDeclContextInfo(D, 522 SemaDCIDForTemplateParmDecl, 523 LexicalDCIDForTemplateParmDecl); 524 D->setDeclContext(Reader.getContext().getTranslationUnitDecl()); 525 } else { 526 DeclContext *SemaDC = ReadDeclAs<DeclContext>(); 527 DeclContext *LexicalDC = ReadDeclAs<DeclContext>(); 528 if (!LexicalDC) 529 LexicalDC = SemaDC; 530 DeclContext *MergedSemaDC = Reader.MergedDeclContexts.lookup(SemaDC); 531 // Avoid calling setLexicalDeclContext() directly because it uses 532 // Decl::getASTContext() internally which is unsafe during derialization. 533 D->setDeclContextsImpl(MergedSemaDC ? MergedSemaDC : SemaDC, LexicalDC, 534 Reader.getContext()); 535 } 536 D->setLocation(ThisDeclLoc); 537 D->setInvalidDecl(Record.readInt()); 538 if (Record.readInt()) { // hasAttrs 539 AttrVec Attrs; 540 Record.readAttributes(Attrs); 541 // Avoid calling setAttrs() directly because it uses Decl::getASTContext() 542 // internally which is unsafe during derialization. 543 D->setAttrsImpl(Attrs, Reader.getContext()); 544 } 545 D->setImplicit(Record.readInt()); 546 D->Used = Record.readInt(); 547 IsDeclMarkedUsed |= D->Used; 548 D->setReferenced(Record.readInt()); 549 D->setTopLevelDeclInObjCContainer(Record.readInt()); 550 D->setAccess((AccessSpecifier)Record.readInt()); 551 D->FromASTFile = true; 552 bool ModulePrivate = Record.readInt(); 553 554 // Determine whether this declaration is part of a (sub)module. If so, it 555 // may not yet be visible. 556 if (unsigned SubmoduleID = readSubmoduleID()) { 557 // Store the owning submodule ID in the declaration. 558 D->setModuleOwnershipKind( 559 ModulePrivate ? Decl::ModuleOwnershipKind::ModulePrivate 560 : Decl::ModuleOwnershipKind::VisibleWhenImported); 561 D->setOwningModuleID(SubmoduleID); 562 563 if (ModulePrivate) { 564 // Module-private declarations are never visible, so there is no work to 565 // do. 566 } else if (Reader.getContext().getLangOpts().ModulesLocalVisibility) { 567 // If local visibility is being tracked, this declaration will become 568 // hidden and visible as the owning module does. 569 } else if (Module *Owner = Reader.getSubmodule(SubmoduleID)) { 570 // Mark the declaration as visible when its owning module becomes visible. 571 if (Owner->NameVisibility == Module::AllVisible) 572 D->setVisibleDespiteOwningModule(); 573 else 574 Reader.HiddenNamesMap[Owner].push_back(D); 575 } 576 } else if (ModulePrivate) { 577 D->setModuleOwnershipKind(Decl::ModuleOwnershipKind::ModulePrivate); 578 } 579 } 580 581 void ASTDeclReader::VisitPragmaCommentDecl(PragmaCommentDecl *D) { 582 VisitDecl(D); 583 D->setLocation(ReadSourceLocation()); 584 D->CommentKind = (PragmaMSCommentKind)Record.readInt(); 585 std::string Arg = ReadString(); 586 memcpy(D->getTrailingObjects<char>(), Arg.data(), Arg.size()); 587 D->getTrailingObjects<char>()[Arg.size()] = '\0'; 588 } 589 590 void ASTDeclReader::VisitPragmaDetectMismatchDecl(PragmaDetectMismatchDecl *D) { 591 VisitDecl(D); 592 D->setLocation(ReadSourceLocation()); 593 std::string Name = ReadString(); 594 memcpy(D->getTrailingObjects<char>(), Name.data(), Name.size()); 595 D->getTrailingObjects<char>()[Name.size()] = '\0'; 596 597 D->ValueStart = Name.size() + 1; 598 std::string Value = ReadString(); 599 memcpy(D->getTrailingObjects<char>() + D->ValueStart, Value.data(), 600 Value.size()); 601 D->getTrailingObjects<char>()[D->ValueStart + Value.size()] = '\0'; 602 } 603 604 void ASTDeclReader::VisitTranslationUnitDecl(TranslationUnitDecl *TU) { 605 llvm_unreachable("Translation units are not serialized"); 606 } 607 608 void ASTDeclReader::VisitNamedDecl(NamedDecl *ND) { 609 VisitDecl(ND); 610 ND->setDeclName(Record.readDeclarationName()); 611 AnonymousDeclNumber = Record.readInt(); 612 } 613 614 void ASTDeclReader::VisitTypeDecl(TypeDecl *TD) { 615 VisitNamedDecl(TD); 616 TD->setLocStart(ReadSourceLocation()); 617 // Delay type reading until after we have fully initialized the decl. 618 TypeIDForTypeDecl = Record.getGlobalTypeID(Record.readInt()); 619 } 620 621 ASTDeclReader::RedeclarableResult 622 ASTDeclReader::VisitTypedefNameDecl(TypedefNameDecl *TD) { 623 RedeclarableResult Redecl = VisitRedeclarable(TD); 624 VisitTypeDecl(TD); 625 TypeSourceInfo *TInfo = GetTypeSourceInfo(); 626 if (Record.readInt()) { // isModed 627 QualType modedT = Record.readType(); 628 TD->setModedTypeSourceInfo(TInfo, modedT); 629 } else 630 TD->setTypeSourceInfo(TInfo); 631 // Read and discard the declaration for which this is a typedef name for 632 // linkage, if it exists. We cannot rely on our type to pull in this decl, 633 // because it might have been merged with a type from another module and 634 // thus might not refer to our version of the declaration. 635 ReadDecl(); 636 return Redecl; 637 } 638 639 void ASTDeclReader::VisitTypedefDecl(TypedefDecl *TD) { 640 RedeclarableResult Redecl = VisitTypedefNameDecl(TD); 641 mergeRedeclarable(TD, Redecl); 642 } 643 644 void ASTDeclReader::VisitTypeAliasDecl(TypeAliasDecl *TD) { 645 RedeclarableResult Redecl = VisitTypedefNameDecl(TD); 646 if (auto *Template = ReadDeclAs<TypeAliasTemplateDecl>()) 647 // Merged when we merge the template. 648 TD->setDescribedAliasTemplate(Template); 649 else 650 mergeRedeclarable(TD, Redecl); 651 } 652 653 ASTDeclReader::RedeclarableResult ASTDeclReader::VisitTagDecl(TagDecl *TD) { 654 RedeclarableResult Redecl = VisitRedeclarable(TD); 655 VisitTypeDecl(TD); 656 657 TD->IdentifierNamespace = Record.readInt(); 658 TD->setTagKind((TagDecl::TagKind)Record.readInt()); 659 if (!isa<CXXRecordDecl>(TD)) 660 TD->setCompleteDefinition(Record.readInt()); 661 TD->setEmbeddedInDeclarator(Record.readInt()); 662 TD->setFreeStanding(Record.readInt()); 663 TD->setCompleteDefinitionRequired(Record.readInt()); 664 TD->setBraceRange(ReadSourceRange()); 665 666 switch (Record.readInt()) { 667 case 0: 668 break; 669 case 1: { // ExtInfo 670 TagDecl::ExtInfo *Info = new (Reader.getContext()) TagDecl::ExtInfo(); 671 ReadQualifierInfo(*Info); 672 TD->TypedefNameDeclOrQualifier = Info; 673 break; 674 } 675 case 2: // TypedefNameForAnonDecl 676 NamedDeclForTagDecl = ReadDeclID(); 677 TypedefNameForLinkage = Record.getIdentifierInfo(); 678 break; 679 default: 680 llvm_unreachable("unexpected tag info kind"); 681 } 682 683 if (!isa<CXXRecordDecl>(TD)) 684 mergeRedeclarable(TD, Redecl); 685 return Redecl; 686 } 687 688 void ASTDeclReader::VisitEnumDecl(EnumDecl *ED) { 689 VisitTagDecl(ED); 690 if (TypeSourceInfo *TI = GetTypeSourceInfo()) 691 ED->setIntegerTypeSourceInfo(TI); 692 else 693 ED->setIntegerType(Record.readType()); 694 ED->setPromotionType(Record.readType()); 695 ED->setNumPositiveBits(Record.readInt()); 696 ED->setNumNegativeBits(Record.readInt()); 697 ED->IsScoped = Record.readInt(); 698 ED->IsScopedUsingClassTag = Record.readInt(); 699 ED->IsFixed = Record.readInt(); 700 701 // If this is a definition subject to the ODR, and we already have a 702 // definition, merge this one into it. 703 if (ED->IsCompleteDefinition && 704 Reader.getContext().getLangOpts().Modules && 705 Reader.getContext().getLangOpts().CPlusPlus) { 706 EnumDecl *&OldDef = Reader.EnumDefinitions[ED->getCanonicalDecl()]; 707 if (!OldDef) { 708 // This is the first time we've seen an imported definition. Look for a 709 // local definition before deciding that we are the first definition. 710 for (auto *D : merged_redecls(ED->getCanonicalDecl())) { 711 if (!D->isFromASTFile() && D->isCompleteDefinition()) { 712 OldDef = D; 713 break; 714 } 715 } 716 } 717 if (OldDef) { 718 Reader.MergedDeclContexts.insert(std::make_pair(ED, OldDef)); 719 ED->IsCompleteDefinition = false; 720 Reader.mergeDefinitionVisibility(OldDef, ED); 721 } else { 722 OldDef = ED; 723 } 724 } 725 726 if (EnumDecl *InstED = ReadDeclAs<EnumDecl>()) { 727 TemplateSpecializationKind TSK = 728 (TemplateSpecializationKind)Record.readInt(); 729 SourceLocation POI = ReadSourceLocation(); 730 ED->setInstantiationOfMemberEnum(Reader.getContext(), InstED, TSK); 731 ED->getMemberSpecializationInfo()->setPointOfInstantiation(POI); 732 } 733 } 734 735 ASTDeclReader::RedeclarableResult 736 ASTDeclReader::VisitRecordDeclImpl(RecordDecl *RD) { 737 RedeclarableResult Redecl = VisitTagDecl(RD); 738 RD->setHasFlexibleArrayMember(Record.readInt()); 739 RD->setAnonymousStructOrUnion(Record.readInt()); 740 RD->setHasObjectMember(Record.readInt()); 741 RD->setHasVolatileMember(Record.readInt()); 742 return Redecl; 743 } 744 745 void ASTDeclReader::VisitValueDecl(ValueDecl *VD) { 746 VisitNamedDecl(VD); 747 VD->setType(Record.readType()); 748 } 749 750 void ASTDeclReader::VisitEnumConstantDecl(EnumConstantDecl *ECD) { 751 VisitValueDecl(ECD); 752 if (Record.readInt()) 753 ECD->setInitExpr(Record.readExpr()); 754 ECD->setInitVal(Record.readAPSInt()); 755 mergeMergeable(ECD); 756 } 757 758 void ASTDeclReader::VisitDeclaratorDecl(DeclaratorDecl *DD) { 759 VisitValueDecl(DD); 760 DD->setInnerLocStart(ReadSourceLocation()); 761 if (Record.readInt()) { // hasExtInfo 762 DeclaratorDecl::ExtInfo *Info 763 = new (Reader.getContext()) DeclaratorDecl::ExtInfo(); 764 ReadQualifierInfo(*Info); 765 DD->DeclInfo = Info; 766 } 767 } 768 769 void ASTDeclReader::VisitFunctionDecl(FunctionDecl *FD) { 770 RedeclarableResult Redecl = VisitRedeclarable(FD); 771 VisitDeclaratorDecl(FD); 772 773 ReadDeclarationNameLoc(FD->DNLoc, FD->getDeclName()); 774 FD->IdentifierNamespace = Record.readInt(); 775 776 // FunctionDecl's body is handled last at ASTDeclReader::Visit, 777 // after everything else is read. 778 779 FD->SClass = (StorageClass)Record.readInt(); 780 FD->IsInline = Record.readInt(); 781 FD->IsInlineSpecified = Record.readInt(); 782 FD->IsExplicitSpecified = Record.readInt(); 783 FD->IsVirtualAsWritten = Record.readInt(); 784 FD->IsPure = Record.readInt(); 785 FD->HasInheritedPrototype = Record.readInt(); 786 FD->HasWrittenPrototype = Record.readInt(); 787 FD->IsDeleted = Record.readInt(); 788 FD->IsTrivial = Record.readInt(); 789 FD->IsDefaulted = Record.readInt(); 790 FD->IsExplicitlyDefaulted = Record.readInt(); 791 FD->HasImplicitReturnZero = Record.readInt(); 792 FD->IsConstexpr = Record.readInt(); 793 FD->UsesSEHTry = Record.readInt(); 794 FD->HasSkippedBody = Record.readInt(); 795 FD->IsLateTemplateParsed = Record.readInt(); 796 FD->setCachedLinkage(Linkage(Record.readInt())); 797 FD->EndRangeLoc = ReadSourceLocation(); 798 799 switch ((FunctionDecl::TemplatedKind)Record.readInt()) { 800 case FunctionDecl::TK_NonTemplate: 801 mergeRedeclarable(FD, Redecl); 802 break; 803 case FunctionDecl::TK_FunctionTemplate: 804 // Merged when we merge the template. 805 FD->setDescribedFunctionTemplate(ReadDeclAs<FunctionTemplateDecl>()); 806 break; 807 case FunctionDecl::TK_MemberSpecialization: { 808 FunctionDecl *InstFD = ReadDeclAs<FunctionDecl>(); 809 TemplateSpecializationKind TSK = 810 (TemplateSpecializationKind)Record.readInt(); 811 SourceLocation POI = ReadSourceLocation(); 812 FD->setInstantiationOfMemberFunction(Reader.getContext(), InstFD, TSK); 813 FD->getMemberSpecializationInfo()->setPointOfInstantiation(POI); 814 mergeRedeclarable(FD, Redecl); 815 break; 816 } 817 case FunctionDecl::TK_FunctionTemplateSpecialization: { 818 FunctionTemplateDecl *Template = ReadDeclAs<FunctionTemplateDecl>(); 819 TemplateSpecializationKind TSK = 820 (TemplateSpecializationKind)Record.readInt(); 821 822 // Template arguments. 823 SmallVector<TemplateArgument, 8> TemplArgs; 824 Record.readTemplateArgumentList(TemplArgs, /*Canonicalize*/ true); 825 826 // Template args as written. 827 SmallVector<TemplateArgumentLoc, 8> TemplArgLocs; 828 SourceLocation LAngleLoc, RAngleLoc; 829 bool HasTemplateArgumentsAsWritten = Record.readInt(); 830 if (HasTemplateArgumentsAsWritten) { 831 unsigned NumTemplateArgLocs = Record.readInt(); 832 TemplArgLocs.reserve(NumTemplateArgLocs); 833 for (unsigned i=0; i != NumTemplateArgLocs; ++i) 834 TemplArgLocs.push_back(Record.readTemplateArgumentLoc()); 835 836 LAngleLoc = ReadSourceLocation(); 837 RAngleLoc = ReadSourceLocation(); 838 } 839 840 SourceLocation POI = ReadSourceLocation(); 841 842 ASTContext &C = Reader.getContext(); 843 TemplateArgumentList *TemplArgList 844 = TemplateArgumentList::CreateCopy(C, TemplArgs); 845 TemplateArgumentListInfo TemplArgsInfo(LAngleLoc, RAngleLoc); 846 for (unsigned i=0, e = TemplArgLocs.size(); i != e; ++i) 847 TemplArgsInfo.addArgument(TemplArgLocs[i]); 848 FunctionTemplateSpecializationInfo *FTInfo 849 = FunctionTemplateSpecializationInfo::Create(C, FD, Template, TSK, 850 TemplArgList, 851 HasTemplateArgumentsAsWritten ? &TemplArgsInfo 852 : nullptr, 853 POI); 854 FD->TemplateOrSpecialization = FTInfo; 855 856 if (FD->isCanonicalDecl()) { // if canonical add to template's set. 857 // The template that contains the specializations set. It's not safe to 858 // use getCanonicalDecl on Template since it may still be initializing. 859 FunctionTemplateDecl *CanonTemplate = ReadDeclAs<FunctionTemplateDecl>(); 860 // Get the InsertPos by FindNodeOrInsertPos() instead of calling 861 // InsertNode(FTInfo) directly to avoid the getASTContext() call in 862 // FunctionTemplateSpecializationInfo's Profile(). 863 // We avoid getASTContext because a decl in the parent hierarchy may 864 // be initializing. 865 llvm::FoldingSetNodeID ID; 866 FunctionTemplateSpecializationInfo::Profile(ID, TemplArgs, C); 867 void *InsertPos = nullptr; 868 FunctionTemplateDecl::Common *CommonPtr = CanonTemplate->getCommonPtr(); 869 FunctionTemplateSpecializationInfo *ExistingInfo = 870 CommonPtr->Specializations.FindNodeOrInsertPos(ID, InsertPos); 871 if (InsertPos) 872 CommonPtr->Specializations.InsertNode(FTInfo, InsertPos); 873 else { 874 assert(Reader.getContext().getLangOpts().Modules && 875 "already deserialized this template specialization"); 876 mergeRedeclarable(FD, ExistingInfo->Function, Redecl); 877 } 878 } 879 break; 880 } 881 case FunctionDecl::TK_DependentFunctionTemplateSpecialization: { 882 // Templates. 883 UnresolvedSet<8> TemplDecls; 884 unsigned NumTemplates = Record.readInt(); 885 while (NumTemplates--) 886 TemplDecls.addDecl(ReadDeclAs<NamedDecl>()); 887 888 // Templates args. 889 TemplateArgumentListInfo TemplArgs; 890 unsigned NumArgs = Record.readInt(); 891 while (NumArgs--) 892 TemplArgs.addArgument(Record.readTemplateArgumentLoc()); 893 TemplArgs.setLAngleLoc(ReadSourceLocation()); 894 TemplArgs.setRAngleLoc(ReadSourceLocation()); 895 896 FD->setDependentTemplateSpecialization(Reader.getContext(), 897 TemplDecls, TemplArgs); 898 // These are not merged; we don't need to merge redeclarations of dependent 899 // template friends. 900 break; 901 } 902 } 903 904 // Read in the parameters. 905 unsigned NumParams = Record.readInt(); 906 SmallVector<ParmVarDecl *, 16> Params; 907 Params.reserve(NumParams); 908 for (unsigned I = 0; I != NumParams; ++I) 909 Params.push_back(ReadDeclAs<ParmVarDecl>()); 910 FD->setParams(Reader.getContext(), Params); 911 } 912 913 void ASTDeclReader::VisitObjCMethodDecl(ObjCMethodDecl *MD) { 914 VisitNamedDecl(MD); 915 if (Record.readInt()) { 916 // Load the body on-demand. Most clients won't care, because method 917 // definitions rarely show up in headers. 918 Reader.PendingBodies[MD] = GetCurrentCursorOffset(); 919 HasPendingBody = true; 920 MD->setSelfDecl(ReadDeclAs<ImplicitParamDecl>()); 921 MD->setCmdDecl(ReadDeclAs<ImplicitParamDecl>()); 922 } 923 MD->setInstanceMethod(Record.readInt()); 924 MD->setVariadic(Record.readInt()); 925 MD->setPropertyAccessor(Record.readInt()); 926 MD->setDefined(Record.readInt()); 927 MD->IsOverriding = Record.readInt(); 928 MD->HasSkippedBody = Record.readInt(); 929 930 MD->IsRedeclaration = Record.readInt(); 931 MD->HasRedeclaration = Record.readInt(); 932 if (MD->HasRedeclaration) 933 Reader.getContext().setObjCMethodRedeclaration(MD, 934 ReadDeclAs<ObjCMethodDecl>()); 935 936 MD->setDeclImplementation((ObjCMethodDecl::ImplementationControl)Record.readInt()); 937 MD->setObjCDeclQualifier((Decl::ObjCDeclQualifier)Record.readInt()); 938 MD->SetRelatedResultType(Record.readInt()); 939 MD->setReturnType(Record.readType()); 940 MD->setReturnTypeSourceInfo(GetTypeSourceInfo()); 941 MD->DeclEndLoc = ReadSourceLocation(); 942 unsigned NumParams = Record.readInt(); 943 SmallVector<ParmVarDecl *, 16> Params; 944 Params.reserve(NumParams); 945 for (unsigned I = 0; I != NumParams; ++I) 946 Params.push_back(ReadDeclAs<ParmVarDecl>()); 947 948 MD->SelLocsKind = Record.readInt(); 949 unsigned NumStoredSelLocs = Record.readInt(); 950 SmallVector<SourceLocation, 16> SelLocs; 951 SelLocs.reserve(NumStoredSelLocs); 952 for (unsigned i = 0; i != NumStoredSelLocs; ++i) 953 SelLocs.push_back(ReadSourceLocation()); 954 955 MD->setParamsAndSelLocs(Reader.getContext(), Params, SelLocs); 956 } 957 958 void ASTDeclReader::VisitObjCTypeParamDecl(ObjCTypeParamDecl *D) { 959 VisitTypedefNameDecl(D); 960 961 D->Variance = Record.readInt(); 962 D->Index = Record.readInt(); 963 D->VarianceLoc = ReadSourceLocation(); 964 D->ColonLoc = ReadSourceLocation(); 965 } 966 967 void ASTDeclReader::VisitObjCContainerDecl(ObjCContainerDecl *CD) { 968 VisitNamedDecl(CD); 969 CD->setAtStartLoc(ReadSourceLocation()); 970 CD->setAtEndRange(ReadSourceRange()); 971 } 972 973 ObjCTypeParamList *ASTDeclReader::ReadObjCTypeParamList() { 974 unsigned numParams = Record.readInt(); 975 if (numParams == 0) 976 return nullptr; 977 978 SmallVector<ObjCTypeParamDecl *, 4> typeParams; 979 typeParams.reserve(numParams); 980 for (unsigned i = 0; i != numParams; ++i) { 981 auto typeParam = ReadDeclAs<ObjCTypeParamDecl>(); 982 if (!typeParam) 983 return nullptr; 984 985 typeParams.push_back(typeParam); 986 } 987 988 SourceLocation lAngleLoc = ReadSourceLocation(); 989 SourceLocation rAngleLoc = ReadSourceLocation(); 990 991 return ObjCTypeParamList::create(Reader.getContext(), lAngleLoc, 992 typeParams, rAngleLoc); 993 } 994 995 void ASTDeclReader::ReadObjCDefinitionData( 996 struct ObjCInterfaceDecl::DefinitionData &Data) { 997 // Read the superclass. 998 Data.SuperClassTInfo = GetTypeSourceInfo(); 999 1000 Data.EndLoc = ReadSourceLocation(); 1001 Data.HasDesignatedInitializers = Record.readInt(); 1002 1003 // Read the directly referenced protocols and their SourceLocations. 1004 unsigned NumProtocols = Record.readInt(); 1005 SmallVector<ObjCProtocolDecl *, 16> Protocols; 1006 Protocols.reserve(NumProtocols); 1007 for (unsigned I = 0; I != NumProtocols; ++I) 1008 Protocols.push_back(ReadDeclAs<ObjCProtocolDecl>()); 1009 SmallVector<SourceLocation, 16> ProtoLocs; 1010 ProtoLocs.reserve(NumProtocols); 1011 for (unsigned I = 0; I != NumProtocols; ++I) 1012 ProtoLocs.push_back(ReadSourceLocation()); 1013 Data.ReferencedProtocols.set(Protocols.data(), NumProtocols, ProtoLocs.data(), 1014 Reader.getContext()); 1015 1016 // Read the transitive closure of protocols referenced by this class. 1017 NumProtocols = Record.readInt(); 1018 Protocols.clear(); 1019 Protocols.reserve(NumProtocols); 1020 for (unsigned I = 0; I != NumProtocols; ++I) 1021 Protocols.push_back(ReadDeclAs<ObjCProtocolDecl>()); 1022 Data.AllReferencedProtocols.set(Protocols.data(), NumProtocols, 1023 Reader.getContext()); 1024 } 1025 1026 void ASTDeclReader::MergeDefinitionData(ObjCInterfaceDecl *D, 1027 struct ObjCInterfaceDecl::DefinitionData &&NewDD) { 1028 // FIXME: odr checking? 1029 } 1030 1031 void ASTDeclReader::VisitObjCInterfaceDecl(ObjCInterfaceDecl *ID) { 1032 RedeclarableResult Redecl = VisitRedeclarable(ID); 1033 VisitObjCContainerDecl(ID); 1034 TypeIDForTypeDecl = Record.getGlobalTypeID(Record.readInt()); 1035 mergeRedeclarable(ID, Redecl); 1036 1037 ID->TypeParamList = ReadObjCTypeParamList(); 1038 if (Record.readInt()) { 1039 // Read the definition. 1040 ID->allocateDefinitionData(); 1041 1042 ReadObjCDefinitionData(ID->data()); 1043 ObjCInterfaceDecl *Canon = ID->getCanonicalDecl(); 1044 if (Canon->Data.getPointer()) { 1045 // If we already have a definition, keep the definition invariant and 1046 // merge the data. 1047 MergeDefinitionData(Canon, std::move(ID->data())); 1048 ID->Data = Canon->Data; 1049 } else { 1050 // Set the definition data of the canonical declaration, so other 1051 // redeclarations will see it. 1052 ID->getCanonicalDecl()->Data = ID->Data; 1053 1054 // We will rebuild this list lazily. 1055 ID->setIvarList(nullptr); 1056 } 1057 1058 // Note that we have deserialized a definition. 1059 Reader.PendingDefinitions.insert(ID); 1060 1061 // Note that we've loaded this Objective-C class. 1062 Reader.ObjCClassesLoaded.push_back(ID); 1063 } else { 1064 ID->Data = ID->getCanonicalDecl()->Data; 1065 } 1066 } 1067 1068 void ASTDeclReader::VisitObjCIvarDecl(ObjCIvarDecl *IVD) { 1069 VisitFieldDecl(IVD); 1070 IVD->setAccessControl((ObjCIvarDecl::AccessControl)Record.readInt()); 1071 // This field will be built lazily. 1072 IVD->setNextIvar(nullptr); 1073 bool synth = Record.readInt(); 1074 IVD->setSynthesize(synth); 1075 } 1076 1077 void ASTDeclReader::ReadObjCDefinitionData( 1078 struct ObjCProtocolDecl::DefinitionData &Data) { 1079 1080 unsigned NumProtoRefs = Record.readInt(); 1081 SmallVector<ObjCProtocolDecl *, 16> ProtoRefs; 1082 ProtoRefs.reserve(NumProtoRefs); 1083 for (unsigned I = 0; I != NumProtoRefs; ++I) 1084 ProtoRefs.push_back(ReadDeclAs<ObjCProtocolDecl>()); 1085 SmallVector<SourceLocation, 16> ProtoLocs; 1086 ProtoLocs.reserve(NumProtoRefs); 1087 for (unsigned I = 0; I != NumProtoRefs; ++I) 1088 ProtoLocs.push_back(ReadSourceLocation()); 1089 Data.ReferencedProtocols.set(ProtoRefs.data(), NumProtoRefs, 1090 ProtoLocs.data(), Reader.getContext()); 1091 } 1092 1093 void ASTDeclReader::MergeDefinitionData(ObjCProtocolDecl *D, 1094 struct ObjCProtocolDecl::DefinitionData &&NewDD) { 1095 // FIXME: odr checking? 1096 } 1097 1098 void ASTDeclReader::VisitObjCProtocolDecl(ObjCProtocolDecl *PD) { 1099 RedeclarableResult Redecl = VisitRedeclarable(PD); 1100 VisitObjCContainerDecl(PD); 1101 mergeRedeclarable(PD, Redecl); 1102 1103 if (Record.readInt()) { 1104 // Read the definition. 1105 PD->allocateDefinitionData(); 1106 1107 ReadObjCDefinitionData(PD->data()); 1108 1109 ObjCProtocolDecl *Canon = PD->getCanonicalDecl(); 1110 if (Canon->Data.getPointer()) { 1111 // If we already have a definition, keep the definition invariant and 1112 // merge the data. 1113 MergeDefinitionData(Canon, std::move(PD->data())); 1114 PD->Data = Canon->Data; 1115 } else { 1116 // Set the definition data of the canonical declaration, so other 1117 // redeclarations will see it. 1118 PD->getCanonicalDecl()->Data = PD->Data; 1119 } 1120 // Note that we have deserialized a definition. 1121 Reader.PendingDefinitions.insert(PD); 1122 } else { 1123 PD->Data = PD->getCanonicalDecl()->Data; 1124 } 1125 } 1126 1127 void ASTDeclReader::VisitObjCAtDefsFieldDecl(ObjCAtDefsFieldDecl *FD) { 1128 VisitFieldDecl(FD); 1129 } 1130 1131 void ASTDeclReader::VisitObjCCategoryDecl(ObjCCategoryDecl *CD) { 1132 VisitObjCContainerDecl(CD); 1133 CD->setCategoryNameLoc(ReadSourceLocation()); 1134 CD->setIvarLBraceLoc(ReadSourceLocation()); 1135 CD->setIvarRBraceLoc(ReadSourceLocation()); 1136 1137 // Note that this category has been deserialized. We do this before 1138 // deserializing the interface declaration, so that it will consider this 1139 /// category. 1140 Reader.CategoriesDeserialized.insert(CD); 1141 1142 CD->ClassInterface = ReadDeclAs<ObjCInterfaceDecl>(); 1143 CD->TypeParamList = ReadObjCTypeParamList(); 1144 unsigned NumProtoRefs = Record.readInt(); 1145 SmallVector<ObjCProtocolDecl *, 16> ProtoRefs; 1146 ProtoRefs.reserve(NumProtoRefs); 1147 for (unsigned I = 0; I != NumProtoRefs; ++I) 1148 ProtoRefs.push_back(ReadDeclAs<ObjCProtocolDecl>()); 1149 SmallVector<SourceLocation, 16> ProtoLocs; 1150 ProtoLocs.reserve(NumProtoRefs); 1151 for (unsigned I = 0; I != NumProtoRefs; ++I) 1152 ProtoLocs.push_back(ReadSourceLocation()); 1153 CD->setProtocolList(ProtoRefs.data(), NumProtoRefs, ProtoLocs.data(), 1154 Reader.getContext()); 1155 } 1156 1157 void ASTDeclReader::VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *CAD) { 1158 VisitNamedDecl(CAD); 1159 CAD->setClassInterface(ReadDeclAs<ObjCInterfaceDecl>()); 1160 } 1161 1162 void ASTDeclReader::VisitObjCPropertyDecl(ObjCPropertyDecl *D) { 1163 VisitNamedDecl(D); 1164 D->setAtLoc(ReadSourceLocation()); 1165 D->setLParenLoc(ReadSourceLocation()); 1166 QualType T = Record.readType(); 1167 TypeSourceInfo *TSI = GetTypeSourceInfo(); 1168 D->setType(T, TSI); 1169 D->setPropertyAttributes( 1170 (ObjCPropertyDecl::PropertyAttributeKind)Record.readInt()); 1171 D->setPropertyAttributesAsWritten( 1172 (ObjCPropertyDecl::PropertyAttributeKind)Record.readInt()); 1173 D->setPropertyImplementation( 1174 (ObjCPropertyDecl::PropertyControl)Record.readInt()); 1175 DeclarationName GetterName = Record.readDeclarationName(); 1176 SourceLocation GetterLoc = ReadSourceLocation(); 1177 D->setGetterName(GetterName.getObjCSelector(), GetterLoc); 1178 DeclarationName SetterName = Record.readDeclarationName(); 1179 SourceLocation SetterLoc = ReadSourceLocation(); 1180 D->setSetterName(SetterName.getObjCSelector(), SetterLoc); 1181 D->setGetterMethodDecl(ReadDeclAs<ObjCMethodDecl>()); 1182 D->setSetterMethodDecl(ReadDeclAs<ObjCMethodDecl>()); 1183 D->setPropertyIvarDecl(ReadDeclAs<ObjCIvarDecl>()); 1184 } 1185 1186 void ASTDeclReader::VisitObjCImplDecl(ObjCImplDecl *D) { 1187 VisitObjCContainerDecl(D); 1188 D->setClassInterface(ReadDeclAs<ObjCInterfaceDecl>()); 1189 } 1190 1191 void ASTDeclReader::VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D) { 1192 VisitObjCImplDecl(D); 1193 D->CategoryNameLoc = ReadSourceLocation(); 1194 } 1195 1196 void ASTDeclReader::VisitObjCImplementationDecl(ObjCImplementationDecl *D) { 1197 VisitObjCImplDecl(D); 1198 D->setSuperClass(ReadDeclAs<ObjCInterfaceDecl>()); 1199 D->SuperLoc = ReadSourceLocation(); 1200 D->setIvarLBraceLoc(ReadSourceLocation()); 1201 D->setIvarRBraceLoc(ReadSourceLocation()); 1202 D->setHasNonZeroConstructors(Record.readInt()); 1203 D->setHasDestructors(Record.readInt()); 1204 D->NumIvarInitializers = Record.readInt(); 1205 if (D->NumIvarInitializers) 1206 D->IvarInitializers = ReadGlobalOffset(); 1207 } 1208 1209 void ASTDeclReader::VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D) { 1210 VisitDecl(D); 1211 D->setAtLoc(ReadSourceLocation()); 1212 D->setPropertyDecl(ReadDeclAs<ObjCPropertyDecl>()); 1213 D->PropertyIvarDecl = ReadDeclAs<ObjCIvarDecl>(); 1214 D->IvarLoc = ReadSourceLocation(); 1215 D->setGetterCXXConstructor(Record.readExpr()); 1216 D->setSetterCXXAssignment(Record.readExpr()); 1217 } 1218 1219 void ASTDeclReader::VisitFieldDecl(FieldDecl *FD) { 1220 VisitDeclaratorDecl(FD); 1221 FD->Mutable = Record.readInt(); 1222 1223 if (auto ISK = static_cast<FieldDecl::InitStorageKind>(Record.readInt())) { 1224 FD->InitStorage.setInt(ISK); 1225 FD->InitStorage.setPointer(ISK == FieldDecl::ISK_CapturedVLAType 1226 ? Record.readType().getAsOpaquePtr() 1227 : Record.readExpr()); 1228 } 1229 1230 if (auto *BW = Record.readExpr()) 1231 FD->setBitWidth(BW); 1232 1233 if (!FD->getDeclName()) { 1234 if (FieldDecl *Tmpl = ReadDeclAs<FieldDecl>()) 1235 Reader.getContext().setInstantiatedFromUnnamedFieldDecl(FD, Tmpl); 1236 } 1237 mergeMergeable(FD); 1238 } 1239 1240 void ASTDeclReader::VisitMSPropertyDecl(MSPropertyDecl *PD) { 1241 VisitDeclaratorDecl(PD); 1242 PD->GetterId = Record.getIdentifierInfo(); 1243 PD->SetterId = Record.getIdentifierInfo(); 1244 } 1245 1246 void ASTDeclReader::VisitIndirectFieldDecl(IndirectFieldDecl *FD) { 1247 VisitValueDecl(FD); 1248 1249 FD->ChainingSize = Record.readInt(); 1250 assert(FD->ChainingSize >= 2 && "Anonymous chaining must be >= 2"); 1251 FD->Chaining = new (Reader.getContext())NamedDecl*[FD->ChainingSize]; 1252 1253 for (unsigned I = 0; I != FD->ChainingSize; ++I) 1254 FD->Chaining[I] = ReadDeclAs<NamedDecl>(); 1255 1256 mergeMergeable(FD); 1257 } 1258 1259 ASTDeclReader::RedeclarableResult ASTDeclReader::VisitVarDeclImpl(VarDecl *VD) { 1260 RedeclarableResult Redecl = VisitRedeclarable(VD); 1261 VisitDeclaratorDecl(VD); 1262 1263 VD->VarDeclBits.SClass = (StorageClass)Record.readInt(); 1264 VD->VarDeclBits.TSCSpec = Record.readInt(); 1265 VD->VarDeclBits.InitStyle = Record.readInt(); 1266 if (!isa<ParmVarDecl>(VD)) { 1267 VD->NonParmVarDeclBits.IsThisDeclarationADemotedDefinition = 1268 Record.readInt(); 1269 VD->NonParmVarDeclBits.ExceptionVar = Record.readInt(); 1270 VD->NonParmVarDeclBits.NRVOVariable = Record.readInt(); 1271 VD->NonParmVarDeclBits.CXXForRangeDecl = Record.readInt(); 1272 VD->NonParmVarDeclBits.ARCPseudoStrong = Record.readInt(); 1273 VD->NonParmVarDeclBits.IsInline = Record.readInt(); 1274 VD->NonParmVarDeclBits.IsInlineSpecified = Record.readInt(); 1275 VD->NonParmVarDeclBits.IsConstexpr = Record.readInt(); 1276 VD->NonParmVarDeclBits.IsInitCapture = Record.readInt(); 1277 VD->NonParmVarDeclBits.PreviousDeclInSameBlockScope = Record.readInt(); 1278 VD->NonParmVarDeclBits.ImplicitParamKind = Record.readInt(); 1279 } 1280 Linkage VarLinkage = Linkage(Record.readInt()); 1281 VD->setCachedLinkage(VarLinkage); 1282 1283 // Reconstruct the one piece of the IdentifierNamespace that we need. 1284 if (VD->getStorageClass() == SC_Extern && VarLinkage != NoLinkage && 1285 VD->getLexicalDeclContext()->isFunctionOrMethod()) 1286 VD->setLocalExternDecl(); 1287 1288 if (uint64_t Val = Record.readInt()) { 1289 VD->setInit(Record.readExpr()); 1290 if (Val > 1) { // IsInitKnownICE = 1, IsInitNotICE = 2, IsInitICE = 3 1291 EvaluatedStmt *Eval = VD->ensureEvaluatedStmt(); 1292 Eval->CheckedICE = true; 1293 Eval->IsICE = Val == 3; 1294 } 1295 } 1296 1297 if (VD->getStorageDuration() == SD_Static && Record.readInt()) 1298 Reader.DefinitionSource[VD] = Loc.F->Kind == ModuleKind::MK_MainFile; 1299 1300 enum VarKind { 1301 VarNotTemplate = 0, VarTemplate, StaticDataMemberSpecialization 1302 }; 1303 switch ((VarKind)Record.readInt()) { 1304 case VarNotTemplate: 1305 // Only true variables (not parameters or implicit parameters) can be 1306 // merged; the other kinds are not really redeclarable at all. 1307 if (!isa<ParmVarDecl>(VD) && !isa<ImplicitParamDecl>(VD) && 1308 !isa<VarTemplateSpecializationDecl>(VD)) 1309 mergeRedeclarable(VD, Redecl); 1310 break; 1311 case VarTemplate: 1312 // Merged when we merge the template. 1313 VD->setDescribedVarTemplate(ReadDeclAs<VarTemplateDecl>()); 1314 break; 1315 case StaticDataMemberSpecialization: { // HasMemberSpecializationInfo. 1316 VarDecl *Tmpl = ReadDeclAs<VarDecl>(); 1317 TemplateSpecializationKind TSK = 1318 (TemplateSpecializationKind)Record.readInt(); 1319 SourceLocation POI = ReadSourceLocation(); 1320 Reader.getContext().setInstantiatedFromStaticDataMember(VD, Tmpl, TSK,POI); 1321 mergeRedeclarable(VD, Redecl); 1322 break; 1323 } 1324 } 1325 1326 return Redecl; 1327 } 1328 1329 void ASTDeclReader::VisitImplicitParamDecl(ImplicitParamDecl *PD) { 1330 VisitVarDecl(PD); 1331 } 1332 1333 void ASTDeclReader::VisitParmVarDecl(ParmVarDecl *PD) { 1334 VisitVarDecl(PD); 1335 unsigned isObjCMethodParam = Record.readInt(); 1336 unsigned scopeDepth = Record.readInt(); 1337 unsigned scopeIndex = Record.readInt(); 1338 unsigned declQualifier = Record.readInt(); 1339 if (isObjCMethodParam) { 1340 assert(scopeDepth == 0); 1341 PD->setObjCMethodScopeInfo(scopeIndex); 1342 PD->ParmVarDeclBits.ScopeDepthOrObjCQuals = declQualifier; 1343 } else { 1344 PD->setScopeInfo(scopeDepth, scopeIndex); 1345 } 1346 PD->ParmVarDeclBits.IsKNRPromoted = Record.readInt(); 1347 PD->ParmVarDeclBits.HasInheritedDefaultArg = Record.readInt(); 1348 if (Record.readInt()) // hasUninstantiatedDefaultArg. 1349 PD->setUninstantiatedDefaultArg(Record.readExpr()); 1350 1351 // FIXME: If this is a redeclaration of a function from another module, handle 1352 // inheritance of default arguments. 1353 } 1354 1355 void ASTDeclReader::VisitDecompositionDecl(DecompositionDecl *DD) { 1356 VisitVarDecl(DD); 1357 BindingDecl **BDs = DD->getTrailingObjects<BindingDecl*>(); 1358 for (unsigned I = 0; I != DD->NumBindings; ++I) 1359 BDs[I] = ReadDeclAs<BindingDecl>(); 1360 } 1361 1362 void ASTDeclReader::VisitBindingDecl(BindingDecl *BD) { 1363 VisitValueDecl(BD); 1364 BD->Binding = Record.readExpr(); 1365 } 1366 1367 void ASTDeclReader::VisitFileScopeAsmDecl(FileScopeAsmDecl *AD) { 1368 VisitDecl(AD); 1369 AD->setAsmString(cast<StringLiteral>(Record.readExpr())); 1370 AD->setRParenLoc(ReadSourceLocation()); 1371 } 1372 1373 void ASTDeclReader::VisitBlockDecl(BlockDecl *BD) { 1374 VisitDecl(BD); 1375 BD->setBody(cast_or_null<CompoundStmt>(Record.readStmt())); 1376 BD->setSignatureAsWritten(GetTypeSourceInfo()); 1377 unsigned NumParams = Record.readInt(); 1378 SmallVector<ParmVarDecl *, 16> Params; 1379 Params.reserve(NumParams); 1380 for (unsigned I = 0; I != NumParams; ++I) 1381 Params.push_back(ReadDeclAs<ParmVarDecl>()); 1382 BD->setParams(Params); 1383 1384 BD->setIsVariadic(Record.readInt()); 1385 BD->setBlockMissingReturnType(Record.readInt()); 1386 BD->setIsConversionFromLambda(Record.readInt()); 1387 1388 bool capturesCXXThis = Record.readInt(); 1389 unsigned numCaptures = Record.readInt(); 1390 SmallVector<BlockDecl::Capture, 16> captures; 1391 captures.reserve(numCaptures); 1392 for (unsigned i = 0; i != numCaptures; ++i) { 1393 VarDecl *decl = ReadDeclAs<VarDecl>(); 1394 unsigned flags = Record.readInt(); 1395 bool byRef = (flags & 1); 1396 bool nested = (flags & 2); 1397 Expr *copyExpr = ((flags & 4) ? Record.readExpr() : nullptr); 1398 1399 captures.push_back(BlockDecl::Capture(decl, byRef, nested, copyExpr)); 1400 } 1401 BD->setCaptures(Reader.getContext(), captures, capturesCXXThis); 1402 } 1403 1404 void ASTDeclReader::VisitCapturedDecl(CapturedDecl *CD) { 1405 VisitDecl(CD); 1406 unsigned ContextParamPos = Record.readInt(); 1407 CD->setNothrow(Record.readInt() != 0); 1408 // Body is set by VisitCapturedStmt. 1409 for (unsigned I = 0; I < CD->NumParams; ++I) { 1410 if (I != ContextParamPos) 1411 CD->setParam(I, ReadDeclAs<ImplicitParamDecl>()); 1412 else 1413 CD->setContextParam(I, ReadDeclAs<ImplicitParamDecl>()); 1414 } 1415 } 1416 1417 void ASTDeclReader::VisitLinkageSpecDecl(LinkageSpecDecl *D) { 1418 VisitDecl(D); 1419 D->setLanguage((LinkageSpecDecl::LanguageIDs)Record.readInt()); 1420 D->setExternLoc(ReadSourceLocation()); 1421 D->setRBraceLoc(ReadSourceLocation()); 1422 } 1423 1424 void ASTDeclReader::VisitExportDecl(ExportDecl *D) { 1425 VisitDecl(D); 1426 D->RBraceLoc = ReadSourceLocation(); 1427 } 1428 1429 void ASTDeclReader::VisitLabelDecl(LabelDecl *D) { 1430 VisitNamedDecl(D); 1431 D->setLocStart(ReadSourceLocation()); 1432 } 1433 1434 void ASTDeclReader::VisitNamespaceDecl(NamespaceDecl *D) { 1435 RedeclarableResult Redecl = VisitRedeclarable(D); 1436 VisitNamedDecl(D); 1437 D->setInline(Record.readInt()); 1438 D->LocStart = ReadSourceLocation(); 1439 D->RBraceLoc = ReadSourceLocation(); 1440 1441 // Defer loading the anonymous namespace until we've finished merging 1442 // this namespace; loading it might load a later declaration of the 1443 // same namespace, and we have an invariant that older declarations 1444 // get merged before newer ones try to merge. 1445 GlobalDeclID AnonNamespace = 0; 1446 if (Redecl.getFirstID() == ThisDeclID) { 1447 AnonNamespace = ReadDeclID(); 1448 } else { 1449 // Link this namespace back to the first declaration, which has already 1450 // been deserialized. 1451 D->AnonOrFirstNamespaceAndInline.setPointer(D->getFirstDecl()); 1452 } 1453 1454 mergeRedeclarable(D, Redecl); 1455 1456 if (AnonNamespace) { 1457 // Each module has its own anonymous namespace, which is disjoint from 1458 // any other module's anonymous namespaces, so don't attach the anonymous 1459 // namespace at all. 1460 NamespaceDecl *Anon = cast<NamespaceDecl>(Reader.GetDecl(AnonNamespace)); 1461 if (!Record.isModule()) 1462 D->setAnonymousNamespace(Anon); 1463 } 1464 } 1465 1466 void ASTDeclReader::VisitNamespaceAliasDecl(NamespaceAliasDecl *D) { 1467 RedeclarableResult Redecl = VisitRedeclarable(D); 1468 VisitNamedDecl(D); 1469 D->NamespaceLoc = ReadSourceLocation(); 1470 D->IdentLoc = ReadSourceLocation(); 1471 D->QualifierLoc = Record.readNestedNameSpecifierLoc(); 1472 D->Namespace = ReadDeclAs<NamedDecl>(); 1473 mergeRedeclarable(D, Redecl); 1474 } 1475 1476 void ASTDeclReader::VisitUsingDecl(UsingDecl *D) { 1477 VisitNamedDecl(D); 1478 D->setUsingLoc(ReadSourceLocation()); 1479 D->QualifierLoc = Record.readNestedNameSpecifierLoc(); 1480 ReadDeclarationNameLoc(D->DNLoc, D->getDeclName()); 1481 D->FirstUsingShadow.setPointer(ReadDeclAs<UsingShadowDecl>()); 1482 D->setTypename(Record.readInt()); 1483 if (NamedDecl *Pattern = ReadDeclAs<NamedDecl>()) 1484 Reader.getContext().setInstantiatedFromUsingDecl(D, Pattern); 1485 mergeMergeable(D); 1486 } 1487 1488 void ASTDeclReader::VisitUsingPackDecl(UsingPackDecl *D) { 1489 VisitNamedDecl(D); 1490 D->InstantiatedFrom = ReadDeclAs<NamedDecl>(); 1491 NamedDecl **Expansions = D->getTrailingObjects<NamedDecl*>(); 1492 for (unsigned I = 0; I != D->NumExpansions; ++I) 1493 Expansions[I] = ReadDeclAs<NamedDecl>(); 1494 mergeMergeable(D); 1495 } 1496 1497 void ASTDeclReader::VisitUsingShadowDecl(UsingShadowDecl *D) { 1498 RedeclarableResult Redecl = VisitRedeclarable(D); 1499 VisitNamedDecl(D); 1500 D->setTargetDecl(ReadDeclAs<NamedDecl>()); 1501 D->UsingOrNextShadow = ReadDeclAs<NamedDecl>(); 1502 UsingShadowDecl *Pattern = ReadDeclAs<UsingShadowDecl>(); 1503 if (Pattern) 1504 Reader.getContext().setInstantiatedFromUsingShadowDecl(D, Pattern); 1505 mergeRedeclarable(D, Redecl); 1506 } 1507 1508 void ASTDeclReader::VisitConstructorUsingShadowDecl( 1509 ConstructorUsingShadowDecl *D) { 1510 VisitUsingShadowDecl(D); 1511 D->NominatedBaseClassShadowDecl = ReadDeclAs<ConstructorUsingShadowDecl>(); 1512 D->ConstructedBaseClassShadowDecl = ReadDeclAs<ConstructorUsingShadowDecl>(); 1513 D->IsVirtual = Record.readInt(); 1514 } 1515 1516 void ASTDeclReader::VisitUsingDirectiveDecl(UsingDirectiveDecl *D) { 1517 VisitNamedDecl(D); 1518 D->UsingLoc = ReadSourceLocation(); 1519 D->NamespaceLoc = ReadSourceLocation(); 1520 D->QualifierLoc = Record.readNestedNameSpecifierLoc(); 1521 D->NominatedNamespace = ReadDeclAs<NamedDecl>(); 1522 D->CommonAncestor = ReadDeclAs<DeclContext>(); 1523 } 1524 1525 void ASTDeclReader::VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D) { 1526 VisitValueDecl(D); 1527 D->setUsingLoc(ReadSourceLocation()); 1528 D->QualifierLoc = Record.readNestedNameSpecifierLoc(); 1529 ReadDeclarationNameLoc(D->DNLoc, D->getDeclName()); 1530 D->EllipsisLoc = ReadSourceLocation(); 1531 mergeMergeable(D); 1532 } 1533 1534 void ASTDeclReader::VisitUnresolvedUsingTypenameDecl( 1535 UnresolvedUsingTypenameDecl *D) { 1536 VisitTypeDecl(D); 1537 D->TypenameLocation = ReadSourceLocation(); 1538 D->QualifierLoc = Record.readNestedNameSpecifierLoc(); 1539 D->EllipsisLoc = ReadSourceLocation(); 1540 mergeMergeable(D); 1541 } 1542 1543 void ASTDeclReader::ReadCXXDefinitionData( 1544 struct CXXRecordDecl::DefinitionData &Data, const CXXRecordDecl *D) { 1545 // Note: the caller has deserialized the IsLambda bit already. 1546 Data.UserDeclaredConstructor = Record.readInt(); 1547 Data.UserDeclaredSpecialMembers = Record.readInt(); 1548 Data.Aggregate = Record.readInt(); 1549 Data.PlainOldData = Record.readInt(); 1550 Data.Empty = Record.readInt(); 1551 Data.Polymorphic = Record.readInt(); 1552 Data.Abstract = Record.readInt(); 1553 Data.IsStandardLayout = Record.readInt(); 1554 Data.HasNoNonEmptyBases = Record.readInt(); 1555 Data.HasPrivateFields = Record.readInt(); 1556 Data.HasProtectedFields = Record.readInt(); 1557 Data.HasPublicFields = Record.readInt(); 1558 Data.HasMutableFields = Record.readInt(); 1559 Data.HasVariantMembers = Record.readInt(); 1560 Data.HasOnlyCMembers = Record.readInt(); 1561 Data.HasInClassInitializer = Record.readInt(); 1562 Data.HasUninitializedReferenceMember = Record.readInt(); 1563 Data.HasUninitializedFields = Record.readInt(); 1564 Data.HasInheritedConstructor = Record.readInt(); 1565 Data.HasInheritedAssignment = Record.readInt(); 1566 Data.NeedOverloadResolutionForCopyConstructor = Record.readInt(); 1567 Data.NeedOverloadResolutionForMoveConstructor = Record.readInt(); 1568 Data.NeedOverloadResolutionForMoveAssignment = Record.readInt(); 1569 Data.NeedOverloadResolutionForDestructor = Record.readInt(); 1570 Data.DefaultedCopyConstructorIsDeleted = Record.readInt(); 1571 Data.DefaultedMoveConstructorIsDeleted = Record.readInt(); 1572 Data.DefaultedMoveAssignmentIsDeleted = Record.readInt(); 1573 Data.DefaultedDestructorIsDeleted = Record.readInt(); 1574 Data.HasTrivialSpecialMembers = Record.readInt(); 1575 Data.DeclaredNonTrivialSpecialMembers = Record.readInt(); 1576 Data.HasIrrelevantDestructor = Record.readInt(); 1577 Data.HasConstexprNonCopyMoveConstructor = Record.readInt(); 1578 Data.HasDefaultedDefaultConstructor = Record.readInt(); 1579 Data.CanPassInRegisters = Record.readInt(); 1580 Data.DefaultedDefaultConstructorIsConstexpr = Record.readInt(); 1581 Data.HasConstexprDefaultConstructor = Record.readInt(); 1582 Data.HasNonLiteralTypeFieldsOrBases = Record.readInt(); 1583 Data.ComputedVisibleConversions = Record.readInt(); 1584 Data.UserProvidedDefaultConstructor = Record.readInt(); 1585 Data.DeclaredSpecialMembers = Record.readInt(); 1586 Data.ImplicitCopyConstructorCanHaveConstParamForVBase = Record.readInt(); 1587 Data.ImplicitCopyConstructorCanHaveConstParamForNonVBase = Record.readInt(); 1588 Data.ImplicitCopyAssignmentHasConstParam = Record.readInt(); 1589 Data.HasDeclaredCopyConstructorWithConstParam = Record.readInt(); 1590 Data.HasDeclaredCopyAssignmentWithConstParam = Record.readInt(); 1591 Data.ODRHash = Record.readInt(); 1592 Data.HasODRHash = true; 1593 1594 if (Record.readInt()) 1595 Reader.DefinitionSource[D] = Loc.F->Kind == ModuleKind::MK_MainFile; 1596 1597 Data.NumBases = Record.readInt(); 1598 if (Data.NumBases) 1599 Data.Bases = ReadGlobalOffset(); 1600 Data.NumVBases = Record.readInt(); 1601 if (Data.NumVBases) 1602 Data.VBases = ReadGlobalOffset(); 1603 1604 Record.readUnresolvedSet(Data.Conversions); 1605 Record.readUnresolvedSet(Data.VisibleConversions); 1606 assert(Data.Definition && "Data.Definition should be already set!"); 1607 Data.FirstFriend = ReadDeclID(); 1608 1609 if (Data.IsLambda) { 1610 typedef LambdaCapture Capture; 1611 CXXRecordDecl::LambdaDefinitionData &Lambda 1612 = static_cast<CXXRecordDecl::LambdaDefinitionData &>(Data); 1613 Lambda.Dependent = Record.readInt(); 1614 Lambda.IsGenericLambda = Record.readInt(); 1615 Lambda.CaptureDefault = Record.readInt(); 1616 Lambda.NumCaptures = Record.readInt(); 1617 Lambda.NumExplicitCaptures = Record.readInt(); 1618 Lambda.ManglingNumber = Record.readInt(); 1619 Lambda.ContextDecl = ReadDeclID(); 1620 Lambda.Captures = (Capture *)Reader.getContext().Allocate( 1621 sizeof(Capture) * Lambda.NumCaptures); 1622 Capture *ToCapture = Lambda.Captures; 1623 Lambda.MethodTyInfo = GetTypeSourceInfo(); 1624 for (unsigned I = 0, N = Lambda.NumCaptures; I != N; ++I) { 1625 SourceLocation Loc = ReadSourceLocation(); 1626 bool IsImplicit = Record.readInt(); 1627 LambdaCaptureKind Kind = static_cast<LambdaCaptureKind>(Record.readInt()); 1628 switch (Kind) { 1629 case LCK_StarThis: 1630 case LCK_This: 1631 case LCK_VLAType: 1632 *ToCapture++ = Capture(Loc, IsImplicit, Kind, nullptr,SourceLocation()); 1633 break; 1634 case LCK_ByCopy: 1635 case LCK_ByRef: 1636 VarDecl *Var = ReadDeclAs<VarDecl>(); 1637 SourceLocation EllipsisLoc = ReadSourceLocation(); 1638 *ToCapture++ = Capture(Loc, IsImplicit, Kind, Var, EllipsisLoc); 1639 break; 1640 } 1641 } 1642 } 1643 } 1644 1645 void ASTDeclReader::MergeDefinitionData( 1646 CXXRecordDecl *D, struct CXXRecordDecl::DefinitionData &&MergeDD) { 1647 assert(D->DefinitionData && 1648 "merging class definition into non-definition"); 1649 auto &DD = *D->DefinitionData; 1650 1651 if (DD.Definition != MergeDD.Definition) { 1652 // Track that we merged the definitions. 1653 Reader.MergedDeclContexts.insert(std::make_pair(MergeDD.Definition, 1654 DD.Definition)); 1655 Reader.PendingDefinitions.erase(MergeDD.Definition); 1656 MergeDD.Definition->IsCompleteDefinition = false; 1657 Reader.mergeDefinitionVisibility(DD.Definition, MergeDD.Definition); 1658 assert(Reader.Lookups.find(MergeDD.Definition) == Reader.Lookups.end() && 1659 "already loaded pending lookups for merged definition"); 1660 } 1661 1662 auto PFDI = Reader.PendingFakeDefinitionData.find(&DD); 1663 if (PFDI != Reader.PendingFakeDefinitionData.end() && 1664 PFDI->second == ASTReader::PendingFakeDefinitionKind::Fake) { 1665 // We faked up this definition data because we found a class for which we'd 1666 // not yet loaded the definition. Replace it with the real thing now. 1667 assert(!DD.IsLambda && !MergeDD.IsLambda && "faked up lambda definition?"); 1668 PFDI->second = ASTReader::PendingFakeDefinitionKind::FakeLoaded; 1669 1670 // Don't change which declaration is the definition; that is required 1671 // to be invariant once we select it. 1672 auto *Def = DD.Definition; 1673 DD = std::move(MergeDD); 1674 DD.Definition = Def; 1675 return; 1676 } 1677 1678 // FIXME: Move this out into a .def file? 1679 bool DetectedOdrViolation = false; 1680 #define OR_FIELD(Field) DD.Field |= MergeDD.Field; 1681 #define MATCH_FIELD(Field) \ 1682 DetectedOdrViolation |= DD.Field != MergeDD.Field; \ 1683 OR_FIELD(Field) 1684 MATCH_FIELD(UserDeclaredConstructor) 1685 MATCH_FIELD(UserDeclaredSpecialMembers) 1686 MATCH_FIELD(Aggregate) 1687 MATCH_FIELD(PlainOldData) 1688 MATCH_FIELD(Empty) 1689 MATCH_FIELD(Polymorphic) 1690 MATCH_FIELD(Abstract) 1691 MATCH_FIELD(IsStandardLayout) 1692 MATCH_FIELD(HasNoNonEmptyBases) 1693 MATCH_FIELD(HasPrivateFields) 1694 MATCH_FIELD(HasProtectedFields) 1695 MATCH_FIELD(HasPublicFields) 1696 MATCH_FIELD(HasMutableFields) 1697 MATCH_FIELD(HasVariantMembers) 1698 MATCH_FIELD(HasOnlyCMembers) 1699 MATCH_FIELD(HasInClassInitializer) 1700 MATCH_FIELD(HasUninitializedReferenceMember) 1701 MATCH_FIELD(HasUninitializedFields) 1702 MATCH_FIELD(HasInheritedConstructor) 1703 MATCH_FIELD(HasInheritedAssignment) 1704 MATCH_FIELD(NeedOverloadResolutionForCopyConstructor) 1705 MATCH_FIELD(NeedOverloadResolutionForMoveConstructor) 1706 MATCH_FIELD(NeedOverloadResolutionForMoveAssignment) 1707 MATCH_FIELD(NeedOverloadResolutionForDestructor) 1708 MATCH_FIELD(DefaultedCopyConstructorIsDeleted) 1709 MATCH_FIELD(DefaultedMoveConstructorIsDeleted) 1710 MATCH_FIELD(DefaultedMoveAssignmentIsDeleted) 1711 MATCH_FIELD(DefaultedDestructorIsDeleted) 1712 OR_FIELD(HasTrivialSpecialMembers) 1713 OR_FIELD(DeclaredNonTrivialSpecialMembers) 1714 MATCH_FIELD(HasIrrelevantDestructor) 1715 OR_FIELD(HasConstexprNonCopyMoveConstructor) 1716 OR_FIELD(HasDefaultedDefaultConstructor) 1717 MATCH_FIELD(CanPassInRegisters) 1718 MATCH_FIELD(DefaultedDefaultConstructorIsConstexpr) 1719 OR_FIELD(HasConstexprDefaultConstructor) 1720 MATCH_FIELD(HasNonLiteralTypeFieldsOrBases) 1721 // ComputedVisibleConversions is handled below. 1722 MATCH_FIELD(UserProvidedDefaultConstructor) 1723 OR_FIELD(DeclaredSpecialMembers) 1724 MATCH_FIELD(ImplicitCopyConstructorCanHaveConstParamForVBase) 1725 MATCH_FIELD(ImplicitCopyConstructorCanHaveConstParamForNonVBase) 1726 MATCH_FIELD(ImplicitCopyAssignmentHasConstParam) 1727 OR_FIELD(HasDeclaredCopyConstructorWithConstParam) 1728 OR_FIELD(HasDeclaredCopyAssignmentWithConstParam) 1729 MATCH_FIELD(IsLambda) 1730 #undef OR_FIELD 1731 #undef MATCH_FIELD 1732 1733 if (DD.NumBases != MergeDD.NumBases || DD.NumVBases != MergeDD.NumVBases) 1734 DetectedOdrViolation = true; 1735 // FIXME: Issue a diagnostic if the base classes don't match when we come 1736 // to lazily load them. 1737 1738 // FIXME: Issue a diagnostic if the list of conversion functions doesn't 1739 // match when we come to lazily load them. 1740 if (MergeDD.ComputedVisibleConversions && !DD.ComputedVisibleConversions) { 1741 DD.VisibleConversions = std::move(MergeDD.VisibleConversions); 1742 DD.ComputedVisibleConversions = true; 1743 } 1744 1745 // FIXME: Issue a diagnostic if FirstFriend doesn't match when we come to 1746 // lazily load it. 1747 1748 if (DD.IsLambda) { 1749 // FIXME: ODR-checking for merging lambdas (this happens, for instance, 1750 // when they occur within the body of a function template specialization). 1751 } 1752 1753 if (D->getODRHash() != MergeDD.ODRHash) { 1754 DetectedOdrViolation = true; 1755 } 1756 1757 if (DetectedOdrViolation) 1758 Reader.PendingOdrMergeFailures[DD.Definition].push_back( 1759 {MergeDD.Definition, &MergeDD}); 1760 } 1761 1762 void ASTDeclReader::ReadCXXRecordDefinition(CXXRecordDecl *D, bool Update) { 1763 struct CXXRecordDecl::DefinitionData *DD; 1764 ASTContext &C = Reader.getContext(); 1765 1766 // Determine whether this is a lambda closure type, so that we can 1767 // allocate the appropriate DefinitionData structure. 1768 bool IsLambda = Record.readInt(); 1769 if (IsLambda) 1770 DD = new (C) CXXRecordDecl::LambdaDefinitionData(D, nullptr, false, false, 1771 LCD_None); 1772 else 1773 DD = new (C) struct CXXRecordDecl::DefinitionData(D); 1774 1775 ReadCXXDefinitionData(*DD, D); 1776 1777 // We might already have a definition for this record. This can happen either 1778 // because we're reading an update record, or because we've already done some 1779 // merging. Either way, just merge into it. 1780 CXXRecordDecl *Canon = D->getCanonicalDecl(); 1781 if (Canon->DefinitionData) { 1782 MergeDefinitionData(Canon, std::move(*DD)); 1783 D->DefinitionData = Canon->DefinitionData; 1784 return; 1785 } 1786 1787 // Mark this declaration as being a definition. 1788 D->IsCompleteDefinition = true; 1789 D->DefinitionData = DD; 1790 1791 // If this is not the first declaration or is an update record, we can have 1792 // other redeclarations already. Make a note that we need to propagate the 1793 // DefinitionData pointer onto them. 1794 if (Update || Canon != D) { 1795 Canon->DefinitionData = D->DefinitionData; 1796 Reader.PendingDefinitions.insert(D); 1797 } 1798 } 1799 1800 ASTDeclReader::RedeclarableResult 1801 ASTDeclReader::VisitCXXRecordDeclImpl(CXXRecordDecl *D) { 1802 RedeclarableResult Redecl = VisitRecordDeclImpl(D); 1803 1804 ASTContext &C = Reader.getContext(); 1805 1806 enum CXXRecKind { 1807 CXXRecNotTemplate = 0, CXXRecTemplate, CXXRecMemberSpecialization 1808 }; 1809 switch ((CXXRecKind)Record.readInt()) { 1810 case CXXRecNotTemplate: 1811 // Merged when we merge the folding set entry in the primary template. 1812 if (!isa<ClassTemplateSpecializationDecl>(D)) 1813 mergeRedeclarable(D, Redecl); 1814 break; 1815 case CXXRecTemplate: { 1816 // Merged when we merge the template. 1817 ClassTemplateDecl *Template = ReadDeclAs<ClassTemplateDecl>(); 1818 D->TemplateOrInstantiation = Template; 1819 if (!Template->getTemplatedDecl()) { 1820 // We've not actually loaded the ClassTemplateDecl yet, because we're 1821 // currently being loaded as its pattern. Rely on it to set up our 1822 // TypeForDecl (see VisitClassTemplateDecl). 1823 // 1824 // Beware: we do not yet know our canonical declaration, and may still 1825 // get merged once the surrounding class template has got off the ground. 1826 TypeIDForTypeDecl = 0; 1827 } 1828 break; 1829 } 1830 case CXXRecMemberSpecialization: { 1831 CXXRecordDecl *RD = ReadDeclAs<CXXRecordDecl>(); 1832 TemplateSpecializationKind TSK = 1833 (TemplateSpecializationKind)Record.readInt(); 1834 SourceLocation POI = ReadSourceLocation(); 1835 MemberSpecializationInfo *MSI = new (C) MemberSpecializationInfo(RD, TSK); 1836 MSI->setPointOfInstantiation(POI); 1837 D->TemplateOrInstantiation = MSI; 1838 mergeRedeclarable(D, Redecl); 1839 break; 1840 } 1841 } 1842 1843 bool WasDefinition = Record.readInt(); 1844 if (WasDefinition) 1845 ReadCXXRecordDefinition(D, /*Update*/false); 1846 else 1847 // Propagate DefinitionData pointer from the canonical declaration. 1848 D->DefinitionData = D->getCanonicalDecl()->DefinitionData; 1849 1850 // Lazily load the key function to avoid deserializing every method so we can 1851 // compute it. 1852 if (WasDefinition) { 1853 DeclID KeyFn = ReadDeclID(); 1854 if (KeyFn && D->IsCompleteDefinition) 1855 // FIXME: This is wrong for the ARM ABI, where some other module may have 1856 // made this function no longer be a key function. We need an update 1857 // record or similar for that case. 1858 C.KeyFunctions[D] = KeyFn; 1859 } 1860 1861 return Redecl; 1862 } 1863 1864 void ASTDeclReader::VisitCXXDeductionGuideDecl(CXXDeductionGuideDecl *D) { 1865 VisitFunctionDecl(D); 1866 } 1867 1868 void ASTDeclReader::VisitCXXMethodDecl(CXXMethodDecl *D) { 1869 VisitFunctionDecl(D); 1870 1871 unsigned NumOverridenMethods = Record.readInt(); 1872 if (D->isCanonicalDecl()) { 1873 while (NumOverridenMethods--) { 1874 // Avoid invariant checking of CXXMethodDecl::addOverriddenMethod, 1875 // MD may be initializing. 1876 if (CXXMethodDecl *MD = ReadDeclAs<CXXMethodDecl>()) 1877 Reader.getContext().addOverriddenMethod(D, MD->getCanonicalDecl()); 1878 } 1879 } else { 1880 // We don't care about which declarations this used to override; we get 1881 // the relevant information from the canonical declaration. 1882 Record.skipInts(NumOverridenMethods); 1883 } 1884 } 1885 1886 void ASTDeclReader::VisitCXXConstructorDecl(CXXConstructorDecl *D) { 1887 // We need the inherited constructor information to merge the declaration, 1888 // so we have to read it before we call VisitCXXMethodDecl. 1889 if (D->isInheritingConstructor()) { 1890 auto *Shadow = ReadDeclAs<ConstructorUsingShadowDecl>(); 1891 auto *Ctor = ReadDeclAs<CXXConstructorDecl>(); 1892 *D->getTrailingObjects<InheritedConstructor>() = 1893 InheritedConstructor(Shadow, Ctor); 1894 } 1895 1896 VisitCXXMethodDecl(D); 1897 } 1898 1899 void ASTDeclReader::VisitCXXDestructorDecl(CXXDestructorDecl *D) { 1900 VisitCXXMethodDecl(D); 1901 1902 if (auto *OperatorDelete = ReadDeclAs<FunctionDecl>()) { 1903 auto *Canon = cast<CXXDestructorDecl>(D->getCanonicalDecl()); 1904 // FIXME: Check consistency if we have an old and new operator delete. 1905 if (!Canon->OperatorDelete) 1906 Canon->OperatorDelete = OperatorDelete; 1907 } 1908 } 1909 1910 void ASTDeclReader::VisitCXXConversionDecl(CXXConversionDecl *D) { 1911 VisitCXXMethodDecl(D); 1912 } 1913 1914 void ASTDeclReader::VisitImportDecl(ImportDecl *D) { 1915 VisitDecl(D); 1916 D->ImportedAndComplete.setPointer(readModule()); 1917 D->ImportedAndComplete.setInt(Record.readInt()); 1918 SourceLocation *StoredLocs = D->getTrailingObjects<SourceLocation>(); 1919 for (unsigned I = 0, N = Record.back(); I != N; ++I) 1920 StoredLocs[I] = ReadSourceLocation(); 1921 Record.skipInts(1); // The number of stored source locations. 1922 } 1923 1924 void ASTDeclReader::VisitAccessSpecDecl(AccessSpecDecl *D) { 1925 VisitDecl(D); 1926 D->setColonLoc(ReadSourceLocation()); 1927 } 1928 1929 void ASTDeclReader::VisitFriendDecl(FriendDecl *D) { 1930 VisitDecl(D); 1931 if (Record.readInt()) // hasFriendDecl 1932 D->Friend = ReadDeclAs<NamedDecl>(); 1933 else 1934 D->Friend = GetTypeSourceInfo(); 1935 for (unsigned i = 0; i != D->NumTPLists; ++i) 1936 D->getTrailingObjects<TemplateParameterList *>()[i] = 1937 Record.readTemplateParameterList(); 1938 D->NextFriend = ReadDeclID(); 1939 D->UnsupportedFriend = (Record.readInt() != 0); 1940 D->FriendLoc = ReadSourceLocation(); 1941 } 1942 1943 void ASTDeclReader::VisitFriendTemplateDecl(FriendTemplateDecl *D) { 1944 VisitDecl(D); 1945 unsigned NumParams = Record.readInt(); 1946 D->NumParams = NumParams; 1947 D->Params = new TemplateParameterList*[NumParams]; 1948 for (unsigned i = 0; i != NumParams; ++i) 1949 D->Params[i] = Record.readTemplateParameterList(); 1950 if (Record.readInt()) // HasFriendDecl 1951 D->Friend = ReadDeclAs<NamedDecl>(); 1952 else 1953 D->Friend = GetTypeSourceInfo(); 1954 D->FriendLoc = ReadSourceLocation(); 1955 } 1956 1957 DeclID ASTDeclReader::VisitTemplateDecl(TemplateDecl *D) { 1958 VisitNamedDecl(D); 1959 1960 DeclID PatternID = ReadDeclID(); 1961 NamedDecl *TemplatedDecl = cast_or_null<NamedDecl>(Reader.GetDecl(PatternID)); 1962 TemplateParameterList *TemplateParams = Record.readTemplateParameterList(); 1963 // FIXME handle associated constraints 1964 D->init(TemplatedDecl, TemplateParams); 1965 1966 return PatternID; 1967 } 1968 1969 ASTDeclReader::RedeclarableResult 1970 ASTDeclReader::VisitRedeclarableTemplateDecl(RedeclarableTemplateDecl *D) { 1971 RedeclarableResult Redecl = VisitRedeclarable(D); 1972 1973 // Make sure we've allocated the Common pointer first. We do this before 1974 // VisitTemplateDecl so that getCommonPtr() can be used during initialization. 1975 RedeclarableTemplateDecl *CanonD = D->getCanonicalDecl(); 1976 if (!CanonD->Common) { 1977 CanonD->Common = CanonD->newCommon(Reader.getContext()); 1978 Reader.PendingDefinitions.insert(CanonD); 1979 } 1980 D->Common = CanonD->Common; 1981 1982 // If this is the first declaration of the template, fill in the information 1983 // for the 'common' pointer. 1984 if (ThisDeclID == Redecl.getFirstID()) { 1985 if (RedeclarableTemplateDecl *RTD 1986 = ReadDeclAs<RedeclarableTemplateDecl>()) { 1987 assert(RTD->getKind() == D->getKind() && 1988 "InstantiatedFromMemberTemplate kind mismatch"); 1989 D->setInstantiatedFromMemberTemplate(RTD); 1990 if (Record.readInt()) 1991 D->setMemberSpecialization(); 1992 } 1993 } 1994 1995 DeclID PatternID = VisitTemplateDecl(D); 1996 D->IdentifierNamespace = Record.readInt(); 1997 1998 mergeRedeclarable(D, Redecl, PatternID); 1999 2000 // If we merged the template with a prior declaration chain, merge the common 2001 // pointer. 2002 // FIXME: Actually merge here, don't just overwrite. 2003 D->Common = D->getCanonicalDecl()->Common; 2004 2005 return Redecl; 2006 } 2007 2008 void ASTDeclReader::VisitClassTemplateDecl(ClassTemplateDecl *D) { 2009 RedeclarableResult Redecl = VisitRedeclarableTemplateDecl(D); 2010 2011 if (ThisDeclID == Redecl.getFirstID()) { 2012 // This ClassTemplateDecl owns a CommonPtr; read it to keep track of all of 2013 // the specializations. 2014 SmallVector<serialization::DeclID, 32> SpecIDs; 2015 ReadDeclIDList(SpecIDs); 2016 ASTDeclReader::AddLazySpecializations(D, SpecIDs); 2017 } 2018 2019 if (D->getTemplatedDecl()->TemplateOrInstantiation) { 2020 // We were loaded before our templated declaration was. We've not set up 2021 // its corresponding type yet (see VisitCXXRecordDeclImpl), so reconstruct 2022 // it now. 2023 Reader.getContext().getInjectedClassNameType( 2024 D->getTemplatedDecl(), D->getInjectedClassNameSpecialization()); 2025 } 2026 } 2027 2028 void ASTDeclReader::VisitBuiltinTemplateDecl(BuiltinTemplateDecl *D) { 2029 llvm_unreachable("BuiltinTemplates are not serialized"); 2030 } 2031 2032 /// TODO: Unify with ClassTemplateDecl version? 2033 /// May require unifying ClassTemplateDecl and 2034 /// VarTemplateDecl beyond TemplateDecl... 2035 void ASTDeclReader::VisitVarTemplateDecl(VarTemplateDecl *D) { 2036 RedeclarableResult Redecl = VisitRedeclarableTemplateDecl(D); 2037 2038 if (ThisDeclID == Redecl.getFirstID()) { 2039 // This VarTemplateDecl owns a CommonPtr; read it to keep track of all of 2040 // the specializations. 2041 SmallVector<serialization::DeclID, 32> SpecIDs; 2042 ReadDeclIDList(SpecIDs); 2043 ASTDeclReader::AddLazySpecializations(D, SpecIDs); 2044 } 2045 } 2046 2047 ASTDeclReader::RedeclarableResult 2048 ASTDeclReader::VisitClassTemplateSpecializationDeclImpl( 2049 ClassTemplateSpecializationDecl *D) { 2050 RedeclarableResult Redecl = VisitCXXRecordDeclImpl(D); 2051 2052 ASTContext &C = Reader.getContext(); 2053 if (Decl *InstD = ReadDecl()) { 2054 if (ClassTemplateDecl *CTD = dyn_cast<ClassTemplateDecl>(InstD)) { 2055 D->SpecializedTemplate = CTD; 2056 } else { 2057 SmallVector<TemplateArgument, 8> TemplArgs; 2058 Record.readTemplateArgumentList(TemplArgs); 2059 TemplateArgumentList *ArgList 2060 = TemplateArgumentList::CreateCopy(C, TemplArgs); 2061 ClassTemplateSpecializationDecl::SpecializedPartialSpecialization *PS 2062 = new (C) ClassTemplateSpecializationDecl:: 2063 SpecializedPartialSpecialization(); 2064 PS->PartialSpecialization 2065 = cast<ClassTemplatePartialSpecializationDecl>(InstD); 2066 PS->TemplateArgs = ArgList; 2067 D->SpecializedTemplate = PS; 2068 } 2069 } 2070 2071 SmallVector<TemplateArgument, 8> TemplArgs; 2072 Record.readTemplateArgumentList(TemplArgs, /*Canonicalize*/ true); 2073 D->TemplateArgs = TemplateArgumentList::CreateCopy(C, TemplArgs); 2074 D->PointOfInstantiation = ReadSourceLocation(); 2075 D->SpecializationKind = (TemplateSpecializationKind)Record.readInt(); 2076 2077 bool writtenAsCanonicalDecl = Record.readInt(); 2078 if (writtenAsCanonicalDecl) { 2079 ClassTemplateDecl *CanonPattern = ReadDeclAs<ClassTemplateDecl>(); 2080 if (D->isCanonicalDecl()) { // It's kept in the folding set. 2081 // Set this as, or find, the canonical declaration for this specialization 2082 ClassTemplateSpecializationDecl *CanonSpec; 2083 if (ClassTemplatePartialSpecializationDecl *Partial = 2084 dyn_cast<ClassTemplatePartialSpecializationDecl>(D)) { 2085 CanonSpec = CanonPattern->getCommonPtr()->PartialSpecializations 2086 .GetOrInsertNode(Partial); 2087 } else { 2088 CanonSpec = 2089 CanonPattern->getCommonPtr()->Specializations.GetOrInsertNode(D); 2090 } 2091 // If there was already a canonical specialization, merge into it. 2092 if (CanonSpec != D) { 2093 mergeRedeclarable<TagDecl>(D, CanonSpec, Redecl); 2094 2095 // This declaration might be a definition. Merge with any existing 2096 // definition. 2097 if (auto *DDD = D->DefinitionData) { 2098 if (CanonSpec->DefinitionData) 2099 MergeDefinitionData(CanonSpec, std::move(*DDD)); 2100 else 2101 CanonSpec->DefinitionData = D->DefinitionData; 2102 } 2103 D->DefinitionData = CanonSpec->DefinitionData; 2104 } 2105 } 2106 } 2107 2108 // Explicit info. 2109 if (TypeSourceInfo *TyInfo = GetTypeSourceInfo()) { 2110 ClassTemplateSpecializationDecl::ExplicitSpecializationInfo *ExplicitInfo 2111 = new (C) ClassTemplateSpecializationDecl::ExplicitSpecializationInfo; 2112 ExplicitInfo->TypeAsWritten = TyInfo; 2113 ExplicitInfo->ExternLoc = ReadSourceLocation(); 2114 ExplicitInfo->TemplateKeywordLoc = ReadSourceLocation(); 2115 D->ExplicitInfo = ExplicitInfo; 2116 } 2117 2118 return Redecl; 2119 } 2120 2121 void ASTDeclReader::VisitClassTemplatePartialSpecializationDecl( 2122 ClassTemplatePartialSpecializationDecl *D) { 2123 RedeclarableResult Redecl = VisitClassTemplateSpecializationDeclImpl(D); 2124 2125 D->TemplateParams = Record.readTemplateParameterList(); 2126 D->ArgsAsWritten = Record.readASTTemplateArgumentListInfo(); 2127 2128 // These are read/set from/to the first declaration. 2129 if (ThisDeclID == Redecl.getFirstID()) { 2130 D->InstantiatedFromMember.setPointer( 2131 ReadDeclAs<ClassTemplatePartialSpecializationDecl>()); 2132 D->InstantiatedFromMember.setInt(Record.readInt()); 2133 } 2134 } 2135 2136 void ASTDeclReader::VisitClassScopeFunctionSpecializationDecl( 2137 ClassScopeFunctionSpecializationDecl *D) { 2138 VisitDecl(D); 2139 D->Specialization = ReadDeclAs<CXXMethodDecl>(); 2140 } 2141 2142 void ASTDeclReader::VisitFunctionTemplateDecl(FunctionTemplateDecl *D) { 2143 RedeclarableResult Redecl = VisitRedeclarableTemplateDecl(D); 2144 2145 if (ThisDeclID == Redecl.getFirstID()) { 2146 // This FunctionTemplateDecl owns a CommonPtr; read it. 2147 SmallVector<serialization::DeclID, 32> SpecIDs; 2148 ReadDeclIDList(SpecIDs); 2149 ASTDeclReader::AddLazySpecializations(D, SpecIDs); 2150 } 2151 } 2152 2153 /// TODO: Unify with ClassTemplateSpecializationDecl version? 2154 /// May require unifying ClassTemplate(Partial)SpecializationDecl and 2155 /// VarTemplate(Partial)SpecializationDecl with a new data 2156 /// structure Template(Partial)SpecializationDecl, and 2157 /// using Template(Partial)SpecializationDecl as input type. 2158 ASTDeclReader::RedeclarableResult 2159 ASTDeclReader::VisitVarTemplateSpecializationDeclImpl( 2160 VarTemplateSpecializationDecl *D) { 2161 RedeclarableResult Redecl = VisitVarDeclImpl(D); 2162 2163 ASTContext &C = Reader.getContext(); 2164 if (Decl *InstD = ReadDecl()) { 2165 if (VarTemplateDecl *VTD = dyn_cast<VarTemplateDecl>(InstD)) { 2166 D->SpecializedTemplate = VTD; 2167 } else { 2168 SmallVector<TemplateArgument, 8> TemplArgs; 2169 Record.readTemplateArgumentList(TemplArgs); 2170 TemplateArgumentList *ArgList = TemplateArgumentList::CreateCopy( 2171 C, TemplArgs); 2172 VarTemplateSpecializationDecl::SpecializedPartialSpecialization *PS = 2173 new (C) 2174 VarTemplateSpecializationDecl::SpecializedPartialSpecialization(); 2175 PS->PartialSpecialization = 2176 cast<VarTemplatePartialSpecializationDecl>(InstD); 2177 PS->TemplateArgs = ArgList; 2178 D->SpecializedTemplate = PS; 2179 } 2180 } 2181 2182 // Explicit info. 2183 if (TypeSourceInfo *TyInfo = GetTypeSourceInfo()) { 2184 VarTemplateSpecializationDecl::ExplicitSpecializationInfo *ExplicitInfo = 2185 new (C) VarTemplateSpecializationDecl::ExplicitSpecializationInfo; 2186 ExplicitInfo->TypeAsWritten = TyInfo; 2187 ExplicitInfo->ExternLoc = ReadSourceLocation(); 2188 ExplicitInfo->TemplateKeywordLoc = ReadSourceLocation(); 2189 D->ExplicitInfo = ExplicitInfo; 2190 } 2191 2192 SmallVector<TemplateArgument, 8> TemplArgs; 2193 Record.readTemplateArgumentList(TemplArgs, /*Canonicalize*/ true); 2194 D->TemplateArgs = TemplateArgumentList::CreateCopy(C, TemplArgs); 2195 D->PointOfInstantiation = ReadSourceLocation(); 2196 D->SpecializationKind = (TemplateSpecializationKind)Record.readInt(); 2197 2198 bool writtenAsCanonicalDecl = Record.readInt(); 2199 if (writtenAsCanonicalDecl) { 2200 VarTemplateDecl *CanonPattern = ReadDeclAs<VarTemplateDecl>(); 2201 if (D->isCanonicalDecl()) { // It's kept in the folding set. 2202 // FIXME: If it's already present, merge it. 2203 if (VarTemplatePartialSpecializationDecl *Partial = 2204 dyn_cast<VarTemplatePartialSpecializationDecl>(D)) { 2205 CanonPattern->getCommonPtr()->PartialSpecializations 2206 .GetOrInsertNode(Partial); 2207 } else { 2208 CanonPattern->getCommonPtr()->Specializations.GetOrInsertNode(D); 2209 } 2210 } 2211 } 2212 2213 return Redecl; 2214 } 2215 2216 /// TODO: Unify with ClassTemplatePartialSpecializationDecl version? 2217 /// May require unifying ClassTemplate(Partial)SpecializationDecl and 2218 /// VarTemplate(Partial)SpecializationDecl with a new data 2219 /// structure Template(Partial)SpecializationDecl, and 2220 /// using Template(Partial)SpecializationDecl as input type. 2221 void ASTDeclReader::VisitVarTemplatePartialSpecializationDecl( 2222 VarTemplatePartialSpecializationDecl *D) { 2223 RedeclarableResult Redecl = VisitVarTemplateSpecializationDeclImpl(D); 2224 2225 D->TemplateParams = Record.readTemplateParameterList(); 2226 D->ArgsAsWritten = Record.readASTTemplateArgumentListInfo(); 2227 2228 // These are read/set from/to the first declaration. 2229 if (ThisDeclID == Redecl.getFirstID()) { 2230 D->InstantiatedFromMember.setPointer( 2231 ReadDeclAs<VarTemplatePartialSpecializationDecl>()); 2232 D->InstantiatedFromMember.setInt(Record.readInt()); 2233 } 2234 } 2235 2236 void ASTDeclReader::VisitTemplateTypeParmDecl(TemplateTypeParmDecl *D) { 2237 VisitTypeDecl(D); 2238 2239 D->setDeclaredWithTypename(Record.readInt()); 2240 2241 if (Record.readInt()) 2242 D->setDefaultArgument(GetTypeSourceInfo()); 2243 } 2244 2245 void ASTDeclReader::VisitNonTypeTemplateParmDecl(NonTypeTemplateParmDecl *D) { 2246 VisitDeclaratorDecl(D); 2247 // TemplateParmPosition. 2248 D->setDepth(Record.readInt()); 2249 D->setPosition(Record.readInt()); 2250 if (D->isExpandedParameterPack()) { 2251 auto TypesAndInfos = 2252 D->getTrailingObjects<std::pair<QualType, TypeSourceInfo *>>(); 2253 for (unsigned I = 0, N = D->getNumExpansionTypes(); I != N; ++I) { 2254 new (&TypesAndInfos[I].first) QualType(Record.readType()); 2255 TypesAndInfos[I].second = GetTypeSourceInfo(); 2256 } 2257 } else { 2258 // Rest of NonTypeTemplateParmDecl. 2259 D->ParameterPack = Record.readInt(); 2260 if (Record.readInt()) 2261 D->setDefaultArgument(Record.readExpr()); 2262 } 2263 } 2264 2265 void ASTDeclReader::VisitTemplateTemplateParmDecl(TemplateTemplateParmDecl *D) { 2266 VisitTemplateDecl(D); 2267 // TemplateParmPosition. 2268 D->setDepth(Record.readInt()); 2269 D->setPosition(Record.readInt()); 2270 if (D->isExpandedParameterPack()) { 2271 TemplateParameterList **Data = 2272 D->getTrailingObjects<TemplateParameterList *>(); 2273 for (unsigned I = 0, N = D->getNumExpansionTemplateParameters(); 2274 I != N; ++I) 2275 Data[I] = Record.readTemplateParameterList(); 2276 } else { 2277 // Rest of TemplateTemplateParmDecl. 2278 D->ParameterPack = Record.readInt(); 2279 if (Record.readInt()) 2280 D->setDefaultArgument(Reader.getContext(), 2281 Record.readTemplateArgumentLoc()); 2282 } 2283 } 2284 2285 void ASTDeclReader::VisitTypeAliasTemplateDecl(TypeAliasTemplateDecl *D) { 2286 VisitRedeclarableTemplateDecl(D); 2287 } 2288 2289 void ASTDeclReader::VisitStaticAssertDecl(StaticAssertDecl *D) { 2290 VisitDecl(D); 2291 D->AssertExprAndFailed.setPointer(Record.readExpr()); 2292 D->AssertExprAndFailed.setInt(Record.readInt()); 2293 D->Message = cast_or_null<StringLiteral>(Record.readExpr()); 2294 D->RParenLoc = ReadSourceLocation(); 2295 } 2296 2297 void ASTDeclReader::VisitEmptyDecl(EmptyDecl *D) { 2298 VisitDecl(D); 2299 } 2300 2301 std::pair<uint64_t, uint64_t> 2302 ASTDeclReader::VisitDeclContext(DeclContext *DC) { 2303 uint64_t LexicalOffset = ReadLocalOffset(); 2304 uint64_t VisibleOffset = ReadLocalOffset(); 2305 return std::make_pair(LexicalOffset, VisibleOffset); 2306 } 2307 2308 template <typename T> 2309 ASTDeclReader::RedeclarableResult 2310 ASTDeclReader::VisitRedeclarable(Redeclarable<T> *D) { 2311 DeclID FirstDeclID = ReadDeclID(); 2312 Decl *MergeWith = nullptr; 2313 2314 bool IsKeyDecl = ThisDeclID == FirstDeclID; 2315 bool IsFirstLocalDecl = false; 2316 2317 uint64_t RedeclOffset = 0; 2318 2319 // 0 indicates that this declaration was the only declaration of its entity, 2320 // and is used for space optimization. 2321 if (FirstDeclID == 0) { 2322 FirstDeclID = ThisDeclID; 2323 IsKeyDecl = true; 2324 IsFirstLocalDecl = true; 2325 } else if (unsigned N = Record.readInt()) { 2326 // This declaration was the first local declaration, but may have imported 2327 // other declarations. 2328 IsKeyDecl = N == 1; 2329 IsFirstLocalDecl = true; 2330 2331 // We have some declarations that must be before us in our redeclaration 2332 // chain. Read them now, and remember that we ought to merge with one of 2333 // them. 2334 // FIXME: Provide a known merge target to the second and subsequent such 2335 // declaration. 2336 for (unsigned I = 0; I != N - 1; ++I) 2337 MergeWith = ReadDecl(); 2338 2339 RedeclOffset = ReadLocalOffset(); 2340 } else { 2341 // This declaration was not the first local declaration. Read the first 2342 // local declaration now, to trigger the import of other redeclarations. 2343 (void)ReadDecl(); 2344 } 2345 2346 T *FirstDecl = cast_or_null<T>(Reader.GetDecl(FirstDeclID)); 2347 if (FirstDecl != D) { 2348 // We delay loading of the redeclaration chain to avoid deeply nested calls. 2349 // We temporarily set the first (canonical) declaration as the previous one 2350 // which is the one that matters and mark the real previous DeclID to be 2351 // loaded & attached later on. 2352 D->RedeclLink = Redeclarable<T>::PreviousDeclLink(FirstDecl); 2353 D->First = FirstDecl->getCanonicalDecl(); 2354 } 2355 2356 T *DAsT = static_cast<T*>(D); 2357 2358 // Note that we need to load local redeclarations of this decl and build a 2359 // decl chain for them. This must happen *after* we perform the preloading 2360 // above; this ensures that the redeclaration chain is built in the correct 2361 // order. 2362 if (IsFirstLocalDecl) 2363 Reader.PendingDeclChains.push_back(std::make_pair(DAsT, RedeclOffset)); 2364 2365 return RedeclarableResult(MergeWith, FirstDeclID, IsKeyDecl); 2366 } 2367 2368 /// \brief Attempts to merge the given declaration (D) with another declaration 2369 /// of the same entity. 2370 template<typename T> 2371 void ASTDeclReader::mergeRedeclarable(Redeclarable<T> *DBase, 2372 RedeclarableResult &Redecl, 2373 DeclID TemplatePatternID) { 2374 // If modules are not available, there is no reason to perform this merge. 2375 if (!Reader.getContext().getLangOpts().Modules) 2376 return; 2377 2378 // If we're not the canonical declaration, we don't need to merge. 2379 if (!DBase->isFirstDecl()) 2380 return; 2381 2382 T *D = static_cast<T*>(DBase); 2383 2384 if (auto *Existing = Redecl.getKnownMergeTarget()) 2385 // We already know of an existing declaration we should merge with. 2386 mergeRedeclarable(D, cast<T>(Existing), Redecl, TemplatePatternID); 2387 else if (FindExistingResult ExistingRes = findExisting(D)) 2388 if (T *Existing = ExistingRes) 2389 mergeRedeclarable(D, Existing, Redecl, TemplatePatternID); 2390 } 2391 2392 /// \brief "Cast" to type T, asserting if we don't have an implicit conversion. 2393 /// We use this to put code in a template that will only be valid for certain 2394 /// instantiations. 2395 template<typename T> static T assert_cast(T t) { return t; } 2396 template<typename T> static T assert_cast(...) { 2397 llvm_unreachable("bad assert_cast"); 2398 } 2399 2400 /// \brief Merge together the pattern declarations from two template 2401 /// declarations. 2402 void ASTDeclReader::mergeTemplatePattern(RedeclarableTemplateDecl *D, 2403 RedeclarableTemplateDecl *Existing, 2404 DeclID DsID, bool IsKeyDecl) { 2405 auto *DPattern = D->getTemplatedDecl(); 2406 auto *ExistingPattern = Existing->getTemplatedDecl(); 2407 RedeclarableResult Result(/*MergeWith*/ ExistingPattern, 2408 DPattern->getCanonicalDecl()->getGlobalID(), 2409 IsKeyDecl); 2410 2411 if (auto *DClass = dyn_cast<CXXRecordDecl>(DPattern)) { 2412 // Merge with any existing definition. 2413 // FIXME: This is duplicated in several places. Refactor. 2414 auto *ExistingClass = 2415 cast<CXXRecordDecl>(ExistingPattern)->getCanonicalDecl(); 2416 if (auto *DDD = DClass->DefinitionData) { 2417 if (ExistingClass->DefinitionData) { 2418 MergeDefinitionData(ExistingClass, std::move(*DDD)); 2419 } else { 2420 ExistingClass->DefinitionData = DClass->DefinitionData; 2421 // We may have skipped this before because we thought that DClass 2422 // was the canonical declaration. 2423 Reader.PendingDefinitions.insert(DClass); 2424 } 2425 } 2426 DClass->DefinitionData = ExistingClass->DefinitionData; 2427 2428 return mergeRedeclarable(DClass, cast<TagDecl>(ExistingPattern), 2429 Result); 2430 } 2431 if (auto *DFunction = dyn_cast<FunctionDecl>(DPattern)) 2432 return mergeRedeclarable(DFunction, cast<FunctionDecl>(ExistingPattern), 2433 Result); 2434 if (auto *DVar = dyn_cast<VarDecl>(DPattern)) 2435 return mergeRedeclarable(DVar, cast<VarDecl>(ExistingPattern), Result); 2436 if (auto *DAlias = dyn_cast<TypeAliasDecl>(DPattern)) 2437 return mergeRedeclarable(DAlias, cast<TypedefNameDecl>(ExistingPattern), 2438 Result); 2439 llvm_unreachable("merged an unknown kind of redeclarable template"); 2440 } 2441 2442 /// \brief Attempts to merge the given declaration (D) with another declaration 2443 /// of the same entity. 2444 template<typename T> 2445 void ASTDeclReader::mergeRedeclarable(Redeclarable<T> *DBase, T *Existing, 2446 RedeclarableResult &Redecl, 2447 DeclID TemplatePatternID) { 2448 T *D = static_cast<T*>(DBase); 2449 T *ExistingCanon = Existing->getCanonicalDecl(); 2450 T *DCanon = D->getCanonicalDecl(); 2451 if (ExistingCanon != DCanon) { 2452 assert(DCanon->getGlobalID() == Redecl.getFirstID() && 2453 "already merged this declaration"); 2454 2455 // Have our redeclaration link point back at the canonical declaration 2456 // of the existing declaration, so that this declaration has the 2457 // appropriate canonical declaration. 2458 D->RedeclLink = Redeclarable<T>::PreviousDeclLink(ExistingCanon); 2459 D->First = ExistingCanon; 2460 ExistingCanon->Used |= D->Used; 2461 D->Used = false; 2462 2463 // When we merge a namespace, update its pointer to the first namespace. 2464 // We cannot have loaded any redeclarations of this declaration yet, so 2465 // there's nothing else that needs to be updated. 2466 if (auto *Namespace = dyn_cast<NamespaceDecl>(D)) 2467 Namespace->AnonOrFirstNamespaceAndInline.setPointer( 2468 assert_cast<NamespaceDecl*>(ExistingCanon)); 2469 2470 // When we merge a template, merge its pattern. 2471 if (auto *DTemplate = dyn_cast<RedeclarableTemplateDecl>(D)) 2472 mergeTemplatePattern( 2473 DTemplate, assert_cast<RedeclarableTemplateDecl*>(ExistingCanon), 2474 TemplatePatternID, Redecl.isKeyDecl()); 2475 2476 // If this declaration is a key declaration, make a note of that. 2477 if (Redecl.isKeyDecl()) 2478 Reader.KeyDecls[ExistingCanon].push_back(Redecl.getFirstID()); 2479 } 2480 } 2481 2482 /// \brief Attempts to merge the given declaration (D) with another declaration 2483 /// of the same entity, for the case where the entity is not actually 2484 /// redeclarable. This happens, for instance, when merging the fields of 2485 /// identical class definitions from two different modules. 2486 template<typename T> 2487 void ASTDeclReader::mergeMergeable(Mergeable<T> *D) { 2488 // If modules are not available, there is no reason to perform this merge. 2489 if (!Reader.getContext().getLangOpts().Modules) 2490 return; 2491 2492 // ODR-based merging is only performed in C++. In C, identically-named things 2493 // in different translation units are not redeclarations (but may still have 2494 // compatible types). 2495 if (!Reader.getContext().getLangOpts().CPlusPlus) 2496 return; 2497 2498 if (FindExistingResult ExistingRes = findExisting(static_cast<T*>(D))) 2499 if (T *Existing = ExistingRes) 2500 Reader.getContext().setPrimaryMergedDecl(static_cast<T *>(D), 2501 Existing->getCanonicalDecl()); 2502 } 2503 2504 void ASTDeclReader::VisitOMPThreadPrivateDecl(OMPThreadPrivateDecl *D) { 2505 VisitDecl(D); 2506 unsigned NumVars = D->varlist_size(); 2507 SmallVector<Expr *, 16> Vars; 2508 Vars.reserve(NumVars); 2509 for (unsigned i = 0; i != NumVars; ++i) { 2510 Vars.push_back(Record.readExpr()); 2511 } 2512 D->setVars(Vars); 2513 } 2514 2515 void ASTDeclReader::VisitOMPDeclareReductionDecl(OMPDeclareReductionDecl *D) { 2516 VisitValueDecl(D); 2517 D->setLocation(ReadSourceLocation()); 2518 D->setCombiner(Record.readExpr()); 2519 D->setInitializer( 2520 Record.readExpr(), 2521 static_cast<OMPDeclareReductionDecl::InitKind>(Record.readInt())); 2522 D->PrevDeclInScope = ReadDeclID(); 2523 } 2524 2525 void ASTDeclReader::VisitOMPCapturedExprDecl(OMPCapturedExprDecl *D) { 2526 VisitVarDecl(D); 2527 } 2528 2529 //===----------------------------------------------------------------------===// 2530 // Attribute Reading 2531 //===----------------------------------------------------------------------===// 2532 2533 /// \brief Reads attributes from the current stream position. 2534 void ASTReader::ReadAttributes(ASTRecordReader &Record, AttrVec &Attrs) { 2535 for (unsigned i = 0, e = Record.readInt(); i != e; ++i) { 2536 Attr *New = nullptr; 2537 attr::Kind Kind = (attr::Kind)Record.readInt(); 2538 SourceRange Range = Record.readSourceRange(); 2539 ASTContext &Context = getContext(); 2540 2541 #include "clang/Serialization/AttrPCHRead.inc" 2542 2543 assert(New && "Unable to decode attribute?"); 2544 Attrs.push_back(New); 2545 } 2546 } 2547 2548 //===----------------------------------------------------------------------===// 2549 // ASTReader Implementation 2550 //===----------------------------------------------------------------------===// 2551 2552 /// \brief Note that we have loaded the declaration with the given 2553 /// Index. 2554 /// 2555 /// This routine notes that this declaration has already been loaded, 2556 /// so that future GetDecl calls will return this declaration rather 2557 /// than trying to load a new declaration. 2558 inline void ASTReader::LoadedDecl(unsigned Index, Decl *D) { 2559 assert(!DeclsLoaded[Index] && "Decl loaded twice?"); 2560 DeclsLoaded[Index] = D; 2561 } 2562 2563 2564 /// \brief Determine whether the consumer will be interested in seeing 2565 /// this declaration (via HandleTopLevelDecl). 2566 /// 2567 /// This routine should return true for anything that might affect 2568 /// code generation, e.g., inline function definitions, Objective-C 2569 /// declarations with metadata, etc. 2570 static bool isConsumerInterestedIn(ASTContext &Ctx, Decl *D, bool HasBody) { 2571 // An ObjCMethodDecl is never considered as "interesting" because its 2572 // implementation container always is. 2573 2574 // An ImportDecl or VarDecl imported from a module map module will get 2575 // emitted when we import the relevant module. 2576 if (isa<ImportDecl>(D) || isa<VarDecl>(D)) { 2577 auto *M = D->getImportedOwningModule(); 2578 if (M && M->Kind == Module::ModuleMapModule && 2579 Ctx.DeclMustBeEmitted(D)) 2580 return false; 2581 } 2582 2583 if (isa<FileScopeAsmDecl>(D) || 2584 isa<ObjCProtocolDecl>(D) || 2585 isa<ObjCImplDecl>(D) || 2586 isa<ImportDecl>(D) || 2587 isa<PragmaCommentDecl>(D) || 2588 isa<PragmaDetectMismatchDecl>(D)) 2589 return true; 2590 if (isa<OMPThreadPrivateDecl>(D) || isa<OMPDeclareReductionDecl>(D)) 2591 return !D->getDeclContext()->isFunctionOrMethod(); 2592 if (VarDecl *Var = dyn_cast<VarDecl>(D)) 2593 return Var->isFileVarDecl() && 2594 Var->isThisDeclarationADefinition() == VarDecl::Definition; 2595 if (FunctionDecl *Func = dyn_cast<FunctionDecl>(D)) 2596 return Func->doesThisDeclarationHaveABody() || HasBody; 2597 2598 if (auto *ES = D->getASTContext().getExternalSource()) 2599 if (ES->hasExternalDefinitions(D) == ExternalASTSource::EK_Never) 2600 return true; 2601 2602 return false; 2603 } 2604 2605 /// \brief Get the correct cursor and offset for loading a declaration. 2606 ASTReader::RecordLocation 2607 ASTReader::DeclCursorForID(DeclID ID, SourceLocation &Loc) { 2608 GlobalDeclMapType::iterator I = GlobalDeclMap.find(ID); 2609 assert(I != GlobalDeclMap.end() && "Corrupted global declaration map"); 2610 ModuleFile *M = I->second; 2611 const DeclOffset &DOffs = 2612 M->DeclOffsets[ID - M->BaseDeclID - NUM_PREDEF_DECL_IDS]; 2613 Loc = TranslateSourceLocation(*M, DOffs.getLocation()); 2614 return RecordLocation(M, DOffs.BitOffset); 2615 } 2616 2617 ASTReader::RecordLocation ASTReader::getLocalBitOffset(uint64_t GlobalOffset) { 2618 ContinuousRangeMap<uint64_t, ModuleFile*, 4>::iterator I 2619 = GlobalBitOffsetsMap.find(GlobalOffset); 2620 2621 assert(I != GlobalBitOffsetsMap.end() && "Corrupted global bit offsets map"); 2622 return RecordLocation(I->second, GlobalOffset - I->second->GlobalBitOffset); 2623 } 2624 2625 uint64_t ASTReader::getGlobalBitOffset(ModuleFile &M, uint32_t LocalOffset) { 2626 return LocalOffset + M.GlobalBitOffset; 2627 } 2628 2629 static bool isSameTemplateParameterList(const TemplateParameterList *X, 2630 const TemplateParameterList *Y); 2631 2632 /// \brief Determine whether two template parameters are similar enough 2633 /// that they may be used in declarations of the same template. 2634 static bool isSameTemplateParameter(const NamedDecl *X, 2635 const NamedDecl *Y) { 2636 if (X->getKind() != Y->getKind()) 2637 return false; 2638 2639 if (const TemplateTypeParmDecl *TX = dyn_cast<TemplateTypeParmDecl>(X)) { 2640 const TemplateTypeParmDecl *TY = cast<TemplateTypeParmDecl>(Y); 2641 return TX->isParameterPack() == TY->isParameterPack(); 2642 } 2643 2644 if (const NonTypeTemplateParmDecl *TX = dyn_cast<NonTypeTemplateParmDecl>(X)) { 2645 const NonTypeTemplateParmDecl *TY = cast<NonTypeTemplateParmDecl>(Y); 2646 return TX->isParameterPack() == TY->isParameterPack() && 2647 TX->getASTContext().hasSameType(TX->getType(), TY->getType()); 2648 } 2649 2650 const TemplateTemplateParmDecl *TX = cast<TemplateTemplateParmDecl>(X); 2651 const TemplateTemplateParmDecl *TY = cast<TemplateTemplateParmDecl>(Y); 2652 return TX->isParameterPack() == TY->isParameterPack() && 2653 isSameTemplateParameterList(TX->getTemplateParameters(), 2654 TY->getTemplateParameters()); 2655 } 2656 2657 static NamespaceDecl *getNamespace(const NestedNameSpecifier *X) { 2658 if (auto *NS = X->getAsNamespace()) 2659 return NS; 2660 if (auto *NAS = X->getAsNamespaceAlias()) 2661 return NAS->getNamespace(); 2662 return nullptr; 2663 } 2664 2665 static bool isSameQualifier(const NestedNameSpecifier *X, 2666 const NestedNameSpecifier *Y) { 2667 if (auto *NSX = getNamespace(X)) { 2668 auto *NSY = getNamespace(Y); 2669 if (!NSY || NSX->getCanonicalDecl() != NSY->getCanonicalDecl()) 2670 return false; 2671 } else if (X->getKind() != Y->getKind()) 2672 return false; 2673 2674 // FIXME: For namespaces and types, we're permitted to check that the entity 2675 // is named via the same tokens. We should probably do so. 2676 switch (X->getKind()) { 2677 case NestedNameSpecifier::Identifier: 2678 if (X->getAsIdentifier() != Y->getAsIdentifier()) 2679 return false; 2680 break; 2681 case NestedNameSpecifier::Namespace: 2682 case NestedNameSpecifier::NamespaceAlias: 2683 // We've already checked that we named the same namespace. 2684 break; 2685 case NestedNameSpecifier::TypeSpec: 2686 case NestedNameSpecifier::TypeSpecWithTemplate: 2687 if (X->getAsType()->getCanonicalTypeInternal() != 2688 Y->getAsType()->getCanonicalTypeInternal()) 2689 return false; 2690 break; 2691 case NestedNameSpecifier::Global: 2692 case NestedNameSpecifier::Super: 2693 return true; 2694 } 2695 2696 // Recurse into earlier portion of NNS, if any. 2697 auto *PX = X->getPrefix(); 2698 auto *PY = Y->getPrefix(); 2699 if (PX && PY) 2700 return isSameQualifier(PX, PY); 2701 return !PX && !PY; 2702 } 2703 2704 /// \brief Determine whether two template parameter lists are similar enough 2705 /// that they may be used in declarations of the same template. 2706 static bool isSameTemplateParameterList(const TemplateParameterList *X, 2707 const TemplateParameterList *Y) { 2708 if (X->size() != Y->size()) 2709 return false; 2710 2711 for (unsigned I = 0, N = X->size(); I != N; ++I) 2712 if (!isSameTemplateParameter(X->getParam(I), Y->getParam(I))) 2713 return false; 2714 2715 return true; 2716 } 2717 2718 /// Determine whether the attributes we can overload on are identical for A and 2719 /// B. Will ignore any overloadable attrs represented in the type of A and B. 2720 static bool hasSameOverloadableAttrs(const FunctionDecl *A, 2721 const FunctionDecl *B) { 2722 // Note that pass_object_size attributes are represented in the function's 2723 // ExtParameterInfo, so we don't need to check them here. 2724 2725 SmallVector<const EnableIfAttr *, 4> AEnableIfs; 2726 // Since this is an equality check, we can ignore that enable_if attrs show up 2727 // in reverse order. 2728 for (const auto *EIA : A->specific_attrs<EnableIfAttr>()) 2729 AEnableIfs.push_back(EIA); 2730 2731 SmallVector<const EnableIfAttr *, 4> BEnableIfs; 2732 for (const auto *EIA : B->specific_attrs<EnableIfAttr>()) 2733 BEnableIfs.push_back(EIA); 2734 2735 // Two very common cases: either we have 0 enable_if attrs, or we have an 2736 // unequal number of enable_if attrs. 2737 if (AEnableIfs.empty() && BEnableIfs.empty()) 2738 return true; 2739 2740 if (AEnableIfs.size() != BEnableIfs.size()) 2741 return false; 2742 2743 llvm::FoldingSetNodeID Cand1ID, Cand2ID; 2744 for (unsigned I = 0, E = AEnableIfs.size(); I != E; ++I) { 2745 Cand1ID.clear(); 2746 Cand2ID.clear(); 2747 2748 AEnableIfs[I]->getCond()->Profile(Cand1ID, A->getASTContext(), true); 2749 BEnableIfs[I]->getCond()->Profile(Cand2ID, B->getASTContext(), true); 2750 if (Cand1ID != Cand2ID) 2751 return false; 2752 } 2753 2754 return true; 2755 } 2756 2757 /// \brief Determine whether the two declarations refer to the same entity. 2758 static bool isSameEntity(NamedDecl *X, NamedDecl *Y) { 2759 assert(X->getDeclName() == Y->getDeclName() && "Declaration name mismatch!"); 2760 2761 if (X == Y) 2762 return true; 2763 2764 // Must be in the same context. 2765 if (!X->getDeclContext()->getRedeclContext()->Equals( 2766 Y->getDeclContext()->getRedeclContext())) 2767 return false; 2768 2769 // Two typedefs refer to the same entity if they have the same underlying 2770 // type. 2771 if (TypedefNameDecl *TypedefX = dyn_cast<TypedefNameDecl>(X)) 2772 if (TypedefNameDecl *TypedefY = dyn_cast<TypedefNameDecl>(Y)) 2773 return X->getASTContext().hasSameType(TypedefX->getUnderlyingType(), 2774 TypedefY->getUnderlyingType()); 2775 2776 // Must have the same kind. 2777 if (X->getKind() != Y->getKind()) 2778 return false; 2779 2780 // Objective-C classes and protocols with the same name always match. 2781 if (isa<ObjCInterfaceDecl>(X) || isa<ObjCProtocolDecl>(X)) 2782 return true; 2783 2784 if (isa<ClassTemplateSpecializationDecl>(X)) { 2785 // No need to handle these here: we merge them when adding them to the 2786 // template. 2787 return false; 2788 } 2789 2790 // Compatible tags match. 2791 if (TagDecl *TagX = dyn_cast<TagDecl>(X)) { 2792 TagDecl *TagY = cast<TagDecl>(Y); 2793 return (TagX->getTagKind() == TagY->getTagKind()) || 2794 ((TagX->getTagKind() == TTK_Struct || TagX->getTagKind() == TTK_Class || 2795 TagX->getTagKind() == TTK_Interface) && 2796 (TagY->getTagKind() == TTK_Struct || TagY->getTagKind() == TTK_Class || 2797 TagY->getTagKind() == TTK_Interface)); 2798 } 2799 2800 // Functions with the same type and linkage match. 2801 // FIXME: This needs to cope with merging of prototyped/non-prototyped 2802 // functions, etc. 2803 if (FunctionDecl *FuncX = dyn_cast<FunctionDecl>(X)) { 2804 FunctionDecl *FuncY = cast<FunctionDecl>(Y); 2805 if (CXXConstructorDecl *CtorX = dyn_cast<CXXConstructorDecl>(X)) { 2806 CXXConstructorDecl *CtorY = cast<CXXConstructorDecl>(Y); 2807 if (CtorX->getInheritedConstructor() && 2808 !isSameEntity(CtorX->getInheritedConstructor().getConstructor(), 2809 CtorY->getInheritedConstructor().getConstructor())) 2810 return false; 2811 } 2812 ASTContext &C = FuncX->getASTContext(); 2813 if (!C.hasSameType(FuncX->getType(), FuncY->getType())) { 2814 // We can get functions with different types on the redecl chain in C++17 2815 // if they have differing exception specifications and at least one of 2816 // the excpetion specs is unresolved. 2817 // FIXME: Do we need to check for C++14 deduced return types here too? 2818 auto *XFPT = FuncX->getType()->getAs<FunctionProtoType>(); 2819 auto *YFPT = FuncY->getType()->getAs<FunctionProtoType>(); 2820 if (C.getLangOpts().CPlusPlus1z && XFPT && YFPT && 2821 (isUnresolvedExceptionSpec(XFPT->getExceptionSpecType()) || 2822 isUnresolvedExceptionSpec(YFPT->getExceptionSpecType())) && 2823 C.hasSameFunctionTypeIgnoringExceptionSpec(FuncX->getType(), 2824 FuncY->getType())) 2825 return true; 2826 return false; 2827 } 2828 return FuncX->getLinkageInternal() == FuncY->getLinkageInternal() && 2829 hasSameOverloadableAttrs(FuncX, FuncY); 2830 } 2831 2832 // Variables with the same type and linkage match. 2833 if (VarDecl *VarX = dyn_cast<VarDecl>(X)) { 2834 VarDecl *VarY = cast<VarDecl>(Y); 2835 if (VarX->getLinkageInternal() == VarY->getLinkageInternal()) { 2836 ASTContext &C = VarX->getASTContext(); 2837 if (C.hasSameType(VarX->getType(), VarY->getType())) 2838 return true; 2839 2840 // We can get decls with different types on the redecl chain. Eg. 2841 // template <typename T> struct S { static T Var[]; }; // #1 2842 // template <typename T> T S<T>::Var[sizeof(T)]; // #2 2843 // Only? happens when completing an incomplete array type. In this case 2844 // when comparing #1 and #2 we should go through their element type. 2845 const ArrayType *VarXTy = C.getAsArrayType(VarX->getType()); 2846 const ArrayType *VarYTy = C.getAsArrayType(VarY->getType()); 2847 if (!VarXTy || !VarYTy) 2848 return false; 2849 if (VarXTy->isIncompleteArrayType() || VarYTy->isIncompleteArrayType()) 2850 return C.hasSameType(VarXTy->getElementType(), VarYTy->getElementType()); 2851 } 2852 return false; 2853 } 2854 2855 // Namespaces with the same name and inlinedness match. 2856 if (NamespaceDecl *NamespaceX = dyn_cast<NamespaceDecl>(X)) { 2857 NamespaceDecl *NamespaceY = cast<NamespaceDecl>(Y); 2858 return NamespaceX->isInline() == NamespaceY->isInline(); 2859 } 2860 2861 // Identical template names and kinds match if their template parameter lists 2862 // and patterns match. 2863 if (TemplateDecl *TemplateX = dyn_cast<TemplateDecl>(X)) { 2864 TemplateDecl *TemplateY = cast<TemplateDecl>(Y); 2865 return isSameEntity(TemplateX->getTemplatedDecl(), 2866 TemplateY->getTemplatedDecl()) && 2867 isSameTemplateParameterList(TemplateX->getTemplateParameters(), 2868 TemplateY->getTemplateParameters()); 2869 } 2870 2871 // Fields with the same name and the same type match. 2872 if (FieldDecl *FDX = dyn_cast<FieldDecl>(X)) { 2873 FieldDecl *FDY = cast<FieldDecl>(Y); 2874 // FIXME: Also check the bitwidth is odr-equivalent, if any. 2875 return X->getASTContext().hasSameType(FDX->getType(), FDY->getType()); 2876 } 2877 2878 // Indirect fields with the same target field match. 2879 if (auto *IFDX = dyn_cast<IndirectFieldDecl>(X)) { 2880 auto *IFDY = cast<IndirectFieldDecl>(Y); 2881 return IFDX->getAnonField()->getCanonicalDecl() == 2882 IFDY->getAnonField()->getCanonicalDecl(); 2883 } 2884 2885 // Enumerators with the same name match. 2886 if (isa<EnumConstantDecl>(X)) 2887 // FIXME: Also check the value is odr-equivalent. 2888 return true; 2889 2890 // Using shadow declarations with the same target match. 2891 if (UsingShadowDecl *USX = dyn_cast<UsingShadowDecl>(X)) { 2892 UsingShadowDecl *USY = cast<UsingShadowDecl>(Y); 2893 return USX->getTargetDecl() == USY->getTargetDecl(); 2894 } 2895 2896 // Using declarations with the same qualifier match. (We already know that 2897 // the name matches.) 2898 if (auto *UX = dyn_cast<UsingDecl>(X)) { 2899 auto *UY = cast<UsingDecl>(Y); 2900 return isSameQualifier(UX->getQualifier(), UY->getQualifier()) && 2901 UX->hasTypename() == UY->hasTypename() && 2902 UX->isAccessDeclaration() == UY->isAccessDeclaration(); 2903 } 2904 if (auto *UX = dyn_cast<UnresolvedUsingValueDecl>(X)) { 2905 auto *UY = cast<UnresolvedUsingValueDecl>(Y); 2906 return isSameQualifier(UX->getQualifier(), UY->getQualifier()) && 2907 UX->isAccessDeclaration() == UY->isAccessDeclaration(); 2908 } 2909 if (auto *UX = dyn_cast<UnresolvedUsingTypenameDecl>(X)) 2910 return isSameQualifier( 2911 UX->getQualifier(), 2912 cast<UnresolvedUsingTypenameDecl>(Y)->getQualifier()); 2913 2914 // Namespace alias definitions with the same target match. 2915 if (auto *NAX = dyn_cast<NamespaceAliasDecl>(X)) { 2916 auto *NAY = cast<NamespaceAliasDecl>(Y); 2917 return NAX->getNamespace()->Equals(NAY->getNamespace()); 2918 } 2919 2920 return false; 2921 } 2922 2923 /// Find the context in which we should search for previous declarations when 2924 /// looking for declarations to merge. 2925 DeclContext *ASTDeclReader::getPrimaryContextForMerging(ASTReader &Reader, 2926 DeclContext *DC) { 2927 if (NamespaceDecl *ND = dyn_cast<NamespaceDecl>(DC)) 2928 return ND->getOriginalNamespace(); 2929 2930 if (CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(DC)) { 2931 // Try to dig out the definition. 2932 auto *DD = RD->DefinitionData; 2933 if (!DD) 2934 DD = RD->getCanonicalDecl()->DefinitionData; 2935 2936 // If there's no definition yet, then DC's definition is added by an update 2937 // record, but we've not yet loaded that update record. In this case, we 2938 // commit to DC being the canonical definition now, and will fix this when 2939 // we load the update record. 2940 if (!DD) { 2941 DD = new (Reader.getContext()) struct CXXRecordDecl::DefinitionData(RD); 2942 RD->IsCompleteDefinition = true; 2943 RD->DefinitionData = DD; 2944 RD->getCanonicalDecl()->DefinitionData = DD; 2945 2946 // Track that we did this horrible thing so that we can fix it later. 2947 Reader.PendingFakeDefinitionData.insert( 2948 std::make_pair(DD, ASTReader::PendingFakeDefinitionKind::Fake)); 2949 } 2950 2951 return DD->Definition; 2952 } 2953 2954 if (EnumDecl *ED = dyn_cast<EnumDecl>(DC)) 2955 return ED->getASTContext().getLangOpts().CPlusPlus? ED->getDefinition() 2956 : nullptr; 2957 2958 // We can see the TU here only if we have no Sema object. In that case, 2959 // there's no TU scope to look in, so using the DC alone is sufficient. 2960 if (auto *TU = dyn_cast<TranslationUnitDecl>(DC)) 2961 return TU; 2962 2963 return nullptr; 2964 } 2965 2966 ASTDeclReader::FindExistingResult::~FindExistingResult() { 2967 // Record that we had a typedef name for linkage whether or not we merge 2968 // with that declaration. 2969 if (TypedefNameForLinkage) { 2970 DeclContext *DC = New->getDeclContext()->getRedeclContext(); 2971 Reader.ImportedTypedefNamesForLinkage.insert( 2972 std::make_pair(std::make_pair(DC, TypedefNameForLinkage), New)); 2973 return; 2974 } 2975 2976 if (!AddResult || Existing) 2977 return; 2978 2979 DeclarationName Name = New->getDeclName(); 2980 DeclContext *DC = New->getDeclContext()->getRedeclContext(); 2981 if (needsAnonymousDeclarationNumber(New)) { 2982 setAnonymousDeclForMerging(Reader, New->getLexicalDeclContext(), 2983 AnonymousDeclNumber, New); 2984 } else if (DC->isTranslationUnit() && 2985 !Reader.getContext().getLangOpts().CPlusPlus) { 2986 if (Reader.getIdResolver().tryAddTopLevelDecl(New, Name)) 2987 Reader.PendingFakeLookupResults[Name.getAsIdentifierInfo()] 2988 .push_back(New); 2989 } else if (DeclContext *MergeDC = getPrimaryContextForMerging(Reader, DC)) { 2990 // Add the declaration to its redeclaration context so later merging 2991 // lookups will find it. 2992 MergeDC->makeDeclVisibleInContextImpl(New, /*Internal*/true); 2993 } 2994 } 2995 2996 /// Find the declaration that should be merged into, given the declaration found 2997 /// by name lookup. If we're merging an anonymous declaration within a typedef, 2998 /// we need a matching typedef, and we merge with the type inside it. 2999 static NamedDecl *getDeclForMerging(NamedDecl *Found, 3000 bool IsTypedefNameForLinkage) { 3001 if (!IsTypedefNameForLinkage) 3002 return Found; 3003 3004 // If we found a typedef declaration that gives a name to some other 3005 // declaration, then we want that inner declaration. Declarations from 3006 // AST files are handled via ImportedTypedefNamesForLinkage. 3007 if (Found->isFromASTFile()) 3008 return nullptr; 3009 3010 if (auto *TND = dyn_cast<TypedefNameDecl>(Found)) 3011 return TND->getAnonDeclWithTypedefName(/*AnyRedecl*/true); 3012 3013 return nullptr; 3014 } 3015 3016 NamedDecl *ASTDeclReader::getAnonymousDeclForMerging(ASTReader &Reader, 3017 DeclContext *DC, 3018 unsigned Index) { 3019 // If the lexical context has been merged, look into the now-canonical 3020 // definition. 3021 if (auto *Merged = Reader.MergedDeclContexts.lookup(DC)) 3022 DC = Merged; 3023 3024 // If we've seen this before, return the canonical declaration. 3025 auto &Previous = Reader.AnonymousDeclarationsForMerging[DC]; 3026 if (Index < Previous.size() && Previous[Index]) 3027 return Previous[Index]; 3028 3029 // If this is the first time, but we have parsed a declaration of the context, 3030 // build the anonymous declaration list from the parsed declaration. 3031 if (!cast<Decl>(DC)->isFromASTFile()) { 3032 numberAnonymousDeclsWithin(DC, [&](NamedDecl *ND, unsigned Number) { 3033 if (Previous.size() == Number) 3034 Previous.push_back(cast<NamedDecl>(ND->getCanonicalDecl())); 3035 else 3036 Previous[Number] = cast<NamedDecl>(ND->getCanonicalDecl()); 3037 }); 3038 } 3039 3040 return Index < Previous.size() ? Previous[Index] : nullptr; 3041 } 3042 3043 void ASTDeclReader::setAnonymousDeclForMerging(ASTReader &Reader, 3044 DeclContext *DC, unsigned Index, 3045 NamedDecl *D) { 3046 if (auto *Merged = Reader.MergedDeclContexts.lookup(DC)) 3047 DC = Merged; 3048 3049 auto &Previous = Reader.AnonymousDeclarationsForMerging[DC]; 3050 if (Index >= Previous.size()) 3051 Previous.resize(Index + 1); 3052 if (!Previous[Index]) 3053 Previous[Index] = D; 3054 } 3055 3056 ASTDeclReader::FindExistingResult ASTDeclReader::findExisting(NamedDecl *D) { 3057 DeclarationName Name = TypedefNameForLinkage ? TypedefNameForLinkage 3058 : D->getDeclName(); 3059 3060 if (!Name && !needsAnonymousDeclarationNumber(D)) { 3061 // Don't bother trying to find unnamed declarations that are in 3062 // unmergeable contexts. 3063 FindExistingResult Result(Reader, D, /*Existing=*/nullptr, 3064 AnonymousDeclNumber, TypedefNameForLinkage); 3065 Result.suppress(); 3066 return Result; 3067 } 3068 3069 DeclContext *DC = D->getDeclContext()->getRedeclContext(); 3070 if (TypedefNameForLinkage) { 3071 auto It = Reader.ImportedTypedefNamesForLinkage.find( 3072 std::make_pair(DC, TypedefNameForLinkage)); 3073 if (It != Reader.ImportedTypedefNamesForLinkage.end()) 3074 if (isSameEntity(It->second, D)) 3075 return FindExistingResult(Reader, D, It->second, AnonymousDeclNumber, 3076 TypedefNameForLinkage); 3077 // Go on to check in other places in case an existing typedef name 3078 // was not imported. 3079 } 3080 3081 if (needsAnonymousDeclarationNumber(D)) { 3082 // This is an anonymous declaration that we may need to merge. Look it up 3083 // in its context by number. 3084 if (auto *Existing = getAnonymousDeclForMerging( 3085 Reader, D->getLexicalDeclContext(), AnonymousDeclNumber)) 3086 if (isSameEntity(Existing, D)) 3087 return FindExistingResult(Reader, D, Existing, AnonymousDeclNumber, 3088 TypedefNameForLinkage); 3089 } else if (DC->isTranslationUnit() && 3090 !Reader.getContext().getLangOpts().CPlusPlus) { 3091 IdentifierResolver &IdResolver = Reader.getIdResolver(); 3092 3093 // Temporarily consider the identifier to be up-to-date. We don't want to 3094 // cause additional lookups here. 3095 class UpToDateIdentifierRAII { 3096 IdentifierInfo *II; 3097 bool WasOutToDate; 3098 3099 public: 3100 explicit UpToDateIdentifierRAII(IdentifierInfo *II) 3101 : II(II), WasOutToDate(false) 3102 { 3103 if (II) { 3104 WasOutToDate = II->isOutOfDate(); 3105 if (WasOutToDate) 3106 II->setOutOfDate(false); 3107 } 3108 } 3109 3110 ~UpToDateIdentifierRAII() { 3111 if (WasOutToDate) 3112 II->setOutOfDate(true); 3113 } 3114 } UpToDate(Name.getAsIdentifierInfo()); 3115 3116 for (IdentifierResolver::iterator I = IdResolver.begin(Name), 3117 IEnd = IdResolver.end(); 3118 I != IEnd; ++I) { 3119 if (NamedDecl *Existing = getDeclForMerging(*I, TypedefNameForLinkage)) 3120 if (isSameEntity(Existing, D)) 3121 return FindExistingResult(Reader, D, Existing, AnonymousDeclNumber, 3122 TypedefNameForLinkage); 3123 } 3124 } else if (DeclContext *MergeDC = getPrimaryContextForMerging(Reader, DC)) { 3125 DeclContext::lookup_result R = MergeDC->noload_lookup(Name); 3126 for (DeclContext::lookup_iterator I = R.begin(), E = R.end(); I != E; ++I) { 3127 if (NamedDecl *Existing = getDeclForMerging(*I, TypedefNameForLinkage)) 3128 if (isSameEntity(Existing, D)) 3129 return FindExistingResult(Reader, D, Existing, AnonymousDeclNumber, 3130 TypedefNameForLinkage); 3131 } 3132 } else { 3133 // Not in a mergeable context. 3134 return FindExistingResult(Reader); 3135 } 3136 3137 // If this declaration is from a merged context, make a note that we need to 3138 // check that the canonical definition of that context contains the decl. 3139 // 3140 // FIXME: We should do something similar if we merge two definitions of the 3141 // same template specialization into the same CXXRecordDecl. 3142 auto MergedDCIt = Reader.MergedDeclContexts.find(D->getLexicalDeclContext()); 3143 if (MergedDCIt != Reader.MergedDeclContexts.end() && 3144 MergedDCIt->second == D->getDeclContext()) 3145 Reader.PendingOdrMergeChecks.push_back(D); 3146 3147 return FindExistingResult(Reader, D, /*Existing=*/nullptr, 3148 AnonymousDeclNumber, TypedefNameForLinkage); 3149 } 3150 3151 template<typename DeclT> 3152 Decl *ASTDeclReader::getMostRecentDeclImpl(Redeclarable<DeclT> *D) { 3153 return D->RedeclLink.getLatestNotUpdated(); 3154 } 3155 Decl *ASTDeclReader::getMostRecentDeclImpl(...) { 3156 llvm_unreachable("getMostRecentDecl on non-redeclarable declaration"); 3157 } 3158 3159 Decl *ASTDeclReader::getMostRecentDecl(Decl *D) { 3160 assert(D); 3161 3162 switch (D->getKind()) { 3163 #define ABSTRACT_DECL(TYPE) 3164 #define DECL(TYPE, BASE) \ 3165 case Decl::TYPE: \ 3166 return getMostRecentDeclImpl(cast<TYPE##Decl>(D)); 3167 #include "clang/AST/DeclNodes.inc" 3168 } 3169 llvm_unreachable("unknown decl kind"); 3170 } 3171 3172 Decl *ASTReader::getMostRecentExistingDecl(Decl *D) { 3173 return ASTDeclReader::getMostRecentDecl(D->getCanonicalDecl()); 3174 } 3175 3176 template<typename DeclT> 3177 void ASTDeclReader::attachPreviousDeclImpl(ASTReader &Reader, 3178 Redeclarable<DeclT> *D, 3179 Decl *Previous, Decl *Canon) { 3180 D->RedeclLink.setPrevious(cast<DeclT>(Previous)); 3181 D->First = cast<DeclT>(Previous)->First; 3182 } 3183 3184 namespace clang { 3185 template<> 3186 void ASTDeclReader::attachPreviousDeclImpl(ASTReader &Reader, 3187 Redeclarable<VarDecl> *D, 3188 Decl *Previous, Decl *Canon) { 3189 VarDecl *VD = static_cast<VarDecl*>(D); 3190 VarDecl *PrevVD = cast<VarDecl>(Previous); 3191 D->RedeclLink.setPrevious(PrevVD); 3192 D->First = PrevVD->First; 3193 3194 // We should keep at most one definition on the chain. 3195 // FIXME: Cache the definition once we've found it. Building a chain with 3196 // N definitions currently takes O(N^2) time here. 3197 if (VD->isThisDeclarationADefinition() == VarDecl::Definition) { 3198 for (VarDecl *CurD = PrevVD; CurD; CurD = CurD->getPreviousDecl()) { 3199 if (CurD->isThisDeclarationADefinition() == VarDecl::Definition) { 3200 Reader.mergeDefinitionVisibility(CurD, VD); 3201 VD->demoteThisDefinitionToDeclaration(); 3202 break; 3203 } 3204 } 3205 } 3206 } 3207 3208 template<> 3209 void ASTDeclReader::attachPreviousDeclImpl(ASTReader &Reader, 3210 Redeclarable<FunctionDecl> *D, 3211 Decl *Previous, Decl *Canon) { 3212 FunctionDecl *FD = static_cast<FunctionDecl*>(D); 3213 FunctionDecl *PrevFD = cast<FunctionDecl>(Previous); 3214 3215 FD->RedeclLink.setPrevious(PrevFD); 3216 FD->First = PrevFD->First; 3217 3218 // If the previous declaration is an inline function declaration, then this 3219 // declaration is too. 3220 if (PrevFD->IsInline != FD->IsInline) { 3221 // FIXME: [dcl.fct.spec]p4: 3222 // If a function with external linkage is declared inline in one 3223 // translation unit, it shall be declared inline in all translation 3224 // units in which it appears. 3225 // 3226 // Be careful of this case: 3227 // 3228 // module A: 3229 // template<typename T> struct X { void f(); }; 3230 // template<typename T> inline void X<T>::f() {} 3231 // 3232 // module B instantiates the declaration of X<int>::f 3233 // module C instantiates the definition of X<int>::f 3234 // 3235 // If module B and C are merged, we do not have a violation of this rule. 3236 FD->IsInline = true; 3237 } 3238 3239 // If we need to propagate an exception specification along the redecl 3240 // chain, make a note of that so that we can do so later. 3241 auto *FPT = FD->getType()->getAs<FunctionProtoType>(); 3242 auto *PrevFPT = PrevFD->getType()->getAs<FunctionProtoType>(); 3243 if (FPT && PrevFPT) { 3244 bool IsUnresolved = isUnresolvedExceptionSpec(FPT->getExceptionSpecType()); 3245 bool WasUnresolved = 3246 isUnresolvedExceptionSpec(PrevFPT->getExceptionSpecType()); 3247 if (IsUnresolved != WasUnresolved) 3248 Reader.PendingExceptionSpecUpdates.insert( 3249 std::make_pair(Canon, IsUnresolved ? PrevFD : FD)); 3250 } 3251 } 3252 } // end namespace clang 3253 3254 void ASTDeclReader::attachPreviousDeclImpl(ASTReader &Reader, ...) { 3255 llvm_unreachable("attachPreviousDecl on non-redeclarable declaration"); 3256 } 3257 3258 /// Inherit the default template argument from \p From to \p To. Returns 3259 /// \c false if there is no default template for \p From. 3260 template <typename ParmDecl> 3261 static bool inheritDefaultTemplateArgument(ASTContext &Context, ParmDecl *From, 3262 Decl *ToD) { 3263 auto *To = cast<ParmDecl>(ToD); 3264 if (!From->hasDefaultArgument()) 3265 return false; 3266 To->setInheritedDefaultArgument(Context, From); 3267 return true; 3268 } 3269 3270 static void inheritDefaultTemplateArguments(ASTContext &Context, 3271 TemplateDecl *From, 3272 TemplateDecl *To) { 3273 auto *FromTP = From->getTemplateParameters(); 3274 auto *ToTP = To->getTemplateParameters(); 3275 assert(FromTP->size() == ToTP->size() && "merged mismatched templates?"); 3276 3277 for (unsigned I = 0, N = FromTP->size(); I != N; ++I) { 3278 NamedDecl *FromParam = FromTP->getParam(N - I - 1); 3279 if (FromParam->isParameterPack()) 3280 continue; 3281 NamedDecl *ToParam = ToTP->getParam(N - I - 1); 3282 3283 if (auto *FTTP = dyn_cast<TemplateTypeParmDecl>(FromParam)) { 3284 if (!inheritDefaultTemplateArgument(Context, FTTP, ToParam)) 3285 break; 3286 } else if (auto *FNTTP = dyn_cast<NonTypeTemplateParmDecl>(FromParam)) { 3287 if (!inheritDefaultTemplateArgument(Context, FNTTP, ToParam)) 3288 break; 3289 } else { 3290 if (!inheritDefaultTemplateArgument( 3291 Context, cast<TemplateTemplateParmDecl>(FromParam), ToParam)) 3292 break; 3293 } 3294 } 3295 } 3296 3297 void ASTDeclReader::attachPreviousDecl(ASTReader &Reader, Decl *D, 3298 Decl *Previous, Decl *Canon) { 3299 assert(D && Previous); 3300 3301 switch (D->getKind()) { 3302 #define ABSTRACT_DECL(TYPE) 3303 #define DECL(TYPE, BASE) \ 3304 case Decl::TYPE: \ 3305 attachPreviousDeclImpl(Reader, cast<TYPE##Decl>(D), Previous, Canon); \ 3306 break; 3307 #include "clang/AST/DeclNodes.inc" 3308 } 3309 3310 // If the declaration was visible in one module, a redeclaration of it in 3311 // another module remains visible even if it wouldn't be visible by itself. 3312 // 3313 // FIXME: In this case, the declaration should only be visible if a module 3314 // that makes it visible has been imported. 3315 D->IdentifierNamespace |= 3316 Previous->IdentifierNamespace & 3317 (Decl::IDNS_Ordinary | Decl::IDNS_Tag | Decl::IDNS_Type); 3318 3319 // If the declaration declares a template, it may inherit default arguments 3320 // from the previous declaration. 3321 if (TemplateDecl *TD = dyn_cast<TemplateDecl>(D)) 3322 inheritDefaultTemplateArguments(Reader.getContext(), 3323 cast<TemplateDecl>(Previous), TD); 3324 } 3325 3326 template<typename DeclT> 3327 void ASTDeclReader::attachLatestDeclImpl(Redeclarable<DeclT> *D, Decl *Latest) { 3328 D->RedeclLink.setLatest(cast<DeclT>(Latest)); 3329 } 3330 void ASTDeclReader::attachLatestDeclImpl(...) { 3331 llvm_unreachable("attachLatestDecl on non-redeclarable declaration"); 3332 } 3333 3334 void ASTDeclReader::attachLatestDecl(Decl *D, Decl *Latest) { 3335 assert(D && Latest); 3336 3337 switch (D->getKind()) { 3338 #define ABSTRACT_DECL(TYPE) 3339 #define DECL(TYPE, BASE) \ 3340 case Decl::TYPE: \ 3341 attachLatestDeclImpl(cast<TYPE##Decl>(D), Latest); \ 3342 break; 3343 #include "clang/AST/DeclNodes.inc" 3344 } 3345 } 3346 3347 template<typename DeclT> 3348 void ASTDeclReader::markIncompleteDeclChainImpl(Redeclarable<DeclT> *D) { 3349 D->RedeclLink.markIncomplete(); 3350 } 3351 void ASTDeclReader::markIncompleteDeclChainImpl(...) { 3352 llvm_unreachable("markIncompleteDeclChain on non-redeclarable declaration"); 3353 } 3354 3355 void ASTReader::markIncompleteDeclChain(Decl *D) { 3356 switch (D->getKind()) { 3357 #define ABSTRACT_DECL(TYPE) 3358 #define DECL(TYPE, BASE) \ 3359 case Decl::TYPE: \ 3360 ASTDeclReader::markIncompleteDeclChainImpl(cast<TYPE##Decl>(D)); \ 3361 break; 3362 #include "clang/AST/DeclNodes.inc" 3363 } 3364 } 3365 3366 /// \brief Read the declaration at the given offset from the AST file. 3367 Decl *ASTReader::ReadDeclRecord(DeclID ID) { 3368 unsigned Index = ID - NUM_PREDEF_DECL_IDS; 3369 SourceLocation DeclLoc; 3370 RecordLocation Loc = DeclCursorForID(ID, DeclLoc); 3371 llvm::BitstreamCursor &DeclsCursor = Loc.F->DeclsCursor; 3372 // Keep track of where we are in the stream, then jump back there 3373 // after reading this declaration. 3374 SavedStreamPosition SavedPosition(DeclsCursor); 3375 3376 ReadingKindTracker ReadingKind(Read_Decl, *this); 3377 3378 // Note that we are loading a declaration record. 3379 Deserializing ADecl(this); 3380 3381 DeclsCursor.JumpToBit(Loc.Offset); 3382 ASTRecordReader Record(*this, *Loc.F); 3383 ASTDeclReader Reader(*this, Record, Loc, ID, DeclLoc); 3384 unsigned Code = DeclsCursor.ReadCode(); 3385 3386 ASTContext &Context = getContext(); 3387 Decl *D = nullptr; 3388 switch ((DeclCode)Record.readRecord(DeclsCursor, Code)) { 3389 case DECL_CONTEXT_LEXICAL: 3390 case DECL_CONTEXT_VISIBLE: 3391 llvm_unreachable("Record cannot be de-serialized with ReadDeclRecord"); 3392 case DECL_TYPEDEF: 3393 D = TypedefDecl::CreateDeserialized(Context, ID); 3394 break; 3395 case DECL_TYPEALIAS: 3396 D = TypeAliasDecl::CreateDeserialized(Context, ID); 3397 break; 3398 case DECL_ENUM: 3399 D = EnumDecl::CreateDeserialized(Context, ID); 3400 break; 3401 case DECL_RECORD: 3402 D = RecordDecl::CreateDeserialized(Context, ID); 3403 break; 3404 case DECL_ENUM_CONSTANT: 3405 D = EnumConstantDecl::CreateDeserialized(Context, ID); 3406 break; 3407 case DECL_FUNCTION: 3408 D = FunctionDecl::CreateDeserialized(Context, ID); 3409 break; 3410 case DECL_LINKAGE_SPEC: 3411 D = LinkageSpecDecl::CreateDeserialized(Context, ID); 3412 break; 3413 case DECL_EXPORT: 3414 D = ExportDecl::CreateDeserialized(Context, ID); 3415 break; 3416 case DECL_LABEL: 3417 D = LabelDecl::CreateDeserialized(Context, ID); 3418 break; 3419 case DECL_NAMESPACE: 3420 D = NamespaceDecl::CreateDeserialized(Context, ID); 3421 break; 3422 case DECL_NAMESPACE_ALIAS: 3423 D = NamespaceAliasDecl::CreateDeserialized(Context, ID); 3424 break; 3425 case DECL_USING: 3426 D = UsingDecl::CreateDeserialized(Context, ID); 3427 break; 3428 case DECL_USING_PACK: 3429 D = UsingPackDecl::CreateDeserialized(Context, ID, Record.readInt()); 3430 break; 3431 case DECL_USING_SHADOW: 3432 D = UsingShadowDecl::CreateDeserialized(Context, ID); 3433 break; 3434 case DECL_CONSTRUCTOR_USING_SHADOW: 3435 D = ConstructorUsingShadowDecl::CreateDeserialized(Context, ID); 3436 break; 3437 case DECL_USING_DIRECTIVE: 3438 D = UsingDirectiveDecl::CreateDeserialized(Context, ID); 3439 break; 3440 case DECL_UNRESOLVED_USING_VALUE: 3441 D = UnresolvedUsingValueDecl::CreateDeserialized(Context, ID); 3442 break; 3443 case DECL_UNRESOLVED_USING_TYPENAME: 3444 D = UnresolvedUsingTypenameDecl::CreateDeserialized(Context, ID); 3445 break; 3446 case DECL_CXX_RECORD: 3447 D = CXXRecordDecl::CreateDeserialized(Context, ID); 3448 break; 3449 case DECL_CXX_DEDUCTION_GUIDE: 3450 D = CXXDeductionGuideDecl::CreateDeserialized(Context, ID); 3451 break; 3452 case DECL_CXX_METHOD: 3453 D = CXXMethodDecl::CreateDeserialized(Context, ID); 3454 break; 3455 case DECL_CXX_CONSTRUCTOR: 3456 D = CXXConstructorDecl::CreateDeserialized(Context, ID, false); 3457 break; 3458 case DECL_CXX_INHERITED_CONSTRUCTOR: 3459 D = CXXConstructorDecl::CreateDeserialized(Context, ID, true); 3460 break; 3461 case DECL_CXX_DESTRUCTOR: 3462 D = CXXDestructorDecl::CreateDeserialized(Context, ID); 3463 break; 3464 case DECL_CXX_CONVERSION: 3465 D = CXXConversionDecl::CreateDeserialized(Context, ID); 3466 break; 3467 case DECL_ACCESS_SPEC: 3468 D = AccessSpecDecl::CreateDeserialized(Context, ID); 3469 break; 3470 case DECL_FRIEND: 3471 D = FriendDecl::CreateDeserialized(Context, ID, Record.readInt()); 3472 break; 3473 case DECL_FRIEND_TEMPLATE: 3474 D = FriendTemplateDecl::CreateDeserialized(Context, ID); 3475 break; 3476 case DECL_CLASS_TEMPLATE: 3477 D = ClassTemplateDecl::CreateDeserialized(Context, ID); 3478 break; 3479 case DECL_CLASS_TEMPLATE_SPECIALIZATION: 3480 D = ClassTemplateSpecializationDecl::CreateDeserialized(Context, ID); 3481 break; 3482 case DECL_CLASS_TEMPLATE_PARTIAL_SPECIALIZATION: 3483 D = ClassTemplatePartialSpecializationDecl::CreateDeserialized(Context, ID); 3484 break; 3485 case DECL_VAR_TEMPLATE: 3486 D = VarTemplateDecl::CreateDeserialized(Context, ID); 3487 break; 3488 case DECL_VAR_TEMPLATE_SPECIALIZATION: 3489 D = VarTemplateSpecializationDecl::CreateDeserialized(Context, ID); 3490 break; 3491 case DECL_VAR_TEMPLATE_PARTIAL_SPECIALIZATION: 3492 D = VarTemplatePartialSpecializationDecl::CreateDeserialized(Context, ID); 3493 break; 3494 case DECL_CLASS_SCOPE_FUNCTION_SPECIALIZATION: 3495 D = ClassScopeFunctionSpecializationDecl::CreateDeserialized(Context, ID); 3496 break; 3497 case DECL_FUNCTION_TEMPLATE: 3498 D = FunctionTemplateDecl::CreateDeserialized(Context, ID); 3499 break; 3500 case DECL_TEMPLATE_TYPE_PARM: 3501 D = TemplateTypeParmDecl::CreateDeserialized(Context, ID); 3502 break; 3503 case DECL_NON_TYPE_TEMPLATE_PARM: 3504 D = NonTypeTemplateParmDecl::CreateDeserialized(Context, ID); 3505 break; 3506 case DECL_EXPANDED_NON_TYPE_TEMPLATE_PARM_PACK: 3507 D = NonTypeTemplateParmDecl::CreateDeserialized(Context, ID, 3508 Record.readInt()); 3509 break; 3510 case DECL_TEMPLATE_TEMPLATE_PARM: 3511 D = TemplateTemplateParmDecl::CreateDeserialized(Context, ID); 3512 break; 3513 case DECL_EXPANDED_TEMPLATE_TEMPLATE_PARM_PACK: 3514 D = TemplateTemplateParmDecl::CreateDeserialized(Context, ID, 3515 Record.readInt()); 3516 break; 3517 case DECL_TYPE_ALIAS_TEMPLATE: 3518 D = TypeAliasTemplateDecl::CreateDeserialized(Context, ID); 3519 break; 3520 case DECL_STATIC_ASSERT: 3521 D = StaticAssertDecl::CreateDeserialized(Context, ID); 3522 break; 3523 case DECL_OBJC_METHOD: 3524 D = ObjCMethodDecl::CreateDeserialized(Context, ID); 3525 break; 3526 case DECL_OBJC_INTERFACE: 3527 D = ObjCInterfaceDecl::CreateDeserialized(Context, ID); 3528 break; 3529 case DECL_OBJC_IVAR: 3530 D = ObjCIvarDecl::CreateDeserialized(Context, ID); 3531 break; 3532 case DECL_OBJC_PROTOCOL: 3533 D = ObjCProtocolDecl::CreateDeserialized(Context, ID); 3534 break; 3535 case DECL_OBJC_AT_DEFS_FIELD: 3536 D = ObjCAtDefsFieldDecl::CreateDeserialized(Context, ID); 3537 break; 3538 case DECL_OBJC_CATEGORY: 3539 D = ObjCCategoryDecl::CreateDeserialized(Context, ID); 3540 break; 3541 case DECL_OBJC_CATEGORY_IMPL: 3542 D = ObjCCategoryImplDecl::CreateDeserialized(Context, ID); 3543 break; 3544 case DECL_OBJC_IMPLEMENTATION: 3545 D = ObjCImplementationDecl::CreateDeserialized(Context, ID); 3546 break; 3547 case DECL_OBJC_COMPATIBLE_ALIAS: 3548 D = ObjCCompatibleAliasDecl::CreateDeserialized(Context, ID); 3549 break; 3550 case DECL_OBJC_PROPERTY: 3551 D = ObjCPropertyDecl::CreateDeserialized(Context, ID); 3552 break; 3553 case DECL_OBJC_PROPERTY_IMPL: 3554 D = ObjCPropertyImplDecl::CreateDeserialized(Context, ID); 3555 break; 3556 case DECL_FIELD: 3557 D = FieldDecl::CreateDeserialized(Context, ID); 3558 break; 3559 case DECL_INDIRECTFIELD: 3560 D = IndirectFieldDecl::CreateDeserialized(Context, ID); 3561 break; 3562 case DECL_VAR: 3563 D = VarDecl::CreateDeserialized(Context, ID); 3564 break; 3565 case DECL_IMPLICIT_PARAM: 3566 D = ImplicitParamDecl::CreateDeserialized(Context, ID); 3567 break; 3568 case DECL_PARM_VAR: 3569 D = ParmVarDecl::CreateDeserialized(Context, ID); 3570 break; 3571 case DECL_DECOMPOSITION: 3572 D = DecompositionDecl::CreateDeserialized(Context, ID, Record.readInt()); 3573 break; 3574 case DECL_BINDING: 3575 D = BindingDecl::CreateDeserialized(Context, ID); 3576 break; 3577 case DECL_FILE_SCOPE_ASM: 3578 D = FileScopeAsmDecl::CreateDeserialized(Context, ID); 3579 break; 3580 case DECL_BLOCK: 3581 D = BlockDecl::CreateDeserialized(Context, ID); 3582 break; 3583 case DECL_MS_PROPERTY: 3584 D = MSPropertyDecl::CreateDeserialized(Context, ID); 3585 break; 3586 case DECL_CAPTURED: 3587 D = CapturedDecl::CreateDeserialized(Context, ID, Record.readInt()); 3588 break; 3589 case DECL_CXX_BASE_SPECIFIERS: 3590 Error("attempt to read a C++ base-specifier record as a declaration"); 3591 return nullptr; 3592 case DECL_CXX_CTOR_INITIALIZERS: 3593 Error("attempt to read a C++ ctor initializer record as a declaration"); 3594 return nullptr; 3595 case DECL_IMPORT: 3596 // Note: last entry of the ImportDecl record is the number of stored source 3597 // locations. 3598 D = ImportDecl::CreateDeserialized(Context, ID, Record.back()); 3599 break; 3600 case DECL_OMP_THREADPRIVATE: 3601 D = OMPThreadPrivateDecl::CreateDeserialized(Context, ID, Record.readInt()); 3602 break; 3603 case DECL_OMP_DECLARE_REDUCTION: 3604 D = OMPDeclareReductionDecl::CreateDeserialized(Context, ID); 3605 break; 3606 case DECL_OMP_CAPTUREDEXPR: 3607 D = OMPCapturedExprDecl::CreateDeserialized(Context, ID); 3608 break; 3609 case DECL_PRAGMA_COMMENT: 3610 D = PragmaCommentDecl::CreateDeserialized(Context, ID, Record.readInt()); 3611 break; 3612 case DECL_PRAGMA_DETECT_MISMATCH: 3613 D = PragmaDetectMismatchDecl::CreateDeserialized(Context, ID, 3614 Record.readInt()); 3615 break; 3616 case DECL_EMPTY: 3617 D = EmptyDecl::CreateDeserialized(Context, ID); 3618 break; 3619 case DECL_OBJC_TYPE_PARAM: 3620 D = ObjCTypeParamDecl::CreateDeserialized(Context, ID); 3621 break; 3622 } 3623 3624 assert(D && "Unknown declaration reading AST file"); 3625 LoadedDecl(Index, D); 3626 // Set the DeclContext before doing any deserialization, to make sure internal 3627 // calls to Decl::getASTContext() by Decl's methods will find the 3628 // TranslationUnitDecl without crashing. 3629 D->setDeclContext(Context.getTranslationUnitDecl()); 3630 Reader.Visit(D); 3631 3632 // If this declaration is also a declaration context, get the 3633 // offsets for its tables of lexical and visible declarations. 3634 if (DeclContext *DC = dyn_cast<DeclContext>(D)) { 3635 std::pair<uint64_t, uint64_t> Offsets = Reader.VisitDeclContext(DC); 3636 if (Offsets.first && 3637 ReadLexicalDeclContextStorage(*Loc.F, DeclsCursor, Offsets.first, DC)) 3638 return nullptr; 3639 if (Offsets.second && 3640 ReadVisibleDeclContextStorage(*Loc.F, DeclsCursor, Offsets.second, ID)) 3641 return nullptr; 3642 } 3643 assert(Record.getIdx() == Record.size()); 3644 3645 // Load any relevant update records. 3646 PendingUpdateRecords.push_back( 3647 PendingUpdateRecord(ID, D, /*JustLoaded=*/true)); 3648 3649 // Load the categories after recursive loading is finished. 3650 if (ObjCInterfaceDecl *Class = dyn_cast<ObjCInterfaceDecl>(D)) 3651 // If we already have a definition when deserializing the ObjCInterfaceDecl, 3652 // we put the Decl in PendingDefinitions so we can pull the categories here. 3653 if (Class->isThisDeclarationADefinition() || 3654 PendingDefinitions.count(Class)) 3655 loadObjCCategories(ID, Class); 3656 3657 // If we have deserialized a declaration that has a definition the 3658 // AST consumer might need to know about, queue it. 3659 // We don't pass it to the consumer immediately because we may be in recursive 3660 // loading, and some declarations may still be initializing. 3661 PotentiallyInterestingDecls.push_back( 3662 InterestingDecl(D, Reader.hasPendingBody())); 3663 3664 return D; 3665 } 3666 3667 void ASTReader::PassInterestingDeclsToConsumer() { 3668 assert(Consumer); 3669 3670 if (PassingDeclsToConsumer) 3671 return; 3672 3673 // Guard variable to avoid recursively redoing the process of passing 3674 // decls to consumer. 3675 SaveAndRestore<bool> GuardPassingDeclsToConsumer(PassingDeclsToConsumer, 3676 true); 3677 3678 // Ensure that we've loaded all potentially-interesting declarations 3679 // that need to be eagerly loaded. 3680 for (auto ID : EagerlyDeserializedDecls) 3681 GetDecl(ID); 3682 EagerlyDeserializedDecls.clear(); 3683 3684 while (!PotentiallyInterestingDecls.empty()) { 3685 InterestingDecl D = PotentiallyInterestingDecls.front(); 3686 PotentiallyInterestingDecls.pop_front(); 3687 if (isConsumerInterestedIn(getContext(), D.getDecl(), D.hasPendingBody())) 3688 PassInterestingDeclToConsumer(D.getDecl()); 3689 } 3690 } 3691 3692 void ASTReader::loadDeclUpdateRecords(PendingUpdateRecord &Record) { 3693 // The declaration may have been modified by files later in the chain. 3694 // If this is the case, read the record containing the updates from each file 3695 // and pass it to ASTDeclReader to make the modifications. 3696 serialization::GlobalDeclID ID = Record.ID; 3697 Decl *D = Record.D; 3698 ProcessingUpdatesRAIIObj ProcessingUpdates(*this); 3699 DeclUpdateOffsetsMap::iterator UpdI = DeclUpdateOffsets.find(ID); 3700 3701 llvm::SmallVector<serialization::DeclID, 8> PendingLazySpecializationIDs; 3702 3703 if (UpdI != DeclUpdateOffsets.end()) { 3704 auto UpdateOffsets = std::move(UpdI->second); 3705 DeclUpdateOffsets.erase(UpdI); 3706 3707 // Check if this decl was interesting to the consumer. If we just loaded 3708 // the declaration, then we know it was interesting and we skip the call 3709 // to isConsumerInterestedIn because it is unsafe to call in the 3710 // current ASTReader state. 3711 bool WasInteresting = 3712 Record.JustLoaded || isConsumerInterestedIn(getContext(), D, false); 3713 for (auto &FileAndOffset : UpdateOffsets) { 3714 ModuleFile *F = FileAndOffset.first; 3715 uint64_t Offset = FileAndOffset.second; 3716 llvm::BitstreamCursor &Cursor = F->DeclsCursor; 3717 SavedStreamPosition SavedPosition(Cursor); 3718 Cursor.JumpToBit(Offset); 3719 unsigned Code = Cursor.ReadCode(); 3720 ASTRecordReader Record(*this, *F); 3721 unsigned RecCode = Record.readRecord(Cursor, Code); 3722 (void)RecCode; 3723 assert(RecCode == DECL_UPDATES && "Expected DECL_UPDATES record!"); 3724 3725 ASTDeclReader Reader(*this, Record, RecordLocation(F, Offset), ID, 3726 SourceLocation()); 3727 Reader.UpdateDecl(D, PendingLazySpecializationIDs); 3728 3729 // We might have made this declaration interesting. If so, remember that 3730 // we need to hand it off to the consumer. 3731 if (!WasInteresting && 3732 isConsumerInterestedIn(getContext(), D, Reader.hasPendingBody())) { 3733 PotentiallyInterestingDecls.push_back( 3734 InterestingDecl(D, Reader.hasPendingBody())); 3735 WasInteresting = true; 3736 } 3737 } 3738 } 3739 // Add the lazy specializations to the template. 3740 assert((PendingLazySpecializationIDs.empty() || isa<ClassTemplateDecl>(D) || 3741 isa<FunctionTemplateDecl>(D) || isa<VarTemplateDecl>(D)) && 3742 "Must not have pending specializations"); 3743 if (auto *CTD = dyn_cast<ClassTemplateDecl>(D)) 3744 ASTDeclReader::AddLazySpecializations(CTD, PendingLazySpecializationIDs); 3745 else if (auto *FTD = dyn_cast<FunctionTemplateDecl>(D)) 3746 ASTDeclReader::AddLazySpecializations(FTD, PendingLazySpecializationIDs); 3747 else if (auto *VTD = dyn_cast<VarTemplateDecl>(D)) 3748 ASTDeclReader::AddLazySpecializations(VTD, PendingLazySpecializationIDs); 3749 PendingLazySpecializationIDs.clear(); 3750 3751 // Load the pending visible updates for this decl context, if it has any. 3752 auto I = PendingVisibleUpdates.find(ID); 3753 if (I != PendingVisibleUpdates.end()) { 3754 auto VisibleUpdates = std::move(I->second); 3755 PendingVisibleUpdates.erase(I); 3756 3757 auto *DC = cast<DeclContext>(D)->getPrimaryContext(); 3758 for (const PendingVisibleUpdate &Update : VisibleUpdates) 3759 Lookups[DC].Table.add( 3760 Update.Mod, Update.Data, 3761 reader::ASTDeclContextNameLookupTrait(*this, *Update.Mod)); 3762 DC->setHasExternalVisibleStorage(true); 3763 } 3764 } 3765 3766 void ASTReader::loadPendingDeclChain(Decl *FirstLocal, uint64_t LocalOffset) { 3767 // Attach FirstLocal to the end of the decl chain. 3768 Decl *CanonDecl = FirstLocal->getCanonicalDecl(); 3769 if (FirstLocal != CanonDecl) { 3770 Decl *PrevMostRecent = ASTDeclReader::getMostRecentDecl(CanonDecl); 3771 ASTDeclReader::attachPreviousDecl( 3772 *this, FirstLocal, PrevMostRecent ? PrevMostRecent : CanonDecl, 3773 CanonDecl); 3774 } 3775 3776 if (!LocalOffset) { 3777 ASTDeclReader::attachLatestDecl(CanonDecl, FirstLocal); 3778 return; 3779 } 3780 3781 // Load the list of other redeclarations from this module file. 3782 ModuleFile *M = getOwningModuleFile(FirstLocal); 3783 assert(M && "imported decl from no module file"); 3784 3785 llvm::BitstreamCursor &Cursor = M->DeclsCursor; 3786 SavedStreamPosition SavedPosition(Cursor); 3787 Cursor.JumpToBit(LocalOffset); 3788 3789 RecordData Record; 3790 unsigned Code = Cursor.ReadCode(); 3791 unsigned RecCode = Cursor.readRecord(Code, Record); 3792 (void)RecCode; 3793 assert(RecCode == LOCAL_REDECLARATIONS && "expected LOCAL_REDECLARATIONS record!"); 3794 3795 // FIXME: We have several different dispatches on decl kind here; maybe 3796 // we should instead generate one loop per kind and dispatch up-front? 3797 Decl *MostRecent = FirstLocal; 3798 for (unsigned I = 0, N = Record.size(); I != N; ++I) { 3799 auto *D = GetLocalDecl(*M, Record[N - I - 1]); 3800 ASTDeclReader::attachPreviousDecl(*this, D, MostRecent, CanonDecl); 3801 MostRecent = D; 3802 } 3803 ASTDeclReader::attachLatestDecl(CanonDecl, MostRecent); 3804 } 3805 3806 namespace { 3807 /// \brief Given an ObjC interface, goes through the modules and links to the 3808 /// interface all the categories for it. 3809 class ObjCCategoriesVisitor { 3810 ASTReader &Reader; 3811 ObjCInterfaceDecl *Interface; 3812 llvm::SmallPtrSetImpl<ObjCCategoryDecl *> &Deserialized; 3813 ObjCCategoryDecl *Tail; 3814 llvm::DenseMap<DeclarationName, ObjCCategoryDecl *> NameCategoryMap; 3815 serialization::GlobalDeclID InterfaceID; 3816 unsigned PreviousGeneration; 3817 3818 void add(ObjCCategoryDecl *Cat) { 3819 // Only process each category once. 3820 if (!Deserialized.erase(Cat)) 3821 return; 3822 3823 // Check for duplicate categories. 3824 if (Cat->getDeclName()) { 3825 ObjCCategoryDecl *&Existing = NameCategoryMap[Cat->getDeclName()]; 3826 if (Existing && 3827 Reader.getOwningModuleFile(Existing) 3828 != Reader.getOwningModuleFile(Cat)) { 3829 // FIXME: We should not warn for duplicates in diamond: 3830 // 3831 // MT // 3832 // / \ // 3833 // ML MR // 3834 // \ / // 3835 // MB // 3836 // 3837 // If there are duplicates in ML/MR, there will be warning when 3838 // creating MB *and* when importing MB. We should not warn when 3839 // importing. 3840 Reader.Diag(Cat->getLocation(), diag::warn_dup_category_def) 3841 << Interface->getDeclName() << Cat->getDeclName(); 3842 Reader.Diag(Existing->getLocation(), diag::note_previous_definition); 3843 } else if (!Existing) { 3844 // Record this category. 3845 Existing = Cat; 3846 } 3847 } 3848 3849 // Add this category to the end of the chain. 3850 if (Tail) 3851 ASTDeclReader::setNextObjCCategory(Tail, Cat); 3852 else 3853 Interface->setCategoryListRaw(Cat); 3854 Tail = Cat; 3855 } 3856 3857 public: 3858 ObjCCategoriesVisitor(ASTReader &Reader, 3859 ObjCInterfaceDecl *Interface, 3860 llvm::SmallPtrSetImpl<ObjCCategoryDecl *> &Deserialized, 3861 serialization::GlobalDeclID InterfaceID, 3862 unsigned PreviousGeneration) 3863 : Reader(Reader), Interface(Interface), Deserialized(Deserialized), 3864 Tail(nullptr), InterfaceID(InterfaceID), 3865 PreviousGeneration(PreviousGeneration) 3866 { 3867 // Populate the name -> category map with the set of known categories. 3868 for (auto *Cat : Interface->known_categories()) { 3869 if (Cat->getDeclName()) 3870 NameCategoryMap[Cat->getDeclName()] = Cat; 3871 3872 // Keep track of the tail of the category list. 3873 Tail = Cat; 3874 } 3875 } 3876 3877 bool operator()(ModuleFile &M) { 3878 // If we've loaded all of the category information we care about from 3879 // this module file, we're done. 3880 if (M.Generation <= PreviousGeneration) 3881 return true; 3882 3883 // Map global ID of the definition down to the local ID used in this 3884 // module file. If there is no such mapping, we'll find nothing here 3885 // (or in any module it imports). 3886 DeclID LocalID = Reader.mapGlobalIDToModuleFileGlobalID(M, InterfaceID); 3887 if (!LocalID) 3888 return true; 3889 3890 // Perform a binary search to find the local redeclarations for this 3891 // declaration (if any). 3892 const ObjCCategoriesInfo Compare = { LocalID, 0 }; 3893 const ObjCCategoriesInfo *Result 3894 = std::lower_bound(M.ObjCCategoriesMap, 3895 M.ObjCCategoriesMap + M.LocalNumObjCCategoriesInMap, 3896 Compare); 3897 if (Result == M.ObjCCategoriesMap + M.LocalNumObjCCategoriesInMap || 3898 Result->DefinitionID != LocalID) { 3899 // We didn't find anything. If the class definition is in this module 3900 // file, then the module files it depends on cannot have any categories, 3901 // so suppress further lookup. 3902 return Reader.isDeclIDFromModule(InterfaceID, M); 3903 } 3904 3905 // We found something. Dig out all of the categories. 3906 unsigned Offset = Result->Offset; 3907 unsigned N = M.ObjCCategories[Offset]; 3908 M.ObjCCategories[Offset++] = 0; // Don't try to deserialize again 3909 for (unsigned I = 0; I != N; ++I) 3910 add(cast_or_null<ObjCCategoryDecl>( 3911 Reader.GetLocalDecl(M, M.ObjCCategories[Offset++]))); 3912 return true; 3913 } 3914 }; 3915 } // end anonymous namespace 3916 3917 void ASTReader::loadObjCCategories(serialization::GlobalDeclID ID, 3918 ObjCInterfaceDecl *D, 3919 unsigned PreviousGeneration) { 3920 ObjCCategoriesVisitor Visitor(*this, D, CategoriesDeserialized, ID, 3921 PreviousGeneration); 3922 ModuleMgr.visit(Visitor); 3923 } 3924 3925 template<typename DeclT, typename Fn> 3926 static void forAllLaterRedecls(DeclT *D, Fn F) { 3927 F(D); 3928 3929 // Check whether we've already merged D into its redeclaration chain. 3930 // MostRecent may or may not be nullptr if D has not been merged. If 3931 // not, walk the merged redecl chain and see if it's there. 3932 auto *MostRecent = D->getMostRecentDecl(); 3933 bool Found = false; 3934 for (auto *Redecl = MostRecent; Redecl && !Found; 3935 Redecl = Redecl->getPreviousDecl()) 3936 Found = (Redecl == D); 3937 3938 // If this declaration is merged, apply the functor to all later decls. 3939 if (Found) { 3940 for (auto *Redecl = MostRecent; Redecl != D; 3941 Redecl = Redecl->getPreviousDecl()) 3942 F(Redecl); 3943 } 3944 } 3945 3946 void ASTDeclReader::UpdateDecl(Decl *D, 3947 llvm::SmallVectorImpl<serialization::DeclID> &PendingLazySpecializationIDs) { 3948 while (Record.getIdx() < Record.size()) { 3949 switch ((DeclUpdateKind)Record.readInt()) { 3950 case UPD_CXX_ADDED_IMPLICIT_MEMBER: { 3951 auto *RD = cast<CXXRecordDecl>(D); 3952 // FIXME: If we also have an update record for instantiating the 3953 // definition of D, we need that to happen before we get here. 3954 Decl *MD = Record.readDecl(); 3955 assert(MD && "couldn't read decl from update record"); 3956 // FIXME: We should call addHiddenDecl instead, to add the member 3957 // to its DeclContext. 3958 RD->addedMember(MD); 3959 break; 3960 } 3961 3962 case UPD_CXX_ADDED_TEMPLATE_SPECIALIZATION: 3963 // It will be added to the template's lazy specialization set. 3964 PendingLazySpecializationIDs.push_back(ReadDeclID()); 3965 break; 3966 3967 case UPD_CXX_ADDED_ANONYMOUS_NAMESPACE: { 3968 NamespaceDecl *Anon = ReadDeclAs<NamespaceDecl>(); 3969 3970 // Each module has its own anonymous namespace, which is disjoint from 3971 // any other module's anonymous namespaces, so don't attach the anonymous 3972 // namespace at all. 3973 if (!Record.isModule()) { 3974 if (TranslationUnitDecl *TU = dyn_cast<TranslationUnitDecl>(D)) 3975 TU->setAnonymousNamespace(Anon); 3976 else 3977 cast<NamespaceDecl>(D)->setAnonymousNamespace(Anon); 3978 } 3979 break; 3980 } 3981 3982 case UPD_CXX_INSTANTIATED_STATIC_DATA_MEMBER: { 3983 VarDecl *VD = cast<VarDecl>(D); 3984 VD->getMemberSpecializationInfo()->setPointOfInstantiation( 3985 ReadSourceLocation()); 3986 uint64_t Val = Record.readInt(); 3987 if (Val && !VD->getInit()) { 3988 VD->setInit(Record.readExpr()); 3989 if (Val > 1) { // IsInitKnownICE = 1, IsInitNotICE = 2, IsInitICE = 3 3990 EvaluatedStmt *Eval = VD->ensureEvaluatedStmt(); 3991 Eval->CheckedICE = true; 3992 Eval->IsICE = Val == 3; 3993 } 3994 } 3995 break; 3996 } 3997 3998 case UPD_CXX_INSTANTIATED_DEFAULT_ARGUMENT: { 3999 auto Param = cast<ParmVarDecl>(D); 4000 4001 // We have to read the default argument regardless of whether we use it 4002 // so that hypothetical further update records aren't messed up. 4003 // TODO: Add a function to skip over the next expr record. 4004 auto DefaultArg = Record.readExpr(); 4005 4006 // Only apply the update if the parameter still has an uninstantiated 4007 // default argument. 4008 if (Param->hasUninstantiatedDefaultArg()) 4009 Param->setDefaultArg(DefaultArg); 4010 break; 4011 } 4012 4013 case UPD_CXX_INSTANTIATED_DEFAULT_MEMBER_INITIALIZER: { 4014 auto FD = cast<FieldDecl>(D); 4015 auto DefaultInit = Record.readExpr(); 4016 4017 // Only apply the update if the field still has an uninstantiated 4018 // default member initializer. 4019 if (FD->hasInClassInitializer() && !FD->getInClassInitializer()) { 4020 if (DefaultInit) 4021 FD->setInClassInitializer(DefaultInit); 4022 else 4023 // Instantiation failed. We can get here if we serialized an AST for 4024 // an invalid program. 4025 FD->removeInClassInitializer(); 4026 } 4027 break; 4028 } 4029 4030 case UPD_CXX_ADDED_FUNCTION_DEFINITION: { 4031 FunctionDecl *FD = cast<FunctionDecl>(D); 4032 if (Reader.PendingBodies[FD]) { 4033 // FIXME: Maybe check for ODR violations. 4034 // It's safe to stop now because this update record is always last. 4035 return; 4036 } 4037 4038 if (Record.readInt()) { 4039 // Maintain AST consistency: any later redeclarations of this function 4040 // are inline if this one is. (We might have merged another declaration 4041 // into this one.) 4042 forAllLaterRedecls(FD, [](FunctionDecl *FD) { 4043 FD->setImplicitlyInline(); 4044 }); 4045 } 4046 FD->setInnerLocStart(ReadSourceLocation()); 4047 ReadFunctionDefinition(FD); 4048 assert(Record.getIdx() == Record.size() && "lazy body must be last"); 4049 break; 4050 } 4051 4052 case UPD_CXX_INSTANTIATED_CLASS_DEFINITION: { 4053 auto *RD = cast<CXXRecordDecl>(D); 4054 auto *OldDD = RD->getCanonicalDecl()->DefinitionData; 4055 bool HadRealDefinition = 4056 OldDD && (OldDD->Definition != RD || 4057 !Reader.PendingFakeDefinitionData.count(OldDD)); 4058 ReadCXXRecordDefinition(RD, /*Update*/true); 4059 4060 // Visible update is handled separately. 4061 uint64_t LexicalOffset = ReadLocalOffset(); 4062 if (!HadRealDefinition && LexicalOffset) { 4063 Record.readLexicalDeclContextStorage(LexicalOffset, RD); 4064 Reader.PendingFakeDefinitionData.erase(OldDD); 4065 } 4066 4067 auto TSK = (TemplateSpecializationKind)Record.readInt(); 4068 SourceLocation POI = ReadSourceLocation(); 4069 if (MemberSpecializationInfo *MSInfo = 4070 RD->getMemberSpecializationInfo()) { 4071 MSInfo->setTemplateSpecializationKind(TSK); 4072 MSInfo->setPointOfInstantiation(POI); 4073 } else { 4074 ClassTemplateSpecializationDecl *Spec = 4075 cast<ClassTemplateSpecializationDecl>(RD); 4076 Spec->setTemplateSpecializationKind(TSK); 4077 Spec->setPointOfInstantiation(POI); 4078 4079 if (Record.readInt()) { 4080 auto PartialSpec = 4081 ReadDeclAs<ClassTemplatePartialSpecializationDecl>(); 4082 SmallVector<TemplateArgument, 8> TemplArgs; 4083 Record.readTemplateArgumentList(TemplArgs); 4084 auto *TemplArgList = TemplateArgumentList::CreateCopy( 4085 Reader.getContext(), TemplArgs); 4086 4087 // FIXME: If we already have a partial specialization set, 4088 // check that it matches. 4089 if (!Spec->getSpecializedTemplateOrPartial() 4090 .is<ClassTemplatePartialSpecializationDecl *>()) 4091 Spec->setInstantiationOf(PartialSpec, TemplArgList); 4092 } 4093 } 4094 4095 RD->setTagKind((TagTypeKind)Record.readInt()); 4096 RD->setLocation(ReadSourceLocation()); 4097 RD->setLocStart(ReadSourceLocation()); 4098 RD->setBraceRange(ReadSourceRange()); 4099 4100 if (Record.readInt()) { 4101 AttrVec Attrs; 4102 Record.readAttributes(Attrs); 4103 // If the declaration already has attributes, we assume that some other 4104 // AST file already loaded them. 4105 if (!D->hasAttrs()) 4106 D->setAttrsImpl(Attrs, Reader.getContext()); 4107 } 4108 break; 4109 } 4110 4111 case UPD_CXX_RESOLVED_DTOR_DELETE: { 4112 // Set the 'operator delete' directly to avoid emitting another update 4113 // record. 4114 auto *Del = ReadDeclAs<FunctionDecl>(); 4115 auto *First = cast<CXXDestructorDecl>(D->getCanonicalDecl()); 4116 // FIXME: Check consistency if we have an old and new operator delete. 4117 if (!First->OperatorDelete) 4118 First->OperatorDelete = Del; 4119 break; 4120 } 4121 4122 case UPD_CXX_RESOLVED_EXCEPTION_SPEC: { 4123 FunctionProtoType::ExceptionSpecInfo ESI; 4124 SmallVector<QualType, 8> ExceptionStorage; 4125 Record.readExceptionSpec(ExceptionStorage, ESI); 4126 4127 // Update this declaration's exception specification, if needed. 4128 auto *FD = cast<FunctionDecl>(D); 4129 auto *FPT = FD->getType()->castAs<FunctionProtoType>(); 4130 // FIXME: If the exception specification is already present, check that it 4131 // matches. 4132 if (isUnresolvedExceptionSpec(FPT->getExceptionSpecType())) { 4133 FD->setType(Reader.getContext().getFunctionType( 4134 FPT->getReturnType(), FPT->getParamTypes(), 4135 FPT->getExtProtoInfo().withExceptionSpec(ESI))); 4136 4137 // When we get to the end of deserializing, see if there are other decls 4138 // that we need to propagate this exception specification onto. 4139 Reader.PendingExceptionSpecUpdates.insert( 4140 std::make_pair(FD->getCanonicalDecl(), FD)); 4141 } 4142 break; 4143 } 4144 4145 case UPD_CXX_DEDUCED_RETURN_TYPE: { 4146 // FIXME: Also do this when merging redecls. 4147 QualType DeducedResultType = Record.readType(); 4148 for (auto *Redecl : merged_redecls(D)) { 4149 // FIXME: If the return type is already deduced, check that it matches. 4150 FunctionDecl *FD = cast<FunctionDecl>(Redecl); 4151 Reader.getContext().adjustDeducedFunctionResultType(FD, 4152 DeducedResultType); 4153 } 4154 break; 4155 } 4156 4157 case UPD_DECL_MARKED_USED: { 4158 // Maintain AST consistency: any later redeclarations are used too. 4159 D->markUsed(Reader.getContext()); 4160 break; 4161 } 4162 4163 case UPD_MANGLING_NUMBER: 4164 Reader.getContext().setManglingNumber(cast<NamedDecl>(D), 4165 Record.readInt()); 4166 break; 4167 4168 case UPD_STATIC_LOCAL_NUMBER: 4169 Reader.getContext().setStaticLocalNumber(cast<VarDecl>(D), 4170 Record.readInt()); 4171 break; 4172 4173 case UPD_DECL_MARKED_OPENMP_THREADPRIVATE: 4174 D->addAttr(OMPThreadPrivateDeclAttr::CreateImplicit(Reader.getContext(), 4175 ReadSourceRange())); 4176 break; 4177 4178 case UPD_DECL_EXPORTED: { 4179 unsigned SubmoduleID = readSubmoduleID(); 4180 auto *Exported = cast<NamedDecl>(D); 4181 if (auto *TD = dyn_cast<TagDecl>(Exported)) 4182 Exported = TD->getDefinition(); 4183 Module *Owner = SubmoduleID ? Reader.getSubmodule(SubmoduleID) : nullptr; 4184 if (Reader.getContext().getLangOpts().ModulesLocalVisibility) { 4185 Reader.getContext().mergeDefinitionIntoModule(cast<NamedDecl>(Exported), 4186 Owner); 4187 Reader.PendingMergedDefinitionsToDeduplicate.insert( 4188 cast<NamedDecl>(Exported)); 4189 } else if (Owner && Owner->NameVisibility != Module::AllVisible) { 4190 // If Owner is made visible at some later point, make this declaration 4191 // visible too. 4192 Reader.HiddenNamesMap[Owner].push_back(Exported); 4193 } else { 4194 // The declaration is now visible. 4195 Exported->setVisibleDespiteOwningModule(); 4196 } 4197 break; 4198 } 4199 4200 case UPD_DECL_MARKED_OPENMP_DECLARETARGET: 4201 case UPD_ADDED_ATTR_TO_RECORD: 4202 AttrVec Attrs; 4203 Record.readAttributes(Attrs); 4204 assert(Attrs.size() == 1); 4205 D->addAttr(Attrs[0]); 4206 break; 4207 } 4208 } 4209 } 4210