X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=sidebyside;f=src%2Frb_polygon.c;h=9a8913c116ea010397a0318a67de27958373eebb;hb=5e566ff6dc37ccfdad0571dd34867cbf1cdd8cbc;hp=438fd3aef7c753ae83f992e8abf7511a5e0c9c2d;hpb=0ab509cfd10cd260793e7bd6d00ace66b8085962;p=ruby-evas.git
diff --git a/src/rb_polygon.c b/src/rb_polygon.c
index 438fd3a..9a8913c 100644
--- a/src/rb_polygon.c
+++ b/src/rb_polygon.c
@@ -1,5 +1,5 @@
/*
- * $Id: rb_polygon.c 32 2004-07-10 14:07:49Z tilman $
+ * $Id: rb_polygon.c 58 2004-08-10 14:10:02Z tilman $
*
* Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
*
@@ -26,17 +26,28 @@
#include "rb_evas.h"
#include "rb_evas_object.h"
+static void c_free (RbEvasObject *e)
+{
+ c_evas_object_free (e, true);
+}
+
+/*
+ * call-seq:
+ * Evas::Polygon.new(evas) => polygon
+ *
+ * Creates an new Evas::Polygon object.
+ */
static VALUE c_new (VALUE klass, VALUE evas)
{
VALUE self, argv[1];
- Evas_Object **rect;
+ RbEvasObject *poly;
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, rect);
- *rect = evas_object_polygon_add (*e);
+ self = Data_Make_Struct (klass, RbEvasObject, c_evas_object_mark,
+ c_free, poly);
+ poly->real = evas_object_polygon_add (e->real);
argv[0] = evas;
rb_obj_call_init (self, 1, argv);
@@ -44,33 +55,44 @@ static VALUE c_new (VALUE klass, VALUE evas)
return self;
}
-static VALUE c_point_add (VALUE self, VALUE x, VALUE y)
+/*
+ * call-seq:
+ * polygon.add_point(x, y) => nil
+ *
+ * Adds a point to polygon.
+ */
+static VALUE c_add_point (VALUE self, VALUE x, VALUE y)
{
- GET_OBJ (self, Evas_Object, e);
+ GET_OBJ (self, RbEvasObject, e);
Check_Type (x, T_FIXNUM);
Check_Type (y, T_FIXNUM);
- evas_object_polygon_point_add (*e, FIX2INT (x), FIX2INT (y));
+ evas_object_polygon_point_add (e->real, FIX2INT (x), FIX2INT (y));
return Qnil;
}
-static VALUE c_points_clear (VALUE self)
+/*
+ * call-seq:
+ * polygon.clear_points => nil
+ *
+ * Clears the points of polygon.
+ */
+static VALUE c_clear_points (VALUE self)
{
- GET_OBJ (self, Evas_Object, e);
+ GET_OBJ (self, RbEvasObject, e);
- evas_object_polygon_points_clear (*e);
+ evas_object_polygon_points_clear (e->real);
return Qnil;
}
void Init_Polygon (void)
{
- VALUE cPolygon = rb_define_class_under (mEvas, "Polygon",
- cEvasObject);
+ VALUE c = rb_define_class_under (mEvas, "Polygon", cEvasObject);
- rb_define_singleton_method (cPolygon, "new", c_new, 1);
- rb_define_method (cPolygon, "point_add", c_point_add, 2);
- rb_define_method (cPolygon, "points_clear", c_points_clear, 0);
+ rb_define_singleton_method (c, "new", c_new, 1);
+ rb_define_method (c, "add_point", c_add_point, 2);
+ rb_define_method (c, "clear_points", c_clear_points, 0);
}