source | all docs for version 0.10.1 | all versions | oilshell.org
This documents describes parts of the Oil language that may be surprising.
All languages have warts, but most of them don't document them for you!  Even a
nice language like Python has surprising cases like 42, and f(x), being a
1-tuple (because of the trailing comma).
Oil's goal is to remove the many warts of shell, documented at Shell WTFs. Nonetheless it has some of its own.
The $'line\n' syntax is confusing because of the $ character.
${var} interpolation.${var} or $(hostname).It's also not consistent with raw strings like r'foo', while c'foo' would
be.
If we were starting from scratch, I would have chosen a different prefix, but it isn't worth the breakage and complexity. All string literals exist in both command and expression mode, which is tricky to implement.
You can do
echo $f(x)
but not
echo "_ $f(x) _"   # means the variable $f and then literals '(x)' !
Instead you have to use an expression sub:
echo "_ $[f(x)] _"
You can also factor it out:
var s = f(x)
echo "_ $s _"
To disambiguate the cases, use explicit braces:
echo "_ ${f}(x) _"  # variable f
echo "_ $[f(x)] _"  # function call f
Block and Expr LiteralsBlocks look different in command vs expression mode:
cd /tmp {                   # command mode { }
  echo $PWD
}
var myblock = ^(echo $PWD)  # expression mode, lazy ^( )
So do expressions:
myproc | where (age > 10)   # command mode, lazy ( )
var myval = age > 10        # expression mode
var myexpr = ^[age > 10]    # expression mode, lazy ^[ ]
It would have been nicer if they were consistent, but shell is already
inconsistent with $(echo hi) and { echo hi; }.
There is consistency in other directions:
^(echo $PWD) is consistent with shell's eagerly evaluated $(echo $PWD).^[42 + f(x)] is consistent with expression sub $[42 + f(x)].Most users won't see these literal forms very much. They're more useful for testing and frameworks rather than simple scripts/applications.
read :x, The Colon is a "Pseudo-Sigil"Sigils like $ and @ are statically
parsed, but the optional : is
dynamically parsed by every builtin that supports it.
This is a minor inconsistency, but I like having a symbol for a variable to be mutated.