2016-10-30 19:15:35 -07:00
|
|
|
justfile grammar
|
2016-10-30 19:16:33 -07:00
|
|
|
================
|
2016-10-30 19:15:35 -07:00
|
|
|
|
2016-10-30 19:40:11 -07:00
|
|
|
Justfiles are processed by a mildly context-sensitive tokenizer
|
2016-10-30 19:17:09 -07:00
|
|
|
and a recursive descent parser. The grammar is mostly LL(1),
|
|
|
|
although an extra token of lookahead is used to distinguish between
|
2016-10-30 19:15:35 -07:00
|
|
|
export assignments and recipes with arguments.
|
|
|
|
|
|
|
|
tokens
|
2016-10-30 19:16:33 -07:00
|
|
|
------
|
2016-10-30 19:15:35 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
BACKTICK = `[^`\n\r]*`
|
|
|
|
COLON = :
|
|
|
|
COMMENT = #([^!].*)?$
|
|
|
|
EOL = \n|\r\n
|
|
|
|
EQUALS = =
|
|
|
|
INTERPOLATION_START = {{
|
|
|
|
INTERPOLATION_END = }}
|
|
|
|
NAME = [a-zA-Z_-][a-zA-Z0-9_-]*
|
|
|
|
PLUS = +
|
|
|
|
RAW_STRING = '[^'\r\n]*'
|
|
|
|
STRING = "[^"]*" # also processes \n \r \t \" \\ escapes
|
|
|
|
INDENT = emitted when indentation increases
|
|
|
|
DEDENT = emitted when indentation decreases
|
|
|
|
LINE = emitted before a recipe line
|
|
|
|
TEXT = recipe text, only matches in a recipe body
|
|
|
|
```
|
|
|
|
|
|
|
|
grammar
|
2016-10-30 19:16:33 -07:00
|
|
|
-------
|
2016-10-30 19:15:35 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
justfile : item* EOF
|
|
|
|
|
|
|
|
item : recipe
|
|
|
|
| assignment
|
|
|
|
| export
|
|
|
|
| EOL
|
|
|
|
|
2016-10-30 19:17:59 -07:00
|
|
|
assignment : NAME '=' expression EOL
|
2016-10-30 19:15:35 -07:00
|
|
|
|
|
|
|
export : 'export' assignment
|
|
|
|
|
|
|
|
expression : STRING
|
|
|
|
| RAW_STRING
|
|
|
|
| NAME
|
2016-11-11 23:11:10 -08:00
|
|
|
| BACKTICK
|
2016-10-30 19:15:35 -07:00
|
|
|
| expression '+' expression
|
|
|
|
|
|
|
|
recipe : NAME arguments? ':' dependencies? body?
|
|
|
|
|
|
|
|
arguments : NAME+
|
|
|
|
|
|
|
|
dependencies : NAME+
|
|
|
|
|
|
|
|
body : INDENT line+ DEDENT
|
|
|
|
|
|
|
|
line : LINE (TEXT | interpolation)+ EOL
|
|
|
|
|
|
|
|
interpolation : '{{' expression '}}'
|
|
|
|
```
|