dav1ddec: Don't consider decoding errors as fatal

Instead use the `gst_video::video_decoder_error!` macro for allowing a
certain number of consecutive errors before actually failing.
This commit is contained in:
Sebastian Dröge 2022-02-02 13:39:54 +02:00
parent 12a718cd88
commit 1a5473264e

View file

@ -147,12 +147,19 @@ impl Dav1dDec {
let input_data = input_buffer
.map_readable()
.map_err(|_| gst::FlowError::Error)?;
let pictures = decoder
.decode(input_data, frame_number, timestamp, duration, || {})
.map_err(|e| {
gst_error!(CAT, "Decoding failed (error code: {})", e);
gst::FlowError::Error
})?;
let pictures = match decoder.decode(input_data, frame_number, timestamp, duration, || {}) {
Ok(pictures) => pictures,
Err(err) => {
gst_error!(CAT, "Decoding failed (error code: {})", err);
return gst_video::video_decoder_error!(
element,
1,
gst::StreamError::Decode,
["Decoding failed (error code {})", err]
)
.map(|_| vec![]);
}
};
let mut decoded_pictures = vec![];
for pic in pictures {