summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDan Goodliffe <dan@randomdan.homeip.net>2023-02-21 20:09:41 +0000
committerDan Goodliffe <dan@randomdan.homeip.net>2023-02-21 20:09:41 +0000
commitf91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d (patch)
treefa0326b9d09687c79360cfbd738ce4e14ef0b1d3
parentRename ModelFactory to AssetFactory (diff)
downloadilt-f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d.tar.bz2
ilt-f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d.tar.xz
ilt-f91e2ea8d9e30b1e62c4f8784fddfd4eb9578d2d.zip
Move Appender in Persistence NS and simplify types
-rw-r--r--assetFactory/object.cpp18
-rw-r--r--lib/persistence.h16
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;