X-Git-Url: https://git.nihav.org/?a=blobdiff_plain;f=nihav-rad%2Fsrc%2Fcodecs%2Fbinkvid.rs;h=9c0dc9e37dd976780c48263dd091377b89794767;hb=e5b5248d8e4f0b6be84db2d00158a9dcdff0d512;hp=4de23e79af74047c369c76384f706ada82052e9f;hpb=7d57ae2f680d7a1eba7af2ee831f305b2f0f9324;p=nihav.git diff --git a/nihav-rad/src/codecs/binkvid.rs b/nihav-rad/src/codecs/binkvid.rs index 4de23e7..9c0dc9e 100644 --- a/nihav-rad/src/codecs/binkvid.rs +++ b/nihav-rad/src/codecs/binkvid.rs @@ -385,14 +385,14 @@ fn map_u8(idx: usize) -> u8 { idx as u8 } impl Default for BinkTrees { fn default() -> Self { - let mut cb: [Codebook; 16]; - unsafe { - cb = std::mem::uninitialized(); - for i in 0..16 { - let mut cr = TableCodebookDescReader::new(&BINK_TREE_CODES[i], &BINK_TREE_BITS[i], map_u8); - std::ptr::write(&mut cb[i], Codebook::new(&mut cr, CodebookMode::LSB).unwrap()); - } - } + let cb = unsafe { + let mut ucb: std::mem::MaybeUninit::<[Codebook; 16]> = std::mem::MaybeUninit::uninit(); + for i in 0..16 { + let mut cr = TableCodebookDescReader::new(&BINK_TREE_CODES[i], &BINK_TREE_BITS[i], map_u8); + std::ptr::write(&mut (*ucb.as_mut_ptr())[i], Codebook::new(&mut cr, CodebookMode::LSB).unwrap()); + } + ucb.assume_init() + }; Self { cb } } } @@ -476,7 +476,7 @@ impl Default for QuantMats { struct BinkDecoder { info: NACodecInfoRef, ips: IPShuffler, - hams: HAMShuffler, + hams: HAMShuffler, is_ver_b: bool, is_ver_i: bool, @@ -1264,14 +1264,14 @@ mod test { use nihav_core::codecs::RegisteredDecoders; use nihav_core::demuxers::RegisteredDemuxers; use nihav_codec_support::test::dec_video::*; - use crate::rad_register_all_codecs; + use crate::rad_register_all_decoders; use crate::rad_register_all_demuxers; #[test] fn test_binkvid_b() { let mut dmx_reg = RegisteredDemuxers::new(); rad_register_all_demuxers(&mut dmx_reg); let mut dec_reg = RegisteredDecoders::new(); - rad_register_all_codecs(&mut dec_reg); + rad_register_all_decoders(&mut dec_reg); test_decoding("bink", "bink-video", "assets/RAD/NEW.BIK", Some(16), &dmx_reg, &dec_reg, ExpectedTestResult::MD5Frames(vec![ @@ -1298,7 +1298,7 @@ mod test { let mut dmx_reg = RegisteredDemuxers::new(); rad_register_all_demuxers(&mut dmx_reg); let mut dec_reg = RegisteredDecoders::new(); - rad_register_all_codecs(&mut dec_reg); + rad_register_all_decoders(&mut dec_reg); test_decoding("bink", "bink-video", "assets/RAD/ActivisionLogo.bik", Some(42), &dmx_reg, &dec_reg,