X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fio%2Fpoll.h;h=b65166d24bffb7cf8d7aea7e30f09f525c7b84d2;hp=f59b499ddbc3bad3702c42a56507c32969ddac84;hb=c3e242c2629cbc9645258b30aaf07b7285d4372b;hpb=e46de55d3c8f65d3b0eeaee76247476695e9eb7c diff --git a/source/io/poll.h b/source/io/poll.h index f59b499..b65166d 100644 --- a/source/io/poll.h +++ b/source/io/poll.h @@ -4,12 +4,13 @@ #include #include #include +#include #include namespace Msp { namespace IO { -class Base; +class EventObject; enum PollEvent { @@ -17,7 +18,8 @@ enum PollEvent P_INPUT = 1, P_PRIO = 2, P_OUTPUT = 4, - P_ERROR = 8 + P_ERROR = 8, + P_HANGUP = 16 }; inline PollEvent operator|(PollEvent e, PollEvent f) @@ -30,20 +32,20 @@ inline PollEvent operator~(PollEvent e) { return PollEvent(~static_cast(e)); } -class Poller +class Poller: private NonCopyable { public: struct Slot { - Base *object; + EventObject *object; PollEvent events; - Slot(Base *o, PollEvent e): object(o), events(e) { } + Slot(EventObject *o, PollEvent e): object(o), events(e) { } }; typedef std::list SlotList; private: - typedef std::map EventMap; + typedef std::map EventMap; struct Private; @@ -54,19 +56,21 @@ private: public: Poller(); + ~Poller(); - void set_object(Base &, PollEvent); + void set_object(EventObject &, PollEvent); int poll(); int poll(const Time::TimeDelta &); private: void rebuild_array(); int do_poll(int); + void platform_poll(int); public: const SlotList &get_result() const { return poll_result; } }; -PollEvent poll(Base &, PollEvent); -PollEvent poll(Base &, PollEvent, const Time::TimeDelta &); +PollEvent poll(EventObject &, PollEvent); +PollEvent poll(EventObject &, PollEvent, const Time::TimeDelta &); } // namespace IO } // namespace Msp