diff options
| author | Berrysoft <Strawberry_Str@hotmail.com> | 2025-04-10 15:12:19 +0800 |
|---|---|---|
| committer | Berrysoft <Strawberry_Str@hotmail.com> | 2025-04-10 15:12:19 +0800 |
| commit | 7aab011dbb6ab2a46c12107d8a516b10a961f2a2 (patch) | |
| tree | 2d6916f9ecaed3db6dcfd881e97eb6140d85ce51 /library/std/src/sys/process/unix/unix.rs | |
| parent | 6813f955a616999109ff69c48bbad6be33c6cdb3 (diff) | |
| download | rust-7aab011dbb6ab2a46c12107d8a516b10a961f2a2.tar.gz rust-7aab011dbb6ab2a46c12107d8a516b10a961f2a2.zip | |
Use posix_spawn on cygwin
Diffstat (limited to 'library/std/src/sys/process/unix/unix.rs')
| -rw-r--r-- | library/std/src/sys/process/unix/unix.rs | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/library/std/src/sys/process/unix/unix.rs b/library/std/src/sys/process/unix/unix.rs index 191a09c8da9..c293c8871ec 100644 --- a/library/std/src/sys/process/unix/unix.rs +++ b/library/std/src/sys/process/unix/unix.rs @@ -415,6 +415,7 @@ impl Command { all(target_os = "linux", target_env = "musl"), target_os = "nto", target_vendor = "apple", + target_os = "cygwin", )))] fn posix_spawn( &mut self, @@ -433,6 +434,7 @@ impl Command { all(target_os = "linux", target_env = "musl"), target_os = "nto", target_vendor = "apple", + target_os = "cygwin", ))] // FIXME(#115199): Rust currently omits weak function definitions // and its metadata from LLVM IR. @@ -587,7 +589,7 @@ impl Command { /// Some platforms can set a new working directory for a spawned process in the /// `posix_spawn` path. This function looks up the function pointer for adding /// such an action to a `posix_spawn_file_actions_t` struct. - #[cfg(not(all(target_os = "linux", target_env = "musl")))] + #[cfg(not(any(all(target_os = "linux", target_env = "musl"), target_os = "cygwin")))] fn get_posix_spawn_addchdir() -> Option<PosixSpawnAddChdirFn> { use crate::sys::weak::weak; @@ -621,7 +623,9 @@ impl Command { /// Weak symbol lookup doesn't work with statically linked libcs, so in cases /// where static linking is possible we need to either check for the presence /// of the symbol at compile time or know about it upfront. - #[cfg(all(target_os = "linux", target_env = "musl"))] + /// + /// Cygwin doesn't support weak symbol, so just link it. + #[cfg(any(all(target_os = "linux", target_env = "musl"), target_os = "cygwin"))] fn get_posix_spawn_addchdir() -> Option<PosixSpawnAddChdirFn> { // Our minimum required musl supports this function, so we can just use it. Some(libc::posix_spawn_file_actions_addchdir_np) |
