forked from enlightenment/efl
Fix some really weird formatting.
Use ELM_NEW instead of calloc directly. No need to retrieve Widget_Data in certain functions so commented out. SVN revision: 43060
This commit is contained in:
parent
48ec1a6e8e
commit
e472033c3b
|
@ -54,14 +54,14 @@ static void _changed_size_hints(void *data, Evas *e, Evas_Object *obj, void *eve
|
|||
static void _submenu_hide(Elm_Menu_Item *item);
|
||||
static void _submenu_open(void *data, Evas_Object *obj, const char *emission, const char *source);
|
||||
|
||||
static void
|
||||
static void
|
||||
_del_hook(Evas_Object *obj)
|
||||
{
|
||||
Eina_List *l, *ll = NULL;
|
||||
Elm_Menu_Item *item;
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
|
||||
if (!wd) return;
|
||||
ll = eina_list_append(ll, wd->items);
|
||||
|
||||
EINA_LIST_FOREACH(ll, ll, l)
|
||||
|
@ -69,9 +69,9 @@ _del_hook(Evas_Object *obj)
|
|||
EINA_LIST_FREE(l, item)
|
||||
{
|
||||
ll = eina_list_append(ll, item->items);
|
||||
if(item->label)
|
||||
if (item->label)
|
||||
eina_stringshare_del(item->label);
|
||||
if(item->bx)
|
||||
if (item->bx)
|
||||
{
|
||||
evas_object_del(item->hv);
|
||||
evas_object_del(item->location);
|
||||
|
@ -79,18 +79,17 @@ _del_hook(Evas_Object *obj)
|
|||
free(item);
|
||||
}
|
||||
}
|
||||
|
||||
free(wd);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_theme_hook(Evas_Object *obj)
|
||||
{
|
||||
Eina_List *l, *_l, *ll = NULL;
|
||||
Elm_Menu_Item *item;
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
|
||||
if (!wd) return;
|
||||
ll = eina_list_append(ll, wd->items);
|
||||
|
||||
EINA_LIST_FOREACH(ll, ll, l)
|
||||
|
@ -98,44 +97,46 @@ _theme_hook(Evas_Object *obj)
|
|||
EINA_LIST_FOREACH(l, _l, item)
|
||||
{
|
||||
ll = eina_list_append(ll, item->items);
|
||||
if(item->separator)
|
||||
_elm_theme_set(item->o, "menu", "separator", elm_widget_style_get(obj));
|
||||
else if(item->bx)
|
||||
if (item->separator)
|
||||
_elm_theme_set(item->o, "menu", "separator",
|
||||
elm_widget_style_get(obj));
|
||||
else if (item->bx)
|
||||
{
|
||||
_elm_theme_set(item->o, "menu", "item_with_submenu", elm_widget_style_get(obj));
|
||||
_elm_theme_set(item->o, "menu", "item_with_submenu",
|
||||
elm_widget_style_get(obj));
|
||||
elm_menu_item_label_set(item, item->label);
|
||||
elm_menu_item_icon_set(item, item->icon);
|
||||
}
|
||||
else
|
||||
{
|
||||
_elm_theme_set(item->o, "menu", "item", elm_widget_style_get(obj));
|
||||
_elm_theme_set(item->o, "menu", "item",
|
||||
elm_widget_style_get(obj));
|
||||
elm_menu_item_label_set(item, item->label);
|
||||
elm_menu_item_icon_set(item, item->icon);
|
||||
}
|
||||
if(item->disabled)
|
||||
if (item->disabled)
|
||||
edje_object_signal_emit(item->o, "elm,state,disabled", "elm");
|
||||
else
|
||||
edje_object_signal_emit(item->o, "elm,state,enabled", "elm");
|
||||
edje_object_message_signal_process(item->o);
|
||||
edje_object_scale_set(item->o, elm_widget_scale_get(obj) * _elm_config->scale);
|
||||
edje_object_scale_set(item->o, elm_widget_scale_get(obj) *
|
||||
_elm_config->scale);
|
||||
}
|
||||
}
|
||||
_sizing_eval(obj);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_sizing_eval(Evas_Object *obj)
|
||||
{
|
||||
Eina_List *l;
|
||||
Elm_Menu_Item *item;
|
||||
Evas_Coord x_p,y_p,w_p,h_p,x2,y2,w2,h2,bx,by,bw,bh;
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd || !wd->parent) return;
|
||||
|
||||
if ((!wd) || (!wd->parent)) return;
|
||||
EINA_LIST_FOREACH(wd->items,l,item)
|
||||
{
|
||||
_item_sizing_eval(item);
|
||||
}
|
||||
_item_sizing_eval(item);
|
||||
|
||||
evas_object_geometry_get(wd->location, &x_p, &y_p, &w_p, &h_p);
|
||||
evas_object_geometry_get(wd->parent, &x2, &y2, &w2, &h2);
|
||||
|
@ -144,14 +145,14 @@ _sizing_eval(Evas_Object *obj)
|
|||
x_p = wd->xloc;
|
||||
y_p = wd->yloc;
|
||||
|
||||
if(x_p+bw > x2+w2)
|
||||
if (x_p+bw > x2+w2)
|
||||
x_p -= x_p+bw - (x2+w2);
|
||||
if(x_p < x2)
|
||||
if (x_p < x2)
|
||||
x_p += x2 - x_p;
|
||||
|
||||
if(y_p+h_p+bh > y2+h2)
|
||||
if (y_p+h_p+bh > y2+h2)
|
||||
y_p -= y_p+h_p+bh - (y2+h2);
|
||||
if(y_p < y2)
|
||||
if (y_p < y2)
|
||||
y_p += y2 - y_p;
|
||||
|
||||
evas_object_move(wd->location, x_p, y_p);
|
||||
|
@ -162,13 +163,13 @@ _sizing_eval(Evas_Object *obj)
|
|||
|
||||
EINA_LIST_FOREACH(wd->items,l,item)
|
||||
{
|
||||
if(item->open)
|
||||
if (item->open)
|
||||
_submenu_sizing_eval(item);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
static void
|
||||
_submenu_sizing_eval(Elm_Menu_Item *parent)
|
||||
{
|
||||
Eina_List *l;
|
||||
|
@ -177,9 +178,7 @@ _submenu_sizing_eval(Elm_Menu_Item *parent)
|
|||
Widget_Data *wd = elm_widget_data_get(parent->menu);
|
||||
|
||||
EINA_LIST_FOREACH(parent->items,l,item)
|
||||
{
|
||||
_item_sizing_eval(item);
|
||||
}
|
||||
_item_sizing_eval(item);
|
||||
|
||||
evas_object_geometry_get(parent->location, &x_p, &y_p, &w_p, &h_p);
|
||||
evas_object_geometry_get(parent->o, &x2, &y2, &w2, &h2);
|
||||
|
@ -189,12 +188,12 @@ _submenu_sizing_eval(Elm_Menu_Item *parent)
|
|||
x_p = x2+w2;
|
||||
y_p = y2;
|
||||
|
||||
if(x_p + bw > px + pw)
|
||||
if (x_p + bw > px + pw)
|
||||
x_p = x2-bw;
|
||||
|
||||
if(y_p+bh > py+ph)
|
||||
if (y_p+bh > py+ph)
|
||||
y_p -= y_p+bh - (py+ph);
|
||||
if(y_p < py)
|
||||
if (y_p < py)
|
||||
y_p += y_p - y_p;
|
||||
|
||||
evas_object_move(parent->location, x_p, y_p);
|
||||
|
@ -205,76 +204,77 @@ _submenu_sizing_eval(Elm_Menu_Item *parent)
|
|||
|
||||
EINA_LIST_FOREACH(parent->items,l,item)
|
||||
{
|
||||
if(item->open)
|
||||
if (item->open)
|
||||
_submenu_sizing_eval(item);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_item_sizing_eval(Elm_Menu_Item *item)
|
||||
{
|
||||
Evas_Coord minw = -1, minh = -1, maxw = -1, maxh = -1;
|
||||
if(!item->separator)
|
||||
|
||||
if (!item->separator)
|
||||
elm_coords_finger_size_adjust(1, &minw, 1, &minh);
|
||||
edje_object_size_min_restricted_calc(item->o, &minw, &minh, minw, minh);
|
||||
if(!item->separator)
|
||||
if (!item->separator)
|
||||
elm_coords_finger_size_adjust(1, &minw, 1, &minh);
|
||||
evas_object_size_hint_min_set(item->o, minw, minh);
|
||||
evas_object_size_hint_max_set(item->o, maxw, maxh);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_changed_size_hints(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(data);
|
||||
// Widget_Data *wd = elm_widget_data_get(data);
|
||||
|
||||
_sizing_eval(data);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_menu_resize(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(data);
|
||||
// Widget_Data *wd = elm_widget_data_get(data);
|
||||
|
||||
_sizing_eval(data);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_parent_resize(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(data);
|
||||
// Widget_Data *wd = elm_widget_data_get(data);
|
||||
|
||||
_sizing_eval(data);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_item_move_resize(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
||||
{
|
||||
Elm_Menu_Item *item = data;
|
||||
|
||||
if(item->open)
|
||||
_submenu_sizing_eval(item);
|
||||
if (item->open)
|
||||
_submenu_sizing_eval(item);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
static void
|
||||
_menu_hide(void *data, Evas_Object *obj, void *event_info)
|
||||
{
|
||||
Eina_List *l;
|
||||
Elm_Menu_Item *item2;
|
||||
|
||||
Widget_Data *wd = elm_widget_data_get(data);
|
||||
|
||||
evas_object_hide(wd->hv);
|
||||
evas_object_hide(data);
|
||||
|
||||
EINA_LIST_FOREACH(wd->items, l, item2)
|
||||
{
|
||||
if(item2->open)
|
||||
if (item2->open)
|
||||
_submenu_hide(item2);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_submenu_hide(Elm_Menu_Item *item)
|
||||
{
|
||||
Eina_List *l;
|
||||
|
@ -284,20 +284,20 @@ _submenu_hide(Elm_Menu_Item *item)
|
|||
item->open = EINA_FALSE;
|
||||
EINA_LIST_FOREACH(item->items, l, item2)
|
||||
{
|
||||
if(item2->open)
|
||||
if (item2->open)
|
||||
_submenu_hide(item2);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
static void
|
||||
_menu_item_select(void *data, Evas_Object *obj, const char *emission, const char *source)
|
||||
{
|
||||
Elm_Menu_Item *it = data;
|
||||
|
||||
if(it->items)
|
||||
if (it->items)
|
||||
{
|
||||
if(!it->open)
|
||||
if (!it->open)
|
||||
_submenu_open(it, NULL, NULL, NULL);
|
||||
else
|
||||
_submenu_hide(it);
|
||||
|
@ -308,19 +308,18 @@ _menu_item_select(void *data, Evas_Object *obj, const char *emission, const char
|
|||
if (it->func) it->func((void *)(it->data), it->menu, it);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_menu_item_activate(void *data, Evas_Object *obj, const char *emission, const char *source)
|
||||
{
|
||||
Eina_List *l;
|
||||
Elm_Menu_Item *item2;
|
||||
|
||||
Elm_Menu_Item *item = data;
|
||||
|
||||
if(item->parent)
|
||||
if (item->parent)
|
||||
{
|
||||
EINA_LIST_FOREACH(item->parent->items, l, item2)
|
||||
{
|
||||
if(item2->open && item2 != item)
|
||||
if ((item2->open) && (item2 != item))
|
||||
_submenu_hide(item2);
|
||||
}
|
||||
}
|
||||
|
@ -329,13 +328,13 @@ _menu_item_activate(void *data, Evas_Object *obj, const char *emission, const ch
|
|||
Widget_Data *wd = elm_widget_data_get(item->menu);
|
||||
EINA_LIST_FOREACH(wd->items, l, item2)
|
||||
{
|
||||
if(item2->open && item2 != item)
|
||||
if ((item2->open) && (item2 != item))
|
||||
_submenu_hide(item2);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_submenu_open(void *data, Evas_Object *obj, const char *emission, const char *source)
|
||||
{
|
||||
Elm_Menu_Item *it = data;
|
||||
|
@ -345,14 +344,14 @@ _submenu_open(void *data, Evas_Object *obj, const char *emission, const char *so
|
|||
_sizing_eval(it->menu);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_show(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(data);
|
||||
evas_object_show(wd->hv);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_item_obj_create(Elm_Menu_Item *item)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(item->menu);
|
||||
|
@ -361,13 +360,13 @@ _item_obj_create(Elm_Menu_Item *item)
|
|||
evas_object_size_hint_fill_set(item->o, EVAS_HINT_FILL, EVAS_HINT_FILL);
|
||||
_elm_theme_set(item->o, "menu", "item", elm_widget_style_get(item->menu));
|
||||
edje_object_signal_callback_add(item->o, "elm,action,click", "",
|
||||
_menu_item_select, item);
|
||||
_menu_item_select, item);
|
||||
edje_object_signal_callback_add(item->o, "elm,action,activate", "",
|
||||
_menu_item_activate, item);
|
||||
_menu_item_activate, item);
|
||||
evas_object_show(item->o);
|
||||
}
|
||||
|
||||
static void
|
||||
static void
|
||||
_item_separator_obj_create(Elm_Menu_Item *item)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(item->menu);
|
||||
|
@ -376,12 +375,11 @@ _item_separator_obj_create(Elm_Menu_Item *item)
|
|||
evas_object_size_hint_fill_set(item->o, EVAS_HINT_FILL, EVAS_HINT_FILL);
|
||||
_elm_theme_set(item->o, "menu", "separator", elm_widget_style_get(item->menu));
|
||||
edje_object_signal_callback_add(item->o, "elm,action,activate", "",
|
||||
_menu_item_activate, item);
|
||||
_menu_item_activate, item);
|
||||
evas_object_show(item->o);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
static void
|
||||
_item_submenu_obj_create(Elm_Menu_Item *item)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(item->menu);
|
||||
|
@ -404,7 +402,7 @@ _item_submenu_obj_create(Elm_Menu_Item *item)
|
|||
elm_menu_item_icon_set(item, item->icon);
|
||||
|
||||
edje_object_signal_callback_add(item->o, "elm,action,open", "",
|
||||
_submenu_open, item);
|
||||
_submenu_open, item);
|
||||
evas_object_event_callback_add(item->o, EVAS_CALLBACK_MOVE, _item_move_resize, item);
|
||||
evas_object_event_callback_add(item->o, EVAS_CALLBACK_RESIZE, _item_move_resize, item);
|
||||
}
|
||||
|
@ -418,7 +416,7 @@ _item_submenu_obj_create(Elm_Menu_Item *item)
|
|||
*
|
||||
* @ingroup Menu
|
||||
*/
|
||||
EAPI Evas_Object *
|
||||
EAPI Evas_Object *
|
||||
elm_menu_add(Evas_Object *parent)
|
||||
{
|
||||
Evas_Object *obj;
|
||||
|
@ -463,13 +461,13 @@ elm_menu_add(Evas_Object *parent)
|
|||
* @param obj The menu object.
|
||||
* @param parent The new parent.
|
||||
*/
|
||||
EAPI void
|
||||
EAPI void
|
||||
elm_menu_parent_set(Evas_Object *obj, Evas_Object *parent)
|
||||
{
|
||||
Eina_List *l, *_l, *ll = NULL;
|
||||
Elm_Menu_Item *item;
|
||||
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
|
||||
if (!wd) return;
|
||||
|
||||
elm_hover_parent_set(wd->hv, parent);
|
||||
|
@ -481,7 +479,7 @@ elm_menu_parent_set(Evas_Object *obj, Evas_Object *parent)
|
|||
{
|
||||
EINA_LIST_FOREACH(l, _l, item)
|
||||
{
|
||||
if(item->hv)
|
||||
if (item->hv)
|
||||
{
|
||||
elm_hover_parent_set(item->hv, parent);
|
||||
ll = eina_list_append(ll, item->items);
|
||||
|
@ -498,12 +496,12 @@ elm_menu_parent_set(Evas_Object *obj, Evas_Object *parent)
|
|||
* @param x The new position.
|
||||
* @param y The new position.
|
||||
*/
|
||||
EAPI void
|
||||
EAPI void
|
||||
elm_menu_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y)
|
||||
{
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
|
||||
if (!wd) return;
|
||||
wd->xloc = x;
|
||||
wd->yloc = y;
|
||||
_sizing_eval(obj);
|
||||
|
@ -520,15 +518,15 @@ elm_menu_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y)
|
|||
* @param data Data sent by the callback.
|
||||
* #return Returns the new item.
|
||||
*/
|
||||
EAPI Elm_Menu_Item *
|
||||
EAPI Elm_Menu_Item *
|
||||
elm_menu_item_add(Evas_Object *obj, Elm_Menu_Item *parent, Evas_Object *icon, const char *label, void (*func) (void *data, Evas_Object *obj, void *event_info), const void *data)
|
||||
{
|
||||
Elm_Menu_Item *subitem;
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
|
||||
subitem = calloc(1, sizeof(Elm_Menu_Item));
|
||||
if(!subitem) return NULL;
|
||||
if (!wd) return;
|
||||
subitem = ELM_NEW(Elm_Menu_Item);
|
||||
if (!subitem) return NULL;
|
||||
subitem->func = func;
|
||||
subitem->data = data;
|
||||
subitem->menu = obj;
|
||||
|
@ -538,10 +536,10 @@ elm_menu_item_add(Evas_Object *obj, Elm_Menu_Item *parent, Evas_Object *icon, co
|
|||
elm_menu_item_label_set(subitem, label);
|
||||
elm_menu_item_icon_set(subitem, icon);
|
||||
|
||||
if(parent)
|
||||
if (parent)
|
||||
{
|
||||
if(!parent->bx)
|
||||
_item_submenu_obj_create(parent);
|
||||
if (!parent->bx)
|
||||
_item_submenu_obj_create(parent);
|
||||
elm_box_pack_end(parent->bx, subitem->o);
|
||||
parent->items = eina_list_append(parent->items, subitem);
|
||||
}
|
||||
|
@ -555,7 +553,7 @@ elm_menu_item_add(Evas_Object *obj, Elm_Menu_Item *parent, Evas_Object *icon, co
|
|||
return subitem;
|
||||
}
|
||||
|
||||
EAPI void
|
||||
EAPI void
|
||||
elm_menu_item_label_set(Elm_Menu_Item *item, const char *label)
|
||||
{
|
||||
Evas_Coord mw, mh;
|
||||
|
@ -576,15 +574,15 @@ elm_menu_item_label_set(Elm_Menu_Item *item, const char *label)
|
|||
_sizing_eval(item->menu);
|
||||
}
|
||||
|
||||
EAPI const char *
|
||||
EAPI const char *
|
||||
elm_menu_item_label_get(Elm_Menu_Item *item)
|
||||
{
|
||||
if(!item) return ;
|
||||
if (!item) return ;
|
||||
return item->label;
|
||||
}
|
||||
|
||||
|
||||
EAPI void
|
||||
EAPI void
|
||||
elm_menu_item_icon_set(Elm_Menu_Item *item, Evas_Object *icon)
|
||||
{
|
||||
if ((item->icon != icon) && (item->icon))
|
||||
|
@ -596,7 +594,7 @@ elm_menu_item_icon_set(Elm_Menu_Item *item, Evas_Object *icon)
|
|||
edje_object_part_swallow(item->o, "elm.swallow.content", icon);
|
||||
edje_object_signal_emit(item->o, "elm,state,icon,visible", "elm");
|
||||
evas_object_event_callback_add(icon, EVAS_CALLBACK_CHANGED_SIZE_HINTS,
|
||||
_changed_size_hints, item->menu);
|
||||
_changed_size_hints, item->menu);
|
||||
edje_object_message_signal_process(item->o);
|
||||
_sizing_eval(item->menu);
|
||||
}
|
||||
|
@ -604,46 +602,45 @@ elm_menu_item_icon_set(Elm_Menu_Item *item, Evas_Object *icon)
|
|||
item->icon = icon;
|
||||
}
|
||||
|
||||
EAPI void
|
||||
EAPI void
|
||||
elm_menu_item_disabled_set(Elm_Menu_Item *item, Eina_Bool disabled)
|
||||
{
|
||||
if(disabled == item->disabled) return;
|
||||
if (disabled == item->disabled) return;
|
||||
|
||||
item->disabled = disabled;
|
||||
if(disabled)
|
||||
if (disabled)
|
||||
{
|
||||
edje_object_signal_emit(item->o, "elm,state,disabled", "elm");
|
||||
if(item->open)
|
||||
_submenu_hide(item);
|
||||
edje_object_signal_emit(item->o, "elm,state,disabled", "elm");
|
||||
if (item->open) _submenu_hide(item);
|
||||
}
|
||||
else
|
||||
edje_object_signal_emit(item->o, "elm,state,enabled", "elm");
|
||||
edje_object_message_signal_process(item->o);
|
||||
}
|
||||
|
||||
EAPI Elm_Menu_Item *
|
||||
EAPI Elm_Menu_Item *
|
||||
elm_menu_item_separator_add(Evas_Object *obj, Elm_Menu_Item *parent)
|
||||
{
|
||||
Elm_Menu_Item *subitem;
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
|
||||
subitem = calloc(1, sizeof(Elm_Menu_Item));
|
||||
if(!subitem) return NULL;
|
||||
if (!wd) return;
|
||||
subitem = ELM_NEW(Elm_Menu_Item);
|
||||
if (!subitem) return NULL;
|
||||
subitem->menu = obj;
|
||||
subitem->separator = 1;
|
||||
|
||||
_item_separator_obj_create(subitem);
|
||||
|
||||
if(!parent)
|
||||
if (!parent)
|
||||
{
|
||||
elm_box_pack_end(wd->bx, subitem->o);
|
||||
wd->items = eina_list_append(wd->items, subitem);
|
||||
}
|
||||
else
|
||||
{
|
||||
if(!parent->bx)
|
||||
_item_submenu_obj_create(parent);
|
||||
if (!parent->bx)
|
||||
_item_submenu_obj_create(parent);
|
||||
elm_box_pack_end(parent->bx, subitem->o);
|
||||
parent->items = eina_list_append(parent->items, subitem);
|
||||
}
|
||||
|
@ -652,24 +649,24 @@ elm_menu_item_separator_add(Evas_Object *obj, Elm_Menu_Item *parent)
|
|||
return subitem;
|
||||
}
|
||||
|
||||
EAPI void
|
||||
EAPI void
|
||||
elm_menu_item_del(Elm_Menu_Item *item)
|
||||
{
|
||||
Eina_List *l;
|
||||
Elm_Menu_Item *_item;
|
||||
|
||||
if(!item) return;
|
||||
if (!item) return;
|
||||
|
||||
EINA_LIST_FREE(item->items, _item)
|
||||
elm_menu_item_del(_item);
|
||||
elm_menu_item_del(_item);
|
||||
|
||||
if(item->label) eina_stringshare_del(item->label);
|
||||
if(item->icon) evas_object_del(item->icon);
|
||||
if(item->hv) evas_object_del(item->hv);
|
||||
if(item->location) evas_object_del(item->location);
|
||||
if(item->o) evas_object_del(item->o);
|
||||
if (item->label) eina_stringshare_del(item->label);
|
||||
if (item->icon) evas_object_del(item->icon);
|
||||
if (item->hv) evas_object_del(item->hv);
|
||||
if (item->location) evas_object_del(item->location);
|
||||
if (item->o) evas_object_del(item->o);
|
||||
|
||||
if(item->parent)
|
||||
if (item->parent)
|
||||
item->parent->items = eina_list_remove(item->parent->items, item);
|
||||
else
|
||||
{
|
||||
|
@ -680,9 +677,8 @@ elm_menu_item_del(Elm_Menu_Item *item)
|
|||
free(item);
|
||||
}
|
||||
|
||||
EAPI const Eina_List *
|
||||
EAPI const Eina_List *
|
||||
elm_menu_item_subitems_get(Elm_Menu_Item *item)
|
||||
{
|
||||
return item->items;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue