Derivce Clone for ZipArchive
This commit is contained in:
parent
3e532d8ef3
commit
1c2024c554
1 changed files with 29 additions and 1 deletions
30
src/read.rs
30
src/read.rs
|
@ -67,7 +67,7 @@ const TM_1980_01_01 : ::time::Tm = ::time::Tm {
|
||||||
///
|
///
|
||||||
/// println!("Result: {:?}", doit());
|
/// println!("Result: {:?}", doit());
|
||||||
/// ```
|
/// ```
|
||||||
#[derive(Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct ZipArchive<R: Read + io::Seek>
|
pub struct ZipArchive<R: Read + io::Seek>
|
||||||
{
|
{
|
||||||
reader: R,
|
reader: R,
|
||||||
|
@ -688,4 +688,32 @@ mod test {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn zip_clone() {
|
||||||
|
use std::io::{self, Read};
|
||||||
|
use super::ZipArchive;
|
||||||
|
|
||||||
|
let mut v = Vec::new();
|
||||||
|
v.extend_from_slice(include_bytes!("../tests/data/mimetype.zip"));
|
||||||
|
let mut reader1 = ZipArchive::new(io::Cursor::new(v)).unwrap();
|
||||||
|
let mut reader2 = reader1.clone();
|
||||||
|
|
||||||
|
let mut file1 = reader1.by_index(0).unwrap();
|
||||||
|
let mut file2 = reader2.by_index(0).unwrap();
|
||||||
|
|
||||||
|
let mut buf1 = [0; 5];
|
||||||
|
let mut buf2 = [0; 5];
|
||||||
|
let mut buf3 = [0; 5];
|
||||||
|
let mut buf4 = [0; 5];
|
||||||
|
|
||||||
|
file1.read(&mut buf1).unwrap();
|
||||||
|
file2.read(&mut buf2).unwrap();
|
||||||
|
file1.read(&mut buf3).unwrap();
|
||||||
|
file2.read(&mut buf4).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(buf1, buf2);
|
||||||
|
assert_eq!(buf3, buf4);
|
||||||
|
assert!(buf1 != buf3);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue