[][src]Struct xz::write::XzEncoder

pub struct XzEncoder<W> where
    W: Write
{ /* fields omitted */ }

A compression stream which will have uncompressed data written to it and will write compressed data to an output stream.

Implementations

impl<W> XzEncoder<W> where
    W: Write
[src]

pub fn new(obj: W, level: u32) -> XzEncoder<W>

Notable traits for XzEncoder<W>

impl<W> Write for XzEncoder<W> where
    W: Write
impl<W> Read for XzEncoder<W> where
    W: Read + Write
[src]

Create a new compression stream which will compress at the given level to write compress output to the give output stream.

pub fn new_stream(obj: W, stream: Stream) -> XzEncoder<W>

Notable traits for XzEncoder<W>

impl<W> Write for XzEncoder<W> where
    W: Write
impl<W> Read for XzEncoder<W> where
    W: Read + Write
[src]

Create a new encoder which will use the specified Stream to encode (compress) data into the provided obj.

pub fn get_ref(&self) -> &W[src]

Acquires a reference to the underlying writer.

pub fn get_mut(&mut self) -> &mut W[src]

Acquires a mutable reference to the underlying writer.

Note that mutating the output/input state of the stream may corrupt this object, so care must be taken when using this method.

pub fn try_finish(&mut self) -> Result<(), Error>[src]

Attempt to finish this output stream, writing out final chunks of data.

Note that this function can only be used once data has finished being written to the output stream. After this function is called then further calls to write may result in a panic.

Panics

Attempts to write data to this stream may result in a panic after this function is called.

pub fn finish(self) -> Result<W, Error>[src]

Consumes this encoder, flushing the output stream.

This will flush the underlying data stream and then return the contained writer if the flush succeeded.

Note that this function may not be suitable to call in a situation where the underlying stream is an asynchronous I/O stream. To finish a stream the try_finish (or shutdown) method should be used instead. To re-acquire ownership of a stream it is safe to call this method after try_finish or shutdown has returned Ok.

pub fn total_out(&self) -> u64[src]

Returns the number of bytes produced by the compressor

Note that, due to buffering, this only bears any relation to total_in() after a call to flush(). At that point, total_out() / total_in() is the compression ratio.

pub fn total_in(&self) -> u64[src]

Returns the number of bytes consumed by the compressor (e.g. the number of bytes written to this stream.)

Trait Implementations

impl<W> Drop for XzEncoder<W> where
    W: Write
[src]

impl<W> Read for XzEncoder<W> where
    W: Read + Write
[src]

impl<W> Write for XzEncoder<W> where
    W: Write
[src]

Auto Trait Implementations

impl<W> RefUnwindSafe for XzEncoder<W> where
    W: RefUnwindSafe

impl<W> Send for XzEncoder<W> where
    W: Send

impl<W> Sync for XzEncoder<W> where
    W: Sync

impl<W> Unpin for XzEncoder<W> where
    W: Unpin

impl<W> UnwindSafe for XzEncoder<W> where
    W: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.