From bebe90e565f852ad858927fd0befe81137bf1326 Mon Sep 17 00:00:00 2001 From: Emmanuele Bassi Date: Mon, 18 Jun 2012 17:54:06 +0100 Subject: [PATCH] interval: Do not leak the result GValue The compute() method will cache the result, to avoid multiple allocations and copies; this means, though, that we need to unset the GValue when destroying the Interval. --- clutter/clutter-interval.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/clutter/clutter-interval.c b/clutter/clutter-interval.c index 96d3122ce..1cbafdabb 100644 --- a/clutter/clutter-interval.c +++ b/clutter/clutter-interval.c @@ -399,8 +399,14 @@ clutter_interval_finalize (GObject *gobject) { ClutterIntervalPrivate *priv = CLUTTER_INTERVAL (gobject)->priv; - g_value_unset (&priv->values[0]); - g_value_unset (&priv->values[1]); + if (G_IS_VALUE (&priv->values[INITIAL])) + g_value_unset (&priv->values[INITIAL]); + + if (G_IS_VALUE (&priv->values[FINAL])) + g_value_unset (&priv->values[FINAL]); + + if (G_IS_VALUE (&priv->values[RESULT])) + g_value_unset (&priv->values[RESULT]); g_free (priv->values);