[clang][deps] NFC: Stop assuming the TU's context hash

The context hash of modular dependencies can be different from the context hash of the original translation unit if we modify their `CompilerInvocation`s.

Stop assuming the TU's context hash everywhere.

No functionality change here, since we're still currently using the unmodified TU CompilerInvocation to compute the context hash.

Reviewed By: dexonsmith

Differential Revision: https://reviews.llvm.org/D102473
This commit is contained in:
Jan Svoboda 2021-05-17 08:50:49 +02:00
parent 5ef21506b9
commit b9d5b0c201
3 changed files with 25 additions and 22 deletions

View File

@ -147,7 +147,7 @@ private:
/// Traverses the previously collected direct modular dependencies to discover /// Traverses the previously collected direct modular dependencies to discover
/// transitive modular dependencies and fills the parent \c ModuleDepCollector /// transitive modular dependencies and fills the parent \c ModuleDepCollector
/// with both. /// with both.
void handleTopLevelModule(const Module *M); ModuleID handleTopLevelModule(const Module *M);
void addAllSubmoduleDeps(const Module *M, ModuleDeps &MD, void addAllSubmoduleDeps(const Module *M, ModuleDeps &MD,
llvm::DenseSet<const Module *> &AddedModules); llvm::DenseSet<const Module *> &AddedModules);
void addModuleDep(const Module *M, ModuleDeps &MD, void addModuleDep(const Module *M, ModuleDeps &MD,
@ -173,13 +173,13 @@ private:
DependencyConsumer &Consumer; DependencyConsumer &Consumer;
/// Path to the main source file. /// Path to the main source file.
std::string MainFile; std::string MainFile;
/// The module hash identifying the compilation conditions. /// Hash identifying the compilation conditions of the current TU.
std::string ContextHash; std::string ContextHash;
/// Non-modular file dependencies. This includes the main source file and /// Non-modular file dependencies. This includes the main source file and
/// textually included header files. /// textually included header files.
std::vector<std::string> FileDeps; std::vector<std::string> FileDeps;
/// Direct and transitive modular dependencies of the main source file. /// Direct and transitive modular dependencies of the main source file.
std::unordered_map<std::string, ModuleDeps> ModularDeps; std::unordered_map<const Module *, ModuleDeps> ModularDeps;
/// Options that control the dependency output generation. /// Options that control the dependency output generation.
std::unique_ptr<DependencyOutputOptions> Opts; std::unique_ptr<DependencyOutputOptions> Opts;
}; };

View File

