Sync changes from upstream
This commit is contained in:
parent
71ee4838ca
commit
7a630e21b3
12 changed files with 97 additions and 77 deletions
23
.github/workflows/ci.yaml
vendored
23
.github/workflows/ci.yaml
vendored
|
@ -16,7 +16,7 @@ jobs:
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest, macOS-latest, windows-latest]
|
os: [ubuntu-latest, macOS-latest, windows-latest]
|
||||||
rust: [stable, 1.36.0]
|
rust: [stable, 1.54.0]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@master
|
- uses: actions/checkout@master
|
||||||
|
@ -39,6 +39,25 @@ jobs:
|
||||||
command: test
|
command: test
|
||||||
args: --all
|
args: --all
|
||||||
|
|
||||||
|
clippy:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: nightly
|
||||||
|
override: true
|
||||||
|
components: clippy
|
||||||
|
|
||||||
|
- name: clippy
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: clippy
|
||||||
|
args: --all-targets --all-features -- -D warnings
|
||||||
|
|
||||||
check_fmt_and_docs:
|
check_fmt_and_docs:
|
||||||
name: Checking fmt and docs
|
name: Checking fmt and docs
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
@ -54,4 +73,4 @@ jobs:
|
||||||
run: cargo fmt --all -- --check
|
run: cargo fmt --all -- --check
|
||||||
|
|
||||||
- name: Docs
|
- name: Docs
|
||||||
run: cargo doc
|
run: cargo doc
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
# Contributor Covenant Code of Conduct
|
# Contributor Covenant Code of Conduct
|
||||||
|
|
||||||
## Our Pledge
|
## Our Pledge
|
||||||
|
|
11
Cargo.toml
11
Cargo.toml
|
@ -12,16 +12,15 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
flate2 = { version = "1.0.0", default-features = false, optional = true }
|
flate2 = { version = "1.0.0", default-features = false, optional = true }
|
||||||
time = { version = "0.1", optional = true }
|
time = { version = "0.3", features = ["formatting", "macros" ], optional = true }
|
||||||
byteorder = "1.3"
|
byteorder = "1.3"
|
||||||
bzip2 = { version = "0.4", optional = true }
|
bzip2 = { version = "0.4", optional = true }
|
||||||
crc32fast = "1.0"
|
crc32fast = "1.1.1"
|
||||||
thiserror = "1.0"
|
zstd = { version = "0.10", optional = true }
|
||||||
zstd = { version = "0.8", optional = true }
|
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
criterion = "0.3"
|
bencher = "0.1"
|
||||||
rand = "0.7"
|
getrandom = "0.2"
|
||||||
walkdir = "2"
|
walkdir = "2"
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
|
|
|
@ -3,6 +3,7 @@ zip-rs
|
||||||
|
|
||||||
[](https://github.com/zip-rs/zip/actions?query=branch%3Amaster+workflow%3ACI)
|
[](https://github.com/zip-rs/zip/actions?query=branch%3Amaster+workflow%3ACI)
|
||||||
[](https://crates.io/crates/zip)
|
[](https://crates.io/crates/zip)
|
||||||
|
[](https://discord.gg/rQ7H9cSsF4)
|
||||||
|
|
||||||
[Documentation](https://docs.rs/zip/0.5.13/zip/)
|
[Documentation](https://docs.rs/zip/0.5.13/zip/)
|
||||||
|
|
||||||
|
@ -17,7 +18,7 @@ Supported compression formats:
|
||||||
* stored (i.e. none)
|
* stored (i.e. none)
|
||||||
* deflate
|
* deflate
|
||||||
* bzip2
|
* bzip2
|
||||||
* zstd (in progress...)
|
* zstd
|
||||||
|
|
||||||
Currently unsupported zip extensions:
|
Currently unsupported zip extensions:
|
||||||
|
|
||||||
|
@ -43,7 +44,7 @@ zip = { version = "0.5", default-features = false }
|
||||||
|
|
||||||
The features available are:
|
The features available are:
|
||||||
|
|
||||||
* `deflate`: Enables the deflate compression algorithm, which is the default for zipfiles.
|
* `deflate`: Enables the deflate compression algorithm, which is the default for zip files.
|
||||||
* `bzip2`: Enables the BZip2 compression algorithm.
|
* `bzip2`: Enables the BZip2 compression algorithm.
|
||||||
* `time`: Enables features using the [time](https://github.com/rust-lang-deprecated/time) crate.
|
* `time`: Enables features using the [time](https://github.com/rust-lang-deprecated/time) crate.
|
||||||
* `zstd`: Enables the Zstandard compression algorithm.
|
* `zstd`: Enables the Zstandard compression algorithm.
|
||||||
|
@ -53,7 +54,7 @@ All of these are enabled by default.
|
||||||
MSRV
|
MSRV
|
||||||
----
|
----
|
||||||
|
|
||||||
Our current Minimum Supported Rust Version is **1.36.0**. When adding features,
|
Our current Minimum Supported Rust Version is **1.54.0**. When adding features,
|
||||||
we will follow these guidelines:
|
we will follow these guidelines:
|
||||||
|
|
||||||
- We will always support the latest four minor Rust versions. This gives you a 6
|
- We will always support the latest four minor Rust versions. This gives you a 6
|
||||||
|
|
|
@ -1,75 +1,43 @@
|
||||||
use criterion::{criterion_group, criterion_main};
|
use bencher::{benchmark_group, benchmark_main};
|
||||||
use criterion::{BenchmarkId, Criterion};
|
|
||||||
|
|
||||||
use std::io::{Cursor, Read, Write};
|
use std::io::{Cursor, Read, Write};
|
||||||
|
|
||||||
use rand::Rng;
|
use bencher::Bencher;
|
||||||
use zip::{CompressionMethod, ZipArchive, ZipWriter};
|
use getrandom::getrandom;
|
||||||
|
use zip::{ZipArchive, ZipWriter};
|
||||||
|
|
||||||
fn generate_random_archive(size: usize, method: Option<CompressionMethod>) -> Vec<u8> {
|
fn generate_random_archive(size: usize) -> Vec<u8> {
|
||||||
let data = Vec::new();
|
let data = Vec::new();
|
||||||
let mut writer = ZipWriter::new(Cursor::new(data));
|
let mut writer = ZipWriter::new(Cursor::new(data));
|
||||||
let options = zip::write::FileOptions::default()
|
let options =
|
||||||
.compression_method(method.unwrap_or(CompressionMethod::Stored));
|
zip::write::FileOptions::default().compression_method(zip::CompressionMethod::Stored);
|
||||||
|
|
||||||
writer.start_file("random.dat", options).unwrap();
|
writer.start_file("random.dat", options).unwrap();
|
||||||
|
|
||||||
// Generate some random data.
|
|
||||||
let mut bytes = vec![0u8; size];
|
let mut bytes = vec![0u8; size];
|
||||||
rand::thread_rng().fill(bytes.as_mut_slice());
|
getrandom(&mut bytes).unwrap();
|
||||||
|
|
||||||
writer.write_all(&bytes).unwrap();
|
writer.write_all(&bytes).unwrap();
|
||||||
|
|
||||||
writer.finish().unwrap().into_inner()
|
writer.finish().unwrap().into_inner()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn read_entry(bench: &mut Criterion) {
|
fn read_entry(bench: &mut Bencher) {
|
||||||
let size = 1024 * 1024;
|
let size = 1024 * 1024;
|
||||||
|
let bytes = generate_random_archive(size);
|
||||||
|
let mut archive = ZipArchive::new(Cursor::new(bytes.as_slice())).unwrap();
|
||||||
|
|
||||||
//
|
bench.iter(|| {
|
||||||
let mut group = bench.benchmark_group("read_entry");
|
let mut file = archive.by_name("random.dat").unwrap();
|
||||||
|
let mut buf = [0u8; 1024];
|
||||||
|
loop {
|
||||||
|
let n = file.read(&mut buf).unwrap();
|
||||||
|
if n == 0 {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
//
|
bench.bytes = size as u64;
|
||||||
for method in CompressionMethod::supported_methods().iter() {
|
|
||||||
group.bench_with_input(BenchmarkId::from_parameter(method), method, |bench, method| {
|
|
||||||
let bytes = generate_random_archive(size, Some(*method));
|
|
||||||
|
|
||||||
bench.iter(|| {
|
|
||||||
let mut archive = ZipArchive::new(Cursor::new(bytes.as_slice())).unwrap();
|
|
||||||
let mut file = archive.by_name("random.dat").unwrap();
|
|
||||||
let mut buf = [0u8; 1024];
|
|
||||||
|
|
||||||
let mut total_bytes = 0;
|
|
||||||
|
|
||||||
loop {
|
|
||||||
let n = file.read(&mut buf).unwrap();
|
|
||||||
total_bytes += n;
|
|
||||||
if n == 0 {
|
|
||||||
return total_bytes;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn write_random_archive(bench: &mut Criterion) {
|
benchmark_group!(benches, read_entry);
|
||||||
let size = 1024 * 1024;
|
benchmark_main!(benches);
|
||||||
|
|
||||||
//
|
|
||||||
let mut group = bench.benchmark_group("write_random_archive");
|
|
||||||
|
|
||||||
//
|
|
||||||
for method in CompressionMethod::supported_methods().iter() {
|
|
||||||
group.bench_with_input(BenchmarkId::from_parameter(method), method, |b, method| {
|
|
||||||
b.iter(|| {
|
|
||||||
generate_random_archive(size, Some(*method));
|
|
||||||
})
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
group.finish();
|
|
||||||
}
|
|
||||||
|
|
||||||
criterion_group!(benches, read_entry, write_random_archive);
|
|
||||||
criterion_main!(benches);
|
|
||||||
|
|
|
@ -59,5 +59,6 @@ fn real_main() -> i32 {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
|
0
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,5 +27,5 @@ fn real_main() -> i32 {
|
||||||
file.read_to_string(&mut contents).unwrap();
|
file.read_to_string(&mut contents).unwrap();
|
||||||
println!("{}", contents);
|
println!("{}", contents);
|
||||||
|
|
||||||
return 0;
|
0
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,5 +49,6 @@ fn real_main() -> i32 {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
|
0
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,5 +30,6 @@ fn real_main() -> i32 {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
|
0
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,7 +59,7 @@ fn real_main() -> i32 {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
0
|
||||||
}
|
}
|
||||||
|
|
||||||
fn zip_dir<T>(
|
fn zip_dir<T>(
|
||||||
|
@ -92,7 +92,7 @@ where
|
||||||
f.read_to_end(&mut buffer)?;
|
f.read_to_end(&mut buffer)?;
|
||||||
zip.write_all(&*buffer)?;
|
zip.write_all(&*buffer)?;
|
||||||
buffer.clear();
|
buffer.clear();
|
||||||
} else if name.as_os_str().len() != 0 {
|
} else if !name.as_os_str().is_empty() {
|
||||||
// Only if not root! Avoids path spec / warning
|
// Only if not root! Avoids path spec / warning
|
||||||
// and mapname conversion failed error on unzip
|
// and mapname conversion failed error on unzip
|
||||||
println!("adding dir {:?} as {:?} ...", path, name);
|
println!("adding dir {:?} as {:?} ...", path, name);
|
||||||
|
@ -116,7 +116,7 @@ fn doit(
|
||||||
let path = Path::new(dst_file);
|
let path = Path::new(dst_file);
|
||||||
let file = File::create(&path).unwrap();
|
let file = File::create(&path).unwrap();
|
||||||
|
|
||||||
let walkdir = WalkDir::new(src_dir.to_string());
|
let walkdir = WalkDir::new(src_dir);
|
||||||
let it = walkdir.into_iter();
|
let it = walkdir.into_iter();
|
||||||
|
|
||||||
zip_dir(&mut it.filter_map(|e| e.ok()), src_dir, file, method)?;
|
zip_dir(&mut it.filter_map(|e| e.ok()), src_dir, file, method)?;
|
||||||
|
|
|
@ -18,7 +18,7 @@ fn real_main() -> i32 {
|
||||||
Err(e) => println!("Error: {:?}", e),
|
Err(e) => println!("Error: {:?}", e),
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
0
|
||||||
}
|
}
|
||||||
|
|
||||||
fn doit(filename: &str) -> zip::result::ZipResult<()> {
|
fn doit(filename: &str) -> zip::result::ZipResult<()> {
|
||||||
|
@ -42,7 +42,7 @@ fn doit(filename: &str) -> zip::result::ZipResult<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
const LOREM_IPSUM : &'static [u8] = b"Lorem ipsum dolor sit amet, consectetur adipiscing elit. In tellus elit, tristique vitae mattis egestas, ultricies vitae risus. Quisque sit amet quam ut urna aliquet
|
const LOREM_IPSUM : &[u8] = b"Lorem ipsum dolor sit amet, consectetur adipiscing elit. In tellus elit, tristique vitae mattis egestas, ultricies vitae risus. Quisque sit amet quam ut urna aliquet
|
||||||
molestie. Proin blandit ornare dui, a tempor nisl accumsan in. Praesent a consequat felis. Morbi metus diam, auctor in auctor vel, feugiat id odio. Curabitur ex ex,
|
molestie. Proin blandit ornare dui, a tempor nisl accumsan in. Praesent a consequat felis. Morbi metus diam, auctor in auctor vel, feugiat id odio. Curabitur ex ex,
|
||||||
dictum quis auctor quis, suscipit id lorem. Aliquam vestibulum dolor nec enim vehicula, porta tristique augue tincidunt. Vivamus ut gravida est. Sed pellentesque, dolor
|
dictum quis auctor quis, suscipit id lorem. Aliquam vestibulum dolor nec enim vehicula, porta tristique augue tincidunt. Vivamus ut gravida est. Sed pellentesque, dolor
|
||||||
vitae tristique consectetur, neque lectus pulvinar dui, sed feugiat purus diam id lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per
|
vitae tristique consectetur, neque lectus pulvinar dui, sed feugiat purus diam id lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per
|
||||||
|
|
31
tests/issue_234.rs
Normal file
31
tests/issue_234.rs
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
use zip::result::ZipError;
|
||||||
|
|
||||||
|
const BUF: &[u8] = &[
|
||||||
|
0, 80, 75, 1, 2, 127, 120, 0, 3, 3, 75, 80, 232, 3, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 7, 0, 0, 0,
|
||||||
|
0, 65, 0, 1, 0, 0, 0, 4, 0, 0, 224, 255, 0, 255, 255, 255, 255, 255, 255, 20, 39, 221, 221,
|
||||||
|
221, 221, 221, 221, 205, 221, 221, 221, 42, 221, 221, 221, 221, 221, 221, 221, 221, 38, 34, 34,
|
||||||
|
219, 80, 75, 5, 6, 0, 0, 0, 0, 5, 96, 0, 1, 71, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 234, 236, 124,
|
||||||
|
221, 221, 37, 221, 221, 221, 221, 221, 129, 4, 0, 0, 221, 221, 80, 75, 1, 2, 127, 120, 0, 4, 0,
|
||||||
|
0, 2, 127, 120, 0, 79, 75, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 0, 0,
|
||||||
|
234, 0, 0, 0, 3, 8, 4, 232, 3, 0, 0, 0, 255, 255, 255, 255, 1, 0, 0, 0, 0, 7, 0, 0, 0, 0, 3, 0,
|
||||||
|
221, 209, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
||||||
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 58, 58, 42, 75, 9, 2, 127,
|
||||||
|
120, 0, 99, 99, 99, 99, 99, 99, 94, 7, 0, 0, 0, 0, 0, 0, 213, 213, 213, 213, 213, 213, 213,
|
||||||
|
213, 213, 7, 0, 0, 211, 211, 211, 211, 124, 236, 99, 99, 99, 94, 7, 0, 0, 0, 0, 0, 0, 213, 213,
|
||||||
|
213, 213, 213, 213, 213, 213, 213, 7, 0, 0, 211, 211, 211, 211, 124, 236, 234, 0, 0, 0, 3, 8,
|
||||||
|
0, 0, 0, 12, 0, 0, 0, 0, 0, 3, 0, 0, 0, 7, 0, 0, 0, 0, 0, 58, 58, 58, 42, 175, 221, 253, 221,
|
||||||
|
221, 221, 221, 221, 80, 75, 9, 2, 127, 120, 0, 99, 99, 99, 99, 99, 99, 94, 7, 0, 0, 0, 0, 0, 0,
|
||||||
|
213, 213, 213, 213, 213, 213, 213, 213, 213, 7, 0, 0, 211, 211, 211, 211, 124, 236, 221, 221,
|
||||||
|
221, 221, 221, 80, 75, 9, 2, 127, 120, 0, 99, 99, 99, 99, 99, 99, 94, 7, 0, 0, 0, 0, 0, 0, 213,
|
||||||
|
213, 213, 213, 213, 213, 213, 213, 213, 7, 0, 0, 211, 211, 211, 211, 124, 236,
|
||||||
|
];
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn invalid_header() {
|
||||||
|
let reader = std::io::Cursor::new(&BUF);
|
||||||
|
let archive = zip::ZipArchive::new(reader);
|
||||||
|
match archive {
|
||||||
|
Err(ZipError::InvalidArchive(_)) => {}
|
||||||
|
value => panic!("Unexpected value: {:?}", value),
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue