--- rxvt-unicode/src/rxvttoolkit.h 2007/10/31 09:55:24 1.33 +++ rxvt-unicode/src/rxvttoolkit.h 2007/11/11 04:08:00 1.34 @@ -29,7 +29,7 @@ # include #endif -#include "iom.h" +#include "ev_cpp.h" #include "rxvtlib.h" #include "rxvtutil.h" @@ -102,6 +102,27 @@ struct im_watcher; struct xevent_watcher; +template +struct event_vec : vector { + void erase_unordered (unsigned int pos) + { + watcher *w = (*this)[this->size () - 1]; + this->pop_back (); + + if (!this->empty ()) + if (((*this)[pos] = w)) // '=' is correct! + w->active = pos + 1; + } +}; + +struct rxvt_watcher { + int active; /* 0 == inactive, else index into respective vector */ + + bool is_active () { return active; } + + rxvt_watcher () : active (0) { } +}; + struct refcounted { int referenced; char *id; @@ -190,9 +211,9 @@ }; struct rxvt_display : refcounted { - io_manager_vec xw; + event_vec xw; - io_watcher x_ev; void x_cb (io_watcher &w, short revents); + ev::io x_ev; void x_cb (ev::io &w, int revents); #ifdef USE_XIM refcache xims; @@ -236,7 +257,7 @@ }; #ifdef USE_XIM -struct im_watcher : watcher, callback { +struct im_watcher : rxvt_watcher, callback { template im_watcher (O object, M method) : callback (object, method) @@ -246,6 +267,7 @@ { display->reg (this); } + void stop (rxvt_display *display) { display->unreg (this); @@ -253,7 +275,7 @@ }; #endif -struct xevent_watcher : watcher, callback { +struct xevent_watcher : rxvt_watcher, callback { Window window; template @@ -266,6 +288,7 @@ this->window = window; display->reg (this); } + void stop (rxvt_display *display) { display->unreg (this);