mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-24 09:58:13 +00:00
livesync: Improve EOS handling
I've looked at the GstQueue code again and tried making livesync behave better with EOS. This isn't very well tested, though. My goal was to make this look saner but I think this should be reviewed by someone who knows the queue code. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/1267>
This commit is contained in:
parent
0954af10c7
commit
72941b5dc5
1 changed files with 48 additions and 17 deletions
|
@ -598,6 +598,9 @@ impl LiveSync {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let mut is_restart = false;
|
||||||
|
let mut is_eos = false;
|
||||||
|
|
||||||
match event.view() {
|
match event.view() {
|
||||||
gst::EventView::FlushStart(_) => {
|
gst::EventView::FlushStart(_) => {
|
||||||
let ret = self.srcpad.push_event(event);
|
let ret = self.srcpad.push_event(event);
|
||||||
|
@ -637,13 +640,11 @@ impl LiveSync {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
gst::EventView::StreamStart(_) => {
|
gst::EventView::StreamStart(_) => is_restart = true,
|
||||||
let mut state = self.state.lock();
|
|
||||||
state.srcresult = Ok(gst::FlowSuccess::Ok);
|
|
||||||
state.eos = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
gst::EventView::Segment(e) => {
|
gst::EventView::Segment(e) => {
|
||||||
|
is_restart = true;
|
||||||
|
|
||||||
let segment = match e.segment().downcast_ref() {
|
let segment = match e.segment().downcast_ref() {
|
||||||
Some(s) => s,
|
Some(s) => s,
|
||||||
None => {
|
None => {
|
||||||
|
@ -656,17 +657,7 @@ impl LiveSync {
|
||||||
state.in_segment = Some(segment.clone());
|
state.in_segment = Some(segment.clone());
|
||||||
}
|
}
|
||||||
|
|
||||||
gst::EventView::Eos(_) => {
|
gst::EventView::Eos(_) => is_eos = true,
|
||||||
let mut state = self.state.lock();
|
|
||||||
|
|
||||||
if let Err(err) = state.srcresult {
|
|
||||||
if matches!(err, gst::FlowError::Flushing | gst::FlowError::Eos) {
|
|
||||||
self.flow_error(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
state.eos = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
gst::EventView::Caps(c) => {
|
gst::EventView::Caps(c) => {
|
||||||
let caps = c.caps_owned();
|
let caps = c.caps_owned();
|
||||||
|
@ -698,7 +689,33 @@ impl LiveSync {
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut state = self.state.lock();
|
let mut state = self.state.lock();
|
||||||
if state.srcresult.is_err() {
|
|
||||||
|
if is_restart {
|
||||||
|
if state.srcresult == Err(gst::FlowError::Eos) {
|
||||||
|
state.srcresult = Ok(gst::FlowSuccess::Ok);
|
||||||
|
}
|
||||||
|
|
||||||
|
state.eos = false;
|
||||||
|
let _ = self.start_src_task();
|
||||||
|
}
|
||||||
|
|
||||||
|
if state.eos {
|
||||||
|
gst::trace!(CAT, imp: self, "Refusing event, we are EOS: {:?}", event);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if is_eos {
|
||||||
|
state.eos = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if let Err(err) = state.srcresult {
|
||||||
|
// Following GstQueue's behavior:
|
||||||
|
// > For EOS events, that are not followed by data flow, we still
|
||||||
|
// > return FALSE here though and report an error.
|
||||||
|
if is_eos && !matches!(err, gst::FlowError::Flushing | gst::FlowError::Eos) {
|
||||||
|
self.flow_error(err);
|
||||||
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -792,6 +809,11 @@ impl LiveSync {
|
||||||
|
|
||||||
let mut state = self.state.lock();
|
let mut state = self.state.lock();
|
||||||
|
|
||||||
|
if state.eos {
|
||||||
|
gst::debug!(CAT, imp: self, "Refusing buffer, we are EOS");
|
||||||
|
return Err(gst::FlowError::Eos);
|
||||||
|
}
|
||||||
|
|
||||||
if state.upstream_latency.is_none() {
|
if state.upstream_latency.is_none() {
|
||||||
gst::debug!(CAT, imp: self, "Have no upstream latency yet, querying");
|
gst::debug!(CAT, imp: self, "Have no upstream latency yet, querying");
|
||||||
let mut q = gst::query::Latency::new();
|
let mut q = gst::query::Latency::new();
|
||||||
|
@ -988,6 +1010,9 @@ impl LiveSync {
|
||||||
self.cond.notify_all();
|
self.cond.notify_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Following GstQueue's behavior:
|
||||||
|
// > let app know about us giving up if upstream is not expected to do so
|
||||||
|
// > EOS is already taken care of elsewhere
|
||||||
if eos && !matches!(err, gst::FlowError::Flushing | gst::FlowError::Eos) {
|
if eos && !matches!(err, gst::FlowError::Flushing | gst::FlowError::Eos) {
|
||||||
self.flow_error(err);
|
self.flow_error(err);
|
||||||
pad.push_event(gst::event::Eos::new());
|
pad.push_event(gst::event::Eos::new());
|
||||||
|
@ -1032,6 +1057,12 @@ impl LiveSync {
|
||||||
push = false;
|
push = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gst::EventView::Eos(_) => {
|
||||||
|
state.out_buffer = None;
|
||||||
|
state.out_timestamp = None;
|
||||||
|
state.srcresult = Err(gst::FlowError::Eos);
|
||||||
|
}
|
||||||
|
|
||||||
gst::EventView::Caps(e) => {
|
gst::EventView::Caps(e) => {
|
||||||
state.pending_caps = Some(e.caps_owned());
|
state.pending_caps = Some(e.caps_owned());
|
||||||
state.update_fallback_duration();
|
state.update_fallback_duration();
|
||||||
|
|
Loading…
Reference in a new issue