1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
use std::{io::Error, os::unix::process::CommandExt, process::Command};
use crate::{builder::CommandGroupBuilder, GroupChild};
use nix::unistd::setsid;
impl CommandGroupBuilder<'_, Command> {
/// Executes the command as a child process group, returning a handle to it.
///
/// By default, stdin, stdout and stderr are inherited from the parent.
///
/// On Windows, this creates a job object instead of a POSIX process group.
///
/// # Examples
///
/// Basic usage:
///
/// ```no_run
/// use std::process::Command;
/// use command_group::CommandGroup;
///
/// Command::new("ls")
/// .group()
/// .spawn()
/// .expect("ls command failed to start");
/// ```
pub fn spawn(&mut self) -> std::io::Result<GroupChild> {
unsafe {
self.command
.pre_exec(|| setsid().map_err(Error::from).map(|_| ()));
}
self.command.spawn().map(GroupChild::new)
}
}