From be8cbdb4a1e4f4805dd2a8eedaa469074492740c Mon Sep 17 00:00:00 2001
From: Edward Hervey <bilboed@bilboed.com>
Date: Mon, 21 Jun 2010 11:54:01 +0200
Subject: [PATCH] GESTimelinePipeline: unref all pads

---
 ges/ges-timeline-pipeline.c | 20 ++++++++++++++++----
 1 file changed, 16 insertions(+), 4 deletions(-)

diff --git a/ges/ges-timeline-pipeline.c b/ges/ges-timeline-pipeline.c
index aeec8da3e9..17ab9ea130 100644
--- a/ges/ges-timeline-pipeline.c
+++ b/ges/ges-timeline-pipeline.c
@@ -363,10 +363,12 @@ pad_added_cb (GstElement * timeline, GstPad * pad, GESTimelinePipeline * self)
   /* Linking pad to tee */
   sinkpad = gst_element_get_static_pad (chain->tee, "sink");
   gst_pad_link (pad, sinkpad);
+  gst_object_unref (sinkpad);
 
   /* Connect playsink */
   if (self->mode & TIMELINE_MODE_PREVIEW) {
     const gchar *sinkpad_name;
+    GstPad *tmppad;
 
     GST_DEBUG_OBJECT (self, "Connecting to playsink");
 
@@ -393,11 +395,13 @@ pad_added_cb (GstElement * timeline, GstPad * pad, GESTimelinePipeline * self)
       goto error;
     }
 
-    if (G_UNLIKELY (gst_pad_link (gst_element_get_request_pad (chain->tee,
-                    "src%d"), sinkpad) != GST_PAD_LINK_OK)) {
+    tmppad = gst_element_get_request_pad (chain->tee, "src%d");
+    if (G_UNLIKELY (gst_pad_link (tmppad, sinkpad) != GST_PAD_LINK_OK)) {
       GST_ERROR_OBJECT (self, "Couldn't link track pad to playsink");
+      gst_object_unref (tmppad);
       goto error;
     }
+    gst_object_unref (tmppad);
 
     GST_DEBUG ("Reconfiguring playsink");
 
@@ -405,11 +409,13 @@ pad_added_cb (GstElement * timeline, GstPad * pad, GESTimelinePipeline * self)
     g_signal_emit_by_name (self->playsink, "reconfigure", &reconfigured);
     GST_DEBUG ("'reconfigure' returned %d", reconfigured);
 
+    /* We still hold a reference on the sinkpad */
     chain->playsinkpad = sinkpad;
   }
 
   /* Connect to encodebin */
   if (self->mode & (TIMELINE_MODE_RENDER | TIMELINE_MODE_SMART_RENDER)) {
+    GstPad *tmppad;
     GST_DEBUG_OBJECT (self, "Connecting to encodebin");
 
     if (!chain->encodebinpad) {
@@ -428,11 +434,13 @@ pad_added_cb (GstElement * timeline, GstPad * pad, GESTimelinePipeline * self)
       chain->encodebinpad = sinkpad;
     }
 
-    if (G_UNLIKELY (gst_pad_link (gst_element_get_request_pad (chain->tee,
-                    "src%d"), chain->encodebinpad) != GST_PAD_LINK_OK)) {
+    tmppad = gst_element_get_request_pad (chain->tee, "src%d");
+    if (G_UNLIKELY (gst_pad_link (tmppad,
+                chain->encodebinpad) != GST_PAD_LINK_OK)) {
       GST_WARNING_OBJECT (self, "Couldn't link track pad to playsink");
       goto error;
     }
+    gst_object_unref (tmppad);
 
   }
 
@@ -478,6 +486,7 @@ pad_removed_cb (GstElement * timeline, GstPad * pad, GESTimelinePipeline * self)
   if (chain->encodebinpad) {
     peer = gst_pad_get_peer (chain->encodebinpad);
     gst_pad_unlink (peer, chain->encodebinpad);
+    gst_object_unref (peer);
     gst_element_release_request_pad (self->encodebin, chain->encodebinpad);
   }
 
@@ -485,12 +494,15 @@ pad_removed_cb (GstElement * timeline, GstPad * pad, GESTimelinePipeline * self)
   if (chain->playsinkpad) {
     peer = gst_pad_get_peer (chain->playsinkpad);
     gst_pad_unlink (peer, chain->playsinkpad);
+    gst_object_unref (peer);
     gst_element_release_request_pad (self->playsink, chain->playsinkpad);
+    gst_object_unref (chain->playsinkpad);
   }
 
   /* Unlike/remove tee */
   peer = gst_element_get_static_pad (chain->tee, "sink");
   gst_pad_unlink (pad, peer);
+  gst_object_unref (peer);
   gst_element_set_state (chain->tee, GST_STATE_NULL);
   gst_bin_remove (GST_BIN (self), chain->tee);