Struct Command

Source
pub struct Command { /* private fields */ }
Available on crate feature async only.
Expand description

Wrapper around tokio::process::Command

Implementations§

Source§

impl Command

Source

pub fn new<S: AsRef<OsStr>>(program: S) -> Self

Source

pub fn arg<S: AsRef<OsStr>>(self, arg: S) -> Self

Source

pub fn args<I, S>(self, args: I) -> Self
where I: IntoIterator<Item = S>, S: AsRef<OsStr>,

Source

pub fn env<K, V>(self, key: K, val: V) -> Self
where K: AsRef<OsStr>, V: AsRef<OsStr>,

Source

pub fn envs<I, K, V>(self, vars: I) -> Self
where I: IntoIterator<Item = (K, V)>, K: AsRef<OsStr>, V: AsRef<OsStr>,

Source

pub fn env_remove<K: AsRef<OsStr>>(self, key: K) -> Self

Source

pub fn env_clear(self) -> Self

Source

pub fn current_dir<P: AsRef<Path>>(self, dir: P) -> Self

Source

pub fn kill_on_drop(self, kill_on_drop: bool) -> Self

Source

pub fn stdin<T: Into<Stdio>>(self, cfg: T) -> Self

Source

pub fn stdout<T: Into<Stdio>>(self, cfg: T) -> Self

Source

pub fn stderr<T: Into<Stdio>>(self, cfg: T) -> Self

Source

pub fn spawn(self, pts: Pts) -> Result<Child>

Executes the command as a child process via tokio::process::Command::spawn on the given pty. The pty will be attached to all of stdin, stdout, and stderr of the child, unless those file descriptors were previously overridden through calls to stdin, stdout, or stderr. The newly created child process will also be made the session leader of a new session, and will have the given pty set as its controlling terminal.

§Errors

Returns an error if we fail to allocate new file descriptors for attaching the pty to the child process, or if we fail to spawn the child process (see the documentation for tokio::process::Command::spawn), or if we fail to make the child a session leader or set its controlling terminal.

Source

pub fn spawn_borrowed(&mut self, pts: &Pts) -> Result<Child>

Available on non-macOS only.

Executes the command as a child process via tokio::process::Command::spawn on the given pty. The pty will be attached to all of stdin, stdout, and stderr of the child, unless those file descriptors were previously overridden through calls to stdin, stdout, or stderr. The newly created child process will also be made the session leader of a new session, and will have the given pty set as its controlling terminal.

Differs from spawn in that it borrows the pty rather than consuming it, allowing for multiple commands to be spawned onto the same pty in sequence, but this functionality is not available on macos.

§Errors

Returns an error if we fail to allocate new file descriptors for attaching the pty to the child process, or if we fail to spawn the child process (see the documentation for tokio::process::Command::spawn), or if we fail to make the child a session leader or set its controlling terminal.

Source

pub fn uid(self, id: u32) -> Self

Source

pub fn gid(self, id: u32) -> Self

Source

pub unsafe fn pre_exec<F>(self, f: F) -> Self
where F: FnMut() -> Result<()> + Send + Sync + 'static,

Source

pub fn arg0<S>(self, arg: S) -> Self
where S: AsRef<OsStr>,

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.