cedric pushed a commit to branch master.
commit dcf65a8eec5c93b4e45c92a4582143706723657a
Author: Cedric Bail <[email protected]>
Date: Fri Jun 28 15:28:30 2013 +0900
eo: add a new macro to make the code easier to read and use it.
---
src/lib/eo/Eo.h | 12 ++++++
src/lib/eo/eo_base_class.c | 92 ++++++++++++++++++++++++++++------------------
2 files changed, 68 insertions(+), 36 deletions(-)
diff --git a/src/lib/eo/Eo.h b/src/lib/eo/Eo.h
index 1e73d16..09d9339 100644
--- a/src/lib/eo/Eo.h
+++ b/src/lib/eo/Eo.h
@@ -513,6 +513,18 @@ typedef struct _Eo_Class_Description Eo_Class_Description;
#define EO_OP_DESCRIPTION_SENTINEL { 0, NULL, NULL, EO_OP_TYPE_INVALID }
/**
+ * @def EO_PARAMETER_GET
+ * An helper macro to get parameter with less mistake
+ */
+#define EO_PARAMETER_GET(Type, Name, List) Type Name = va_arg(*List, Type);
+
+/**
+ * @def EO_PARAMETER_ENUM_GET
+ * An helper macro to get parameter that are enum with less mistake (require
to ask an int)
+ */
+#define EO_PARAMETER_ENUM_GET(Type, Name, List) Type Name = va_arg(*List, int);
+
+/**
* @brief Create a new class.
* @param desc the class description to create the class with.
* @param parent the class to inherit from.
diff --git a/src/lib/eo/eo_base_class.c b/src/lib/eo/eo_base_class.c
index d87bcff..49cfe7f 100644
--- a/src/lib/eo/eo_base_class.c
+++ b/src/lib/eo/eo_base_class.c
@@ -61,9 +61,10 @@ static void
_data_set(Eo *obj, void *class_data, va_list *list)
{
Private_Data *pd = class_data;
- const char *key = va_arg(*list, const char *);
- const void *data = va_arg(*list, const void *);
- eo_base_data_free_func free_func = va_arg(*list, eo_base_data_free_func);
+
+ EO_PARAMETER_GET(const char *, key, list);
+ EO_PARAMETER_GET(const void *, data, list);
+ EO_PARAMETER_GET(eo_base_data_free_func, free_func, list);
Eo_Generic_Data_Node *node;
@@ -83,10 +84,11 @@ static void
_data_get(Eo *obj EINA_UNUSED, void *class_data, va_list *list)
{
/* We don't really change it... */
- Private_Data *pd = (Private_Data *) class_data;
- const char *key = va_arg(*list, const char *);
- void **data = va_arg(*list, void **);
Eo_Generic_Data_Node *node;
+ Private_Data *pd = (Private_Data *) class_data;
+
+ EO_PARAMETER_GET(const char *, key, list);
+ EO_PARAMETER_GET(void **, data, list);
if (!data) return;
*data = NULL;
@@ -115,10 +117,10 @@ _dbg_info_get(Eo *obj EINA_UNUSED, void *class_data
EINA_UNUSED,
static void
_data_del(Eo *obj EINA_UNUSED, void *class_data, va_list *list)
{
+ Eo_Generic_Data_Node *node;
Private_Data *pd = class_data;
- const char *key = va_arg(*list, const char *);
- Eo_Generic_Data_Node *node;
+ EO_PARAMETER_GET(const char *, key, list);
if (!key) return;
@@ -155,7 +157,8 @@ _wref_add(Eo *obj, void *class_data, va_list *list)
{
Private_Data *pd = (Private_Data *) class_data;
size_t count;
- Eo **wref = va_arg(*list, Eo **);
+
+ EO_PARAMETER_GET(Eo **, wref, list);
count = _wref_count(pd);
count += 1; /* New wref. */
@@ -172,7 +175,9 @@ _wref_del(Eo *obj, void *class_data, va_list *list)
{
Private_Data *pd = (Private_Data *) class_data;
size_t count;
- Eo **wref = va_arg(*list, Eo **);
+
+ EO_PARAMETER_GET(Eo **, wref, list);
+
if (*wref != obj)
{
ERR("Wref is a weak ref to %p, while this function was called on %p.",
@@ -356,13 +361,15 @@ _eo_callbacks_sorted_insert(Private_Data *pd,
Eo_Callback_Description *cb)
static void
_ev_cb_priority_add(Eo *obj, void *class_data, va_list *list)
{
+ Eo_Callback_Description *cb;
Private_Data *pd = (Private_Data *) class_data;
- const Eo_Event_Description *desc = va_arg(*list, const Eo_Event_Description
*);
- Eo_Callback_Priority priority = va_arg(*list, int);
- Eo_Event_Cb func = va_arg(*list, Eo_Event_Cb);
- const void *data = va_arg(*list, const void *);
- Eo_Callback_Description *cb = calloc(1, sizeof(*cb));
+ EO_PARAMETER_GET(const Eo_Event_Description *, desc, list);
+ EO_PARAMETER_ENUM_GET(Eo_Callback_Priority, priority, list);
+ EO_PARAMETER_GET(Eo_Event_Cb, func, list);
+ EO_PARAMETER_GET(const void *, data, list);
+
+ cb = calloc(1, sizeof(*cb));
cb->items.item.desc = desc;
cb->items.item.func = func;
cb->func_data = (void *) data;
@@ -378,12 +385,13 @@ _ev_cb_priority_add(Eo *obj, void *class_data, va_list
*list)
static void
_ev_cb_del(Eo *obj, void *class_data, va_list *list)
{
+ Eo_Callback_Description *cb;
Private_Data *pd = (Private_Data *) class_data;
- const Eo_Event_Description *desc = va_arg(*list, const Eo_Event_Description
*);
- Eo_Event_Cb func = va_arg(*list, Eo_Event_Cb);
- void *user_data = va_arg(*list, void *);
- Eo_Callback_Description *cb;
+ EO_PARAMETER_GET(const Eo_Event_Description *, desc, list);
+ EO_PARAMETER_GET(Eo_Event_Cb, func, list);
+ EO_PARAMETER_GET(void *, user_data, list);
+
for (cb = pd->callbacks ; cb ; cb = cb->next)
{
if ((cb->items.item.desc == desc) && (cb->items.item.func == func) &&
@@ -405,12 +413,14 @@ _ev_cb_del(Eo *obj, void *class_data, va_list *list)
static void
_ev_cb_array_priority_add(Eo *obj, void *class_data, va_list *list)
{
+ Eo_Callback_Description *cb;
Private_Data *pd = (Private_Data *) class_data;
- const Eo_Callback_Array_Item *array = va_arg(*list, const
Eo_Callback_Array_Item *);
- Eo_Callback_Priority priority = va_arg(*list, int);
- const void *data = va_arg(*list, const void *);
- Eo_Callback_Description *cb = calloc(1, sizeof(*cb));
+ EO_PARAMETER_GET(const Eo_Callback_Array_Item *, array, list);
+ EO_PARAMETER_ENUM_GET(Eo_Callback_Priority, priority, list);
+ EO_PARAMETER_GET(const void *, data, list);
+
+ cb = calloc(1, sizeof(*cb));
cb->func_data = (void *) data;
cb->priority = priority;
cb->items.item_array = array;
@@ -425,11 +435,12 @@ _ev_cb_array_priority_add(Eo *obj, void *class_data,
va_list *list)
static void
_ev_cb_array_del(Eo *obj, void *class_data, va_list *list)
{
+ Eo_Callback_Description *cb;
Private_Data *pd = (Private_Data *) class_data;
- const Eo_Callback_Array_Item *array = va_arg(*list, const
Eo_Callback_Array_Item *);
- void *user_data = va_arg(*list, void *);
- Eo_Callback_Description *cb;
+ EO_PARAMETER_GET(const Eo_Callback_Array_Item *, array, list);
+ EO_PARAMETER_GET(void *, user_data, list);
+
for (cb = pd->callbacks ; cb ; cb = cb->next)
{
if ((cb->items.item_array == array) && (cb->func_data == user_data))
@@ -449,10 +460,13 @@ _ev_cb_array_del(Eo *obj, void *class_data, va_list *list)
static void
_ev_cb_call(Eo *obj_id, void *class_data, va_list *list)
{
+ Eo_Callback_Description *cb;
Private_Data *pd = (Private_Data *) class_data;
- const Eo_Event_Description *desc = va_arg(*list, const Eo_Event_Description
*);
- void *event_info = va_arg(*list, void *);
- Eina_Bool *ret = va_arg(*list, Eina_Bool *);
+
+ EO_PARAMETER_GET(const Eo_Event_Description *, desc, list);
+ EO_PARAMETER_GET(void *, event_info, list);
+ EO_PARAMETER_GET(Eina_Bool *, ret, list);
+
EO_OBJ_POINTER_RETURN(obj_id, obj);
if (ret) *ret = EINA_TRUE;
@@ -460,7 +474,6 @@ _ev_cb_call(Eo *obj_id, void *class_data, va_list *list)
_eo_ref(obj);
pd->walking_list++;
- Eo_Callback_Description *cb;
for (cb = pd->callbacks ; cb ; cb = cb->next)
{
if (!cb->delete_me)
@@ -468,6 +481,7 @@ _ev_cb_call(Eo *obj_id, void *class_data, va_list *list)
if (cb->func_array)
{
const Eo_Callback_Array_Item *it;
+
for (it = cb->items.item_array ; it->func ; it++)
{
if (it->desc != desc)
@@ -518,7 +532,9 @@ _eo_event_forwarder_callback(void *data, Eo *obj, const
Eo_Event_Description *de
(void) obj;
Eo *new_obj = (Eo *) data;
Eina_Bool ret;
+
eo_do(new_obj, eo_event_callback_call(desc, event_info, &ret));
+
return ret;
}
@@ -526,8 +542,9 @@ _eo_event_forwarder_callback(void *data, Eo *obj, const
Eo_Event_Description *de
static void
_ev_cb_forwarder_add(Eo *obj, void *class_data EINA_UNUSED, va_list *list)
{
- const Eo_Event_Description *desc = va_arg(*list, const Eo_Event_Description
*);
- Eo *new_obj = va_arg(*list, Eo *);
+ EO_PARAMETER_GET(const Eo_Event_Description *, desc, list);
+ EO_PARAMETER_GET(Eo *, new_obj, list);
+
/* FIXME: Add it EO_MAGIC_RETURN(new_obj, EO_EINA_MAGIC); */
eo_do(obj, eo_event_callback_add(desc, _eo_event_forwarder_callback,
new_obj));
@@ -536,8 +553,9 @@ _ev_cb_forwarder_add(Eo *obj, void *class_data EINA_UNUSED,
va_list *list)
static void
_ev_cb_forwarder_del(Eo *obj, void *class_data EINA_UNUSED, va_list *list)
{
- const Eo_Event_Description *desc = va_arg(*list, const Eo_Event_Description
*);
- Eo *new_obj = va_arg(*list, Eo *);
+ EO_PARAMETER_GET(const Eo_Event_Description *, desc, list);
+ EO_PARAMETER_GET(Eo *, new_obj, list);
+
/* FIXME: Add it EO_MAGIC_RETURN(new_obj, EO_EINA_MAGIC); */
eo_do(obj, eo_event_callback_del(desc, _eo_event_forwarder_callback,
new_obj));
@@ -568,7 +586,8 @@ static void
_ev_freeze_get(Eo *obj EINA_UNUSED, void *class_data, va_list *list)
{
Private_Data *pd = (Private_Data *) class_data;
- int *ret = va_arg(*list, int *);
+ EO_PARAMETER_GET(int *, ret, list);
+
*ret = pd->event_freeze_count;
}
@@ -594,7 +613,8 @@ _ev_global_thaw(const Eo_Class *klass EINA_UNUSED, va_list
*list EINA_UNUSED)
static void
_ev_global_freeze_get(const Eo_Class *klass EINA_UNUSED, va_list *list)
{
- int *ret = va_arg(*list, int *);
+ EO_PARAMETER_GET(int *, ret, list);
+
*ret = event_freeze_count;
}
--
------------------------------------------------------------------------------
This SF.net email is sponsored by Windows:
Build for Windows Store.
http://p.sf.net/sfu/windows-dev2dev