command_group/tokio/windows.rs
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 35 36 37 38 39 40 41
use tokio::process::Command;
use winapi::um::winbase::CREATE_SUSPENDED;
use crate::{builder::CommandGroupBuilder, winres::*, AsyncGroupChild};
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 tokio::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<AsyncGroupChild> {
let (job, completion_port) = job_object(self.kill_on_drop)?;
self.command
.creation_flags(self.creation_flags | CREATE_SUSPENDED);
let child = self.command.spawn()?;
assign_child(
child
.raw_handle()
.expect("child has exited but it has not even started"),
job,
)?;
Ok(AsyncGroupChild::new(child, job, completion_port))
}
}