//! Wad file chunk type. use crate::{durandal::{bin::*, err::*, image}, marathon::{map, pict}}; /// Reads all chunks in an entry. pub fn read(b: &[u8], old: bool, siz_cnk: usize) -> ResultS> { let mut chunks = Vec::new(); let mut p = 0; let read_chunk_minf = if old {map::minf::read_old} else {map::minf::read}; let read_chunk_sids = if old {map::sids::read_old} else {map::sids::read}; let read_chunk_poly = if old {map::poly::read_old} else {map::poly::read}; let read_chunk_lite = if old {map::lite::read_old} else {map::lite::read}; while p < b.len() { read_data! { endian: BIG, buf: b, size: siz_cnk, start: p, data { let iden = Ident[0]; let size = u32[8] usize; } } let beg = p + siz_cnk; let end = beg + size; let data = ok!(b.get(beg..end), "not enough data")?; chunks.push(match &iden.0 { b"PICT" => Chunk::Pict(pict::load_pict(data)?), b"Minf" => Chunk::Minf(read_chunk_minf(data)?), b"iidx" => Chunk::Iidx(rd_array(data, map::iidx::read)?), b"EPNT" => Chunk::Epnt(rd_array(data, map::epnt::read)?), b"PNTS" => Chunk::Pnts(rd_array(data, map::pnts::read)?), b"LINS" => Chunk::Lins(rd_array(data, map::lins::read)?), b"SIDS" => Chunk::Sids(rd_array(data, read_chunk_sids)?), b"POLY" => Chunk::Poly(rd_array(data, read_chunk_poly)?), b"OBJS" => Chunk::Objs(rd_array(data, map::objs::read)?), b"LITE" => Chunk::Lite(rd_array(data, read_chunk_lite)?), b"plac" => Chunk::Plac(rd_array(data, map::plac::read)?), b"ambi" => Chunk::Ambi(rd_array(data, map::ambi::read)?), b"bonk" => Chunk::Bonk(rd_array(data, map::bonk::read)?), b"medi" => Chunk::Medi(rd_array(data, map::medi::read)?), b"plat" => Chunk::Plat(rd_array(data, map::plat::read)?), b"NOTE" => Chunk::Note(rd_array(data, map::note::read)?), b"term" => Chunk::Term(rd_array(data, map::term::read)?), b"FXpx" => Chunk::Fxpx(rd_array(data, map::fxpx::read)?), b"MNpx" => Chunk::Mnpx(rd_array(data, map::mnpx::read)?), b"PRpx" => Chunk::Prpx(rd_array(data, map::prpx::read)?), b"PXpx" => Chunk::Pxpx(rd_array(data, map::pxpx::read)?), b"WPpx" => Chunk::Wppx(rd_array(data, map::wppx::read)?), _ => Chunk::Data{iden, data: data.to_vec()}, }); p = end; } Ok(chunks) } /// Any kind of chunk in an `Entry`. #[cfg_attr(feature = "serde_obj", derive(serde::Serialize))] #[derive(Debug, Eq, PartialEq)] pub enum Chunk { /** A `PICT` chunk. */ Pict(image::Image8), /** A `Minf` chunk. */ Minf(map::minf::Minf), /** An `iidx` chunk. */ Iidx(Vec), /** An `EPNT` chunk. */ Epnt(Vec), /** A `PNTS` chunk. */ Pnts(Vec), /** A `LINS` chunk. */ Lins(Vec), /** A `SIDS` chunk. */ Sids(Vec), /** A `POLY` chunk. */ Poly(Vec), /** A `LITE` chunk. */ Lite(Vec), /** An `OBJS` chunk. */ Objs(Vec), /** A `plac` chunk. */ Plac(Vec), /** An `ambi` chunk. */ Ambi(Vec), /** A `bonk` chunk. */ Bonk(Vec), /** A `medi` chunk. */ Medi(Vec), /** A `plat` chunk. */ Plat(Vec), /** A `NOTE` chunk. */ Note(Vec), /** A `term` chunk. */ Term(Vec), /** A `FXpx` chunk. */ Fxpx(Vec), /** A `MNpx` chunk. */ Mnpx(Vec), /** A `PRpx` chunk. */ Prpx(Vec), /** A `PXpx` chunk. */ Pxpx(Vec), /** A `WPpx` chunk. */ Wppx(Vec), /// Any other type of chunk, which may have arbitrary data in it. Data{/** The name of the chunk. */ iden: Ident, /** The data. */ data: Vec}, } // EOF