From 28ae54f7433ee40eba33e17a534268a9c34f74a9 Mon Sep 17 00:00:00 2001 From: Truman Kilen Date: Thu, 23 Feb 2023 16:49:35 -0600 Subject: [PATCH] Add progress bar for packing/unpacking --- repak_cli/Cargo.toml | 1 + repak_cli/src/main.rs | 26 ++++++++++++++++++-------- 2 files changed, 19 insertions(+), 8 deletions(-) diff --git a/repak_cli/Cargo.toml b/repak_cli/Cargo.toml index a296d4c..740e076 100644 --- a/repak_cli/Cargo.toml +++ b/repak_cli/Cargo.toml @@ -14,6 +14,7 @@ path = "src/main.rs" aes = { workspace = true } base64 = { workspace = true } clap = { version = "4.1.4", features = ["derive"] } +indicatif = { version = "0.17.3", features = ["rayon"] } path-clean = "0.1.0" path-slash = "0.2.1" rayon = "1.6.1" diff --git a/repak_cli/src/main.rs b/repak_cli/src/main.rs index 32da1d8..4a7a9a1 100644 --- a/repak_cli/src/main.rs +++ b/repak_cli/src/main.rs @@ -178,6 +178,8 @@ fn list(args: ActionInfo) -> Result<(), repak::Error> { Ok(()) } +const STYLE: &str = "[{elapsed_precise}] [{wide_bar}] {pos}/{len} ({eta})"; + fn unpack(args: ActionUnpack) -> Result<(), repak::Error> { let pak = repak::PakReader::new_any( BufReader::new(File::open(&args.input)?), @@ -246,11 +248,15 @@ fn unpack(args: ActionUnpack) -> Result<(), repak::Error> { .filter_map(|e| e.transpose()) .collect::, repak::Error>>()?; - entries.par_iter().try_for_each_init( - || File::open(&args.input), - |file, entry| -> Result<(), repak::Error> { + use indicatif::ParallelProgressIterator; + + let iter = entries.par_iter().progress_with_style(indicatif::ProgressStyle::with_template(STYLE).unwrap()); + let progress = iter.progress.clone(); + iter.try_for_each_init( + || (progress.clone(), File::open(&args.input)), + |(progress, file), entry| -> Result<(), repak::Error> { if args.verbose { - println!("extracting {}", entry.entry_path); + progress.println(format!("unpacking {}", entry.entry_path)); } fs::create_dir_all(&entry.out_dir)?; pak.read_file( @@ -302,17 +308,21 @@ fn pack(args: ActionPack) -> Result<(), repak::Error> { Some(args.path_hash_seed), ); - for p in &paths { + use indicatif::ProgressIterator; + + let mut iter = paths.iter().progress_with_style(indicatif::ProgressStyle::with_template(STYLE).unwrap()); + let progress = iter.progress.clone(); + iter.try_for_each(|p| { let rel = &p .strip_prefix(input_path) .expect("file not in input directory") .to_slash() .expect("failed to convert to slash path"); if args.verbose { - println!("packing {}", &rel); + progress.println(format!("packing {}", &rel)); } - pak.write_file(rel, &mut BufReader::new(File::open(p)?))?; - } + pak.write_file(rel, &mut BufReader::new(File::open(p)?)) + })?; pak.write_index()?;