pub struct ContainedProcessGroup { /* private fields */ }Expand description
A logical group of spawned processes that share an originator label.
Each ContainedProcessGroup::spawn call builds its own OS-level
containment (Job Object on Windows, process-group on Unix), so the
group itself is just metadata.
Implementations§
Source§impl ContainedProcessGroup
impl ContainedProcessGroup
Sourcepub fn with_originator(originator: &str) -> Result<Self, Error>
pub fn with_originator(originator: &str) -> Result<Self, Error>
Create a new process group with an originator name.
Sourcepub fn originator(&self) -> Option<&str>
pub fn originator(&self) -> Option<&str>
Returns the originator name, if set.
Sourcepub fn originator_value(&self) -> Option<String>
pub fn originator_value(&self) -> Option<String>
Returns the full originator env var value (TOOL:PID), if set.
Sourcepub fn spawn(
&self,
command: &mut Command,
stdio: SpawnStdio<'_>,
) -> Result<SpawnedChild, Error>
pub fn spawn( &self, command: &mut Command, stdio: SpawnStdio<'_>, ) -> Result<SpawnedChild, Error>
Spawn a contained child process. The child is contained by its own
Job Object on Windows / process group on Unix and is killed when
the returned SpawnedChild is dropped.
Sourcepub fn spawn_daemon(&self, command: &mut Command) -> Result<DaemonChild, Error>
pub fn spawn_daemon(&self, command: &mut Command) -> Result<DaemonChild, Error>
Spawn a detached daemon child. The child has NUL stdio, a sanitized
handle list, and survives the returned DaemonChild being
dropped. To terminate, call DaemonChild::kill.
The parent-child association (this group’s originator env var) is injected into the child before the spawn so cross-process tracking can resolve the spawned daemon back to its parent.
Auto Trait Implementations§
impl Freeze for ContainedProcessGroup
impl RefUnwindSafe for ContainedProcessGroup
impl Send for ContainedProcessGroup
impl Sync for ContainedProcessGroup
impl Unpin for ContainedProcessGroup
impl UnsafeUnpin for ContainedProcessGroup
impl UnwindSafe for ContainedProcessGroup
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more