X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-commonfmt%2Fsrc%2Fcodecs%2Fatrac3.rs;h=b74c5339149d9e0d00a9f84cb1972a752d1b9c0c;hb=2dbe1e64ee27b0f28a6d670daba0fc56c76a2fb1;hp=9d416e2b812c03cde9e76dc9a688ae3dd0676eb2;hpb=08a1fab72215ea7716f51adf7008f85372e80c71;p=nihav.git diff --git a/nihav-commonfmt/src/codecs/atrac3.rs b/nihav-commonfmt/src/codecs/atrac3.rs index 9d416e2..b74c533 100644 --- a/nihav-commonfmt/src/codecs/atrac3.rs +++ b/nihav-commonfmt/src/codecs/atrac3.rs @@ -4,7 +4,7 @@ use nihav_core::codecs::*; use nihav_core::io::bitreader::*; use nihav_core::io::byteio::*; use nihav_core::io::codebook::*; -use nihav_core::dsp::mdct::IMDCT; +use nihav_codec_support::dsp::mdct::IMDCT; use std::f32::consts; #[derive(Clone,Copy,PartialEq)] @@ -622,7 +622,7 @@ impl NADecoder for Atrac3Decoder { } { - let mut br = BitReader::new(self.pkt_buf.as_slice(), frame_size, BitReaderMode::BE); + let mut br = BitReader::new(&self.pkt_buf[0..frame_size], BitReaderMode::BE); let id = br.read(6)?; validate!(id == 0x28); self.ch_data[0].decode_unit(&mut br, &self.codebooks, &self.scalefactors)?; @@ -644,7 +644,7 @@ impl NADecoder for Atrac3Decoder { } else { off = frame_size / 2; } - let mut br = BitReader::new(&self.pkt_buf[off..], frame_size - off, BitReaderMode::BE); + let mut br = BitReader::new(&self.pkt_buf[off..frame_size], BitReaderMode::BE); if self.mode == Mode::JointStereo { let id = br.read(2)?; validate!(id == 0x3); @@ -695,6 +695,12 @@ impl NADecoder for Atrac3Decoder { } } +impl NAOptionHandler for Atrac3Decoder { + fn get_supported_options(&self) -> &[NAOptionDefinition] { &[] } + fn set_options(&mut self, _options: &[NAOption]) { } + fn query_option_value(&self, _name: &str) -> Option { None } +} + pub fn get_decoder() -> Box { Box::new(Atrac3Decoder::new()) } @@ -703,9 +709,9 @@ pub fn get_decoder() -> Box { mod test { use nihav_core::codecs::RegisteredDecoders; use nihav_core::demuxers::RegisteredDemuxers; - use nihav_core::test::dec_video::test_decode_audio; - use crate::codecs::generic_register_all_codecs; - use nihav_realmedia::demuxers::realmedia_register_all_demuxers; + use nihav_codec_support::test::dec_video::test_decode_audio; + use crate::generic_register_all_codecs; + use nihav_realmedia::realmedia_register_all_demuxers; #[test] fn test_atrac3() { let mut dmx_reg = RegisteredDemuxers::new();