pub struct Deserializer<'db> { /* private fields */ }
Expand description

A configurable deserializer for Roblox binary models and places.

Example

use std::fs::File;
use std::io::BufReader;

use rbx_binary::Deserializer;

let input = BufReader::new(File::open("File.rbxm")?);

let deserializer = Deserializer::new();
let dom = deserializer.deserialize(input)?;

// rbx_binary always returns a DOM with a DataModel at the top level.
// To get to the instances from our file, we need to go one level deeper.

println!("Root instances in file:");
for &referent in dom.root().children() {
    let instance = dom.get_by_ref(referent).unwrap();
    println!("- {}", instance.name);
}

Configuration

A custom ReflectionDatabase can be specified via reflection_database.

Implementations§

source§

impl<'db> Deserializer<'db>

source

pub fn new() -> Self

Create a new Deserializer with the default settings.

source

pub fn reflection_database(self, database: &'db ReflectionDatabase<'db>) -> Self

Sets what reflection database for the deserializer to use.

source

pub fn deserialize<R: Read>(&self, reader: R) -> Result<WeakDom, Error>

Deserialize a Roblox binary model or place from the given stream using this deserializer.

Trait Implementations§

source§

impl<'db> Default for Deserializer<'db>

source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<'db> RefUnwindSafe for Deserializer<'db>

§

impl<'db> Send for Deserializer<'db>

§

impl<'db> Sync for Deserializer<'db>

§

impl<'db> Unpin for Deserializer<'db>

§

impl<'db> UnwindSafe for Deserializer<'db>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V