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