Expand description
Arkiv
Arkiv is a convenience library to download, open, consult and extract archives of various format through a single consistent interface.
Supported Formats
sample.zip(requires the zip feature).sample.tar(requires thetarfeature).sample.tgzorsample.tar.gz(requirestarandgzipfeatures).sample.tar.xz(requirestarandxzfeatures).sample.tar.bz2(requirestarandbzipfeatures).sample.tar.zstdorsample.tar.zst(requirestarandzstdfeatures).
Usage
use arkiv::{Result, Archive};
fn main() -> Result<()> {
// open the archive from a local file
let mut archive = arkiv::Archive::open("path/to/archive.tar.xz")?;
// or download it over HTTP(S) - requires the `download` feature.
#[cfg(feature="download")]
let mut archive = {
let url = "https://github.com/meuter/arkiv-rs/raw/main/tests/sample/sample.tar.zstd";
arkiv::Archive::download(url)?
};
// iterate over entries
for entry in archive.entries_iter()? {
let entry = entry?;
println!("{} {}", entry.size(), entry.path().display());
}
// extract the archive (perserves permission on unix targets)
archive.unpack("/tmp/")?;
Ok(())
}Structs
- A collection of files, possibly compressed (e.g.
tar,tar.gz,zip, …). - Download destination is missing in Downloader.
- Allows to download an archive file and open it. This struct provides a bit more flexibility compared to Archive::download
- A descriptor of one entry in an archive.
- URL is missing in Downloader.
- URL is provided in Downloader.
Enums
- Download destination is provided in Downloader.
- Error type used throughout this crate
- Available archive file formats.
Type Aliases
- ArchiveKindDeprecatedAvailable archive file formats.
- An iterator over the entries of the archive
- Result type used throughout this crate