binkaud: split out common data definitions for the future encoder
[nihav.git] / nihav-rad / src / codecs / mod.rs
... / ...
CommitLineData
1use nihav_core::codecs::*;
2
3#[cfg(debug_assertions)]
4macro_rules! validate {
5 ($a:expr) => { if !$a { println!("check failed at {}:{}", file!(), line!()); return Err(DecoderError::InvalidData); } };
6}
7#[cfg(not(debug_assertions))]
8macro_rules! validate {
9 ($a:expr) => { if !$a { return Err(DecoderError::InvalidData); } };
10}
11
12#[cfg(any(feature="decoder_smkaud", feature="decoder_smkvid"))]
13mod smacker;
14#[cfg(feature="decoder_binkaud")]
15mod binkaud;
16#[cfg(feature="decoder_binkaud")]
17mod binkauddata;
18#[cfg(feature="decoder_binkvid")]
19mod binkvid;
20#[cfg(any(feature="decoder_binkvid", feature="encoder_binkvid"))]
21mod binkviddata;
22#[cfg(feature="decoder_bink2")]
23mod bink2;
24
25const RAD_CODECS: &[DecoderInfo] = &[
26#[cfg(feature="decoder_smkaud")]
27 DecoderInfo { name: "smacker-audio", get_decoder: smacker::get_decoder_audio },
28#[cfg(feature="decoder_smkvid")]
29 DecoderInfo { name: "smacker-video", get_decoder: smacker::get_decoder_video },
30#[cfg(feature="decoder_binkaud")]
31 DecoderInfo { name: "bink-audio-dct", get_decoder: binkaud::get_decoder_dct },
32#[cfg(feature="decoder_binkaud")]
33 DecoderInfo { name: "bink-audio-rdft", get_decoder: binkaud::get_decoder_rdft },
34#[cfg(feature="decoder_binkvid")]
35 DecoderInfo { name: "bink-video", get_decoder: binkvid::get_decoder },
36#[cfg(feature="decoder_bink2")]
37 DecoderInfo { name: "bink2-video", get_decoder: bink2::get_decoder },
38];
39
40/// Registers all available codecs provided by this crate.
41pub fn rad_register_all_decoders(rd: &mut RegisteredDecoders) {
42 for decoder in RAD_CODECS.iter() {
43 rd.add_decoder(*decoder);
44 }
45}
46
47#[cfg(feature="encoder_binkvid")]
48mod binkvidenc;
49
50#[cfg(feature="encoders")]
51const ENCODERS: &[EncoderInfo] = &[
52#[cfg(feature="encoder_binkvid")]
53 EncoderInfo { name: "bink-video", get_encoder: binkvidenc::get_encoder },
54];
55
56/// Registers all available encoders provided by this crate.
57#[cfg(feature="encoders")]
58pub fn rad_register_all_encoders(re: &mut RegisteredEncoders) {
59 for encoder in ENCODERS.iter() {
60 re.add_encoder(*encoder);
61 }
62}