X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=inline;f=src%2Fecore_evas%2Frb_ecore_evas.c;h=c2d17f0a7f7ee42eb1a5862aef021d40cb977ad4;hb=d907bd016f15dc5be72d12ee1742047eafc2abae;hp=057b5be85c62de4b4590b519da9ee0ca93eae33b;hpb=f805cf241a9d1fb9765892f0af48ede8359e9b65;p=ruby-ecore.git
diff --git a/src/ecore_evas/rb_ecore_evas.c b/src/ecore_evas/rb_ecore_evas.c
index 057b5be..c2d17f0 100644
--- a/src/ecore_evas/rb_ecore_evas.c
+++ b/src/ecore_evas/rb_ecore_evas.c
@@ -1,7 +1,7 @@
/*
- * $Id: rb_ecore_evas.c 50 2004-08-01 10:18:39Z tilman $
+ * $Id: rb_ecore_evas.c 386 2006-09-06 19:38:45Z tilman $
*
- * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
+ * Copyright (C) 2004 ruby-ecore team (see AUTHORS)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
@@ -30,38 +30,40 @@
#include "rb_ecore_evas_main.h"
#include "rb_ecore_evas.h"
-#define CALLBACK_ADD_HANDLER(name) \
+#define RUBY_ECORE_EVAS_KEY "__RB_ECORE_EVAS_KEY"
+
+#define CALLBACK_DEFINE_HANDLER(name) \
static void on_##name (Ecore_Evas *real) \
{ \
- VALUE self = rb_hash_aref (objects, INT2NUM ((long) real)); \
- VALUE cb; \
+ VALUE self, cb; \
\
+ self = (VALUE) ecore_evas_data_get (real, \
+ RUBY_ECORE_EVAS_KEY); \
GET_OBJ (self, RbEcoreEvas, ee); \
\
- cb = rb_hash_aref (ee->callbacks, rb_str_new2 (#name)); \
+ cb = rb_hash_aref (ee->callbacks, \
+ LONG2NUM ((long) ecore_evas_callback_##name##_set)); \
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 ()) \
return Qnil; \
\
- rb_hash_aset (ee->callbacks, rb_str_new2 (#name), \
+ if (NIL_P (ee->callbacks)) \
+ ee->callbacks = rb_hash_new (); \
+\
+ rb_hash_aset (ee->callbacks, \
+ LONG2NUM ((long) ecore_evas_callback_##name##_set), \
rb_block_proc ()); \
\
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;
/* called by the child classes */
void c_ecore_evas_mark (RbEcoreEvas *ee)
@@ -69,7 +71,8 @@ void c_ecore_evas_mark (RbEcoreEvas *ee)
if (!NIL_P (ee->evas))
rb_gc_mark (ee->evas);
- rb_gc_mark (ee->callbacks);
+ if (!NIL_P (ee->callbacks))
+ rb_gc_mark (ee->callbacks);
}
void c_ecore_evas_free (RbEcoreEvas *ee, bool free_mem)
@@ -84,23 +87,31 @@ 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);
ee->evas = Qnil;
- ee->callbacks = rb_hash_new ();
+ ee->callbacks = Qnil;
- rb_hash_aset (objects, INT2NUM ((long) ee->real), self);
+ ecore_evas_data_set (ee->real, RUBY_ECORE_EVAS_KEY, (void *) 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 +121,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 +136,12 @@ static VALUE c_hide (VALUE self)
return Qnil;
}
+/*
+ * call-seq:
+ * ee.visible? => true or false
+ *
+ * Returns true if ee is visible, else returns false.
+ */
static VALUE c_visible_get (VALUE self)
{
GET_OBJ (self, RbEcoreEvas, ee);
@@ -126,6 +149,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 +164,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 +179,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 +192,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 +209,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 +225,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 +247,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 +267,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 +287,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 +307,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 +327,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 +348,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 +368,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 +386,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 +403,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 returns false.
+ */
static VALUE c_borderless_get (VALUE self)
{
GET_OBJ (self, RbEcoreEvas, ee);
@@ -284,6 +416,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 +433,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 returns false.
+ */
static VALUE c_shaped_get (VALUE self)
{
GET_OBJ (self, RbEcoreEvas, ee);
@@ -302,6 +446,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 +463,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 returns false.
+ */
static VALUE c_sticky_get (VALUE self)
{
GET_OBJ (self, RbEcoreEvas, ee);
@@ -320,6 +476,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 +493,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 +506,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 +523,101 @@ static VALUE c_rotation_set (VALUE self, VALUE val)
return Qnil;
}
-/* FIXME: this is unsafe! */
+static VALUE c_name_class_get (VALUE self)
+{
+ const char *name = NULL, *klass = NULL;
+
+ GET_OBJ (self, RbEcoreEvas, ee);
+
+ ecore_evas_name_class_get (ee->real, &name, &klass);
+
+ return rb_ary_new3 (2, name ? rb_str_new2 (name) : Qnil,
+ klass ? rb_str_new2 (klass) : Qnil);
+}
+
+static VALUE c_name_class_set (VALUE self, VALUE ary)
+{
+ VALUE s1, s2;
+
+ GET_OBJ (self, RbEcoreEvas, ee);
+
+ Check_Type (ary, T_ARRAY);
+
+ s1 = rb_ary_shift (ary);
+ s2 = rb_ary_shift (ary);
+
+ StringValue (s1);
+ StringValue (s2);
+
+ ecore_evas_name_class_set (ee->real, StringValuePtr (s1),
+ StringValuePtr (s2));
+
+ return Qnil;
+}
+
+/*
+ * call-seq:
+ * ee.iconified? => true or false
+ *
+ * Returns true if ee is iconified, else returns false.
+ */
+static VALUE c_iconified_get (VALUE self)
+{
+ GET_OBJ (self, RbEcoreEvas, ee);
+
+ return ecore_evas_iconified_get (ee->real) ? Qtrue : Qfalse;
+}
+
+/*
+ * call-seq:
+ * ee.iconified(true or false)
+ *
+ * Sets whether ee is iconified or not.
+ */
+static VALUE c_iconified_set (VALUE self, VALUE val)
+{
+ GET_OBJ (self, RbEcoreEvas, ee);
+
+ CHECK_BOOL (val);
+
+ ecore_evas_iconified_set (ee->real, val == Qtrue);
+
+ return Qnil;
+}
+
+/*
+ * call-seq:
+ * ee.has_alpha? => true or false
+ *
+ * Returns true if ee has an alpha channel, else returns false.
+ */
+static VALUE c_has_alpha_get (VALUE self)
+{
+ GET_OBJ (self, RbEcoreEvas, ee);
+
+ return ecore_evas_alpha_get (ee->real) ? Qtrue : Qfalse;
+}
+
+/*
+ * call-seq:
+ * ee.has_alpha(true or false)
+ *
+ * Sets whether ee has an alpha channel or not.
+ */
+static VALUE c_has_alpha_set (VALUE self, VALUE val)
+{
+ GET_OBJ (self, RbEcoreEvas, ee);
+
+ CHECK_BOOL (val);
+
+ ecore_evas_alpha_set (ee->real, val == Qtrue);
+
+ return Qnil;
+}
+
+/* FIXME: this is unsafe!
+ * :nodoc:
+ */
static VALUE c_delete (VALUE self)
{
GET_OBJ (self, RbEcoreEvas, ee);
@@ -358,31 +626,160 @@ static VALUE c_delete (VALUE self)
rb_gc_start ();
ecore_evas_free (ee->real);
- rb_hash_aset (objects, INT2NUM ((long) ee->real), Qnil);
ee->real = NULL;
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)
{
cEcoreEvas = rb_define_class_under (mEvas, "EcoreEvas", rb_cObject);
- rb_define_private_method (rb_singleton_class (cEcoreEvas),
- "new", NULL, 0);
rb_define_method (cEcoreEvas, "initialize", c_init, -1);
rb_define_method (cEcoreEvas, "inspect", c_inspect, 0);
rb_define_method (cEcoreEvas, "delete", c_delete, 0);
@@ -411,20 +808,23 @@ void Init_EcoreEvas (void)
rb_define_method (cEcoreEvas, "sticky=", c_sticky_set, 1);
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);
-
- objects = rb_hash_new ();
- rb_global_variable (&objects);
+ rb_define_method (cEcoreEvas, "name_class", c_name_class_get, 0);
+ rb_define_method (cEcoreEvas, "name_class=", c_name_class_set, 1);
+ rb_define_method (cEcoreEvas, "iconified?", c_iconified_get, 0);
+ rb_define_method (cEcoreEvas, "iconified=", c_iconified_set, 1);
+ rb_define_method (cEcoreEvas, "has_alpha?", c_has_alpha_get, 0);
+ rb_define_method (cEcoreEvas, "has_alpha=", c_has_alpha_set, 1);
+
+ 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);
}