//===--- MultiplexExternalSemaSource.cpp ---------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file implements the event dispatching to the subscribed clients. // //===----------------------------------------------------------------------===// #include "clang/Sema/MultiplexExternalSemaSource.h" #include "clang/Sema/Lookup.h" using namespace clang; char MultiplexExternalSemaSource::ID; /// Constructs a new multiplexing external sema source and appends the /// given element to it. /// MultiplexExternalSemaSource::MultiplexExternalSemaSource( ExternalSemaSource *S1, ExternalSemaSource *S2) { S1->Retain(); S2->Retain(); Sources.push_back(S1); Sources.push_back(S2); } // pin the vtable here. MultiplexExternalSemaSource::~MultiplexExternalSemaSource() { for (auto *S : Sources) S->Release(); } /// Appends new source to the source list. /// ///\param[in] source - An ExternalSemaSource. /// void MultiplexExternalSemaSource::AddSource(ExternalSemaSource *Source) { Source->Retain(); Sources.push_back(Source); } //===----------------------------------------------------------------------===// // ExternalASTSource. //===----------------------------------------------------------------------===// Decl *MultiplexExternalSemaSource::GetExternalDecl(GlobalDeclID ID) { for(size_t i = 0; i < Sources.size(); ++i) if (Decl *Result = Sources[i]->GetExternalDecl(ID)) return Result; return nullptr; } void MultiplexExternalSemaSource::CompleteRedeclChain(const Decl *D) { for (size_t i = 0; i < Sources.size(); ++i) Sources[i]->CompleteRedeclChain(D); } Selector MultiplexExternalSemaSource::GetExternalSelector(uint32_t ID) { Selector Sel; for(size_t i = 0; i < Sources.size(); ++i) { Sel = Sources[i]->GetExternalSelector(ID); if (!Sel.isNull()) return Sel; } return Sel; } uint32_t MultiplexExternalSemaSource::GetNumExternalSelectors() { uint32_t total = 0; for(size_t i = 0; i < Sources.size(); ++i) total += Sources[i]->GetNumExternalSelectors(); return total; } Stmt *MultiplexExternalSemaSource::GetExternalDeclStmt(uint64_t Offset) { for(size_t i = 0; i < Sources.size(); ++i) if (Stmt *Result = Sources[i]->GetExternalDeclStmt(Offset)) return Result; return nullptr; } CXXBaseSpecifier *MultiplexExternalSemaSource::GetExternalCXXBaseSpecifiers( uint64_t Offset){ for(size_t i = 0; i < Sources.size(); ++i) if (CXXBaseSpecifier *R = Sources[i]->GetExternalCXXBaseSpecifiers(Offset)) return R; return nullptr; } CXXCtorInitializer ** MultiplexExternalSemaSource::GetExternalCXXCtorInitializers(uint64_t Offset) { for (auto *S : Sources) if (auto *R = S->GetExternalCXXCtorInitializers(Offset)) return R; return nullptr; } ExternalASTSource::ExtKind MultiplexExternalSemaSource::hasExternalDefinitions(const Decl *D) { for (const auto &S : Sources) if (auto EK = S->hasExternalDefinitions(D)) if (EK != EK_ReplyHazy) return EK; return EK_ReplyHazy; } bool MultiplexExternalSemaSource:: FindExternalVisibleDeclsByName(const DeclContext *DC, DeclarationName Name) { bool AnyDeclsFound = false; for (size_t i = 0; i < Sources.size(); ++i) AnyDeclsFound |= Sources[i]->FindExternalVisibleDeclsByName(DC, Name); return AnyDeclsFound; } void MultiplexExternalSemaSource::completeVisibleDeclsMap(const DeclContext *DC){ for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->completeVisibleDeclsMap(DC); } void MultiplexExternalSemaSource::FindExternalLexicalDecls( const DeclContext *DC, llvm::function_ref IsKindWeWant, SmallVectorImpl &Result) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->FindExternalLexicalDecls(DC, IsKindWeWant, Result); } void MultiplexExternalSemaSource::FindFileRegionDecls(FileID File, unsigned Offset, unsigned Length, SmallVectorImpl &Decls){ for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->FindFileRegionDecls(File, Offset, Length, Decls); } void MultiplexExternalSemaSource::CompleteType(TagDecl *Tag) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->CompleteType(Tag); } void MultiplexExternalSemaSource::CompleteType(ObjCInterfaceDecl *Class) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->CompleteType(Class); } void MultiplexExternalSemaSource::ReadComments() { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadComments(); } void MultiplexExternalSemaSource::StartedDeserializing() { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->StartedDeserializing(); } void MultiplexExternalSemaSource::FinishedDeserializing() { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->FinishedDeserializing(); } void MultiplexExternalSemaSource::StartTranslationUnit(ASTConsumer *Consumer) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->StartTranslationUnit(Consumer); } void MultiplexExternalSemaSource::PrintStats() { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->PrintStats(); } Module *MultiplexExternalSemaSource::getModule(unsigned ID) { for (size_t i = 0; i < Sources.size(); ++i) if (auto M = Sources[i]->getModule(ID)) return M; return nullptr; } bool MultiplexExternalSemaSource::layoutRecordType(const RecordDecl *Record, uint64_t &Size, uint64_t &Alignment, llvm::DenseMap &FieldOffsets, llvm::DenseMap &BaseOffsets, llvm::DenseMap &VirtualBaseOffsets){ for(size_t i = 0; i < Sources.size(); ++i) if (Sources[i]->layoutRecordType(Record, Size, Alignment, FieldOffsets, BaseOffsets, VirtualBaseOffsets)) return true; return false; } void MultiplexExternalSemaSource:: getMemoryBufferSizes(MemoryBufferSizes &sizes) const { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->getMemoryBufferSizes(sizes); } //===----------------------------------------------------------------------===// // ExternalSemaSource. //===----------------------------------------------------------------------===// void MultiplexExternalSemaSource::InitializeSema(Sema &S) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->InitializeSema(S); } void MultiplexExternalSemaSource::ForgetSema() { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ForgetSema(); } void MultiplexExternalSemaSource::ReadMethodPool(Selector Sel) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadMethodPool(Sel); } void MultiplexExternalSemaSource::updateOutOfDateSelector(Selector Sel) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->updateOutOfDateSelector(Sel); } void MultiplexExternalSemaSource::ReadKnownNamespaces( SmallVectorImpl &Namespaces){ for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadKnownNamespaces(Namespaces); } void MultiplexExternalSemaSource::ReadUndefinedButUsed( llvm::MapVector &Undefined) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadUndefinedButUsed(Undefined); } void MultiplexExternalSemaSource::ReadMismatchingDeleteExpressions( llvm::MapVector, 4>> & Exprs) { for (auto &Source : Sources) Source->ReadMismatchingDeleteExpressions(Exprs); } bool MultiplexExternalSemaSource::LookupUnqualified(LookupResult &R, Scope *S){ for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->LookupUnqualified(R, S); return !R.empty(); } void MultiplexExternalSemaSource::ReadTentativeDefinitions( SmallVectorImpl &TentativeDefs) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadTentativeDefinitions(TentativeDefs); } void MultiplexExternalSemaSource::ReadUnusedFileScopedDecls( SmallVectorImpl &Decls) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadUnusedFileScopedDecls(Decls); } void MultiplexExternalSemaSource::ReadDelegatingConstructors( SmallVectorImpl &Decls) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadDelegatingConstructors(Decls); } void MultiplexExternalSemaSource::ReadExtVectorDecls( SmallVectorImpl &Decls) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadExtVectorDecls(Decls); } void MultiplexExternalSemaSource::ReadDeclsToCheckForDeferredDiags( llvm::SmallSetVector &Decls) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadDeclsToCheckForDeferredDiags(Decls); } void MultiplexExternalSemaSource::ReadUnusedLocalTypedefNameCandidates( llvm::SmallSetVector &Decls) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadUnusedLocalTypedefNameCandidates(Decls); } void MultiplexExternalSemaSource::ReadReferencedSelectors( SmallVectorImpl > &Sels) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadReferencedSelectors(Sels); } void MultiplexExternalSemaSource::ReadWeakUndeclaredIdentifiers( SmallVectorImpl > &WI) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadWeakUndeclaredIdentifiers(WI); } void MultiplexExternalSemaSource::ReadUsedVTables( SmallVectorImpl &VTables) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadUsedVTables(VTables); } void MultiplexExternalSemaSource::ReadPendingInstantiations( SmallVectorImpl > &Pending) { for(size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadPendingInstantiations(Pending); } void MultiplexExternalSemaSource::ReadLateParsedTemplates( llvm::MapVector> &LPTMap) { for (size_t i = 0; i < Sources.size(); ++i) Sources[i]->ReadLateParsedTemplates(LPTMap); } TypoCorrection MultiplexExternalSemaSource::CorrectTypo( const DeclarationNameInfo &Typo, int LookupKind, Scope *S, CXXScopeSpec *SS, CorrectionCandidateCallback &CCC, DeclContext *MemberContext, bool EnteringContext, const ObjCObjectPointerType *OPT) { for (size_t I = 0, E = Sources.size(); I < E; ++I) { if (TypoCorrection C = Sources[I]->CorrectTypo(Typo, LookupKind, S, SS, CCC, MemberContext, EnteringContext, OPT)) return C; } return TypoCorrection(); } bool MultiplexExternalSemaSource::MaybeDiagnoseMissingCompleteType( SourceLocation Loc, QualType T) { for (size_t I = 0, E = Sources.size(); I < E; ++I) { if (Sources[I]->MaybeDiagnoseMissingCompleteType(Loc, T)) return true; } return false; } void MultiplexExternalSemaSource::AssignedLambdaNumbering( const CXXRecordDecl *Lambda) { for (auto *Source : Sources) Source->AssignedLambdaNumbering(Lambda); }