Struct inflate::DeflateDecoder

source ·
pub struct DeflateDecoder<R> { /* private fields */ }
Expand description

A DEFLATE decoder/decompressor.

This structure implements a Read interface and takes a stream of compressed data that implements the Read trait as input, provoding the decompressed data when read from.

Example

use std::io::Read;
use inflate::DeflateDecoder;
const TEST_STRING: &'static str = "Hello, world";
let encoded = vec![243, 72, 205, 201, 201, 215, 81, 40, 207, 47, 202, 73, 1, 0];
let mut decoder = DeflateDecoder::new(&encoded[..]);
let mut output = Vec::new();
let status = decoder.read_to_end(&mut output);
assert_eq!(String::from_utf8(output).unwrap(), TEST_STRING);

Implementations

Create a new Deflatedecoderbuf to read from a raw deflate stream.

Create a new DeflateDecoderbuf that reads from a zlib wrapped deflate stream.

Create a new DeflateDecoderbuf that reads from a zlib wrapped deflate stream. without calculating and validating the checksum.

Resets the decompressor, and replaces the current inner BufRead instance by r. without doing any extra reallocations.

Note that this function doesn’t ensure that all data has been output.

Returns a reference to the underlying reader.

Returns a mutable reference to the underlying reader.

Note that mutation of the reader may cause surprising results if the decoder is going to keep being used.

Returns the total number of bytes output from this decoder.

Resets the decoder, but continue to read from the same reader.

Note that this function doesn’t ensure that all data has been output.

Returns the total bytes read from the underlying reader.

Returns the total number of bytes output from this decoder.

Returns the calculated checksum value of the currently decoded data.

Will return 0 for cases where the checksum is not validated.

Trait Implementations

Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
Like read, except that it reads into a slice of buffers. Read more
🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
Read all bytes until EOF in this source, placing them into buf. Read more
Read all bytes until EOF in this source, appending them to buf. Read more
Read the exact number of bytes required to fill buf. Read more
🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
Creates a “by reference” adaptor for this instance of Read. Read more
Transforms this Read instance to an Iterator over its bytes. Read more
Creates an adapter which will chain this stream with another. Read more
Creates an adapter which will read at most limit bytes from it. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.