[clang] 7806a92 - [clang][modules][deps] Serialize inputs into PCMs using the "as requested" name
Jan Svoboda via cfe-commits
cfe-commits at lists.llvm.org
Fri Dec 2 16:12:24 PST 2022
Author: Jan Svoboda
Date: 2022-12-02T16:12:16-08:00
New Revision: 7806a928688c12accdf47e7f8dc33d484c295858
URL: https://github.com/llvm/llvm-project/commit/7806a928688c12accdf47e7f8dc33d484c295858
DIFF: https://github.com/llvm/llvm-project/commit/7806a928688c12accdf47e7f8dc33d484c295858.diff
LOG: [clang][modules][deps] Serialize inputs into PCMs using the "as requested" name
This patch changes the PCM serialization logic to refer to input files by their "requested" name. This fixes a bug where the dependency scanner reports the "final" file paths, which can result in failed explicit compiles due to the `module.modulemap` file not being surrounded by the expected framework directory structure.
Depends on D135634.
Reviewed By: benlangmuir, Bigcheese
Differential Revision: https://reviews.llvm.org/D135636
Added:
clang/test/ClangScanDeps/modules-file-name-as-requested.m
Modified:
clang/lib/Serialization/ASTWriter.cpp
clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp
Removed:
################################################################################
diff --git a/clang/lib/Serialization/ASTWriter.cpp b/clang/lib/Serialization/ASTWriter.cpp
index 2c85d62981ec..db76a4767cf7 100644
--- a/clang/lib/Serialization/ASTWriter.cpp
+++ b/clang/lib/Serialization/ASTWriter.cpp
@@ -1625,7 +1625,7 @@ void ASTWriter::WriteInputFiles(SourceManager &SourceMgr,
Entry.IsTransient,
Entry.IsTopLevelModuleMap};
- EmitRecordWithPath(IFAbbrevCode, Record, Entry.File.getName());
+ EmitRecordWithPath(IFAbbrevCode, Record, Entry.File.getNameAsRequested());
}
// Emit content hash for this file.
diff --git a/clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp b/clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp
index bfb609c28cf5..e5996815881e 100644
--- a/clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp
+++ b/clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp
@@ -451,9 +451,9 @@ ModuleID ModuleDepCollectorPP::handleTopLevelModule(const Module *M) {
MDC.ScanInstance.getASTReader()->visitTopLevelModuleMaps(
*MF, [&](FileEntryRef FE) {
- if (FE.getName().endswith("__inferred_module.map"))
+ if (FE.getNameAsRequested().endswith("__inferred_module.map"))
return;
- MD.ModuleMapFileDeps.emplace_back(FE.getName());
+ MD.ModuleMapFileDeps.emplace_back(FE.getNameAsRequested());
});
CompilerInvocation CI = MDC.makeInvocationForModuleBuildWithoutOutputs(
diff --git a/clang/test/ClangScanDeps/modules-file-name-as-requested.m b/clang/test/ClangScanDeps/modules-file-name-as-requested.m
new file mode 100644
index 000000000000..bf6c03e13eb3
--- /dev/null
+++ b/clang/test/ClangScanDeps/modules-file-name-as-requested.m
@@ -0,0 +1,64 @@
+// This test checks that the module map paths we're reporting are the as-requested
+// paths (as opposed to the paths files resolve to after going through VFS overlays).
+
+// RUN: rm -rf %t
+// RUN: split-file %s %t
+
+//--- real/module.modulemap
+framework module FW { header "Header.h" }
+//--- real/Header.h
+//--- overlay.json.template
+{
+ "case-sensitive": "false",
+ "version": "0",
+ "roots": [
+ {
+ "contents": [
+ {
+ "external-contents" : "DIR/real/Header.h",
+ "name" : "Header.h",
+ "type" : "file"
+ }
+ ],
+ "name": "DIR/frameworks/FW.framework/Headers",
+ "type": "directory"
+ },
+ {
+ "contents": [
+ {
+ "external-contents": "DIR/real/module.modulemap",
+ "name": "module.modulemap",
+ "type": "file"
+ }
+ ],
+ "name": "DIR/frameworks/FW.framework/Modules",
+ "type": "directory"
+ }
+ ]
+}
+
+//--- modules/module.modulemap
+module Importer { header "header.h" }
+//--- modules/header.h
+#include <FW/Header.h>
+
+//--- cdb.json.template
+[{
+ "file": "DIR/tu.m",
+ "directory": "DIR",
+ "command": "clang -fmodules -fmodules-cache-path=DIR/cache -Werror=non-modular-include-in-module -ivfsoverlay DIR/overlay.json -F DIR/frameworks -I DIR/modules -c DIR/tu.m -o DIR/tu.o"
+}]
+
+//--- tu.m
+ at import Importer;
+
+// RUN: sed -e "s|DIR|%/t|g" %t/overlay.json.template > %t/overlay.json
+// RUN: sed -e "s|DIR|%/t|g" %t/cdb.json.template > %t/cdb.json
+// RUN: clang-scan-deps -compilation-database %t/cdb.json -format experimental-full > %t/result.json
+
+// RUN: %deps-to-rsp %t/result.json --module-name=FW > %t/FW.cc1.rsp
+// RUN: %deps-to-rsp %t/result.json --module-name=Importer > %t/Importer.cc1.rsp
+// RUN: %deps-to-rsp %t/result.json --tu-index=0 > %t/tu.rsp
+// RUN: %clang @%t/FW.cc1.rsp
+// RUN: %clang @%t/Importer.cc1.rsp
+// RUN: %clang @%t/tu.rsp
More information about the cfe-commits
mailing list