Struct Xbc1

Source
pub struct Xbc1 {
    pub compression_type: CompressionType,
    pub decompressed_size: u32,
    pub compressed_size: u32,
    pub decompressed_hash: u32,
    pub name: String,
    pub compressed_stream: Vec<u8>,
}
Expand description

A compressed container for a single file or stream.

Fields§

§compression_type: CompressionType

The compression type for compressed_stream.

§decompressed_size: u32

The number of bytes in Self::decompress.

§compressed_size: u32

The number of bytes in compressed_stream.

§decompressed_hash: u32

Hash of the original decompressed bytes for compressed_stream using hash_crc.

§name: String

The name for this archive. This is often the name of the original file like 3d4f4c6_middle.witx.

§compressed_stream: Vec<u8>

A compressed stream encoded based on compression_type. The decompressed stream will have size decompressed_size.

Implementations§

Source§

impl Xbc1

Source

pub fn new<T>( name: String, data: &T, compression_type: CompressionType, ) -> Result<Self, CreateXbc1Error>
where T: WriteFull<Args = ()>,

Write and compress data. Use CompressionType::Zlib for best compatibility.

Source

pub fn from_decompressed( name: String, decompressed: &[u8], compression_type: CompressionType, ) -> Result<Self, CreateXbc1Error>

Compress the data in decompressed. Use CompressionType::Zlib for best compatibility.

Source

pub fn decompress(&self) -> Result<Vec<u8>, DecompressStreamError>

Decompresses the data in compressed_stream.

Unlike Self::decompress_check_hash, this skips a slow hashing check for the decompressed data.

Source

pub fn decompress_check_hash(&self) -> Result<Vec<u8>, DecompressStreamError>

Similar to Self::decompress but returns an error if the hash of the decompressed data does not match.

Source

pub fn extract<T>(&self) -> Result<T, DecompressStreamError>
where for<'a> T: BinRead<Args<'a> = ()>,

Decompress and parse the decompressed data.

Source§

impl Xbc1

Source

pub fn write<W: Write + Seek>(&self, writer: &mut W) -> Xc3Result<()>

Source

pub fn save<P: AsRef<Path>>(&self, path: P) -> Xc3Result<()>

Write to path using a buffered writer for better performance.

Source

pub fn to_bytes(&self) -> Xc3Result<Vec<u8>>

Write the result of Self::write to a byte buffer.

Source§

impl Xbc1

Source

pub fn read<R: Read + Seek>(reader: &mut R) -> BinResult<Self>

Source

pub fn from_file<P: AsRef<Path>>(path: P) -> Result<Self, ReadFileError>

Read from path using a fully buffered reader for performance.

Source

pub fn from_bytes<T: AsRef<[u8]>>(bytes: T) -> BinResult<Self>

Read from bytes using a fully buffered reader for performance.

Trait Implementations§

Source§

impl BinRead for Xbc1

Source§

type Args<'__binrw_generated_args_lifetime> = ()

The type used for the args parameter of read_args() and read_options(). Read more
Source§

fn read_options<R: Read + Seek>( __binrw_generated_var_reader: &mut R, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_>, ) -> BinResult<Self>

Read Self from the reader using the given Endian and arguments. Read more
Source§

fn read_be<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming big-endian byte order. Read more
Source§

fn read_le<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming little-endian byte order. Read more
Source§

fn read_ne<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read T from the reader assuming native-endian byte order. Read more
Source§

fn read_be_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming big-endian byte order, using the given arguments. Read more
Source§

fn read_le_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming little-endian byte order, using the given arguments. Read more
Source§

fn read_ne_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read T from the reader, assuming native-endian byte order, using the given arguments. Read more
Source§

impl BinWrite for Xbc1

Source§

type Args<'__binrw_generated_args_lifetime> = ()

The type used for the args parameter of write_args() and write_options(). Read more
Source§

fn write_options<W: Write + Seek>( &self, __binrw_generated_var_writer: &mut W, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_>, ) -> BinResult<()>

Write Self to the writer using the given Endian and arguments. Read more
Source§

fn write_be<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming big-endian byte order. Read more
Source§

fn write_le<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming little-endian byte order. Read more
Source§

fn write_ne<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming native-endian byte order. Read more
Source§

fn write_be_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming big-endian byte order, using the given arguments. Read more
Source§

fn write_le_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming little-endian byte order, using the given arguments. Read more
Source§

fn write_ne_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming native-endian byte order, using the given arguments. Read more
Source§

impl Clone for Xbc1

Source§

fn clone(&self) -> Xbc1

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Xbc1

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for Xbc1

Source§

fn eq(&self, other: &Xbc1) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl ReadMagic for Xbc1

Source§

const MAGIC: Self::MagicType

The magic number.
Source§

type MagicType = [u8; 4]

The type of the magic number.
Source§

impl WriteMagic for Xbc1

Source§

const MAGIC: Self::MagicType

The magic number.
Source§

type MagicType = [u8; 4]

The type of the magic number.
Source§

impl Xc3Write for Xbc1

Source§

const ALIGNMENT: u64 = 16u64

The alignment of absolute offsets for this type in bytes.
Source§

type Offsets<'a> = ()

The type storing offset data to be used in Xc3WriteOffsets.
Source§

fn xc3_write<W: Write + Seek>( &self, writer: &mut W, endian: Endian, ) -> Xc3Result<Self::Offsets<'_>>

Write all fields and placeholder offsets. This should almost always be derived for non primitive types. Read more
Source§

fn should_write(&self) -> Option<bool>

Return Some(_) if the offset should be updated and Some(true) if the data should also be written. Defaults to Some(true).
Source§

impl StructuralPartialEq for Xbc1

Auto Trait Implementations§

§

impl Freeze for Xbc1

§

impl RefUnwindSafe for Xbc1

§

impl Send for Xbc1

§

impl Sync for Xbc1

§

impl Unpin for Xbc1

§

impl UnwindSafe for Xbc1

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

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

Source§

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>,

Source§

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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more