Cmd

Cmd

Represents a command to be executed in a child process.

Output

Represents the output of a command.

new : Str -> Cmd

Create a new command to execute the given program in a child process.

arg : Cmd, Str -> Cmd

Add a single argument to the command. ! Shell features like variable subsitition (e.g. $FOO), glob patterns (e.g. *.txt), ... are not available.

# Represent the command "ls -l"
Cmd.new "ls"
|> Cmd.arg "-l"

args : Cmd, List Str -> Cmd

Add multiple arguments to the command. ! Shell features like variable subsitition (e.g. $FOO), glob patterns (e.g. *.txt), ... are not available.

# Represent the command "ls -l -a"
Cmd.new "ls"
|> Cmd.args ["-l", "-a"]

env : Cmd, Str, Str -> Cmd

Add a single environment variable to the command.

# Run "env" and add the environment variable "FOO" with value "BAR"
Cmd.new "env"
|> Cmd.env "FOO" "BAR"

envs : Cmd, List ( Str, Str ) -> Cmd

Add multiple environment variables to the command.

# Run "env" and add the variables "FOO" and "BAZ"
Cmd.new "env"
|> Cmd.envs [("FOO", "BAR"), ("BAZ", "DUCK")]

clear_envs : Cmd -> Cmd

Clear all environment variables, and prevent inheriting from parent, only the environment variables provided to command are available to the child.

# Represents "env" with only "FOO" environment variable set
Cmd.new "env"
|> Cmd.clear_envs
|> Cmd.env "FOO" "BAR"

output! : Cmd => Output

Execute command and capture stdout and stderr

Stdin is not inherited from the parent and any attempt by the child process to read from the stdin stream will result in the stream immediately closing.

status! : Cmd => Result I32 [CmdStatusErr InternalIOErr.IOErr]

Execute command and inherit stdin, stdout and stderr from parent

exec! : Str, List Str => Result {} [CmdStatusErr InternalIOErr.IOErr]

Execute command and inherit stdin, stdout and stderr from parent

# Call echo to print "hello world"
Cmd.exec! "echo" ["hello world"]