cra

Crates.iocra
lib.rscra
version0.1.3
sourcesrc
created_at2024-01-31 10:03:51.426386
updated_at2024-05-05 11:14:15.477839
descriptionSimple library for extracting/archiving in multiple formats fully in memory
homepagehttps://github.com/chrontax/cra
repositoryhttps://github.com/chrontax/cra
max_upload_size
id1121607
size37,906
(chrontax)

documentation

README

Cra

Simple library for extracting/archiving in multiple formats fully in memory

Features

  • effortlessly read archives and iterate over their entries
  • support for 7z, zip and tar
  • fully in memory
  • create archives in any supported format

Usage

cargo add cra

Examples

Read and iterate over archive:

use cra::{ArcReader, ArcEntry};

let mut archive = ArcReader::new(&archive_bytes).unwrap();

for entry in archive {
    match entry {
        ArcEntry::File(name, data) => { /* do something */ }
        ArcEntry::Directory(name) => { /* do something else */ }
    }
}

Create a zip archive with a directory and a file:

use cra::{ArcWriter, ArcEntry, ArcFormat};

let mut writer = ArcWriter::new(Format::Zip);

writer.push(ArcEntry::Directory(String::from("some_dir")));
writer.push(ArcEntry::File(String::from("some_file"), data));

let finished_archive = writer.archive().unwrap(); // Vec<u8>
Commit count: 7

cargo fmt