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