summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorF1rst-Unicorn <f1rst_unicorn@njsm.de>2018-11-18 11:38:26 +0100
committerF1rst-Unicorn <f1rst_unicorn@njsm.de>2018-11-19 09:33:37 +0100
commit35c0d6344a7abeb27c4b43785d9824afd81ac3f1 (patch)
tree5727397bf8f765d07714572687af9445d9e75057
parent3f9548a88833701559f13eeb10df59dd49643ffd (diff)
downloadnix-35c0d6344a7abeb27c4b43785d9824afd81ac3f1.zip
Add execvpe support, conditional on platform
-rw-r--r--CHANGELOG.md2
-rw-r--r--src/unistd.rs21
-rw-r--r--test/test_unistd.rs3
3 files changed, 26 insertions, 0 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 7dd7a4b9..f9e6e4d5 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -36,6 +36,8 @@ This project adheres to [Semantic Versioning](http://semver.org/).
([#952](https://github.com/nix-rust/nix/pull/952))
- Added the `time_t` and `suseconds_t` public aliases within `sys::time`.
([#968](https://github.com/nix-rust/nix/pull/968))
+- Added `unistd::execvpe` for Haiku, Linux and OpenBSD
+ ([#975](https://github.com/nix-rust/nix/pull/975))
### Changed
- Increased required Rust version to 1.24.1
diff --git a/src/unistd.rs b/src/unistd.rs
index aadd3c6b..12f3566a 100644
--- a/src/unistd.rs
+++ b/src/unistd.rs
@@ -701,6 +701,27 @@ pub fn execvp(filename: &CString, args: &[CString]) -> Result<Void> {
Err(Error::Sys(Errno::last()))
}
+/// Replace the current process image with a new one and replicate shell `PATH`
+/// searching behavior (see
+/// [`execvpe(3)`](http://man7.org/linux/man-pages/man3/exec.3.html)).
+///
+/// This functions like a combination of `execvp(2)` and `execve(2)` to pass an
+/// environment and have a search path. See these two for additional
+/// information.
+#[cfg(any(target_os = "haiku",
+ target_os = "linux",
+ target_os = "openbsd"))]
+pub fn execvpe(filename: &CString, args: &[CString], env: &[CString]) -> Result<Void> {
+ let args_p = to_exec_array(args);
+ let env_p = to_exec_array(env);
+
+ unsafe {
+ libc::execvpe(filename.as_ptr(), args_p.as_ptr(), env_p.as_ptr())
+ };
+
+ Err(Error::Sys(Errno::last()))
+}
+
/// Replace the current process image with a new one (see
/// [fexecve(2)](http://pubs.opengroup.org/onlinepubs/9699919799/functions/fexecve.html)).
///
diff --git a/test/test_unistd.rs b/test/test_unistd.rs
index 52eb365c..b03e8853 100644
--- a/test/test_unistd.rs
+++ b/test/test_unistd.rs
@@ -243,6 +243,9 @@ cfg_if!{
}
}
+#[cfg(any(target_os = "haiku", target_os = "linux", target_os = "openbsd"))]
+execve_test_factory!(test_execvpe, execvpe, &CString::new("sh").unwrap());
+
cfg_if!{
if #[cfg(target_os = "android")] {
use nix::fcntl::AtFlags;