Rust bindings for isa-l
Supports the following codecs using the ISA-L library under the hood:
isal::read::GzipEncoder/GzipDecoder
isal::write::GzipEncoder/GzipDecoder
isal::read::DeflateEncoder/DeflateDecoder
isal::write::DeflateEncoder/DeflateDecoder
isal::read::ZlibEncoder/ZlibDecoder
isal::write::ZlibEncoder/ZlibDecoder
Or can use functions of de/compress
and de/compress_into
Building requires some system tools like autotools
, nasm
, make
, and anything the official ISA-L repo suggests.
On Windows the build is invoked with nmake
, other systems use the ./autogen.sh
and ./configure
setups.
compress_into
and decompress
(Similar functionality with compress
and decompress_into
)
use isal::{CompressionLevel, Codec, compress_into, decompress};
let mut compressed = vec![0u8; 100];
let nbytes = compress_into(b"foobar", &mut compressed, CompressionLevel::Three, Codec::Gzip).unwrap();
let decompressed = decompress(&compressed[..nbytes], Codec::Gzip).unwrap();
assert_eq!(decompressed.as_slice(), b"foobar");
io::Read
use std::{io, io::Read};
use isal::{read::{Encoder, GzipEncoder}, CompressionLevel, decompress, Codec};
let data = b"Hello, World!".to_vec();
// Note these two encoders are equivelent...
let mut encoder = GzipEncoder::new(data.as_slice(), CompressionLevel::Three);
let mut encoder = Encoder::new(data.as_slice(), CompressionLevel::Three, Codec::Gzip);
// Number of compressed bytes written to `output`
let mut compressed = vec![];
let n = io::copy(&mut encoder, &mut compressed).unwrap();
assert_eq!(n as usize, compressed.len());
let decompressed = decompress(compressed.as_slice(), Codec::Gzip).unwrap();
assert_eq!(decompressed.as_slice(), data);
io::Write
use std::{io, io::Write};
use isal::{write::Decoder, CompressionLevel, compress, Codec};
let data = b"Hello, World!".to_vec();
let compressed = compress(data.as_slice(), CompressionLevel::Three, Codec::Gzip).unwrap();
let mut decompressed = vec![];
let mut decoder = Decoder::new(&mut decompressed, Codec::Gzip);
// Number of compressed bytes written to `output`
let n = io::copy(&mut io::Cursor::new(&compressed), &mut decoder).unwrap();
assert_eq!(n as usize, compressed.len());
assert_eq!(decompressed.as_slice(), data);
TL/DR: It’s roughly 5-10x faster than flate2 with the default features, and ~2-3x faster using flate2 with zlib-ng backend.
Checkout the README in the benches directory. Criterion benchmark report available here: https://milesgranger.github.io/isal-rs/benches/criterion/report/
NOTE: ISA-L supports compression levels 0, 1, 3. These benchmarks compare gzip using compression level 3 for both flate2 and isal-rs.
Versions are specified in normal SemVer format, and a trailing “+<< commit hash >>
” to indicate
which commit in isa-l the crate is built against. ie: 0.1.0+62519d9