From c1c72302fe4553a39be37b5c310d046975e55019 Mon Sep 17 00:00:00 2001 From: Jan Svoboda Date: Tue, 11 Oct 2022 15:38:48 -0700 Subject: [PATCH] [clang][deps] Prevent emitting diagnostics outside of source file The dependency scanner needs to report the module map file describing the module whose implementation is being compiled (see D134222). However, calling `Preprocessor::getCurrentModuleImplementation()` in the scanner might cause a diagnostic during module map parsing and emitting a diagnostic without being "in" a source file is illegal (e.g. in `TextDiagnosticPrinter`). This patch ensures the module map parse is triggered while the compiler is still "in" a source file, avoiding the failure case. Reviewed By: Bigcheese Differential Revision: https://reviews.llvm.org/D135637 --- clang/lib/Frontend/FrontendAction.cpp | 3 ++ .../modules-implementation-module-map.c | 38 ++++++++++++++++++++++ 2 files changed, 41 insertions(+) create mode 100644 clang/test/ClangScanDeps/modules-implementation-module-map.c diff --git a/clang/lib/Frontend/FrontendAction.cpp b/clang/lib/Frontend/FrontendAction.cpp index b541c59..45f04ea 100644 --- a/clang/lib/Frontend/FrontendAction.cpp +++ b/clang/lib/Frontend/FrontendAction.cpp @@ -914,6 +914,9 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI, CI.getDiagnostics().Report(diag::err_module_map_not_found) << Filename; } + // If compiling implementation of a module, load its module map file now. + (void)CI.getPreprocessor().getCurrentModuleImplementation(); + // Add a module declaration scope so that modules from -fmodule-map-file // arguments may shadow modules found implicitly in search paths. CI.getPreprocessor() diff --git a/clang/test/ClangScanDeps/modules-implementation-module-map.c b/clang/test/ClangScanDeps/modules-implementation-module-map.c new file mode 100644 index 0000000..d76d315 --- /dev/null +++ b/clang/test/ClangScanDeps/modules-implementation-module-map.c @@ -0,0 +1,38 @@ +// RUN: rm -rf %t +// RUN: split-file %s %t + +//--- cdb.json.template +[{ + "file": "DIR/tu.m", + "directory": "DIR", + "command": "clang -fmodules -fimplicit-module-maps -fmodules-cache-path=DIR/cache -fmodule-name=FWPrivate -c DIR/tu.m -o DIR/tu.o -F DIR/frameworks -Wprivate-module" +}] + +//--- frameworks/FW.framework/Modules/module.modulemap +framework module FW {} +//--- frameworks/FW.framework/Modules/module.private.modulemap +// The module name will trigger a diagnostic. +framework module FWPrivate { header "private.h" } +//--- frameworks/FW.framework/PrivateHeaders/private.h +//--- tu.m + +// 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: cat %t/result.json | sed 's:\\\\\?:/:g' | FileCheck %s -DPREFIX=%/t +// CHECK: "translation-units": [ +// CHECK-NEXT: { +// CHECK-NEXT: "commands": [ +// CHECK: { +// CHECK: "command-line": [ +// CHECK: "-fmodule-map-file=[[PREFIX]]/frameworks/FW.framework/Modules/module.private.modulemap", +// CHECK: "-fmodule-name=FWPrivate", +// CHECK: ], +// CHECK-NEXT: "executable": "clang", +// CHECK-NEXT: "file-deps": [ +// CHECK-NEXT: "[[PREFIX]]/tu.m" +// CHECK-NEXT: ], +// CHECK-NEXT: "input-file": "[[PREFIX]]/tu.m" +// CHECK-NEXT: } +// CHECK: ] +// CHECK: } +// CHECK: ] -- 2.7.4