From 02c93163cf5f7f772ce3087e41f322f8fd82d711 Mon Sep 17 00:00:00 2001 From: Dietmar Maurer Date: Fri, 15 Mar 2019 08:02:04 +0100 Subject: [PATCH] src/pxar/decoder.rs: correctly call callback() --- src/client/pxar_decode_writer.rs | 2 +- src/pxar/decoder.rs | 9 +++++---- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/src/client/pxar_decode_writer.rs b/src/client/pxar_decode_writer.rs index b0700a31..968b3f6d 100644 --- a/src/client/pxar_decode_writer.rs +++ b/src/client/pxar_decode_writer.rs @@ -35,7 +35,7 @@ impl PxarDecodeWriter { if let Err(err) = decoder.restore(&base, & |path| { if verbose { - println!("RESTORE: {:?}", path); + println!("{:?}", path); } Ok(()) }) { diff --git a/src/pxar/decoder.rs b/src/pxar/decoder.rs index 463b7d22..af8084f2 100644 --- a/src/pxar/decoder.rs +++ b/src/pxar/decoder.rs @@ -266,6 +266,8 @@ impl <'a, R: Read> PxarDecoder<'a, R> { check_ca_header::(&head, CA_FORMAT_ENTRY)?; let entry: CaFormatEntry = self.read_item()?; + (callback)(path)?; + let mode = entry.mode as u32; //fixme: upper 32bits? let ifmt = mode & libc::S_IFMT; @@ -286,8 +288,7 @@ impl <'a, R: Read> PxarDecoder<'a, R> { while head.htype == CA_FORMAT_FILENAME { let name = self.read_filename(head.size)?; path.push(&name); - println!("NAME: {:?}", path); - + //println!("NAME: {:?}", path); self.restore_sequential(path, &name, &dir, callback)?; path.pop(); @@ -298,7 +299,7 @@ impl <'a, R: Read> PxarDecoder<'a, R> { bail!("got unknown header type inside directory entry {:016x}", head.htype); } - println!("Skip Goodbye"); + //println!("Skip Goodbye"); if head.size < HEADER_SIZE { bail!("detected short goodbye table"); } self.skip_bytes((head.size - HEADER_SIZE) as usize)?; @@ -322,7 +323,7 @@ impl <'a, R: Read> PxarDecoder<'a, R> { match head.htype { CA_FORMAT_SYMLINK => { let target = self.read_symlink(head.size)?; - println!("TARGET: {:?}", target); + //println!("TARGET: {:?}", target); if let Err(err) = symlinkat(&target, parent_fd, filename) { bail!("create symlink {:?} failed - {}", path, err); }