Merge pull request #17 from vrmiguel/byte-formatting

Add pretty-printing for bytes
This commit is contained in:
Vinícius Miguel 2021-04-06 03:13:22 -03:00 committed by GitHub
commit e080de860a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 125 additions and 19 deletions

30
src/bytes.rs Normal file
View File

@ -0,0 +1,30 @@
use std::cmp;
const UNITS: [&str; 4] = ["B", "kB", "MB", "GB"];
pub struct Bytes {
bytes: f64,
}
impl Bytes {
pub fn new(bytes: u64) -> Self {
Self {
bytes: bytes as f64,
}
}
}
impl std::fmt::Display for Bytes {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
let num = self.bytes;
debug_assert!(num >= 0.0);
if num < 1_f64 {
return write!(f, "{} B", num);
}
let delimiter = 1000_f64;
let exponent = cmp::min((num.ln() / 6.90775).floor() as i32, 4);
write!(f, "{:.2} ", num / delimiter.powi(exponent))?;
write!(f, "{}", UNITS[exponent as usize])
}
}

View File

@ -5,6 +5,7 @@ use colored::Colorize;
use super::{Compressor, Entry};
use crate::{
extension::CompressionFormat,
bytes::Bytes,
file::File,
utils::{check_for_multiple_files, ensure_exists},
};
@ -22,10 +23,10 @@ impl BzipCompressor {
};
println!(
"{}: compressed {:?} into memory ({} bytes)",
"{}: compressed {:?} into memory ({})",
"info".yellow(),
&path,
contents.len()
Bytes::new(contents.len() as u64)
);
Ok(contents)

View File

@ -6,6 +6,7 @@ use super::{Compressor, Entry};
use crate::{
extension::CompressionFormat,
file::File,
bytes::Bytes,
utils::{check_for_multiple_files, ensure_exists},
};
@ -27,10 +28,10 @@ impl GzipCompressor {
};
println!(
"{}: compressed {:?} into memory ({} bytes)",
"{}: compressed {:?} into memory ({})",
"info".yellow(),
&path,
bytes.len()
Bytes::new(bytes.len() as u64)
);
Ok(bytes)

View File

@ -6,6 +6,7 @@ use super::{Compressor, Entry};
use crate::{
extension::CompressionFormat,
file::File,
bytes::Bytes,
utils::{check_for_multiple_files, ensure_exists},
};
@ -27,10 +28,10 @@ impl LzmaCompressor {
};
println!(
"{}: compressed {:?} into memory ({} bytes)",
"{}: compressed {:?} into memory ({})",
"info".yellow(),
&path,
bytes.len()
Bytes::new(bytes.len() as u64)
);
Ok(bytes)

View File

@ -8,7 +8,7 @@ use colored::Colorize;
use tar::{self, Archive};
use super::decompressor::{DecompressionResult, Decompressor};
use crate::{dialogs::Confirmation, file::File, utils};
use crate::{dialogs::Confirmation, file::File, bytes::Bytes, utils};
#[derive(Debug)]
pub struct TarDecompressor {}
@ -45,10 +45,10 @@ impl TarDecompressor {
file.unpack_in(into)?;
println!(
"{}: {:?} extracted. ({} bytes)",
"{}: {:?} extracted. ({})",
"info".yellow(),
into.join(file.path()?),
file.size()
Bytes::new(file.size())
);
let file_path = fs::canonicalize(file_path)?;

View File

@ -7,7 +7,7 @@ use colored::Colorize;
use super::decompressor::{DecompressionResult, Decompressor};
use crate::utils;
// use niffler;
use crate::bytes::Bytes;
use crate::{extension::CompressionFormat, file::File};
struct DecompressorToMemory {}
@ -37,10 +37,10 @@ impl DecompressorToMemory {
let bytes_read = reader.read_to_end(&mut buffer)?;
println!(
"{}: {:?} extracted into memory ({} bytes).",
"{}: {:?} extracted into memory ({}).",
"info".yellow(),
path,
bytes_read
Bytes::new(bytes_read as u64)
);
Ok(buffer)

View File

@ -8,7 +8,7 @@ use colored::Colorize;
use zip::{self, read::ZipFile, ZipArchive};
use super::decompressor::{DecompressionResult, Decompressor};
use crate::{dialogs::Confirmation, file::File, utils};
use crate::{dialogs::Confirmation, file::File, bytes::Bytes, utils};
#[cfg(unix)]
fn __unix_set_permissions(file_path: &Path, file: &ZipFile) {
@ -73,10 +73,10 @@ impl ZipDecompressor {
}
}
println!(
"{}: \"{}\" extracted. ({} bytes)",
"{}: \"{}\" extracted. ({})",
"info".yellow(),
file_path.display(),
file.size()
Bytes::new(file.size())
);
let mut output_file = fs::File::create(&file_path)?;

View File

@ -7,6 +7,7 @@ use std::{
use colored::Colorize;
use crate::{
bytes::Bytes,
cli::{VERSION, Command},
compressors::{
Entry, Compressor, BzipCompressor, GzipCompressor, LzmaCompressor, TarCompressor,
@ -199,10 +200,10 @@ impl Evaluator {
};
println!(
"{}: writing to {:?}. ({} bytes)",
"{}: writing to {:?}. ({})",
"info".yellow(),
output_path,
bytes.len()
Bytes::new(bytes.len() as u64)
);
fs::write(output_path, bytes)?;

View File

@ -7,7 +7,7 @@ use std::{
use CompressionFormat::*;
use crate::{debug, utils::to_utf};
use crate::utils::to_utf;
/// Represents the extension of a file, but only really caring about
/// compression formats (and .tar).

View File

@ -1,3 +1,4 @@
mod bytes;
mod cli;
mod compressors;
mod decompressors;

View File

@ -26,7 +26,7 @@ where
}
#[cfg(test)]
mod tests {
mod argparsing {
use super::{make_dummy_files};
use crate::cli;
use crate::cli::Command;
@ -103,6 +103,77 @@ mod tests {
}
}
#[cfg(test)]
mod byte_pretty_printing {
use crate::bytes::Bytes;
#[test]
fn bytes () {
assert_eq!(
&format!("{}", Bytes::new(234)),
"234.00 B"
);
assert_eq!(
&format!("{}", Bytes::new(999)),
"999.00 B"
);
}
#[test]
fn kilobytes () {
assert_eq!(
&format!("{}", Bytes::new(2234)),
"2.23 kB"
);
assert_eq!(
&format!("{}", Bytes::new(62500)),
"62.50 kB"
);
assert_eq!(
&format!("{}", Bytes::new(329990)),
"329.99 kB"
);
}
#[test]
fn megabytes () {
assert_eq!(
&format!("{}", Bytes::new(2750000)),
"2.75 MB"
);
assert_eq!(
&format!("{}", Bytes::new(55000000)),
"55.00 MB"
);
assert_eq!(
&format!("{}", Bytes::new(987654321)),
"987.65 MB"
);
}
#[test]
fn gigabytes () {
assert_eq!(
&format!("{}", Bytes::new(5280000000)),
"5.28 GB"
);
assert_eq!(
&format!("{}", Bytes::new(95200000000)),
"95.20 GB"
);
assert_eq!(
&format!("{}", Bytes::new(302000000000)),
"302.00 GB"
);
}
}
// #[cfg(test)]
// mod cli {
// use super::*;