projects
/
ruby-evas.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
bacd52d
)
Updated for new smart object API.
master
author
Tilman Sauerbeck
<tilman@code-monkey.de>
Mon, 27 Aug 2007 17:48:12 +0000
(19:48 +0200)
committer
Tilman Sauerbeck
<tilman@code-monkey.de>
Mon, 27 Aug 2007 17:48:12 +0000
(19:48 +0200)
src/rb_smart.c
patch
|
blob
|
history
diff --git
a/src/rb_smart.c
b/src/rb_smart.c
index 4c036afbb25324eb9c22f7c58161106666447f90..b6ea30416db1153d5fad3fd53617f0d6d9bbde84 100644
(file)
--- a/
src/rb_smart.c
+++ b/
src/rb_smart.c
@@
-55,7
+55,14
@@
rb_funcall (self, id, 2, INT2FIX ((int) a), INT2FIX ((int) b)); \
}
rb_funcall (self, id, 2, INT2FIX ((int) a), INT2FIX ((int) b)); \
}
-static ID id_smart_object;
+typedef struct {
+ Evas_Smart_Class smart_class;
+ Evas_Smart *smart;
+
+ VALUE name;
+} SmartData;
+
+static ID id_smart_data;
SMART_CB (delete);
SMART_CB (show);
SMART_CB (delete);
SMART_CB (show);
@@
-75,15
+82,21
@@
static void smart_color_set (Evas_Object *o, int r, int g, int b, int a)
static VALUE c_inherited (VALUE klass, VALUE child)
{
static VALUE c_inherited (VALUE klass, VALUE child)
{
- rb_const_set (child, id_smart_
object
, Qnil);
+ rb_const_set (child, id_smart_
data
, Qnil);
return Qnil;
}
return Qnil;
}
+static void
+c_data_mark (SmartData *sd)
+{
+ rb_gc_mark (sd->name);
+}
+
static VALUE c_init (VALUE self, VALUE evas)
{
static VALUE c_init (VALUE self, VALUE evas)
{
- VALUE klass,
smart, name
;
-
Evas_Smart **s = NULL
;
+ VALUE klass,
data
;
+
SmartData *sd
;
CHECK_CLASS (evas, cEvas);
GET_OBJ (evas, RbEvas, e);
CHECK_CLASS (evas, cEvas);
GET_OBJ (evas, RbEvas, e);
@@
-92,28
+105,35
@@
static VALUE c_init (VALUE self, VALUE evas)
klass = rb_obj_class (self);
/* check whether the smart object has been created already */
klass = rb_obj_class (self);
/* check whether the smart object has been created already */
-
smart = rb_const_get (klass, id_smart_object
);
- if (!NIL_P (
smart
))
- Data_Get_Struct (
smart, Evas_Smart *, s
);
+
data = rb_const_get (klass, id_smart_data
);
+ if (!NIL_P (
data
))
+ Data_Get_Struct (
data, SmartData, sd
);
else {
else {
- name = rb_class_path (klass);
+ data = Data_Make_Struct (rb_cObject, SmartData,
+ c_data_mark, NULL, sd);
+
+ sd->name = rb_class_path (klass);
+
+ sd->smart_class.name = StringValuePtr (sd->name);
+ sd->smart_class.version = EVAS_SMART_CLASS_VERSION;
- smart = Data_Make_Struct (rb_cObject, Evas_Smart *, NULL, NULL, s);
+ sd->smart_class.add = NULL;
+ sd->smart_class.del = smart_delete;
+ sd->smart_class.move = smart_move;
+ sd->smart_class.resize = smart_resize;
+ sd->smart_class.show = smart_show;
+ sd->smart_class.hide = smart_hide;
+ sd->smart_class.color_set = smart_color_set;
+ sd->smart_class.clip_set = smart_clip_set;
+ sd->smart_class.clip_unset = smart_clip_unset;
- *s = evas_smart_new (StringValuePtr (name),
- NULL, smart_delete, NULL,
- NULL, NULL, NULL, NULL,
- smart_move, smart_resize,
- smart_show, smart_hide,
- smart_color_set,
- smart_clip_set, smart_clip_unset,
- NULL);
+ sd->smart = evas_smart_class_new (&sd->smart_class);
- rb_mod_remove_const
(klass, ID2SYM (id_smart_object
));
- rb_const_set (klass, id_smart_
object, smart
);
+ rb_mod_remove_const
(klass, ID2SYM (id_smart_data
));
+ rb_const_set (klass, id_smart_
data, data
);
}
}
- s2->real = evas_object_smart_add (e->real,
*s
);
+ s2->real = evas_object_smart_add (e->real,
sd->smart
);
rb_call_super (1, &evas);
rb_call_super (1, &evas);
@@
-139,5
+159,5
@@
void Init_Smart (void)
rb_define_method (c, "initialize", c_init, 1);
rb_define_method (c, "add_member", c_add_member, 1);
rb_define_method (c, "initialize", c_init, 1);
rb_define_method (c, "add_member", c_add_member, 1);
- id_smart_
object = rb_intern ("SMART_OBJECT
");
+ id_smart_
data = rb_intern ("SMART_DATA
");
}
}