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>
impl<READ: Read, DEC: BorrowMut<FrameDecoder>> StreamingDecoder<READ, DEC>
pub fn new_with_decoder( source: READ, decoder: DEC, ) -> Result<StreamingDecoder<READ, DEC>, FrameDecoderError>
Source§impl<READ: Read> StreamingDecoder<READ, FrameDecoder>
impl<READ: Read> StreamingDecoder<READ, FrameDecoder>
pub fn new( source: READ, ) -> Result<StreamingDecoder<READ, FrameDecoder>, FrameDecoderError>
Source§impl<READ: Read, DEC: BorrowMut<FrameDecoder>> StreamingDecoder<READ, DEC>
impl<READ: Read, DEC: BorrowMut<FrameDecoder>> StreamingDecoder<READ, DEC>
Sourcepub fn get_mut(&mut self) -> &mut READ
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.
Sourcepub fn into_inner(self) -> READwhere
READ: Sized,
pub fn into_inner(self) -> READwhere
READ: Sized,
Destructures this object into the inner reader.
Sourcepub fn into_parts(self) -> (READ, DEC)where
READ: Sized,
pub fn into_parts(self) -> (READ, DEC)where
READ: Sized,
Destructures this object into both the inner reader and FrameDecoder.
Sourcepub fn into_frame_decoder(self) -> DEC
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>
impl<READ: Read, DEC: BorrowMut<FrameDecoder>> Read for StreamingDecoder<READ, DEC>
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error>
fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error>
1.36.0 · Source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
read
, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
can_vector
)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
buf
. Read more1.0.0 · Source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
buf
. Read more1.6.0 · Source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
buf
. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
read_buf
)Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
read_buf
)cursor
. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Read
. Read more