Macro tweaks.
authorTilman Sauerbeck <tilman@code-monkey.de>
Sun, 25 Jul 2004 13:14:34 +0000 (13:14 +0000)
committerTilman Sauerbeck <tilman@code-monkey.de>
Sun, 25 Jul 2004 13:14:34 +0000 (13:14 +0000)
src/ecore/rb_ecore.h
src/ecore/rb_idler.c
src/ecore/rb_timer.c
src/ecore_evas/Makefile.am
src/ecore_evas/rb_ecore_evas.c
src/ecore_evas/rb_fb.c
src/ecore_evas/rb_gl_x11.c
src/ecore_evas/rb_software_x11.c
src/ecore_job/rb_job.c

index 8ce543209993ed987bdb79e57039bc4da12eb802..115aca81efc4fa0f133df4d2496b425f970d15f5 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_ecore.h 9 2004-06-19 19:53:47Z tilman $
+ * $Id: rb_ecore.h 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
 #ifndef __RB_ECORE_H
 #define __RB_ECORE_H
 
+#define GET_OBJ(obj, type, o) \
+       type *(o) = NULL; \
+\
+       Data_Get_Struct ((obj), type, (o)); \
+\
+       if (!*(o)) { \
+               rb_raise (rb_eException, \
+                         "%s destroyed already", \
+                         rb_obj_classname ((obj))); \
+               return Qnil; \
+       }
+
+#define CHECK_BOOL(val) \
+       if (TYPE ((val)) != T_TRUE && TYPE ((val)) != T_FALSE) { \
+               rb_raise (rb_eTypeError, \
+                         "wrong argument type %s (expected true or false)", \
+                         rb_obj_classname ((val))); \
+               return Qnil; \
+       }
+
+#define INSPECT(obj, type) \
+       char buf[128]; \
+\
+       GET_OBJ (obj, type, o); \
+\
+       snprintf (buf, sizeof (buf), \
+                 "#<%s:%p ptr=%p>", rb_obj_classname ((obj)), \
+                 (void *) obj, *o); \
+\
+       return rb_str_new2 (buf);
+
 VALUE mEcore;
 
 #endif
index 414b6fb85395c625f6a0913d833a9cf2997d0259..ce6bc03817828da9f55585eb9517ad22adfa1b72 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_idler.c 27 2004-07-08 18:25:05Z tilman $
+ * $Id: rb_idler.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -31,8 +31,6 @@ typedef struct {
        bool deleted;
 } RbEcoreIdler;
 
