gst-plugins-rs/gst-plugin-threadshare
François Laignel 116cf9bd3c threadshare/*src: rework pause/flush_start/flush_stop
This commit fixes several issues with the `Ts*Src` elements.

The pause functions used cancel_task which breaks the Task loop at await
points. For some elements, this implies making sure no item is being lost.
Moreover, cancelling the Task also cancels downstream processing, which
makes it difficult to ensure elements can handle all cases.

This commit reimplements Task::pause which allows completing the running
loop iteration before pausing the loop.

See https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/277#note_439529

In the Paused state, incoming items were rejected by TsAppSrc and DataQueue.

See https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/277#note_438455

- FlushStart must engage items rejection and cancel the Task.
- FlushStop must purge the internal stream & accept items again.

If the task was cancelled, `push_prelude` could set `need_initial_events`
to `true` when the events weren't actually pushed yet.

TsAppSrc used to renew its internal channel which could cause Buffer loss
when transitionning Playing -> Paused -> Playing.

See https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/issues/98
2020-03-21 18:46:03 +00:00
..
examples Fix various new clippy warnings from 1.40 2019-12-22 11:35:01 +02:00
src threadshare/*src: rework pause/flush_start/flush_stop 2020-03-21 18:46:03 +00:00
tests threadshare/*src: rework pause/flush_start/flush_stop 2020-03-21 18:46:03 +00:00
build.rs threadshare/rtpjitterbuffer: Use different GType names than used by the C rtpjitterbuffer 2020-03-04 15:08:59 +00:00
Cargo.toml threadshare: Refactor infrastructure 2020-03-15 13:17:26 +02:00