summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2023-05-19 12:33:05 (GMT)
committerKitware Robot <kwrobot@kitware.com>2023-05-19 12:33:20 (GMT)
commita60ce4e5f46a16c6f21cee003a7ce7762219b743 (patch)
treebda3bd11ffde3d52385bdc2c7e3115b97423041a
parent685eba4dd9e6c666bb0e331531096ea847ecdb97 (diff)
parent51c343b788eb20d4fc86da36a1a7694f20b1575d (diff)
downloadCMake-a60ce4e5f46a16c6f21cee003a7ce7762219b743.zip
CMake-a60ce4e5f46a16c6f21cee003a7ce7762219b743.tar.gz
CMake-a60ce4e5f46a16c6f21cee003a7ce7762219b743.tar.bz2
Merge topic 'vs-cxxmodules'
51c343b788 ci: Enable C++20 module testing with VS 2022 on ARM64 406a103318 VS: Add support for C++ module internal partitions in VS 17.6 and newer Acked-by: Kitware Robot <kwrobot@kitware.com> Merge-request: !8471
-rw-r--r--.gitlab/ci/configure_windows_arm64_vs2022.cmake3
-rw-r--r--.gitlab/ci/configure_windows_vs2022_x64.cmake2
-rw-r--r--Source/cmGlobalVisualStudio10Generator.h2
-rw-r--r--Source/cmGlobalVisualStudioVersionedGenerator.cxx16
-rw-r--r--Source/cmGlobalVisualStudioVersionedGenerator.h2
-rw-r--r--Source/cmVisualStudio10TargetGenerator.cxx9
6 files changed, 32 insertions, 2 deletions
diff --git a/.gitlab/ci/configure_windows_arm64_vs2022.cmake b/.gitlab/ci/configure_windows_arm64_vs2022.cmake
index c7d41ea..290d380 100644
--- a/.gitlab/ci/configure_windows_arm64_vs2022.cmake
+++ b/.gitlab/ci/configure_windows_arm64_vs2022.cmake
@@ -1 +1,4 @@
+set(CMake_TEST_MODULE_COMPILATION "named,partitions,internal_partitions" CACHE STRING "")
+
+include("${CMAKE_CURRENT_LIST_DIR}/configure_windows_msvc_cxx_modules_common.cmake")
include("${CMAKE_CURRENT_LIST_DIR}/configure_windows_vs_common.cmake")
diff --git a/.gitlab/ci/configure_windows_vs2022_x64.cmake b/.gitlab/ci/configure_windows_vs2022_x64.cmake
index 1e0f584..290d380 100644
--- a/.gitlab/ci/configure_windows_vs2022_x64.cmake
+++ b/.gitlab/ci/configure_windows_vs2022_x64.cmake
@@ -1,4 +1,4 @@
-set(CMake_TEST_MODULE_COMPILATION "named,partitions" CACHE STRING "")
+set(CMake_TEST_MODULE_COMPILATION "named,partitions,internal_partitions" CACHE STRING "")
include("${CMAKE_CURRENT_LIST_DIR}/configure_windows_msvc_cxx_modules_common.cmake")
include("${CMAKE_CURRENT_LIST_DIR}/configure_windows_vs_common.cmake")
diff --git a/Source/cmGlobalVisualStudio10Generator.h b/Source/cmGlobalVisualStudio10Generator.h
index 6917ffc..38942cb 100644
--- a/Source/cmGlobalVisualStudio10Generator.h
+++ b/Source/cmGlobalVisualStudio10Generator.h
@@ -149,6 +149,8 @@ public:
virtual bool IsUtf8EncodingSupported() const { return false; }
+ virtual bool IsScanDependenciesSupported() const { return false; }
+
static std::string GetInstalledNsightTegraVersion();
/** Return the first two components of CMAKE_SYSTEM_VERSION. */
diff --git a/Source/cmGlobalVisualStudioVersionedGenerator.cxx b/Source/cmGlobalVisualStudioVersionedGenerator.cxx
index f28419a..602b42f 100644
--- a/Source/cmGlobalVisualStudioVersionedGenerator.cxx
+++ b/Source/cmGlobalVisualStudioVersionedGenerator.cxx
@@ -739,6 +739,22 @@ bool cmGlobalVisualStudioVersionedGenerator::IsUtf8EncodingSupported() const
cmSystemTools::VersionCompareGreaterEq(*vsVer, vsVer16_10_P2));
}
+bool cmGlobalVisualStudioVersionedGenerator::IsScanDependenciesSupported()
+ const
+{
+ // Supported from Visual Studio 17.6 Preview 7.
+ if (this->Version > cmGlobalVisualStudioGenerator::VSVersion::VS17) {
+ return true;
+ }
+ if (this->Version < cmGlobalVisualStudioGenerator::VSVersion::VS17) {
+ return false;
+ }
+ static std::string const vsVer17_6_P7 = "17.6.33706.43";
+ cm::optional<std::string> vsVer = this->GetVSInstanceVersion();
+ return (vsVer &&
+ cmSystemTools::VersionCompareGreaterEq(*vsVer, vsVer17_6_P7));
+}
+
const char*
cmGlobalVisualStudioVersionedGenerator::GetAndroidApplicationTypeRevision()
const
diff --git a/Source/cmGlobalVisualStudioVersionedGenerator.h b/Source/cmGlobalVisualStudioVersionedGenerator.h
index fb4b1d7..558ea7c 100644
--- a/Source/cmGlobalVisualStudioVersionedGenerator.h
+++ b/Source/cmGlobalVisualStudioVersionedGenerator.h
@@ -44,6 +44,8 @@ public:
bool IsUtf8EncodingSupported() const override;
+ bool IsScanDependenciesSupported() const override;
+
const char* GetAndroidApplicationTypeRevision() const override;
bool CheckCxxModuleSupport() override
diff --git a/Source/cmVisualStudio10TargetGenerator.cxx b/Source/cmVisualStudio10TargetGenerator.cxx
index 7360bf5..6d62aff 100644
--- a/Source/cmVisualStudio10TargetGenerator.cxx
+++ b/Source/cmVisualStudio10TargetGenerator.cxx
@@ -2802,7 +2802,14 @@ void cmVisualStudio10TargetGenerator::OutputSourceSpecificFlags(
fs->GetType() == "CXX_MODULE_HEADER_UNITS"_s)) {
if (lang == "CXX"_s) {
if (fs->GetType() == "CXX_MODULES"_s) {
- compileAsPerConfig = "CompileAsCppModule";
+ if (shouldScanForModules &&
+ this->GlobalGenerator->IsScanDependenciesSupported()) {
+ // ScanSourceforModuleDependencies uses 'cl /scanDependencies' and
+ // can distinguish module interface units and internal partitions.
+ compileAsPerConfig = "CompileAsCpp";
+ } else {
+ compileAsPerConfig = "CompileAsCppModule";
+ }
} else {
compileAsPerConfig = "CompileAsHeaderUnit";
}