From 5be843617b65a5a2d72503e493dce9f8e3a2f3c4 Mon Sep 17 00:00:00 2001 From: Adrian Prantl Date: Thu, 24 Sep 2015 16:10:00 +0000 Subject: [PATCH] Refactor ASTSourceDescriptor to not store copies of all strings. (NFC) git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@248509 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/clang/AST/ExternalASTSource.h | 21 ++++++++++++++------- lib/AST/ExternalASTSource.cpp | 9 ++++++++- lib/CodeGen/CGDebugInfo.cpp | 13 +++++++------ 3 files changed, 29 insertions(+), 14 deletions(-) diff --git a/include/clang/AST/ExternalASTSource.h b/include/clang/AST/ExternalASTSource.h index ec7978fcc8..e3db1ee4c5 100644 --- a/include/clang/AST/ExternalASTSource.h +++ b/include/clang/AST/ExternalASTSource.h @@ -145,17 +145,24 @@ public: /// Abstracts clang modules and precompiled header files and holds /// everything needed to generate debug info for an imported module /// or PCH. - struct ASTSourceDescriptor { + class ASTSourceDescriptor { + StringRef PCHModuleName; + StringRef Path; + StringRef ASTFile; + uint64_t Signature = 0; + const Module *ClangModule = nullptr; + + public: ASTSourceDescriptor(){}; - ASTSourceDescriptor(std::string Name, std::string Path, std::string ASTFile, + ASTSourceDescriptor(StringRef Name, StringRef Path, StringRef ASTFile, uint64_t Signature) - : FullModuleName(std::move(Name)), Path(std::move(Path)), + : PCHModuleName(std::move(Name)), Path(std::move(Path)), ASTFile(std::move(ASTFile)), Signature(Signature){}; ASTSourceDescriptor(const Module &M); - std::string FullModuleName; - std::string Path; - std::string ASTFile; - uint64_t Signature = 0; + std::string getFullModuleName() const; + StringRef getPath() const { return Path; } + StringRef getASTFile() const { return ASTFile; } + uint64_t getSignature() const { return Signature; } }; /// Return a descriptor for the corresponding module, if one exists. diff --git a/lib/AST/ExternalASTSource.cpp b/lib/AST/ExternalASTSource.cpp index 8d32dd23bb..f3b15fc58c 100644 --- a/lib/AST/ExternalASTSource.cpp +++ b/lib/AST/ExternalASTSource.cpp @@ -29,13 +29,20 @@ ExternalASTSource::getSourceDescriptor(unsigned ID) { } ExternalASTSource::ASTSourceDescriptor::ASTSourceDescriptor(const Module &M) - : FullModuleName(M.getFullModuleName()), Signature(M.Signature) { + : Signature(M.Signature), ClangModule(&M) { if (M.Directory) Path = M.Directory->getName(); if (auto *File = M.getASTFile()) ASTFile = File->getName(); } +std::string ExternalASTSource::ASTSourceDescriptor::getFullModuleName() const { + if (ClangModule) + return ClangModule->getFullModuleName(); + else + return PCHModuleName; +} + void ExternalASTSource::FindFileRegionDecls(FileID File, unsigned Offset, unsigned Length, SmallVectorImpl &Decls) {} diff --git a/lib/CodeGen/CGDebugInfo.cpp b/lib/CodeGen/CGDebugInfo.cpp index 72ddf4efc7..04d6876076 100644 --- a/lib/CodeGen/CGDebugInfo.cpp +++ b/lib/CodeGen/CGDebugInfo.cpp @@ -1676,7 +1676,8 @@ llvm::DIType *CGDebugInfo::CreateType(const ObjCInterfaceType *Ty, llvm::DIModule * CGDebugInfo::getOrCreateModuleRef(ExternalASTSource::ASTSourceDescriptor Mod, bool CreateSkeletonCU) { - auto &ModRef = ModuleRefCache[Mod.FullModuleName]; + std::string FullModuleName = Mod.getFullModuleName(); + auto &ModRef = ModuleRefCache[FullModuleName]; if (ModRef) return cast(ModRef); @@ -1705,14 +1706,14 @@ CGDebugInfo::getOrCreateModuleRef(ExternalASTSource::ASTSourceDescriptor Mod, if (CreateSkeletonCU) { llvm::DIBuilder DIB(CGM.getModule()); - DIB.createCompileUnit(TheCU->getSourceLanguage(), Mod.FullModuleName, - Mod.Path, TheCU->getProducer(), true, StringRef(), 0, - Mod.ASTFile, llvm::DIBuilder::FullDebug, - Mod.Signature); + DIB.createCompileUnit(TheCU->getSourceLanguage(), FullModuleName, + Mod.getPath(), TheCU->getProducer(), true, + StringRef(), 0, Mod.getASTFile(), + llvm::DIBuilder::FullDebug, Mod.getSignature()); DIB.finalize(); } llvm::DIModule *M = - DBuilder.createModule(TheCU, Mod.FullModuleName, ConfigMacros, Mod.Path, + DBuilder.createModule(TheCU, FullModuleName, ConfigMacros, Mod.getPath(), CGM.getHeaderSearchOpts().Sysroot); ModRef.reset(M); return M; -- 2.40.0