Eobj: added default constructor/destructor.

When NULL is passed, the default one is called.

SVN revision: 70001
This commit is contained in:
Tom Hacohen 2012-04-11 07:05:10 +00:00
parent 61dc86ec9d
commit fc75687bc7
8 changed files with 30 additions and 72 deletions

View File

@ -17,18 +17,6 @@ _prot_print(Eobj *obj, Eobj_Op op, va_list *list)
printf("%s %d\n", __func__, pd->protected_x1); printf("%s %d\n", __func__, pd->protected_x1);
} }
static void
_constructor(Eobj *obj)
{
eobj_constructor_super(obj);
}
static void
_destructor(Eobj *obj)
{
eobj_destructor_super(obj);
}
static void static void
_class_constructor(Eobj_Class *klass) _class_constructor(Eobj_Class *klass)
{ {
@ -56,8 +44,8 @@ inherit_class_get(void)
EOBJ_CLASS_DESCRIPTION_OPS(&INHERIT_BASE_ID, op_desc, INHERIT_SUB_ID_LAST), EOBJ_CLASS_DESCRIPTION_OPS(&INHERIT_BASE_ID, op_desc, INHERIT_SUB_ID_LAST),
NULL, NULL,
0, 0,
_constructor, NULL,
_destructor, NULL,
_class_constructor, _class_constructor,
NULL NULL
}; };

View File

@ -31,18 +31,6 @@ _a_set(Eobj *obj, Eobj_Op op, va_list *list)
eobj_event_callback_call(obj, SIG_A_CHANGED, &pd->a); eobj_event_callback_call(obj, SIG_A_CHANGED, &pd->a);
} }
static void
_constructor(Eobj *obj)
{
eobj_constructor_super(obj);
}
static void
_destructor(Eobj *obj)
{
eobj_destructor_super(obj);
}
static void static void
_class_constructor(Eobj_Class *klass) _class_constructor(Eobj_Class *klass)
{ {
@ -75,8 +63,8 @@ simple_class_get(void)
EOBJ_CLASS_DESCRIPTION_OPS(&SIMPLE_BASE_ID, op_desc, SIMPLE_SUB_ID_LAST), EOBJ_CLASS_DESCRIPTION_OPS(&SIMPLE_BASE_ID, op_desc, SIMPLE_SUB_ID_LAST),
event_desc, event_desc,
sizeof(Private_Data), sizeof(Private_Data),
_constructor, NULL,
_destructor, NULL,
_class_constructor, _class_constructor,
NULL NULL
}; };

View File

@ -12,12 +12,6 @@ _constructor(Eobj *obj)
eobj_constructor_error_set(obj); eobj_constructor_error_set(obj);
} }
static void
_destructor(Eobj *obj)
{
eobj_destructor_super(obj);
}
const Eobj_Class * const Eobj_Class *
simple2_class_get(void) simple2_class_get(void)
{ {
@ -30,7 +24,7 @@ simple2_class_get(void)
NULL, NULL,
0, 0,
_constructor, _constructor,
_destructor, NULL,
NULL, NULL,
NULL NULL
}; };

View File

@ -10,12 +10,6 @@ _constructor(Eobj *obj)
(void) obj; (void) obj;
} }
static void
_destructor(Eobj *obj)
{
eobj_destructor_super(obj);
}
const Eobj_Class * const Eobj_Class *
simple3_class_get(void) simple3_class_get(void)
{ {
@ -28,7 +22,7 @@ simple3_class_get(void)
NULL, NULL,
0, 0,
_constructor, _constructor,
_destructor, NULL,
NULL, NULL,
NULL NULL
}; };

View File

@ -5,18 +5,6 @@
static Eobj_Class *_my_class = NULL; static Eobj_Class *_my_class = NULL;
static void
_constructor(Eobj *obj)
{
eobj_constructor_super(obj);
}
static void
_destructor(Eobj *obj)
{
eobj_destructor_super(obj);
}
const Eobj_Class * const Eobj_Class *
simple4_class_get(void) simple4_class_get(void)
{ {
@ -28,8 +16,8 @@ simple4_class_get(void)
EOBJ_CLASS_DESCRIPTION_OPS(NULL, NULL, 0), EOBJ_CLASS_DESCRIPTION_OPS(NULL, NULL, 0),
NULL, NULL,
0, 0,
_constructor, NULL,
_destructor, NULL,
NULL, NULL,
NULL NULL
}; };

