From c93b3616adbf26673fc928fdfbbec814fec41c75 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Thu, 11 Jan 2024 18:15:00 +0100 Subject: w --- serialize/ground-atlas.cpp | 21 ++++++++++++++++----- serialize/ground-atlas.hpp | 14 ++++++++++---- 2 files changed, 26 insertions(+), 9 deletions(-) (limited to 'serialize') diff --git a/serialize/ground-atlas.cpp b/serialize/ground-atlas.cpp index 3522e85c..517b8186 100644 --- a/serialize/ground-atlas.cpp +++ b/serialize/ground-atlas.cpp @@ -2,7 +2,7 @@ #include "serialize/corrade-string.hpp" #include "serialize/magnum-vector.hpp" #include "serialize/pass-mode.hpp" -#include "loader/ground-info.hpp" +#include "loader/loader.hpp" #include #include @@ -14,15 +14,13 @@ using namespace floormat; namespace nlohmann { -#if 0 -void adl_serializer::to_json(json& j, const ground_info& x) +void adl_serializer::to_json(json& j, const ground_def& x) { using nlohmann::to_json; j = std::tuple{x.name, x.size, x.pass}; } -#endif -void adl_serializer::from_json(const json& j, ground_info& val) +void adl_serializer::from_json(const json& j, ground_def& val) { using nlohmann::from_json; val.name = j["name"]; @@ -31,4 +29,17 @@ void adl_serializer::from_json(const json& j, ground_info& val) val.pass = j["pass-mode"]; } +void adl_serializer>::to_json(json& j, const std::shared_ptr& x) +{ + j = std::tuple{x->name(), x->num_tiles2(), x->pass_mode()}; +} + +void adl_serializer>::from_json(const json& j, std::shared_ptr& val) +{ + char buf[FILENAME_MAX]; + ground_def info = j; + auto path = loader.make_atlas_path(buf, loader.GROUND_TILESET_PATH, info.name); + val = std::make_shared(std::move(info), path, loader.texture(""_s, path)); +} + } // namespace nlohmann diff --git a/serialize/ground-atlas.hpp b/serialize/ground-atlas.hpp index 7ca57ede..fc8acec5 100644 --- a/serialize/ground-atlas.hpp +++ b/serialize/ground-atlas.hpp @@ -1,5 +1,5 @@ #pragma once -#include "loader/ground-info.hpp" +#include "src/ground-atlas.hpp" #include namespace floormat { @@ -11,9 +11,15 @@ struct ground_info; namespace nlohmann { template<> -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); +struct adl_serializer final { + static void to_json(json& j, const floormat::ground_def& x); + static void from_json(const json& j, floormat::ground_def& x); +}; + +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); }; } // namespace nlohmann -- cgit v1.2.3