#archive #zip-archive #extract #compression #read-write #read-memory

cra

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

5 releases

0.1.4 Nov 12, 2024
0.1.3 May 5, 2024
0.1.2 May 5, 2024
0.1.1 Feb 1, 2024
0.1.0 Jan 31, 2024

#747 in Encoding

Download history 17/week @ 2024-09-21 5/week @ 2024-09-28 1/week @ 2024-10-05 6/week @ 2024-10-12 116/week @ 2024-11-09 22/week @ 2024-11-16 8/week @ 2024-11-23 2/week @ 2024-11-30

319 downloads per month
Used in 2 crates (via comiconv)

MIT/Apache

13KB
241 lines

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>

lib.rs:

Simple abstraction over archive formats.

You can read and write archives in zip, 7z, and tar formats.

Dependencies

~9–19MB
~285K SLoC