From 57e6fe17689de1646a53a20a46374936391db3e2 Mon Sep 17 00:00:00 2001 From: root Date: Sat, 8 Dec 2007 14:27:38 +0000 Subject: fix c++ interface --- ev++.h | 29 +++++++++++++---------------- 1 file changed, 13 insertions(+), 16 deletions(-) (limited to 'ev++.h') diff --git a/ev++.h b/ev++.h index fea0ac1..71a3d52 100644 --- a/ev++.h +++ b/ev++.h @@ -22,10 +22,10 @@ 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_ watcher *w, int revents)) { - this->data = object; - ev_set_cb (static_cast(this), cb); + this->data = data; + ev_set_cb (static_cast(this), cb); } template @@ -35,11 +35,10 @@ namespace ev { } template - static void method_thunk (EV_P_ ev_watcher *w, int revents) + static void method_thunk (EV_P_ 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) (*w, revents); } template @@ -49,24 +48,22 @@ namespace ev { } template - static void const_method_thunk (EV_P_ ev_watcher *w, int revents) + static void const_method_thunk (EV_P_ 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) (*w, revents); } - template - void set () + template + void set (void *data = 0) { set_ (data, function_thunk); } template - static void function_thunk (EV_P_ ev_watcher *w, int revents) + static void function_thunk (EV_P_ watcher *w, int revents) { - watcher *self = static_cast(w); - function (*self, revents); + function (*w, revents); } void operator ()(int events = EV_UNDEF) -- cgit v1.2.3