~ Home Sigil
 ~ Home Sigil
Home directory path variable
Description
The tilde token is used as a convenience shortcut to users home directory.
By itself, ~ will point to the current users home directory.
If a username follows, eg ~joe.bloggs, then the home directory for that user is returned irrespective of who is presently logged in. Characters supported by tilde usernames are alpha upper and lower case, numeric, underscore, full stop (period), and hyphens.
Examples
Current user
Assuming current username is "bob":
» out ~
/home/bob
Alternative user
Assuming "joe" is a valid user on local system:
» out ~joe
/home/joe
Unhappy path
If username does not exist, ~ will default to the root path.
Assuming "foobar" isn't a valid local user:
» out ~foobar
/
Detail
Infixing
Tilde can be expanded inside double quotes, brace quotes as well as used naked. But it cannot be expanded inside single quotes.
» out ~
/home/bob
» out '~'
~
» out "~"
/home/bob
» out %(~)
/home/bob
Error Handling
If a username is supplied that that user doesn't exist, the tilde will raise an error. For example:
» ~joe.bloggs
Error in `expr` (0,1): cannot expand variable `~joe.bloggs`: user: unknown user joe.bloggs
See Also
- Create JSON Array: ja: A sophisticated yet simply way to build a JSON array
- Define Variable: set: Define a variable (typically local) and set it's value
- Output String, stdout: out: Print a string to the stdout with a trailing new line character
- Reserved Variables: Special variables reserved by Murex
- "Double Quote": Initiates or terminates a string (variables expanded)
- %(Brace Quote): Initiates or terminates a string (variables expanded)
- 'Single Quote': Initiates or terminates a string (variables not expanded)
- (brace quote): Write a string to the stdout without new line (deprecated)
- @ArraySigil: Expand values as an array
- HOME(path): Return the home directory for the current session user
- string(stringing): string (primitive)
This document was generated from gen/parser/variables_doc.yaml.