diff options
author | Clyne Sullivan <clyne@bitgloo.com> | 2019-09-02 18:53:21 -0400 |
---|---|---|
committer | Clyne Sullivan <clyne@bitgloo.com> | 2019-09-02 18:53:21 -0400 |
commit | aa7b0a92d065b4435467d482ec65dd97b03459ee (patch) | |
tree | 0b1c4406f4fbeea6fee2e73eaf735386c5cc1ab6 | |
parent | 6614ea639414caab546091841bf920fe6459cc9e (diff) |
made json names readable
-rw-r--r-- | lib/entityx/entityx/Entity.h | 8 | ||||
-rw-r--r-- | src/components/Light.hpp | 8 | ||||
-rw-r--r-- | src/components/Name.hpp | 8 | ||||
-rw-r--r-- | src/components/Player.hpp | 4 | ||||
-rw-r--r-- | src/components/Position.hpp | 8 | ||||
-rw-r--r-- | src/components/Render.hpp | 8 | ||||
-rw-r--r-- | src/components/Script.hpp | 4 | ||||
-rw-r--r-- | src/components/Velocity.hpp | 8 | ||||
-rw-r--r-- | src/engine.cpp | 1 |
9 files changed, 45 insertions, 12 deletions
diff --git a/lib/entityx/entityx/Entity.h b/lib/entityx/entityx/Entity.h index 193d581..27a8820 100644 --- a/lib/entityx/entityx/Entity.h +++ b/lib/entityx/entityx/Entity.h @@ -243,6 +243,7 @@ struct BaseComponent { void operator delete[]([[maybe_unused]] void *p) { fail(); } virtual void internal_serialize(bool save, void *ar) = 0; + virtual std::string serializeName(void) const = 0; protected: static void fail() { @@ -757,8 +758,11 @@ class EntityManager : entityx::help::NonCopyable { for (size_t i = 0; i < component_helpers_.size(); i++) { BaseComponentHelper *helper = component_helpers_[i]; if (helper && mask.test(i)) { - helper->get_component(entity)->internal_serialize(save, - static_cast<void*>(&ar)); + auto* c = helper->get_component(entity); + ar.setNextName(c->serializeName().c_str()); + ar.startNode(); + c->internal_serialize(save, static_cast<void*>(&ar)); + ar.finishNode(); } } } diff --git a/src/components/Light.hpp b/src/components/Light.hpp index 2cb0e1b..6849d7c 100644 --- a/src/components/Light.hpp +++ b/src/components/Light.hpp @@ -51,11 +51,15 @@ public: } void serialize(cereal::JSONOutputArchive& ar) final { - ar(r, g, b, strength); + ar(CEREAL_NVP(r), CEREAL_NVP(g), CEREAL_NVP(b), CEREAL_NVP(strength)); } void serialize(cereal::JSONInputArchive& ar) final { - ar(r, g, b, strength); + ar(CEREAL_NVP(r), CEREAL_NVP(g), CEREAL_NVP(b), CEREAL_NVP(strength)); + } + + std::string serializeName(void) const final { + return "Light"; } }; diff --git a/src/components/Name.hpp b/src/components/Name.hpp index b42ef46..a6a6d8a 100644 --- a/src/components/Name.hpp +++ b/src/components/Name.hpp @@ -40,11 +40,15 @@ public: } void serialize(cereal::JSONOutputArchive& ar) final { - ar(name); + ar(CEREAL_NVP(name)); } void serialize(cereal::JSONInputArchive& ar) final { - ar(name); + ar(CEREAL_NVP(name)); + } + + std::string serializeName(void) const final { + return "Name"; } }; diff --git a/src/components/Player.hpp b/src/components/Player.hpp index 95b2a96..33db1eb 100644 --- a/src/components/Player.hpp +++ b/src/components/Player.hpp @@ -35,6 +35,10 @@ public: void serialize([[maybe_unused]] cereal::JSONOutputArchive& ar) final {} void serialize([[maybe_unused]] cereal::JSONInputArchive& ar) final {} + + std::string serializeName(void) const final { + return "Player"; + } }; #endif // COMPONENT_PLAYER_HPP_ diff --git a/src/components/Position.hpp b/src/components/Position.hpp index 6157265..56e8707 100644 --- a/src/components/Position.hpp +++ b/src/components/Position.hpp @@ -44,11 +44,15 @@ public: } void serialize(cereal::JSONOutputArchive& ar) final { - ar(x, y); + ar(CEREAL_NVP(x), CEREAL_NVP(y)); } void serialize(cereal::JSONInputArchive& ar) final { - ar(x, y); + ar(CEREAL_NVP(x), CEREAL_NVP(y)); + } + + std::string serializeName(void) const final { + return "Position"; } }; diff --git a/src/components/Render.hpp b/src/components/Render.hpp index 49a9588..81ca591 100644 --- a/src/components/Render.hpp +++ b/src/components/Render.hpp @@ -55,11 +55,15 @@ public: } void serialize(cereal::JSONOutputArchive& ar) final { - ar(visible, flipX); + ar(CEREAL_NVP(visible), CEREAL_NVP(flipX)); } void serialize(cereal::JSONInputArchive& ar) final { - ar(visible, flipX); + ar(CEREAL_NVP(visible), CEREAL_NVP(flipX)); + } + + std::string serializeName(void) const final { + return "Render"; } }; diff --git a/src/components/Script.hpp b/src/components/Script.hpp index 178c933..f792750 100644 --- a/src/components/Script.hpp +++ b/src/components/Script.hpp @@ -63,6 +63,10 @@ public: void serialize([[maybe_unused]] cereal::JSONOutputArchive& ar) final {} void serialize([[maybe_unused]] cereal::JSONInputArchive& ar) final {} + + std::string serializeName(void) const final { + return "Scripted"; + } }; #endif // COMPONENT_SCRIPT_HPP_ diff --git a/src/components/Velocity.hpp b/src/components/Velocity.hpp index 7a75706..776c1dd 100644 --- a/src/components/Velocity.hpp +++ b/src/components/Velocity.hpp @@ -45,11 +45,15 @@ public: } void serialize(cereal::JSONOutputArchive& ar) final { - ar(x, y); + ar(CEREAL_NVP(x), CEREAL_NVP(y)); } void serialize(cereal::JSONInputArchive& ar) final { - ar(x, y); + ar(CEREAL_NVP(x), CEREAL_NVP(y)); + } + + std::string serializeName(void) const final { + return "Velocity"; } }; diff --git a/src/engine.cpp b/src/engine.cpp index db31b9d..539515c 100644 --- a/src/engine.cpp +++ b/src/engine.cpp @@ -126,6 +126,7 @@ void Engine::run(void) entities.entity_serialize(e, true, archive); archive.finishNode(); } + std::cout << std::endl; } bool Engine::shouldRun(void) |