Why Sponsor Oils? | source | all docs for version 0.24.0 | all versions | oilshell.org
Oils Reference — Chapter Word Language
This chapter describes the word language for OSH and YSH. Words evaluate to strings, or arrays of strings.
(in progress)
Try to turn an expression into a string. Examples:
$ echo $[3 * 2]
6
$ var s = 'foo'
$ echo $[s[1:]]
oo
Some types can't be stringified, like Dict and List:
$ var d = {k: 42}
$ echo $[d]
fatal: expected Null, Bool, Int, Float, Eggex
You can explicitly use toJson8
or toJson()
:
$ echo $[toJson8(d)]
{"k":42}
(This is similar to json write (d)
)
Splicing puts the elements of a List
into a string array context:
$ var foods = ['ale', 'bean', 'corn']
$ echo pizza @[foods[1:]] worm
pizza bean corn worm
This syntax is enabled by shopt --set
parse_at, which is part of YSH.
$ var foods = ['ale', 'bean', 'corn']
echo @foods
This syntax is enabled by shopt --set
parse_at, which is part of YSH.
Not done.
echo ${x %.3f}
Not done.
echo ${x|html}
$'\n'
TODO: elaborate
YSH strings in the word language are the same as in the expression language.
See ysh-string in chap-expr-lang.
Triple-quoted in the word language are the same as in the expression language.
See triple-quoted in chap-expr-lang.
Not done.
Executes a command and captures its stdout.
OSH has shell-compatible command sub like $(echo hi)
. If a trailing newline
is returned, it's removed:
$ hostname
example.com
$ echo "/tmp/$(hostname)"
/tmp/example.com
YSH has spliced command subs, enabled by shopt --set parse_at
. The result is
a List of strings, rather than a single string.
$ write -- @(echo foo; echo 'with spaces')
foo
with-spaces
The command's stdout parsed as the "J8 Lines" format, where each line is either:
""
or J8-style b'' u'' ''
)See J8 Notation for more details.
Evaluates to the value of a variable:
$ x=X
$ echo $x ${x}
X X
Shell has C-style arithmetic:
$ echo $(( 1 + 2*3 ))
7
Used as a shortcut for a user's home directory:
~/src # my home dir
~bob/src # user bob's home dir
Open stdout as a named file in /dev/fd
, which can be passed to a command:
diff <(sort L.txt) <(sort R.txt)
Open stdin as a named file in /dev/fd
:
seq 3 | tee >(sleep 1; tac)
Shell has boolean operations within ${}
. I use :-
most frequently:
x=${1:-default}
osh=${OSH:-default}
This idiom is also useful:
: ${LIB_OSH=stdlib/osh}
Remove prefixes or suffixes from strings:
echo ${y#prefix}
echo ${y##'prefix'}
echo ${y%suffix}
echo ${y%%'suffix'}
The prefix and suffix can be glob patterns, but this usage is discouraged because it may be slow.
Replace a substring or pattern.
The character after the first /
can be /
to replace all occurrences:
$ x=food
$ echo ${x//o/--} # replace 1 o with 2 --
f----d
It can be #
or %
for an anchored replacement:
$ echo ${x/#f/--} # left anchored f
--ood
$ echo ${x/%d/--} # right anchored d
foo--
The pattern can also be a glob:
$ echo ${x//[a-z]/o} # replace 1 char with o
oooo
$ echo ${x//[a-z]+/o} # replace multiple chars
o
echo ${a[i+1]}
echo ${a[@]:1:2}
echo ${@:1:2}
${x@P} evaluates x as a prompt string, i.e. the string that would be printed if PS1=$x.
${x@Q}
quotes the value of x
, if necessary, so that it can be evaluated as
a shell word.
$ x='<'
$ echo "value = $x, quoted = ${x@Q}."
value = <, quoted = '<'.
$ x=a
$ echo "value = $x, quoted = ${x@Q}."
value = a, quoted = a.
In the second case, the string a
doesn't need to be quoted.
Format operations like @Q
generally treat empty variables differently
than unset variables.
That is, ${empty@Q}
is the string ''
, while ${unset@Q}
is an empty
string:
$ x=''
$ echo "value = $x, quoted = ${x@Q}."
value = , quoted = ''.
$ unset -v x
$ echo "value = $x, quoted = ${x@Q}."
value = , quoted = .