X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Fecore_x%2Frb_ecore_x.c;h=69520a36476033330752f6f4d9a6711f9e2c81ad;hb=4f2835571a13e31777b36def3056547b997e0599;hp=83405b02bd30160e3fb726eb8b0dd363efe536e6;hpb=ed7756f1892ec068be14445c39a86f14f7e76a46;p=ruby-ecore.git diff --git a/src/ecore_x/rb_ecore_x.c b/src/ecore_x/rb_ecore_x.c index 83405b0..69520a3 100644 --- a/src/ecore_x/rb_ecore_x.c +++ b/src/ecore_x/rb_ecore_x.c @@ -1,5 +1,5 @@ /* - * $Id: rb_ecore_x.c 98 2004-08-26 13:12:55Z tilman $ + * $Id: rb_ecore_x.c 365 2006-02-14 21:50:47Z tilman $ * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * @@ -221,6 +221,37 @@ static VALUE c_ev_win_delete_request_init (VALUE self, VALUE event) return self; } +static VALUE c_ev_win_configure_request_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Window_Configure_Request *e = (void *) event; + + rb_define_attr (c, "window", 1, 0); + rb_define_attr (c, "window_above", 1, 0); + rb_define_attr (c, "x", 1, 0); + rb_define_attr (c, "y", 1, 0); + rb_define_attr (c, "w", 1, 0); + rb_define_attr (c, "h", 1, 0); + rb_define_attr (c, "border", 1, 0); + rb_define_attr (c, "detail", 1, 0); + rb_define_attr (c, "value_mask", 1, 0); + rb_define_attr (c, "time", 1, 0); + + rb_iv_set (self, "@window", TO_ECORE_X_WINDOW (Qnil, e->win)); + rb_iv_set (self, "@window_above", TO_ECORE_X_WINDOW (Qnil, + e->abovewin)); + rb_iv_set (self, "@x", INT2FIX (e->x)); + rb_iv_set (self, "@y", INT2FIX (e->y)); + rb_iv_set (self, "@w", INT2FIX (e->w)); + rb_iv_set (self, "@h", INT2FIX (e->h)); + rb_iv_set (self, "@border", INT2FIX (e->border)); + rb_iv_set (self, "@detail", INT2FIX (e->detail)); + rb_iv_set (self, "@value_mask", INT2FIX (e->value_mask)); + rb_iv_set (self, "@time", UINT2NUM (e->time)); + + return self; +} + static VALUE c_ev_win_configure_init (VALUE self, VALUE event) { VALUE c = CLASS_OF (self); @@ -252,6 +283,46 @@ static VALUE c_ev_win_configure_init (VALUE self, VALUE event) return self; } +static VALUE c_ev_win_resize_request_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Window_Resize_Request *e = (void *) event; + + rb_define_attr (c, "window", 1, 0); + rb_define_attr (c, "w", 1, 0); + rb_define_attr (c, "h", 1, 0); + rb_define_attr (c, "time", 1, 0); + + rb_iv_set (self, "@window", TO_ECORE_X_WINDOW (Qnil, e->win)); + rb_iv_set (self, "@w", INT2FIX (e->w)); + rb_iv_set (self, "@h", INT2FIX (e->h)); + rb_iv_set (self, "@time", UINT2NUM (e->time)); + + return self; +} + +static VALUE c_ev_win_damage_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Window_Damage *e = (void *) event; + + rb_define_attr (c, "window", 1, 0); + rb_define_attr (c, "x", 1, 0); + rb_define_attr (c, "y", 1, 0); + rb_define_attr (c, "w", 1, 0); + rb_define_attr (c, "h", 1, 0); + rb_define_attr (c, "time", 1, 0); + + rb_iv_set (self, "@window", TO_ECORE_X_WINDOW (Qnil, e->win)); + rb_iv_set (self, "@x", INT2FIX (e->x)); + rb_iv_set (self, "@y", INT2FIX (e->y)); + rb_iv_set (self, "@w", INT2FIX (e->w)); + rb_iv_set (self, "@h", INT2FIX (e->h)); + rb_iv_set (self, "@time", UINT2NUM (e->time)); + + return self; +} + static VALUE c_ev_win_visibility_change_init (VALUE self, VALUE event) { VALUE c = CLASS_OF (self); @@ -385,83 +456,92 @@ void Init_ecore_x (void) DEF_CONST (c, ECORE_X_MODIFIER_, WIN); /* events */ - ADD_EVENT (mX, ECORE_X_EVENT_, KEY_DOWN, "KeyDown", c); + ADD_EVENT (mX, ECORE_X_EVENT_KEY_DOWN, "KeyDown", c); rb_define_private_method (c, "initialize", c_ev_key_down_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, KEY_UP, "KeyUp", c); + ADD_EVENT (mX, ECORE_X_EVENT_KEY_UP, "KeyUp", c); rb_define_private_method (c, "initialize", c_ev_key_down_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, MOUSE_BUTTON_DOWN, + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_BUTTON_DOWN, "MouseButtonDown", c); rb_define_private_method (c, "initialize", c_ev_mouse_button_down_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, MOUSE_BUTTON_UP, + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_BUTTON_UP, "MouseButtonUp", c); rb_define_private_method (c, "initialize", c_ev_mouse_button_up_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, MOUSE_MOVE, "MouseMove", c); + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_MOVE, "MouseMove", c); rb_define_private_method (c, "initialize", c_ev_mouse_move_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, MOUSE_IN, "MouseIn", c); + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_IN, "MouseIn", c); rb_define_private_method (c, "initialize", c_ev_mouse_in_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, MOUSE_OUT, "MouseOut", c); + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_OUT, "MouseOut", c); rb_define_private_method (c, "initialize", c_ev_mouse_in_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_FOCUS_IN, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_FOCUS_IN, "WindowFocusIn", c); rb_define_private_method (c, "initialize", c_ev_win_focus_change_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_FOCUS_OUT, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_FOCUS_OUT, "WindowFocusOut", c); rb_define_private_method (c, "initialize", c_ev_win_focus_change_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_DELETE_REQUEST, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_DELETE_REQUEST, "WindowDeleteRequest", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_CONFIGURE_REQUEST, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_CONFIGURE_REQUEST, "WindowConfigureRequest", c); rb_define_private_method (c, "initialize", - c_ev_win_delete_request_init, 1); + c_ev_win_configure_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_CONFIGURE, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_CONFIGURE, "WindowConfigure", c); rb_define_private_method (c, "initialize", c_ev_win_configure_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_VISIBILITY_CHANGE, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_RESIZE_REQUEST, + "WindowResizeRequest", c); + rb_define_private_method (c, "initialize", + c_ev_win_resize_request_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_DAMAGE, "WindowDamage", c); + rb_define_private_method (c, "initialize", + c_ev_win_damage_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_VISIBILITY_CHANGE, "WindowVisibilityChange", c); rb_define_private_method (c, "initialize", c_ev_win_visibility_change_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_CREATE, "WindowCreate", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_CREATE, "WindowCreate", c); rb_define_private_method (c, "initialize", c_ev_win_create_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_DESTROY, "WindowDestroy", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_DESTROY, "WindowDestroy", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_SHOW, "WindowShow", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_SHOW, "WindowShow", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_HIDE, "WindowHide", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_HIDE, "WindowHide", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_SHOW_REQUEST, + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_SHOW_REQUEST, "WindowShowRequest", c); rb_define_private_method (c, "initialize", c_ev_win_show_request_init, 1);