1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
use std::collections::BTreeSet; use std::fmt::Write; pub fn plain_list_names(names: BTreeSet<String>) -> String { let mut s = String::new(); let len = names.len(); for (idx, n) in names.into_iter().enumerate() { if idx != 0 { if idx == len - 1 { if len == 2 { write!(s, " and ").unwrap(); } else { write!(s, ", and ").unwrap(); } } else { write!(s, ", ").unwrap(); } } write!(s, "{}", n).unwrap(); } s } pub fn prettyprint_usize(x: usize) -> String { let num = format!("{}", x); let mut result = String::new(); let mut i = num.len(); for c in num.chars() { result.push(c); i -= 1; if i > 0 && i % 3 == 0 { result.push(','); } } result } pub fn abbreviated_format(x: usize) -> String { if x >= 1000 { let ks = x as f32 / 1000.0; format!("{:.1}k", ks) } else { x.to_string() } } pub fn basename<I: AsRef<str>>(path: I) -> String { std::path::Path::new(path.as_ref()) .file_stem() .unwrap() .to_os_string() .into_string() .unwrap() } pub fn parent_path(path: &str) -> String { format!("{}", std::path::Path::new(path).parent().unwrap().display()) }