st-widget: fix GList leak
clutter_actor_get_children returns a newly allocated GList and it was not freed. However, as there's no reason to copy the children list, switch to iterator api. https://bugzilla.gnome.org/show_bug.cgi?id=678406
This commit is contained in:
parent
4e4092f9e8
commit
556d5d181e
@ -762,18 +762,17 @@ st_widget_get_paint_volume (ClutterActor *self,
|
|||||||
static GList *
|
static GList *
|
||||||
st_widget_real_get_focus_chain (StWidget *widget)
|
st_widget_real_get_focus_chain (StWidget *widget)
|
||||||
{
|
{
|
||||||
GList *children;
|
ClutterActorIter iter;
|
||||||
|
ClutterActor *child;
|
||||||
GList *focus_chain = NULL;
|
GList *focus_chain = NULL;
|
||||||
|
|
||||||
for (children = clutter_actor_get_children (CLUTTER_ACTOR (widget));
|
clutter_actor_iter_init (&iter, CLUTTER_ACTOR (widget));
|
||||||
children;
|
while (clutter_actor_iter_next (&iter, &child))
|
||||||
children = children->next)
|
|
||||||
{
|
{
|
||||||
ClutterActor *child = children->data;
|
|
||||||
|
|
||||||
if (CLUTTER_ACTOR_IS_VISIBLE (child))
|
if (CLUTTER_ACTOR_IS_VISIBLE (child))
|
||||||
focus_chain = g_list_prepend (focus_chain, child);
|
focus_chain = g_list_prepend (focus_chain, child);
|
||||||
}
|
}
|
||||||
|
|
||||||
return g_list_reverse (focus_chain);
|
return g_list_reverse (focus_chain);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user