X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgame%2Fowned.h;h=fc2acab6ecb02ab0d4079630dae5f5fe5b8fc939;hb=48051ee2bab13f65e48c371e453b9ea65920921e;hp=19daa7efe12afbbffeb3676d635088daca4889ff;hpb=c7d0e1aff305778f97974b329826628966380158;p=libs%2Fgame.git diff --git a/source/game/owned.h b/source/game/owned.h index 19daa7e..fc2acab 100644 --- a/source/game/owned.h +++ b/source/game/owned.h @@ -2,6 +2,8 @@ #define MSP_GAME_OWNED_H_ #include +#include "accessguard.h" +#include "events.h" #include "handle.h" #include "stage.h" @@ -16,11 +18,15 @@ class Owned: public Handle public: Owned() = default; - template - Owned(Handle, Args &&...); + template + Owned(Handle

, Args &&...); - template - Owned(Entity &parent, Args &&... args): Owned(Handle::from_object(&parent), std::forward(args)...) { } + template + Owned(Owned

&p, Args &&... a): Owned(static_cast &>(p), std::forward(a)...) { } + + template + requires(!std::is_const_v

) + Owned(P &parent, Args &&... args): Owned(Handle

::from_object(&parent), std::forward(args)...) { } Owned(Owned &&other): Handle(other) { other.ptr = nullptr; } Owned &operator=(Owned &&other); @@ -35,21 +41,29 @@ private: template -template -Owned::Owned(Handle parent, Args &&... args) +template +Owned::Owned(Handle

parent, Args &&... args) { +#ifdef DEBUG + AccessGuard::get_instance().check(); +#endif + if(!parent) throw std::invalid_argument("Owned::Owned"); - using DependentEntity = std::conditional_t; - Handle dparent = parent; - - Pool &pool = get_stage(*dparent).get_pools().template get_pool(); + Stage &stage = get_stage(*parent); + Pool &pool = stage.get_pools().get_pool(); this->ptr = pool.create(parent, std::forward(args)...); if constexpr(std::is_base_of_v) - dparent->add_component(*this); + { + parent->add_component(*this); + stage.get_event_source().emit(*this); + } else - dparent->add_child(*this); + { + parent->add_child(*this); + stage.get_event_source().emit(*this); + } } template @@ -80,13 +94,24 @@ void Owned::destroy() if(!obj) return; - Pool &pool = get_stage(*obj).get_pools().template get_pool(); +#ifdef DEBUG + AccessGuard::get_instance().check(); +#endif + + Stage &stage = get_stage(*obj); if constexpr(std::is_base_of_v) + { + stage.get_event_source().emit(*this); obj->get_entity()->remove_component(*this); + } else if(auto parent = obj->get_parent().get()) + { + stage.get_event_source().emit(*this); parent->remove_child(*this); + } + Pool &pool = stage.get_pools().get_pool(); pool.destroy(this->ptr); }