Skip to main content

CommandFlow

Struct CommandFlow 

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

๐Ÿ–ฅ๏ธ โฌก An executable flow of OS process invocations.


๐Ÿ“ work/process


A CommandFlow represents one or more Commands executed as a single unit. In the current implementation, commands are arranged linearly, connecting the stdout of each command to the stdin of the next.

Command flows are constructed programmatically (for example via cmd!) and do not involve a shell. As a result:

  • No globbing, quoting, or redirection is performed.
  • Each command is spawned directly via the OS process API.

Execution is eager: all commands in the flow are spawned before waiting for completion.

See also the cmd! macro for a compact construction syntax.

Implementationsยง

Sourceยง

impl CommandFlow

Source

pub fn new(cmd: Command) -> Self

Creates a new flow with a single command.

This is equivalent to a flow of length 1, with no piping.

Source

pub fn command_shell(line: &str) -> Result<Self, ShellWordError> โ“˜

Available on crate feature shell only.

Creates a one-command flow from shell-like command words.

Source

pub fn then(self, next: Command) -> Self

Appends a command to the flow, piping the previous command into it.

The stdout of the current command is connected to the stdin of next using an OS pipe.

This consumes the flow and returns an extended one, allowing chaining.

ยงPanics

Panics if the flow is empty. This invariant is upheld by construction.

Source

pub fn run(self) -> IoResult<ExitStatus>

Runs the flow and waits for all commands to complete.

All commands are spawned first. The method then waits for each process, returning the exit status of the last command in the flow.

Standard input, output, and error streams are inherited unless modified earlier (for example by piping or capture methods).

ยงErrors

Returns an I/O error if any command fails to spawn or wait.

Source

pub fn stdout(self) -> IoResult<Output>

Runs the flow and captures the standard output of the last command.

The stdout of the final command is redirected into a pipe and fully collected into a byte buffer.

All commands are spawned before any output is read. The method waits for all commands to complete and returns an Output containing the exit status and captured stdout. The stderr field is empty.

ยงNotes
  • Output is buffered in memory.
  • Stderr is not captured.
ยงErrors

Returns an I/O error if spawning, piping, reading, or waiting fails.

Source

pub fn output(self) -> IoResult<Output>

Runs the flow and captures both stdout and stderr of the last command.

The stdout and stderr streams of the final command are merged into a single byte stream, equivalent to:

... | cmd 2>&1
ยงNotes
  • The relative ordering of stdout and stderr bytes is unspecified.
  • Output is buffered in memory.

Returns an Output containing the exit status and merged stdout/stderr. The merged output is stored in Output.stdout; stderr is empty.

ยงErrors

Returns an I/O error if spawning, piping, reading, or waiting fails.

Source

pub fn stdout_with<F>(self, f: F) -> IoResult<ExitStatus>
where F: FnMut(&[u8]),

Runs the flow and streams the stdout of the last command to a callback.

The provided function f is invoked incrementally with chunks of bytes as they become available from the final commandโ€™s standard output.

This enables streaming consumption without buffering the full output in memory.

ยงExecution model
  • All commands are spawned eagerly.
  • Bytes are read from the pipe in a loop.
  • The callback is invoked on the reader thread.
ยงNotes
  • Only stdout of the last command is streamed.
  • Stderr is inherited.

Returns the exit status of the last command.

ยงErrors

Returns an I/O error if spawning, piping, reading, or waiting fails.

Trait Implementationsยง

Sourceยง

impl Debug for CommandFlow

Sourceยง

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

Formats the value using the given formatter. Read more

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> AnyExt for T
where T: Any + ?Sized,

Sourceยง

fn type_id() -> TypeId

Returns the TypeId of Self. Read more
Sourceยง

fn type_of(&self) -> TypeId

Returns the TypeId of self. Read more
Sourceยง

fn type_name(&self) -> &'static str โ“˜

Returns the type name of self. Read more
Sourceยง

fn type_is<T: 'static>(&self) -> bool

Returns true if Self is of type T. Read more
Sourceยง

fn type_hash(&self) -> u64

Returns a deterministic hash of the TypeId of Self.
Sourceยง

fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64

Returns a deterministic hash of the TypeId of Self using a custom hasher.
Sourceยง

