aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2012-02-24 21:55:04 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2012-02-27 15:46:44 +0800
commited191caba6658b580db78a1802f2c8293e4564fb (patch)
tree4cf418bfa5b7e668d2094d5fd10007f8eaa2d32c
parente790a2faa4d607cd812d6babe22b0078ba5906d4 (diff)
downloadgsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.tar
gsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.tar.gz
gsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.tar.bz2
gsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.tar.lz
gsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.tar.xz
gsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.tar.zst
gsoc2013-empathy-ed191caba6658b580db78a1802f2c8293e4564fb.zip
audio-sink: fix GstPad leaks
gst_ghost_pad_new() doesn't take ownership of the target pad so we have to unref it ourself. https://bugzilla.gnome.org/show_bug.cgi?id=670745
-rw-r--r--src/empathy-audio-sink.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/empathy-audio-sink.c b/src/empathy-audio-sink.c
index fbffa4885..b4680a0fb 100644
--- a/src/empathy-audio-sink.c
+++ b/src/empathy-audio-sink.c
@@ -301,7 +301,7 @@ empathy_audio_sink_request_new_pad (GstElement *element,
EmpathyGstAudioSink *self = EMPATHY_GST_AUDIO_SINK (element);
GstElement *bin, *resample, *audioconvert0, *audioconvert1;
GstPad *pad = NULL;
- GstPad *subpad, *filterpad;
+ GstPad *subpad = NULL, *filterpad;
bin = gst_bin_new (NULL);
@@ -355,6 +355,8 @@ empathy_audio_sink_request_new_pad (GstElement *element,
goto error;
subpad = gst_ghost_pad_new ("sink", filterpad);
+ gst_object_unref (filterpad);
+
if (!gst_element_add_pad (GST_ELEMENT (bin), subpad))
goto error;
@@ -362,6 +364,7 @@ empathy_audio_sink_request_new_pad (GstElement *element,
pad = gst_ghost_pad_new (name, subpad);
g_assert (pad != NULL);
+ gst_object_unref (subpad);
if (!gst_element_sync_state_with_parent (bin))
goto error;
@@ -380,6 +383,8 @@ error:
gst_object_unref (pad);
}
+ tp_clear_pointer (&subpad, gst_object_unref);
+
gst_object_unref (bin);
g_warning ("Failed to create output subpipeline");
return NULL;