77 lines
1.6 KiB
Markdown
77 lines
1.6 KiB
Markdown
|
# tar-rs
|
||
|
|
||
|
[Documentation](https://docs.rs/tar)
|
||
|
|
||
|
A tar archive reading/writing library for Rust.
|
||
|
|
||
|
```toml
|
||
|
# Cargo.toml
|
||
|
[dependencies]
|
||
|
tar = "0.4"
|
||
|
```
|
||
|
|
||
|
## Reading an archive
|
||
|
|
||
|
```rust,no_run
|
||
|
extern crate tar;
|
||
|
|
||
|
use std::io::prelude::*;
|
||
|
use std::fs::File;
|
||
|
use tar::Archive;
|
||
|
|
||
|
fn main() {
|
||
|
let file = File::open("foo.tar").unwrap();
|
||
|
let mut a = Archive::new(file);
|
||
|
|
||
|
for file in a.entries().unwrap() {
|
||
|
// Make sure there wasn't an I/O error
|
||
|
let mut file = file.unwrap();
|
||
|
|
||
|
// Inspect metadata about the file
|
||
|
println!("{:?}", file.header().path().unwrap());
|
||
|
println!("{}", file.header().size().unwrap());
|
||
|
|
||
|
// files implement the Read trait
|
||
|
let mut s = String::new();
|
||
|
file.read_to_string(&mut s).unwrap();
|
||
|
println!("{}", s);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
```
|
||
|
|
||
|
## Writing an archive
|
||
|
|
||
|
```rust,no_run
|
||
|
extern crate tar;
|
||
|
|
||
|
use std::io::prelude::*;
|
||
|
use std::fs::File;
|
||
|
use tar::Builder;
|
||
|
|
||
|
fn main() {
|
||
|
let file = File::create("foo.tar").unwrap();
|
||
|
let mut a = Builder::new(file);
|
||
|
|
||
|
a.append_path("file1.txt").unwrap();
|
||
|
a.append_file("file2.txt", &mut File::open("file3.txt").unwrap()).unwrap();
|
||
|
}
|
||
|
```
|
||
|
|
||
|
# License
|
||
|
|
||
|
This project is licensed under either of
|
||
|
|
||
|
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
||
|
http://www.apache.org/licenses/LICENSE-2.0)
|
||
|
* MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
||
|
http://opensource.org/licenses/MIT)
|
||
|
|
||
|
at your option.
|
||
|
|
||
|
### Contribution
|
||
|
|
||
|
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.
|