X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=sidebyside;f=src%2Frb_evas_object.c;h=b37d66d650d41f60f0351ffd01631fb495037936;hb=9ee77c744d2cb8d6d215aab112ff2d77eb8464fd;hp=e465bfc4dc7520de75937680ad3e8310491ced2f;hpb=1f6059ba8be27832fc4b6f88c99548e39f4264cb;p=ruby-evas.git
diff --git a/src/rb_evas_object.c b/src/rb_evas_object.c
index e465bfc..b37d66d 100644
--- a/src/rb_evas_object.c
+++ b/src/rb_evas_object.c
@@ -1,5 +1,5 @@
/*
- * $Id: rb_evas_object.c 58 2004-08-10 14:10:02Z tilman $
+ * $Id: rb_evas_object.c 382 2006-05-25 09:20:31Z tilman $
*
* Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
*
@@ -30,10 +30,31 @@
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)
{
rb_gc_mark (e->parent);
+
+ if (!NIL_P (e->callbacks))
+ rb_gc_mark (e->callbacks);
+
+ if (!NIL_P (e->userdata))
+ rb_gc_mark (e->userdata);
}
void c_evas_object_free (RbEvasObject *e, bool free_mem)
@@ -45,6 +66,19 @@ void c_evas_object_free (RbEvasObject *e, bool free_mem)
free (e);
}
+static void c_free (RbEvasObject *e)
+{
+ c_evas_object_free (e, true);
+}
+
+static VALUE c_alloc (VALUE klass)
+{
+ RbEvasObject *e;
+
+ return Data_Make_Struct (klass, RbEvasObject, c_evas_object_mark,
+ c_free, e);
+}
+
/* :nodoc: */
static VALUE c_init (VALUE self, VALUE parent)
{
@@ -53,6 +87,7 @@ static VALUE c_init (VALUE self, VALUE parent)
evas_object_data_set (e->real, RUBY_EVAS_OBJECT_KEY, (void *) self);
e->parent = parent;
+ e->callbacks = Qnil;
return self;
}
@@ -63,6 +98,17 @@ static VALUE c_inspect (VALUE self)
INSPECT (self, RbEvasObject);
}
+static VALUE c_type_get (VALUE self)
+{
+ const char *s;
+
+ GET_OBJ (self, RbEvasObject, e);
+
+ s = evas_object_type_get (e->real);
+
+ return s ? rb_str_new2 (s) : Qnil;
+}
+
/*
* call-seq:
* e.delete => nil
@@ -180,7 +226,7 @@ static VALUE c_hide (VALUE self)
* call-seq:
* e.visible? => true or false
*
- * Returns true if e is visible, else false.
+ * Returns true if e is visible, else returns false.
*/
static VALUE c_visible_get (VALUE self)
{
@@ -189,6 +235,36 @@ static VALUE c_visible_get (VALUE self)
return evas_object_visible_get (e->real) ? Qtrue : Qfalse;
}
+/*
+ * call-seq:
+ * e.focused? => true or false
+ *
+ * Returns true if e is focused, else returns false.
+ */
+static VALUE c_focused_get (VALUE self)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ return evas_object_focus_get (e->real) ? Qtrue : Qfalse;
+}
+
+/*
+ * call-seq:
+ * e.focused(true or false)
+ *
+ * (Un)focuses e.
+ */
+static VALUE c_focused_set (VALUE self, VALUE val)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ CHECK_BOOL (val);
+
+ evas_object_focus_set (e->real, val == Qtrue);
+
+ return Qnil;
+}
+
/*
* call-seq:
* e.evas => evas
@@ -230,8 +306,6 @@ static VALUE c_name_set (VALUE self, VALUE val)
{
GET_OBJ (self, RbEvasObject, e);
- Check_Type (val, T_STRING);
-
evas_object_name_set (e->real, StringValuePtr (val));
return Qnil;
@@ -312,12 +386,29 @@ static VALUE c_set_color (VALUE self, VALUE r, VALUE g, VALUE b,
return Qnil;
}
+static VALUE c_get_clip (VALUE self)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ return TO_EVAS_OBJECT (evas_object_clip_get (e->real));
+}
+
+static VALUE c_set_clip (VALUE self, VALUE clip)
+{
+ GET_OBJ (self, RbEvasObject, e);
+ GET_OBJ (clip, RbEvasObject, e2);
+
+ evas_object_clip_set (e->real, e2->real);
+
+ return Qnil;
+}
+
/*
* call-seq:
* e.pass_events? => true or false
*
* Returns true if e passes events on to EvasObjects that are
- * below itself, else false.
+ * below itself, else returns false.
*/
static VALUE c_pass_events_get (VALUE self)
{
@@ -344,6 +435,56 @@ 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;
+}
+
+static VALUE c_anti_alias_get (VALUE self)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ return evas_object_anti_alias_get (e->real) ? Qtrue : Qfalse;
+}
+
+static VALUE c_anti_alias_set (VALUE self, VALUE val)
+{
+ GET_OBJ (self, RbEvasObject, e);
+
+ CHECK_BOOL (val);
+
+ evas_object_anti_alias_set (e->real, val == Qtrue);
+
+ return Qnil;
+}
+
/*
* call-seq:
* e.raise => nil
@@ -419,20 +560,9 @@ 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));
}
/*
@@ -444,20 +574,19 @@ 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;
+ return TO_EVAS_OBJECT (evas_object_below_get (e->real));
+}
- if (!(obj = evas_object_data_get (o, RUBY_EVAS_OBJECT_KEY))) {
- rb_raise (rb_eException, "EvasObject Ruby object key missing");
- return Qnil;
- }
+static VALUE c_userdata_get (VALUE self)
+{
+ GET_OBJ (self, RbEvasObject, e);
- return (VALUE) obj;
+ if (NIL_P (e->userdata))
+ e->userdata = rb_hash_new ();
+
+ return e->userdata;
}
void Init_EvasObject (void)
@@ -465,10 +594,10 @@ void Init_EvasObject (void)
cEvasObject = rb_define_class_under (mEvas, "EvasObject",
rb_cObject);
- rb_define_private_method (rb_singleton_class (cEvasObject),
- "new", NULL, 0);
+ rb_define_alloc_func (cEvasObject, c_alloc);
rb_define_method (cEvasObject, "initialize", c_init, 1);
rb_define_method (cEvasObject, "inspect", c_inspect, 0);
+ rb_define_method (cEvasObject, "type", c_type_get, 0);
rb_define_method (cEvasObject, "delete", c_delete, 0);
rb_define_method (cEvasObject, "resize", c_resize, 2);
rb_define_method (cEvasObject, "move", c_move, 2);
@@ -476,6 +605,8 @@ void Init_EvasObject (void)
rb_define_method (cEvasObject, "show", c_show, 0);
rb_define_method (cEvasObject, "hide", c_hide, 0);
rb_define_method (cEvasObject, "visible?", c_visible_get, 0);
+ rb_define_method (cEvasObject, "focused?", c_focused_get, 0);
+ rb_define_method (cEvasObject, "focused=", c_focused_set, 1);
rb_define_method (cEvasObject, "evas", c_evas_get, 0);
rb_define_method (cEvasObject, "name", c_name_get, 0);
rb_define_method (cEvasObject, "name=", c_name_set, 1);
@@ -483,12 +614,23 @@ 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, "clip", c_get_clip, 0);
+ rb_define_method (cEvasObject, "clip=", c_set_clip, 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, "anti_alias?", c_anti_alias_get, 0);
+ rb_define_method (cEvasObject, "anti_alias=", c_anti_alias_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);
rb_define_method (cEvasObject, "stack_below", c_stack_below, 1);
rb_define_method (cEvasObject, "above", c_above_get, 0);
rb_define_method (cEvasObject, "below", c_below_get, 0);
+ rb_define_method (cEvasObject, "userdata", c_userdata_get, 0);
}