X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Frb_evas_object_events.c;h=4ccf6b2f1f7b78e63f2641cf2d40f3cd95794e47;hb=HEAD;hp=dc94a48b5371aa3d2e3629e22eaaf7988abfc722;hpb=47ac4c55f54e9154e3e7d149fb77efe0b9613e93;p=ruby-evas.git diff --git a/src/rb_evas_object_events.c b/src/rb_evas_object_events.c index dc94a48..4ccf6b2 100644 --- a/src/rb_evas_object_events.c +++ b/src/rb_evas_object_events.c @@ -1,6 +1,4 @@ /* - * $Id: rb_evas_object_events.c 306 2005-03-23 17:29:37Z tilman $ - * * Copyright (C) 2005 Tilman Sauerbeck (tilman at code-monkey de) * * This library is free software; you can redistribute it and/or @@ -31,49 +29,50 @@ static void on_##name (void *data, Evas *evas, \ Evas_Object *evas_obj, void *event) \ { \ - RbEvasObject *e = (RbEvasObject *) data; \ - VALUE argv[1] = {(VALUE) event}, klass, cb, ev, s; \ -\ - s = rb_str_new2 (#name); \ -\ - cb = rb_hash_aref (e->callbacks, s); \ + VALUE tmp = (VALUE) event, klass, cb = (VALUE) data, ev; \ \ - klass = rb_hash_aref (event_classes, s); \ + klass = rb_hash_aref (event_classes, INT2FIX (EVAS_CALLBACK_##name)); \ if (!NIL_P (klass)) { \ - ev = rb_class_new_instance (1, argv, klass); \ + ev = rb_class_new_instance (1, &tmp, klass); \ rb_funcall (cb, rb_intern ("call"), 1, ev); \ } else \ rb_funcall (cb, rb_intern ("call"), 0); \ } -#define CALLBACK_HANDLER_METHOD(name, callback) \ +#define CALLBACK_HANDLER_METHOD(callback) \ + VALUE cb; \ GET_OBJ (self, RbEvasObject, e); \ \ if (!rb_block_given_p ()) \ return Qnil; \ +\ + cb = rb_block_proc (); \ \ if (NIL_P (e->callbacks)) \ - e->callbacks = rb_hash_new (); \ + e->callbacks = rb_ary_new (); \ +\ + rb_ary_push (e->callbacks, cb); \ \ - rb_hash_aset (e->callbacks, rb_str_new2 (#name), \ - rb_block_proc ()); \ evas_object_event_callback_add (e->real, EVAS_CALLBACK_##callback, \ - on_##name, e); \ + on_##callback, (void *) cb); \ \ return Qnil; -#define CALLBACK_REGISTER(name, clsname) \ +#define CALLBACK_REGISTER(name, callback, clsname) \ rb_define_method (cEvasObject, "on_"#name, c_on_##name, 0); \ \ c = rb_define_class_under (mEvas, (clsname), cEvent); \ rb_define_private_method (rb_singleton_class (c), "new", NULL, 0); \ rb_define_private_method (c, "initialize", c_ev_##name##_init, 1); \ \ - rb_hash_aset (event_classes, rb_str_new2 (#name), c); + rb_hash_aset (event_classes, INT2FIX (EVAS_CALLBACK_##callback), c); #define CALLBACK_REGISTER2(name) \ rb_define_method (cEvasObject, "on_"#name, c_on_##name, 0); +#define TO_STR(s) \ + (s) ? rb_str_new2 ((s)) : Qnil + static VALUE event_classes, cPos; static VALUE c_ev_mouse_in_init (VALUE self, VALUE ev) @@ -191,10 +190,10 @@ static VALUE c_ev_key_down_init (VALUE self, VALUE ev) { Evas_Event_Key_Down *e = (Evas_Event_Key_Down *) ev; - rb_iv_set (self, "@keyname", rb_str_new2 (e->keyname)); - rb_iv_set (self, "@key", rb_str_new2 (e->key)); - rb_iv_set (self, "@string", rb_str_new2 (e->string)); - rb_iv_set (self, "@compose", rb_str_new2 (e->compose)); + rb_iv_set (self, "@keyname", TO_STR (e->keyname)); + rb_iv_set (self, "@key", TO_STR (e->key)); + rb_iv_set (self, "@string", TO_STR (e->string)); + rb_iv_set (self, "@compose", TO_STR (e->compose)); return self; } @@ -203,103 +202,103 @@ static VALUE c_ev_key_up_init (VALUE self, VALUE ev) { Evas_Event_Key_Up *e = (Evas_Event_Key_Up *) ev; - rb_iv_set (self, "@keyname", rb_str_new2 (e->keyname)); - rb_iv_set (self, "@key", rb_str_new2 (e->key)); - rb_iv_set (self, "@string", rb_str_new2 (e->string)); - rb_iv_set (self, "@compose", rb_str_new2 (e->compose)); + rb_iv_set (self, "@keyname", TO_STR (e->keyname)); + rb_iv_set (self, "@key", TO_STR (e->key)); + rb_iv_set (self, "@string", TO_STR (e->string)); + rb_iv_set (self, "@compose", TO_STR (e->compose)); return self; } -CALLBACK_HANDLER_FUNC (mouse_in); -CALLBACK_HANDLER_FUNC (mouse_out); -CALLBACK_HANDLER_FUNC (mouse_down); -CALLBACK_HANDLER_FUNC (mouse_up); -CALLBACK_HANDLER_FUNC (mouse_move); -CALLBACK_HANDLER_FUNC (mouse_wheel); -CALLBACK_HANDLER_FUNC (key_down); -CALLBACK_HANDLER_FUNC (key_up); -CALLBACK_HANDLER_FUNC (focus_in); -CALLBACK_HANDLER_FUNC (focus_out); -CALLBACK_HANDLER_FUNC (show); -CALLBACK_HANDLER_FUNC (hide); -CALLBACK_HANDLER_FUNC (move); -CALLBACK_HANDLER_FUNC (resize); -CALLBACK_HANDLER_FUNC (restack); +CALLBACK_HANDLER_FUNC (MOUSE_IN); +CALLBACK_HANDLER_FUNC (MOUSE_OUT); +CALLBACK_HANDLER_FUNC (MOUSE_DOWN); +CALLBACK_HANDLER_FUNC (MOUSE_UP); +CALLBACK_HANDLER_FUNC (MOUSE_MOVE); +CALLBACK_HANDLER_FUNC (MOUSE_WHEEL); +CALLBACK_HANDLER_FUNC (KEY_DOWN); +CALLBACK_HANDLER_FUNC (KEY_UP); +CALLBACK_HANDLER_FUNC (FOCUS_IN); +CALLBACK_HANDLER_FUNC (FOCUS_OUT); +CALLBACK_HANDLER_FUNC (SHOW); +CALLBACK_HANDLER_FUNC (HIDE); +CALLBACK_HANDLER_FUNC (MOVE); +CALLBACK_HANDLER_FUNC (RESIZE); +CALLBACK_HANDLER_FUNC (RESTACK); static VALUE c_on_mouse_in (VALUE self) { - CALLBACK_HANDLER_METHOD (mouse_in, MOUSE_IN); + CALLBACK_HANDLER_METHOD (MOUSE_IN); } static VALUE c_on_mouse_out (VALUE self) { - CALLBACK_HANDLER_METHOD (mouse_out, MOUSE_OUT); + CALLBACK_HANDLER_METHOD (MOUSE_OUT); } static VALUE c_on_mouse_down (VALUE self) { - CALLBACK_HANDLER_METHOD (mouse_down, MOUSE_DOWN); + CALLBACK_HANDLER_METHOD (MOUSE_DOWN); } static VALUE c_on_mouse_up (VALUE self) { - CALLBACK_HANDLER_METHOD (mouse_up, MOUSE_UP); + CALLBACK_HANDLER_METHOD (MOUSE_UP); } static VALUE c_on_mouse_move (VALUE self) { - CALLBACK_HANDLER_METHOD (mouse_move, MOUSE_MOVE); + CALLBACK_HANDLER_METHOD (MOUSE_MOVE); } static VALUE c_on_mouse_wheel (VALUE self) { - CALLBACK_HANDLER_METHOD (mouse_wheel, MOUSE_WHEEL); + CALLBACK_HANDLER_METHOD (MOUSE_WHEEL); } static VALUE c_on_key_down (VALUE self) { - CALLBACK_HANDLER_METHOD (key_down, KEY_DOWN); + CALLBACK_HANDLER_METHOD (KEY_DOWN); } static VALUE c_on_key_up (VALUE self) { - CALLBACK_HANDLER_METHOD (key_up, KEY_UP); + CALLBACK_HANDLER_METHOD (KEY_UP); } static VALUE c_on_focus_in (VALUE self) { - CALLBACK_HANDLER_METHOD (focus_in, FOCUS_IN); + CALLBACK_HANDLER_METHOD (FOCUS_IN); } static VALUE c_on_focus_out (VALUE self) { - CALLBACK_HANDLER_METHOD (focus_out, FOCUS_OUT); + CALLBACK_HANDLER_METHOD (FOCUS_OUT); } static VALUE c_on_show (VALUE self) { - CALLBACK_HANDLER_METHOD (show, SHOW); + CALLBACK_HANDLER_METHOD (SHOW); } static VALUE c_on_hide (VALUE self) { - CALLBACK_HANDLER_METHOD (hide, HIDE); + CALLBACK_HANDLER_METHOD (HIDE); } static VALUE c_on_move (VALUE self) { - CALLBACK_HANDLER_METHOD (move, MOVE); + CALLBACK_HANDLER_METHOD (MOVE); } static VALUE c_on_resize (VALUE self) { - CALLBACK_HANDLER_METHOD (resize, RESIZE); + CALLBACK_HANDLER_METHOD (RESIZE); } static VALUE c_on_restack (VALUE self) { - CALLBACK_HANDLER_METHOD (restack, RESTACK); + CALLBACK_HANDLER_METHOD (RESTACK); } static VALUE c_ev_init (VALUE argc, VALUE argv, VALUE self) @@ -337,39 +336,39 @@ void Init_EvasObjectEvents (void) rb_define_attr (cPos, "canvas_x", 1, 0); rb_define_attr (cPos, "canvas_y", 1, 0); - CALLBACK_REGISTER (mouse_in, "MouseInEvent"); + CALLBACK_REGISTER (mouse_in, MOUSE_IN, "MouseInEvent"); rb_define_attr (c, "buttons", 1, 0); rb_define_attr (c, "position", 1, 0); - CALLBACK_REGISTER (mouse_out, "MouseOutEvent"); + CALLBACK_REGISTER (mouse_out, MOUSE_OUT, "MouseOutEvent"); rb_define_attr (c, "buttons", 1, 0); rb_define_attr (c, "position", 1, 0); - CALLBACK_REGISTER (mouse_down, "MouseDownEvent"); + CALLBACK_REGISTER (mouse_down, MOUSE_DOWN, "MouseDownEvent"); rb_define_attr (c, "button", 1, 0); rb_define_attr (c, "position", 1, 0); - CALLBACK_REGISTER (mouse_up, "MouseUpEvent"); + CALLBACK_REGISTER (mouse_up, MOUSE_UP, "MouseUpEvent"); rb_define_attr (c, "button", 1, 0); rb_define_attr (c, "position", 1, 0); - CALLBACK_REGISTER (mouse_move, "MouseMoveEvent"); + CALLBACK_REGISTER (mouse_move, MOUSE_MOVE, "MouseMoveEvent"); rb_define_attr (c, "current", 1, 0); rb_define_attr (c, "previous", 1, 0); rb_define_attr (c, "buttons", 1, 0); - CALLBACK_REGISTER (mouse_wheel, "MouseWheelEvent"); + CALLBACK_REGISTER (mouse_wheel, MOUSE_WHEEL, "MouseWheelEvent"); rb_define_attr (c, "direction", 1, 0); rb_define_attr (c, "z", 1, 0); rb_define_attr (c, "position", 1, 0); - CALLBACK_REGISTER (key_down, "KeyDownEvent"); + CALLBACK_REGISTER (key_down, KEY_DOWN, "KeyDownEvent"); rb_define_attr (c, "keyname", 1, 0); rb_define_attr (c, "key", 1, 0); rb_define_attr (c, "string", 1, 0); rb_define_attr (c, "compose", 1, 0); - CALLBACK_REGISTER (key_up, "KeyUpEvent"); + CALLBACK_REGISTER (key_up, KEY_UP, "KeyUpEvent"); rb_define_attr (c, "keyname", 1, 0); rb_define_attr (c, "key", 1, 0); rb_define_attr (c, "string", 1, 0);