7 releases

0.2.1 Jan 3, 2025
0.2.0 Nov 29, 2023
0.1.6 May 6, 2023
0.1.5 Apr 9, 2023
0.1.1 Mar 24, 2020

#63 in Compression

Download history 21111/week @ 2024-09-22 22045/week @ 2024-09-29 22258/week @ 2024-10-06 18781/week @ 2024-10-13 15221/week @ 2024-10-20 17384/week @ 2024-10-27 17672/week @ 2024-11-03 17599/week @ 2024-11-10 18902/week @ 2024-11-17 18007/week @ 2024-11-24 23288/week @ 2024-12-01 19331/week @ 2024-12-08 20937/week @ 2024-12-15 15829/week @ 2024-12-22 20661/week @ 2024-12-29 27025/week @ 2025-01-05

86,555 downloads per month
Used in 15 crates (8 directly)

Apache-2.0 OR MIT

130KB
3K SLoC

Yazi - Yet another zlib implementation

Yazi is a pure Rust implementation of the RFC 1950 DEFLATE specification with support for the zlib wrapper. It provides streaming compression and decompression.

Crates.io Docs.rs Apache 2.0 or MIT license.

Usage

The following demonstrates simple usage for compressing and decompressing in-memory buffers:

use yazi::*;
// Your source data.
let data = &(0..=255).cycle().take(8192).collect::<Vec<u8>>()[..];
// Compress it into a Vec<u8> with a zlib wrapper using the default compression level.
let compressed = compress(data, Format::Zlib, CompressionLevel::Default).unwrap();
// Decompress it into a Vec<u8>.
let (decompressed, checksum) = decompress(&compressed, Format::Zlib).unwrap();
// Verify the checksum.
assert_eq!(Adler32::from_buf(&decompressed).finish(), checksum.unwrap());
// Verify that the decompressed data matches the original.
assert_eq!(data, &decompressed[..]);

For detail on more advanced usage, see the full API documentation.

License

Licensed under either of

at your option.

Contribution

Contributions are welcome by pull request. The Rust code of conduct applies.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be licensed as above, without any additional terms or conditions.

No runtime deps