pub struct XzDecoder<R: Read> { /* private fields */ }
Expand description
A decompression stream which wraps a compressed stream of data. Decompressed data will be read from the stream.
Implementations§
Source§impl<R: Read> XzDecoder<R>
impl<R: Read> XzDecoder<R>
Sourcepub fn new(r: R) -> XzDecoder<R> ⓘ
pub fn new(r: R) -> XzDecoder<R> ⓘ
Create a new decompression stream, which will read compressed
data from the given input stream, and decompress one xz stream.
It may also consume input data that follows the xz stream.
Use [xz::bufread::XzDecoder
] instead to process a mix of xz and non-xz data.
Sourcepub fn new_multi_decoder(r: R) -> XzDecoder<R> ⓘ
pub fn new_multi_decoder(r: R) -> XzDecoder<R> ⓘ
Create a new decompression stream, which will read compressed data from the given input and decompress all the xz stream it contains.
Sourcepub fn new_stream(r: R, stream: Stream) -> XzDecoder<R> ⓘ
pub fn new_stream(r: R, stream: Stream) -> XzDecoder<R> ⓘ
Creates a new decoder with a custom Stream
.
The Stream
can be pre-configured for various checks, different
decompression options/tuning, etc.
Sourcepub fn get_mut(&mut self) -> &mut R
pub fn get_mut(&mut self) -> &mut R
Acquires a mutable reference to the underlying stream
Note that mutation of the stream may result in surprising results if this encoder is continued to be used.
Sourcepub fn into_inner(self) -> R
pub fn into_inner(self) -> R
Unwrap the underlying writer, finishing the compression stream.
Sourcepub fn total_out(&self) -> u64
pub fn total_out(&self) -> u64
Returns the number of bytes produced by the decompressor (e.g. the number of bytes read from this stream)
Note that, due to buffering, this only bears any relation to
total_in() when the decompressor reaches a sync point
(e.g. where the original compressed stream was flushed).
At that point, total_in() / total_out()
is the compression ratio.
Trait Implementations§
Source§impl<R: Read> Read for XzDecoder<R>
impl<R: Read> Read for XzDecoder<R>
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
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 moreSource§impl<W: Write + Read> Write for XzDecoder<W>
impl<W: Write + Read> Write for XzDecoder<W>
Source§fn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Source§fn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Source§fn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
can_vector
)1.0.0 · Source§fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
Source§fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
write_all_vectored
)