diff options
| author | Stefan Boberg <[email protected]> | 2025-11-07 14:49:13 +0100 |
|---|---|---|
| committer | GitHub Enterprise <[email protected]> | 2025-11-07 14:49:13 +0100 |
| commit | 24e43a913f29ac3b314354e8ce5175f135bcc64f (patch) | |
| tree | ca442937ceeb63461012b33a4576e9835099f106 /thirdparty/ryml/test/test_nested_mapx3.cpp | |
| parent | get oplog attachments (#622) (diff) | |
| download | zen-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.cpp | 103 |
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 |