X-Git-Url: https://git.nihav.org/?p=nihav.git;a=blobdiff_plain;f=nihav-duck%2Fsrc%2Fcodecs%2Ftruemotion2.rs;h=4020e732810833f9744103bd388dfb9e73d5ef87;hp=2ee8b24f593bde977ddcfefea708b32cc6943074;hb=HEAD;hpb=e64739f87a35f29be0bbbce366876180ba3eb57e diff --git a/nihav-duck/src/codecs/truemotion2.rs b/nihav-duck/src/codecs/truemotion2.rs index 2ee8b24..4020e73 100644 --- a/nihav-duck/src/codecs/truemotion2.rs +++ b/nihav-duck/src/codecs/truemotion2.rs @@ -102,7 +102,7 @@ impl Default for TM2Stream { impl TM2Stream { fn read_header(&mut self, src: &[u8], br: &mut ByteReader) -> DecoderResult<()> { - self.tokens.truncate(0); + self.tokens.clear(); self.pos = 0; let len = br.read_u32le()? as usize; @@ -336,6 +336,7 @@ struct TM2Decoder { impl TM2Decoder { fn new() -> Self { Self::default() } + #[allow(clippy::manual_memcpy)] fn decode_blocks(&mut self) -> DecoderResult { let ydst = &mut self.cur_frame.ydata; let udst = &mut self.cur_frame.udata; @@ -434,7 +435,7 @@ impl TM2Decoder { for _ in 0..4 { for x in 0..4 { let dy = self.streams[TM2StreamType::Update as usize].get_token()?; - ydst[yoff + x] = ((ysrc[yoff + x] as i32) + dy) as u8; + ydst[yoff + x] = (i32::from(ysrc[yoff + x]) + dy) as u8; } yoff += ystride; } @@ -560,8 +561,8 @@ impl NADecoder for TM2Decoder { let magic = br.read_u32be()?; validate!(magic == 0x100 || magic == 0x101); br.read_skip(36)?; - for str in self.streams.iter_mut() { - str.read_header(&src, &mut br)?; + for stream in self.streams.iter_mut() { + stream.read_header(&src, &mut br)?; } let myinfo = NAVideoInfo::new(self.width, self.height, false, RGB24_FORMAT); @@ -581,6 +582,12 @@ impl NADecoder for TM2Decoder { } } +impl NAOptionHandler for TM2Decoder { + 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(TM2Decoder::new()) } @@ -589,16 +596,17 @@ pub fn get_decoder() -> Box { mod test { use nihav_core::codecs::RegisteredDecoders; use nihav_core::demuxers::RegisteredDemuxers; - use nihav_core::test::dec_video::*; - use crate::duck_register_all_codecs; + use nihav_codec_support::test::dec_video::*; + use crate::duck_register_all_decoders; use nihav_commonfmt::generic_register_all_demuxers; #[test] fn test_tm2() { let mut dmx_reg = RegisteredDemuxers::new(); generic_register_all_demuxers(&mut dmx_reg); let mut dec_reg = RegisteredDecoders::new(); - duck_register_all_codecs(&mut dec_reg); + duck_register_all_decoders(&mut dec_reg); + // sample: https://samples.mplayerhq.hu/V-codecs/TM20/tm20.avi test_decoding("avi", "truemotion2", "assets/Duck/tm20.avi", Some(16), &dmx_reg, &dec_reg, ExpectedTestResult::MD5Frames(vec![ [0x8c336eb4, 0x10d0d934, 0x52392306, 0xc0bc6dd3],