X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-indeo%2Fsrc%2Fcodecs%2Fmod.rs;h=85523d6b6a4e151a4087879fcd0179f088c34cd3;hb=6064de24fc9486d32f7a67e1e19c7881a75afcde;hp=321fe3844ff794e657f5dbcb60008de86eab4d58;hpb=78fb6560c73965d834b215fb0b49505ae5443288;p=nihav.git diff --git a/nihav-indeo/src/codecs/mod.rs b/nihav-indeo/src/codecs/mod.rs index 321fe38..85523d6 100644 --- a/nihav-indeo/src/codecs/mod.rs +++ b/nihav-indeo/src/codecs/mod.rs @@ -1,8 +1,13 @@ use nihav_core::codecs::*; +#[cfg(debug_assertions)] macro_rules! validate { ($a:expr) => { if !$a { println!("check failed at {}:{}", file!(), line!()); return Err(DecoderError::InvalidData); } }; } +#[cfg(not(debug_assertions))] +macro_rules! validate { + ($a:expr) => { if !$a { return Err(DecoderError::InvalidData); } }; +} #[cfg(feature="decoder_intel263")] mod intel263; @@ -10,6 +15,8 @@ mod intel263; mod indeo2; #[cfg(feature="decoder_indeo3")] mod indeo3; +#[cfg(any(feature="decoder_indeo3", feature="encoder_indeo3"))] +mod indeo3data; #[cfg(feature="decoder_indeo4")] mod indeo4; #[cfg(feature="decoder_indeo5")] @@ -37,6 +44,8 @@ const INDEO_CODECS: &[DecoderInfo] = &[ DecoderInfo { name: "indeo4", get_decoder: indeo4::get_decoder }, #[cfg(feature="decoder_indeo5")] DecoderInfo { name: "indeo5", get_decoder: indeo5::get_decoder }, +#[cfg(feature="decoder_indeo5")] + DecoderInfo { name: "indeo5s", get_decoder: indeo5::get_decoder_scalable }, #[cfg(feature="decoder_intel263")] DecoderInfo { name: "intel263", get_decoder: intel263::get_decoder }, @@ -49,6 +58,22 @@ const INDEO_CODECS: &[DecoderInfo] = &[ /// Registers all available codecs provided by this crate. pub fn indeo_register_all_decoders(rd: &mut RegisteredDecoders) { for decoder in INDEO_CODECS.iter() { - rd.add_decoder(decoder.clone()); + rd.add_decoder(*decoder); + } +} + +#[cfg(feature="encoder_indeo3")] +mod indeo3enc; + +const INDEO_ENCODERS: &[EncoderInfo] = &[ +#[cfg(feature="encoder_indeo3")] + EncoderInfo { name: "indeo3", get_encoder: indeo3enc::get_encoder }, +]; + +/// Registers all available encoders provided by this crate. +pub fn indeo_register_all_encoders(re: &mut RegisteredEncoders) { + for encoder in INDEO_ENCODERS.iter() { + re.add_encoder(*encoder); } } +