-static VALUE cIdler;
-
 static int on_idler (void *data)
 {
        VALUE r;
@@ -97,9 +95,8 @@ static VALUE c_delete (VALUE self)
 
 void Init_Idler (void)
 {
-       cIdler = rb_define_class_under (mEcore, "Idler", rb_cObject);
+       VALUE c = rb_define_class_under (mEcore, "Idler", rb_cObject);
 
-       rb_define_singleton_method (cIdler, "new", c_new, 1);
-       rb_define_method (cIdler, "delete", c_delete, 0);
+       rb_define_singleton_method (c, "new", c_new, 1);
+       rb_define_method (c, "delete", c_delete, 0);
 }
-
index 315a65a56e4e0a3d9d38a6ec6d039f30ad049dd8..543a5415f6dcc2c3ad2a423dce81ec361b8d04b1 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_timer.c 27 2004-07-08 18:25:05Z tilman $
+ * $Id: rb_timer.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -31,8 +31,6 @@ typedef struct {
        bool deleted;
 } RbEcoreTimer;
 
-static VALUE cTimer;
-
 static int on_timer (void *data)
 {
        VALUE r;
@@ -98,9 +96,8 @@ static VALUE c_delete (VALUE self)
 
 void Init_Timer (void)
 {
-       cTimer = rb_define_class_under (mEcore, "Timer", rb_cObject);
+       VALUE c = rb_define_class_under (mEcore, "Timer", rb_cObject);
 
-       rb_define_singleton_method (cTimer, "new", c_new, 1);
-       rb_define_method (cTimer, "delete", c_delete, 0);
+       rb_define_singleton_method (c, "new", c_new, 1);
+       rb_define_method (c, "delete", c_delete, 0);
 }
-
index f9687ae40ff04de07e5427c0b9928b04ade25f53..9b4b71a32c1ef4fb48f6414c7b4a6aa936ed3b29 100644 (file)
@@ -1,4 +1,4 @@
-## $Id: Makefile.am 22 2004-06-26 16:43:41Z tilman $
+## $Id: Makefile.am 40 2004-07-25 13:14:34Z tilman $
 
 AM_CFLAGS = $(ECORE_CFLAGS) $(EVAS_CFLAGS)
 INCLUDES = -I$(RUBYDIR) -I$(RUBYSITEDIR)
@@ -14,3 +14,6 @@ ecore_evas_la_SOURCES = rb_ecore_evas_main.c rb_ecore_evas_main.h \
 
 ecore_evas_la_LIBADD = -lruby $(ECORE_LIBS) $(EVAS_LIBS)
 ecore_evas_la_LDFLAGS = -module -avoid-version
+
+pkgincludedir = $(RUBYSITEDIR)
+pkginclude_HEADERS = rb_ecore_evas.h
index 7c78a267426b68de74a7acb0f45120703d923c6a..e59b2b9a406ef4e0c1a6fee98fa73aeee2fa3798 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_ecore_evas.c 30 2004-07-10 14:05:30Z tilman $
+ * $Id: rb_ecore_evas.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
 #include <Ecore_Evas.h>
 #include <rb_evas.h>
 
+#include "../ecore/rb_ecore.h"
 #include "rb_ecore_evas_main.h"
 #include "rb_ecore_evas.h"
 
-#define GET_OBJ(obj, type, o) \
-       type **(o) = NULL; \
+#define CALLBACK_ADD_HANDLER(name) \
+       static void on_##name (Ecore_Evas *ee) \
+       { \
+               VALUE self = rb_hash_aref (objects, INT2NUM ((long) ee)); \
+               VALUE hash = rb_hash_aref (callbacks, self); \
 \
-       Data_Get_Struct ((obj), type *, (o)); \
+               rb_funcall (rb_hash_aref (hash, rb_str_new2 (#name)), \
+                           rb_intern ("call"), 0); \
+       } \
 \
-       if (!*(o)) { \
-               rb_raise (rb_eException, \
-                         "%s destroyed already", \
-                         rb_obj_classname ((obj))); \
-               return Qnil; \
-       }
-
-#define CHECK_BOOL(val) \
-       if (TYPE ((val)) != T_TRUE && TYPE ((val)) != T_FALSE) { \
-               rb_raise (rb_eTypeError, \
-                         "wrong argument type %s (expected true or false)", \
-                         rb_obj_classname ((val))); \
-               return Qnil; \
-       }
-
-#define INSPECT(obj, type) \
-       char buf[128]; \
+       static VALUE c_on_##name (VALUE self) \
+       { \
+               VALUE hash; \
+\
+               GET_OBJ (self, Ecore_Evas *, ee); \
+\
+               if (!rb_block_given_p ()) \
+                       return Qnil; \
 \
-       GET_OBJ (obj, type, o); \
+               if (NIL_P ((hash = rb_hash_aref (callbacks, self)))) { \
+                       hash = rb_hash_new (); \
 \
-       snprintf (buf, sizeof (buf), \
-                 "#<%s:%p ptr=%p>", rb_obj_classname ((obj)), \
-                 (void *) obj, *o); \
+                       rb_global_variable (&hash); \
+                       rb_hash_aset (callbacks, self, hash); \
+               } \
 \
-       return rb_str_new2 (buf);
+               rb_hash_aset (hash, rb_str_new2 (#name), rb_block_proc ()); \
+\
+               ecore_evas_callback_##name##_set (*ee, on_##name); \
+\
+               return Qnil; \
+       }
 
-static VALUE evases;
+#define CALLBACK_ADD(mod, name) \
+       rb_define_method ((mod), "on_"#name, c_on_##name, 0);
+
+static VALUE evases, callbacks, objects;
 
 /* called by the child classes */
 void c_ecore_evas_free (Ecore_Evas **ee)
 {
-       if (*ee)
+       if (*ee) {
+               rb_hash_aset (objects, INT2NUM ((long) *ee), Qnil);
                ecore_evas_free (*ee);
+       }
 
        rb_hash_aset (evases, INT2NUM ((long) ee), Qnil);
 
@@ -74,14 +82,25 @@ void c_ecore_evas_free (Ecore_Evas **ee)
        free (ee);
 }
 
+static VALUE c_initialize (int argc, VALUE *argv, VALUE self)
+{
+       Ecore_Evas **ee = NULL;
+
+       Data_Get_Struct (self, Ecore_Evas *, ee);
+
+       rb_hash_aset (objects, INT2NUM ((long) *ee), self);
+
+       return Qnil;
+}
+
 static VALUE c_inspect (VALUE self)
 {
-       INSPECT (self, Ecore_Evas);
+       INSPECT (self, Ecore_Evas *);
 }
 
 static VALUE c_show (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        ecore_evas_show (*ee);
 
@@ -90,7 +109,7 @@ static VALUE c_show (VALUE self)
 
 static VALUE c_hide (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        ecore_evas_hide (*ee);
 
@@ -99,14 +118,14 @@ static VALUE c_hide (VALUE self)
 
 static VALUE c_visible_get (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        return ecore_evas_visibility_get (*ee) ? Qtrue : Qfalse;
 }
 
 static VALUE c_raise (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        ecore_evas_raise (*ee);
 
@@ -115,7 +134,7 @@ static VALUE c_raise (VALUE self)
 
 static VALUE c_lower (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        ecore_evas_lower (*ee);
 
@@ -124,14 +143,14 @@ static VALUE c_lower (VALUE self)
 
 static VALUE c_layer_get (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        return INT2FIX (ecore_evas_layer_get (*ee));
 }
 
 static VALUE c_layer_set (VALUE self, VALUE val)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (val, T_FIXNUM);
 
@@ -140,11 +159,11 @@ static VALUE c_layer_set (VALUE self, VALUE val)
        return Qnil;
 }
 
-static VALUE c_evas (VALUE self)
+static VALUE c_evas_get (VALUE self)
 {
        VALUE evas;
 
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        if (NIL_P (evas = rb_hash_aref (evases, INT2NUM ((long) (ee))))) {
                evas = TO_EVAS (self, ecore_evas_get (*ee));
@@ -154,11 +173,23 @@ static VALUE c_evas (VALUE self)
        return evas;
 }
 
+static VALUE c_geometry_get (VALUE self)
+{
+       int x = 0, y = 0, w = 0, h = 0;
+
+       GET_OBJ (self, Ecore_Evas *, ee);
+
+       ecore_evas_geometry_get (*ee, &x, &y, &w, &h);
+
+       return rb_ary_new3 (4, INT2FIX (x), INT2FIX (y),
+                           INT2FIX (w), INT2FIX (h));
+}
+
 static VALUE c_get_size_min (VALUE self)
 {
        int w = 0, h = 0;
 
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        ecore_evas_size_min_get (*ee, &w, &h);
 
@@ -167,7 +198,7 @@ static VALUE c_get_size_min (VALUE self)
 
 static VALUE c_set_size_min (VALUE self, VALUE w, VALUE h)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (w, T_FIXNUM);
        Check_Type (h, T_FIXNUM);
@@ -181,7 +212,7 @@ static VALUE c_get_size_max (VALUE self)
 {
        int w = 0, h = 0;
 
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        ecore_evas_size_max_get (*ee, &w, &h);
 
@@ -190,7 +221,7 @@ static VALUE c_get_size_max (VALUE self)
 
 static VALUE c_set_size_max (VALUE self, VALUE w, VALUE h)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (w, T_FIXNUM);
        Check_Type (h, T_FIXNUM);
@@ -202,7 +233,7 @@ static VALUE c_set_size_max (VALUE self, VALUE w, VALUE h)
 
 static VALUE c_move (VALUE self, VALUE x, VALUE y)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (x, T_FIXNUM);
        Check_Type (y, T_FIXNUM);
@@ -214,7 +245,7 @@ static VALUE c_move (VALUE self, VALUE x, VALUE y)
 
 static VALUE c_resize (VALUE self, VALUE w, VALUE h)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (w, T_FIXNUM);
        Check_Type (h, T_FIXNUM);
@@ -228,7 +259,7 @@ static VALUE c_title_get (VALUE self)
 {
        const char *tmp;
 
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        if (!(tmp = ecore_evas_title_get (*ee)))
                return Qnil;
@@ -238,7 +269,7 @@ static VALUE c_title_get (VALUE self)
 
 static VALUE c_title_set (VALUE self, VALUE val)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (val, T_STRING);
 
@@ -249,14 +280,14 @@ static VALUE c_title_set (VALUE self, VALUE val)
 
 static VALUE c_borderless_get (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        return ecore_evas_borderless_get (*ee) ? Qtrue : Qfalse;
 }
 
 static VALUE c_borderless_set (VALUE self, VALUE val)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        CHECK_BOOL (val);
 
@@ -267,14 +298,14 @@ static VALUE c_borderless_set (VALUE self, VALUE val)
 
 static VALUE c_shaped_get (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        return ecore_evas_shaped_get (*ee) ? Qtrue : Qfalse;
 }
 
 static VALUE c_shaped_set (VALUE self, VALUE val)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        CHECK_BOOL (val);
 
@@ -285,14 +316,14 @@ static VALUE c_shaped_set (VALUE self, VALUE val)
 
 static VALUE c_sticky_get (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        return ecore_evas_sticky_get (*ee) ? Qtrue : Qfalse;
 }
 
 static VALUE c_sticky_set (VALUE self, VALUE val)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        CHECK_BOOL (val);
 
@@ -303,14 +334,14 @@ static VALUE c_sticky_set (VALUE self, VALUE val)
 
 static VALUE c_rotation_get (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        return INT2FIX (ecore_evas_rotation_get (*ee));
 }
 
 static VALUE c_rotation_set (VALUE self, VALUE val)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        Check_Type (val, T_FIXNUM);
 
@@ -319,25 +350,41 @@ static VALUE c_rotation_set (VALUE self, VALUE val)
        return Qnil;
 }
 
+/* FIXME: this is unsafe! */
 static VALUE c_delete (VALUE self)
 {
-       GET_OBJ (self, Ecore_Evas, ee);
+       GET_OBJ (self, Ecore_Evas *, ee);
 
        /* reap our children */
        rb_gc_start ();
 
        ecore_evas_free (*ee);
+       rb_hash_aset (objects, INT2NUM ((long) *ee), Qnil);
        *ee = NULL;
 
        return Qnil;
 }
 
+CALLBACK_ADD_HANDLER (resize);
+CALLBACK_ADD_HANDLER (move);
+CALLBACK_ADD_HANDLER (show);
+CALLBACK_ADD_HANDLER (hide);
+CALLBACK_ADD_HANDLER (delete_request);
+CALLBACK_ADD_HANDLER (destroy);
+CALLBACK_ADD_HANDLER (focus_in);
+CALLBACK_ADD_HANDLER (focus_out);
+CALLBACK_ADD_HANDLER (mouse_in);
+CALLBACK_ADD_HANDLER (mouse_out);
+CALLBACK_ADD_HANDLER (pre_render);
+CALLBACK_ADD_HANDLER (post_render);
+
 void Init_EcoreEvas (void)
 {
        cEcoreEvas = rb_define_class_under (mEvas, "EcoreEvas", rb_cObject);
 
        rb_define_private_method (rb_singleton_class (cEcoreEvas),
                                  "new", NULL, 0);
+       rb_define_method (cEcoreEvas, "initialize", c_initialize, -1);
        rb_define_method (cEcoreEvas, "inspect", c_inspect, 0);
        rb_define_method (cEcoreEvas, "delete", c_delete, 0);
        rb_define_method (cEcoreEvas, "show", c_show, 0);
@@ -347,7 +394,8 @@ void Init_EcoreEvas (void)
        rb_define_method (cEcoreEvas, "lower", c_lower, 0);
        rb_define_method (cEcoreEvas, "layer", c_layer_get, 0);
        rb_define_method (cEcoreEvas, "layer=", c_layer_set, 1);
-       rb_define_method (cEcoreEvas, "evas", c_evas, 0);
+       rb_define_method (cEcoreEvas, "evas", c_evas_get, 0);
+       rb_define_method (cEcoreEvas, "geometry", c_geometry_get, 0);
        rb_define_method (cEcoreEvas, "get_size_min", c_get_size_min, 0);
        rb_define_method (cEcoreEvas, "set_size_min", c_set_size_min, 2);
        rb_define_method (cEcoreEvas, "get_size_max", c_get_size_max, 0);
@@ -365,6 +413,25 @@ void Init_EcoreEvas (void)
        rb_define_method (cEcoreEvas, "rotation", c_rotation_get, 0);
        rb_define_method (cEcoreEvas, "rotation=", c_rotation_set, 1);
 
+       CALLBACK_ADD (cEcoreEvas, resize);
+       CALLBACK_ADD (cEcoreEvas, move);
+       CALLBACK_ADD (cEcoreEvas, show);
+       CALLBACK_ADD (cEcoreEvas, hide);
+       CALLBACK_ADD (cEcoreEvas, delete_request);
+       CALLBACK_ADD (cEcoreEvas, destroy);
+       CALLBACK_ADD (cEcoreEvas, focus_in);
+       CALLBACK_ADD (cEcoreEvas, focus_out);
+       CALLBACK_ADD (cEcoreEvas, mouse_in);
+       CALLBACK_ADD (cEcoreEvas, mouse_out);
+       CALLBACK_ADD (cEcoreEvas, pre_render);
+       CALLBACK_ADD (cEcoreEvas, post_render);
+
        evases = rb_hash_new ();
        rb_global_variable (&evases);
+
+       objects = rb_hash_new ();
+       rb_global_variable (&objects);
+
+       callbacks = rb_hash_new ();
+       rb_global_variable (&callbacks);
 }
index b5c262b7484a9883fe23236ca22e35c0e8e971e3..8359ef2b6a943eba3582f7a96ad149f6b86ec984 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_fb.c 27 2004-07-08 18:25:05Z tilman $
+ * $Id: rb_fb.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -70,7 +70,7 @@ static VALUE c_new (int argc, VALUE *argv, VALUE klass)
 
 void Init_Fb (void)
 {
-       VALUE cFb = rb_define_class_under (mEvas, "Fb", cEcoreEvas);
+       VALUE c = rb_define_class_under (mEvas, "Fb", cEcoreEvas);
 
-       rb_define_singleton_method (cFb, "new", c_new, -1);
+       rb_define_singleton_method (c, "new", c_new, -1);
 }
index de65a7313ff8884eab6c36ef54da730bb28b7e3f..274230e4cb01bfcf8ac9500071e7b8b8dafa744d 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_gl_x11.c 27 2004-07-08 18:25:05Z tilman $
+ * $Id: rb_gl_x11.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -64,7 +64,7 @@ static VALUE c_new (int argc, VALUE *argv, VALUE klass)
 
 void Init_GlX11 (void)
 {
-       VALUE cGlX11 = rb_define_class_under (mEvas, "GlX11", cEcoreEvas);
+       VALUE c = rb_define_class_under (mEvas, "GlX11", cEcoreEvas);
 
-       rb_define_singleton_method (cGlX11, "new", c_new, -1);
+       rb_define_singleton_method (c, "new", c_new, -1);
 }
index d61c66fd95f5b916d160cc48e592a7a30f3745ce..055c17e1a357a6c55f0c95de89784e33675a7295 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_software_x11.c 27 2004-07-08 18:25:05Z tilman $
+ * $Id: rb_software_x11.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
 #include <Ecore.h>
 #include <Ecore_Evas.h>
 
+#include "../ecore/rb_ecore.h"
+#include "../ecore_x/rb_window.h"
 #include "rb_ecore_evas_main.h"
 #include "rb_ecore_evas.h"
 
+static VALUE windows;
+
 static VALUE c_new (int argc, VALUE *argv, VALUE klass)
 {
        VALUE self, disp, parent, geom[4];
@@ -62,11 +66,33 @@ static VALUE c_new (int argc, VALUE *argv, VALUE klass)
        return self;
 }
 
+static VALUE c_window_get (VALUE self)
+{
+       VALUE o;
+       Ecore_X_Window w;
+
+       GET_OBJ (self, Ecore_Evas *, ee);
+
+       if (NIL_P (o = rb_hash_aref (windows, INT2NUM ((long) (ee))))) {
+               w = ecore_evas_software_x11_window_get (*ee);
+               o = TO_ECORE_X_WINDOW (self, w);
+               rb_hash_aset (windows, INT2NUM ((long) ee), o);
+       }
+
+       return o;
+}
+
 void Init_SoftwareX11 (void)
 {
-       VALUE cSoftwareX11 = rb_define_class_under (mEvas,
-                                                   "SoftwareX11",
-                                                   cEcoreEvas);
+       VALUE c;
+
+       rb_require ("ecore_x");
+
+       c = rb_define_class_under (mEvas, "SoftwareX11", cEcoreEvas);
+
+       rb_define_singleton_method (c, "new", c_new, -1);
+       rb_define_method (c, "window", c_window_get, 0);
 
-       rb_define_singleton_method (cSoftwareX11, "new", c_new, -1);
+       windows = rb_hash_new ();
+       rb_global_variable (&windows);
 }
index e0b1691054f4dcc2ab36ec5855cadc6cd0c53e3d..0ef669be9d91b53a4b5ada85d2ce7fb529190f5c 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * $Id: rb_job.c 27 2004-07-08 18:25:05Z tilman $
+ * $Id: rb_job.c 40 2004-07-25 13:14:34Z tilman $
  *
  * Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
  *
@@ -32,8 +32,6 @@ typedef struct {
        bool deleted;
 } RbEcoreJob;
 
-static VALUE cJob;
-
 static void on_job (void *data)
 {
        RbEcoreJob *job = data;
@@ -91,9 +89,8 @@ static VALUE c_delete (VALUE self)
 
 void Init_Job (void)
 {
-       cJob = rb_define_class_under (mJob, "Job", rb_cObject);
+       VALUE c = rb_define_class_under (mJob, "Job", rb_cObject);
 
-       rb_define_singleton_method (cJob, "new", c_new, 0);
-       rb_define_method (cJob, "delete", c_delete, 0);
+       rb_define_singleton_method (c, "new", c_new, 0);
+       rb_define_method (c, "delete", c_delete, 0);
 }
-