X-Git-Url: https://git.nihav.org/?p=nihav.git;a=blobdiff_plain;f=nihav-rad%2Fsrc%2Fcodecs%2Fbinkaud.rs;h=7e34739f07a2f6dbb8992ead35b3aed168e96e5a;hp=888a72469b7ed0cef518ec11ebb6cea093a2b792;hb=e64739f87a35f29be0bbbce366876180ba3eb57e;hpb=9e78289cc98dddb8f6d6ea4fc4c3655636e31a72 diff --git a/nihav-rad/src/codecs/binkaud.rs b/nihav-rad/src/codecs/binkaud.rs index 888a724..7e34739 100644 --- a/nihav-rad/src/codecs/binkaud.rs +++ b/nihav-rad/src/codecs/binkaud.rs @@ -71,7 +71,7 @@ impl BinkAudioDecoder { transform: Transform::None, version_b: false, len: 0, - quants: quants, + quants, bands: [MAX_BANDS + 1; 26], num_bands: 0, duration: 0, @@ -234,7 +234,7 @@ impl NADecoder for BinkAudioDecoder { if let NACodecTypeInfo::Audio(_) = info.get_properties() { let pktbuf = pkt.get_buffer(); validate!(pktbuf.len() > 1); - let mut br = BitReader::new(&pktbuf, pktbuf.len(), BitReaderMode::LE); + let mut br = BitReader::new(&pktbuf, BitReaderMode::LE); let nsamples = br.read(32)? as usize; // validate!(nsamples % self.duration == 0); @@ -273,13 +273,16 @@ impl NADecoder for BinkAudioDecoder { Err(DecoderError::InvalidData) } } + fn flush(&mut self) { + self.delay = [[0.0; 256]; 2]; + } } -pub fn get_decoder_dct() -> Box { +pub fn get_decoder_dct() -> Box { Box::new(BinkAudioDecoder::new(true)) } -pub fn get_decoder_rdft() -> Box { +pub fn get_decoder_rdft() -> Box { Box::new(BinkAudioDecoder::new(false)) } @@ -288,8 +291,8 @@ mod test { use nihav_core::codecs::RegisteredDecoders; use nihav_core::demuxers::RegisteredDemuxers; use nihav_core::test::dec_video::*; - use crate::codecs::rad_register_all_codecs; - use crate::demuxers::rad_register_all_demuxers; + use crate::rad_register_all_codecs; + use crate::rad_register_all_demuxers; #[test] fn test_bink_audio() { @@ -303,6 +306,6 @@ mod test { // let file = "assets/RAD/Snd0a110c51.dee"; // let file = "assets/RAD/NEW.BIK"; // let file = "assets/RAD/ge_video_86l.bk2"; - test_decode_audio("bink", file, None, "bink", &dmx_reg, &dec_reg); + test_decode_audio("bink", file, None, None/*Some("bink")*/, &dmx_reg, &dec_reg); } }