diff options
Diffstat (limited to 'serialize')
-rw-r--r-- | serialize/tile.cpp | 15 | ||||
-rw-r--r-- | serialize/tile.hpp | 2 | ||||
-rw-r--r-- | serialize/world.cpp | 29 | ||||
-rw-r--r-- | serialize/world.hpp | 25 |
4 files changed, 56 insertions, 15 deletions
diff --git a/serialize/tile.cpp b/serialize/tile.cpp index 2eb3a81a..2e94bfb8 100644 --- a/serialize/tile.cpp +++ b/serialize/tile.cpp @@ -2,7 +2,6 @@ #include "src/chunk.hpp" #include "serialize/tile.hpp" #include "serialize/tile-atlas.hpp" -#include "global-coords.hpp" #include <nlohmann/json.hpp> namespace floormat { @@ -10,14 +9,6 @@ namespace floormat { NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(tile_image, atlas, variant) NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(tile, ground_image, wall_north, wall_west, passability) NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(local_coords, x, y) -NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(chunk_coords, x, y) - -struct global_coords_ final { - chunk_coords chunk; - local_coords local; -}; - -NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(global_coords_, chunk, local) } // namespace floormat @@ -37,10 +28,4 @@ void adl_serializer<chunk>::from_json(const json& j, chunk& val) { using nlohman void adl_serializer<local_coords>::to_json(json& j, const local_coords& val) { using nlohmann::to_json; to_json(j, val); } void adl_serializer<local_coords>::from_json(const json& j, local_coords& val) { using nlohmann::from_json; from_json(j, val); } -void adl_serializer<chunk_coords>::to_json(json& j, const chunk_coords& val) { using nlohmann::to_json; to_json(j, val); } -void adl_serializer<chunk_coords>::from_json(const json& j, chunk_coords& val) { using nlohmann::from_json; from_json(j, val); } - -void adl_serializer<global_coords>::to_json(json& j, const global_coords& val) { using nlohmann::to_json; to_json(j, global_coords_{val.chunk(), val.local()}); } -void adl_serializer<global_coords>::from_json(const json& j, global_coords& val) { using nlohmann::from_json; global_coords_ x; from_json(j, x); val = {x.chunk, x.local}; } - } // namespace nlohmann diff --git a/serialize/tile.hpp b/serialize/tile.hpp index 318c86bb..09c23f9a 100644 --- a/serialize/tile.hpp +++ b/serialize/tile.hpp @@ -2,10 +2,12 @@ #include <nlohmann/json_fwd.hpp> namespace floormat { + struct tile_image; struct tile; struct chunk; struct local_coords; + } // namespace floormat namespace nlohmann { diff --git a/serialize/world.cpp b/serialize/world.cpp new file mode 100644 index 00000000..b52fe3b9 --- /dev/null +++ b/serialize/world.cpp @@ -0,0 +1,29 @@ +#include "world.hpp" +#include "tile.hpp" +#include "global-coords.hpp" +#include <nlohmann/json.hpp> + +namespace floormat { + +NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(chunk_coords, x, y) + +struct global_coords_ final { + chunk_coords chunk; + local_coords local; +}; + +NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(global_coords_, chunk, local) + +} // namespace floormat + +namespace nlohmann { + +using namespace floormat; + +void adl_serializer<chunk_coords>::to_json(json& j, const chunk_coords& val) { using nlohmann::to_json; to_json(j, val); } +void adl_serializer<chunk_coords>::from_json(const json& j, chunk_coords& val) { using nlohmann::from_json; from_json(j, val); } + +void adl_serializer<global_coords>::to_json(json& j, const global_coords& val) { using nlohmann::to_json; to_json(j, global_coords_{val.chunk(), val.local()}); } +void adl_serializer<global_coords>::from_json(const json& j, global_coords& val) { using nlohmann::from_json; global_coords_ x; from_json(j, x); val = {x.chunk, x.local}; } + +} // namespace nlohmann diff --git a/serialize/world.hpp b/serialize/world.hpp new file mode 100644 index 00000000..05c88b40 --- /dev/null +++ b/serialize/world.hpp @@ -0,0 +1,25 @@ +#pragma once +#include <nlohmann/json_fwd.hpp> + +namespace floormat { + +struct chunk_coords; +struct global_coords; + +} // namespace floormat + +namespace nlohmann { + +template<> +struct adl_serializer<floormat::chunk_coords> { + static void to_json(json& j, const floormat::chunk_coords& val); + static void from_json(const json& j, floormat::chunk_coords& val); +}; + +template<> +struct adl_serializer<floormat::global_coords> { + static void to_json(json& j, const floormat::global_coords& val); + static void from_json(const json& j, floormat::global_coords& val); +}; + +} // namespace nlohmann |