libflate 2.2.1

A Rust implementation of DEFLATE algorithm and related formats (ZLIB, GZIP)
Documentation
#[cfg(test)]
pub(crate) mod testonly {
    use alloc::vec;
    use alloc::vec::Vec;
    use core2::io::{self, Read};

    pub struct WouldBlockReader<R> {
        inner: R,
        do_block: bool,
    }

    impl<R: Read> WouldBlockReader<R> {
        pub fn new(inner: R) -> Self {
            WouldBlockReader {
                inner,
                do_block: false,
            }
        }
    }

    impl<R: Read> Read for WouldBlockReader<R> {
        fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
            self.do_block = !self.do_block;
            if self.do_block {
                Err(io::Error::new(io::ErrorKind::WouldBlock, "Would block"))
            } else if buf.is_empty() {
                Ok(0)
            } else {
                let mut byte = [0; 1];
                if self.inner.read(&mut byte[..])? == 1 {
                    buf[0] = byte[0];
                    Ok(1)
                } else {
                    Ok(0)
                }
            }
        }
    }

    pub fn nb_read_to_end<R: Read>(mut reader: R) -> io::Result<Vec<u8>> {
        let mut buf = vec![0; 1024];
        let mut offset = 0;
        loop {
            match reader.read(&mut buf[offset..]) {
                Err(e) => {
                    if e.kind() != io::ErrorKind::WouldBlock {
                        return Err(e);
                    }
                }
                Ok(0) => {
                    buf.truncate(offset);
                    break;
                }
                Ok(size) => {
                    offset += size;
                    if offset == buf.len() {
                        buf.resize(offset * 2, 0);
                    }
                }
            }
        }
        Ok(buf)
    }
}
#[cfg(test)]
pub(crate) use testonly::*;