Merge topic 'cxxmodules-obj-lib'

c09f8d27cd cxxmodules: compute link information for C++ module-consuming targets

Acked-by: Kitware Robot <kwrobot@kitware.com>
Tested-by: buildbot <buildbot@kitware.com>
Reviewed-by: Ben Boeckel <ben.boeckel@kitware.com>
Merge-request: !9154
This commit is contained in:
Brad King
2024-01-17 14:35:23 +00:00
committed by Kitware Robot
5 changed files with 22 additions and 1 deletions

View File

@@ -553,7 +553,8 @@ bool cmComputeLinkInformation::Compute()
this->Target->GetType() == cmStateEnums::MODULE_LIBRARY ||
this->Target->GetType() == cmStateEnums::STATIC_LIBRARY ||
(this->Target->CanCompileSources() &&
(this->Target->HaveCxx20ModuleSources() ||
(this->Target->HaveCxxModuleSupport(this->Config) ==
cmGeneratorTarget::Cxx20SupportLevel::Supported ||
this->Target->HaveFortranSources())))) {
return false;
}

View File

@@ -180,6 +180,7 @@ if ("named" IN_LIST CMake_TEST_MODULE_COMPILATION)
run_cxx_module_test(non-trivial-collation-order-randomized)
run_cxx_module_test(duplicate)
set(RunCMake_CXXModules_NO_TEST 1)
run_cxx_module_test(import-from-object)
run_cxx_module_test(circular)
run_cxx_module_test(try-compile)
run_cxx_module_test(try-run)

View File

@@ -0,0 +1,16 @@
cmake_minimum_required(VERSION 3.24...3.28)
project(cxx_modules_import_from_object CXX)
include("${CMAKE_SOURCE_DIR}/../cxx-modules-rules.cmake")
set(CMAKE_CXX_STANDARD 20)
add_library(a STATIC)
target_sources(a
PUBLIC
FILE_SET CXX_MODULES
FILES
object-a.cxx)
add_library(b OBJECT object-b.cxx)
target_link_libraries(b PRIVATE a)

View File

@@ -0,0 +1,2 @@
module;
export module a;

View File

@@ -0,0 +1 @@
import a;