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§
Source§impl<R: Read> DeflateDecoder<R>
impl<R: Read> DeflateDecoder<R>
Sourcepub fn new(reader: R) -> DeflateDecoder<R> ⓘ
pub fn new(reader: R) -> DeflateDecoder<R> ⓘ
Create a new Deflatedecoderbuf
to read from a raw deflate stream.
Sourcepub fn from_zlib(reader: R) -> DeflateDecoder<R> ⓘ
pub fn from_zlib(reader: R) -> DeflateDecoder<R> ⓘ
Create a new DeflateDecoderbuf
that reads from a zlib wrapped deflate stream.
Sourcepub fn from_zlib_no_checksum(reader: R) -> DeflateDecoder<R> ⓘ
pub fn from_zlib_no_checksum(reader: R) -> DeflateDecoder<R> ⓘ
Create a new DeflateDecoderbuf
that reads from a zlib wrapped deflate stream.
without calculating and validating the checksum.
Sourcepub fn reset(&mut self, r: R) -> R
pub fn reset(&mut self, r: R) -> R
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.
Sourcepub fn get_mut(&mut self) -> &mut R
pub fn get_mut(&mut self) -> &mut R
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.
Sourcepub fn into_inner(self) -> R
pub fn into_inner(self) -> R
Returns the total number of bytes output from this decoder.
Source§impl<R> DeflateDecoder<R>
impl<R> DeflateDecoder<R>
Sourcepub fn reset_data(&mut self)
pub fn reset_data(&mut self)
Resets the decoder, but continue to read from the same reader.
Note that this function doesn’t ensure that all data has been output.
Sourcepub fn current_checksum(&self) -> u32
pub fn current_checksum(&self) -> u32
Returns the calculated checksum value of the currently decoded data.
Will return 0 for cases where the checksum is not validated.
Trait Implementations§
Source§impl<R: Read> Read for DeflateDecoder<R>
impl<R: Read> Read for DeflateDecoder<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 more