inflate

A DEFLATE decoder written in rust.

This library provides functionality to decompress data compressed with the DEFLATE algorithm, both with and without a zlib header/trailer.

Examples

The easiest way to get std::Vec<u8> containing the decompressed bytes is to use either inflate::inflate_bytes or inflate::inflate_bytes_zlib (depending on whether the encoded data has zlib headers and trailers or not). The following example decodes the DEFLATE encoded string "Hello, world" and prints it:

```rust use inflate::inflatebytes; use std::str::fromutf8;

let encoded = [243, 72, 205, 201, 201, 215, 81, 40, 207, 47, 202, 73, 1, 0]; let decoded = inflatebytes(&encoded).unwrap(); println!("{}", fromutf8(&decoded).unwrap()); // prints "Hello, world" ```

If you need more flexibility, then the library also provides an implementation of std::io::Writer in inflate::writer. Below is an example using an inflate::writer::InflateWriter to decode the DEFLATE encoded string "Hello, world":

```rust use inflate::InflateWriter; use std::io::Write; use std::str::from_utf8;

let encoded = [243, 72, 205, 201, 201, 215, 81, 40, 207, 47, 202, 73, 1, 0]; let mut decoder = InflateWriter::new(Vec::new()); decoder.write(&encoded).unwrap(); let decoded = decoder.finish().unwrap(); println!("{}", from_utf8(&decoded).unwrap()); // prints "Hello, world" ```

Finally, if you need even more flexibility, or if you only want to depend on core, you can use the inflate::InflateStream API. The below example decodes an array of DEFLATE encoded bytes:

```rust use inflate::InflateStream;

let data = [0x73, 0x49, 0x4d, 0xcb, 0x49, 0x2c, 0x49, 0x55, 0x00, 0x11, 0x00]; let mut inflater = InflateStream::new(); let mut out = Vec::::new(); let mut n = 0; while n < data.len() { let res = inflater.update(&data[n..]); if let Ok((numbytesread, result)) = res { n += numbytesread; out.extend(result.iter().cloned()); } else { res.unwrap(); } } ```