Crate zune_inflate
source ·Expand description
An incredibly spiffy deflate decoder.
This crate features a deflate/zlib decoder inspired by Eric Bigger’s libdeflate.
This libary has a smaller set of features hence you should use it if it aligns with your end goals.
Use it if
- You want a smaller library footprint when compared to flate/miniz-oxide
- You want faster speeds than zlib-ng/zlib/miniz-oxide.
- You do full buffer decompression and not streaming decompression.
- You don’t need compression support for now, it will come soon enough.
- You want a 100% safe, pure rust implementation with above.
Do not use it if
- You want compression support, not yet there
- You stream your data, not compatible with this library
§Alternatives
-
For the fastest speeds, check out libdeflate (C), if using Rust there is libdeflater which provides bindings to libdeflate
-
For streaming support use flate2-rs with an appropriate backend(zlib-ng is recommended for speed)
§Features
You can disable features depending on what you need. the following are features present
- gzip: Enable gzip decoding
- zlib: Enable zlib decoding
These features are enabled by default
To disable a feature , modify Cargo.toml to disable default features and add the needed feature , e.g below will include zlib decoding and disable gzip decoding
zune-inflate={ version="0.2",default-features=false,feature=["zlib"]}
§Errors
In case of an error, the library returns the error and the decoded data up to when the error was encountered hence that data can be recovered but no data further than that can be recovered
§Usage
Decoding delfate data
use zune_inflate::DeflateDecoder;
let totally_valid_data = [0;23];
let mut decoder = DeflateDecoder::new(&totally_valid_data);
let decompressed =decoder.decode_deflate().unwrap();
Decoding zlib data
use zune_inflate::DeflateDecoder;
// yea this isn't valid
let totally_valid_data = [0;23];
let mut decoder = DeflateDecoder::new(&totally_valid_data);
let decompressed =decoder.decode_zlib().unwrap();
Decoding zlib data without confirming the adler32 checksum
use zune_inflate::DeflateDecoder;
use zune_inflate::DeflateOptions;
let totally_valid_data=[0;23];
let mut options = DeflateOptions::default()
.set_confirm_checksum(false);
let decoder = DeflateDecoder::new_with_options(&totally_valid_data,options);
Modules§
- Errors possible when decoding deflate/zlib/gzip streams
Structs§
- A deflate decoder instance.
- A simple Deflate Encoder.
- Options that can influence decompression in Deflate/Zlib/Gzip