jackdanielz pushed a commit to branch master. http://git.enlightenment.org/core/elementary.git/commit/?id=6cd9f5550aba7d814b1f005be9935a148a80489b
commit 6cd9f5550aba7d814b1f005be9935a148a80489b Author: Daniel Zaoui <daniel.za...@samsung.com> Date: Sun Mar 30 10:57:14 2014 +0300 Eolian: Integration of Multi Button Entry --- src/lib/Makefile.am | 4 + src/lib/elc_multibuttonentry.c | 565 +++++++--------------------------- src/lib/elc_multibuttonentry.eo | 286 +++++++++++++++++ src/lib/elc_multibuttonentry_eo.h | 4 + src/lib/elm_widget_multibuttonentry.h | 10 +- 5 files changed, 405 insertions(+), 464 deletions(-) diff --git a/src/lib/Makefile.am b/src/lib/Makefile.am index 20e9d90..de387b8 100644 --- a/src/lib/Makefile.am +++ b/src/lib/Makefile.am @@ -621,6 +621,8 @@ BUILT_SOURCES = \ elm_map.eo.h \ elm_menu.eo.c \ elm_menu.eo.h \ + elc_multibuttonentry.eo.c \ + elc_multibuttonentry.eo.h \ elm_panel.eo.c \ elm_panel.eo.h \ elm_mapbuf.eo.c \ @@ -727,6 +729,7 @@ EXTRA_DIST += \ elm_map_pan.eo \ elm_map.eo \ elm_menu.eo \ + elc_multibuttonentry.eo \ elm_panel.eo \ elm_mapbuf.eo \ elm_notify.eo \ @@ -805,6 +808,7 @@ nodist_includesunstable_HEADERS = \ elm_map_pan.eo.h \ elm_map.eo.h \ elm_menu.eo.h \ + elc_multibuttonentry.eo.h \ elm_panel.eo.h \ elm_mapbuf.eo.h \ elm_notify.eo.h \ diff --git a/src/lib/elc_multibuttonentry.c b/src/lib/elc_multibuttonentry.c index ed9953e..dad7367 100644 --- a/src/lib/elc_multibuttonentry.c +++ b/src/lib/elc_multibuttonentry.c @@ -6,8 +6,6 @@ #include "elm_priv.h" #include "elm_widget_multibuttonentry.h" -EAPI Eo_Op ELM_OBJ_MULTIBUTTONENTRY_BASE_ID = EO_NOOP; - #define MY_CLASS ELM_OBJ_MULTIBUTTONENTRY_CLASS #define MY_CLASS_NAME "Elm_Multibuttonentry" @@ -41,11 +39,9 @@ static const Evas_Smart_Cb_Description _smart_callbacks[] = { {NULL, NULL} }; -static void -_elm_multibuttonentry_smart_translate(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_translate(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - Elm_Multibuttonentry_Smart_Data *sd = _pd; Elm_Multibuttonentry_Item *it; Eina_List *l; @@ -54,7 +50,7 @@ _elm_multibuttonentry_smart_translate(Eo *obj EINA_UNUSED, void *_pd, va_list *l eo_do_super(obj, MY_CLASS, elm_obj_widget_translate(NULL)); - if (ret) *ret = EINA_TRUE; + return EINA_TRUE; } static char * @@ -66,20 +62,15 @@ _format_count(int count, void *data EINA_UNUSED) return strdup(buf); } -static void -_elm_multibuttonentry_smart_theme(Eo *obj, void *_pd, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_theme_apply(Eo *obj, Elc_Multibuttonentry_Data *sd) { Eina_List *l; Elm_Multibuttonentry_Item *item; - Elm_Multibuttonentry_Smart_Data *sd = _pd; - Eina_Bool int_ret; - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - if (ret) *ret = EINA_FALSE; - eo_do_super(obj, MY_CLASS, elm_obj_widget_theme_apply(&int_ret)); - if (!int_ret) return; + if (!int_ret) return EINA_FALSE; EINA_LIST_FOREACH(sd->items, l, item) { @@ -93,7 +84,7 @@ _elm_multibuttonentry_smart_theme(Eo *obj, void *_pd, va_list *list) elm_layout_sizing_eval(obj); - if (ret) *ret = EINA_TRUE; + return EINA_TRUE; } static void @@ -271,7 +262,7 @@ _shrink_mode_set(Evas_Object *obj, } static void -_view_update(Elm_Multibuttonentry_Smart_Data *sd) +_view_update(Elc_Multibuttonentry_Data *sd) { Evas_Coord width = 1, height = 1; Evas_Object *obj = sd->parent; @@ -301,14 +292,9 @@ _view_update(Elm_Multibuttonentry_Smart_Data *sd) _visual_guide_text_set(obj); } -static void -_elm_multibuttonentry_smart_on_focus(Eo *obj, void *_pd, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_on_focus(Eo *obj, Elc_Multibuttonentry_Data *sd) { - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - if (ret) *ret = EINA_FALSE; - if (elm_widget_focus_get(obj)) { // ACCESS @@ -338,7 +324,7 @@ _elm_multibuttonentry_smart_on_focus(Eo *obj, void *_pd, va_list *list) } end: - if (ret) *ret = EINA_TRUE; + return EINA_TRUE; } static void @@ -647,7 +633,7 @@ _access_multibuttonentry_item_register(Evas_Object *obj, } static Elm_Object_Item * -_button_item_add(Elm_Multibuttonentry_Smart_Data *sd, +_button_item_add(Elc_Multibuttonentry_Data *sd, const char *str, Multibuttonentry_Pos pos, const void *ref, @@ -844,32 +830,25 @@ _button_item_add(Elm_Multibuttonentry_Smart_Data *sd, //FIXME: having an empty event handling function and reacting on Evas //events on specific objects is crazy, someone should fix that. -static void -_elm_multibuttonentry_smart_event(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_event(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd EINA_UNUSED, Evas_Object *src, Evas_Callback_Type type, void *ev) { - Evas_Object *src = va_arg(*list, Evas_Object *); - Evas_Callback_Type type = va_arg(*list, Evas_Callback_Type); - void *ev = va_arg(*list, void *); - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - - if (ret) *ret = EINA_FALSE; (void)src; (void)type; (void)ev; // ACCESS - if (_elm_config->access_mode == ELM_ACCESS_MODE_ON) return; + if (_elm_config->access_mode == ELM_ACCESS_MODE_ON) return EINA_FALSE; - if (ret) *ret = EINA_TRUE; + return EINA_TRUE; } -static void -_elm_multibuttonentry_smart_sizing_eval(Eo *obj, void *_pd, va_list *list EINA_UNUSED) +EOLIAN static void +_elc_multibuttonentry_elm_layout_sizing_eval(Eo *obj, Elc_Multibuttonentry_Data *sd) { Evas_Coord minw = -1, minh = -1; Evas_Coord left, right, top, bottom; - Elm_Multibuttonentry_Smart_Data *sd = _pd; ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd); evas_object_size_hint_min_get(sd->box, &minw, &minh); @@ -891,7 +870,7 @@ _mouse_clicked_signal_cb(void *data, const char *emission EINA_UNUSED, const char *source EINA_UNUSED) { - Elm_Multibuttonentry_Smart_Data *sd = data; + Elc_Multibuttonentry_Data *sd = data; _view_update(sd); @@ -1352,7 +1331,7 @@ _box_layout_cb(Evas_Object *o, } static void -_view_init(Evas_Object *obj, Elm_Multibuttonentry_Smart_Data *sd) +_view_init(Evas_Object *obj, Elc_Multibuttonentry_Data *sd) { sd->box = elm_box_add(obj); @@ -1403,12 +1382,9 @@ _view_init(Evas_Object *obj, Elm_Multibuttonentry_Smart_Data *sd) } } -static void -_elm_multibuttonentry_smart_text_set(Eo *obj, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_layout_text_set(Eo *obj, Elc_Multibuttonentry_Data *sd EINA_UNUSED, const char *part, const char *label) { - const char *part = va_arg(*list, const char *); - const char *label = va_arg(*list, const char *); - Eina_Bool *ret = va_arg(*list, Eina_Bool *); Eina_Bool int_ret; if (!part || !strcmp(part, "default")) @@ -1424,27 +1400,26 @@ _elm_multibuttonentry_smart_text_set(Eo *obj, void *_pd EINA_UNUSED, va_list *li else eo_do_super(obj, MY_CLASS, elm_obj_layout_text_set(part, label, &int_ret)); - if (ret) *ret = int_ret; + return int_ret; } -static void -_elm_multibuttonentry_smart_text_get(Eo *obj, void *_pd, va_list *list) +EOLIAN static const char* +_elc_multibuttonentry_elm_layout_text_get(Eo *obj, Elc_Multibuttonentry_Data *sd, const char *part) { - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - const char *part = va_arg(*list, const char *); - const char **text = va_arg(*list, const char **); + const char *text = NULL; if (!part || !strcmp(part, "default")) { - *text = sd->label_str; + text = sd->label_str; } else if (!strcmp(part, "guide")) { - *text = sd->guide_text_str; + text = sd->guide_text_str; } else - eo_do_super(obj, MY_CLASS, elm_obj_layout_text_get(part, text)); + eo_do_super(obj, MY_CLASS, elm_obj_layout_text_get(part, &text)); + + return text; } static char * @@ -1485,10 +1460,9 @@ _access_info_cb(void *data EINA_UNUSED, Evas_Object *obj) return ret; } -static void -_elm_multibuttonentry_smart_add(Eo *obj, void *_pd, va_list *list EINA_UNUSED) +EOLIAN static void +_elc_multibuttonentry_evas_smart_add(Eo *obj, Elc_Multibuttonentry_Data *priv) { - Elm_Multibuttonentry_Smart_Data *priv = _pd; ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd); eo_do_super(obj, MY_CLASS, evas_obj_smart_add()); @@ -1516,13 +1490,11 @@ _elm_multibuttonentry_smart_add(Eo *obj, void *_pd, va_list *list EINA_UNUSED) (_elm_access_info_get(obj), ELM_ACCESS_INFO, _access_info_cb, NULL); } -static void -_elm_multibuttonentry_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED) +EOLIAN static void +_elc_multibuttonentry_evas_smart_del(Eo *obj, Elc_Multibuttonentry_Data *sd) { Elm_Multibuttonentry_Item *item; - Elm_Multibuttonentry_Smart_Data *sd = _pd; - EINA_LIST_FREE(sd->items, item) { evas_object_del(item->button); @@ -1544,27 +1516,21 @@ _elm_multibuttonentry_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED) static Eina_Bool _elm_multibuttonentry_smart_focus_next_enable = EINA_FALSE; -static void -_elm_multibuttonentry_smart_focus_direction_manager_is(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_focus_direction_manager_is(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd EINA_UNUSED) { - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - *ret = EINA_FALSE; + return EINA_FALSE; } -static void -_elm_multibuttonentry_smart_focus_next_manager_is(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_focus_next_manager_is(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd EINA_UNUSED) { - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - *ret = _elm_multibuttonentry_smart_focus_next_enable; + return _elm_multibuttonentry_smart_focus_next_enable; } -static void -_elm_multibuttonentry_smart_focus_next(Eo *obj, void *_pd, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_elm_widget_focus_next(Eo *obj, Elc_Multibuttonentry_Data *sd, Elm_Focus_Direction dir, Evas_Object **next) { - Elm_Focus_Direction dir = va_arg(*list, Elm_Focus_Direction); - Evas_Object **next = va_arg(*list, Evas_Object **); - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - if (ret) *ret = EINA_FALSE; Eina_Bool int_ret = EINA_FALSE; Eina_List *items = NULL; @@ -1573,13 +1539,10 @@ _elm_multibuttonentry_smart_focus_next(Eo *obj, void *_pd, va_list *list) Evas_Object *ao; Evas_Object *po; - Elm_Multibuttonentry_Smart_Data *sd = _pd; - if (!elm_widget_focus_get(obj)) { *next = (Evas_Object *)obj; - if (ret) *ret = EINA_TRUE; - return; + return EINA_TRUE; } if (sd->label) @@ -1608,9 +1571,11 @@ _elm_multibuttonentry_smart_focus_next(Eo *obj, void *_pd, va_list *list) items = eina_list_append(items, sd->box); } - if (int_ret && ret) - *ret = elm_widget_focus_list_next_get + if (int_ret) + return elm_widget_focus_list_next_get (obj, items, eina_list_data_get, dir, next); + + return EINA_FALSE; } static void @@ -1629,10 +1594,10 @@ _access_obj_process(Evas_Object *obj, Eina_Bool is_access) _access_multibuttonentry_item_register(obj, it, is_access); } -static void -_elm_multibuttonentry_smart_access(Eo *obj, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static void +_elc_multibuttonentry_elm_widget_access(Eo *obj, Elc_Multibuttonentry_Data *sd EINA_UNUSED, Eina_Bool acs) { - _elm_multibuttonentry_smart_focus_next_enable = va_arg(*list, int); + _elm_multibuttonentry_smart_focus_next_enable = acs; _access_obj_process(obj, _elm_multibuttonentry_smart_focus_next_enable); } @@ -1645,8 +1610,8 @@ elm_multibuttonentry_add(Evas_Object *parent) return obj; } -static void -_constructor(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED) +EOLIAN static void +_elc_multibuttonentry_eo_base_constructor(Eo *obj, Elc_Multibuttonentry_Data *sd EINA_UNUSED) { eo_do_super(obj, MY_CLASS, eo_constructor()); eo_do(obj, @@ -1654,83 +1619,33 @@ _constructor(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED) evas_obj_smart_callbacks_descriptions_set(_smart_callbacks, NULL)); } -EAPI Evas_Object * -elm_multibuttonentry_entry_get(const Evas_Object *obj) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj) NULL; - Evas_Object *ret = NULL; - eo_do((Eo *) obj, elm_obj_multibuttonentry_entry_get(&ret)); - return ret; -} - -static void -_entry_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) -{ - Evas_Object **ret = va_arg(*list, Evas_Object **); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = sd->entry; -} - -EAPI Eina_Bool -elm_multibuttonentry_expanded_get(const Evas_Object *obj) +EOLIAN static Evas_Object* +_elc_multibuttonentry_entry_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - ELM_MULTIBUTTONENTRY_CHECK(obj) EINA_FALSE; - Eina_Bool ret = EINA_FALSE; - eo_do((Eo *) obj, elm_obj_multibuttonentry_expanded_get(&ret)); - return ret; + return sd->entry; } -static void -_expanded_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static Eina_Bool +_elc_multibuttonentry_expanded_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = sd->view_state == MULTIBUTTONENTRY_VIEW_SHRINK ? + return sd->view_state == MULTIBUTTONENTRY_VIEW_SHRINK ? EINA_FALSE : EINA_TRUE; } -EAPI void -elm_multibuttonentry_format_function_set(Evas_Object *obj, - Elm_Multibuttonentry_Format_Cb f_func, - const void *data) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj); - - eo_do((Eo *) obj, elm_obj_multibuttonentry_format_function_set - (f_func, data)); - -} - -static void -_format_function_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static void +_elc_multibuttonentry_format_function_set(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Elm_Multibuttonentry_Format_Cb f_func, const void *data) { - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - sd->format_func = va_arg(*list, Elm_Multibuttonentry_Format_Cb); - + sd->format_func = f_func; if (!sd->format_func) sd->format_func = _format_count; - sd->format_func_data = va_arg(*list, void *); + sd->format_func_data = data; _view_update(sd); } -EAPI void -elm_multibuttonentry_expanded_set(Evas_Object *obj, - Eina_Bool expanded) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj); - eo_do(obj, elm_obj_multibuttonentry_expanded_set(expanded)); -} - -static void -_expanded_set(Eo *obj, void *_pd, va_list *list) +EOLIAN static void +_elc_multibuttonentry_expanded_set(Eo *obj, Elc_Multibuttonentry_Data *sd, Eina_Bool expanded) { - Eina_Bool expanded = va_arg(*list, int); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - if (((sd->view_state == MULTIBUTTONENTRY_VIEW_SHRINK) ? EINA_FALSE : EINA_TRUE) == expanded) return; @@ -1740,20 +1655,9 @@ _expanded_set(Eo *obj, void *_pd, va_list *list) _shrink_mode_set(obj, EINA_TRUE); } -EAPI void -elm_multibuttonentry_editable_set(Evas_Object *obj, - Eina_Bool editable) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj); - eo_do(obj, elm_obj_multibuttonentry_editable_set(editable)); -} - -static void -_editable_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static void +_elc_multibuttonentry_editable_set(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Eina_Bool editable) { - Eina_Bool editable = va_arg(*list, int); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - editable = !!editable; if (sd->editable == editable) return; sd->editable = editable; @@ -1767,194 +1671,58 @@ _editable_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list) } } -EAPI Eina_Bool -elm_multibuttonentry_editable_get(const Evas_Object *obj) +EOLIAN static Eina_Bool +_elc_multibuttonentry_editable_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - ELM_MULTIBUTTONENTRY_CHECK(obj) - 1; - Eina_Bool ret = EINA_FALSE; - eo_do((Eo *) obj, elm_obj_multibuttonentry_editable_get(&ret)); - return ret; + return sd->editable; } -static void -_editable_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_item_prepend(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, const char *label, Evas_Smart_Cb func, void *data) { - Eina_Bool *ret = va_arg(*list, Eina_Bool *); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = sd->editable; + return _button_item_add(sd, label, MULTIBUTTONENTRY_POS_START, NULL, func, data); } -EAPI Elm_Object_Item * -elm_multibuttonentry_item_prepend(Evas_Object *obj, - const char *label, - Evas_Smart_Cb func, - void *data) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_item_append(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, const char *label, Evas_Smart_Cb func, void *data) { - Elm_Object_Item *ret = NULL; - eo_do(obj, elm_obj_multibuttonentry_item_prepend(label, func, data, &ret)); - return ret; + return _button_item_add(sd, label, MULTIBUTTONENTRY_POS_END, NULL, func, data); } -static void -_item_prepend(Eo *obj, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_item_insert_before(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Elm_Object_Item *before, const char *label, Evas_Smart_Cb func, void *data) { - const char *label = va_arg(*list, const char *); - Evas_Smart_Cb func = va_arg(*list, Evas_Smart_Cb); - void *data = va_arg(*list, void *); - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - *ret = NULL; - - ELM_MULTIBUTTONENTRY_DATA_GET_OR_RETURN(obj, sd); - *ret = _button_item_add(sd, label, MULTIBUTTONENTRY_POS_START, NULL, func, data); + return _button_item_add(sd, label, MULTIBUTTONENTRY_POS_BEFORE, before, func, data); } -EAPI Elm_Object_Item * -elm_multibuttonentry_item_append(Evas_Object *obj, - const char *label, - Evas_Smart_Cb func, - void *data) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_item_insert_after(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Elm_Object_Item *after, const char *label, Evas_Smart_Cb func, void *data) { - Elm_Object_Item *ret = NULL; - eo_do(obj, elm_obj_multibuttonentry_item_append(label, func, data, &ret)); - return ret; + return _button_item_add(sd, label, MULTIBUTTONENTRY_POS_AFTER, after, func, data); } -static void -_item_append(Eo *obj, void *_pd EINA_UNUSED, va_list *list) +EOLIAN static const Eina_List* +_elc_multibuttonentry_items_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - const char *label = va_arg(*list, const char *); - Evas_Smart_Cb func = va_arg(*list, Evas_Smart_Cb); - void *data = va_arg(*list, void *); - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - *ret = NULL; - - ELM_MULTIBUTTONENTRY_DATA_GET_OR_RETURN(obj, sd); - *ret = _button_item_add(sd, label, MULTIBUTTONENTRY_POS_END, NULL, func, data); + return sd->items; } -EAPI Elm_Object_Item * -elm_multibuttonentry_item_insert_before(Evas_Object *obj, - Elm_Object_Item *before, - const char *label, - Evas_Smart_Cb func, - void *data) -{ - Elm_Object_Item *ret = NULL; - eo_do(obj, elm_obj_multibuttonentry_item_insert_before(before, label, func, data, &ret)); - return ret; -} - -static void -_item_insert_before(Eo *obj, void *_pd EINA_UNUSED, va_list *list) -{ - Elm_Object_Item *before = va_arg(*list, Elm_Object_Item *); - const char *label = va_arg(*list, const char *); - Evas_Smart_Cb func = va_arg(*list, Evas_Smart_Cb); - void *data = va_arg(*list, void *); - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - *ret = NULL; - - ELM_MULTIBUTTONENTRY_DATA_GET_OR_RETURN(obj, sd); - *ret = _button_item_add(sd, label, MULTIBUTTONENTRY_POS_BEFORE, before, func, data); -} - -EAPI Elm_Object_Item * -elm_multibuttonentry_item_insert_after(Evas_Object *obj, - Elm_Object_Item *after, - const char *label, - Evas_Smart_Cb func, - void *data) -{ - Elm_Object_Item *ret = NULL; - eo_do(obj, elm_obj_multibuttonentry_item_insert_after(after, label, func, data, &ret)); - return ret; -} - -static void -_item_insert_after(Eo *obj, void *_pd EINA_UNUSED, va_list *list) -{ - Elm_Object_Item *after = va_arg(*list, Elm_Object_Item *); - const char *label = va_arg(*list, const char *); - Evas_Smart_Cb func = va_arg(*list, Evas_Smart_Cb); - void *data = va_arg(*list, void *); - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - *ret = NULL; - - ELM_MULTIBUTTONENTRY_DATA_GET_OR_RETURN(obj, sd); - *ret = _button_item_add(sd, label, MULTIBUTTONENTRY_POS_AFTER, after, func, data); -} - -EAPI const Eina_List * -elm_multibuttonentry_items_get(const Evas_Object *obj) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj) NULL; - const Eina_List *ret = NULL; - eo_do((Eo *) obj, elm_obj_multibuttonentry_items_get(&ret)); - return ret; -} - -static void -_items_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) -{ - const Eina_List **ret = va_arg(*list, const Eina_List **); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = sd->items; -} - -EAPI Elm_Object_Item * -elm_multibuttonentry_first_item_get(const Evas_Object *obj) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj) NULL; - Elm_Object_Item *ret = NULL; - eo_do((Eo *) obj, elm_obj_multibuttonentry_first_item_get(&ret)); - return ret; -} - -static void -_first_item_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_first_item_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = eina_list_data_get(sd->items); + return eina_list_data_get(sd->items); } -EAPI Elm_Object_Item * -elm_multibuttonentry_last_item_get(const Evas_Object *obj) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_last_item_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - ELM_MULTIBUTTONENTRY_CHECK(obj) NULL; - Elm_Object_Item *ret = NULL; - eo_do((Eo *) obj, elm_obj_multibuttonentry_last_item_get(&ret)); - return ret; + return eina_list_data_get(eina_list_last(sd->items)); } -static void -_last_item_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static Elm_Object_Item* +_elc_multibuttonentry_selected_item_get(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = eina_list_data_get(eina_list_last(sd->items)); -} - -EAPI Elm_Object_Item * -elm_multibuttonentry_selected_item_get(const Evas_Object *obj) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj) NULL; - Elm_Object_Item *ret = NULL; - eo_do((Eo *) obj, elm_obj_multibuttonentry_selected_item_get(&ret)); - return ret; -} - -static void -_selected_item_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list) -{ - Elm_Object_Item **ret = va_arg(*list, Elm_Object_Item **); - Elm_Multibuttonentry_Smart_Data *sd = _pd; - - *ret = sd->selected_it; + return sd->selected_it; } EAPI void @@ -1978,18 +1746,10 @@ elm_multibuttonentry_item_selected_get(const Elm_Object_Item *it) return EINA_TRUE; } -EAPI void -elm_multibuttonentry_clear(Evas_Object *obj) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj); - eo_do(obj, elm_obj_multibuttonentry_clear()); -} - -static void -_clear(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED) +EOLIAN static void +_elc_multibuttonentry_clear(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd) { Elm_Multibuttonentry_Item *item; - Elm_Multibuttonentry_Smart_Data *sd = _pd; if (sd->items) { @@ -2060,28 +1820,13 @@ elm_multibuttonentry_item_data_set(Elm_Object_Item *it, return elm_widget_item_data_set(it, data); } -EAPI void -elm_multibuttonentry_item_filter_append(Evas_Object *obj, - Elm_Multibuttonentry_Item_Filter_Cb func, - void *data) -{ - - ELM_MULTIBUTTONENTRY_CHECK(obj); - eo_do(obj, elm_obj_multibuttonentry_item_filter_append(func, data)); -} - -static void -_item_filter_append(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static void +_elc_multibuttonentry_item_filter_append(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Elm_Multibuttonentry_Item_Filter_Cb func, void *data) { - Elm_Multibuttonentry_Item_Filter_Cb func = va_arg(*list, Elm_Multibuttonentry_Item_Filter_Cb); - void *data = va_arg(*list, void *); - Elm_Multibuttonentry_Item_Filter *new_item_filter = NULL; Elm_Multibuttonentry_Item_Filter *_item_filter = NULL; Eina_List *l; - Elm_Multibuttonentry_Smart_Data *sd = _pd; - EINA_SAFETY_ON_NULL_RETURN(func); EINA_LIST_FOREACH(sd->filter_list, l, _item_filter) @@ -2099,26 +1844,13 @@ _item_filter_append(Eo *obj EINA_UNUSED, void *_pd, va_list *list) sd->filter_list = eina_list_append(sd->filter_list, new_item_filter); } -EAPI void -elm_multibuttonentry_item_filter_prepend(Evas_Object *obj, - Elm_Multibuttonentry_Item_Filter_Cb func, - void *data) -{ - ELM_MULTIBUTTONENTRY_CHECK(obj); - eo_do(obj, elm_obj_multibuttonentry_item_filter_prepend(func, data)); -} - -static void -_item_filter_prepend(Eo *obj EINA_UNUSED, void *_pd, va_list *list) +EOLIAN static void +_elc_multibuttonentry_item_filter_prepend(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Elm_Multibuttonentry_Item_Filter_Cb func, void *data) { - Elm_Multibuttonentry_Item_Filter_Cb func = va_arg(*list, Elm_Multibuttonentry_Item_Filter_Cb); - void *data = va_arg(*list, void *); - Elm_Multibuttonentry_Item_Filter *new_item_filter = NULL; Elm_Multibuttonentry_Item_Filter *_item_filter = NULL; Eina_List *l; - Elm_Multibuttonentry_Smart_Data *sd = _pd; EINA_SAFETY_ON_NULL_RETURN(func); new_item_filter = _filter_new(func, data); @@ -2137,26 +1869,12 @@ _item_filter_prepend(Eo *obj EINA_UNUSED, void *_pd, va_list *list) sd->filter_list = eina_list_prepend(sd->filter_list, new_item_filter); } -EAPI void -elm_multibuttonentry_item_filter_remove(Evas_Object *obj, - Elm_Multibuttonentry_Item_Filter_Cb func, - void *data) +EOLIAN static void +_elc_multibuttonentry_item_filter_remove(Eo *obj EINA_UNUSED, Elc_Multibuttonentry_Data *sd, Elm_Multibuttonentry_Item_Filter_Cb func, void *data) { - ELM_MULTIBUTTONENTRY_CHECK(obj); - eo_do(obj, elm_obj_multibuttonentry_item_filter_remove(func, data)); -} - -static void -_item_filter_remove(Eo *obj EINA_UNUSED, void *_pd, va_list *list) -{ - Elm_Multibuttonentry_Item_Filter_Cb func = va_arg(*list, Elm_Multibuttonentry_Item_Filter_Cb); - void *data = va_arg(*list, void *); - Eina_List *l; Elm_Multibuttonentry_Item_Filter *item_filter; - Elm_Multibuttonentry_Smart_Data *sd = _pd; - EINA_SAFETY_ON_NULL_RETURN(func); EINA_LIST_FOREACH(sd->filter_list, l, item_filter) @@ -2172,83 +1890,12 @@ _item_filter_remove(Eo *obj EINA_UNUSED, void *_pd, va_list *list) } static void -_class_constructor(Eo_Class *klass) -{ - const Eo_Op_Func_Description func_desc[] = { - EO_OP_FUNC(EO_BASE_ID(EO_BASE_SUB_ID_CONSTRUCTOR), _constructor), - - EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_ADD), _elm_multibuttonentry_smart_add), - EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_DEL), _elm_multibuttonentry_smart_del), - - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_THEME_APPLY), _elm_multibuttonentry_smart_theme), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_TRANSLATE), _elm_multibuttonentry_smart_translate), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_EVENT), _elm_multibuttonentry_smart_event), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_ON_FOCUS), _elm_multibuttonentry_smart_on_focus), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_FOCUS_NEXT_MANAGER_IS), _elm_multibuttonentry_smart_focus_next_manager_is), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_FOCUS_NEXT), _elm_multibuttonentry_smart_focus_next), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_FOCUS_DIRECTION_MANAGER_IS), _elm_multibuttonentry_smart_focus_direction_manager_is), - EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_ACCESS), _elm_multibuttonentry_smart_access), - - EO_OP_FUNC(ELM_OBJ_LAYOUT_ID(ELM_OBJ_LAYOUT_SUB_ID_TEXT_SET), _elm_multibuttonentry_smart_text_set), - EO_OP_FUNC(ELM_OBJ_LAYOUT_ID(ELM_OBJ_LAYOUT_SUB_ID_TEXT_GET), _elm_multibuttonentry_smart_text_get), - EO_OP_FUNC(ELM_OBJ_LAYOUT_ID(ELM_OBJ_LAYOUT_SUB_ID_SIZING_EVAL), _elm_multibuttonentry_smart_sizing_eval), - - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ENTRY_GET), _entry_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EXPANDED_GET), _expanded_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EXPANDED_SET), _expanded_set), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EDITABLE_SET), _editable_set), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EDITABLE_GET), _editable_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_PREPEND), _item_prepend), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_APPEND), _item_append), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_INSERT_BEFORE), _item_insert_before), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_INSERT_AFTER), _item_insert_after), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEMS_GET), _items_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_FIRST_ITEM_GET), _first_item_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_LAST_ITEM_GET), _last_item_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_SELECTED_ITEM_GET), _selected_item_get), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_CLEAR), _clear), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_FILTER_APPEND), _item_filter_append), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_FILTER_PREPEND), _item_filter_prepend), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_FILTER_REMOVE), _item_filter_remove), - EO_OP_FUNC(ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_FORMAT_FUNCTION_SET), _format_function_set), - EO_OP_FUNC_SENTINEL - }; - eo_class_funcs_set(klass, func_desc); - +_elc_multibuttonentry_class_constructor(Eo_Class *klass) +{ evas_smart_legacy_type_register(MY_CLASS_NAME_LEGACY, klass); if (_elm_config->access_mode != ELM_ACCESS_MODE_OFF) _elm_multibuttonentry_smart_focus_next_enable = EINA_TRUE; } -static const Eo_Op_Description op_desc[] = { - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ENTRY_GET, "Get the entry of the multibuttonentry object."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EXPANDED_GET, "Get the value of expanded state."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EXPANDED_SET, "Set/Unset the multibuttonentry to expanded state."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EDITABLE_SET, "Sets if the multibuttonentry is to be editable or not."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_EDITABLE_GET, "Get whether the multibuttonentry is editable or not."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_PREPEND, "Prepend a new item to the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_APPEND, "Append a new item to the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_INSERT_BEFORE, "Add a new item to the multibuttonentry before the indicated object."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_INSERT_AFTER, "Add a new item to the multibuttonentry after the indicated object."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEMS_GET, "Get a list of items in the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_FIRST_ITEM_GET, "Get the first item in the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_LAST_ITEM_GET, "Get the last item in the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_SELECTED_ITEM_GET, "Get the selected item in the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_CLEAR, "Remove all items in the multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_FILTER_APPEND, "Append an item filter function for text inserted in the Multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_FILTER_PREPEND, "Prepend a filter function for text inserted in the Multibuttonentry."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_ITEM_FILTER_REMOVE, "Remove a filter from the list."), - EO_OP_DESCRIPTION(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_FORMAT_FUNCTION_SET, "Set a function to format the string that will be used to display the hidden items counter."), - EO_OP_DESCRIPTION_SENTINEL -}; -static const Eo_Class_Description class_desc = { - EO_VERSION, - MY_CLASS_NAME, - EO_CLASS_TYPE_REGULAR, - EO_CLASS_DESCRIPTION_OPS(&ELM_OBJ_MULTIBUTTONENTRY_BASE_ID, op_desc, ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_LAST), - NULL, - sizeof(Elm_Multibuttonentry_Smart_Data), - _class_constructor, - NULL -}; -EO_DEFINE_CLASS(elm_obj_multibuttonentry_class_get, &class_desc, ELM_OBJ_LAYOUT_CLASS, NULL); + +#include "elc_multibuttonentry.eo.c" diff --git a/src/lib/elc_multibuttonentry.eo b/src/lib/elc_multibuttonentry.eo new file mode 100644 index 0000000..8598f1d --- /dev/null +++ b/src/lib/elc_multibuttonentry.eo @@ -0,0 +1,286 @@ +class Elc_Multibuttonentry (Elm_Layout) +{ + legacy_prefix: elm_multibuttonentry; + eo_prefix: elm_obj_multibuttonentry; + properties { + editable { + set { + /*@ + Sets if the multibuttonentry is to be editable or not. + + @ingroup Multibuttonentry + + @since 1.7 */ + } + get { + /*@ + Get whether the multibuttonentry is editable or not. + + @return @c EINA_TRUE if the multibuttonentry is editable by the user. @c EINA_FALSE if not. + + @ingroup Multibuttonentry + + @since 1.7 */ + } + values { + Eina_Bool editable; /*@ If @c EINA_TRUE, user can add/delete item in multibuttonentry, if not, the multibuttonentry is non-editable. */ + } + } + expanded { + set { + /*@ + Set/Unset the multibuttonentry to expanded state. + In expanded state, the complete entry will be displayed. + Otherwise, only single line of the entry will be displayed. + + @ingroup Multibuttonentry */ + } + get { + /*@ + Get the value of expanded state. + In expanded state, the complete entry will be displayed. + Otherwise, only single line of the entry will be displayed. + + @return @c EINA_TRUE if the widget is in expanded state. @c EINA_FALSE if not. + + @ingroup Multibuttonentry */ + } + values { + Eina_Bool expanded; /*@ the value of expanded state. + Set this to @c EINA_TRUE for expanded state. + Set this to EINA_FALSE for single line state. */ + } + } + format_function { + set { + /*@ + Set a function to format the string that will be used to display + the hidden items counter. + + If @a format_function is @c NULL, the default format will be used, + which is @c "... + %d". + + @see elm_multibuttonentry_format_function_set + @since 1.9 + + @ingroup Multibuttonentry */ + } + values { + Elm_Multibuttonentry_Format_Cb format_function; /*@ format_function The actual format function */ + const void *data; /*@ data User data to passed to @a format_function */ + } + } + items { + get { + /*@ + Get a list of items in the multibuttonentry + + @return The list of items, or NULL if none + + @ingroup Multibuttonentry */ + return const Eina_List *; + } + } + first_item { + get { + /*@ + Get the first item in the multibuttonentry + + @return The first item, or NULL if none + + @ingroup Multibuttonentry */ + return Elm_Object_Item *; + } + } + last_item { + get { + /*@ + Get the last item in the multibuttonentry + + @return The last item, or NULL if none + + @ingroup Multibuttonentry */ + return Elm_Object_Item *; + } + } + entry { + get { + /*@ + Get the entry of the multibuttonentry object + + @return The entry object, or NULL if none + + @ingroup Multibuttonentry */ + return Evas_Object *; + } + } + selected_item { + get { + /*@ + Get the selected item in the multibuttonentry + + @return The selected item, or NULL if none + + @ingroup Multibuttonentry */ + return Elm_Object_Item *; + } + } + } + methods { + item_prepend { + /*@ + Prepend a new item to the multibuttonentry + + @return A handle to the item added or NULL if not possible + + @see Use elm_object_item_del() to delete the item. + + @ingroup Multibuttonentry */ + + return Elm_Object_Item *; + params { + @in const char *label; /*@ The label of new item */ + @in Evas_Smart_Cb func; /*@ The callback function to be invoked when this item is pressed. */ + @in void *data; /*@ The pointer to the data to be attached */ + } + } + clear { + /*@ + Remove all items in the multibuttonentry. + + @ingroup Multibuttonentry */ + + } + item_filter_remove { + /*@ + Remove a filter from the list + + Removes the given callback from the filter list. See elm_multibuttonentry_item_filter_append() + for more information. + + @ingroup Multibuttonentry */ + + params { + @in Elm_Multibuttonentry_Item_Filter_Cb func; /*@ The filter function to remove */ + @in void *data; /*@ The user data passed when adding the function */ + } + } + item_insert_before { + /*@ + Add a new item to the multibuttonentry before the indicated object + + reference. + @return A handle to the item added or NULL if not possible + + @see Use elm_object_item_del() to delete the item. + + @ingroup Multibuttonentry */ + + return Elm_Object_Item *; + params { + @in Elm_Object_Item *before; /*@ The item before which to add it */ + @in const char *label; /*@ The label of new item */ + @in Evas_Smart_Cb func; /*@ The callback function to be invoked when this item is pressed. */ + @in void *data; /*@ The pointer to the data to be attached */ + } + } + item_append { + /*@ + Append a new item to the multibuttonentry + + @return A handle to the item added or NULL if not possible + + @see Use elm_object_item_del() to delete the item. + + @ingroup Multibuttonentry */ + + return Elm_Object_Item *; + params { + @in const char *label; /*@ The label of new item */ + @in Evas_Smart_Cb func; /*@ The callback function to be invoked when this item is pressed. */ + @in void *data; /*@ The pointer to the data to be attached */ + } + } + item_filter_prepend { + /*@ + Prepend a filter function for text inserted in the Multibuttonentry + + Prepend the given callback to the list. See elm_multibuttonentry_item_filter_append() + for more information + + @ingroup Multibuttonentry */ + + params { + @in Elm_Multibuttonentry_Item_Filter_Cb func; /*@ The function to use as text filter */ + @in void *data; /*@ User data to pass to @p func */ + } + } + item_filter_append { + /*@ + Append an item filter function for text inserted in the Multibuttonentry + + Append the given callback to the list. This functions will be called + whenever any text is inserted into the Multibuttonentry, with the text to be inserted + as a parameter. The callback function is free to alter the text in any way + it wants, but it must remember to free the given pointer and update it. + If the new text is to be discarded, the function can free it and set it text + parameter to NULL. This will also prevent any following filters from being + called. + + @ingroup Multibuttonentry */ + + params { + @in Elm_Multibuttonentry_Item_Filter_Cb func; /*@ The function to use as item filter */ + @in void *data; /*@ User data to pass to @p func */ + } + } + item_insert_after { + /*@ + Add a new item to the multibuttonentry after the indicated object + + @return A handle to the item added or NULL if not possible + + @see Use elm_object_item_del() to delete the item. + + @ingroup Multibuttonentry */ + + return Elm_Object_Item *; + params { + @in Elm_Object_Item *after; /*@ The item after which to add it */ + @in const char *label; /*@ The label of new item */ + @in Evas_Smart_Cb func; /*@ The callback function to be invoked when this item is pressed. */ + @in void *data; /*@ The pointer to the data to be attached */ + } + } + } + implements { + class::constructor; + Eo_Base::constructor; + Evas_Smart::add; + Evas_Smart::del; + Elm_Widget::theme_apply; + Elm_Widget::focus_next_manager_is; + Elm_Widget::focus_direction_manager_is; + Elm_Widget::access; + Elm_Widget::focus_next; + Elm_Widget::on_focus; + Elm_Widget::translate; + Elm_Widget::event; + Elm_Layout::text_set; + Elm_Layout::text_get; + Elm_Layout::sizing_eval; + } + events { + item,selected; + item,added; + item,deleted; + item,clicked; + clicked; + focused; + unfocused; + expanded; + contracted; + expand,state,changed; + } + +} diff --git a/src/lib/elc_multibuttonentry_eo.h b/src/lib/elc_multibuttonentry_eo.h index 81f5830..cfe3063 100644 --- a/src/lib/elc_multibuttonentry_eo.h +++ b/src/lib/elc_multibuttonentry_eo.h @@ -1,3 +1,6 @@ +#include "elc_multibuttonentry.eo.h" + +#if 0 #define ELM_OBJ_MULTIBUTTONENTRY_CLASS elm_obj_multibuttonentry_class_get() const Eo_Class *elm_obj_multibuttonentry_class_get(void) EINA_CONST; @@ -302,3 +305,4 @@ enum * @ingroup Multibuttonentry */ #define elm_obj_multibuttonentry_format_function_set(format_function, data) ELM_OBJ_MULTIBUTTONENTRY_ID(ELM_OBJ_MULTIBUTTONENTRY_SUB_ID_FORMAT_FUNCTION_SET), EO_TYPECHECK(Elm_Multibuttonentry_Format_Cb, format_function), EO_TYPECHECK(const void *, data) +#endif diff --git a/src/lib/elm_widget_multibuttonentry.h b/src/lib/elm_widget_multibuttonentry.h index 984d7f4..a685832 100644 --- a/src/lib/elm_widget_multibuttonentry.h +++ b/src/lib/elm_widget_multibuttonentry.h @@ -65,9 +65,9 @@ typedef struct _Elm_Multibuttonentry_Item_Filter void *data; } Elm_Multibuttonentry_Item_Filter; -typedef struct _Elm_Multibuttonentry_Smart_Data - Elm_Multibuttonentry_Smart_Data; -struct _Elm_Multibuttonentry_Smart_Data +typedef struct _Elc_Multibuttonentry_Data + Elc_Multibuttonentry_Data; +struct _Elc_Multibuttonentry_Data { Evas_Object *parent; Evas_Object *box; @@ -106,7 +106,7 @@ struct _Elm_Multibuttonentry_Smart_Data */ #define ELM_MULTIBUTTONENTRY_DATA_GET_OR_RETURN(o, ptr) \ - Elm_Multibuttonentry_Smart_Data *ptr = eo_data_scope_get(o, ELM_OBJ_MULTIBUTTONENTRY_CLASS); \ + Elc_Multibuttonentry_Data *ptr = eo_data_scope_get(o, ELM_OBJ_MULTIBUTTONENTRY_CLASS); \ if (EINA_UNLIKELY(!ptr)) \ { \ CRI("No widget data for object %p (%s)", \ @@ -115,7 +115,7 @@ struct _Elm_Multibuttonentry_Smart_Data } #define ELM_MULTIBUTTONENTRY_DATA_GET_OR_RETURN_VAL(o, ptr, val) \ - Elm_Multibuttonentry_Smart_Data * ptr = eo_data_scope_get(o, ELM_OBJ_MULTIBUTTONENTRY_CLASS); \ + Elc_Multibuttonentry_Data * ptr = eo_data_scope_get(o, ELM_OBJ_MULTIBUTTONENTRY_CLASS); \ if (EINA_UNLIKELY(!ptr)) \ { \ CRI("No widget data for object %p (%s)", \ --