aboutsummaryrefslogtreecommitdiff
path: root/thirdparty/ryml/test/test_nested_mapx3.cpp
diff options
context:
space:
mode:
authorStefan Boberg <[email protected]>2025-11-07 14:49:13 +0100
committerGitHub Enterprise <[email protected]>2025-11-07 14:49:13 +0100
commit24e43a913f29ac3b314354e8ce5175f135bcc64f (patch)
treeca442937ceeb63461012b33a4576e9835099f106 /thirdparty/ryml/test/test_nested_mapx3.cpp
parentget oplog attachments (#622) (diff)
downloadzen-24e43a913f29ac3b314354e8ce5175f135bcc64f.tar.xz
zen-24e43a913f29ac3b314354e8ce5175f135bcc64f.zip
switch to xmake for package management (#611)
This change removes our dependency on vcpkg for package management, in favour of bringing some code in-tree in the `thirdparty` folder as well as using the xmake build-in package management feature. For the latter, all the package definitions are maintained in the zen repo itself, in the `repo` folder. It should now also be easier to build the project as it will no longer depend on having the right version of vcpkg installed, which has been a common problem for new people coming in to the codebase. Now you should only need xmake to build. * Bumps xmake requirement on github runners to 2.9.9 to resolve an issue where xmake on Windows invokes cmake with `v144` toolchain which does not exist * BLAKE3 is now in-tree at `thirdparty/blake3` * cpr is now in-tree at `thirdparty/cpr` * cxxopts is now in-tree at `thirdparty/cxxopts` * fmt is now in-tree at `thirdparty/fmt` * robin-map is now in-tree at `thirdparty/robin-map` * ryml is now in-tree at `thirdparty/ryml` * sol2 is now in-tree at `thirdparty/sol2` * spdlog is now in-tree at `thirdparty/spdlog` * utfcpp is now in-tree at `thirdparty/utfcpp` * xmake package repo definitions is in `repo` * implemented support for sanitizers. ASAN is supported on windows, TSAN, UBSAN, MSAN etc are supported on Linux/MacOS though I have not yet tested it extensively on MacOS * the zencore encryption implementation also now supports using mbedTLS which is used on MacOS, though for now we still use openssl on Linux * crashpad * bumps libcurl to 8.11.0 (from 8.8.0) which should address a rare build upload bug
Diffstat (limited to 'thirdparty/ryml/test/test_nested_mapx3.cpp')
-rw-r--r--thirdparty/ryml/test/test_nested_mapx3.cpp103
1 files changed, 103 insertions, 0 deletions
diff --git a/thirdparty/ryml/test/test_nested_mapx3.cpp b/thirdparty/ryml/test/test_nested_mapx3.cpp
new file mode 100644
index 000000000..2ae163475
--- /dev/null
+++ b/thirdparty/ryml/test/test_nested_mapx3.cpp
@@ -0,0 +1,103 @@
+#include "./test_group.hpp"
+
+namespace c4 {
+namespace yml {
+
+CASE_GROUP(NESTED_MAPX3)
+{
+
+ADD_CASE_TO_GROUP("nested map x3, explicit",
+R"({
+ foo0: {
+ foo1: {foo2: 000, bar2: 001, baz2: 002},
+ bar1: {foo2: 010, bar2: 011, baz2: 012},
+ baz1: {foo2: 020, bar2: 021, baz2: 022}
+ },
+ bar0: {
+ foo1: {foo2: 100, bar2: 101, baz2: 102},
+ bar1: {foo2: 110, bar2: 111, baz2: 112},
+ baz1: {foo2: 120, bar2: 121, baz2: 122}
+ },
+ baz0: {
+ foo1: {foo2: 200, bar2: 201, baz2: 202},
+ bar1: {foo2: 210, bar2: 211, baz2: 212},
+ baz1: {foo2: 220, bar2: 221, baz2: 222}
+ }
+})",
+ L{
+ N{"foo0", L{
+ N{"foo1", L{N{"foo2", "000"}, N{"bar2", "001"}, N{"baz2", "002"}}},
+ N{"bar1", L{N{"foo2", "010"}, N{"bar2", "011"}, N{"baz2", "012"}}},
+ N{"baz1", L{N{"foo2", "020"}, N{"bar2", "021"}, N{"baz2", "022"}}} }},
+ N{"bar0", L{
+ N{"foo1", L{N{"foo2", "100"}, N{"bar2", "101"}, N{"baz2", "102"}}},
+ N{"bar1", L{N{"foo2", "110"}, N{"bar2", "111"}, N{"baz2", "112"}}},
+ N{"baz1", L{N{"foo2", "120"}, N{"bar2", "121"}, N{"baz2", "122"}}} }},
+ N{"baz0", L{
+ N{"foo1", L{N{"foo2", "200"}, N{"bar2", "201"}, N{"baz2", "202"}}},
+ N{"bar1", L{N{"foo2", "210"}, N{"bar2", "211"}, N{"baz2", "212"}}},
+ N{"baz1", L{N{"foo2", "220"}, N{"bar2", "221"}, N{"baz2", "222"}}} }},
+ }
+);
+
+ADD_CASE_TO_GROUP("nested map x3",
+R"(
+foo0:
+ foo1:
+ foo2: 000
+ bar2: 001
+ baz2: 002
+ bar1:
+ foo2: 010
+ bar2: 011
+ baz2: 012
+ baz1:
+ foo2: 020
+ bar2: 021
+ baz2: 022
+bar0:
+ foo1:
+ foo2: 100
+ bar2: 101
+ baz2: 102
+ bar1:
+ foo2: 110
+ bar2: 111
+ baz2: 112
+ baz1:
+ foo2: 120
+ bar2: 121
+ baz2: 122
+baz0:
+ foo1:
+ foo2: 200
+ bar2: 201
+ baz2: 202
+ bar1:
+ foo2: 210
+ bar2: 211
+ baz2: 212
+ baz1:
+ foo2: 220
+ bar2: 221
+ baz2: 222
+)",
+ L{
+ N{"foo0", L{
+ N{"foo1", L{N{"foo2", "000"}, N{"bar2", "001"}, N{"baz2", "002"}}},
+ N{"bar1", L{N{"foo2", "010"}, N{"bar2", "011"}, N{"baz2", "012"}}},
+ N{"baz1", L{N{"foo2", "020"}, N{"bar2", "021"}, N{"baz2", "022"}}} }},
+ N{"bar0", L{
+ N{"foo1", L{N{"foo2", "100"}, N{"bar2", "101"}, N{"baz2", "102"}}},
+ N{"bar1", L{N{"foo2", "110"}, N{"bar2", "111"}, N{"baz2", "112"}}},
+ N{"baz1", L{N{"foo2", "120"}, N{"bar2", "121"}, N{"baz2", "122"}}} }},
+ N{"baz0", L{
+ N{"foo1", L{N{"foo2", "200"}, N{"bar2", "201"}, N{"baz2", "202"}}},
+ N{"bar1", L{N{"foo2", "210"}, N{"bar2", "211"}, N{"baz2", "212"}}},
+ N{"baz1", L{N{"foo2", "220"}, N{"bar2", "221"}, N{"baz2", "222"}}} }},
+ }
+);
+}
+
+} // namespace yml
+} // namespace c4