View File

@ -39,17 +39,6 @@ _constructor(Eobj *obj)
eobj_evas_object_set(obj, wd->bx); eobj_evas_object_set(obj, wd->bx);
} }
static void
_destructor(Eobj *obj)
{
eobj_destructor_super(obj);
//Widget_Data *wd = eobj_data_get(obj, _my_class);
/* FIXME: Commented out because it's automatically done because our tree
* is not made of only eobj */
// evas_object_del(wd->bx);
}
static void static void
_class_constructor(Eobj_Class *klass) _class_constructor(Eobj_Class *klass)
{ {
@ -78,7 +67,7 @@ elw_box_class_get(void)
NULL, NULL,
sizeof(Widget_Data), sizeof(Widget_Data),
_constructor, _constructor,
_destructor, NULL,
_class_constructor, _class_constructor,
NULL NULL
}; };

View File

@ -87,6 +87,7 @@ EAPI Eina_Bool eobj_init(void);
EAPI Eina_Bool eobj_shutdown(void); EAPI Eina_Bool eobj_shutdown(void);
#define eobj_do(object, ...) eobj_do_internal(object, __VA_ARGS__, NULL) #define eobj_do(object, ...) eobj_do_internal(object, __VA_ARGS__, NULL)
/* FIXME: Change this to SUPER as well. */
#define eobj_class_do(object, klass, ...) eobj_class_do_internal(object, klass, __VA_ARGS__, NULL) #define eobj_class_do(object, klass, ...) eobj_class_do_internal(object, klass, __VA_ARGS__, NULL)
#define eobj_class_parent_do(object, klass, ...) eobj_class_do_internal(object, eobj_class_parent_get(klass), __VA_ARGS__, NULL) #define eobj_class_parent_do(object, klass, ...) eobj_class_do_internal(object, eobj_class_parent_get(klass), __VA_ARGS__, NULL)

View File

@ -439,8 +439,6 @@ eobj_class_new(const Eobj_Class_Description *desc, const Eobj_Class *parent, ...
_CLS_NEW_CHECK(desc); _CLS_NEW_CHECK(desc);
_CLS_NEW_CHECK(desc->name); _CLS_NEW_CHECK(desc->name);
_CLS_NEW_CHECK(desc->constructor);
_CLS_NEW_CHECK(desc->destructor);
klass = calloc(1, sizeof(Eobj_Class)); klass = calloc(1, sizeof(Eobj_Class));
klass->parent = parent; klass->parent = parent;
@ -660,6 +658,18 @@ eobj_constructor_error_get(const Eobj *obj)
return (intptr_t) eobj_generic_data_get(obj, CONSTRUCT_ERROR_KEY); return (intptr_t) eobj_generic_data_get(obj, CONSTRUCT_ERROR_KEY);
} }
static inline void
_eobj_constructor_default(Eobj *obj)
{
eobj_constructor_super(obj);
}
static inline void
_eobj_destructor_default(Eobj *obj)
{
eobj_destructor_super(obj);
}
static void static void
eobj_class_constructor(Eobj *obj, const Eobj_Class *klass) eobj_class_constructor(Eobj *obj, const Eobj_Class *klass)
{ {
@ -677,7 +687,10 @@ eobj_class_constructor(Eobj *obj, const Eobj_Class *klass)
extn->klass->desc->constructor(obj); extn->klass->desc->constructor(obj);
} }
klass->desc->constructor(obj); if (klass->desc->constructor)
klass->desc->constructor(obj);
else
_eobj_constructor_default(obj);
} }
static void static void
@ -690,7 +703,10 @@ eobj_class_destructor(Eobj *obj, const Eobj_Class *klass)
if (!klass) if (!klass)
return; return;
klass->desc->destructor(obj); if (klass->desc->destructor)
klass->desc->destructor(obj);
else
_eobj_destructor_default(obj);
EINA_INLIST_REVERSE_FOREACH(klass->extensions, extn) EINA_INLIST_REVERSE_FOREACH(klass->extensions, extn)
{ {