X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fio%2Feventdispatcher.cpp;h=47aafa52818eacf85fbd815c17db31697314255a;hp=cf37c1e7e1fbd81155608895bd14ebe9bd882e10;hb=df6fc46950e15bb30a92368f34dc2005393b0e5b;hpb=f635ee3173be05375cd7d5c7a8edfbfb61f70d60 diff --git a/source/io/eventdispatcher.cpp b/source/io/eventdispatcher.cpp index cf37c1e..47aafa5 100644 --- a/source/io/eventdispatcher.cpp +++ b/source/io/eventdispatcher.cpp @@ -4,23 +4,19 @@ #include "eventobject.h" #include "poll.h" +using namespace std; + namespace Msp { namespace IO { -EventDispatcher::EventDispatcher() -{ } - -EventDispatcher::~EventDispatcher() -{ } - void EventDispatcher::add(EventObject &obj) { - SlotMap::iterator i = objects.find(&obj); + Slot slot(*this, obj); + set::iterator i = objects.find(slot); if(i==objects.end()) { - i = objects.insert(SlotMap::value_type(&obj, Slot(&obj))).first; - i->second.evch_conn = obj.signal_events_changed.connect(sigc::bind(sigc::mem_fun(this, &EventDispatcher::object_events_changed), &obj)); - i->second.del_conn = obj.signal_deleted.connect(sigc::bind(sigc::mem_fun(this, &EventDispatcher::object_deleted), &obj)); + i = objects.insert(slot).first; + i->connect_signals(); if(obj.get_events()) poller.set_object(obj, obj.get_events()); @@ -29,11 +25,9 @@ void EventDispatcher::add(EventObject &obj) void EventDispatcher::remove(EventObject &obj) { - SlotMap::iterator i = objects.find(&obj); + set::iterator i = objects.find(Slot(*this, obj)); if(i!=objects.end()) { - i->second.evch_conn.disconnect(); - i->second.del_conn.disconnect(); objects.erase(i); poller.set_object(obj, P_NONE); @@ -67,21 +61,33 @@ void EventDispatcher::tick(const Time::Timer &timer) tick(); } -void EventDispatcher::object_events_changed(PollEvent ev, EventObject *obj) +void EventDispatcher::dispatch() { - poller.set_object(*obj, ev); + const Poller::SlotList &result = poller.get_result(); + for(Poller::SlotList::const_iterator i=result.begin(); i!=result.end(); ++i) + i->object->event(i->events); } -void EventDispatcher::object_deleted(EventObject *obj) + +EventDispatcher::Slot::Slot(EventDispatcher &d, EventObject &o): + disp(d), + obj(o) +{ } + +void EventDispatcher::Slot::connect_signals() const { - remove(*obj); + obj.signal_events_changed.connect(sigc::mem_fun(this, &Slot::events_changed)); + obj.signal_deleted.connect(sigc::mem_fun(this, &Slot::deleted)); } -void EventDispatcher::dispatch() +void EventDispatcher::Slot::events_changed(PollEvent ev) const { - const Poller::SlotList &result = poller.get_result(); - for(Poller::SlotList::const_iterator i=result.begin(); i!=result.end(); ++i) - i->object->event(i->events); + disp.poller.set_object(obj, ev); +} + +void EventDispatcher::Slot::deleted() const +{ + disp.remove(obj); } } // namespace IO