X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=sidebyside;f=src%2Frb_evas_object.c;h=6a4c5748588d8b6d62f5ced33c3b6f7236c69d2b;hb=f372062dbc05ab13546a64d0d77026851388bc10;hp=6c0a90f99498f4d6ea7f68c908765de73bd7b3bc;hpb=31278d5bfe44418ddc64610ff049a46990b7a5f8;p=ruby-evas.git
diff --git a/src/rb_evas_object.c b/src/rb_evas_object.c
index 6c0a90f..6a4c574 100644
--- a/src/rb_evas_object.c
+++ b/src/rb_evas_object.c
@@ -1,5 +1,5 @@
/*
- * $Id: rb_evas_object.c 64 2004-08-12 19:37:04Z tilman $
+ * $Id: rb_evas_object.c 105 2004-08-29 15:45:48Z tilman $
*
* Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
*
@@ -30,6 +30,21 @@
VALUE cEvasObject;
+VALUE TO_EVAS_OBJECT (Evas_Object *o)
+{
+ void *obj;
+
+ if (!o)
+ return Qnil;
+
+ if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) {
+ rb_raise (rb_eException, "EvasObject Ruby object key missing");
+ return Qnil;
+ }
+
+ return (VALUE) obj;
+}
+
/* called by the child classes */
void c_evas_object_mark (RbEvasObject *e)
{
@@ -344,6 +359,38 @@ static VALUE c_pass_events_set (VALUE self, VALUE val)
return Qnil;
}
+/*
+ * call-seq:
+ * e.repeat_events? => true or false
+ *
+ * Returns true if e repeats events to EvasObjects that are
+ * below itself, else returns false.
+ */
+static VALUE c_repeat_events_get (VALUE self)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ return evas_object_repeat_events_get (e->real) ? Qtrue : Qfalse;
+}
+
+/*
+ * call-seq:
+ * e.repeat_events(true or false)
+ *
+ * Sets whether e repeats events to EvasObjects that are
+ * below itself.
+ */
+static VALUE c_repeat_events_set (VALUE self, VALUE val)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ CHECK_BOOL (val);
+
+ evas_object_repeat_events_set (e->real, val == Qtrue);
+
+ return Qnil;
+}
+
/*
* call-seq:
* e.raise => nil
@@ -420,19 +467,10 @@ static VALUE c_stack_below (VALUE self, VALUE target)
static VALUE c_above_get (VALUE self)
{
Evas_Object *o;
- void *obj;
GET_OBJ (self, RbEvasObject, e);
- if (!(o = evas_object_above_get (e->real)))
- return Qnil;
-
- if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) {
- rb_raise (rb_eException, "EvasObject Ruby object key missing");
- return Qnil;
- }
-
- return (VALUE) obj;
+ return TO_EVAS_OBJECT (evas_object_above_get (e->real));
}
/*
@@ -445,19 +483,10 @@ static VALUE c_above_get (VALUE self)
static VALUE c_below_get (VALUE self)
{
Evas_Object *o;
- void *obj;
GET_OBJ (self, RbEvasObject, e);
- if (!(o = evas_object_below_get (e->real)))
- return Qnil;
-
- if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) {
- rb_raise (rb_eException, "EvasObject Ruby object key missing");
- return Qnil;
- }
-
- return (VALUE) obj;
+ return TO_EVAS_OBJECT (evas_object_below_get (e->real));
}
void Init_EvasObject (void)
@@ -483,8 +512,14 @@ void Init_EvasObject (void)
rb_define_method (cEvasObject, "layer=", c_layer_set, 1);
rb_define_method (cEvasObject, "get_color", c_get_color, 0);
rb_define_method (cEvasObject, "set_color", c_set_color, 4);
- rb_define_method (cEvasObject, "pass_events?", c_pass_events_get, 0);
- rb_define_method (cEvasObject, "pass_events=", c_pass_events_set, 1);
+ rb_define_method (cEvasObject, "pass_events?",
+ c_pass_events_get, 0);
+ rb_define_method (cEvasObject, "pass_events=",
+ c_pass_events_set, 1);
+ rb_define_method (cEvasObject, "repeat_events?",
+ c_repeat_events_get, 0);
+ rb_define_method (cEvasObject, "repeat_events=",
+ c_repeat_events_set, 1);
rb_define_method (cEvasObject, "raise", c_raise, 0);
rb_define_method (cEvasObject, "lower", c_lower, 0);
rb_define_method (cEvasObject, "stack_above", c_stack_above, 1);