From a4ecf1ccd5d8b5d9d3295f92156f15e1d7ae818a Mon Sep 17 00:00:00 2001 From: Bo Maryniuk Date: Thu, 2 Nov 2023 17:54:27 +0100 Subject: [PATCH] Refactor filters to share resources between other objects --- src/filters/defs.rs | 2 +- src/filters/resources.rs | 24 ++++++++++++++++++++ src/filters/texts.rs | 4 ++-- src/scanner/dlst.rs | 48 +++++++++++++++++++--------------------- 4 files changed, 50 insertions(+), 28 deletions(-) diff --git a/src/filters/defs.rs b/src/filters/defs.rs index fd88b5f..80a0ebf 100644 --- a/src/filters/defs.rs +++ b/src/filters/defs.rs @@ -16,7 +16,7 @@ pub const DOC_FP_EXT: &[&str] = &[".eps", ".pdf", ".ps"]; pub const DOC_LOCATIONS: &[&str] = &["/usr/share/doc"]; /// Headers -pub const H_SRC_F_EXT: &[&str] = &[".h", ".hpp"]; +pub const SRC_FH_EXT: &[&str] = &[".h", ".hpp"]; /// Archives pub const ARC_F_EXT: &[&str] = &[".gz", ".bz2", ".xz", ".zip", ".tar"]; diff --git a/src/filters/resources.rs b/src/filters/resources.rs index 6c48916..45b1e4f 100644 --- a/src/filters/resources.rs +++ b/src/filters/resources.rs @@ -59,6 +59,30 @@ impl ResourcesDataFilter { false } + + /// Detects if a file is still a potential junk (but unsure) + pub fn is_potential_junk(fname: &str) -> bool { + for ext in + defs::DOC_F_EXT.iter().chain(defs::ARC_F_EXT.iter()).chain(defs::SRC_FH_EXT.iter()).chain(defs::DOC_FP_EXT.iter()) + { + if fname.ends_with(ext) { + return true; + } + } + + for sf in defs::DOC_STUB_FILES { + if fname == *sf { + return true; + } + } + + // Potentially doc stubfile that doesn't look like a known one + if fname == fname.to_uppercase() { + return true; + } + + false + } } impl DataFilter for ResourcesDataFilter { diff --git a/src/filters/texts.rs b/src/filters/texts.rs index 582fe88..eec0674 100644 --- a/src/filters/texts.rs +++ b/src/filters/texts.rs @@ -65,7 +65,7 @@ impl TextDataFilter { let p = p.to_str().unwrap(); - for c in ["/doc/"].iter().chain(defs::DOC_STUB_FILES.iter()) { + for c in ["/doc/"].iter().chain(defs::DOC_STUB_FILES) { if p.to_lowercase().contains(c.to_lowercase().as_str()) { return true; } @@ -77,7 +77,7 @@ impl TextDataFilter { } } - for c in defs::DOC_F_EXT { + for c in defs::DOC_F_EXT.iter().chain(defs::DOC_FP_EXT).chain(defs::SRC_FH_EXT) { if p.ends_with(c) { return true; } diff --git a/src/scanner/dlst.rs b/src/scanner/dlst.rs index 45edd64..eb76a85 100644 --- a/src/scanner/dlst.rs +++ b/src/scanner/dlst.rs @@ -2,7 +2,10 @@ Data lister (fancy STDOUT printer) */ -use crate::filters::defs::{self}; +use crate::filters::{ + defs::{self}, + resources, +}; use bytesize::ByteSize; use colored::Colorize; use std::{ @@ -25,6 +28,9 @@ impl<'a> ContentFormatter<'a> { pub(crate) fn format(&mut self) { let d_len = self.fs_data.len() - 1; let mut t_size: u64 = 0; + let mut j_size: u64 = 0; // size of junk + let mut j_total: u64 = 0; // total junk files + for (pi, p) in self.fs_data.iter().enumerate() { t_size += p.metadata().unwrap().len(); let (dname, mut fname) = self.dn(p); @@ -53,7 +59,9 @@ impl<'a> ContentFormatter<'a> { } else { if fname.ends_with(".so") || fname.contains(".so.") { fname = fname.green().to_string(); - } else if self.is_potential_junk(&fname) { + } else if resources::ResourcesDataFilter::is_potential_junk(&fname) { + j_total += 1; + j_size += p.metadata().unwrap().len(); fname = format!("{} {}", "⚠️".bright_red().bold(), fname.bright_red()); } @@ -61,30 +69,20 @@ impl<'a> ContentFormatter<'a> { } } - println!("\nPreserved {} files, taking space: {}\n", d_len + 1, ByteSize::b(t_size)); - } - - fn is_potential_junk(&self, fname: &str) -> bool { - for ext in - defs::DOC_F_EXT.iter().chain(defs::ARC_F_EXT.iter()).chain(defs::H_SRC_F_EXT.iter()).chain(defs::DOC_FP_EXT.iter()) - { - if fname.ends_with(ext) { - return true; - } + // Print the summary + println!( + "\nPreserved {} files, taking {} of a disk space", + (d_len + 1).to_string().bright_green(), + ByteSize::b(t_size).to_string().bright_yellow() + ); + if j_total > 0 { + println!( + "Potentially {} junk files, taking {} of a disk space", + j_total.to_string().bright_red(), + ByteSize::b(j_size).to_string().bright_yellow() + ); } - - for sf in defs::DOC_STUB_FILES { - if fname == *sf { - return true; - } - } - - // Potentially doc stubfile that doesn't look like a known one - if fname == fname.to_uppercase() { - return true; - } - - false + println!(""); } /// Get dir/name split, painted accordingly