davemds pushed a commit to branch master.
http://git.enlightenment.org/core/efl.git/commit/?id=f0a0da9f449b0878fe6a5ce2abc50b8b6589c50a
Advertising
commit f0a0da9f449b0878fe6a5ce2abc50b8b6589c50a
Author: Dave Andreoli <d...@gurumeditation.it>
Date: Fri Apr 13 20:37:36 2018 +0200
Genlist: restore old behaviour of item next/prev in group items
Commit fd82c2521 has changed the behaviour of item_next/prev_get()
in case of genlist with group items (not tree).
The lagacy behaviour was to tread normal items and group items
in a flat way, like if group items was on the same level of
the children normal items.
As the commit already implement bug compatibility, seems to me
the case to restore also this case. Note that this changes only
apply to legacy genlist (I think).
Let me know if this broke something for you...as touching genlist
code is always an "I hope this is right" operation.
---
src/lib/elementary/elm_genlist.c | 20 ++++++++++++++++++--
1 file changed, 18 insertions(+), 2 deletions(-)
diff --git a/src/lib/elementary/elm_genlist.c b/src/lib/elementary/elm_genlist.c
index 82025ebe0a..012b99a397 100644
--- a/src/lib/elementary/elm_genlist.c
+++ b/src/lib/elementary/elm_genlist.c
@@ -6958,6 +6958,12 @@ _elm_genlist_next_item_get_insane(Elm_Genlist_Data *sd,
Elm_Gen_Item *it)
if (sd->filter && !_item_filtered_get(it2))
continue;
+ // Insanity does not apply for group items
+ // (group and normal items was treated in a flat way)
+ if (it->item->type == ELM_GENLIST_ITEM_GROUP ||
+ it2->item->type == ELM_GENLIST_ITEM_GROUP)
+ return EO_OBJ(it2);
+
// 1. Return next sibling in list, if any
if (it->parent == it2->parent)
return EO_OBJ(it2);
@@ -6981,7 +6987,7 @@ _elm_genlist_next_item_get_insane(Elm_Genlist_Data *sd,
Elm_Gen_Item *it)
return EO_OBJ(it->parent);
}
/* if item is already last item, return its parent if a parent exists */
- if (it->parent)
+ if (it->parent && it->parent->item->type != ELM_GENLIST_ITEM_GROUP)
return EO_OBJ(it->parent);
return EO_OBJ(it2);
}
@@ -7001,6 +7007,16 @@ _elm_genlist_prev_item_get_insane(Elm_Genlist_Data *sd,
Elm_Gen_Item *it)
return EO_OBJ(it2);
}
+ // Insanity does not apply for group items
+ // (group and normal items was treated in a flat way)
+ if (it->item->type == ELM_GENLIST_ITEM_GROUP)
+ {
+ for (it2 = ELM_GEN_ITEM_PREV(it); it2; it2 = ELM_GEN_ITEM_PREV(it2))
+ if (!sd->filter || _item_filtered_get(it2))
+ break;
+ return EO_OBJ(it2);
+ }
+
parent = it->parent;
if (!parent)
{
@@ -7020,7 +7036,7 @@ _elm_genlist_prev_item_get_insane(Elm_Genlist_Data *sd,
Elm_Gen_Item *it)
}
it2 = ELM_GEN_ITEM_PREV(it);
- if (it2 == parent)
+ if (it2 == parent && it2->item->type != ELM_GENLIST_ITEM_GROUP)
return _elm_genlist_prev_item_get_insane(sd, it2);
return EO_OBJ(it2);
--