X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgame%2Feventbus.h;h=a4de18f2bb24c699fb73aea61794b73578cdba77;hb=fce6e7846814e54de9d38000d2f5e2295ee2119e;hp=ce9c812e20b1593cbbe6489b537d4ad201f1f52f;hpb=6a93721ab67315e916f6c649b1f7bc5447d611a4;p=libs%2Fgame.git diff --git a/source/game/eventbus.h b/source/game/eventbus.h index ce9c812..a4de18f 100644 --- a/source/game/eventbus.h +++ b/source/game/eventbus.h @@ -23,9 +23,10 @@ struct EventDispatcher { handlers.emplace_back(obs, std::move(cb)); } void remove_observer(EventObserver *obs) - { std::erase_if(handlers, [obs](const Handler &h){ return h.observer==obs; }); } + { std::erase_if(handlers, [obs](auto &h){ return h.observer==obs; }); } void dispatch(const T &) const; + void dispatch_to(EventObserver &, const T &) const; }; @@ -52,18 +53,21 @@ public: private: template - EventDispatcher &get_emitter(); + EventDispatcher &get_dispatcher(); public: template void add_observer(EventObserver &obs, std::function cb) - { get_emitter().add_observer(obs, std::move(cb)); } + { get_dispatcher().add_observer(&obs, std::move(cb)); } void replace_observer(EventObserver &, EventObserver &); void remove_observer(EventObserver &); template void dispatch(const T &) const; + + template + void dispatch_to(EventObserver &, const T &) const; }; @@ -74,6 +78,14 @@ void EventDispatcher::dispatch(const T &event) const h.callback(event); } +template +void EventDispatcher::dispatch_to(EventObserver &obs, const T &event) const +{ + for(const Handler &h: handlers) + if(h.observer==&obs) + h.callback(event); +} + template inline unsigned EventBus::get_event_id() @@ -83,7 +95,7 @@ inline unsigned EventBus::get_event_id() } template -inline EventDispatcher &EventBus::get_emitter() +inline EventDispatcher &EventBus::get_dispatcher() { unsigned id = get_event_id(); if(dispatchers.size()<=id) @@ -94,10 +106,10 @@ inline EventDispatcher &EventBus::get_emitter() { event.dispatcher = new EventDispatcher; event.deleter = [](void *p){ delete static_cast *>(p); }; - event.remover = [](void *p, EventObserver &o){ static_cast *>(p)->remove_observer(o); }; + event.remover = [](void *p, EventObserver &o){ static_cast *>(p)->remove_observer(&o); }; } - return static_cast *>(event.dispatcher); + return *static_cast *>(event.dispatcher); } template @@ -108,6 +120,14 @@ inline void EventBus::dispatch(const T &event) const static_cast *>(dispatchers[id].dispatcher)->dispatch(event); } +template +inline void EventBus::dispatch_to(EventObserver &obs, const T &event) const +{ + unsigned id = get_event_id(); + if(id *>(dispatchers[id].dispatcher)->dispatch_to(obs, event); +} + } // namespace Msp::Game #endif