std::process::exit(real_main());
let args: Vec<_> = std::env::args().collect();
println!("Usage {} <filename>", args[0]);
let fname = std::path::Path::new(&*args[1]);
let file = fs::File::open(&fname).unwrap();
let mut archive = zip::ZipArchive::new(file).unwrap();
for i in 0..archive.len() {
let mut file = archive.by_index(i).unwrap();
let outpath = match file.enclosed_name() {
Some(path) => path.to_owned(),
{ let comment = file.comment();
println!("File {} comment:{}", i, comment);
if (*file.name()).ends_with('/'){
println!("File {} extracted to \"{}\"", i, outpath.display());
fs::create_dir_all(&outpath).unwrap();
println!("File {} extracted to \"{}\" ({} bytes)", i, outpath.display(), file.size());
if let Some(p) = outpath.parent(){
fs::create_dir_all(&p).unwrap();
let mut outfile = fs::File::create(&outpath).unwrap();
io::copy(&mut file, &mut outfile).unwrap();
use std::os::unix::fs::PermissionsExt;
if let Some(mode) = file.unix.mode(){
fs::set_permissions(&outpath, fs::Permissions::from_mode(mode)).unwrap();