diff --git a/src-tauri/src/commands/folders.rs b/src-tauri/src/commands/folders.rs index f27cc7f..9b5155d 100644 --- a/src-tauri/src/commands/folders.rs +++ b/src-tauri/src/commands/folders.rs @@ -3,7 +3,7 @@ use std::fs::{File, OpenOptions}; use std::hash::{Hash, Hasher}; use std::io::Write; use std::path::{Component, Path, PathBuf}; -use std::process::{Command, Stdio}; +use std::process::Stdio; use std::sync::{mpsc, LazyLock, Mutex}; use std::time::{Duration, Instant, UNIX_EPOCH}; @@ -1883,7 +1883,7 @@ fn git_check_ignored_paths( return Ok(HashSet::new()); } - let mut child = Command::new("git") + let mut child = crate::process::std_command("git") .args(["check-ignore", "--stdin", "-z"]) .current_dir(repo_path) .stdin(Stdio::piped()) diff --git a/src-tauri/src/process.rs b/src-tauri/src/process.rs index 4407e6c..22e1ea6 100644 --- a/src-tauri/src/process.rs +++ b/src-tauri/src/process.rs @@ -1,4 +1,5 @@ use std::ffi::{OsStr, OsString}; +use std::process::Command; #[cfg(windows)] use std::path::Path; @@ -6,6 +7,25 @@ use std::path::Path; #[cfg(windows)] const CREATE_NO_WINDOW: u32 = 0x0800_0000; +pub fn configure_std_command(command: &mut Command) -> &mut Command { + #[cfg(windows)] + { + use std::os::windows::process::CommandExt; + command.creation_flags(CREATE_NO_WINDOW); + } + + command +} + +pub fn std_command(program: S) -> Command +where + S: AsRef, +{ + let mut command = Command::new(normalized_program(program)); + configure_std_command(&mut command); + command +} + pub fn configure_tokio_command( command: &mut tokio::process::Command, ) -> &mut tokio::process::Command {