Crates.io | pna |
lib.rs | pna |
version | 0.20.0 |
source | src |
created_at | 2023-03-07 04:59:11.233303 |
updated_at | 2024-11-17 15:18:01.388258 |
description | PNA(Portable-Network-Archive) decoding and encoding library |
homepage | |
repository | https://github.com/ChanTsune/Portable-Network-Archive.git |
max_upload_size | |
id | 803297 |
size | 15,212 |
A pna archive reading/writing library for Rust.
# Cargo.toml
[dependencies]
pna = "0.20"
use pna::{Archive, ReadOptions};
use std::fs::File;
use std::io::{self, copy, prelude::*};
fn main() -> io::Result<()> {
let file = File::open("foo.pna")?;
let mut archive = Archive::read_header(file)?;
for entry in archive.entries_skip_solid() {
let entry = entry?;
let mut file = File::create(entry.header().path().as_path())?;
let mut reader = entry.reader(ReadOptions::builder().build())?;
copy(&mut reader, &mut file)?;
}
Ok(())
}
use pna::{Archive, EntryBuilder, WriteOptions};
use std::fs::File;
use std::io::{self, prelude::*};
fn main() -> io::Result<()> {
let file = File::create("foo.pna")?;
let mut archive = Archive::write_header(file)?;
let mut entry_builder = EntryBuilder::new_file(
"bar.txt".into(),
WriteOptions::builder().build(),
)?;
entry_builder.write(b"content")?;
let entry = entry_builder.build()?;
archive.add_entry(entry)?;
archive.finalize()?;
Ok(())
}
Command line user interface are available, and you can install via cargo or build from source.
cargo install portable-network-archive
cargo install --git https://github.com/ChanTsune/Portable-Network-Archive.git portable-network-archive
This project is licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.