Added EvasObject#userdata.
authorTilman Sauerbeck <tilman@code-monkey.de>
Tue, 22 Mar 2005 17:51:51 +0000 (17:51 +0000)
committerTilman Sauerbeck <tilman@code-monkey.de>
Tue, 22 Mar 2005 17:51:51 +0000 (17:51 +0000)
src/rb_evas_object.c
src/rb_evas_object.h

index c2d39af4f9c7661dd90e69a6638e98f80620cdf6..6e93a8fe3bec6fc5eaae14243988e7d918171d40 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_evas_object.c 302 2005-03-22 17:41:35Z tilman $
+ * $Id: rb_evas_object.c 304 2005-03-22 17:51:51Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -52,6 +52,9 @@ void c_evas_object_mark (RbEvasObject *e)
 
        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)
@@ -489,6 +492,16 @@ static VALUE c_below_get (VALUE self)
        return TO_EVAS_OBJECT (evas_object_below_get (e->real));
 }
 
+static VALUE c_userdata_get (VALUE self)
+{
+       GET_OBJ (self, RbEvasObject, e);
+
+       if (NIL_P (e->userdata))
+               e->userdata = rb_hash_new ();
+
+       return e->userdata;
+}
+
 void Init_EvasObject (void)
 {
        cEvasObject = rb_define_class_under (mEvas, "EvasObject",
@@ -526,4 +539,5 @@ void Init_EvasObject (void)
        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);
 }
index ae60574bea8915b3d7d7efe66768872703040914..99e0743dd684a5203209770ddb740bd9b7d36769 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_evas_object.h 281 2005-03-14 20:51:40Z tilman $
+ * $Id: rb_evas_object.h 304 2005-03-22 17:51:51Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -29,6 +29,7 @@ typedef struct {
        Evas_Object *real;
        VALUE parent;
        VALUE callbacks;
+       VALUE userdata;
 } RbEvasObject;
 
 void Init_EvasObject (void);