X-Git-Url: http://git.code-monkey.de/?p=ruby-ecore.git;a=blobdiff_plain;f=src%2Fecore_x%2Frb_window.c;h=e3f1bcfb018cd050df517407a05686ae88206d1c;hp=429559a5e3f760dbf646d23f8a5b99637d912988;hb=0f8d24c745efc1057f8d25ada1375c88a1ab2ed7;hpb=b5fcf070433a323bcf1c769fc22dbc5514573095 diff --git a/src/ecore_x/rb_window.c b/src/ecore_x/rb_window.c index 429559a..e3f1bcf 100644 --- a/src/ecore_x/rb_window.c +++ b/src/ecore_x/rb_window.c @@ -1,6 +1,4 @@ /* - * $Id: rb_window.c 102 2004-08-28 10:00:03Z tilman $ - * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * * This library is free software; you can redistribute it and/or @@ -29,7 +27,7 @@ #include "rb_window.h" #include "rb_cursor.h" -VALUE cWindow; +static VALUE cWindow; static void c_mark (RbWindow *w) { @@ -60,14 +58,21 @@ VALUE TO_ECORE_X_WINDOW (VALUE parent, Ecore_X_Window w) return self; } -static VALUE c_new (int argc, VALUE *argv, VALUE klass) +static VALUE c_alloc (VALUE klass) { - VALUE self, parent, geom[4]; - RbWindow *window = NULL, *p = NULL; + RbWindow *window = NULL; + + return Data_Make_Struct (cWindow, RbWindow, c_mark, c_free, window); +} + +static VALUE c_init (int argc, VALUE *argv, VALUE self) +{ + VALUE parent, geom[4]; + RbWindow *p = NULL; int i, igeom[4] = {0, 0, 0, 0}; Ecore_X_Window pwin = 0; - self = Data_Make_Struct (cWindow, RbWindow, c_mark, c_free, window); + GET_OBJ (self, RbWindow, win); rb_scan_args (argc, argv, "05", &parent, &geom[0], &geom[1], &geom[2], &geom[3]); @@ -84,17 +89,10 @@ static VALUE c_new (int argc, VALUE *argv, VALUE klass) igeom[i] = FIX2INT (geom[i]); } - window->real = ecore_x_window_new (pwin, igeom[0], igeom[1], - igeom[2], igeom[3]); - window->parent = parent; + win->real = ecore_x_window_new (pwin, igeom[0], igeom[1], + igeom[2], igeom[3]); + win->parent = parent; - rb_obj_call_init (self, 0, NULL); - - return self; -} - -static VALUE c_init (int argc, VALUE *argv, VALUE self) -{ rb_iv_set (self, "@cursor", Qnil); return self; @@ -269,7 +267,7 @@ static VALUE c_resize (VALUE self, VALUE w, VALUE h) Check_Type (w, T_FIXNUM); Check_Type (h, T_FIXNUM); - ecore_x_window_move (win->real, FIX2INT (w), FIX2INT (h)); + ecore_x_window_resize (win->real, FIX2INT (w), FIX2INT (h)); return Qnil; } @@ -330,6 +328,7 @@ static VALUE c_parent_get (VALUE self) ecore_x_window_parent_get (win->real)); } +#if 0 static VALUE c_title_get (VALUE self) { char *s; @@ -351,6 +350,7 @@ static VALUE c_title_set (VALUE self, VALUE val) return Qnil; } +#endif static VALUE c_set_event_mask (VALUE self, VALUE val) { @@ -374,6 +374,7 @@ static VALUE c_unset_event_mask (VALUE self, VALUE val) return Qnil; } +#if 0 static VALUE c_set_protocol (VALUE self, VALUE proto, VALUE on) { GET_OBJ (self, RbWindow, win); @@ -386,6 +387,7 @@ static VALUE c_set_protocol (VALUE self, VALUE proto, VALUE on) return Qnil; } +#endif static VALUE c_get_protocol (VALUE self, VALUE proto) { @@ -398,6 +400,7 @@ static VALUE c_get_protocol (VALUE self, VALUE proto) return s ? Qtrue : Qfalse; } +#if 0 static VALUE c_sticky_get (VALUE self) { int s; @@ -421,6 +424,29 @@ static VALUE c_sticky_set (VALUE self, VALUE val) return Qnil; } +static VALUE c_borderless_get (VALUE self) +{ + int s; + + GET_OBJ (self, RbWindow, win); + + s = ecore_x_window_prop_borderless_get (win->real); + + return s ? Qtrue : Qfalse; +} + +static VALUE c_borderless_set (VALUE self, VALUE val) +{ + GET_OBJ (self, RbWindow, win); + + CHECK_BOOL (val); + + ecore_x_window_prop_borderless_set (win->real, val == Qtrue); + + return Qnil; +} +#endif + static VALUE c_cursor_set (VALUE self, VALUE val) { GET_OBJ (self, RbWindow, win); @@ -483,10 +509,12 @@ void Init_Window (void) { cWindow = rb_define_class_under (mX, "Window", rb_cObject); - rb_define_singleton_method (cWindow, "new", c_new, -1); + rb_define_alloc_func (cWindow, c_alloc); rb_define_method (cWindow, "initialize", c_init, -1); rb_define_method (cWindow, "inspect", c_inspect, 0); + rb_define_method (cWindow, "eql?", c_equal_value, 1); rb_define_method (cWindow, "==", c_equal_value, 1); + rb_define_method (cWindow, "===", c_equal_value, 1); rb_define_method (cWindow, "configure", c_configure, -1); rb_define_method (cWindow, "show", c_show, 0); rb_define_method (cWindow, "hide", c_hide, 0); @@ -506,15 +534,23 @@ void Init_Window (void) rb_define_method (cWindow, "border_width=", c_border_width_set, 1); rb_define_method (cWindow, "depth", c_depth_get, 0); rb_define_method (cWindow, "parent", c_parent_get, 0); +#if 0 rb_define_method (cWindow, "title", c_title_get, 0); rb_define_method (cWindow, "title=", c_title_set, 1); +#endif rb_define_method (cWindow, "set_event_mask", c_set_event_mask, 1); rb_define_method (cWindow, "unset_event_mask", c_unset_event_mask, 1); +#if 0 rb_define_method (cWindow, "set_protocol", c_set_protocol, 2); +#endif rb_define_method (cWindow, "get_protocol", c_get_protocol, 1); +#if 0 rb_define_method (cWindow, "sticky?", c_sticky_get, 0); rb_define_method (cWindow, "sticky=", c_sticky_set, 1); + rb_define_method (cWindow, "borderless?", c_borderless_get, 0); + rb_define_method (cWindow, "borderless=", c_borderless_set, 1); +#endif rb_define_method (cWindow, "cursor=", c_cursor_set, 1); rb_define_method (cWindow, "manage", c_manage, 0); rb_define_method (cWindow, "manage_container", c_manage_container, 0);