X-Git-Url: http://git.code-monkey.de/?p=ruby-ecore.git;a=blobdiff_plain;f=src%2Fecore_evas%2Frb_ecore_evas.c;h=557ca04b9ff4ed3b05bcf8f758f1fe6ec9b5290d;hp=057b5be85c62de4b4590b519da9ee0ca93eae33b;hb=041804188a058aa7bbc76c81e4a816255a635f00;hpb=192810ef6a572e9581c60cdbbd5b3858e815d1d6 diff --git a/src/ecore_evas/rb_ecore_evas.c b/src/ecore_evas/rb_ecore_evas.c index 057b5be..557ca04 100644 --- a/src/ecore_evas/rb_ecore_evas.c +++ b/src/ecore_evas/rb_ecore_evas.c @@ -1,5 +1,5 @@ /* - * $Id: rb_ecore_evas.c 50 2004-08-01 10:18:39Z tilman $ + * $Id: rb_ecore_evas.c 60 2004-08-10 14:12:36Z tilman $ * * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de) * @@ -30,7 +30,7 @@ #include "rb_ecore_evas_main.h" #include "rb_ecore_evas.h" -#define CALLBACK_ADD_HANDLER(name) \ +#define CALLBACK_DEFINE_HANDLER(name) \ static void on_##name (Ecore_Evas *real) \ { \ VALUE self = rb_hash_aref (objects, INT2NUM ((long) real)); \ @@ -41,9 +41,8 @@ cb = rb_hash_aref (ee->callbacks, rb_str_new2 (#name)); \ rb_funcall (cb, rb_intern ("call"), 0); \ } \ -\ - static VALUE c_on_##name (VALUE self) \ - { \ + +#define CALLBACK_REG_HANDLER(name) \ GET_OBJ (self, RbEcoreEvas, ee); \ \ if (!rb_block_given_p ()) \ @@ -54,11 +53,7 @@ \ ecore_evas_callback_##name##_set (ee->real, on_##name); \ \ - return Qnil; \ - } - -#define CALLBACK_ADD(mod, name) \ - rb_define_method ((mod), "on_"#name, c_on_##name, 0); + return Qnil; VALUE cEcoreEvas; static VALUE objects; @@ -84,6 +79,7 @@ void c_ecore_evas_free (RbEcoreEvas *ee, bool free_mem) free (ee); } +/* :nodoc: */ static VALUE c_init (int argc, VALUE *argv, VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -96,11 +92,18 @@ static VALUE c_init (int argc, VALUE *argv, VALUE self) return Qnil; } +/* :nodoc: */ static VALUE c_inspect (VALUE self) { INSPECT (self, RbEcoreEvas); } +/* + * call-seq: + * ee.show => nil + * + * Shows ee. + */ static VALUE c_show (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -110,6 +113,12 @@ static VALUE c_show (VALUE self) return Qnil; } +/* + * call-seq: + * ee.hide => nil + * + * Hides ee. + */ static VALUE c_hide (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -119,6 +128,12 @@ static VALUE c_hide (VALUE self) return Qnil; } +/* + * call-seq: + * ee.visible? => true or false + * + * Returns true if ee is visible, else false. + */ static VALUE c_visible_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -126,6 +141,12 @@ static VALUE c_visible_get (VALUE self) return ecore_evas_visibility_get (ee->real) ? Qtrue : Qfalse; } +/* + * call-seq: + * ee.raise => nil + * + * Raises ee. + */ static VALUE c_raise (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -135,6 +156,12 @@ static VALUE c_raise (VALUE self) return Qnil; } +/* + * call-seq: + * ee.lower => nil + * + * Lowers ee. + */ static VALUE c_lower (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -144,6 +171,12 @@ static VALUE c_lower (VALUE self) return Qnil; } +/* + * call-seq: + * ee.layer => fixnum + * + * Returns the layer of ee. + */ static VALUE c_layer_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -151,6 +184,12 @@ static VALUE c_layer_get (VALUE self) return INT2FIX (ecore_evas_layer_get (ee->real)); } +/* + * call-seq: + * ee.layer(fixnum) => fixnum + * + * Sets the layer of ee. + */ static VALUE c_layer_set (VALUE self, VALUE val) { GET_OBJ (self, RbEcoreEvas, ee); @@ -162,6 +201,12 @@ static VALUE c_layer_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * ee.evas => evas + * + * Returns the Evas::Evas object for ee. + */ static VALUE c_evas_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -172,6 +217,16 @@ static VALUE c_evas_get (VALUE self) return ee->evas; } +/* + * call-seq: + * ee.geometry => array + * + * Returns an array containing the geometry of ee. + * + * ee.move(150, 300) #=> nil + * ee.resize(200, 200) #=> nil + * ee.geometry #=> [150, 300, 200, 200] + */ static VALUE c_geometry_get (VALUE self) { int x = 0, y = 0, w = 0, h = 0; @@ -184,6 +239,15 @@ static VALUE c_geometry_get (VALUE self) INT2FIX (w), INT2FIX (h)); } +/* + * call-seq: + * ee.get_size_min => array + * + * Returns an array containing the minimum size of ee. + * + * ee.set_size_min(100, 200) #=> nil + * ee.get_size_min #=> [100, 200] + */ static VALUE c_get_size_min (VALUE self) { int w = 0, h = 0; @@ -195,6 +259,14 @@ static VALUE c_get_size_min (VALUE self) return rb_ary_new3 (2, INT2FIX (w), INT2FIX (h)); } +/* + * call-seq: + * ee.set_size_min(width, height) => nil + * + * Sets the minimum size of ee. + * + * ee.set_size_min(100, 200) #=> nil + */ static VALUE c_set_size_min (VALUE self, VALUE w, VALUE h) { GET_OBJ (self, RbEcoreEvas, ee); @@ -207,6 +279,15 @@ static VALUE c_set_size_min (VALUE self, VALUE w, VALUE h) return Qnil; } +/* + * call-seq: + * ee.get_size_max => array + * + * Returns an array containing the maximum size of ee. + * + * ee.set_size_max(100, 200) #=> nil + * ee.get_size_max #=> [100, 200] + */ static VALUE c_get_size_max (VALUE self) { int w = 0, h = 0; @@ -218,6 +299,14 @@ static VALUE c_get_size_max (VALUE self) return rb_ary_new3 (2, INT2FIX (w), INT2FIX (h)); } +/* + * call-seq: + * ee.set_size_max(width, height) => nil + * + * Sets the maximum size of ee. + * + * ee.set_size_max(100, 200) #=> nil + */ static VALUE c_set_size_max (VALUE self, VALUE w, VALUE h) { GET_OBJ (self, RbEcoreEvas, ee); @@ -230,6 +319,15 @@ static VALUE c_set_size_max (VALUE self, VALUE w, VALUE h) return Qnil; } +/* + * call-seq: + * ee.move(x, y) => nil + * + * Moves ee to the coordinates specified in + * x and y. + * + * ee.move(100, 200) #=> nil + */ static VALUE c_move (VALUE self, VALUE x, VALUE y) { GET_OBJ (self, RbEcoreEvas, ee); @@ -242,6 +340,14 @@ static VALUE c_move (VALUE self, VALUE x, VALUE y) return Qnil; } +/* + * call-seq: + * ee.resize(width, height) => nil + * + * Resizes ee to width x height. + * + * ee.resize(100, 200) #=> nil + */ static VALUE c_resize (VALUE self, VALUE w, VALUE h) { GET_OBJ (self, RbEcoreEvas, ee); @@ -254,6 +360,12 @@ static VALUE c_resize (VALUE self, VALUE w, VALUE h) return Qnil; } +/* + * call-seq: + * ee.title => string + * + * Returns the title of ee. + */ static VALUE c_title_get (VALUE self) { const char *tmp; @@ -266,6 +378,12 @@ static VALUE c_title_get (VALUE self) return rb_str_new2 (tmp); } +/* + * call-seq: + * ee.title(string) + * + * Sets the title of ee. + */ static VALUE c_title_set (VALUE self, VALUE val) { GET_OBJ (self, RbEcoreEvas, ee); @@ -277,6 +395,12 @@ static VALUE c_title_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * ee.borderless? => true or false + * + * Returns true if ee is borderless, else false. + */ static VALUE c_borderless_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -284,6 +408,12 @@ static VALUE c_borderless_get (VALUE self) return ecore_evas_borderless_get (ee->real) ? Qtrue : Qfalse; } +/* + * call-seq: + * ee.borderless(true or false) + * + * Sets whether ee is borderless or not. + */ static VALUE c_borderless_set (VALUE self, VALUE val) { GET_OBJ (self, RbEcoreEvas, ee); @@ -295,6 +425,12 @@ static VALUE c_borderless_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * ee.shaped? => true or false + * + * Returns true if ee is shaped, else false. + */ static VALUE c_shaped_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -302,6 +438,12 @@ static VALUE c_shaped_get (VALUE self) return ecore_evas_shaped_get (ee->real) ? Qtrue : Qfalse; } +/* + * call-seq: + * ee.shaped(true or false) + * + * Sets whether ee is shaped or not. + */ static VALUE c_shaped_set (VALUE self, VALUE val) { GET_OBJ (self, RbEcoreEvas, ee); @@ -313,6 +455,12 @@ static VALUE c_shaped_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * ee.sticky? => true or false + * + * Returns true if ee is sticky, else false. + */ static VALUE c_sticky_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -320,6 +468,12 @@ static VALUE c_sticky_get (VALUE self) return ecore_evas_sticky_get (ee->real) ? Qtrue : Qfalse; } +/* + * call-seq: + * ee.sticky(true or false) + * + * Sets whether ee is sticky or not. + */ static VALUE c_sticky_set (VALUE self, VALUE val) { GET_OBJ (self, RbEcoreEvas, ee); @@ -331,6 +485,12 @@ static VALUE c_sticky_set (VALUE self, VALUE val) return Qnil; } +/* + * call-seq: + * ee.rotation => fixnum + * + * Returns the rotation of ee. + */ static VALUE c_rotation_get (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -338,6 +498,12 @@ static VALUE c_rotation_get (VALUE self) return INT2FIX (ecore_evas_rotation_get (ee->real)); } +/* + * call-seq: + * ee.rotation(fixnum) + * + * Sets the rotation of ee. + */ static VALUE c_rotation_set (VALUE self, VALUE val) { GET_OBJ (self, RbEcoreEvas, ee); @@ -349,7 +515,9 @@ static VALUE c_rotation_set (VALUE self, VALUE val) return Qnil; } -/* FIXME: this is unsafe! */ +/* FIXME: this is unsafe! + * :nodoc: + */ static VALUE c_delete (VALUE self) { GET_OBJ (self, RbEcoreEvas, ee); @@ -364,18 +532,150 @@ static VALUE c_delete (VALUE self) return Qnil; } -CALLBACK_ADD_HANDLER (resize); -CALLBACK_ADD_HANDLER (move); -CALLBACK_ADD_HANDLER (show); -CALLBACK_ADD_HANDLER (hide); -CALLBACK_ADD_HANDLER (delete_request); -CALLBACK_ADD_HANDLER (destroy); -CALLBACK_ADD_HANDLER (focus_in); -CALLBACK_ADD_HANDLER (focus_out); -CALLBACK_ADD_HANDLER (mouse_in); -CALLBACK_ADD_HANDLER (mouse_out); -CALLBACK_ADD_HANDLER (pre_render); -CALLBACK_ADD_HANDLER (post_render); +CALLBACK_DEFINE_HANDLER (resize); +CALLBACK_DEFINE_HANDLER (move); +CALLBACK_DEFINE_HANDLER (show); +CALLBACK_DEFINE_HANDLER (hide); +CALLBACK_DEFINE_HANDLER (delete_request); +CALLBACK_DEFINE_HANDLER (destroy); +CALLBACK_DEFINE_HANDLER (focus_in); +CALLBACK_DEFINE_HANDLER (focus_out); +CALLBACK_DEFINE_HANDLER (mouse_in); +CALLBACK_DEFINE_HANDLER (mouse_out); +CALLBACK_DEFINE_HANDLER (pre_render); +CALLBACK_DEFINE_HANDLER (post_render); + +/* + * call-seq: + * ee.on_resize { block } => nil + * + * Sets the handler for the resize event. + */ +static VALUE c_on_resize (VALUE self) +{ + CALLBACK_REG_HANDLER (resize); +} + +/* + * call-seq: + * ee.on_move { block } => nil + * + * Sets the handler for the move event. + */ +static VALUE c_on_move (VALUE self) +{ + CALLBACK_REG_HANDLER (move); +} + +/* + * call-seq: + * ee.on_show { block } => nil + * + * Sets the handler for the show event. + */ +static VALUE c_on_show (VALUE self) +{ + CALLBACK_REG_HANDLER (show); +} + +/* + * call-seq: + * ee.on_hide { block } => nil + * + * Sets the handler for the hide event. + */ +static VALUE c_on_hide (VALUE self) +{ + CALLBACK_REG_HANDLER (hide); +} + +/* + * call-seq: + * ee.on_delete_request { block } => nil + * + * Sets the handler for the delete request event. + */ +static VALUE c_on_delete_request (VALUE self) +{ + CALLBACK_REG_HANDLER (delete_request); +} + +/* + * call-seq: + * ee.on_destroy { block } => nil + * + * Sets the handler for the destroy event. + */ +static VALUE c_on_destroy (VALUE self) +{ + CALLBACK_REG_HANDLER (destroy); +} + +/* + * call-seq: + * ee.on_focus_in { block } => nil + * + * Sets the handler for the focus in event. + */ +static VALUE c_on_focus_in (VALUE self) +{ + CALLBACK_REG_HANDLER (focus_in); +} + +/* + * call-seq: + * ee.on_focus_out { block } => nil + * + * Sets the handler for the focus out event. + */ +static VALUE c_on_focus_out (VALUE self) +{ + CALLBACK_REG_HANDLER (focus_out); +} + +/* + * call-seq: + * ee.on_mouse_in { block } => nil + * + * Sets the handler for the mouse in event. + */ +static VALUE c_on_mouse_in (VALUE self) +{ + CALLBACK_REG_HANDLER (mouse_in); +} + +/* + * call-seq: + * ee.on_mouse_out { block } => nil + * + * Sets the handler for the mouse out event. + */ +static VALUE c_on_mouse_out (VALUE self) +{ + CALLBACK_REG_HANDLER (mouse_out); +} + +/* + * call-seq: + * ee.on_pre_render { block } => nil + * + * Sets the handler for the pre render event. + */ +static VALUE c_on_pre_render (VALUE self) +{ + CALLBACK_REG_HANDLER (pre_render); +} + +/* + * call-seq: + * ee.on_post_render { block } => nil + * + * Sets the handler for the post render event. + */ +static VALUE c_on_post_render (VALUE self) +{ + CALLBACK_REG_HANDLER (post_render); +} void Init_EcoreEvas (void) { @@ -412,18 +712,18 @@ void Init_EcoreEvas (void) rb_define_method (cEcoreEvas, "rotation", c_rotation_get, 0); rb_define_method (cEcoreEvas, "rotation=", c_rotation_set, 1); - CALLBACK_ADD (cEcoreEvas, resize); - CALLBACK_ADD (cEcoreEvas, move); - CALLBACK_ADD (cEcoreEvas, show); - CALLBACK_ADD (cEcoreEvas, hide); - CALLBACK_ADD (cEcoreEvas, delete_request); - CALLBACK_ADD (cEcoreEvas, destroy); - CALLBACK_ADD (cEcoreEvas, focus_in); - CALLBACK_ADD (cEcoreEvas, focus_out); - CALLBACK_ADD (cEcoreEvas, mouse_in); - CALLBACK_ADD (cEcoreEvas, mouse_out); - CALLBACK_ADD (cEcoreEvas, pre_render); - CALLBACK_ADD (cEcoreEvas, post_render); + rb_define_method (cEcoreEvas, "on_resize", c_on_resize, 0); + rb_define_method (cEcoreEvas, "on_move", c_on_move, 0); + rb_define_method (cEcoreEvas, "on_show", c_on_show, 0); + rb_define_method (cEcoreEvas, "on_hide", c_on_hide, 0); + rb_define_method (cEcoreEvas, "on_delete_request", c_on_delete_request, 0); + rb_define_method (cEcoreEvas, "on_destroy", c_on_destroy, 0); + rb_define_method (cEcoreEvas, "on_focus_in", c_on_focus_in, 0); + rb_define_method (cEcoreEvas, "on_focus_out", c_on_focus_out, 0); + rb_define_method (cEcoreEvas, "on_mouse_in", c_on_mouse_in, 0); + rb_define_method (cEcoreEvas, "on_mouse_out", c_on_mouse_out, 0); + rb_define_method (cEcoreEvas, "on_pre_render", c_on_pre_render, 0); + rb_define_method (cEcoreEvas, "on_post_render", c_on_post_render, 0); objects = rb_hash_new (); rb_global_variable (&objects);