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::decoding::errors::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 structured_zstd::decoding::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: DECImplementations§
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>
Sourcepub fn new_with_dictionary_handle(
source: READ,
dict: &DictionaryHandle,
) -> Result<StreamingDecoder<READ, FrameDecoder>, FrameDecoderError>
pub fn new_with_dictionary_handle( source: READ, dict: &DictionaryHandle, ) -> Result<StreamingDecoder<READ, FrameDecoder>, FrameDecoderError>
Create a streaming decoder using a pre-parsed dictionary handle.
§Warning
This constructor initializes the underlying FrameDecoder with
dict, even if a frame header omits the optional dictionary ID.
Callers must only use it when they already know the stream was encoded
with this dictionary; otherwise decoded output can be silently
corrupted.
Sourcepub fn new_with_dictionary_bytes(
source: READ,
raw_dictionary: &[u8],
) -> Result<StreamingDecoder<READ, FrameDecoder>, FrameDecoderError>
pub fn new_with_dictionary_bytes( source: READ, raw_dictionary: &[u8], ) -> Result<StreamingDecoder<READ, FrameDecoder>, FrameDecoderError>
Create a streaming decoder using a serialized dictionary blob.
§Warning
This API forwards to StreamingDecoder::new_with_dictionary_handle
and therefore applies the decoded dictionary to frames whose headers may
omit the optional dictionary ID. Only use it when the stream is known to
be encoded with that dictionary.
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