summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmCxxModuleMapper.cxx13
-rw-r--r--Tests/RunCMake/CXXModules/RunCMakeTest.cmake2
-rw-r--r--Tests/RunCMake/CXXModules/examples/circular-build-stdout.txt2
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order-randomized/CMakeLists.txt9
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/CMakeLists.txt132
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/main.cxx6
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod1.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod2.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod3.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod4.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod5.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod6.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod7.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl-non-partition.cxx10
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl1.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl2.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl3.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl4.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl5.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl6.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl7.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf1.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf2.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf3.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf4.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf5.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf6.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf7.cxx8
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/partition_level.cxx15
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target1.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target2.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target3.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target4.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target5.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target6.cxx7
-rw-r--r--Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target7.cxx7
36 files changed, 392 insertions, 6 deletions
diff --git a/Source/cmCxxModuleMapper.cxx b/Source/cmCxxModuleMapper.cxx
index e6c10c6..f45c011 100644
--- a/Source/cmCxxModuleMapper.cxx
+++ b/Source/cmCxxModuleMapper.cxx
@@ -346,13 +346,16 @@ std::set<std::string> CxxModuleUsageSeed(
// Add the direct usage.
this_usages.insert(r.LogicalName);
- // Add the transitive usage.
- if (transitive_usages != usages.Usage.end()) {
+ if (transitive_usages == usages.Usage.end() ||
+ internal_usages.find(r.LogicalName) != internal_usages.end()) {
+ // Mark that we need to update transitive usages later.
+ if (bmi_loc.IsKnown()) {
+ internal_usages[p.LogicalName].insert(r.LogicalName);
+ }
+ } else {
+ // Add the transitive usage.
this_usages.insert(transitive_usages->second.begin(),
transitive_usages->second.end());
- } else if (bmi_loc.IsKnown()) {
- // Mark that we need to update transitive usages later.
- internal_usages[p.LogicalName].insert(r.LogicalName);
}
}
diff --git a/Tests/RunCMake/CXXModules/RunCMakeTest.cmake b/Tests/RunCMake/CXXModules/RunCMakeTest.cmake
index 0c0f1b4..fcfa60a 100644
--- a/Tests/RunCMake/CXXModules/RunCMakeTest.cmake
+++ b/Tests/RunCMake/CXXModules/RunCMakeTest.cmake
@@ -174,6 +174,8 @@ if ("named" IN_LIST CMake_TEST_MODULE_COMPILATION)
run_cxx_module_test(object-library)
run_cxx_module_test(generated)
run_cxx_module_test(deep-chain)
+ run_cxx_module_test(non-trivial-collation-order)
+ run_cxx_module_test(non-trivial-collation-order-randomized)
run_cxx_module_test(duplicate)
set(RunCMake_CXXModules_NO_TEST 1)
run_cxx_module_test(circular)
diff --git a/Tests/RunCMake/CXXModules/examples/circular-build-stdout.txt b/Tests/RunCMake/CXXModules/examples/circular-build-stdout.txt
index ac80356..f6f5e5f 100644
--- a/Tests/RunCMake/CXXModules/examples/circular-build-stdout.txt
+++ b/Tests/RunCMake/CXXModules/examples/circular-build-stdout.txt
@@ -1 +1 @@
-((Ninja generators)?(build stopped: dependency cycle:)|(Visual Studio generators)?(error : Cannot build the following source files because there is a cyclic dependency between them))
+((Ninja generators)?(CMake Error: Circular dependency detected in the C\+\+ module import graph. See modules named: "a", "b")|(Visual Studio generators)?(error : Cannot build the following source files because there is a cyclic dependency between them))
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order-randomized/CMakeLists.txt b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order-randomized/CMakeLists.txt
new file mode 100644
index 0000000..4e1e7af
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order-randomized/CMakeLists.txt
@@ -0,0 +1,9 @@
+cmake_minimum_required(VERSION 3.24...3.28)
+project(cxx_modules_non_trivial_collation_order_randomized CXX)
+
+include("${CMAKE_SOURCE_DIR}/../cxx-modules-rules.cmake")
+
+set(non_trivial_collation_order_randomized TRUE)
+
+add_subdirectory("${CMAKE_CURRENT_SOURCE_DIR}/../non-trivial-collation-order/"
+ "${CMAKE_CURRENT_BINARY_DIR}/non-trivial-collation-order")
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/CMakeLists.txt b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/CMakeLists.txt
new file mode 100644
index 0000000..218b45f
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/CMakeLists.txt
@@ -0,0 +1,132 @@
+cmake_minimum_required(VERSION 3.24...3.28)
+project(cxx_modules_non_trivial_collation_order CXX)
+
+include("${CMAKE_SOURCE_DIR}/../cxx-modules-rules.cmake")
+
+if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
+ include(CheckCompilerFlag)
+ check_compiler_flag(CXX "-Wread-modules-implicitly" have_implicit_module_warning)
+ if (have_implicit_module_warning)
+ add_compile_options(-Werror=read-modules-implicitly)
+ endif ()
+endif ()
+
+# Returns an random integer from range [0,length)
+function(get_random_index result length)
+ # math(EXPR) parses and evaluates as 64-bit signed integer.
+ string(RANDOM LENGTH 18 ALPHABET "0123456789" value)
+ # Modulo is not uniformly distributed, but we doesn't need that here.
+ math(EXPR ${result} "${value} % ${length}")
+ return(PROPAGATE ${result})
+endfunction()
+
+# Shuffle list_var randomly
+function(shuffle_list list_var)
+ set(result)
+ set(length 0)
+ foreach(item IN LISTS "${list_var}")
+ math(EXPR length "${length} + 1")
+ get_random_index(index ${length})
+ list(INSERT result ${index} "${item}")
+ endforeach()
+ set("${list_var}" "${result}" PARENT_SCOPE)
+endfunction()
+
+# The import chain is:
+# impl-non-partition --(implicitly)--> partition_level(primary interface unit)
+# --> :intf7 --> :intf6 --> :intf5 --> :intf4 --> :intf3 --> :intf2 --> :intf1
+# --> :impl7 --> :impl6 --> :impl5 --> :impl4 --> :impl3 --> :impl2 --> :impl1
+set(partition_level_srcs
+ partition_level/partition_level.cxx
+ partition_level/intf1.cxx
+ partition_level/intf3.cxx
+ partition_level/intf4.cxx
+ partition_level/intf2.cxx # intentional order
+ partition_level/intf5.cxx
+ partition_level/intf6.cxx
+ partition_level/intf7.cxx
+ partition_level/impl1.cxx
+ partition_level/impl3.cxx
+ partition_level/impl4.cxx
+ partition_level/impl2.cxx # intentional order
+ partition_level/impl5.cxx
+ partition_level/impl6.cxx
+ partition_level/impl7.cxx
+)
+
+# The import chain is:
+# mod7 --> mod6 --> mod5 --> mod4 --> mod3 --> mod2 --> mod1 --> partition_level
+set(module_level_srcs
+ ${partition_level_srcs}
+ module_level/mod1.cxx
+ module_level/mod3.cxx
+ module_level/mod4.cxx
+ module_level/mod2.cxx # intentional order
+ module_level/mod5.cxx
+ module_level/mod6.cxx
+ module_level/mod7.cxx
+)
+
+# The import chain is:
+# target7 --> target6 --> target5 --> target4 -->
+# target3 --> target2 --> target1 --> target_module_level
+set(targets
+ target_module_level
+ target1
+ target3
+ target4
+ target2 # intentional order
+ target5
+ target6
+ target7
+)
+
+if(non_trivial_collation_order_randomized)
+ shuffle_list(module_level_srcs)
+ shuffle_list(targets)
+endif()
+
+message(STATUS "module_level_srcs: ${module_level_srcs}")
+message(STATUS "targets: ${targets}")
+
+foreach(tgt IN LISTS targets)
+ if (tgt STREQUAL "target_module_level")
+
+ add_library(target_module_level STATIC)
+ target_sources(target_module_level
+ PUBLIC
+ FILE_SET CXX_MODULES
+ BASE_DIRS "${CMAKE_CURRENT_SOURCE_DIR}"
+ FILES ${module_level_srcs}
+ PRIVATE
+ partition_level/impl-non-partition.cxx
+ )
+ target_compile_features(target_module_level PUBLIC cxx_std_20)
+
+ else()
+
+ add_library(${tgt} STATIC)
+ target_sources(${tgt}
+ PUBLIC
+ FILE_SET CXX_MODULES
+ BASE_DIRS "${CMAKE_CURRENT_SOURCE_DIR}"
+ FILES target_level/${tgt}.cxx
+ )
+ target_compile_features(${tgt} PUBLIC cxx_std_20)
+ if (tgt MATCHES "^target([2-9])$")
+ math(EXPR dep_number "${CMAKE_MATCH_1} - 1")
+ target_link_libraries(${tgt} PRIVATE "target${dep_number}")
+ else()
+ target_link_libraries(${tgt} PRIVATE target_module_level)
+ endif()
+
+ endif()
+endforeach()
+
+add_executable(exe)
+target_link_libraries(exe PRIVATE target7)
+target_sources(exe
+ PRIVATE
+ main.cxx)
+
+add_test(NAME exe COMMAND exe)
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/main.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/main.cxx
new file mode 100644
index 0000000..6496776
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/main.cxx
@@ -0,0 +1,6 @@
+import target7;
+
+int main()
+{
+ return target7();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod1.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod1.cxx
new file mode 100644
index 0000000..1999688
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod1.cxx
@@ -0,0 +1,7 @@
+export module mod1;
+import partition_level;
+
+export int mod1()
+{
+ return partition_level::get();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod2.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod2.cxx
new file mode 100644
index 0000000..454899f
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod2.cxx
@@ -0,0 +1,7 @@
+export module mod2;
+import mod1;
+
+export int mod2()
+{
+ return mod1();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod3.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod3.cxx
new file mode 100644
index 0000000..85dea1e
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod3.cxx
@@ -0,0 +1,7 @@
+export module mod3;
+import mod2;
+
+export int mod3()
+{
+ return mod2();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod4.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod4.cxx
new file mode 100644
index 0000000..e6143d7
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod4.cxx
@@ -0,0 +1,7 @@
+export module mod4;
+import mod3;
+
+export int mod4()
+{
+ return mod3();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod5.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod5.cxx
new file mode 100644
index 0000000..94355a9
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod5.cxx
@@ -0,0 +1,7 @@
+export module mod5;
+import mod4;
+
+export int mod5()
+{
+ return mod4();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod6.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod6.cxx
new file mode 100644
index 0000000..998ed8b
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod6.cxx
@@ -0,0 +1,7 @@
+export module mod6;
+import mod5;
+
+export int mod6()
+{
+ return mod5();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod7.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod7.cxx
new file mode 100644
index 0000000..15c52b0
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/module_level/mod7.cxx
@@ -0,0 +1,7 @@
+export module mod7;
+import mod6;
+
+export int mod7()
+{
+ return mod6();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl-non-partition.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl-non-partition.cxx
new file mode 100644
index 0000000..0cf184f
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl-non-partition.cxx
@@ -0,0 +1,10 @@
+module partition_level;
+
+namespace partition_level {
+int non_partition()
+{
+ return primary() + intf1() + intf2() + intf3() + intf4() + intf5() +
+ intf6() + intf7() + impl1() + impl2() + impl3() + impl4() + impl5() +
+ impl6() + impl7();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl1.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl1.cxx
new file mode 100644
index 0000000..86c27c6
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl1.cxx
@@ -0,0 +1,7 @@
+module partition_level:impl1;
+namespace partition_level {
+int impl1()
+{
+ return 0;
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl2.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl2.cxx
new file mode 100644
index 0000000..49d10e3
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl2.cxx
@@ -0,0 +1,8 @@
+module partition_level:impl2;
+import :impl1;
+namespace partition_level {
+int impl2()
+{
+ return impl1();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl3.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl3.cxx
new file mode 100644
index 0000000..cbd183b
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl3.cxx
@@ -0,0 +1,8 @@
+module partition_level:impl3;
+import :impl2;
+namespace partition_level {
+int impl3()
+{
+ return impl2();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl4.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl4.cxx
new file mode 100644
index 0000000..7ce9390
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl4.cxx
@@ -0,0 +1,8 @@
+module partition_level:impl4;
+import :impl3;
+namespace partition_level {
+int impl4()
+{
+ return impl3();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl5.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl5.cxx
new file mode 100644
index 0000000..901eda9
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl5.cxx
@@ -0,0 +1,8 @@
+module partition_level:impl5;
+import :impl4;
+namespace partition_level {
+int impl5()
+{
+ return impl4();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl6.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl6.cxx
new file mode 100644
index 0000000..38130c7
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl6.cxx
@@ -0,0 +1,8 @@
+module partition_level:impl6;
+import :impl5;
+namespace partition_level {
+int impl6()
+{
+ return impl5();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl7.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl7.cxx
new file mode 100644
index 0000000..c3b1322
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/impl7.cxx
@@ -0,0 +1,8 @@
+module partition_level:impl7;
+import :impl6;
+namespace partition_level {
+int impl7()
+{
+ return impl6();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf1.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf1.cxx
new file mode 100644
index 0000000..5d8500d
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf1.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf1;
+import :impl7;
+namespace partition_level {
+int intf1()
+{
+ return impl7();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf2.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf2.cxx
new file mode 100644
index 0000000..76c6eed
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf2.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf2;
+export import :intf1;
+namespace partition_level {
+int intf2()
+{
+ return intf1();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf3.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf3.cxx
new file mode 100644
index 0000000..3b16053
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf3.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf3;
+export import :intf2;
+namespace partition_level {
+int intf3()
+{
+ return intf2();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf4.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf4.cxx
new file mode 100644
index 0000000..2826717
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf4.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf4;
+export import :intf3;
+namespace partition_level {
+int intf4()
+{
+ return intf3();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf5.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf5.cxx
new file mode 100644
index 0000000..ede117e
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf5.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf5;
+export import :intf4;
+namespace partition_level {
+int intf5()
+{
+ return intf4();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf6.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf6.cxx
new file mode 100644
index 0000000..c89a554
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf6.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf6;
+export import :intf5;
+namespace partition_level {
+int intf6()
+{
+ return intf5();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf7.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf7.cxx
new file mode 100644
index 0000000..ee0b250
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/intf7.cxx
@@ -0,0 +1,8 @@
+export module partition_level:intf7;
+export import :intf6;
+namespace partition_level {
+int intf7()
+{
+ return intf6();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/partition_level.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/partition_level.cxx
new file mode 100644
index 0000000..7f3ddb2
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/partition_level/partition_level.cxx
@@ -0,0 +1,15 @@
+export module partition_level;
+export import :intf7;
+namespace partition_level {
+int primary()
+{
+ return intf7();
+}
+
+int non_partition();
+
+export int get()
+{
+ return non_partition();
+}
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target1.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target1.cxx
new file mode 100644
index 0000000..5487e21
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target1.cxx
@@ -0,0 +1,7 @@
+export module target1;
+import mod7;
+
+export int target1()
+{
+ return mod7();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target2.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target2.cxx
new file mode 100644
index 0000000..52c87dc
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target2.cxx
@@ -0,0 +1,7 @@
+export module target2;
+import target1;
+
+export int target2()
+{
+ return target1();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target3.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target3.cxx
new file mode 100644
index 0000000..4a1a3c0
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target3.cxx
@@ -0,0 +1,7 @@
+export module target3;
+import target2;
+
+export int target3()
+{
+ return target2();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target4.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target4.cxx
new file mode 100644
index 0000000..da1bf9d
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target4.cxx
@@ -0,0 +1,7 @@
+export module target4;
+import target3;
+
+export int target4()
+{
+ return target3();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target5.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target5.cxx
new file mode 100644
index 0000000..f18df7a
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target5.cxx
@@ -0,0 +1,7 @@
+export module target5;
+import target4;
+
+export int target5()
+{
+ return target4();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target6.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target6.cxx
new file mode 100644
index 0000000..a598df8
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target6.cxx
@@ -0,0 +1,7 @@
+export module target6;
+import target5;
+
+export int target6()
+{
+ return target5();
+}
diff --git a/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target7.cxx b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target7.cxx
new file mode 100644
index 0000000..641cfbc
--- /dev/null
+++ b/Tests/RunCMake/CXXModules/examples/non-trivial-collation-order/target_level/target7.cxx
@@ -0,0 +1,7 @@
+export module target7;
+import target6;
+
+export int target7()
+{
+ return target6();
+}