pub struct XzEncoder<R> { /* private fields */ }Expand description
A xz encoder, or compressor.
This structure implements a BufRead interface and will read uncompressed
data from an underlying stream and emit a stream of compressed data.
Implementations§
Source§impl<R: BufRead> XzEncoder<R>
 
impl<R: BufRead> XzEncoder<R>
Sourcepub fn new(r: R, level: u32) -> XzEncoder<R> ⓘ
 
pub fn new(r: R, level: u32) -> XzEncoder<R> ⓘ
Creates a new encoder which will read uncompressed data from the given stream and emit the compressed stream.
The level argument here is typically 0-9 with 6 being a good default.
Sourcepub fn new_stream(r: R, stream: Stream) -> XzEncoder<R> ⓘ
 
pub fn new_stream(r: R, stream: Stream) -> XzEncoder<R> ⓘ
Creates a new encoder with a custom Stream.
The Stream can be pre-configured for multithreaded encoding, different
compression options/tuning, etc.
Source§impl<R> XzEncoder<R>
 
impl<R> XzEncoder<R>
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
Consumes this encoder, returning the underlying reader.
Sourcepub fn total_out(&self) -> u64
 
pub fn total_out(&self) -> u64
Returns the number of bytes produced by the compressor (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 compressor chooses to flush its data
(unfortunately, this won’t happen in general at the end of the
stream, because the compressor doesn’t know if there’s more data
to come).  At that point, total_out() / total_in() would be
the compression ratio.
Trait Implementations§
Source§impl<R: BufRead> Read for XzEncoder<R>
 
impl<R: BufRead> Read for XzEncoder<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> Write for XzEncoder<W>
 
impl<W: Write> Write for XzEncoder<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)