mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 06:29:31 +00:00
Seek event handling cleanup
This commit is contained in:
parent
b580ee8cd7
commit
84c8de8ab6
1 changed files with 17 additions and 16 deletions
|
@ -489,8 +489,6 @@ gst_dash_demux_src_event (GstPad * pad, GstEvent * event)
|
||||||
guint nb_active_stream;
|
guint nb_active_stream;
|
||||||
guint stream_idx;
|
guint stream_idx;
|
||||||
|
|
||||||
GST_INFO_OBJECT (demux, "Received GST_EVENT_SEEK");
|
|
||||||
|
|
||||||
if (gst_mpd_client_is_live (demux->client)) {
|
if (gst_mpd_client_is_live (demux->client)) {
|
||||||
GST_WARNING_OBJECT (demux, "Received seek event for live stream");
|
GST_WARNING_OBJECT (demux, "Received seek event for live stream");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -502,16 +500,13 @@ gst_dash_demux_src_event (GstPad * pad, GstEvent * event)
|
||||||
if (format != GST_FORMAT_TIME)
|
if (format != GST_FORMAT_TIME)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
nb_active_stream = gst_mpdparser_get_nb_active_stream (demux->client);
|
GST_DEBUG_OBJECT (demux,
|
||||||
gst_task_stop (demux->download_task);
|
"seek event, rate: %f type: %d start: %" GST_TIME_FORMAT " stop: %"
|
||||||
GST_DEBUG_OBJECT (demux, "seek event, rate: %f start: %" GST_TIME_FORMAT
|
GST_TIME_FORMAT, rate, start_type, GST_TIME_ARGS (start),
|
||||||
" stop: %" GST_TIME_FORMAT, rate, GST_TIME_ARGS (start),
|
|
||||||
GST_TIME_ARGS (stop));
|
GST_TIME_ARGS (stop));
|
||||||
|
|
||||||
GST_MPD_CLIENT_LOCK (demux->client);
|
GST_MPD_CLIENT_LOCK (demux->client);
|
||||||
stream =
|
stream = gst_mpdparser_get_active_stream_by_index (demux->client, 0);
|
||||||
g_list_nth_data (demux->client->active_streams,
|
|
||||||
demux->client->stream_idx);
|
|
||||||
|
|
||||||
current_pos = 0;
|
current_pos = 0;
|
||||||
target_pos = (GstClockTime) start;
|
target_pos = (GstClockTime) start;
|
||||||
|
@ -527,12 +522,12 @@ gst_dash_demux_src_event (GstPad * pad, GstEvent * event)
|
||||||
GST_MPD_CLIENT_UNLOCK (demux->client);
|
GST_MPD_CLIENT_UNLOCK (demux->client);
|
||||||
|
|
||||||
if (walk == NULL) {
|
if (walk == NULL) {
|
||||||
gst_dash_demux_resume_stream_task (demux);
|
|
||||||
gst_dash_demux_resume_download_task (demux);
|
|
||||||
GST_WARNING_OBJECT (demux, "Could not find seeked fragment");
|
GST_WARNING_OBJECT (demux, "Could not find seeked fragment");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* We can actually perform the seek */
|
||||||
|
nb_active_stream = gst_mpdparser_get_nb_active_stream (demux->client);
|
||||||
|
|
||||||
if (flags & GST_SEEK_FLAG_FLUSH) {
|
if (flags & GST_SEEK_FLAG_FLUSH) {
|
||||||
GST_DEBUG_OBJECT (demux, "sending flush start");
|
GST_DEBUG_OBJECT (demux, "sending flush start");
|
||||||
|
@ -544,25 +539,30 @@ gst_dash_demux_src_event (GstPad * pad, GstEvent * event)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Stop the demux */
|
||||||
demux->cancelled = TRUE;
|
demux->cancelled = TRUE;
|
||||||
gst_dash_demux_pause_stream_task (demux);
|
gst_dash_demux_stop (demux);
|
||||||
gst_uri_downloader_cancel (demux->downloader);
|
|
||||||
|
|
||||||
/* wait for streaming to finish */
|
/* Wait for streaming to finish */
|
||||||
g_static_rec_mutex_lock (&demux->stream_lock);
|
g_static_rec_mutex_lock (&demux->stream_lock);
|
||||||
|
|
||||||
|
/* Clear the buffering queue */
|
||||||
|
/* FIXME: allow seeking in the buffering queue */
|
||||||
gst_dash_demux_clear_queue (demux);
|
gst_dash_demux_clear_queue (demux);
|
||||||
|
|
||||||
GST_MPD_CLIENT_LOCK (demux->client);
|
GST_MPD_CLIENT_LOCK (demux->client);
|
||||||
GST_DEBUG_OBJECT (demux, "seeking to sequence %d", current_sequence);
|
GST_DEBUG_OBJECT (demux, "Seeking to sequence %d", current_sequence);
|
||||||
stream_idx = 0;
|
stream_idx = 0;
|
||||||
|
/* Update the current sequence on all streams */
|
||||||
while (stream_idx < nb_active_stream) {
|
while (stream_idx < nb_active_stream) {
|
||||||
stream =
|
stream =
|
||||||
gst_mpdparser_get_active_stream_by_index (demux->client,
|
gst_mpdparser_get_active_stream_by_index (demux->client,
|
||||||
stream_idx);
|
stream_idx);
|
||||||
|
/* FIXME: we should'nt fiddle with stream internals like that */
|
||||||
stream->segment_idx = current_sequence;
|
stream->segment_idx = current_sequence;
|
||||||
stream_idx++;
|
stream_idx++;
|
||||||
}
|
}
|
||||||
|
/* Calculate offset in the next fragment */
|
||||||
gst_mpd_client_get_current_position (demux->client, &demux->position);
|
gst_mpd_client_get_current_position (demux->client, &demux->position);
|
||||||
demux->position_shift = start - demux->position;
|
demux->position_shift = start - demux->position;
|
||||||
demux->need_segment = TRUE;
|
demux->need_segment = TRUE;
|
||||||
|
@ -570,7 +570,7 @@ gst_dash_demux_src_event (GstPad * pad, GstEvent * event)
|
||||||
|
|
||||||
|
|
||||||
if (flags & GST_SEEK_FLAG_FLUSH) {
|
if (flags & GST_SEEK_FLAG_FLUSH) {
|
||||||
GST_DEBUG_OBJECT (demux, "sending flush stop on all pad");
|
GST_DEBUG_OBJECT (demux, "Sending flush stop on all pad");
|
||||||
stream_idx = 0;
|
stream_idx = 0;
|
||||||
while (stream_idx < nb_active_stream) {
|
while (stream_idx < nb_active_stream) {
|
||||||
gst_pad_push_event (demux->srcpad[stream_idx],
|
gst_pad_push_event (demux->srcpad[stream_idx],
|
||||||
|
@ -579,6 +579,7 @@ gst_dash_demux_src_event (GstPad * pad, GstEvent * event)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Restart the demux */
|
||||||
demux->cancelled = FALSE;
|
demux->cancelled = FALSE;
|
||||||
gst_dash_demux_resume_download_task (demux);
|
gst_dash_demux_resume_download_task (demux);
|
||||||
gst_dash_demux_resume_stream_task (demux);
|
gst_dash_demux_resume_stream_task (demux);
|
||||||
|
|
Loading…
Reference in a new issue