X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Fecore_x%2Frb_ecore_x.c;h=3ef0b1e1fcb4beefa55a7b8d6fcd3d8f3e5b9e93;hb=0b272da1f7cdde3609b78fb949a7cff429c33eb7;hp=cd1b70ec2a3d2964f246f05a3149b4883efa5933;hpb=6aefc9e933176f5287f7cedf3b44224dc629e5d0;p=ruby-ecore.git diff --git a/src/ecore_x/rb_ecore_x.c b/src/ecore_x/rb_ecore_x.c index cd1b70e..3ef0b1e 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 83 2004-08-21 19:55:35Z tilman $ + * $Id: rb_ecore_x.c 88 2004-08-22 14:52:37Z tilman $ * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * @@ -45,6 +45,62 @@ static VALUE m_default_root_window_get (VALUE self) return default_root; } +static VALUE c_ev_mouse_move_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Mouse_Move *e = (void *) event; + + rb_define_attr (c, "modifiers", 1, 0); + rb_define_attr (c, "x", 1, 0); + rb_define_attr (c, "y", 1, 0); + rb_define_attr (c, "root", 1, 0); + rb_define_attr (c, "window", 1, 0); + rb_define_attr (c, "event_window", 1, 0); + rb_define_attr (c, "time", 1, 0); + + rb_iv_set (self, "@modifiers", INT2FIX (e->modifiers)); + rb_iv_set (self, "@x", INT2FIX (e->x)); + rb_iv_set (self, "@y", INT2FIX (e->y)); + rb_iv_set (self, "@root", rb_ary_new3 (2, INT2FIX (e->root.x), + INT2FIX (e->root.y))); + rb_iv_set (self, "@window", TO_ECORE_X_WINDOW (Qnil, e->win)); + rb_iv_set (self, "@event_window", + TO_ECORE_X_WINDOW (Qnil, e->event_win)); + rb_iv_set (self, "@time", UINT2NUM (e->time)); + + return self; +} + +static VALUE c_ev_mouse_in_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Mouse_In *e = (void *) event; + + rb_define_attr (c, "modifiers", 1, 0); + rb_define_attr (c, "x", 1, 0); + rb_define_attr (c, "y", 1, 0); + rb_define_attr (c, "root", 1, 0); + rb_define_attr (c, "window", 1, 0); + rb_define_attr (c, "event_window", 1, 0); + rb_define_attr (c, "mode", 1, 0); + rb_define_attr (c, "detail", 1, 0); + rb_define_attr (c, "time", 1, 0); + + rb_iv_set (self, "@modifiers", INT2FIX (e->modifiers)); + rb_iv_set (self, "@x", INT2FIX (e->x)); + rb_iv_set (self, "@y", INT2FIX (e->y)); + rb_iv_set (self, "@root", rb_ary_new3 (2, INT2FIX (e->root.x), + INT2FIX (e->root.y))); + rb_iv_set (self, "@window", TO_ECORE_X_WINDOW (Qnil, e->win)); + rb_iv_set (self, "@event_window", + TO_ECORE_X_WINDOW (Qnil, e->event_win)); + rb_iv_set (self, "@mode", INT2FIX (e->mode)); + rb_iv_set (self, "@detail", INT2FIX (e->detail)); + rb_iv_set (self, "@time", UINT2NUM (e->time)); + + return self; +} + static VALUE c_ev_win_focus_change_init (VALUE self, VALUE event) { VALUE c = CLASS_OF (self); @@ -124,6 +180,22 @@ static VALUE c_ev_win_visibility_change_init (VALUE self, VALUE event) return self; } +static VALUE c_ev_win_create_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Window_Create *e = (void *) event; + + rb_define_attr (c, "window", 1, 0); + rb_define_attr (c, "override", 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, "@override", e->override ? Qtrue : Qfalse); + rb_iv_set (self, "@time", UINT2NUM (e->time)); + + return self; +} + static VALUE c_ev_win_show_request_init (VALUE self, VALUE event) { VALUE c = CLASS_OF (self); @@ -215,6 +287,18 @@ void Init_ecore_x (void) DEF_CONST (c, ECORE_X_EVENT_DETAIL_, DETAIL_NONE); /* events */ + 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); + rb_define_private_method (c, "initialize", + c_ev_mouse_in_init, 1); + + 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, "WindowFocusIn", c); rb_define_private_method (c, "initialize", @@ -245,6 +329,14 @@ void Init_ecore_x (void) rb_define_private_method (c, "initialize", c_ev_win_visibility_change_init, 1); + 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); + rb_define_private_method (c, "initialize", + c_ev_win_delete_request_init, 1); + ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_SHOW, "WindowShow", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1);