-
Notifications
You must be signed in to change notification settings - Fork 4
/
grammar.txt
92 lines (60 loc) · 2.33 KB
/
grammar.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
# grammar for lox
# --- main entry ---
program = declaration* EOF ;
# --- declarations ---
declaration = classDecl
| funDecl
| varDecl
| statement ;
classDecl = "class" INDENTIFIER ( "<" IDENTIFIER )?
"{" function* "}" ;
funDecl = "fun" function ;
varDecl = "var" IDENTIFIER ( "=" expression )? ";" ;
# --- statements ---
statement = exprStmt
| forStmt
| ifStmt
| printStmt
| returnStmt
| whileStmt
| block ;
exprStmt = expression ";" ;
forStmt = "for" "(" ( varDecl | exprStmt | ";" )
expression? ";"
expression? ")" statement ;
ifStmt = "if" "(" expression ")" statement ( "else" statement )? ;
printStmt = "print" expression ";" ;
returnStmt = "return" expression? ";" ;
whileStmt = "while" "(" expression ")" statement ;
block = "{" declaration* "}" ;
# --- expressions ---
expression = assignment ;
assignment = ( call "." )? IDENTIFIER "=" assignment
| logic_or ;
logic_or = logic_and ( "or" logic_and )* ;
logic_and = equality ( "and" equality )* ;
equality = comparison ( ( "!=" | "==" ) comparison )* ;
comparison = addition ( ( ">" | ">=" | "<" | "<=" ) addition )* ;
addition = multiplication ( ( "-" | "+" ) multiplication )* ;
multiplication = unary ( ( "/" | "*" ) unary )* ;
unary = ( "!" | "-" ) unary | call;
call = primary ( "(" arguments? ")" | "." IDENTIFIER )* ;
primary = "true"
| "false"
| "nil"
| "this"
| NUMBER
| STRING
| IDENTIFIER
| "(" expression ")"
| "super" "." IDENTIFIER ;
# --- utility rules ---
function = IDENTIFIER "(" parameters? ")" block ;
parameters = IDENTIFIER ( "," IDENTIFIER )* ;
arguments = expression ( "," expression )* ;
# --- lexical grammar ---
NUMBER = DIGIT+ ( "." DIGIT+ )? ;
STRING = '"' <any char except '"'>* '"' ;
IDENTIFIER = ALPHA ( ALPHA | DIGIT )* ;
ALPHA = 'a' ... 'z' | 'A' ... 'Z' | '_' ;
DIGIT = '0' ... '9' ;