CommandBuilder

Struct CommandBuilder 

pub struct CommandBuilder { /* private fields */ }
Available on crate feature terminal only.
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§

§

impl CommandBuilder

pub fn new<S>(program: S) -> CommandBuilder
where S: AsRef<OsStr>,

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

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

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

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

pub fn get_controlling_tty(&self) -> bool

pub fn new_default_prog() -> CommandBuilder

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.

pub fn is_default_prog(&self) -> bool

Returns true if this builder was created via new_default_prog

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

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

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

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

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

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

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

pub fn env_clear(&mut self)

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

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

pub fn clear_cwd(&mut self)

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

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.

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

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

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

§

impl CommandBuilder

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

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§

§

impl Clone for CommandBuilder

§

fn clone(&self) -> CommandBuilder

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
§

impl Debug for CommandBuilder

§

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

Formats the value using the given formatter. Read more
§

impl PartialEq for CommandBuilder

§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

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

impl StructuralPartialEq for CommandBuilder

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
§

impl<T> AnyEq for T
where T: Any + PartialEq,

§

fn equals(&self, other: &(dyn Any + 'static)) -> bool

§

fn as_any(&self) -> &(dyn Any + 'static)

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> ComponentProps for T
where T: Any + PartialEq,

Source§

fn changed(&self, other: &(dyn ComponentProps + 'static)) -> bool

§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

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.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

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

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.
§

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.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

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

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

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 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.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
Source§

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

Source§

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