X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-commonfmt%2Fsrc%2Fcodecs%2Fmod.rs;h=cf0c8462395ac58c7b80930c3a22468bf848faa9;hb=820b43313ea6d0e03c7bf063ee6a64f3ff0cf659;hp=9e2a0943447ccb81f1656a45ac94e700e4fb5769;hpb=57777a0a5ea7d4f36f25e4e2d90b4a33b920a88b;p=nihav.git diff --git a/nihav-commonfmt/src/codecs/mod.rs b/nihav-commonfmt/src/codecs/mod.rs index 9e2a094..cf0c846 100644 --- a/nihav-commonfmt/src/codecs/mod.rs +++ b/nihav-commonfmt/src/codecs/mod.rs @@ -8,18 +8,30 @@ macro_rules! validate { 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")] +mod rawvideo_ms; +#[cfg(feature="decoder_zmbv")] +mod zmbv; -#[cfg(feature="decoder_aac")] -mod aac; #[cfg(feature="decoder_atrac3")] +#[allow(clippy::identity_op)] +#[allow(clippy::useless_let_if_seq)] mod atrac3; -#[cfg(feature="decoder_pcm")] +#[cfg(any(feature="decoder_pcm",feature="encoder_pcm"))] mod pcm; #[cfg(feature="decoder_sipro")] +#[allow(clippy::collapsible_if)] +#[allow(clippy::identity_op)] +#[allow(clippy::manual_memcpy)] 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 }, @@ -27,22 +39,58 @@ 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")] + DecoderInfo { name: "rawvideo-ms", get_decoder: rawvideo_ms::get_decoder }, +#[cfg(feature="decoder_zmbv")] + DecoderInfo { name: "zmbv", get_decoder: zmbv::get_decoder }, #[cfg(feature="decoder_pcm")] DecoderInfo { name: "pcm", get_decoder: pcm::get_decoder }, +#[cfg(feature="decoder_pcm")] + DecoderInfo { name: "alaw", get_decoder: pcm::get_a_law_decoder }, +#[cfg(feature="decoder_pcm")] + DecoderInfo { name: "ulaw", get_decoder: pcm::get_mu_law_decoder }, #[cfg(feature="decoder_sipro")] DecoderInfo { name: "sipro", get_decoder: sipro::get_decoder }, #[cfg(feature="decoder_ts102366")] 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. -pub fn generic_register_all_codecs(rd: &mut RegisteredDecoders) { +#[cfg(feature="decoders")] +pub fn generic_register_all_decoders(rd: &mut RegisteredDecoders) { for decoder in DECODERS.iter() { - rd.add_decoder(decoder.clone()); + rd.add_decoder(*decoder); } } + +#[cfg(feature="encoder_cinepak")] +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 }, +#[cfg(feature="encoder_zmbv")] + EncoderInfo { name: "zmbv", get_encoder: zmbvenc::get_encoder }, + +#[cfg(feature="encoder_pcm")] + EncoderInfo { name: "pcm", get_encoder: pcm::get_encoder }, +]; + +/// 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); + } +} +