set
ARES System Manual: exec Shell
(input)
(input)
(input)
(input)
(input)
(input)
(input)
(input)
Sets a shell environment variable to the specified value. Variable names should start with letters. They are case-sensitive. They may contain underscores, hyphens, and numbers.
The special value
The value
The
The
The
The
To use an environment variable, type
To remove variables you no longer need, use
Variable substitutions may be used in any exec invocation, i.e. commands that can be called with
Environment variables are stored in the
Environment variables may be set to the output from running a system command by using the bundled program xset.
Shell built-in command: This command is part of the exec shell and does not have a corresponding system binary. It must be used shell scripts without a preceding
To use this command with
(input)
@set <variable> <string>
(input)
@set <variable> %key
(input)
@set <variable> %keys <JSON>
(input)
@set <variable> %undefined
(input)
@set <variable> %count lines|chars|words|keys in <string>
(input)
@set <variable> %line|%char|%word <index> in <string>
(input)
@set <variable> %index <key> of <JSON>
(input)
@set <variable> = <expression>
Sets a shell environment variable to the specified value. Variable names should start with letters. They are case-sensitive. They may contain underscores, hyphens, and numbers.
The special value
%key
can be used to set a variable to a new randomly-generated UUID.
The value
%undefined
can be used to remove a variable.
The
%count
syntax counts the number of lines, characters, or words in a string, or keys in a JSON object. For example, set n %count chars in ARES
sets the environment variable n
to 4
.
The
%line
, %char
, and %word
syntaxes extract individual parts from a string. For example, set w %word 3 in One, Two, Three, Four!
sets w
to Four!
(Indexes start at 0.)
The
%keys
syntax (not to be confused with %key
) will return a space-separated list of keys in the JSON object <JSON>, which can then be iterated over with %word
and %count words
.
The
%index
syntax will extract part of a JSON object. It supports .
notation for nested objects (but not JSON arrays). For example, set fruit %index alpha in {"alpha":"apple","beta":"banana"}
will yield 'apple'.
To use an environment variable, type
$
and the variable name. For example, @set x = $x + 1
will modify the variable x
by adding 1 to its current value.
To remove variables you no longer need, use
set <name> %undefined
. It is good practice to clean up after yourself at the end of a script that uses temporary environment variables.
Variable substitutions may be used in any exec invocation, i.e. commands that can be called with
@
from input.
Environment variables are stored in the
env
section of the database and can be reviewed with @db show env
.
Environment variables may be set to the output from running a system command by using the bundled program xset.
Shell built-in command: This command is part of the exec shell and does not have a corresponding system binary. It must be used shell scripts without a preceding
@
and cannot be called directly with the system invoke()
API.
To use this command with
invoke()
, use the syntax exec set <variable> <value>
or manipulate the env
database section directly with setdbl("env", [<variable>], <value>)
.