[PATCH] D108540: [clang][deps] Collect precompiled deps from submodules too
This revision was automatically updated to reflect the committed changes. Closed by commit rG83c633ea1a5b: [clang][deps] Collect precompiled deps from submodules too (authored by jansvoboda11). Changed prior to commit: https://reviews.llvm.org/D108540?vs=368064=368575#toc Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D108540/new/ https://reviews.llvm.org/D108540 Files: clang/include/clang/Tooling/DependencyScanning/ModuleDepCollector.h clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/cdb_pch.json clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/cdb_tu.json clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/mod_common.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/mod_tu.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/mod_tu_sub.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/module.modulemap clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/pch.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/tu.c clang/test/ClangScanDeps/modules-pch-common-via-submodule.c Index: clang/test/ClangScanDeps/modules-pch-common-via-submodule.c === --- /dev/null +++ clang/test/ClangScanDeps/modules-pch-common-via-submodule.c @@ -0,0 +1,137 @@ +// Check that we discover dependency on a precompiled module (and generate the +// appropriate `-fmodule-file=` argument) when it's imported by a **submodule** +// instead of a top-level module. + +// RUN: rm -rf %t && mkdir %t +// RUN: cp %S/Inputs/modules-pch-common-via-submodule/* %t + +// Scan dependencies of the PCH: +// +// RUN: sed "s|DIR|%/t|g" %S/Inputs/modules-pch-common-via-submodule/cdb_pch.json > %t/cdb.json +// RUN: echo -%t > %t/result_pch.json +// RUN: clang-scan-deps -compilation-database %t/cdb.json -format experimental-full \ +// RUN: -generate-modules-path-args -module-files-dir %t/build >> %t/result_pch.json +// RUN: cat %t/result_pch.json | sed 's:\?:/:g' | FileCheck %s -check-prefix=CHECK-PCH +// +// CHECK-PCH: -[[PREFIX:.*]] +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "modules": [ +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "clang-module-deps": [], +// CHECK-PCH-NEXT: "clang-modulemap-file": "[[PREFIX]]/module.modulemap", +// CHECK-PCH-NEXT: "command-line": [ +// CHECK-PCH-NEXT: "-cc1" +// CHECK-PCH: "-emit-module" +// CHECK-PCH: "-fmodules" +// CHECK-PCH: "-fmodule-name=ModCommon" +// CHECK-PCH: "-fno-implicit-modules" +// CHECK-PCH:], +// CHECK-PCH-NEXT: "context-hash": "[[HASH_MOD_COMMON:.*]]", +// CHECK-PCH-NEXT: "file-deps": [ +// CHECK-PCH-NEXT: "[[PREFIX]]/mod_common.h", +// CHECK-PCH-NEXT: "[[PREFIX]]/module.modulemap" +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "name": "ModCommon" +// CHECK-PCH-NEXT: } +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "translation-units": [ +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "clang-context-hash": "[[HASH_PCH:.*]]", +// CHECK-PCH-NEXT: "clang-module-deps": [ +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "context-hash": "[[HASH_MOD_COMMON]]", +// CHECK-PCH-NEXT: "module-name": "ModCommon" +// CHECK-PCH-NEXT: } +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "command-line": [ +// CHECK-PCH-NEXT: "-fno-implicit-modules" +// CHECK-PCH-NEXT: "-fno-implicit-module-maps" +// CHECK-PCH-NEXT: "-fmodule-file=[[PREFIX]]/build/[[HASH_MOD_COMMON]]/ModCommon-{{.*}}.pcm" +// CHECK-PCH-NEXT: "-fmodule-map-file=[[PREFIX]]/module.modulemap" +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "file-deps": [ +// CHECK-PCH-NEXT: "[[PREFIX]]/pch.h" +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "input-file": "[[PREFIX]]/pch.h" +// CHECK-PCH-NEXT: } +// CHECK-PCH-NEXT: ] +// CHECK-PCH-NEXT: } + +// Explicitly build the PCH: +// +// RUN: tail -n +2 %t/result_pch.json > %t/result_pch_stripped.json +// RUN: %python %S/../../utils/module-deps-to-rsp.py %t/result_pch_stripped.json \ +// RUN: --module-name=ModCommon > %t/mod_common.cc1.rsp +// RUN: %python %S/../../utils/module-deps-to-rsp.py %t/result_pch_stripped.json \ +// RUN: --tu-index=0 > %t/pch.rsp +// +// RUN: %clang @%t/mod_common.cc1.rsp +// RUN: %clang -x c-header %t/pch.h -fmodules -gmodules -fimplicit-module-maps \ +// RUN: -fmodules-cache-path=%t/cache -o %t/pch.h.gch @%t/pch.rsp + +// Scan dependencies of the TU: +// +// RUN: sed "s|DIR|%/t|g" %S/Inputs/modules-pch-common-via-submodule/cdb_tu.json > %t/cdb.json +// RUN: echo -%t > %t/result_tu.json +// RUN: clang-scan-deps -compilation-database %t/cdb.json -format experimental-full \ +// RUN: -generate-modules-path-args -module-files-dir
[PATCH] D108540: [clang][deps] Collect precompiled deps from submodules too
dexonsmith accepted this revision. dexonsmith added a comment. This revision is now accepted and ready to land. LGTM. Comment at: clang/test/ClangScanDeps/modules-pch-common-via-submodule.c:85 +// CHECK-TU: "-emit-module" +// CHECK-TU: "-fmodule-file=[[PREFIX]]/build/[[HASH_MOD_COMMON:.*]]/ModCommon-{{.*}}.pcm" +// CHECK-TU: "-fmodules" jansvoboda11 wrote: > Previously, we'd miss this module included from `mod_tu_sub.h`, resulting in > a compilation error for `ModTU`. Can you add a comment to the top of the testcase explaining what's interesting about it? (Something similar to what you have here.) Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D108540/new/ https://reviews.llvm.org/D108540 ___ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
[PATCH] D108540: [clang][deps] Collect precompiled deps from submodules too
jansvoboda11 added inline comments. Comment at: clang/test/ClangScanDeps/modules-pch-common-via-submodule.c:85 +// CHECK-TU: "-emit-module" +// CHECK-TU: "-fmodule-file=[[PREFIX]]/build/[[HASH_MOD_COMMON:.*]]/ModCommon-{{.*}}.pcm" +// CHECK-TU: "-fmodules" Previously, we'd miss this module included from `mod_tu_sub.h`, resulting in a compilation error for `ModTU`. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D108540/new/ https://reviews.llvm.org/D108540 ___ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
[PATCH] D108540: [clang][deps] Collect precompiled deps from submodules too
jansvoboda11 created this revision. jansvoboda11 added reviewers: Bigcheese, dexonsmith, arphaman. jansvoboda11 requested review of this revision. Herald added a project: clang. Herald added a subscriber: cfe-commits. In this patch, the dependency scanner starts collecting precompiled dependencies from all encountered submodules, not only from top-level modules. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D108540 Files: clang/include/clang/Tooling/DependencyScanning/ModuleDepCollector.h clang/lib/Tooling/DependencyScanning/ModuleDepCollector.cpp clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/cdb_pch.json clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/cdb_tu.json clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/mod_common.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/mod_tu.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/mod_tu_sub.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/module.modulemap clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/pch.h clang/test/ClangScanDeps/Inputs/modules-pch-common-via-submodule/tu.c clang/test/ClangScanDeps/modules-pch-common-via-submodule.c Index: clang/test/ClangScanDeps/modules-pch-common-via-submodule.c === --- /dev/null +++ clang/test/ClangScanDeps/modules-pch-common-via-submodule.c @@ -0,0 +1,133 @@ +// RUN: rm -rf %t && mkdir %t +// RUN: cp %S/Inputs/modules-pch-common-via-submodule/* %t + +// Scan dependencies of the PCH: +// +// RUN: sed "s|DIR|%/t|g" %S/Inputs/modules-pch-common-via-submodule/cdb_pch.json > %t/cdb.json +// RUN: echo -%t > %t/result_pch.json +// RUN: clang-scan-deps -compilation-database %t/cdb.json -format experimental-full \ +// RUN: -generate-modules-path-args -module-files-dir %t/build >> %t/result_pch.json +// RUN: cat %t/result_pch.json | sed 's:\?:/:g' | FileCheck %s -check-prefix=CHECK-PCH +// +// CHECK-PCH: -[[PREFIX:.*]] +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "modules": [ +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "clang-module-deps": [], +// CHECK-PCH-NEXT: "clang-modulemap-file": "[[PREFIX]]/module.modulemap", +// CHECK-PCH-NEXT: "command-line": [ +// CHECK-PCH-NEXT: "-cc1" +// CHECK-PCH: "-emit-module" +// CHECK-PCH: "-fmodules" +// CHECK-PCH: "-fmodule-name=ModCommon" +// CHECK-PCH: "-fno-implicit-modules" +// CHECK-PCH:], +// CHECK-PCH-NEXT: "context-hash": "[[HASH_MOD_COMMON:.*]]", +// CHECK-PCH-NEXT: "file-deps": [ +// CHECK-PCH-NEXT: "[[PREFIX]]/mod_common.h", +// CHECK-PCH-NEXT: "[[PREFIX]]/module.modulemap" +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "name": "ModCommon" +// CHECK-PCH-NEXT: } +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "translation-units": [ +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "clang-context-hash": "[[HASH_PCH:.*]]", +// CHECK-PCH-NEXT: "clang-module-deps": [ +// CHECK-PCH-NEXT: { +// CHECK-PCH-NEXT: "context-hash": "[[HASH_MOD_COMMON]]", +// CHECK-PCH-NEXT: "module-name": "ModCommon" +// CHECK-PCH-NEXT: } +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "command-line": [ +// CHECK-PCH-NEXT: "-fno-implicit-modules" +// CHECK-PCH-NEXT: "-fno-implicit-module-maps" +// CHECK-PCH-DAG: "-fmodule-file=[[PREFIX]]/build/[[HASH_MOD_COMMON]]/ModCommon-{{.*}}.pcm" +// CHECK-PCH-NEXT: "-fmodule-map-file=[[PREFIX]]/module.modulemap" +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "file-deps": [ +// CHECK-PCH-NEXT: "[[PREFIX]]/pch.h" +// CHECK-PCH-NEXT: ], +// CHECK-PCH-NEXT: "input-file": "[[PREFIX]]/pch.h" +// CHECK-PCH-NEXT: } +// CHECK-PCH-NEXT: ] +// CHECK-PCH-NEXT: } + +// Explicitly build the PCH: +// +// RUN: tail -n +2 %t/result_pch.json > %t/result_pch_stripped.json +// RUN: %python %S/../../utils/module-deps-to-rsp.py %t/result_pch_stripped.json \ +// RUN: --module-name=ModCommon > %t/mod_common.cc1.rsp +// RUN: %python %S/../../utils/module-deps-to-rsp.py %t/result_pch_stripped.json \ +// RUN: --tu-index=0 > %t/pch.rsp +// +// RUN: %clang @%t/mod_common.cc1.rsp +// RUN: %clang -x c-header %t/pch.h -fmodules -gmodules -fimplicit-module-maps \ +// RUN: -fmodules-cache-path=%t/cache -o %t/pch.h.gch @%t/pch.rsp + +// Scan dependencies of the TU: +// +// RUN: sed "s|DIR|%/t|g" %S/Inputs/modules-pch-common-via-submodule/cdb_tu.json > %t/cdb.json +// RUN: echo -%t > %t/result_tu.json +// RUN: clang-scan-deps -compilation-database %t/cdb.json -format experimental-full \ +// RUN: -generate-modules-path-args -module-files-dir %t/build >> %t/result_tu.json +// RUN: cat %t/result_tu.json | sed 's:\?:/:g' | FileCheck %s -check-prefix=CHECK-TU +// +// CHECK-TU: -[[PREFIX:.*]] +// CHECK-TU-NEXT: