Author: rsmith Date: Fri Jul 15 19:35:14 2016 New Revision: 275653 URL: http://llvm.org/viewvc/llvm-project?rev=275653&view=rev Log: Reimplement ExternalSemaSource delegation in terms of MultiplexExternalSemaSource to remove one of the places that needs updating every time the ExternalSemaSource interface changes.
Modified: cfe/trunk/lib/Frontend/ChainedIncludesSource.cpp Modified: cfe/trunk/lib/Frontend/ChainedIncludesSource.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Frontend/ChainedIncludesSource.cpp?rev=275653&r1=275652&r2=275653&view=diff ============================================================================== --- cfe/trunk/lib/Frontend/ChainedIncludesSource.cpp (original) +++ cfe/trunk/lib/Frontend/ChainedIncludesSource.cpp Fri Jul 15 19:35:14 2016 @@ -18,6 +18,7 @@ #include "clang/Frontend/TextDiagnosticPrinter.h" #include "clang/Lex/Preprocessor.h" #include "clang/Parse/ParseAST.h" +#include "clang/Sema/MultiplexExternalSemaSource.h" #include "clang/Serialization/ASTReader.h" #include "clang/Serialization/ASTWriter.h" #include "llvm/Support/MemoryBuffer.h" @@ -25,51 +26,48 @@ using namespace clang; namespace { -class ChainedIncludesSource : public ExternalSemaSource { +class ChainedIncludesSourceImpl : public ExternalSemaSource { public: - ~ChainedIncludesSource() override; - - ExternalSemaSource &getFinalReader() const { return *FinalReader; } - - std::vector<CompilerInstance *> CIs; - IntrusiveRefCntPtr<ExternalSemaSource> FinalReader; + ChainedIncludesSourceImpl(std::vector<std::unique_ptr<CompilerInstance>> CIs) + : CIs(std::move(CIs)) {} protected: //===----------------------------------------------------------------------===// // ExternalASTSource interface. //===----------------------------------------------------------------------===// - Decl *GetExternalDecl(uint32_t ID) override; - Selector GetExternalSelector(uint32_t ID) override; - uint32_t GetNumExternalSelectors() override; - Stmt *GetExternalDeclStmt(uint64_t Offset) override; - CXXCtorInitializer **GetExternalCXXCtorInitializers(uint64_t Offset) override; - CXXBaseSpecifier *GetExternalCXXBaseSpecifiers(uint64_t Offset) override; - bool FindExternalVisibleDeclsByName(const DeclContext *DC, - DeclarationName Name) override; - void - FindExternalLexicalDecls(const DeclContext *DC, - llvm::function_ref<bool(Decl::Kind)> IsKindWeWant, - SmallVectorImpl<Decl *> &Result) override; - void CompleteType(TagDecl *Tag) override; - void CompleteType(ObjCInterfaceDecl *Class) override; - void StartedDeserializing() override; - void FinishedDeserializing() override; - void StartTranslationUnit(ASTConsumer *Consumer) override; - void PrintStats() override; - /// Return the amount of memory used by memory buffers, breaking down /// by heap-backed versus mmap'ed memory. - void getMemoryBufferSizes(MemoryBufferSizes &sizes) const override; + void getMemoryBufferSizes(MemoryBufferSizes &sizes) const override { + for (unsigned i = 0, e = CIs.size(); i != e; ++i) { + if (const ExternalASTSource *eSrc = + CIs[i]->getASTContext().getExternalSource()) { + eSrc->getMemoryBufferSizes(sizes); + } + } + } - //===----------------------------------------------------------------------===// - // ExternalSemaSource interface. - //===----------------------------------------------------------------------===// +private: + std::vector<std::unique_ptr<CompilerInstance>> CIs; +}; - void InitializeSema(Sema &S) override; - void ForgetSema() override; - void ReadMethodPool(Selector Sel) override; - bool LookupUnqualified(LookupResult &R, Scope *S) override; +/// Members of ChainedIncludesSource, factored out so we can initialize +/// them before we initialize the ExternalSemaSource base class. +struct ChainedIncludesSourceMembers { + ChainedIncludesSourceImpl Impl; + IntrusiveRefCntPtr<ExternalSemaSource> FinalReader; +}; + +/// Use MultiplexExternalSemaSource to dispatch all ExternalSemaSource +/// calls to the final reader. +class ChainedIncludesSource + : private ChainedIncludesSourceMembers, + public MultiplexExternalSemaSource { +public: + ChainedIncludesSource(std::vector<std::unique_ptr<CompilerInstance>> CIs, + IntrusiveRefCntPtr<ExternalSemaSource> FinalReader) + : ChainedIncludesSourceMembers{{std::move(CIs)}, std::move(FinalReader)}, + MultiplexExternalSemaSource(Impl, *this->FinalReader) {} }; } @@ -107,18 +105,13 @@ createASTReader(CompilerInstance &CI, St return nullptr; } -ChainedIncludesSource::~ChainedIncludesSource() { - for (unsigned i = 0, e = CIs.size(); i != e; ++i) - delete CIs[i]; -} - IntrusiveRefCntPtr<ExternalSemaSource> clang::createChainedIncludesSource( CompilerInstance &CI, IntrusiveRefCntPtr<ExternalSemaSource> &Reader) { std::vector<std::string> &includes = CI.getPreprocessorOpts().ChainedIncludes; assert(!includes.empty() && "No '-chain-include' in options!"); - IntrusiveRefCntPtr<ChainedIncludesSource> source(new ChainedIncludesSource()); + std::vector<std::unique_ptr<CompilerInstance>> CIs; InputKind IK = CI.getFrontendOpts().Inputs[0].getKind(); SmallVector<std::unique_ptr<llvm::MemoryBuffer>, 4> SerialBufs; @@ -206,7 +199,7 @@ IntrusiveRefCntPtr<ExternalSemaSource> c SerialBufs.push_back(llvm::MemoryBuffer::getMemBufferCopy( StringRef(serialAST.data(), serialAST.size()))); serialAST.clear(); - source->CIs.push_back(Clang.release()); + CIs.push_back(std::move(Clang)); } assert(!SerialBufs.empty()); @@ -216,83 +209,6 @@ IntrusiveRefCntPtr<ExternalSemaSource> c if (!Reader) return nullptr; - source->FinalReader = Reader; - return source; -} - -//===----------------------------------------------------------------------===// -// ExternalASTSource interface. -//===----------------------------------------------------------------------===// - -Decl *ChainedIncludesSource::GetExternalDecl(uint32_t ID) { - return getFinalReader().GetExternalDecl(ID); -} -Selector ChainedIncludesSource::GetExternalSelector(uint32_t ID) { - return getFinalReader().GetExternalSelector(ID); -} -uint32_t ChainedIncludesSource::GetNumExternalSelectors() { - return getFinalReader().GetNumExternalSelectors(); -} -Stmt *ChainedIncludesSource::GetExternalDeclStmt(uint64_t Offset) { - return getFinalReader().GetExternalDeclStmt(Offset); + return IntrusiveRefCntPtr<ChainedIncludesSource>( + new ChainedIncludesSource(std::move(CIs), Reader)); } -CXXBaseSpecifier * -ChainedIncludesSource::GetExternalCXXBaseSpecifiers(uint64_t Offset) { - return getFinalReader().GetExternalCXXBaseSpecifiers(Offset); -} -CXXCtorInitializer ** -ChainedIncludesSource::GetExternalCXXCtorInitializers(uint64_t Offset) { - return getFinalReader().GetExternalCXXCtorInitializers(Offset); -} -bool -ChainedIncludesSource::FindExternalVisibleDeclsByName(const DeclContext *DC, - DeclarationName Name) { - return getFinalReader().FindExternalVisibleDeclsByName(DC, Name); -} -void ChainedIncludesSource::FindExternalLexicalDecls( - const DeclContext *DC, llvm::function_ref<bool(Decl::Kind)> IsKindWeWant, - SmallVectorImpl<Decl *> &Result) { - return getFinalReader().FindExternalLexicalDecls(DC, IsKindWeWant, Result); -} -void ChainedIncludesSource::CompleteType(TagDecl *Tag) { - return getFinalReader().CompleteType(Tag); -} -void ChainedIncludesSource::CompleteType(ObjCInterfaceDecl *Class) { - return getFinalReader().CompleteType(Class); -} -void ChainedIncludesSource::StartedDeserializing() { - return getFinalReader().StartedDeserializing(); -} -void ChainedIncludesSource::FinishedDeserializing() { - return getFinalReader().FinishedDeserializing(); -} -void ChainedIncludesSource::StartTranslationUnit(ASTConsumer *Consumer) { - return getFinalReader().StartTranslationUnit(Consumer); -} -void ChainedIncludesSource::PrintStats() { - return getFinalReader().PrintStats(); -} -void ChainedIncludesSource::getMemoryBufferSizes(MemoryBufferSizes &sizes)const{ - for (unsigned i = 0, e = CIs.size(); i != e; ++i) { - if (const ExternalASTSource *eSrc = - CIs[i]->getASTContext().getExternalSource()) { - eSrc->getMemoryBufferSizes(sizes); - } - } - - getFinalReader().getMemoryBufferSizes(sizes); -} - -void ChainedIncludesSource::InitializeSema(Sema &S) { - return getFinalReader().InitializeSema(S); -} -void ChainedIncludesSource::ForgetSema() { - return getFinalReader().ForgetSema(); -} -void ChainedIncludesSource::ReadMethodPool(Selector Sel) { - getFinalReader().ReadMethodPool(Sel); -} -bool ChainedIncludesSource::LookupUnqualified(LookupResult &R, Scope *S) { - return getFinalReader().LookupUnqualified(R, S); -} - _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits