summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2023-11-29 12:51:31 (GMT)
committerKitware Robot <kwrobot@kitware.com>2023-11-29 12:51:41 (GMT)
commit1b82da7e151d83c38b7a48e4ab39c8ef0f853350 (patch)
treef1d6f604ae57317906fda6bebeb8bdb7cd3092ce
parent503aa3c3cc2799244a19bae49f1ad2f1d7a4baad (diff)
parentcbd549b09e7f8c0baa8142eda221e686b132f2a4 (diff)
downloadCMake-1b82da7e151d83c38b7a48e4ab39c8ef0f853350.zip
CMake-1b82da7e151d83c38b7a48e4ab39c8ef0f853350.tar.gz
CMake-1b82da7e151d83c38b7a48e4ab39c8ef0f853350.tar.bz2
Merge topic 'cxxmodules-diagnostics' into release-3.28
cbd549b09e cxxmodules: Add more suggestions to no-modules-support diagnostics Acked-by: Kitware Robot <kwrobot@kitware.com> Tested-by: buildbot <buildbot@kitware.com> Merge-request: !9011
-rw-r--r--Source/cmGeneratorTarget.cxx19
-rw-r--r--Tests/RunCMake/CXXModules/NoCXX-stderr.txt11
-rw-r--r--Tests/RunCMake/CXXModules/NoCXX20-stderr.txt11
-rw-r--r--Tests/RunCMake/CXXModules/NoDyndepSupport-stderr.txt11
-rw-r--r--Tests/RunCMake/CXXModules/NoScanningSourceFileProperty-stderr.txt15
-rw-r--r--Tests/RunCMake/CXXModules/NoScanningTargetProperty-stderr.txt15
6 files changed, 61 insertions, 21 deletions
diff --git a/Source/cmGeneratorTarget.cxx b/Source/cmGeneratorTarget.cxx
index 8d21e63..4b4d8b9 100644
--- a/Source/cmGeneratorTarget.cxx
+++ b/Source/cmGeneratorTarget.cxx
@@ -9227,11 +9227,15 @@ void cmGeneratorTarget::CheckCxxModuleStatus(std::string const& config) const
cmGlobalGenerator::CxxModuleSupportQuery::Expected)) {
this->Makefile->IssueMessage(
MessageType::FATAL_ERROR,
- cmStrCat(
- "The target named \"", this->GetName(),
- "\" has C++ sources that may use modules, but modules are not "
- "supported by this generator. See the cmake-cxxmodules(7) manual "
- "and the CMAKE_CXX_SCAN_FOR_MODULES variable."));
+ cmStrCat("The target named \"", this->GetName(),
+ "\" has C++ sources that may use modules, but modules are not "
+ "supported by this generator:\n ",
+ this->GetGlobalGenerator()->GetName(), '\n',
+ "Modules are supported only by Ninja, Ninja Multi-Config, "
+ "and Visual Studio generators for VS 17.4 and newer. "
+ "See the cmake-cxxmodules(7) manual for details. "
+ "Use the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or "
+ "disable scanning."));
return;
}
@@ -9266,8 +9270,9 @@ void cmGeneratorTarget::CheckCxxModuleStatus(std::string const& config) const
cmStrCat("The target named \"", this->GetName(),
"\" has C++ sources that may use modules, but the compiler "
"does not provide a way to discover the import graph "
- "dependencies. See the cmake-cxxmodules(7) manual "
- "and the CMAKE_CXX_SCAN_FOR_MODULES variable."));
+ "dependencies. See the cmake-cxxmodules(7) manual for "
+ "details. Use the CMAKE_CXX_SCAN_FOR_MODULES variable to "
+ "enable or disable scanning."));
} break;
case cmGeneratorTarget::Cxx20SupportLevel::Supported:
// All is well.
diff --git a/Tests/RunCMake/CXXModules/NoCXX-stderr.txt b/Tests/RunCMake/CXXModules/NoCXX-stderr.txt
index ba2715b..2ca67d6 100644
--- a/Tests/RunCMake/CXXModules/NoCXX-stderr.txt
+++ b/Tests/RunCMake/CXXModules/NoCXX-stderr.txt
@@ -3,8 +3,15 @@
language has not been enabled\.
|CMake Error in CMakeLists.txt:
The target named "nocxx" has C\+\+ sources that may use modules, but modules
- are not supported by this generator\. See the cmake-cxxmodules\(7\) manual
- and the CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ are not supported by this generator:
+
+ [^
+]+
+
+ Modules are supported only by Ninja, Ninja Multi-Config, and Visual Studio
+ generators for VS 17\.4 and newer\. See the cmake-cxxmodules\(7\) manual for
+ details\. Use the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable
+ scanning\.
|CMake Error in CMakeLists.txt:
Target "nocxx" has source file
diff --git a/Tests/RunCMake/CXXModules/NoCXX20-stderr.txt b/Tests/RunCMake/CXXModules/NoCXX20-stderr.txt
index 3f3a547..16adba5 100644
--- a/Tests/RunCMake/CXXModules/NoCXX20-stderr.txt
+++ b/Tests/RunCMake/CXXModules/NoCXX20-stderr.txt
@@ -4,6 +4,13 @@
"cxx_std_17"\.
|CMake Error in CMakeLists.txt:
The target named "nocxx20" has C\+\+ sources that may use modules, but
- modules are not supported by this generator\. See the cmake-cxxmodules\(7\)
- manual and the CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ modules are not supported by this generator:
+
+ [^
+]+
+
+ Modules are supported only by Ninja, Ninja Multi-Config, and Visual Studio
+ generators for VS 17\.4 and newer\. See the cmake-cxxmodules\(7\) manual for
+ details\. Use the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable
+ scanning\.
)
diff --git a/Tests/RunCMake/CXXModules/NoDyndepSupport-stderr.txt b/Tests/RunCMake/CXXModules/NoDyndepSupport-stderr.txt
index c7e2979..5452ddb 100644
--- a/Tests/RunCMake/CXXModules/NoDyndepSupport-stderr.txt
+++ b/Tests/RunCMake/CXXModules/NoDyndepSupport-stderr.txt
@@ -7,6 +7,13 @@
due to lack of required features\. Ninja 1\.11 or higher is required\.
|CMake Error in CMakeLists.txt:
The target named "nodyndep" has C\+\+ sources that may use modules, but
- modules are not supported by this generator\. See the cmake-cxxmodules\(7\)
- manual and the CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ modules are not supported by this generator:
+
+ [^
+]+
+
+ Modules are supported only by Ninja, Ninja Multi-Config, and Visual Studio
+ generators for VS 17\.4 and newer\. See the cmake-cxxmodules\(7\) manual for
+ details\. Use the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable
+ scanning\.
)
diff --git a/Tests/RunCMake/CXXModules/NoScanningSourceFileProperty-stderr.txt b/Tests/RunCMake/CXXModules/NoScanningSourceFileProperty-stderr.txt
index ed78672..ce548b9 100644
--- a/Tests/RunCMake/CXXModules/NoScanningSourceFileProperty-stderr.txt
+++ b/Tests/RunCMake/CXXModules/NoScanningSourceFileProperty-stderr.txt
@@ -1,10 +1,17 @@
(CMake Error in CMakeLists.txt:
The target named "noscanning-sf-property" has C\+\+ sources that may use
modules, but the compiler does not provide a way to discover the import
- graph dependencies\. See the cmake-cxxmodules\(7\) manual and the
- CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ graph dependencies\. See the cmake-cxxmodules\(7\) manual for details\. Use
+ the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable scanning\.
|CMake Error in CMakeLists.txt:
The target named "noscanning-sf-property" has C\+\+ sources that may use
- modules, but modules are not supported by this generator\. See the
- cmake-cxxmodules\(7\) manual and the CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ modules, but modules are not supported by this generator:
+
+ [^
+]+
+
+ Modules are supported only by Ninja, Ninja Multi-Config, and Visual Studio
+ generators for VS 17\.4 and newer\. See the cmake-cxxmodules\(7\) manual for
+ details\. Use the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable
+ scanning\.
)
diff --git a/Tests/RunCMake/CXXModules/NoScanningTargetProperty-stderr.txt b/Tests/RunCMake/CXXModules/NoScanningTargetProperty-stderr.txt
index 9dfb3e9..a72fd16 100644
--- a/Tests/RunCMake/CXXModules/NoScanningTargetProperty-stderr.txt
+++ b/Tests/RunCMake/CXXModules/NoScanningTargetProperty-stderr.txt
@@ -1,10 +1,17 @@
(CMake Error in CMakeLists.txt:
The target named "noscanning-target-property" has C\+\+ sources that may use
modules, but the compiler does not provide a way to discover the import
- graph dependencies\. See the cmake-cxxmodules\(7\) manual and the
- CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ graph dependencies\. See the cmake-cxxmodules\(7\) manual for details\. Use
+ the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable scanning\.
|CMake Error in CMakeLists.txt:
The target named "noscanning-target-property" has C\+\+ sources that may use
- modules, but modules are not supported by this generator\. See the
- cmake-cxxmodules\(7\) manual and the CMAKE_CXX_SCAN_FOR_MODULES variable\.
+ modules, but modules are not supported by this generator:
+
+ [^
+]+
+
+ Modules are supported only by Ninja, Ninja Multi-Config, and Visual Studio
+ generators for VS 17\.4 and newer\. See the cmake-cxxmodules\(7\) manual for
+ details\. Use the CMAKE_CXX_SCAN_FOR_MODULES variable to enable or disable
+ scanning\.
)