--- gvpe/src/iom.h 2003/03/21 21:17:02 1.2 +++ gvpe/src/iom.h 2003/10/14 17:24:19 1.13 @@ -21,15 +21,17 @@ #include -#include +#include +#include "poll.h" + +#include "callback.h" #include "slog.h" typedef double tstamp; extern tstamp NOW; -template class callback; struct io_watcher; struct time_watcher; @@ -37,10 +39,14 @@ vector pfs; vector iow; vector tw; // actually a heap + + void idle_cb (time_watcher &w); time_watcher *idle; public: + void reschedule_time_watchers (); + // register a watcher - void reg (int fd, short events, io_watcher *w); + void reg (io_watcher *w); void unreg (io_watcher *w); void reg (time_watcher *w); void unreg (time_watcher *w); @@ -51,43 +57,32 @@ ~io_manager (); }; -extern io_manager iom; +extern io_manager iom; // a singleton, together with it's construction/destruction problems. + +struct io_watcher : callback2 { + bool registered; // already registered? + int fd; + short events; -template -class callback { - struct object { }; - - void *obj; - R (object::*meth)(A arg); - - // a proxy is a kind of recipe on how to call a specific class method - struct proxy_base { - virtual R call (void *obj, void (object::*meth)(A), A arg) = 0; - }; template - struct proxy : proxy_base { - virtual R call (void *obj, void (object::*meth)(A), A arg) - { - ((reinterpret_cast(obj)) ->* (reinterpret_cast(meth))) - (arg); - } - }; + io_watcher (O1 *object, void (O2::*method)(io_watcher &, short)) + : callback2(object,method) + , registered(false) + { } - proxy_base *prxy; + ~io_watcher (); -public: - template - callback (O1 *object, void (O2::*method)(A)) + void set(int fd_, short events_); + + void set(short events_) { - static proxy p; - obj = reinterpret_cast(object); - meth = reinterpret_cast(method); - prxy = &p; + set (fd, events_); } - R call(A arg) + void start (int fd_, short events_) { - return prxy->call (obj, meth, arg); + set (fd_, events_); + iom.reg (this); } void stop () @@ -96,37 +91,48 @@ } }; -struct io_watcher : callback { - template - io_watcher (O1 *object, void (O2::*method)(short revents)) - : callback(object,method) - { } +#define TSTAMP_CANCEL -1. - void start (int fd, short events) - { - iom.reg (fd, events, this); - } - -}; - -struct time_watcher : callback { +struct time_watcher : callback1 { + bool registered; // already registered? tstamp at; template - time_watcher (O1 *object, void (O2::*method)(tstamp &)) - : callback(object,method) + time_watcher (O1 *object, void (O2::*method)(time_watcher &)) + : callback1(object,method) + , registered(false) { } + ~time_watcher (); + void set (tstamp when); + void trigger (); - void trigger () + void operator ()() { - call (at); + trigger (); + } + + void start () + { + iom.reg (this); } void start (tstamp when) { set (when); + iom.reg (this); + } + + void stop () + { + iom.unreg (this); + } + + void reset (tstamp when = TSTAMP_CANCEL) + { + stop (); + at = when; } };