summaryrefslogtreecommitdiff
path: root/gst-libs
diff options
context:
space:
mode:
authorThiago Santos <thiago.sousa.santos@collabora.com>2013-02-07 00:28:15 -0300
committerThiago Santos <thiago.sousa.santos@collabora.com>2013-05-07 20:02:41 -0300
commit99efe87b5dd357cff504cfdca340ec0368af2616 (patch)
tree880a5867515b511eab74b6e064b49db609eb1548 /gst-libs
parentf72869816c543ef9c01abdd79fecf63a1ba2fbec (diff)
downloadgstreamer-plugins-bad-99efe87b5dd357cff504cfdca340ec0368af2616.tar.gz
uridownloader: properly unref the urisrc between downloads
This prevents leaking the element. Also sets the bus to flushing to completely reset the downloader state
Diffstat (limited to 'gst-libs')
-rw-r--r--gst-libs/gst/uridownloader/gsturidownloader.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/gst-libs/gst/uridownloader/gsturidownloader.c b/gst-libs/gst/uridownloader/gsturidownloader.c
index 4ca0dc70e..142bb2a56 100644
--- a/gst-libs/gst/uridownloader/gsturidownloader.c
+++ b/gst-libs/gst/uridownloader/gsturidownloader.c
@@ -248,7 +248,8 @@ gst_uri_downloader_stop (GstUriDownloader * downloader)
{
GstPad *pad;
- GST_DEBUG_OBJECT (downloader, "Stopping source element");
+ GST_DEBUG_OBJECT (downloader, "Stopping source element %s",
+ GST_ELEMENT_NAME (downloader->priv->urisrc));
/* remove the bus' sync handler */
gst_bus_set_sync_handler (downloader->priv->bus, NULL, NULL, NULL);
@@ -262,6 +263,11 @@ gst_uri_downloader_stop (GstUriDownloader * downloader)
gst_element_set_state (downloader->priv->urisrc, GST_STATE_NULL);
gst_element_get_state (downloader->priv->urisrc, NULL, NULL,
GST_CLOCK_TIME_NONE);
+ gst_element_set_bus (downloader->priv->urisrc, NULL);
+ gst_object_unref (downloader->priv->urisrc);
+ downloader->priv->urisrc = NULL;
+
+ gst_bus_set_flushing (downloader->priv->bus, TRUE);
}
void
@@ -308,6 +314,8 @@ gst_uri_downloader_set_uri (GstUriDownloader * downloader, const gchar * uri)
if (!gst_uri_is_valid (uri))
return FALSE;
+ g_assert (downloader->priv->urisrc == NULL);
+
GST_DEBUG_OBJECT (downloader, "Creating source element for the URI:%s", uri);
downloader->priv->urisrc =
gst_element_make_from_uri (GST_URI_SRC, uri, NULL, NULL);
@@ -346,6 +354,7 @@ gst_uri_downloader_fetch_uri (GstUriDownloader * downloader, const gchar * uri)
downloader->priv->download = gst_fragment_new ();
+ gst_bus_set_flushing (downloader->priv->bus, FALSE);
ret = gst_element_set_state (downloader->priv->urisrc, GST_STATE_PLAYING);
if (ret == GST_STATE_CHANGE_FAILURE) {
g_object_unref (downloader->priv->download);