X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-commonfmt%2Fsrc%2Fcodecs%2Fmod.rs;h=f69fc6441e5b6c70627713f2eed1350645bb33d5;hb=1ee737a48ec7a767c64bd72e67313ef67cfcc367;hp=cc1cf74f1121fb217f80501b6bde3cb4c1e2c166;hpb=9a59c451c92ca4283fb6f2274e399393d9a5f972;p=nihav.git diff --git a/nihav-commonfmt/src/codecs/mod.rs b/nihav-commonfmt/src/codecs/mod.rs index cc1cf74..f69fc64 100644 --- a/nihav-commonfmt/src/codecs/mod.rs +++ b/nihav-commonfmt/src/codecs/mod.rs @@ -1,13 +1,20 @@ 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_cinepak")] mod cinepak; #[cfg(feature="decoder_clearvideo")] mod clearvideo; +#[cfg(feature="decoder_jpeg")] +mod jpeg; #[cfg(feature="decoder_rawvideo")] mod rawvideo; #[cfg(feature="decoder_rawvideo_ms")] @@ -15,10 +22,6 @@ mod rawvideo_ms; #[cfg(feature="decoder_zmbv")] mod zmbv; -#[cfg(feature="decoder_aac")] -#[allow(clippy::manual_memcpy)] -#[allow(clippy::useless_let_if_seq)] -mod aac; #[cfg(feature="decoder_atrac3")] #[allow(clippy::identity_op)] #[allow(clippy::useless_let_if_seq)] @@ -33,6 +36,7 @@ mod sipro; #[cfg(feature="decoder_ts102366")] mod ts102366; +#[cfg(feature="decoders")] const DECODERS: &[DecoderInfo] = &[ #[cfg(feature="decoder_cinepak")] DecoderInfo { name: "cinepak", get_decoder: cinepak::get_decoder }, @@ -40,6 +44,8 @@ const DECODERS: &[DecoderInfo] = &[ DecoderInfo { name: "clearvideo", get_decoder: clearvideo::get_decoder }, #[cfg(feature="decoder_clearvideo")] DecoderInfo { name: "clearvideo_rm", get_decoder: clearvideo::get_decoder_rm }, +#[cfg(feature="decoder_jpeg")] + DecoderInfo { name: "jpeg", get_decoder: jpeg::get_decoder }, #[cfg(feature="decoder_rawvideo")] DecoderInfo { name: "rawvideo", get_decoder: rawvideo::get_decoder }, #[cfg(feature="decoder_rawvideo_ms")] @@ -59,11 +65,10 @@ const DECODERS: &[DecoderInfo] = &[ DecoderInfo { name: "ac3", get_decoder: ts102366::get_decoder }, #[cfg(feature="decoder_atrac3")] DecoderInfo { name: "atrac3", get_decoder: atrac3::get_decoder }, -#[cfg(feature="decoder_aac")] - DecoderInfo { name: "aac", get_decoder: aac::get_decoder }, ]; /// Registers all available codecs provided by this crate. +#[cfg(feature="decoders")] pub fn generic_register_all_decoders(rd: &mut RegisteredDecoders) { for decoder in DECODERS.iter() { rd.add_decoder(*decoder); @@ -75,6 +80,7 @@ mod cinepakenc; #[cfg(feature="encoder_zmbv")] mod zmbvenc; +#[cfg(feature="encoders")] const ENCODERS: &[EncoderInfo] = &[ #[cfg(feature="encoder_cinepak")] EncoderInfo { name: "cinepak", get_encoder: cinepakenc::get_encoder }, @@ -86,6 +92,7 @@ const ENCODERS: &[EncoderInfo] = &[ ]; /// Registers all available encoders provided by this crate. +#[cfg(feature="encoders")] pub fn generic_register_all_encoders(re: &mut RegisteredEncoders) { for encoder in ENCODERS.iter() { re.add_encoder(*encoder);