evas_shutdown() isn't exported anymore.
authorTilman Sauerbeck <tilman@code-monkey.de>
Thu, 8 Jul 2004 18:47:44 +0000 (18:47 +0000)
committerTilman Sauerbeck <tilman@code-monkey.de>
Thu, 8 Jul 2004 18:47:44 +0000 (18:47 +0000)
Evas is inited and shut down automatically now.

src/rb_evas.c
src/rb_evas_main.c
src/rb_evas_object.c

index 3da4ccf678ac4224a79cd0db2b06d3db700f5e66..b6d9887030afa32cfb5e63e0f3e87db637bf41fb 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_evas.c 23 2004-06-26 22:55:31Z tilman $
+ * $Id: rb_evas.c 29 2004-07-08 18:47:44Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -37,6 +37,15 @@ static void c_mark (Evas **e)
                rb_gc_mark (parent);
 }
 
+static void c_free (Evas **e)
+{
+       /* do NOT call evas_free() here, since the Evas is freed
+        * by ecore_evas_free() eventually */
+       rb_hash_aset (parents, INT2NUM ((long) e), Qnil);
+
+       free (e);
+}
+
 VALUE TO_EVAS (VALUE parent, Evas *e)
 {
        VALUE self;
@@ -46,7 +55,7 @@ VALUE TO_EVAS (VALUE parent, Evas *e)
                return Qnil;
 
        self = Data_Make_Struct (cEvas, Evas *,
-                                c_mark, free, my_e);
+                                c_mark, c_free, my_e);
        *my_e = e;
 
        rb_hash_aset (parents, INT2NUM ((long) my_e), parent);
@@ -56,6 +65,18 @@ VALUE TO_EVAS (VALUE parent, Evas *e)
        return self;
 }
 
+static VALUE c_inspect (VALUE self)
+{
+       char buf[128];
+
+       GET_OBJ (self, Evas, e, "Evas");
+
+       snprintf (buf, sizeof (buf), "#<Evas::Evas:%p ptr=%p>",
+                 (void *) self, *e);
+
+       return rb_str_new2 (buf);
+}
+
 static VALUE c_render (VALUE self)
 {
        GET_OBJ (self, Evas, e, "Evas");
@@ -240,6 +261,7 @@ void Init_Evas (void)
        /* not publically instantiable yet */
        rb_define_private_method (rb_singleton_class (cEvas),
                                  "new", NULL, 0);
+       rb_define_method (cEvas, "inspect", c_inspect, 0);
        rb_define_method (cEvas, "render", c_render, 0);
        rb_define_method (cEvas, "font_path_clear", c_font_path_clear, 0);
        rb_define_method (cEvas, "font_path_append", c_font_path_append, 1);
index 2fbb484c44e5067a52b9de329af170c6da4e915a..288408a1340714717f91b3e7617d0acc5af1d2dc 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_evas_main.c 23 2004-06-26 22:55:31Z tilman $
+ * $Id: rb_evas_main.c 29 2004-07-08 18:47:44Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
 #include "rb_image.h"
 #include "rb_text.h"
 
-static VALUE m_shutdown (VALUE self)
+#ifdef DEBUG
+static VALUE m_init (VALUE self)
 {
-       evas_shutdown ();
+       return INT2FIX (evas_init ());
+}
 
-       return Qnil;
+static VALUE m_shutdown (VALUE self)
+{
+       return INT2FIX (evas_shutdown ());
 }
+#endif
 
 void Init_evas (void)
 {
        mEvas = rb_define_module ("Evas");
 
+#ifdef DEBUG
+       rb_define_module_function (mEvas, "init", m_init, 0);
        rb_define_module_function (mEvas, "shutdown", m_shutdown, 0);
+#endif
 
        Init_Evas ();
        Init_EvasObject ();
index ee25e1d3f4bce9d32f823497f0d92d8b9aacfa82..79dc66f7cc5f56d4f0b69bf3252ac5db5eaf52e8 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_evas_object.c 23 2004-06-26 22:55:31Z tilman $
+ * $Id: rb_evas_object.c 29 2004-07-08 18:47:44Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -34,6 +34,8 @@ void c_evas_object_free (Evas_Object **e)
        if (*e)
                evas_object_del (*e);
 
+       rb_hash_aset (parents, INT2NUM ((long) e), Qnil);
+
        free (e);
 }
 
@@ -63,7 +65,7 @@ static VALUE c_inspect (VALUE self)
 
        GET_OBJ (self, Evas_Object, e, "EvasObject");
 
-       snprintf (buf, sizeof (buf), "#<EvasObject:%p ptr=%p>",
+       snprintf (buf, sizeof (buf), "#<Evas::EvasObject:%p ptr=%p>",
                  (void *) self, *e);
 
        return rb_str_new2 (buf);
@@ -73,10 +75,8 @@ static VALUE c_delete (VALUE self)
 {
        GET_OBJ (self, Evas_Object, e, "EvasObject");
 
-       if (*e) {
-               evas_object_del (*e);
-               *e = NULL;
-       }
+       evas_object_del (*e);
+       *e = NULL;
 
        return Qnil;
 }