X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fio%2Feventdispatcher.h;h=f95f477daac5199df5995698a217baa64e6e3f99;hp=b542d67e74d3fa896811b4a04263e9554e4f8902;hb=df6fc46950e15bb30a92368f34dc2005393b0e5b;hpb=f635ee3173be05375cd7d5c7a8edfbfb61f70d60 diff --git a/source/io/eventdispatcher.h b/source/io/eventdispatcher.h index b542d67..f95f477 100644 --- a/source/io/eventdispatcher.h +++ b/source/io/eventdispatcher.h @@ -1,7 +1,7 @@ #ifndef MSP_IO_EVENTDISPATCHER_H_ #define MSP_IO_EVENTDISPATCHER_H_ -#include +#include #include #include #include @@ -14,27 +14,27 @@ namespace IO { Put your I/O objects inside one of these to get signaled when something happens on some of them. */ -class EventDispatcher: public sigc::trackable +class EventDispatcher { private: - struct Slot + struct Slot: public sigc::trackable { - EventObject *obj; - sigc::connection evch_conn; - sigc::connection del_conn; + EventDispatcher &disp; + EventObject &obj; - Slot(EventObject *o): obj(o) { } - }; + Slot(EventDispatcher &, EventObject &); + + void connect_signals() const; + void events_changed(PollEvent) const; + void deleted() const; - typedef std::map SlotMap; + bool operator<(const Slot &o) const { return &obj<&o.obj; } + }; Poller poller; - SlotMap objects; + std::set objects; public: - EventDispatcher(); - ~EventDispatcher(); - void add(EventObject &); void remove(EventObject &); @@ -51,8 +51,6 @@ public: void tick(const Time::Timer &); private: - void object_events_changed(PollEvent, EventObject *); - void object_deleted(EventObject *); void dispatch(); };