/*
- * $Id: rb_idle_enterer.c 154 2004-12-09 18:49:18Z tilman $
+ * $Id: rb_idle_enterer.c 351 2006-02-10 15:25:40Z tilman $
*
* Copyright (C) 2004 ruby-ecore team (see AUTHORS)
*
free (idle_enterer);
}
+static VALUE c_alloc (VALUE klass)
+{
+ RbIdleEnterer *idle_enterer;
+
+ ecore_init ();
+
+ return Data_Make_Struct (klass, RbIdleEnterer, c_mark, c_free,
+ idle_enterer);
+}
+
/*
* call-seq:
* Ecore::IdleEnterer.new { block } => idle_enterer
* When Ecore enters the idle state, the specified block will be called.
* If the block returns false, the IdleEnterer is deleted.
*/
-static VALUE c_new (VALUE klass)
+static VALUE c_init (VALUE self)
{
- VALUE self;
- RbIdleEnterer *idle_enterer;
+ GET_OBJ (self, RbIdleEnterer, idle_enterer);
if (!rb_block_given_p ())
- return Qnil;
-
- self = Data_Make_Struct (klass, RbIdleEnterer, c_mark, c_free,
- idle_enterer);
-
- ecore_init ();
+ rb_raise (rb_eStandardError, "block missing");
idle_enterer->callback = rb_block_proc ();
idle_enterer->deleted = false;
idle_enterer->real = ecore_idle_enterer_add (on_idle_enter,
idle_enterer);
- rb_obj_call_init (self, 0, NULL);
-
return self;
}
{
VALUE c = rb_define_class_under (mEcore, "IdleEnterer", rb_cObject);
- rb_define_singleton_method (c, "new", c_new, 0);
+ rb_define_alloc_func (c, c_alloc);
+ rb_define_method (c, "initialize", c_init, 0);
rb_define_method (c, "delete", c_delete, 0);
}