/*
- * $Id$
+ * $Id: rb_idler.c 40 2004-07-25 13:14:34Z tilman $
*
* Copyright (C) 2004 Tilman Sauerbeck (tilman at code-monkey de)
*
bool deleted;
} RbEcoreIdler;
-VALUE cIdler;
-
static int on_idler (void *data)
{
VALUE r;
return (r != Qfalse);
}
-static VALUE c_init (VALUE self)
-{
- RbEcoreIdler *idler = NULL;
-
- Data_Get_Struct (self, RbEcoreIdler, idler);
-
- idler->cb = (void *) rb_block_proc ();
- idler->idler = ecore_idler_add (on_idler, idler);
-
- return self;
-}
-
static void c_free (RbEcoreIdler *idler)
{
if (idler->idler && !idler->deleted)
ecore_idler_del (idler->idler);
+ ecore_shutdown ();
+
free (idler);
}
VALUE self;
RbEcoreIdler *idler;
+ if (!rb_block_given_p ())
+ return Qnil;
+
self = Data_Make_Struct (klass, RbEcoreIdler, NULL, c_free, idler);
+ ecore_init ();
+
+ idler->cb = (void *) rb_block_proc ();
+ idler->idler = ecore_idler_add (on_idler, idler);
+
rb_obj_call_init (self, 0, NULL);
return self;
void Init_Idler (void)
{
- cIdler = rb_define_class_under (mEcore, "Idler", rb_cObject);
+ VALUE c = rb_define_class_under (mEcore, "Idler", rb_cObject);
- rb_define_singleton_method (cIdler, "new", c_new, 1);
- rb_define_method (cIdler, "initialize", c_init, 1);
- rb_define_method (cIdler, "delete", c_delete, 0);
+ rb_define_singleton_method (c, "new", c_new, 1);
+ rb_define_method (c, "delete", c_delete, 0);
}
-