X-Git-Url: http://git.code-monkey.de/?p=ruby-ecore.git;a=blobdiff_plain;f=src%2Fecore%2Frb_idler.c;h=41f1cb30711f46892a2fb70a054f0bbd3cd57e70;hp=263b7149b4561349ed567e5f6500cd8f04e90315;hb=0f8d24c745efc1057f8d25ada1375c88a1ab2ed7;hpb=0ad70bf579b712a8bf770e2775cffa4a50097557 diff --git a/src/ecore/rb_idler.c b/src/ecore/rb_idler.c index 263b714..41f1cb3 100644 --- a/src/ecore/rb_idler.c +++ b/src/ecore/rb_idler.c @@ -1,6 +1,4 @@ /* - * $Id: rb_idler.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 @@ -62,6 +60,15 @@ static void c_free (RbIdler *idler) free (idler); } +static VALUE c_alloc (VALUE klass) +{ + RbIdler *idler; + + ecore_init (); + + return Data_Make_Struct (klass, RbIdler, c_mark, c_free, idler); +} + /* * call-seq: * Ecore::Idler.new { block } => idler @@ -70,24 +77,17 @@ static void c_free (RbIdler *idler) * When Ecore is idle, the specified block will be called. * If the block returns false, the idler is deleted. */ -static VALUE c_new (VALUE klass) +static VALUE c_init (VALUE self) { - VALUE self; - RbIdler *idler; + GET_OBJ (self, RbIdler, idler); if (!rb_block_given_p ()) - return Qnil; - - self = Data_Make_Struct (klass, RbIdler, c_mark, c_free, idler); - - ecore_init (); + rb_raise (rb_eStandardError, "block missing"); idler->callback = rb_block_proc (); idler->deleted = false; idler->real = ecore_idler_add (on_idler, idler); - rb_obj_call_init (self, 0, NULL); - return self; } @@ -115,6 +115,7 @@ void Init_Idler (void) { VALUE c = rb_define_class_under (mEcore, "Idler", rb_cObject); - rb_define_singleton_method (c, "new", c_new, 1); + rb_define_alloc_func (c, c_alloc); + rb_define_method (c, "initialize", c_init, 0); rb_define_method (c, "delete", c_delete, 0); }