X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=src%2Fecore%2Frb_ecore.c;h=239da0f89518826932c508c86cec865585c47143;hb=b19653233d0564dde78f97ef518d4d11f3eb11c4;hp=9ff2ea37445608e96cd1f131934a035298ae302a;hpb=0808f1c1131c38d4f1d72b9013856c5fd138dc1f;p=ruby-ecore.git diff --git a/src/ecore/rb_ecore.c b/src/ecore/rb_ecore.c index 9ff2ea3..239da0f 100644 --- a/src/ecore/rb_ecore.c +++ b/src/ecore/rb_ecore.c @@ -1,5 +1,5 @@ /* - * $Id: rb_ecore.c 152 2004-12-09 18:33:15Z tilman $ + * $Id: rb_ecore.c 360 2006-02-12 15:53:44Z tilman $ * * Copyright (C) 2004 ruby-ecore team (see AUTHORS) * @@ -27,6 +27,7 @@ #include "rb_timer.h" #include "rb_animator.h" #include "rb_idler.h" +#include "rb_idle_enterer.h" #include "rb_event_handler.h" #include "rb_fd_handler.h" @@ -76,6 +77,31 @@ static VALUE m_time_get (VALUE self) return rb_float_new (ecore_time_get ()); } +static VALUE m_new_event_type (VALUE self, VALUE klass) +{ + VALUE num; + + num = INT2FIX (ecore_event_type_new()); + rb_hash_aset (event_classes, num, klass); + + return num; +} + +static void free_ruby_event (void *data, void *event) +{ + /* do nothing */ +} + +static VALUE m_add_event (VALUE self, VALUE type, VALUE event) +{ + Check_Type (type, T_FIXNUM); + + ecore_event_add (FIX2INT (type), (void *) event, free_ruby_event, NULL); + + return Qnil; +} + +#if 0 static VALUE c_ev_exe_exit_init (VALUE self, VALUE event) { VALUE c = CLASS_OF (self); @@ -95,6 +121,7 @@ static VALUE c_ev_exe_exit_init (VALUE self, VALUE event) return self; } +#endif static VALUE c_ev_sig_user_init (VALUE self, VALUE event) { @@ -134,10 +161,19 @@ static VALUE c_ev_sig_rt_init (VALUE self, VALUE event) return self; } +static void at_exit () +{ + ecore_shutdown (); +} + void Init_ecore (void) { VALUE c; + ecore_init (); + + atexit (at_exit); + mEcore = rb_define_module ("Ecore"); rb_define_module_function (mEcore, "main_loop_begin", @@ -147,6 +183,9 @@ void Init_ecore (void) rb_define_module_function (mEcore, "main_loop_quit", m_main_loop_quit, 0); rb_define_module_function (mEcore, "time", m_time_get, 0); + rb_define_module_function (mEcore, "new_event_type", + m_new_event_type, 1); + rb_define_module_function (mEcore, "add_event", m_add_event, 2); Init_Timer (); Init_Animator (); @@ -165,9 +204,11 @@ void Init_ecore (void) "SignalPower", c); rb_define_private_method (c, "initialize", c_ev_generic_init, 1); +#if 0 /* EXE_EXIT */ ADD_EVENT (mEcore, ECORE_EVENT_, EXE_EXIT, "ExeExit", c); rb_define_private_method (c, "initialize", c_ev_exe_exit_init, 1); +#endif /* SIGNAL_USER */ ADD_EVENT (mEcore, ECORE_EVENT_, SIGNAL_USER,