mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
hlsdemux: switch pads when we seek (need_segment) since tsdemux doesn't cope well with a reset
This commit is contained in:
parent
2d90f1c0dc
commit
3f42050c34
1 changed files with 8 additions and 1 deletions
|
@ -706,12 +706,19 @@ gst_hls_demux_loop (GstHLSDemux * demux)
|
||||||
|
|
||||||
/* Figure out if we need to create/switch pads */
|
/* Figure out if we need to create/switch pads */
|
||||||
if (G_UNLIKELY (!demux->srcpad
|
if (G_UNLIKELY (!demux->srcpad
|
||||||
|| GST_BUFFER_CAPS (buf) != GST_PAD_CAPS (demux->srcpad))) {
|
|| GST_BUFFER_CAPS (buf) != GST_PAD_CAPS (demux->srcpad)
|
||||||
|
|| demux->need_segment)) {
|
||||||
switch_pads (demux, GST_BUFFER_CAPS (buf));
|
switch_pads (demux, GST_BUFFER_CAPS (buf));
|
||||||
|
demux->need_segment = TRUE;
|
||||||
|
}
|
||||||
|
if (demux->need_segment) {
|
||||||
/* And send a newsegment */
|
/* And send a newsegment */
|
||||||
|
GST_DEBUG_OBJECT (demux, "Sending new-segment. Segment start:%"
|
||||||
|
GST_TIME_FORMAT, GST_TIME_ARGS (demux->position));
|
||||||
gst_pad_push_event (demux->srcpad,
|
gst_pad_push_event (demux->srcpad,
|
||||||
gst_event_new_new_segment (0, 1.0, GST_FORMAT_TIME, demux->position,
|
gst_event_new_new_segment (0, 1.0, GST_FORMAT_TIME, demux->position,
|
||||||
GST_CLOCK_TIME_NONE, demux->position));
|
GST_CLOCK_TIME_NONE, demux->position));
|
||||||
|
demux->need_segment = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GST_CLOCK_TIME_IS_VALID (GST_BUFFER_DURATION (buf)))
|
if (GST_CLOCK_TIME_IS_VALID (GST_BUFFER_DURATION (buf)))
|
||||||
|
|
Loading…
Reference in a new issue