X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdynamicobjectloader.h;h=e29633d7b6724ab7bc39071a39938887e851dcf3;hb=6e78ca102c93c2bab2f8f68f71879baf40225a78;hp=b5830b8c9512a9a95840a6bf57c08f87f25b62ba;hpb=616f6fa9d983da10bf323c45d7a44d94c5a09f1e;p=libs%2Fdatafile.git diff --git a/source/dynamicobjectloader.h b/source/dynamicobjectloader.h index b5830b8..e29633d 100644 --- a/source/dynamicobjectloader.h +++ b/source/dynamicobjectloader.h @@ -48,7 +48,7 @@ private: public: T *get_object() { T *o = object; object = 0; return o; } - void store_object(Collection &, const std::string &); + T *store_object(Collection &, const std::string &); private: void type(const Symbol &); @@ -83,13 +83,15 @@ void DynamicObjectLoader::init_actions() } template -void DynamicObjectLoader::store_object(Collection &c, const std::string &name) +T *DynamicObjectLoader::store_object(Collection &c, const std::string &name) { if(!store_func) throw std::logic_error("no store function"); + T *o = object; store_func(c, name, object); object = 0; + return o; } template @@ -126,7 +128,7 @@ void DynamicObjectLoader::CreateObject::operator()(const std::string &, ldr.object = obj; ldr.obj_loader = ldr.create_object_loader(*obj); ldr.add_auxiliary_loader(*ldr.obj_loader); - ldr.store_func = [&ldr](Collection &c, const std::string &n, T *o){ c.add(n, static_cast(o)); }; + ldr.store_func = [](Collection &c, const std::string &n, T *o){ c.add(n, static_cast(o)); }; } } // namespace DataFile