X-Git-Url: https://git.llucax.com/software/libev.git/blobdiff_plain/7f61bc3d979ef53b867172664694f8fcf9e5bdd0..86521c1ef67d371e724e4419f5100dc0da641194:/ev%20%20.h/software/libev.git/blobdiff_plain/7f61bc3d979ef53b867172664694f8fcf9e5bdd0..86521c1ef67d371e724e4419f5100dc0da641194:/ev++.h diff --git a/ev++.h b/ev++.h index fea0ac1..f535515 100644 --- a/ev++.h +++ b/ev++.h @@ -1,7 +1,11 @@ #ifndef EVPP_H__ #define EVPP_H__ -#include "ev.h" +#ifdef EV_H +# include EV_H +#else +# include +#endif namespace ev { @@ -22,12 +26,13 @@ namespace ev { ev_init (this, 0); } - void set_ (void *object, void (*cb)(EV_P_ ev_watcher *w, int revents)) + void set_ (void *data, void (*cb)(EV_P_ ev_watcher *w, int revents)) { - this->data = object; + this->data = data; ev_set_cb (static_cast(this), cb); } + // method callback template void set (K *object) { @@ -37,11 +42,11 @@ namespace ev { template static void method_thunk (EV_P_ ev_watcher *w, int revents) { - watcher *self = static_cast(w); - K *obj = static_cast(self->data); - (obj->*method) (*self, revents); + K *obj = static_cast(w->data); + (obj->*method) (*static_cast(w), revents); } + // const method callback template void set (const K *object) { @@ -51,13 +56,13 @@ namespace ev { template static void const_method_thunk (EV_P_ ev_watcher *w, int revents) { - watcher *self = static_cast(w); - K *obj = static_cast(self->data); - (obj->*method) (*self, revents); + K *obj = static_cast(w->data); + (static_cast(w->data)->*method) (*static_cast(w), revents); } - template - void set () + // function callback + template + void set (void *data = 0) { set_ (data, function_thunk); } @@ -65,8 +70,21 @@ namespace ev { template static void function_thunk (EV_P_ ev_watcher *w, int revents) { - watcher *self = static_cast(w); - function (*self, revents); + function (*static_cast(w), revents); + } + + // simple callback + template + void set (K *object) + { + set_ (object, method_noargs_thunk); + } + + template + static void method_noargs_thunk (EV_P_ ev_watcher *w, int revents) + { + K *obj = static_cast(w->data); + (obj->*method) (); } void operator ()(int events = EV_UNDEF)