From ee44c1ed90d46fb231ea2fb79d1bcf39dd115a85 Mon Sep 17 00:00:00 2001 From: Thayne McCombs Date: Wed, 18 Jan 2023 23:24:05 -0700 Subject: [PATCH 1/4] refactor: Use scoped threads from stdlib in spawn_receiver This makes it so we don't need to use Arc as much. Fixes #1141 --- src/exec/job.rs | 8 ++++---- src/exec/mod.rs | 6 +++--- src/walk.rs | 36 +++++++++++++++++------------------- 3 files changed, 24 insertions(+), 26 deletions(-) diff --git a/src/exec/job.rs b/src/exec/job.rs index b2ea0a40c..af603cc63 100644 --- a/src/exec/job.rs +++ b/src/exec/job.rs @@ -1,4 +1,4 @@ -use std::sync::{Arc, Mutex}; +use std::sync::Mutex; use crossbeam_channel::Receiver; @@ -15,8 +15,8 @@ use super::CommandSet; /// be executed, and this process will continue until the receiver's sender has closed. pub fn job( rx: Receiver, - cmd: Arc, - out_perm: Arc>, + cmd: &CommandSet, + out_perm: &Mutex<()>, config: &Config, ) -> ExitCode { // Output should be buffered when only running a single thread @@ -41,7 +41,7 @@ pub fn job( results.push(cmd.execute( dir_entry.stripped_path(config), config.path_separator.as_deref(), - Arc::clone(&out_perm), + out_perm, buffer_output, )) } diff --git a/src/exec/mod.rs b/src/exec/mod.rs index 17060b373..0fa4d4c23 100644 --- a/src/exec/mod.rs +++ b/src/exec/mod.rs @@ -9,7 +9,7 @@ use std::io; use std::iter; use std::path::{Component, Path, PathBuf, Prefix}; use std::process::Stdio; -use std::sync::{Arc, Mutex}; +use std::sync::Mutex; use anyhow::{bail, Result}; use argmax::Command; @@ -86,14 +86,14 @@ impl CommandSet { &self, input: &Path, path_separator: Option<&str>, - out_perm: Arc>, + out_perm: &Mutex<()>, buffer_output: bool, ) -> ExitCode { let commands = self .commands .iter() .map(|c| c.generate(input, path_separator)); - execute_commands(commands, &out_perm, buffer_output) + execute_commands(commands, out_perm, buffer_output) } pub fn execute_batch(&self, paths: I, limit: usize, path_separator: Option<&str>) -> ExitCode diff --git a/src/walk.rs b/src/walk.rs index 2b03fa9a6..502d98b14 100644 --- a/src/walk.rs +++ b/src/walk.rs @@ -347,28 +347,26 @@ fn spawn_receiver( if cmd.in_batch_mode() { exec::batch(rx, cmd, &config) } else { - let out_perm = Arc::new(Mutex::new(())); + let out_perm = Mutex::new(()); - // Each spawned job will store it's thread handle in here. - let mut handles = Vec::with_capacity(threads); - for _ in 0..threads { - let config = Arc::clone(&config); - let rx = rx.clone(); - let cmd = Arc::clone(cmd); - let out_perm = Arc::clone(&out_perm); + thread::scope(|scope| { + // Each spawned job will store it's thread handle in here. + let mut handles = Vec::with_capacity(threads); + for _ in 0..threads { + let rx = rx.clone(); - // Spawn a job thread that will listen for and execute inputs. - let handle = thread::spawn(move || exec::job(rx, cmd, out_perm, &config)); + // Spawn a job thread that will listen for and execute inputs. + let handle = scope.spawn(|| exec::job(rx, cmd, &out_perm, &config)); - // Push the handle of the spawned thread into the vector for later joining. - handles.push(handle); - } - - let exit_codes = handles - .into_iter() - .map(|handle| handle.join().unwrap()) - .collect::>(); - merge_exitcodes(exit_codes) + // Push the handle of the spawned thread into the vector for later joining. + handles.push(handle); + } + let exit_codes = handles + .into_iter() + .map(|handle| handle.join().unwrap()) + .collect::>(); + merge_exitcodes(exit_codes) + }) } } else { let stdout = io::stdout(); From ccf8e69650b20905d3fdb30a3e31842e729c6817 Mon Sep 17 00:00:00 2001 From: Thayne McCombs Date: Wed, 18 Jan 2023 23:31:12 -0700 Subject: [PATCH 2/4] fix: clippy warning for unnecessary closure Now that MSRV is above 1.62, we can use `then_some` instead of a simple closure. --- src/cli.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/cli.rs b/src/cli.rs index bb00a1cbb..a60260e87 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -695,7 +695,7 @@ impl Opts { pub fn max_results(&self) -> Option { self.max_results .filter(|&m| m > 0) - .or_else(|| self.max_one_result.then(|| 1)) + .or_else(|| self.max_one_result.then_some(1)) } #[cfg(feature = "completions")] From 424d6efcc0cf54904cfa5eab237ec61a379533f9 Mon Sep 17 00:00:00 2001 From: Thayne McCombs Date: Wed, 18 Jan 2023 23:36:54 -0700 Subject: [PATCH 3/4] fix: Remove unnecessary collection into a vec. --- src/walk.rs | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/walk.rs b/src/walk.rs index 502d98b14..0e66b9ab5 100644 --- a/src/walk.rs +++ b/src/walk.rs @@ -361,10 +361,7 @@ fn spawn_receiver( // Push the handle of the spawned thread into the vector for later joining. handles.push(handle); } - let exit_codes = handles - .into_iter() - .map(|handle| handle.join().unwrap()) - .collect::>(); + let exit_codes = handles.into_iter().map(|handle| handle.join().unwrap()); merge_exitcodes(exit_codes) }) } From 31ac4a3f5c4d86c5f20ddf98437eea86326d0875 Mon Sep 17 00:00:00 2001 From: Thayne McCombs Date: Mon, 20 Mar 2023 01:22:52 -0600 Subject: [PATCH 4/4] Bump MSRV to 1.67.0 --- .github/workflows/CICD.yml | 2 +- Cargo.toml | 2 +- clippy.toml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/CICD.yml b/.github/workflows/CICD.yml index 594706191..efc1bd30f 100644 --- a/.github/workflows/CICD.yml +++ b/.github/workflows/CICD.yml @@ -1,7 +1,7 @@ name: CICD env: - MIN_SUPPORTED_RUST_VERSION: "1.64.0" + MIN_SUPPORTED_RUST_VERSION: "1.67.0" CICD_INTERMEDIATES_DIR: "_cicd-intermediates" on: diff --git a/Cargo.toml b/Cargo.toml index dabe48a76..4ffb4ac7e 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -18,7 +18,7 @@ readme = "README.md" repository = "https://github.com/sharkdp/fd" version = "8.7.0" edition= "2021" -rust-version = "1.64.0" +rust-version = "1.67.0" [badges.appveyor] repository = "sharkdp/fd" diff --git a/clippy.toml b/clippy.toml index 22fd4be73..91884d3a0 100644 --- a/clippy.toml +++ b/clippy.toml @@ -1 +1 @@ -msrv = "1.64.0" +msrv = "1.67.0"