/*
- * $Id$
+ * $Id: rb_esmart_container.c 52 2004-08-01 10:19:14Z tilman $
*
* Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
*
#include <ruby.h>
#include <Esmart/Esmart_Container.h>
-#include <rb_evas.h>
-#include <rb_evas_object.h>
+#include <evas/rb_evas.h>
+#include <evas/rb_evas_object.h>
#include "../rb_esmart.h"
+static void c_free (RbEvasObject *e)
+{
+ c_evas_object_free (e, true);
+}
+
static VALUE c_new (VALUE klass, VALUE evas)
{
VALUE self, argv[1];
- Evas_Object **cont;
+ RbEvasObject *cont;
CHECK_CLASS (evas, cEvas);
- GET_OBJ (evas, Evas *, e);
+ GET_OBJ (evas, RbEvas, e);
- self = Data_Make_Struct (klass, Evas_Object *, c_evas_object_mark,
- c_evas_object_free, cont);
- *cont = esmart_container_new (*e);
+ self = Data_Make_Struct (klass, RbEvasObject, c_evas_object_mark,
+ c_free, cont);
+ cont->real = esmart_container_new (e->real);
argv[0] = evas;
rb_obj_call_init (self, 1, argv);
static VALUE c_element_append (VALUE self, VALUE element)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
CHECK_CLASS (element, cEvasObject);
GET_OBJ (element, Evas_Object *, o);
- esmart_container_element_append (*e, *o);
+ esmart_container_element_append (e->real, *o);
return Qnil;
}
static VALUE c_element_prepend (VALUE self, VALUE element)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
CHECK_CLASS (element, cEvasObject);
GET_OBJ (element, Evas_Object *, o);
- esmart_container_element_prepend (*e, *o);
+ esmart_container_element_prepend (e->real, *o);
return Qnil;
}
static VALUE c_element_remove (VALUE self, VALUE element)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
CHECK_CLASS (element, cEvasObject);
GET_OBJ (element, Evas_Object *, o);
- esmart_container_element_remove (*e, *o);
+ esmart_container_element_remove (e->real, *o);
return Qnil;
}
static VALUE c_direction_get (VALUE self)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
- return INT2FIX (esmart_container_direction_get (*e));
+ return INT2FIX (esmart_container_direction_get (e->real));
}
static VALUE c_direction_set (VALUE self, VALUE val)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
Check_Type (val, T_FIXNUM);
- esmart_container_direction_set (*e, FIX2INT (val));
+ esmart_container_direction_set (e->real, FIX2INT (val));
return Qnil;
}
static VALUE c_spacing_get (VALUE self)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
- return INT2FIX (esmart_container_spacing_get (*e));
+ return INT2FIX (esmart_container_spacing_get (e->real));
}
static VALUE c_spacing_set (VALUE self, VALUE val)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
Check_Type (val, T_FIXNUM);
- esmart_container_spacing_set (*e, FIX2INT (val));
+ esmart_container_spacing_set (e->real, FIX2INT (val));
return Qnil;
}
static VALUE c_fill_policy_get (VALUE self)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
- return INT2FIX (esmart_container_fill_policy_get (*e));
+ return INT2FIX (esmart_container_fill_policy_get (e->real));
}
static VALUE c_fill_policy_set (VALUE self, VALUE val)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
Check_Type (val, T_FIXNUM);
- esmart_container_fill_policy_set (*e, FIX2INT (val));
+ esmart_container_fill_policy_set (e->real, FIX2INT (val));
return Qnil;
}
{
double l = 0, r = 0, t = 0, b = 0;
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
- esmart_container_padding_get (*e, &l, &r, &t, &b);
+ esmart_container_padding_get (e->real, &l, &r, &t, &b);
return rb_ary_new3 (4, rb_float_new (l), rb_float_new (r),
rb_float_new (t), rb_float_new (b));
static VALUE c_set_padding (VALUE self, VALUE l, VALUE r,
VALUE t, VALUE b)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
Check_Type (l, T_FLOAT);
Check_Type (r, T_FLOAT);
Check_Type (t, T_FLOAT);
Check_Type (b, T_FLOAT);
- esmart_container_padding_set (*e, NUM2DBL (l), NUM2DBL (r),
+ esmart_container_padding_set (e->real, NUM2DBL (l), NUM2DBL (r),
NUM2DBL (t), NUM2DBL (b));
return Qnil;
static VALUE c_scroll (VALUE self, VALUE val)
{
- GET_OBJ (self, Evas_Object *, e);
+ GET_OBJ (self, RbEvasObject, e);
Check_Type (val, T_FIXNUM);
- esmart_container_scroll (*e, FIX2INT (val));
+ esmart_container_scroll (e->real, FIX2INT (val));
return Qnil;
}