mirror of
https://github.com/brl/mutter.git
synced 2025-01-27 11:59:12 +00:00
Plug a memory leak in clutter-table-layout
Whenever the allocation is changed on a child of a ClutterTableLayout and animations are not in effect then it would store a copy of the allocation in the child meta data. However it was not freeing the old copy of the allocation so it would end up with a small leak. Instead of just changing it to free the old value this patch makes it store the allocation inline in the meta data struct because it seems that the size of an actor box is already quite small compared to the size of the meta data struct so it is probably not worth having a separate allocation for it. To detect the case when there has not yet been an allocation a separate boolean is used instead of storing NULL. http://bugzilla.clutter-project.org/show_bug.cgi?id=2358
This commit is contained in:
parent
42dac6c997
commit
4724be167f
@ -131,10 +131,11 @@ struct _ClutterTableChild
|
|||||||
{
|
{
|
||||||
ClutterLayoutMeta parent_instance;
|
ClutterLayoutMeta parent_instance;
|
||||||
|
|
||||||
/* the last stable allocation before an animation; it is
|
/* the last stable allocation before an animation; it is used as the
|
||||||
* used as the initial ActorBox when interpolating
|
* initial ActorBox when interpolating. If has_last_allocation is
|
||||||
|
* FALSE then this value is not yet known
|
||||||
*/
|
*/
|
||||||
ClutterActorBox *last_allocation;
|
ClutterActorBox last_allocation;
|
||||||
|
|
||||||
gint col;
|
gint col;
|
||||||
gint row;
|
gint row;
|
||||||
@ -145,10 +146,11 @@ struct _ClutterTableChild
|
|||||||
ClutterTableAlignment x_align;
|
ClutterTableAlignment x_align;
|
||||||
ClutterTableAlignment y_align;
|
ClutterTableAlignment y_align;
|
||||||
|
|
||||||
guint x_expand : 1;
|
guint x_expand : 1;
|
||||||
guint y_expand : 1;
|
guint y_expand : 1;
|
||||||
guint x_fill : 1;
|
guint x_fill : 1;
|
||||||
guint y_fill : 1;
|
guint y_fill : 1;
|
||||||
|
guint has_last_allocation : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -570,16 +572,6 @@ clutter_table_child_get_property (GObject *gobject,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
clutter_table_child_finalize (GObject *gobject)
|
|
||||||
{
|
|
||||||
ClutterTableChild *self = CLUTTER_TABLE_CHILD (gobject);
|
|
||||||
|
|
||||||
clutter_actor_box_free (self->last_allocation);
|
|
||||||
|
|
||||||
G_OBJECT_CLASS (clutter_table_child_parent_class)->finalize (gobject);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
clutter_table_child_class_init (ClutterTableChildClass *klass)
|
clutter_table_child_class_init (ClutterTableChildClass *klass)
|
||||||
{
|
{
|
||||||
@ -588,7 +580,6 @@ clutter_table_child_class_init (ClutterTableChildClass *klass)
|
|||||||
|
|
||||||
gobject_class->set_property = clutter_table_child_set_property;
|
gobject_class->set_property = clutter_table_child_set_property;
|
||||||
gobject_class->get_property = clutter_table_child_get_property;
|
gobject_class->get_property = clutter_table_child_get_property;
|
||||||
gobject_class->finalize = clutter_table_child_finalize;
|
|
||||||
|
|
||||||
pspec = g_param_spec_int ("column",
|
pspec = g_param_spec_int ("column",
|
||||||
P_("Column Number"),
|
P_("Column Number"),
|
||||||
@ -696,7 +687,7 @@ clutter_table_child_init (ClutterTableChild *self)
|
|||||||
self->x_fill = TRUE;
|
self->x_fill = TRUE;
|
||||||
self->y_fill = TRUE;
|
self->y_fill = TRUE;
|
||||||
|
|
||||||
self->last_allocation = NULL;
|
self->has_last_allocation = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static GType
|
static GType
|
||||||
@ -1532,18 +1523,19 @@ clutter_table_layout_allocate (ClutterLayoutManager *layout,
|
|||||||
|
|
||||||
p = clutter_layout_manager_get_animation_progress (layout);
|
p = clutter_layout_manager_get_animation_progress (layout);
|
||||||
|
|
||||||
start = meta->last_allocation;
|
if (!meta->has_last_allocation)
|
||||||
if (start == NULL)
|
|
||||||
{
|
{
|
||||||
/* if there is no allocation available then the child has just
|
/* if there is no allocation available then the child has just
|
||||||
* been added to the container; we put it in the final state
|
* been added to the container; we put it in the final state
|
||||||
* and store its allocation for later
|
* and store its allocation for later
|
||||||
*/
|
*/
|
||||||
meta->last_allocation = clutter_actor_box_copy (&childbox);
|
meta->last_allocation = childbox;
|
||||||
|
meta->has_last_allocation = TRUE;
|
||||||
|
|
||||||
goto do_allocate;
|
goto do_allocate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
start = &meta->last_allocation;
|
||||||
end = childbox;
|
end = childbox;
|
||||||
|
|
||||||
/* interpolate between the initial and final values */
|
/* interpolate between the initial and final values */
|
||||||
@ -1564,7 +1556,8 @@ clutter_table_layout_allocate (ClutterLayoutManager *layout,
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* store the allocation for later animations */
|
/* store the allocation for later animations */
|
||||||
meta->last_allocation = clutter_actor_box_copy (&childbox);
|
meta->last_allocation = childbox;
|
||||||
|
meta->has_last_allocation = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
do_allocate:
|
do_allocate:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user