summaryrefslogtreecommitdiff
path: root/gst/hls
diff options
context:
space:
mode:
authorAndoni Morales Alastruey <ylatuya@gmail.com>2011-02-15 21:55:26 +0100
committerSebastian Dröge <sebastian.droege@collabora.co.uk>2011-03-30 09:19:21 +0200
commitfe883740c5819b079cd0877e7d6ad5e107757fa4 (patch)
tree140bc9e77ecc78cadf7177e762cce335b629dc03 /gst/hls
parent5a40a62ff4f402f8a15cda1ae1817b26d730c6d0 (diff)
hlsdemux: reuse the code in reset() to free resources in dispose()
Diffstat (limited to 'gst/hls')
-rw-r--r--gst/hls/gsthlsdemux.c26
1 files changed, 9 insertions, 17 deletions
diff --git a/gst/hls/gsthlsdemux.c b/gst/hls/gsthlsdemux.c
index 48666b1d8..c15501317 100644
--- a/gst/hls/gsthlsdemux.c
+++ b/gst/hls/gsthlsdemux.c
@@ -103,7 +103,7 @@ static gboolean gst_hls_demux_schedule (GstHLSDemux * demux);
static gboolean gst_hls_demux_switch_playlist (GstHLSDemux * demux);
static gboolean gst_hls_demux_get_next_fragment (GstHLSDemux * demux, gboolean retry);
static gboolean gst_hls_demux_update_playlist (GstHLSDemux * demux, gboolean retry);
-static void gst_hls_demux_reset (GstHLSDemux * demux);
+static void gst_hls_demux_reset (GstHLSDemux * demux, gboolean dispose);
static gboolean gst_hls_demux_set_location (GstHLSDemux * demux, const gchar * uri);
static void
@@ -142,11 +142,6 @@ gst_hls_demux_dispose (GObject * obj)
g_cond_free (demux->fetcher_cond);
g_mutex_free (demux->fetcher_lock);
- if (demux->client) {
- gst_m3u8_client_free (demux->client);
- demux->client = NULL;
- }
-
g_cond_free (demux->thread_cond);
g_mutex_free (demux->thread_lock);
@@ -157,15 +152,11 @@ gst_hls_demux_dispose (GObject * obj)
gst_object_unref (demux->task);
g_static_rec_mutex_free (&demux->task_lock);
- while (!g_queue_is_empty (demux->queue)) {
- GstBuffer *buf = g_queue_pop_head (demux->queue);
- gst_buffer_unref (buf);
- }
- g_queue_free (demux->queue);
-
gst_object_unref (demux->fetcher_bus);
gst_object_unref (demux->fetcherpad);
+ gst_hls_demux_reset (demux, TRUE);
+
G_OBJECT_CLASS (parent_class)->dispose (obj);
}
@@ -238,8 +229,6 @@ gst_hls_demux_init (GstHLSDemux * demux, GstHLSDemuxClass * klass)
g_static_rec_mutex_init (&demux->task_lock);
demux->task = gst_task_create ((GstTaskFunction) gst_hls_demux_loop, demux);
gst_task_set_lock (demux->task, &demux->task_lock);
-
- gst_hls_demux_reset (demux);
}
static void
@@ -288,7 +277,7 @@ gst_hls_demux_change_state (GstElement * element, GstStateChange transition)
switch (transition) {
case GST_STATE_CHANGE_NULL_TO_READY:
- gst_hls_demux_reset (demux);
+ gst_hls_demux_reset (demux, FALSE);
break;
default:
break;
@@ -577,7 +566,7 @@ gst_hls_demux_make_fetcher (GstHLSDemux * demux, const gchar * uri)
}
static void
-gst_hls_demux_reset (GstHLSDemux * demux)
+gst_hls_demux_reset (GstHLSDemux * demux, gboolean dispose)
{
demux->need_cache = TRUE;
demux->thread_return = FALSE;
@@ -601,7 +590,10 @@ gst_hls_demux_reset (GstHLSDemux * demux)
if (demux->client)
gst_m3u8_client_free (demux->client);
- demux->client = gst_m3u8_client_new ("");
+
+ if (!dispose) {
+ demux->client = gst_m3u8_client_new ("");
+ }
while (!g_queue_is_empty (demux->queue)) {
GstBuffer *buf = g_queue_pop_head (demux->queue);