diff options
author | Max-001 <80035972+Max-001@users.noreply.github.com> | 2025-01-08 16:00:45 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-01-08 16:00:45 +0100 |
commit | e6666d662678239d1d0c4c71f271855fdcdc3800 (patch) | |
tree | d6effc80f9e989b8ca148958109100bb13d3cbab | |
parent | 533be30e21d3b42732852e6879a8450c4f7e417b (diff) | |
parent | 099f9d42db9b15f1be2090ce2a8869ace871a644 (diff) |
Merge pull request #115 from lonkaars/loek/replay
replay for text components
-rw-r--r-- | src/crepe/api/Text.cpp | 13 | ||||
-rw-r--r-- | src/crepe/api/Text.h | 6 |
2 files changed, 19 insertions, 0 deletions
diff --git a/src/crepe/api/Text.cpp b/src/crepe/api/Text.cpp index e5b623d..e5cc39d 100644 --- a/src/crepe/api/Text.cpp +++ b/src/crepe/api/Text.cpp @@ -3,6 +3,7 @@ #include "Text.h" using namespace crepe; +using namespace std; Text::Text( game_object_id_t id, const vec2 & dimensions, const std::string & font_family, @@ -12,3 +13,15 @@ Text::Text( text(text), data(data), font_family(font_family) {} + +unique_ptr<Component> Text::save() const { return unique_ptr<Component>(new Text(*this)); } + +void Text::restore(const Component & snapshot) { *this = static_cast<const Text &>(snapshot); } + +Text & Text::operator=(const Text & snapshot) { + this->active = snapshot.active; + this->data = snapshot.data; + this->text = snapshot.text; + this->font_family = snapshot.font_family; + return *this; +} diff --git a/src/crepe/api/Text.h b/src/crepe/api/Text.h index 8b3d53e..859490e 100644 --- a/src/crepe/api/Text.h +++ b/src/crepe/api/Text.h @@ -49,6 +49,12 @@ public: std::optional<Asset> font; //! Data instance Data data; + +protected: + virtual std::unique_ptr<Component> save() const; + Text(const Text &) = default; + virtual void restore(const Component & snapshot); + virtual Text & operator=(const Text &); }; } // namespace crepe |