Struct ruzstd::streaming_decoder::StreamingDecoder

source ·
pub struct StreamingDecoder<READ: Read, DEC: BorrowMut<FrameDecoder>> {
    pub decoder: DEC,
    /* private fields */
}
Expand description

High level Zstandard frame decoder that can be used to decompress a given Zstandard frame.

This decoder implements io::Read, so you can interact with it by calling io::Read::read_to_end / io::Read::read_exact or passing this to another library / module as a source for the decoded content

If you need more control over how decompression takes place, you can use the lower level FrameDecoder, which allows for greater control over how decompression takes place but the implementor must call FrameDecoder::decode_blocks repeatedly to decode the entire frame.

§Caveat

StreamingDecoder expects the underlying stream to only contain a single frame, yet the specification states that a single archive may contain multiple frames.

To decode all the frames in a finite stream, the calling code needs to recreate the instance of the decoder and handle crate::frame::ReadFrameHeaderError::SkipFrame errors by skipping forward the length amount of bytes, see https://github.com/KillingSpark/zstd-rs/issues/57

// `read_to_end` is not implemented by the no_std implementation.
#[cfg(feature = "std")]
{
    use std::fs::File;
    use std::io::Read;
    use ruzstd::{StreamingDecoder};

    // Read a Zstandard archive from the filesystem then decompress it into a vec.
    let mut f: File = todo!("Read a .zstd archive from somewhere");
    let mut decoder = StreamingDecoder::new(f).unwrap();
    let mut result = Vec::new();
    Read::read_to_end(&mut decoder, &mut result).unwrap();
}

Fields§

§decoder: DEC

Implementations§

source§

impl<READ: Read, DEC: BorrowMut<FrameDecoder>> StreamingDecoder<READ, DEC>

source

pub fn new_with_decoder( source: READ, decoder: DEC ) -> Result<StreamingDecoder<READ, DEC>, FrameDecoderError>

source§

impl<READ: Read> StreamingDecoder<READ, FrameDecoder>

source§

impl<READ: Read, DEC: BorrowMut<FrameDecoder>> StreamingDecoder<READ, DEC>

source

pub fn get_ref(&self) -> &READ

Gets a reference to the underlying reader.

source

pub fn get_mut(&mut self) -> &mut READ

Gets a mutable reference to the underlying reader.

It is inadvisable to directly read from the underlying reader.

source

pub fn into_inner(self) -> READ
where READ: Sized,

Destructures this object into the inner reader.

source

pub fn into_parts(self) -> (READ, DEC)
where READ: Sized,

Destructures this object into both the inner reader and FrameDecoder.

source

pub fn into_frame_decoder(self) -> DEC

Destructures this object into the inner FrameDecoder.

Trait Implementations§

source§

impl<READ: Read, DEC: BorrowMut<FrameDecoder>> Read for StreamingDecoder<READ, DEC>

source§

fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error>

Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
1.36.0 · source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>

Like read, except that it reads into a slice of buffers. Read more
source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
1.0.0 · source§

fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>

Read all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Read all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>

Read the exact number of bytes required to fill buf. Read more
source§

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · source§

fn bytes(self) -> Bytes<Self>
where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · source§

fn chain<R>(self, next: R) -> Chain<Self, R>
where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · source§

fn take(self, limit: u64) -> Take<Self>
where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more

Auto Trait Implementations§

§

impl<READ, DEC> Freeze for StreamingDecoder<READ, DEC>
where DEC: Freeze, READ: Freeze,

§

impl<READ, DEC> RefUnwindSafe for StreamingDecoder<READ, DEC>
where DEC: RefUnwindSafe, READ: RefUnwindSafe,

§

impl<READ, DEC> Send for StreamingDecoder<READ, DEC>
where DEC: Send, READ: Send,

§

impl<READ, DEC> Sync for StreamingDecoder<READ, DEC>
where DEC: Sync, READ: Sync,

§

impl<READ, DEC> Unpin for StreamingDecoder<READ, DEC>
where DEC: Unpin, READ: Unpin,

§

impl<READ, DEC> UnwindSafe for StreamingDecoder<READ, DEC>
where DEC: UnwindSafe, READ: UnwindSafe,

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.