diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-02-21 20:09:41 +0000 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-02-21 20:09:41 +0000 |
commit | f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d (patch) | |
tree | fa0326b9d09687c79360cfbd738ce4e14ef0b1d3 | |
parent | Rename ModelFactory to AssetFactory (diff) | |
download | ilt-f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d.tar.bz2 ilt-f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d.tar.xz ilt-f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d.zip |
Move Appender in Persistence NS and simplify types
-rw-r--r-- | assetFactory/object.cpp | 18 | ||||
-rw-r--r-- | lib/persistence.h | 16 |
2 files changed, 17 insertions, 17 deletions
diff --git a/assetFactory/object.cpp b/assetFactory/object.cpp index faa9a17..ae5a301 100644 --- a/assetFactory/object.cpp +++ b/assetFactory/object.cpp @@ -16,24 +16,8 @@ Object::createMesh(ModelFactoryMesh & mesh, const Mutation::Matrix & mutation) c return faces; } -template<typename Container, typename Type> struct Appender : public Persistence::SelectionT<std::shared_ptr<Type>> { - Appender(Container & c) : Persistence::SelectionT<std::shared_ptr<Type>> {s}, container {c} { } - using Persistence::SelectionT<std::shared_ptr<Type>>::SelectionT; - void - endObject(Persistence::Stack & stk) override - { - container.emplace_back(s); - stk.pop(); - } - -private: - std::shared_ptr<Type> s; - Container & container; -}; - bool Object::persist(Persistence::PersistenceStore & store) { - using UseAppend = Appender<Use::Collection, Use>; - return STORE_TYPE && STORE_MEMBER(id) && STORE_NAME_HELPER("use", uses, UseAppend); + return STORE_TYPE && STORE_MEMBER(id) && STORE_NAME_HELPER("use", uses, Persistence::Appender<Use::Collection>); } diff --git a/lib/persistence.h b/lib/persistence.h index d55062a..5c8454c 100644 --- a/lib/persistence.h +++ b/lib/persistence.h @@ -273,6 +273,22 @@ namespace Persistence { Map & map; }; + template<typename Container, typename Type = typename Container::value_type> + struct Appender : public Persistence::SelectionT<Type> { + Appender(Container & c) : Persistence::SelectionT<Type> {s}, container {c} { } + using Persistence::SelectionT<Type>::SelectionT; + void + endObject(Persistence::Stack & stk) override + { + container.emplace_back(std::move(s)); + stk.pop(); + } + + private: + Type s; + Container & container; + }; + struct Persistable { Persistable() = default; virtual ~Persistable() = default; |