Macro updates.
[ruby-ecore.git] / src / ecore_evas / rb_software_x11.c
index eae769ff56fb6e56a09ac1be835d22f75531ba3c..d61c66fd95f5b916d160cc48e592a7a30f3745ce 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_software_x11.c 15 2004-06-20 13:23:07Z tilman $
+ * $Id: rb_software_x11.c 27 2004-07-08 18:25:05Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
 
 #include <ruby.h>
 
+#include <Ecore.h>
 #include <Ecore_Evas.h>
 
 #include "rb_ecore_evas_main.h"
 #include "rb_ecore_evas.h"
 
-VALUE cSoftwareX11;
-
-static VALUE c_init (int argc, VALUE *argv, VALUE self)
+static VALUE c_new (int argc, VALUE *argv, VALUE klass)
 {
-       VALUE disp, parent, geom[4];
+       VALUE self, disp, parent, geom[4];
        Ecore_Evas **ee = NULL;
        char *cdisp = NULL;
-       int i, igeom[4] = {0};
+       int i, igeom[4] = {0, 0, 0, 0};
 
-       Data_Get_Struct (self, Ecore_Evas *, ee);
+       self = Data_Make_Struct (klass, Ecore_Evas *,
+                                NULL, c_ecore_evas_free, ee);
 
        rb_scan_args (argc, argv, "06", &disp, &parent,
                      &geom[0], &geom[1], &geom[2], &geom[3]);
@@ -50,33 +50,23 @@ static VALUE c_init (int argc, VALUE *argv, VALUE self)
                        igeom[i] = NUM2INT (geom[i]);
                }
 
+       ecore_init ();
+       ecore_evas_init ();
+
        *ee = ecore_evas_software_x11_new (cdisp, 0,
                                           igeom[0], igeom[1],
                                           igeom[2], igeom[3]);
 
-       return self;
-}
-
-static VALUE c_new (int argc, VALUE *argv, VALUE klass)
-{
-       VALUE self;
-       Ecore_Evas **ee;
-
-       self = Data_Make_Struct (klass, Ecore_Evas *,
-                                NULL, c_ecore_evas_free, ee);
-
-       rb_obj_call_init (self, argc, argv);
+       rb_obj_call_init (self, 0, NULL);
 
        return self;
 }
 
 void Init_SoftwareX11 (void)
 {
-       cSoftwareX11 = rb_define_class_under (mEvas,
-                                             "SoftwareX11",
-                                             cEcoreEvas);
+       VALUE cSoftwareX11 = rb_define_class_under (mEvas,
+                                                   "SoftwareX11",
+                                                   cEcoreEvas);
 
        rb_define_singleton_method (cSoftwareX11, "new", c_new, -1);
-       rb_define_method (cSoftwareX11, "initialize", c_init, -1);
 }
-