pub struct ZstdDecoder<R> { /* private fields */ }
futures-io
and zstd
only.Expand description
A zstd decoder, or decompressor
This structure implements an AsyncRead
interface and will
read compressed data from an underlying stream and emit a stream of uncompressed data.
Implementations§
Source§impl<R: AsyncBufRead> ZstdDecoder<R>
impl<R: AsyncBufRead> ZstdDecoder<R>
Sourcepub fn new(read: R) -> ZstdDecoder<R>
pub fn new(read: R) -> ZstdDecoder<R>
Creates a new decoder which will read compressed data from the given stream and emit a uncompressed stream.
Sourcepub fn with_params(inner: R, params: &[DParameter]) -> Self
pub fn with_params(inner: R, params: &[DParameter]) -> Self
Creates a new decoder, using the specified parameters, which will read compressed data from the given stream and emit a decompressed stream.
Sourcepub fn with_dict(inner: R, dictionary: &[u8]) -> Result<Self>
pub fn with_dict(inner: R, dictionary: &[u8]) -> Result<Self>
Creates a new decoder, using the specified compression level and pre-trained dictionary, which will read compressed data from the given stream and emit an uncompressed stream.
Dictionaries provide better compression ratios for small files, but are required to be present during decompression. The dictionary used must be the same as the one used for compression.
§Errors
Returns error when dictionary
is not valid.
Source§impl<R> ZstdDecoder<R>
impl<R> ZstdDecoder<R>
Sourcepub fn multiple_members(&mut self, enabled: bool)
pub fn multiple_members(&mut self, enabled: bool)
Configure multi-member/frame decoding, if enabled this will reset the decoder state when reaching the end of a compressed member/frame and expect either EOF or another compressed member/frame to follow it in the stream.
Sourcepub fn get_ref(&self) -> &R
pub fn get_ref(&self) -> &R
Acquires a reference to the underlying reader that this decoder is wrapping.
Sourcepub fn get_mut(&mut self) -> &mut R
pub fn get_mut(&mut self) -> &mut R
Acquires a mutable reference to the underlying reader that this decoder is wrapping.
Note that care must be taken to avoid tampering with the state of the reader which may otherwise confuse this decoder.
Sourcepub fn get_pin_mut(self: Pin<&mut Self>) -> Pin<&mut R>
pub fn get_pin_mut(self: Pin<&mut Self>) -> Pin<&mut R>
Acquires a pinned mutable reference to the underlying reader that this decoder is wrapping.
Note that care must be taken to avoid tampering with the state of the reader which may otherwise confuse this decoder.
Sourcepub fn into_inner(self) -> R
pub fn into_inner(self) -> R
Consumes this decoder returning the underlying reader.
Note that this may discard internal state of this decoder, so care should be taken to avoid losing resources when this is called.
Trait Implementations§
Source§impl<R: AsyncBufRead> AsyncRead for ZstdDecoder<R>
impl<R: AsyncBufRead> AsyncRead for ZstdDecoder<R>
Source§impl<R: AsyncWrite> AsyncWrite for ZstdDecoder<R>
impl<R: AsyncWrite> AsyncWrite for ZstdDecoder<R>
Source§fn poll_write(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
buf: &[u8],
) -> Poll<Result<usize>>
fn poll_write( self: Pin<&mut Self>, cx: &mut Context<'_>, buf: &[u8], ) -> Poll<Result<usize>>
buf
into the object. Read more