From: Tilman Sauerbeck Date: Sat, 21 Aug 2004 09:43:23 +0000 (+0000) Subject: Don't fail in TO_ECORE_X_WINDOW if the window passed is 0. X-Git-Url: http://git.code-monkey.de/?p=ruby-ecore.git;a=commitdiff_plain;h=aaf65fd2a802aa98b8fb2001bf711fac0f5c74e3 Don't fail in TO_ECORE_X_WINDOW if the window passed is 0. Also implemented lots of new methods. --- diff --git a/src/ecore_x/rb_window.c b/src/ecore_x/rb_window.c index 525281a..58c3d6b 100644 --- a/src/ecore_x/rb_window.c +++ b/src/ecore_x/rb_window.c @@ -1,5 +1,5 @@ /* - * $Id: rb_window.c 78 2004-08-19 21:02:11Z tilman $ + * $Id: rb_window.c 81 2004-08-21 09:43:23Z tilman $ * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * @@ -49,9 +49,6 @@ VALUE TO_ECORE_X_WINDOW (VALUE parent, Ecore_X_Window w) VALUE self; RbWindow *window = NULL; - if (!w) - return Qnil; - self = Data_Make_Struct (cWindow, RbWindow, c_mark, free, window); window->real = w; @@ -123,6 +120,13 @@ static VALUE c_hide (VALUE self) return Qnil; } +static VALUE c_visible_get (VALUE self) +{ + GET_OBJ (self, RbWindow, win); + + return ecore_x_window_visible_get (win->real) ? Qtrue : Qfalse; +} + static VALUE c_delete (VALUE self) { GET_OBJ (self, RbWindow, win); @@ -153,6 +157,22 @@ static VALUE c_lower (VALUE self) return Qnil; } +static VALUE c_reparent (VALUE self, VALUE other, VALUE x, VALUE y) +{ + GET_OBJ (self, RbWindow, win); + + CHECK_CLASS (other, cWindow); + GET_OBJ (other, RbWindow, o); + + Check_Type (x, T_FIXNUM); + Check_Type (y, T_FIXNUM); + + ecore_x_window_reparent (win->real, o->real, + FIX2INT (x), FIX2INT (y)); + + return Qnil; +} + static VALUE c_move (VALUE self, VALUE x, VALUE y) { GET_OBJ (self, RbWindow, win); @@ -200,6 +220,46 @@ static VALUE c_geometry_get (VALUE self) INT2FIX (w), INT2FIX (h)); } +static VALUE c_border_size_get (VALUE self) +{ + GET_OBJ (self, RbWindow, win); + + return INT2FIX (ecore_x_window_border_size_get (win->real)); +} + +static VALUE c_depth_get (VALUE self) +{ + GET_OBJ (self, RbWindow, win); + + return INT2FIX (ecore_x_window_depth_get (win->real)); +} + +static VALUE c_parent_get (VALUE self) +{ + GET_OBJ (self, RbWindow, win); + + return TO_ECORE_X_WINDOW (Qnil, + ecore_x_window_parent_get (win->real)); +} + +static VALUE c_title_get (VALUE self) +{ + GET_OBJ (self, RbWindow, win); + + return rb_str_new2 (ecore_x_window_prop_title_get (win->real)); +} + +static VALUE c_title_set (VALUE self, VALUE val) +{ + GET_OBJ (self, RbWindow, win); + + Check_Type (val, T_STRING); + + ecore_x_window_prop_title_set (win->real, StringValuePtr (val)); + + return Qnil; +} + static VALUE c_set_event_mask (VALUE self, VALUE val) { GET_OBJ (self, RbWindow, win); @@ -243,13 +303,20 @@ void Init_Window (void) rb_define_method (cWindow, "==", c_equal_value, 1); rb_define_method (cWindow, "show", c_show, 0); rb_define_method (cWindow, "hide", c_hide, 0); + rb_define_method (cWindow, "visible?", c_visible_get, 0); rb_define_method (cWindow, "delete", c_delete, 0); rb_define_method (cWindow, "raise", c_raise, 0); rb_define_method (cWindow, "lower", c_lower, 0); + rb_define_method (cWindow, "reparent", c_reparent, 3); rb_define_method (cWindow, "move", c_move, 2); rb_define_method (cWindow, "resize", c_resize, 2); rb_define_method (cWindow, "size", c_size_get, 0); rb_define_method (cWindow, "geometry", c_geometry_get, 0); + rb_define_method (cWindow, "border_size", c_border_size_get, 0); + rb_define_method (cWindow, "depth", c_depth_get, 0); + rb_define_method (cWindow, "parent", c_parent_get, 0); + rb_define_method (cWindow, "title", c_title_get, 0); + rb_define_method (cWindow, "title=", c_title_set, 1); rb_define_method (cWindow, "set_event_mask", c_set_event_mask, 1); rb_define_method (cWindow, "unset_event_mask", c_unset_event_mask, 1);