mod error;
mod header;
mod state;
use std::{io::Read, str};
use rbx_dom_weak::WeakDom;
use rbx_reflection::ReflectionDatabase;
use self::state::DeserializerState;
pub(crate) use self::header::FileHeader;
pub use self::error::Error;
pub struct Deserializer<'a> {
database: Option<&'a ReflectionDatabase<'a>>,
}
impl<'a> Deserializer<'a> {
pub fn new() -> Self {
Self {
database: Some(rbx_reflection_database::get()),
}
}
pub fn deserialize<R: Read>(&self, reader: R) -> Result<WeakDom, Error> {
profiling::scope!("rbx_binary::deserialize");
let mut deserializer = DeserializerState::new(self, reader)?;
loop {
let chunk = deserializer.next_chunk()?;
match &chunk.name {
b"META" => deserializer.decode_meta_chunk(&chunk.data)?,
b"SSTR" => deserializer.decode_sstr_chunk(&chunk.data)?,
b"INST" => deserializer.decode_inst_chunk(&chunk.data)?,
b"PROP" => deserializer.decode_prop_chunk(&chunk.data)?,
b"PRNT" => deserializer.decode_prnt_chunk(&chunk.data)?,
b"END\0" => {
deserializer.decode_end_chunk(&chunk.data)?;
break;
}
_ => match str::from_utf8(&chunk.name) {
Ok(name) => log::info!("Unknown binary chunk name {}", name),
Err(_) => log::info!("Unknown binary chunk name {:?}", chunk.name),
},
}
}
Ok(deserializer.finish())
}
}
impl<'a> Default for Deserializer<'a> {
fn default() -> Self {
Self::new()
}
}