// Copyright 2022 The ChromiumOS Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. //! This file contains a dummy backend whose only purpose is to let the decoder //! run so we can test it in isolation. use std::cell::RefCell; use std::rc::Rc; use crate::backend::dummy::decoder::Backend; use crate::backend::dummy::decoder::Handle; use crate::codec::vp9::parser::Header; use crate::codec::vp9::parser::MAX_SEGMENTS; use crate::codec::vp9::parser::NUM_REF_FRAMES; use crate::decoder::stateless::vp9::Segmentation; use crate::decoder::stateless::vp9::StatelessVp9DecoderBackend; use crate::decoder::stateless::vp9::Vp9; use crate::decoder::stateless::NewPictureResult; use crate::decoder::stateless::NewStatelessDecoderError; use crate::decoder::stateless::StatelessBackendResult; use crate::decoder::stateless::StatelessDecoder; use crate::decoder::BlockingMode; impl StatelessVp9DecoderBackend for Backend { fn new_sequence(&mut self, _: &Header) -> StatelessBackendResult<()> { Ok(()) } fn new_picture(&mut self, _: u64) -> NewPictureResult { Ok(()) } fn submit_picture( &mut self, _: Self::Picture, _: &Header, _: &[Option; NUM_REF_FRAMES], _: &[u8], _: &[Segmentation; MAX_SEGMENTS], ) -> StatelessBackendResult { Ok(Handle { handle: Rc::new(RefCell::new(Default::default())) }) } } impl StatelessDecoder { // Creates a new instance of the decoder using the dummy backend. pub fn new_dummy(blocking_mode: BlockingMode) -> Result { Self::new(Backend::new(), blocking_mode) } }