X-Git-Url: http://git.code-monkey.de/?p=ruby-ecore.git;a=blobdiff_plain;f=src%2Fecore_x%2Frb_ecore_x.c;h=c0c358fd65ff6701f0579c3044416cd6a33c2873;hp=0acba6b698c8a54324b59a4d5de39752a9becbb4;hb=ab7b3b89f6a3a3069871ca5f59722a3f23e2f631;hpb=dfaa1fcfd2bee38479f36ef86fb4021fafe82484 diff --git a/src/ecore_x/rb_ecore_x.c b/src/ecore_x/rb_ecore_x.c index 0acba6b..c0c358f 100644 --- a/src/ecore_x/rb_ecore_x.c +++ b/src/ecore_x/rb_ecore_x.c @@ -1,6 +1,4 @@ /* - * $Id: rb_ecore_x.c 84 2004-08-21 20:16:25Z tilman $ - * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * * This library is free software; you can redistribute it and/or @@ -22,17 +20,17 @@ #include #include +#include #include "../ecore/rb_ecore.h" #include "../ecore/rb_event_handler.h" #include "rb_ecore_x.h" #include "rb_window.h" +#include "rb_cursor.h" -#define DEF_CONST(mod, prefix, name) \ - rb_define_const ((mod), #name, \ - INT2FIX (prefix##name)); - +#if 0 static VALUE default_root; +#endif static void at_exit () { @@ -40,10 +38,158 @@ static void at_exit () ecore_shutdown (); } +#if 0 static VALUE m_default_root_window_get (VALUE self) { return default_root; } +#endif + +static VALUE c_ev_key_down_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Key_Down *e = (void *) event; + + rb_define_attr (c, "keyname", 1, 0); + rb_define_attr (c, "keysymbol", 1, 0); + rb_define_attr (c, "key_compose", 1, 0); + rb_define_attr (c, "modifiers", 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, "@keyname", + e->keyname ? rb_str_new2 (e->keyname) : Qnil); + rb_iv_set (self, "@keysymbol", + e->keysymbol ? rb_str_new2 (e->keysymbol) : Qnil); + rb_iv_set (self, "@key_compose", + e->key_compose ? rb_str_new2 (e->key_compose) : Qnil); + rb_iv_set (self, "@modifiers", INT2FIX (e->modifiers)); + 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_button_down_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Mouse_Button_Down *e = (void *) event; + + rb_define_attr (c, "button", 1, 0); + 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_define_attr (c, "double_click", 1, 0); + rb_define_attr (c, "triple_click", 1, 0); + + rb_iv_set (self, "@button", INT2FIX (e->button)); + rb_iv_set (self, "@modifiers", INT2FIX (e->modifiers)); + rb_iv_set (self, "@x", INT2FIX (e->x)); + rb_iv_set (self, "@y", INT2FIX (e->x)); + 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)); + rb_iv_set (self, "@double_click", + e->double_click ? Qtrue : Qfalse); + rb_iv_set (self, "@triple_click", + e->triple_click ? Qtrue : Qfalse); + + return self; +} + +static VALUE c_ev_mouse_button_up_init (VALUE self, VALUE event) +{ + VALUE c = CLASS_OF (self); + Ecore_X_Event_Mouse_Button_Up *e = (void *) event; + + rb_define_attr (c, "button", 1, 0); + 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, "@button", INT2FIX (e->button)); + rb_iv_set (self, "@modifiers", INT2FIX (e->modifiers)); + rb_iv_set (self, "@x", INT2FIX (e->x)); + rb_iv_set (self, "@y", INT2FIX (e->x)); + 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_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) { @@ -77,6 +223,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); @@ -108,6 +285,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); @@ -159,6 +376,7 @@ static VALUE c_ev_win_show_request_init (VALUE self, VALUE event) void Init_ecore_x (void) { VALUE c; + Ecore_X_Window w; rb_require ("ecore"); @@ -170,15 +388,21 @@ void Init_ecore_x (void) atexit (at_exit); mX = rb_define_module_under (mEcore, "X"); + +#if 0 rb_define_module_function (mX, "default_root_window", m_default_root_window_get, 0); +#endif Init_Window (); + Init_Cursor (); +#if 0 /* now create the default root window object */ - default_root = TO_ECORE_X_WINDOW (Qnil, 0); - OBJ_FREEZE (default_root); + w = DefaultRootWindow (ecore_x_display_get ()); + default_root = TO_ECORE_X_WINDOW (Qnil, w); rb_global_variable (&default_root); +#endif /* event mask values */ c = rb_define_class_under (mX, "EventMask", rb_cObject); @@ -219,7 +443,7 @@ void Init_ecore_x (void) DEF_CONST (c, ECORE_X_EVENT_MODE_, UNGRAB); /* event details */ - c = rb_define_class_under (mX, "EventDetails", rb_cObject); + c = rb_define_class_under (mX, "EventDetail", rb_cObject); rb_define_private_method (rb_singleton_class (c), "new", NULL, 0); DEF_CONST (c, ECORE_X_EVENT_DETAIL_, ANCESTOR); DEF_CONST (c, ECORE_X_EVENT_DETAIL_, VIRTUAL); @@ -230,55 +454,102 @@ void Init_ecore_x (void) DEF_CONST (c, ECORE_X_EVENT_DETAIL_, POINTER_ROOT); DEF_CONST (c, ECORE_X_EVENT_DETAIL_, DETAIL_NONE); + /* key modifiers */ + c = rb_define_class_under (mX, "Modifier", rb_cObject); + rb_define_private_method (rb_singleton_class (c), "new", NULL, 0); + DEF_CONST (c, ECORE_X_MODIFIER_, SHIFT); + DEF_CONST (c, ECORE_X_MODIFIER_, CTRL); + DEF_CONST (c, ECORE_X_MODIFIER_, ALT); + DEF_CONST (c, ECORE_X_MODIFIER_, WIN); + /* events */ - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_FOCUS_IN, - "WindowFocusIn", c); + ADD_EVENT (mX, ECORE_X_EVENT_KEY_DOWN, "KeyDownEvent", c); + rb_define_private_method (c, "initialize", + c_ev_key_down_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_KEY_UP, "KeyUpEvent", c); + rb_define_private_method (c, "initialize", + c_ev_key_down_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_BUTTON_DOWN, + "MouseButtonDownEvent", c); + rb_define_private_method (c, "initialize", + c_ev_mouse_button_down_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_BUTTON_UP, + "MouseButtonUpEvent", c); + rb_define_private_method (c, "initialize", + c_ev_mouse_button_up_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_MOVE, "MouseMoveEvent", c); + rb_define_private_method (c, "initialize", + c_ev_mouse_move_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_IN, "MouseInEvent", c); + rb_define_private_method (c, "initialize", + c_ev_mouse_in_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_MOUSE_OUT, "MouseOutEvent", c); + rb_define_private_method (c, "initialize", + c_ev_mouse_in_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_FOCUS_IN, + "WindowFocusInEvent", c); rb_define_private_method (c, "initialize", c_ev_win_focus_change_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_FOCUS_OUT, - "WindowFocusOut", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_FOCUS_OUT, + "WindowFocusOutEvent", c); rb_define_private_method (c, "initialize", c_ev_win_focus_change_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_DELETE_REQUEST, - "WindowDeleteRequest", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_DELETE_REQUEST, + "WindowDeleteRequestEvent", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_CONFIGURE_REQUEST, - "WindowConfigureRequest", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_CONFIGURE_REQUEST, + "WindowConfigureRequestEvent", 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, - "WindowConfigure", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_CONFIGURE, + "WindowConfigureEvent", c); rb_define_private_method (c, "initialize", c_ev_win_configure_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_VISIBILITY_CHANGE, - "WindowVisibilityChange", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_RESIZE_REQUEST, + "WindowResizeRequestEvent", c); + rb_define_private_method (c, "initialize", + c_ev_win_resize_request_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_DAMAGE, "WindowDamageEvent", c); + rb_define_private_method (c, "initialize", + c_ev_win_damage_init, 1); + + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_VISIBILITY_CHANGE, + "WindowVisibilityChangeEvent", 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, "WindowCreateEvent", 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, "WindowDestroyEvent", 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, "WindowShowEvent", 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, "WindowHideEvent", c); rb_define_private_method (c, "initialize", c_ev_win_delete_request_init, 1); - ADD_EVENT (mX, ECORE_X_EVENT_, WINDOW_SHOW_REQUEST, - "WindowShowRequest", c); + ADD_EVENT (mX, ECORE_X_EVENT_WINDOW_SHOW_REQUEST, + "WindowShowRequestEvent", c); rb_define_private_method (c, "initialize", c_ev_win_show_request_init, 1); }