mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-02 05:28:48 +00:00
Replaced references to playlist (HLS) by references to manifest (DASH)
This commit is contained in:
parent
ad22e0da6d
commit
7764efb761
2 changed files with 34 additions and 34 deletions
|
@ -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, ×tamp)) {
|
stream_idx, &discont, &next_fragment_uri, &duration, ×tamp)) {
|
||||||
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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
Loading…
Reference in a new issue