23 releases (10 stable)
new 4.0.2 | Jan 17, 2025 |
---|---|
4.0.0 | Nov 27, 2024 |
3.0.2 | May 4, 2024 |
2.0.1 | Apr 12, 2024 |
0.3.0 | Nov 30, 2022 |
#91 in Compression
190 downloads per month
Used in rfmp
58KB
1K
SLoC
mtzip
MTZIP (Stands for Multi-Threaded ZIP) is a library for making zip archives while utilising all available performance available with multithreading. The amount of threads can be limited by the user or detected automatically.
Example usage:
use mtzip::ZipArchive;
// Creating the zipper that holds data and handles compression
let mut zipper = ZipArchive::new();
// Adding a file from filesystem
zipper.add_file_from_fs(
Path::new("input/test_text_file.txt"),
"test_text_file.txt".to_owned(),
);
// Adding a file with data from a memory location
zipper.add_file_from_memory(b"Hello, world!", "hello_world.txt".to_owned());
// Adding a directory and a file to it
zipper.add_directory("test_dir".to_owned());
zipper.add_file_from_fs(
Path::new("input/file_that_goes_to_a_dir.txt"),
"test_dir/file_that_goes_to_a_dir.txt".to_owned(),
);
// Writing to a file
// First, open the file
let mut file = File::create("output.zip").unwrap();
// Then, write to it
zipper.write(&mut file); // Amount of threads is chosen automatically
The amount of threads is also determined by the amount of files that are going to be compressed. Because Deflate compression cannot be multithreaded, the multithreading is achieved by having the files compressed individually. This means that if you have 12 threads available but only 6 files being added to the archive, you will only use 6 threads.
Async
As each compression job runs in its own thread, there is no need to use async for concurrency between those. You can put the call to the write
function into a separate blocking thread to do synchronous write I/O. Here is a list of helpers for using asynchronous I/O types as synchronous:
tokio
:SyncIoBridge
fromtokio-util
futures
:Async{Read,Write}::compat_write
. TheCompat
struct implements synchronous std I/O operations.
Rayon
This crate also supports rayon
for thread management and parallelism, enabled with rayon
feature.
Crate features
rust_backend
- enablesflate2/rust_backend
feature, enabled by defaultzlib
- enablesflate2/zlib
featurerayon
- enables rayon supportwasi_fs
- enabled use of WASI filesistem metadata extensions
Dependencies
~0.6–1.5MB
~32K SLoC