From 6fa5b4ff14b88eff42f36fb74058bdb46c6e92b4 Mon Sep 17 00:00:00 2001 From: Carl-Anton Ingmarsson Date: Wed, 1 Apr 2009 21:40:14 +0200 Subject: vdpau: make the decoder clean up after itself --- sys/vdpau/gstvdpaudecoder.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'sys/vdpau/gstvdpaudecoder.c') diff --git a/sys/vdpau/gstvdpaudecoder.c b/sys/vdpau/gstvdpaudecoder.c index deb93c49..8d5ed4e5 100644 --- a/sys/vdpau/gstvdpaudecoder.c +++ b/sys/vdpau/gstvdpaudecoder.c @@ -57,6 +57,7 @@ static GstStaticPadTemplate src_template = GST_STATIC_PAD_TEMPLATE ("src", GST_BOILERPLATE_FULL (GstVdpauDecoder, gst_vdpaudecoder, GstElement, GST_TYPE_ELEMENT, DEBUG_INIT); +static void gst_vdpau_decoder_finalize (GObject * object); static void gst_vdpaudecoder_set_property (GObject * object, guint prop_id, const GValue * value, GParamSpec * pspec); static void gst_vdpaudecoder_get_property (GObject * object, guint prop_id, @@ -453,6 +454,7 @@ gst_vdpaudecoder_class_init (GstVdpauDecoderClass * klass) gobject_class = (GObjectClass *) klass; gstelement_class = (GstElementClass *) klass; + gobject_class->finalize = gst_vdpau_decoder_finalize; gobject_class->set_property = gst_vdpaudecoder_set_property; gobject_class->get_property = gst_vdpaudecoder_get_property; @@ -494,6 +496,19 @@ gst_vdpaudecoder_init (GstVdpauDecoder * dec, GstVdpauDecoderClass * klass) gst_pad_set_active (dec->sink, TRUE); } +static void +gst_vdpau_decoder_finalize (GObject * object) +{ + GstVdpauDecoder *dec = (GstVdpauDecoder *) object; + + if (dec->src_caps) + g_object_unref (dec->src_caps); + if (dec->device) + g_object_unref (dec->device); + + g_free (dec->display_name); +} + static void gst_vdpaudecoder_set_property (GObject * object, guint prop_id, const GValue * value, GParamSpec * pspec) -- cgit v1.2.1