X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=src%2Fcodecs%2Fmod.rs;h=aea7a9e912749f840c4ccc42f2a0fc20a8be3b6a;hb=HEAD;hp=206032e6997b63c5cbb7c9dfc6ee5a916fbf71a9;hpb=3234da61c291704c7e9d928c4c50dd41f537e0c5;p=nihav.git diff --git a/src/codecs/mod.rs b/src/codecs/mod.rs deleted file mode 100644 index 206032e..0000000 --- a/src/codecs/mod.rs +++ /dev/null @@ -1,100 +0,0 @@ -#[cfg(feature="decoder_indeo2")] -pub mod indeo2; -#[cfg(feature="decoder_pcm")] -pub mod pcm; - -use frame::*; -use std::rc::Rc; -use std::cell::RefCell; -use io::byteio::ByteIOError; -use io::bitreader::BitReaderError; -use io::codebook::CodebookError; - -#[derive(Debug,Clone,Copy,PartialEq)] -#[allow(dead_code)] -pub enum DecoderError { - InvalidData, - ShortData, - MissingReference, - NotImplemented, - Bug, -} - -type DecoderResult = Result; - -impl From for DecoderError { - fn from(_: ByteIOError) -> Self { DecoderError::ShortData } -} - -impl From for DecoderError { - fn from(e: BitReaderError) -> Self { - match e { - BitReaderError::BitstreamEnd => DecoderError::ShortData, - _ => DecoderError::InvalidData, - } - } -} - -impl From for DecoderError { - fn from(_: CodebookError) -> Self { DecoderError::InvalidData } -} - -#[allow(dead_code)] -struct HAMShuffler { - lastframe: Option>, -} - -impl HAMShuffler { - #[allow(dead_code)] - fn new() -> Self { HAMShuffler { lastframe: None } } - #[allow(dead_code)] - fn clear(&mut self) { self.lastframe = None; } - #[allow(dead_code)] - fn add_frame(&mut self, buf: NAVideoBuffer) { - self.lastframe = Some(buf); - } - #[allow(dead_code)] - fn clone_ref(&mut self) -> Option> { - if let Some(ref mut frm) = self.lastframe { - let newfrm = frm.copy_buffer(); - *frm = newfrm.clone(); - Some(newfrm) - } else { - None - } - } - #[allow(dead_code)] - fn get_output_frame(&mut self) -> Option> { - match self.lastframe { - Some(ref frm) => Some(frm.clone()), - None => None, - } - } -} - -pub trait NADecoder { - fn init(&mut self, info: Rc) -> DecoderResult<()>; - fn decode(&mut self, pkt: &NAPacket) -> DecoderResult; -} - -#[derive(Clone,Copy)] -pub struct DecoderInfo { - name: &'static str, - get_decoder: fn () -> Box, -} - -const DECODERS: &[DecoderInfo] = &[ -#[cfg(feature="decoder_indeo2")] - DecoderInfo { name: "indeo2", get_decoder: indeo2::get_decoder }, -#[cfg(feature="decoder_pcm")] - DecoderInfo { name: "pcm", get_decoder: pcm::get_decoder }, -]; - -pub fn find_decoder(name: &str) -> Option Box> { - for &dec in DECODERS { - if dec.name == name { - return Some(dec.get_decoder); - } - } - None -}