summaryrefslogtreecommitdiffstats
path: root/Source/cmGlobalNinjaGenerator.h
diff options
context:
space:
mode:
authorBen Boeckel <ben.boeckel@kitware.com>2023-11-18 03:53:45 (GMT)
committerBrad King <brad.king@kitware.com>2023-11-23 19:25:09 (GMT)
commitd2fa56772f290c61925a70161c77be5f4334fd77 (patch)
treef049f8a15a723b6a7bb70a8efecfb7e1ab254cb3 /Source/cmGlobalNinjaGenerator.h
parent06df59b9308d74b3f8a5eada84cf2402dd22b434 (diff)
downloadCMake-d2fa56772f290c61925a70161c77be5f4334fd77.zip
CMake-d2fa56772f290c61925a70161c77be5f4334fd77.tar.gz
CMake-d2fa56772f290c61925a70161c77be5f4334fd77.tar.bz2
Ninja: support "forwarding" modules from other targets
When a target uses objects from another target which provides modules as sources, the modules provided by the referenced target must also be treated as if they were provided by the referencing target. Add the concept of "forwarding" modules so that consumers can use modules created by these sources as well. Note that this is only sensible for Fortran where module usages are implicit as far as CMake's visibility model is concerned. C++ modules have their own concept of visibility which does not require or support such `$<TARGET_OBJECTS>` reuse in this way.
Diffstat (limited to 'Source/cmGlobalNinjaGenerator.h')
-rw-r--r--Source/cmGlobalNinjaGenerator.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/Source/cmGlobalNinjaGenerator.h b/Source/cmGlobalNinjaGenerator.h
index c5d6901..220d393 100644
--- a/Source/cmGlobalNinjaGenerator.h
+++ b/Source/cmGlobalNinjaGenerator.h
@@ -430,6 +430,7 @@ public:
std::string const& arg_dd, std::vector<std::string> const& arg_ddis,
std::string const& module_dir,
std::vector<std::string> const& linked_target_dirs,
+ std::vector<std::string> const& forward_modules_from_target_dirs,
std::string const& arg_lang, std::string const& arg_modmapfmt,
cmCxxModuleExportInfo const& export_info);