@ -143,7 +143,7 @@ DependencyScanningTool::getFullDependencies(
for (auto &&M : ClangModuleDeps) { for (auto &&M : ClangModuleDeps) {
auto &MD = M.second; auto &MD = M.second;
if (MD.ImportedByMainFile) if (MD.ImportedByMainFile)
FD.ClangModuleDeps.push_back({MD.ID.ModuleName, ContextHash}); FD.ClangModuleDeps.push_back(MD.ID);
} }
FullDependenciesResult FDR; FullDependenciesResult FDR;

View File

@ -144,8 +144,6 @@ void ModuleDepCollectorPP::handleImport(const Module *Imported) {
return; return;
const Module *TopLevelModule = Imported->getTopLevelModule(); const Module *TopLevelModule = Imported->getTopLevelModule();
MDC.ModularDeps[MDC.ContextHash + TopLevelModule->getFullModuleName()]
.ImportedByMainFile = true;
DirectModularDeps.insert(TopLevelModule); DirectModularDeps.insert(TopLevelModule);
} }
@ -164,28 +162,27 @@ void ModuleDepCollectorPP::EndOfMainFile() {
MDC.Consumer.handleFileDependency(*MDC.Opts, I); MDC.Consumer.handleFileDependency(*MDC.Opts, I);
} }
void ModuleDepCollectorPP::handleTopLevelModule(const Module *M) { ModuleID ModuleDepCollectorPP::handleTopLevelModule(const Module *M) {
assert(M == M->getTopLevelModule() && "Expected top level module!"); assert(M == M->getTopLevelModule() && "Expected top level module!");
auto ModI = MDC.ModularDeps.insert( // If this module has been handled already, just return its ID.
std::make_pair(MDC.ContextHash + M->getFullModuleName(), ModuleDeps{})); auto ModI = MDC.ModularDeps.insert({M, ModuleDeps{}});
if (!ModI.second)
if (!ModI.first->second.ID.ModuleName.empty()) return ModI.first->second.ID;
return;
ModuleDeps &MD = ModI.first->second; ModuleDeps &MD = ModI.first->second;
MD.ID.ModuleName = M->getFullModuleName();
MD.ImportedByMainFile = DirectModularDeps.contains(M);
MD.ImplicitModulePCMPath = std::string(M->getASTFile()->getName());
MD.IsSystem = M->IsSystem;
const FileEntry *ModuleMap = Instance.getPreprocessor() const FileEntry *ModuleMap = Instance.getPreprocessor()
.getHeaderSearchInfo() .getHeaderSearchInfo()
.getModuleMap() .getModuleMap()
.getContainingModuleMapFile(M); .getContainingModuleMapFile(M);
MD.Invocation = Instance.getInvocationPtr();
MD.ClangModuleMapFile = std::string(ModuleMap ? ModuleMap->getName() : ""); MD.ClangModuleMapFile = std::string(ModuleMap ? ModuleMap->getName() : "");
MD.ID.ModuleName = M->getFullModuleName();
MD.ImplicitModulePCMPath = std::string(M->getASTFile()->getName());
MD.ID.ContextHash = MDC.ContextHash;
MD.IsSystem = M->IsSystem;
serialization::ModuleFile *MF = serialization::ModuleFile *MF =
MDC.Instance.getASTReader()->getModuleManager().lookup(M->getASTFile()); MDC.Instance.getASTReader()->getModuleManager().lookup(M->getASTFile());
MDC.Instance.getASTReader()->visitInputFiles( MDC.Instance.getASTReader()->visitInputFiles(
@ -193,8 +190,16 @@ void ModuleDepCollectorPP::handleTopLevelModule(const Module *M) {
MD.FileDeps.insert(IF.getFile()->getName()); MD.FileDeps.insert(IF.getFile()->getName());
}); });
// FIXME: Prepare the CompilerInvocation for building this module **now**, so
// that we store the actual context hash for this module (not just the
// context hash inherited from the original TU).
MD.Invocation = Instance.getInvocationPtr();
MD.ID.ContextHash = MD.Invocation->getModuleHash();
llvm::DenseSet<const Module *> AddedModules; llvm::DenseSet<const Module *> AddedModules;
addAllSubmoduleDeps(M, MD, AddedModules); addAllSubmoduleDeps(M, MD, AddedModules);
return MD.ID;
} }
void ModuleDepCollectorPP::addAllSubmoduleDeps( void ModuleDepCollectorPP::addAllSubmoduleDeps(
@ -211,11 +216,9 @@ void ModuleDepCollectorPP::addModuleDep(
llvm::DenseSet<const Module *> &AddedModules) { llvm::DenseSet<const Module *> &AddedModules) {
for (const Module *Import : M->Imports) { for (const Module *Import : M->Imports) {
if (Import->getTopLevelModule() != M->getTopLevelModule()) { if (Import->getTopLevelModule() != M->getTopLevelModule()) {
ModuleID ImportID = handleTopLevelModule(Import->getTopLevelModule());
if (AddedModules.insert(Import->getTopLevelModule()).second) if (AddedModules.insert(Import->getTopLevelModule()).second)
MD.ClangModuleDeps.push_back( MD.ClangModuleDeps.push_back(ImportID);
{std::string(Import->getTopLevelModuleName()),
Instance.getInvocation().getModuleHash()});
handleTopLevelModule(Import->getTopLevelModule());
} }
} }
} }