pub struct CommandBuilder { /* private fields */ }
Expand description

CommandBuilder is used to prepare a command to be spawned into a pty. The interface is intentionally similar to that of std::process::Command.

Implementations§

source§

impl CommandBuilder

source

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

Create a new builder instance with argv[0] set to the specified program.

source

pub fn from_argv(args: Vec<OsString>) -> Self

Create a new builder instance from a pre-built argument vector

source

pub fn set_controlling_tty(&mut self, controlling_tty: bool)

Set whether we should set the pty as the controlling terminal. The default is true, which is usually what you want, but you may need to set this to false if you are crossing container boundaries (eg: flatpak) to workaround issues like: https://github.com/flatpak/flatpak/issues/3697 https://github.com/flatpak/flatpak/issues/3285

source

pub fn get_controlling_tty(&self) -> bool

source

pub fn new_default_prog() -> Self

Create a new builder instance that will run some idea of a default program. Such a builder will panic if arg is called on it.

source

pub fn is_default_prog(&self) -> bool

Returns true if this builder was created via new_default_prog

source

pub fn arg<S: AsRef<OsStr>>(&mut self, arg: S)

Append an argument to the current command line. Will panic if called on a builder created via new_default_prog.

source

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

Append a sequence of arguments to the current command line

source

pub fn get_argv(&self) -> &Vec<OsString>

source

pub fn get_argv_mut(&mut self) -> &mut Vec<OsString>

source

pub fn env<K, V>(&mut self, key: K, value: V)where K: AsRef<OsStr>, V: AsRef<OsStr>,

Override the value of an environmental variable

source

pub fn env_remove<K>(&mut self, key: K)where K: AsRef<OsStr>,

source

pub fn env_clear(&mut self)

source

pub fn get_env<K>(&self, key: K) -> Option<&OsStr>where K: AsRef<OsStr>,

source

pub fn cwd<D>(&mut self, dir: D)where D: AsRef<OsStr>,

source

pub fn clear_cwd(&mut self)

source

pub fn get_cwd(&self) -> Option<&OsString>

source

pub fn iter_extra_env_as_str(&self) -> impl Iterator<Item = (&str, &str)>

Iterate over the configured environment. Only includes environment variables set by the caller via env, not variables set in the base environment.

source

pub fn iter_full_env_as_str(&self) -> impl Iterator<Item = (&str, &str)>

source

pub fn as_unix_command_line(&self) -> Result<String>

Return the configured command and arguments as a single string, quoted per the unix shell conventions.

source§

impl CommandBuilder

source

pub fn umask(&mut self, mask: Option<mode_t>)

source

pub fn get_shell(&self) -> String

Determine which shell to run. We take the contents of the $SHELL env var first, then fall back to looking it up from the password database.

Trait Implementations§

source§

impl Clone for CommandBuilder

source§

fn clone(&self) -> CommandBuilder

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for CommandBuilder

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl PartialEq<CommandBuilder> for CommandBuilder

source§

fn eq(&self, other: &CommandBuilder) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl StructuralPartialEq for CommandBuilder

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> Downcast for Twhere T: Any,

source§

fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>

Convert 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 + 'static>

Convert 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)

Convert &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)

Convert &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 Twhere T: Any + Send + Sync,

source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync + 'static>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.