summaryrefslogtreecommitdiffstats
path: root/ext/annodex/gstcmmldec.c
diff options
context:
space:
mode:
authorJulien Moutte <julien@moutte.net>2006-02-25 11:37:10 +0000
committerJulien Moutte <julien@moutte.net>2006-02-25 11:37:10 +0000
commit36e55fc8582b7c256ddf606ff096eafd10c237ab (patch)
treee38c4c0dbe707688b9ec8e73a198595fddc65a8e /ext/annodex/gstcmmldec.c
parent22e1a6cf15645507e499bc00f69d3ea5339de801 (diff)
ext/annodex/: Fix possible memleaks.
Original commit message from CVS: 2006-02-25 Julien MOUTTE <julien@moutte.net> * ext/annodex/gstcmmldec.c: (gst_cmml_dec_class_init), (gst_cmml_dec_finalize), (gst_cmml_dec_change_state): * ext/annodex/gstcmmlenc.c: (gst_cmml_enc_class_init), (gst_cmml_enc_finalize), (gst_cmml_enc_change_state): * ext/annodex/gstcmmlutils.c: (gst_cmml_track_list_destroy): Fix possible memleaks.
Diffstat (limited to 'ext/annodex/gstcmmldec.c')
-rw-r--r--ext/annodex/gstcmmldec.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/ext/annodex/gstcmmldec.c b/ext/annodex/gstcmmldec.c
index f996f3f2..54ea2134 100644
--- a/ext/annodex/gstcmmldec.c
+++ b/ext/annodex/gstcmmldec.c
@@ -121,6 +121,8 @@ static void gst_cmml_dec_push_clip (GstCmmlDec * dec, GstCmmlTagClip * clip);
static void gst_cmml_dec_send_clip_tag (GstCmmlDec * dec,
GstCmmlTagClip * clip);
+static void gst_cmml_dec_finalize (GObject * object);
+
static void
gst_cmml_dec_base_init (gpointer g_class)
{
@@ -142,6 +144,7 @@ gst_cmml_dec_class_init (GstCmmlDecClass * dec_class)
klass->set_property = gst_cmml_dec_set_property;
klass->get_property = gst_cmml_dec_get_property;
+ klass->finalize = gst_cmml_dec_finalize;
g_object_class_install_property (klass, GST_CMML_DEC_WAIT_CLIP_END,
g_param_spec_boolean ("wait-clip-end-time",
@@ -199,6 +202,19 @@ gst_cmml_dec_set_property (GObject * object, guint property_id,
}
}
+static void
+gst_cmml_dec_finalize (GObject * object)
+{
+ GstCmmlDec *dec = GST_CMML_DEC (object);
+
+ if (dec->tracks) {
+ gst_cmml_track_list_destroy (dec->tracks);
+ dec->tracks = NULL;
+ }
+
+ G_OBJECT_CLASS (parent_class)->finalize (object);
+}
+
static GstStateChangeReturn
gst_cmml_dec_change_state (GstElement * element, GstStateChange transition)
{
@@ -235,6 +251,7 @@ gst_cmml_dec_change_state (GstElement * element, GstStateChange transition)
case GST_STATE_CHANGE_PAUSED_TO_READY:
gst_cmml_parser_free (dec->parser);
gst_cmml_track_list_destroy (dec->tracks);
+ dec->tracks = NULL;
break;
default:
break;