From ba90ba2ca91c448d80722985811fc6bddc6e9bf2 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Thu, 11 Jan 2024 16:40:29 +0100 Subject: w --- serialize/ground-atlas.cpp | 50 ++++++++++++++-------------------------------- serialize/ground-atlas.hpp | 15 +++++++++----- serialize/wall-atlas.cpp | 1 - 3 files changed, 25 insertions(+), 41 deletions(-) (limited to 'serialize') diff --git a/serialize/ground-atlas.cpp b/serialize/ground-atlas.cpp index 76c8686e..8703881d 100644 --- a/serialize/ground-atlas.cpp +++ b/serialize/ground-atlas.cpp @@ -1,58 +1,38 @@ +#include "ground-atlas.hpp" #include "src/ground-atlas.hpp" -#include "serialize/ground-atlas.hpp" #include "serialize/corrade-string.hpp" #include "serialize/magnum-vector.hpp" #include "loader/loader.hpp" #include "serialize/pass-mode.hpp" #include "compat/exception.hpp" +#include #include #include #include -using namespace floormat; - -namespace { +namespace floormat { -struct proxy { - StringView name; - Vector2ub size; - pass_mode passability; -}; +} // namespace floormat -NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(proxy, name, size) - -} // namespace +using namespace floormat; namespace nlohmann { -void adl_serializer>::to_json(json& j, const std::shared_ptr& x) +#if 0 +void adl_serializer::to_json(json& j, const ground_info& x) { using nlohmann::to_json; - if (!x) - j = nullptr; - else - to_json(j, proxy{x->name(), x->num_tiles2(), x->pass_mode()}); + j = std::tuple{x.name, x.size, x.pass}; } +#endif -void adl_serializer>::from_json(const json& j, std::shared_ptr& val) +void adl_serializer::from_json(const json& j, ground_info& val) { - if (j.is_null()) - val = nullptr; - else - { - using nlohmann::from_json; - proxy x; - from_json(j, x); - pass_mode p = ground_atlas::default_pass_mode; - if (j.contains("pass-mode")) - p = j["pass-mode"]; - val = loader.ground_atlas(x.name, x.size, p); - if (auto p2 = val->pass_mode(); p2 != p) - { - const auto name = val->name(); - fm_throw("atlas {} wrong pass mode {} should be {}"_cf, name, uint8_t(p2), uint8_t(p)); - } - } + using nlohmann::from_json; + val.name = j["name"]; + val.size = j["size"]; + if (j.contains("pass-mode")) + val.pass = j["pass-mode"]; } } // namespace nlohmann diff --git a/serialize/ground-atlas.hpp b/serialize/ground-atlas.hpp index 344e8714..7ca57ede 100644 --- a/serialize/ground-atlas.hpp +++ b/serialize/ground-atlas.hpp @@ -1,14 +1,19 @@ #pragma once -#include "src/ground-atlas.hpp" -#include +#include "loader/ground-info.hpp" #include +namespace floormat { + +struct ground_info; + +} // namespace floormat + namespace nlohmann { template<> -struct adl_serializer> final { - static void to_json(json& j, const std::shared_ptr& x); - static void from_json(const json& j, std::shared_ptr& x); +struct adl_serializer final { + static void to_json(json& j, const floormat::ground_info& x) = delete; + static void from_json(const json& j, floormat::ground_info& x); }; } // namespace nlohmann diff --git a/serialize/wall-atlas.cpp b/serialize/wall-atlas.cpp index dc0c42cc..85de29ec 100644 --- a/serialize/wall-atlas.cpp +++ b/serialize/wall-atlas.cpp @@ -9,7 +9,6 @@ #include #include #include -#include #include #include #include -- cgit v1.2.3