X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fio%2Fpoll.h;h=40c15a70cb84389caa0d9df7a0273383dbc87ac2;hp=d7823aa9108d8d16bd856fd2fbb4b35f41ac04fa;hb=242a4a9abe1e1113b5eb39aa751aa054f696d7be;hpb=bb719167603abe640052de1ed119b6522b7b912e diff --git a/source/io/poll.h b/source/io/poll.h index d7823aa..40c15a7 100644 --- a/source/io/poll.h +++ b/source/io/poll.h @@ -1,9 +1,10 @@ #ifndef MSP_IO_POLL_H_ #define MSP_IO_POLL_H_ -#include #include #include +#include +#include #include namespace Msp { @@ -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,40 +32,42 @@ inline PollEvent operator~(PollEvent e) { return PollEvent(~static_cast(e)); } -class Poller +class Poller: private NonCopyable { public: - struct Slot + struct PolledObject { EventObject *object; PollEvent events; - Slot(EventObject *o, PollEvent e): object(o), events(e) { } + PolledObject(EventObject *o, PollEvent e): object(o), events(e) { } }; - typedef std::list SlotList; -private: - typedef std::map EventMap; + typedef PolledObject Slot DEPRECATED; + typedef std::vector SlotList DEPRECATED; +private: struct Private; - EventMap objects; + std::vector objects; Private *priv; + bool events_changed; bool objs_changed; - SlotList poll_result; + std::vector poll_result; public: Poller(); ~Poller(); void set_object(EventObject &, PollEvent); - int poll(); - int poll(const Time::TimeDelta &); + unsigned poll(); + unsigned poll(const Time::TimeDelta &); private: void rebuild_array(); - int do_poll(int); + unsigned do_poll(int); + void platform_poll(int); public: - const SlotList &get_result() const { return poll_result; } + const std::vector &get_result() const { return poll_result; } }; PollEvent poll(EventObject &, PollEvent);