Replaced references to playlist (HLS) by references to manifest (DASH)

This commit is contained in:
David Corvoysier 2012-10-15 11:40:55 +02:00 committed by Thiago Santos
parent ad22e0da6d
commit 7764efb761
2 changed files with 34 additions and 34 deletions

View file

@ -320,7 +320,7 @@ gst_dash_demux_change_state (GstElement * element, GstStateChange transition)
break; break;
case GST_STATE_CHANGE_PAUSED_TO_PLAYING: case GST_STATE_CHANGE_PAUSED_TO_PLAYING:
/* Start the streaming loop in paused only if we already received /* Start the streaming loop in paused only if we already received
the main playlist. It might have been stopped if we were in PAUSED the manifest. It might have been stopped if we were in PAUSED
state and we filled our queue with enough cached fragments state and we filled our queue with enough cached fragments
*/ */
if (gst_mpdparser_get_baseURL (demux->client) != NULL) if (gst_mpdparser_get_baseURL (demux->client) != NULL)
@ -492,17 +492,17 @@ gst_dash_demux_sink_event (GstPad * pad, GstEvent * event)
switch (event->type) { switch (event->type) {
case GST_EVENT_EOS:{ case GST_EVENT_EOS:{
gchar *playlist; gchar *manifest;
GstQuery *query; GstQuery *query;
gboolean res; gboolean res;
if (demux->playlist == NULL) { if (demux->manifest == NULL) {
GST_WARNING_OBJECT (demux, "Received EOS without a playlist."); GST_WARNING_OBJECT (demux, "Received EOS without a manifest.");
break; break;
} }
GST_DEBUG_OBJECT (demux, GST_DEBUG_OBJECT (demux,
"Got EOS on the sink pad: main playlist fetched"); "Got EOS on the sink pad: manifest fetched");
if (demux->client) if (demux->client)
gst_mpd_client_free (demux->client); gst_mpd_client_free (demux->client);
@ -519,20 +519,20 @@ gst_dash_demux_sink_event (GstPad * pad, GstEvent * event)
} }
gst_query_unref (query); gst_query_unref (query);
playlist = (gchar *) GST_BUFFER_DATA (demux->playlist); manifest = (gchar *) GST_BUFFER_DATA (demux->manifest);
if (playlist == NULL) { if (manifest == NULL) {
GST_WARNING_OBJECT (demux, "Error validating first playlist."); GST_WARNING_OBJECT (demux, "Error validating the manifest.");
} else if (!gst_mpd_parse (demux->client, playlist, } else if (!gst_mpd_parse (demux->client, manifest,
GST_BUFFER_SIZE (demux->playlist))) { GST_BUFFER_SIZE (demux->manifest))) {
/* In most cases, this will happen if we set a wrong url in the /* In most cases, this will happen if we set a wrong url in the
* source element and we have received the 404 HTML response instead of * source element and we have received the 404 HTML response instead of
* the playlist */ * the manifest */
GST_ELEMENT_ERROR (demux, STREAM, DECODE, ("Invalid playlist."), GST_ELEMENT_ERROR (demux, STREAM, DECODE, ("Invalid manifest."),
(NULL)); (NULL));
return FALSE; return FALSE;
} }
gst_buffer_unref (demux->playlist); gst_buffer_unref (demux->manifest);
demux->playlist = NULL; demux->manifest = NULL;
if (!gst_mpd_client_setup_streaming (demux->client, GST_STREAM_VIDEO, "")) { if (!gst_mpd_client_setup_streaming (demux->client, GST_STREAM_VIDEO, "")) {
GST_ELEMENT_ERROR (demux, STREAM, DECODE, GST_ELEMENT_ERROR (demux, STREAM, DECODE,
@ -667,7 +667,7 @@ gst_dash_demux_src_query (GstPad * pad, GstQuery * query)
default: default:
/* Don't fordward queries upstream because of the special nature of this /* Don't fordward queries upstream because of the special nature of this
* "demuxer", which relies on the upstream element only to be fed with the * "demuxer", which relies on the upstream element only to be fed with the
* first playlist */ * manifest file */
break; break;
} }
@ -679,10 +679,10 @@ gst_dash_demux_pad (GstPad * pad, GstBuffer * buf)
{ {
GstDashDemux *demux = GST_DASH_DEMUX (gst_pad_get_parent (pad)); GstDashDemux *demux = GST_DASH_DEMUX (gst_pad_get_parent (pad));
if (demux->playlist == NULL) if (demux->manifest == NULL)
demux->playlist = buf; demux->manifest = buf;
else else
demux->playlist = gst_buffer_join (demux->playlist, buf); demux->manifest = gst_buffer_join (demux->manifest, buf);
gst_object_unref (demux); gst_object_unref (demux);
@ -795,7 +795,7 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
* a buffering event to tell the main application to pause. * a buffering event to tell the main application to pause.
* *
* Teardown: * Teardown:
* The task is stopped when we reach the end of the playlist */ * The task is stopped when we reach the end of the manifest */
/* Wait until the next scheduled push downstream */ /* Wait until the next scheduled push downstream */
if (g_cond_timed_wait (GST_TASK_GET_COND (demux->stream_task), if (g_cond_timed_wait (GST_TASK_GET_COND (demux->stream_task),
@ -804,14 +804,14 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
} }
if (g_queue_is_empty (demux->queue)) { if (g_queue_is_empty (demux->queue)) {
if (demux->end_of_playlist) if (demux->end_of_manifest)
goto end_of_playlist; goto end_of_manifest;
return; return;
} }
if (GST_STATE (demux) == GST_STATE_PLAYING) { if (GST_STATE (demux) == GST_STATE_PLAYING) {
if (!demux->end_of_playlist if (!demux->end_of_manifest
&& gst_dash_demux_get_buffering_time (demux) < && gst_dash_demux_get_buffering_time (demux) <
demux->min_buffering_time) { demux->min_buffering_time) {
/* Warn we are below our threshold: this will eventually pause /* Warn we are below our threshold: this will eventually pause
@ -862,9 +862,9 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
return; return;
end_of_playlist: end_of_manifest:
{ {
GST_DEBUG_OBJECT (demux, "Reached end of playlist, sending EOS"); GST_DEBUG_OBJECT (demux, "Reached end of manifest, sending EOS");
guint i = 0; guint i = 0;
for (i = 0; i < nb_adaptation_set; i++) { for (i = 0; i < nb_adaptation_set; i++) {
gst_pad_push_event (demux->srcpad[i], gst_event_new_eos ()); gst_pad_push_event (demux->srcpad[i], gst_event_new_eos ());
@ -892,7 +892,7 @@ pause_task:
static void static void
gst_dash_demux_reset (GstDashDemux * demux, gboolean dispose) gst_dash_demux_reset (GstDashDemux * demux, gboolean dispose)
{ {
demux->end_of_playlist = FALSE; demux->end_of_manifest = FALSE;
demux->cancelled = FALSE; demux->cancelled = FALSE;
guint i = 0; guint i = 0;
@ -902,9 +902,9 @@ gst_dash_demux_reset (GstDashDemux * demux, gboolean dispose)
demux->input_caps[i] = NULL; demux->input_caps[i] = NULL;
} }
if (demux->playlist) { if (demux->manifest) {
gst_buffer_unref (demux->playlist); gst_buffer_unref (demux->manifest);
demux->playlist = NULL; demux->manifest = NULL;
} }
if (demux->client) { if (demux->client) {
gst_mpd_client_free (demux->client); gst_mpd_client_free (demux->client);
@ -970,7 +970,7 @@ gst_dash_demux_download_loop (GstDashDemux * demux)
gst_mpd_client_get_target_duration (demux->client); gst_mpd_client_get_target_duration (demux->client);
if (demux->max_buffering_time > target_buffering_time) if (demux->max_buffering_time > target_buffering_time)
target_buffering_time = demux->max_buffering_time; target_buffering_time = demux->max_buffering_time;
if (!demux->end_of_playlist if (!demux->end_of_manifest
&& gst_dash_demux_get_buffering_time (demux) < target_buffering_time) { && gst_dash_demux_get_buffering_time (demux) < target_buffering_time) {
if (GST_STATE (demux) != GST_STATE_PLAYING) { if (GST_STATE (demux) != GST_STATE_PLAYING) {
/* Signal our buffering status (this will eventually restart the /* Signal our buffering status (this will eventually restart the
@ -987,7 +987,7 @@ gst_dash_demux_download_loop (GstDashDemux * demux)
gst_dash_demux_get_buffering_ratio (demux)); gst_dash_demux_get_buffering_ratio (demux));
if (!gst_dash_demux_get_next_fragment (demux, FALSE)) { if (!gst_dash_demux_get_next_fragment (demux, FALSE)) {
if (!demux->end_of_playlist && !demux->cancelled) { if (!demux->end_of_manifest && !demux->cancelled) {
demux->client->update_failed_count++; demux->client->update_failed_count++;
if (demux->client->update_failed_count < DEFAULT_FAILED_COUNT) { if (demux->client->update_failed_count < DEFAULT_FAILED_COUNT) {
GST_WARNING_OBJECT (demux, "Could not fetch the next fragment"); GST_WARNING_OBJECT (demux, "Could not fetch the next fragment");
@ -1325,8 +1325,8 @@ gst_dash_demux_get_next_fragment (GstDashDemux * demux, gboolean caching)
while (stream_idx < gst_mpdparser_get_nb_active_stream (demux->client)) { while (stream_idx < gst_mpdparser_get_nb_active_stream (demux->client)) {
if (!gst_mpd_client_get_next_fragment (demux->client, if (!gst_mpd_client_get_next_fragment (demux->client,
stream_idx, &discont, &next_fragment_uri, &duration, &timestamp)) { stream_idx, &discont, &next_fragment_uri, &duration, &timestamp)) {
GST_INFO_OBJECT (demux, "This playlist doesn't contain more fragments"); GST_INFO_OBJECT (demux, "This manifest doesn't contain more fragments");
demux->end_of_playlist = TRUE; demux->end_of_manifest = TRUE;
gst_task_start (demux->stream_task); gst_task_start (demux->stream_task);
return FALSE; return FALSE;
} }

View file

@ -64,11 +64,11 @@ struct _GstDashDemux
GstCaps *output_caps[MAX_LANGUAGES]; /*Video/Audio/Application output buf caps*/ GstCaps *output_caps[MAX_LANGUAGES]; /*Video/Audio/Application output buf caps*/
GstCaps *input_caps[MAX_LANGUAGES]; /*Video/Audio/Application input caps*/ GstCaps *input_caps[MAX_LANGUAGES]; /*Video/Audio/Application input caps*/
GstBuffer *playlist; GstBuffer *manifest;
GstUriDownloader *downloader; GstUriDownloader *downloader;
GstMpdClient *client; /* MPD client */ GstMpdClient *client; /* MPD client */
GQueue *queue; /*Video/Audio/Application List of fragment storing the fetched fragments */ GQueue *queue; /*Video/Audio/Application List of fragment storing the fetched fragments */
gboolean end_of_playlist; gboolean end_of_manifest;
/* Properties */ /* Properties */
GstClockTime min_buffering_time; /* Minimum buffering time accumulated before playback */ GstClockTime min_buffering_time; /* Minimum buffering time accumulated before playback */