From 1d4b7fee65a36a9d4752588f223d0a269a563e3a Mon Sep 17 00:00:00 2001 From: Wei Zhang Date: Mon, 1 Apr 2024 14:13:06 +0800 Subject: [PATCH] :construction: Signed-off-by: Wei Zhang --- Cargo.lock | 109 +++++++++++++++++++++++----------------------- src/core.rs | 8 ++++ src/display.rs | 27 +++++++++++- src/meta/owner.rs | 52 ++++++++++++---------- 4 files changed, 116 insertions(+), 80 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 1a749ed7a..99f8e557f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -4,9 +4,9 @@ version = 3 [[package]] name = "aho-corasick" -version = "1.1.2" +version = "1.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b2969dcb958b36655471fc61f7e416fa76033bdd4bfed0678d8fee1e2d07a1f0" +checksum = "8e60d3430d3a69478ad0993f19238d2df97c507009a52b3c10addcd7f6bcb916" dependencies = [ "memchr", ] @@ -107,9 +107,9 @@ dependencies = [ [[package]] name = "autocfg" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" +checksum = "f1fdabc7756949593fe60f30ec81974b613357de856987752631dea1e3394c80" [[package]] name = "bitflags" @@ -119,9 +119,9 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] name = "bitflags" -version = "2.4.2" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ed570934406eb16438a4e976b1b4500774099c13b8cb96eec99f620f05090ddf" +checksum = "cf4b9d6a944f767f8e5e0db018570623c85f3d925ac718db4e06d0187adb21c1" dependencies = [ "serde", ] @@ -161,9 +161,9 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "chrono" -version = "0.4.35" +version = "0.4.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8eaf5903dcbc0a39312feb77df2ff4c76387d591b9fc7b04a238dcf8bb62639a" +checksum = "8a0d04d43504c61aa6c7531f1871dd0d418d91130162063b789da00fd7057a5e" dependencies = [ "android-tzdata", "iana-time-zone", @@ -277,7 +277,7 @@ version = "0.27.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f476fe445d41c9e991fd07515a6f463074b782242ccf4a5b7b1d1012e70824df" dependencies = [ - "bitflags 2.4.2", + "bitflags 2.5.0", "crossterm_winapi", "libc", "mio", @@ -361,9 +361,9 @@ dependencies = [ [[package]] name = "fastrand" -version = "2.0.1" +version = "2.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25cbce373ec4653f1a01a31e8a5e5ec0c622dc27ff9c4e6606eefef5cbbed4a5" +checksum = "658bd65b1cf4c852a3cc96f18a8ce7b5640f6b703f905c7d74532294c2a63984" [[package]] name = "float-cmp" @@ -473,11 +473,11 @@ dependencies = [ [[package]] name = "git2" -version = "0.18.2" +version = "0.18.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1b3ba52851e73b46a4c3df1d89343741112003f0f6f13beb0dfac9e457c3fdcd" +checksum = "232e6a7bfe35766bf715e55a88b39a700596c0ccfd88cd3680b4cdb40d66ef70" dependencies = [ - "bitflags 2.4.2", + "bitflags 2.5.0", "libc", "libgit2-sys", "log", @@ -509,7 +509,7 @@ version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0bf760ebf69878d9fd8f110c89703d90ce35095324d1f1edcb595c63945ee757" dependencies = [ - "bitflags 2.4.2", + "bitflags 2.5.0", "ignore", "walkdir", ] @@ -589,9 +589,9 @@ dependencies = [ [[package]] name = "indexmap" -version = "2.2.5" +version = "2.2.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b0b929d511467233429c45a44ac1dcaa21ba0f5ba11e4879e6ed28ddb4f9df4" +checksum = "168fb715dda47215e360912c096649d23d58bf392ac62f73919e831745e40f26" dependencies = [ "equivalent", "hashbrown", @@ -621,9 +621,9 @@ dependencies = [ [[package]] name = "itoa" -version = "1.0.10" +version = "1.0.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1a46d1a171d865aa5f83f92695765caa047a9b4cbae2cbf37dbd613a793fd4c" +checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" [[package]] name = "jobserver" @@ -669,20 +669,19 @@ dependencies = [ [[package]] name = "libredox" -version = "0.0.1" +version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "85c833ca1e66078851dba29046874e38f08b2c883700aa29a03ddd3b23814ee8" +checksum = "c0ff37bd590ca25063e35af745c343cb7a0271906fb7b37e4813e8f79f00268d" dependencies = [ - "bitflags 2.4.2", + "bitflags 2.5.0", "libc", - "redox_syscall", ] [[package]] name = "libz-sys" -version = "1.1.15" +version = "1.1.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "037731f5d3aaa87a5675e895b63ddff1a87624bc29f77004ea829809654e48f6" +checksum = "5e143b5e666b2695d28f6bca6497720813f699c9602dd7f5cac91008b8ada7f9" dependencies = [ "cc", "libc", @@ -774,9 +773,9 @@ dependencies = [ [[package]] name = "memchr" -version = "2.7.1" +version = "2.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "523dc4f511e55ab87b694dc30d0f820d60906ef06413f93d4d7a1385599cc149" +checksum = "6c8640c5d730cb13ebd907d8d04b52f55ac9a2eec55b440c8892f40d56c76c1d" [[package]] name = "mio" @@ -857,9 +856,9 @@ checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" [[package]] name = "pin-project-lite" -version = "0.2.13" +version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8afb450f006bf6385ca15ef45d71d2288452bc3683ce2e2cacc0d18e4be60b58" +checksum = "bda66fc9667c18cb2758a2ac84d1167245054bcf85d5d1aaa6923f45801bdd02" [[package]] name = "pin-utils" @@ -905,9 +904,9 @@ dependencies = [ [[package]] name = "proc-macro2" -version = "1.0.78" +version = "1.0.79" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e2422ad645d89c99f8f3e6b88a9fdeca7fabeac836b1002371c4367c8f984aae" +checksum = "e835ff2298f5721608eb1a980ecaee1aef2c132bf95ecc026a11b7bf3c01c02e" dependencies = [ "unicode-ident", ] @@ -938,9 +937,9 @@ dependencies = [ [[package]] name = "redox_users" -version = "0.4.4" +version = "0.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a18479200779601e498ada4e8c1e1f50e3ee19deb0259c25825a98b5603b2cb4" +checksum = "bd283d9651eeda4b2a83a43c1c91b266c40fd76ecd39a50a8c630ae69dc72891" dependencies = [ "getrandom", "libredox", @@ -949,9 +948,9 @@ dependencies = [ [[package]] name = "regex" -version = "1.10.3" +version = "1.10.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b62dbe01f0b06f9d8dc7d49e05a0785f153b00b2c227856282f671e0318c9b15" +checksum = "c117dbdfde9c8308975b6a18d71f3f385c89461f7b3fb054288ecf2a2058ba4c" dependencies = [ "aho-corasick", "memchr", @@ -972,9 +971,9 @@ dependencies = [ [[package]] name = "regex-syntax" -version = "0.8.2" +version = "0.8.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f" +checksum = "adad44e29e4c806119491a7f06f03de4d1af22c3a680dd47f1e6e179439d1f56" [[package]] name = "rustix" @@ -992,11 +991,11 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.31" +version = "0.38.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6ea3e1a662af26cd7a3ba09c0297a31af215563ecf42817c98df621387f4e949" +checksum = "65e04861e65f21776e67888bfbea442b3642beaa0138fdb1dd7a84a52dffdb89" dependencies = [ - "bitflags 2.4.2", + "bitflags 2.5.0", "errno", "libc", "linux-raw-sys 0.4.13", @@ -1046,9 +1045,9 @@ dependencies = [ [[package]] name = "serde_yaml" -version = "0.9.32" +version = "0.9.34+deprecated" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8fd075d994154d4a774f95b51fb96bdc2832b0ea48425c92546073816cda1f2f" +checksum = "6a8b1a1a2ebf674015cc02edccce75287f1a0130d394307b36743c2f5d504b47" dependencies = [ "indexmap", "itoa", @@ -1123,9 +1122,9 @@ dependencies = [ [[package]] name = "smallvec" -version = "1.13.1" +version = "1.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" +checksum = "3c5e1a9a646d36c3599cd173a41282daf47c44583ad367b8e6837255952e5c67" [[package]] name = "strsim" @@ -1135,9 +1134,9 @@ checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" [[package]] name = "syn" -version = "2.0.52" +version = "2.0.57" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b699d15b36d1f02c3e7c69f8ffef53de37aefae075d8488d4ba1a7788d574a07" +checksum = "11a6ae1e52eb25aab8f3fb9fca13be982a373b8f1157ca14b897a825ba4a2d35" dependencies = [ "proc-macro2", "quote", @@ -1161,7 +1160,7 @@ checksum = "85b77fafb263dd9d05cbeac119526425676db3784113aa9295c88498cbf8bff1" dependencies = [ "cfg-if", "fastrand", - "rustix 0.38.31", + "rustix 0.38.32", "windows-sys 0.52.0", ] @@ -1190,7 +1189,7 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "21bebf2b7c9e0a515f6e0f8c51dc0f8e4696391e6f1ff30379559f8365fb0df7" dependencies = [ - "rustix 0.38.31", + "rustix 0.38.32", "windows-sys 0.48.0", ] @@ -1202,18 +1201,18 @@ checksum = "3369f5ac52d5eb6ab48c6b4ffdc8efbcad6b89c765749064ba298f2c68a16a76" [[package]] name = "thiserror" -version = "1.0.57" +version = "1.0.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e45bcbe8ed29775f228095caf2cd67af7a4ccf756ebff23a306bf3e8b47b24b" +checksum = "03468839009160513471e86a034bb2c5c0e4baae3b43f79ffc55c4a5427b3297" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.57" +version = "1.0.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a953cb265bef375dae3de6663da4d3804eee9682ea80d8e2542529b73c531c81" +checksum = "c61f3ba182994efc43764a46c018c347bc492c79f024e705f46567b418f6d4f7" dependencies = [ "proc-macro2", "quote", @@ -1264,9 +1263,9 @@ checksum = "e51733f11c9c4f72aa0c160008246859e340b00807569a0da0e7a1079b27ba85" [[package]] name = "unsafe-libyaml" -version = "0.2.10" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab4c90930b95a82d00dc9e9ac071b4991924390d46cbd0dfe566148667605e4b" +checksum = "673aac59facbab8a9007c7f6108d11f63b603f7cabff99fabf650fea5c32b861" [[package]] name = "url" @@ -1638,7 +1637,7 @@ checksum = "8da84f1a25939b27f6820d92aed108f83ff920fdf11a7b19366c27c4cda81d4f" dependencies = [ "libc", "linux-raw-sys 0.4.13", - "rustix 0.38.31", + "rustix 0.38.32", ] [[package]] diff --git a/src/core.rs b/src/core.rs index cc526a1ff..e1a41ffe9 100644 --- a/src/core.rs +++ b/src/core.rs @@ -19,6 +19,7 @@ use crate::flags::blocks::Block; use crate::git_theme::GitTheme; #[cfg(target_os = "windows")] use terminal_size::terminal_size; +use users::UsersCache; pub struct Core { flags: Flags, @@ -171,9 +172,14 @@ impl Core { } fn display(&self, metas: &[Meta]) { + let users = UsersCache::new(); + let groups = UsersCache::new(); + let output = if self.flags.layout == Layout::Tree { display::tree( metas, + &users, + &groups, &self.flags, &self.colors, &self.icons, @@ -182,6 +188,8 @@ impl Core { } else { display::grid( metas, + &users, + &groups, &self.flags, &self.colors, &self.icons, diff --git a/src/display.rs b/src/display.rs index 72515f63f..c612073e1 100644 --- a/src/display.rs +++ b/src/display.rs @@ -9,6 +9,7 @@ use std::collections::HashMap; use term_grid::{Cell, Direction, Filling, Grid, GridOptions}; use terminal_size::terminal_size; use unicode_width::UnicodeWidthStr; +use users::{Groups, Users}; const EDGE: &str = "\u{251c}\u{2500}\u{2500}"; // "├──" const LINE: &str = "\u{2502} "; // "│ " @@ -17,6 +18,8 @@ const BLANK: &str = " "; pub fn grid( metas: &[Meta], + users: &impl Users, + groups: &impl Groups, flags: &Flags, colors: &Colors, icons: &Icons, @@ -27,6 +30,8 @@ pub fn grid( inner_display_grid( &DisplayOption::None, metas, + users, + groups, flags, colors, icons, @@ -38,6 +43,8 @@ pub fn grid( pub fn tree( metas: &[Meta], + users: &impl Users, + groups: &impl Groups, flags: &Flags, colors: &Colors, icons: &Icons, @@ -59,6 +66,8 @@ pub fn tree( for cell in inner_display_tree( metas, + users, + groups, flags, colors, icons, @@ -77,6 +86,8 @@ pub fn tree( fn inner_display_grid( display_option: &DisplayOption, metas: &[Meta], + users: &impl Users, + groups: &impl Groups, flags: &Flags, colors: &Colors, icons: &Icons, @@ -117,6 +128,8 @@ fn inner_display_grid( let blocks = get_output( meta, + users, + groups, colors, icons, git_theme, @@ -176,6 +189,8 @@ fn inner_display_grid( output += &inner_display_grid( &display_option, content, + users, + groups, flags, colors, icons, @@ -223,6 +238,8 @@ fn add_header(flags: &Flags, cells: &[Cell], grid: &mut Grid) { #[allow(clippy::too_many_arguments)] fn inner_display_tree( metas: &[Meta], + users: &impl Users, + groups: &impl Groups, flags: &Flags, colors: &Colors, icons: &Icons, @@ -248,6 +265,8 @@ fn inner_display_tree( for block in get_output( meta, + users, + groups, colors, icons, git_theme, @@ -276,6 +295,8 @@ fn inner_display_tree( cells.extend(inner_display_tree( content, + users, + groups, flags, colors, icons, @@ -314,6 +335,8 @@ fn display_folder_path(meta: &Meta) -> String { #[allow(clippy::too_many_arguments)] fn get_output( meta: &Meta, + users: &impl Users, + groups: &impl Groups, colors: &Colors, icons: &Icons, git_theme: &GitTheme, @@ -357,11 +380,11 @@ fn get_output( ]); } Block::User => block_vec.push(match &meta.owner { - Some(owner) => owner.render_user(colors, flags), + Some(owner) => owner.render_user(colors, users, flags), None => colorize_missing("?"), }), Block::Group => block_vec.push(match &meta.owner { - Some(owner) => owner.render_group(colors, flags), + Some(owner) => owner.render_group(colors, groups, flags), None => colorize_missing("?"), }), Block::Context => block_vec.push(match &meta.access_control { diff --git a/src/meta/owner.rs b/src/meta/owner.rs index 247a8c987..2ea30c654 100644 --- a/src/meta/owner.rs +++ b/src/meta/owner.rs @@ -3,25 +3,24 @@ use crate::Flags; #[cfg(unix)] use std::fs::Metadata; +use users::{Groups, Users}; + #[derive(Clone, Debug)] pub struct Owner { - user: String, - group: String, + user: u32, + group: u32, } impl Owner { #[cfg_attr(unix, allow(dead_code))] - pub fn new(user: String, group: String) -> Self { + pub fn new(user: u32, group: u32) -> Self { Self { user, group } } } impl Default for Owner { fn default() -> Owner { - Owner { - user: String::from("-"), - group: String::from("-"), - } + Owner { user: 0, group: 0 } } } @@ -29,19 +28,11 @@ impl Default for Owner { impl From<&Metadata> for Owner { fn from(meta: &Metadata) -> Self { use std::os::unix::fs::MetadataExt; - use users::{get_group_by_gid, get_user_by_uid}; - - let user = match get_user_by_uid(meta.uid()) { - Some(res) => res.name().to_string_lossy().to_string(), - None => meta.uid().to_string(), - }; - - let group = match get_group_by_gid(meta.gid()) { - Some(res) => res.name().to_string_lossy().to_string(), - None => meta.gid().to_string(), - }; - Self { user, group } + Self { + user: meta.uid(), + group: meta.gid(), + } } } @@ -62,10 +53,15 @@ fn truncate(input: &str, after: Option, marker: Option) -> String } impl Owner { - pub fn render_user(&self, colors: &Colors, flags: &Flags) -> ColoredString { + pub fn render_user(&self, colors: &Colors, users: &impl Users, flags: &Flags) -> ColoredString { + let user = match users.get_user_by_uid(self.user) { + Some(user) => user.name().to_string_lossy().to_string(), + None => self.user.to_string(), + }; + colors.colorize( truncate( - &self.user, + &user, flags.truncate_owner.after, flags.truncate_owner.marker.clone(), ), @@ -73,10 +69,20 @@ impl Owner { ) } - pub fn render_group(&self, colors: &Colors, flags: &Flags) -> ColoredString { + pub fn render_group( + &self, + colors: &Colors, + groups: &impl Groups, + flags: &Flags, + ) -> ColoredString { + let group = match groups.get_group_by_gid(self.group) { + Some(group) => group.name().to_string_lossy().to_string(), + None => self.group.to_string(), + }; + colors.colorize( truncate( - &self.group, + &group, flags.truncate_owner.after, flags.truncate_owner.marker.clone(), ),