fn as_any_ref(&self) -> &dyn Any
where Self: Sized,

Upcasts &self as &dyn Any. Read more
Sourceยง

fn as_any_mut(&mut self) -> &mut dyn Any
where Self: Sized,

Upcasts &mut self as &mut dyn Any. Read more
Sourceยง

fn as_any_box(self: Box<Self>) -> Box<dyn Any>
where Self: Sized,

Available on crate feature alloc only.
Upcasts Box<self> as Box<dyn Any>. Read more
Sourceยง

fn downcast_ref<T: 'static>(&self) -> Option<&T> โ“˜

Available on crate feature unsafe_layout and non-crate feature safe_code only.
Returns some shared reference to the inner value if it is of type T. Read more
Sourceยง

fn downcast_mut<T: 'static>(&mut self) -> Option<&mut T> โ“˜

Available on crate feature unsafe_layout and non-crate feature safe_code only.
Returns some exclusive reference to the inner value if it is of type T. 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> ByteSized for T

Sourceยง

const BYTE_ALIGN: usize = _

The alignment of this type in bytes.
Sourceยง

const BYTE_SIZE: usize = _

The size of this type in bytes.
Sourceยง

fn byte_align(&self) -> usize

Returns the alignment of this type in bytes.
Sourceยง

fn byte_size(&self) -> usize

Returns the size of this type in bytes. Read more
Sourceยง

fn ptr_size_ratio(&self) -> [usize; 2]

Returns the size ratio between Ptr::BYTES and BYTE_SIZE. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

Sourceยง

impl<T> Hook for T

Sourceยง

fn hook<F>(self, f: F) -> Self
where F: FnOnce(&mut Self),

Hooks a mutation step into the value and returns it. Read more
Sourceยง

fn tap<F>(self, f: F) -> Self
where F: FnOnce(&Self),

Taps into the value for observation and returns it unchanged. 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> MemExt for T
where T: ?Sized,

Sourceยง

const NEEDS_DROP: bool = _

Know whether dropping values of this type matters, in compile-time.
Sourceยง

fn mem_align_of<T>() -> usize

Returns the minimum alignment of the type in bytes. Read more
Sourceยง

fn mem_align_of_val(&self) -> usize

Returns the alignment of the pointed-to value in bytes. Read more
Sourceยง

fn mem_size_of<T>() -> usize

Returns the size of a type in bytes. Read more
Sourceยง

fn mem_size_of_val(&self) -> usize

Returns the size of the pointed-to value in bytes. Read more
Sourceยง

fn mem_copy(&self) -> Self
where Self: Copy,

Bitwise-copies a value. Read more
Sourceยง

fn mem_needs_drop(&self) -> bool

Returns true if dropping values of this type matters. Read more
Sourceยง

fn mem_drop(self)
where Self: Sized,

Drops self by running its destructor. Read more
Sourceยง

fn mem_forget(self)
where Self: Sized,

Forgets about self without running its destructor. Read more
Sourceยง

fn mem_replace(&mut self, other: Self) -> Self
where Self: Sized,

Replaces self with other, returning the previous value of self. Read more
Sourceยง

fn mem_take(&mut self) -> Self
where Self: Default,

Replaces self with its default value, returning the previous value of self. Read more
Sourceยง

fn mem_swap(&mut self, other: &mut Self)
where Self: Sized,

Swaps the value of self and other without deinitializing either one. Read more
Sourceยง

unsafe fn mem_zeroed<T>() -> T

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

fn mem_as_bytes(&self) -> &[u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &[u8]. Read more
Sourceยง

fn mem_as_bytes_mut(&mut self) -> &mut [u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &mut [u8]. Read more
Sourceยง

impl<T, R> Morph<R> for T
where T: ?Sized,

Sourceยง

fn morph<F>(self, f: F) -> R
where F: FnOnce(Self) -> R, Self: Sized,

Morphs the value into a new one and returns it. Read more
Sourceยง

fn morph_ref<F>(&self, f: F) -> R
where F: FnOnce(&Self) -> R,

Morphs the value by shared reference and returns the result. Read more
Sourceยง

fn morph_mut<F>(&mut self, f: F) -> R
where F: FnOnce(&mut Self) -> R,

Morphs the value by exclusive reference and returns the result. 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.