projects
/
ruby-ecore.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use a configure task and extension tasks to build ruby-ecore.
[ruby-ecore.git]
/
src
/
ecore
/
rb_ecore.c
diff --git
a/src/ecore/rb_ecore.c
b/src/ecore/rb_ecore.c
index 7e673feaaa95f29a015d36c6adccc983a1b89cbd..0d18a9a3a3ea502e40d00de17d665a8b7a1d0d3c 100644
(file)
--- a/
src/ecore/rb_ecore.c
+++ b/
src/ecore/rb_ecore.c
@@
-1,6
+1,4
@@
/*
/*
- * $Id: rb_ecore.c 77 2004-08-19 17:39:29Z tilman $
- *
* Copyright (C) 2004 ruby-ecore team (see AUTHORS)
*
* This library is free software; you can redistribute it and/or
* Copyright (C) 2004 ruby-ecore team (see AUTHORS)
*
* This library is free software; you can redistribute it and/or
@@
-25,8
+23,11
@@
#define __RB_ECORE_C
#include "rb_ecore.h"
#include "rb_timer.h"
#define __RB_ECORE_C
#include "rb_ecore.h"
#include "rb_timer.h"
+#include "rb_animator.h"
#include "rb_idler.h"
#include "rb_idler.h"
+#include "rb_idle_enterer.h"
#include "rb_event_handler.h"
#include "rb_event_handler.h"
+#include "rb_fd_handler.h"
VALUE mEcore;
VALUE mEcore;
@@
-69,10
+70,23
@@
static VALUE m_main_loop_quit (VALUE self)
return Qnil;
}
return Qnil;
}
+static VALUE m_time_get (VALUE self)
+{
+ return rb_float_new (ecore_time_get ());
+}
+
+#if 0
static VALUE c_ev_exe_exit_init (VALUE self, VALUE event)
{
static VALUE c_ev_exe_exit_init (VALUE self, VALUE event)
{
+ VALUE c = CLASS_OF (self);
Ecore_Event_Exe_Exit *e = (void *) event;
Ecore_Event_Exe_Exit *e = (void *) event;
+ rb_define_attr (c, "pid", 1, 0);
+ rb_define_attr (c, "exit_code", 1, 0);
+ rb_define_attr (c, "exit_signal", 1, 0);
+ rb_define_attr (c, "exited", 1, 0);
+ rb_define_attr (c, "signalled", 1, 0);
+
rb_iv_set (self, "@pid", INT2FIX (e->pid));
rb_iv_set (self, "@exit_code", INT2FIX (e->exit_code));
rb_iv_set (self, "@exit_signal", INT2FIX (e->exit_signal));
rb_iv_set (self, "@pid", INT2FIX (e->pid));
rb_iv_set (self, "@exit_code", INT2FIX (e->exit_code));
rb_iv_set (self, "@exit_signal", INT2FIX (e->exit_signal));
@@
-81,11
+95,14
@@
static VALUE c_ev_exe_exit_init (VALUE self, VALUE event)
return self;
}
return self;
}
+#endif
static VALUE c_ev_sig_user_init (VALUE self, VALUE event)
{
Ecore_Event_Signal_User *e = (void *) event;
static VALUE c_ev_sig_user_init (VALUE self, VALUE event)
{
Ecore_Event_Signal_User *e = (void *) event;
+ rb_define_attr (CLASS_OF (self), "number", 1, 0);
+
rb_iv_set (self, "@number", INT2FIX (e->number));
return self;
rb_iv_set (self, "@number", INT2FIX (e->number));
return self;
@@
-93,8
+110,13
@@
static VALUE c_ev_sig_user_init (VALUE self, VALUE event)
static VALUE c_ev_sig_exit_init (VALUE self, VALUE event)
{
static VALUE c_ev_sig_exit_init (VALUE self, VALUE event)
{
+ VALUE c = CLASS_OF (self);
Ecore_Event_Signal_Exit *e = (void *) event;
Ecore_Event_Signal_Exit *e = (void *) event;
+ rb_define_attr (c, "interrupt", 1, 0);
+ rb_define_attr (c, "quit", 1, 0);
+ rb_define_attr (c, "terminate", 1, 0);
+
rb_iv_set (self, "@interrupt", e->interrupt ? Qtrue : Qfalse);
rb_iv_set (self, "@quit", e->quit ? Qtrue : Qfalse);
rb_iv_set (self, "@terminate", e->terminate ? Qtrue : Qfalse);
rb_iv_set (self, "@interrupt", e->interrupt ? Qtrue : Qfalse);
rb_iv_set (self, "@quit", e->quit ? Qtrue : Qfalse);
rb_iv_set (self, "@terminate", e->terminate ? Qtrue : Qfalse);
@@
-106,15
+128,26
@@
static VALUE c_ev_sig_rt_init (VALUE self, VALUE event)
{
Ecore_Event_Signal_Realtime *e = (void *) event;
{
Ecore_Event_Signal_Realtime *e = (void *) event;
+ rb_define_attr (CLASS_OF (self), "number", 1, 0);
+
rb_iv_set (self, "@number", INT2FIX (e->num));
return self;
}
rb_iv_set (self, "@number", INT2FIX (e->num));
return self;
}
+static void at_exit ()
+{
+ ecore_shutdown ();
+}
+
void Init_ecore (void)
{
VALUE c;
void Init_ecore (void)
{
VALUE c;
+ ecore_init ();
+
+ atexit (at_exit);
+
mEcore = rb_define_module ("Ecore");
rb_define_module_function (mEcore, "main_loop_begin",
mEcore = rb_define_module ("Ecore");
rb_define_module_function (mEcore, "main_loop_begin",
@@
-123,52
+156,42
@@
void Init_ecore (void)
m_main_loop_iterate, 0);
rb_define_module_function (mEcore, "main_loop_quit",
m_main_loop_quit, 0);
m_main_loop_iterate, 0);
rb_define_module_function (mEcore, "main_loop_quit",
m_main_loop_quit, 0);
+ rb_define_module_function (mEcore, "time", m_time_get, 0);
Init_Timer ();
Init_Timer ();
+ Init_Animator ();
Init_Idler ();
Init_Idler ();
+ Init_IdleEnterer ();
Init_EventHandler ();
Init_EventHandler ();
+ Init_FdHandler ();
/* SIGNAL_HUP */
/* SIGNAL_HUP */
- ADD_EVENT (mEcore, ECORE_EVENT_, SIGNAL_HUP,
- "SignalHup", c);
- rb_define_private_method (c, "initialize", c_ev_generic_init, 1);
+ ADD_EVENT (mEcore, ECORE_EVENT_SIGNAL_HUP,
+ "SignalHupEvent", c);
/* SIGNAL_POWER */
/* SIGNAL_POWER */
- ADD_EVENT (mEcore, ECORE_EVENT_, SIGNAL_POWER,
- "SignalPower", c);
- rb_define_private_method (c, "initialize", c_ev_generic_init, 1);
+ ADD_EVENT (mEcore, ECORE_EVENT_SIGNAL_POWER,
+ "SignalPowerEvent", c);
+#if 0
/* EXE_EXIT */
/* EXE_EXIT */
- ADD_EVENT (mEcore, ECORE_EVENT_
, EXE_EXIT, "ExeExi
t", c);
+ ADD_EVENT (mEcore, ECORE_EVENT_
EXE_EXIT, "ExeExitEven
t", c);
rb_define_private_method (c, "initialize", c_ev_exe_exit_init, 1);
rb_define_private_method (c, "initialize", c_ev_exe_exit_init, 1);
-
- rb_define_attr (c, "pid", 1, 0);
- rb_define_attr (c, "exit_code", 1, 0);
- rb_define_attr (c, "exit_signal", 1, 0);
- rb_define_attr (c, "exited", 1, 0);
- rb_define_attr (c, "signalled", 1, 0);
+#endif
/* SIGNAL_USER */
/* SIGNAL_USER */
- ADD_EVENT (mEcore, ECORE_EVENT_
,
SIGNAL_USER,
- "SignalUser", c);
+ ADD_EVENT (mEcore, ECORE_EVENT_SIGNAL_USER,
+ "SignalUser
Event
", c);
rb_define_private_method (c, "initialize", c_ev_sig_user_init, 1);
rb_define_private_method (c, "initialize", c_ev_sig_user_init, 1);
- rb_define_attr (c, "number", 1, 0);
-
/* SIGNAL_EXIT */
/* SIGNAL_EXIT */
- ADD_EVENT (mEcore, ECORE_EVENT_
,
SIGNAL_EXIT,
- "SignalExit", c);
+ ADD_EVENT (mEcore, ECORE_EVENT_SIGNAL_EXIT,
+ "SignalExit
Event
", c);
rb_define_private_method (c, "initialize", c_ev_sig_exit_init, 1);
rb_define_private_method (c, "initialize", c_ev_sig_exit_init, 1);
- rb_define_attr (c, "interrupt", 1, 0);
- rb_define_attr (c, "quit", 1, 0);
- rb_define_attr (c, "terminate", 1, 0);
-
/* SIGNAL_REALTIME */
/* SIGNAL_REALTIME */
- ADD_EVENT (mEcore, ECORE_EVENT_
,
SIGNAL_REALTIME,
- "SignalRealtime", c);
+ ADD_EVENT (mEcore, ECORE_EVENT_SIGNAL_REALTIME,
+ "SignalRealtime
Event
", c);
rb_define_private_method (c, "initialize", c_ev_sig_rt_init, 1);
rb_define_private_method (c, "initialize", c_ev_sig_rt_init, 1);
-
- rb_define_attr (c, "number", 1, 0);
}
}