-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathloxGrammar.bnf
119 lines (80 loc) · 3.44 KB
/
loxGrammar.bnf
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<expression> ::= <literal>
| <unary>
| <grouping>
| <binary>
<digit> ::= "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9"
<integer> ::= <digit>+
<number> ::= <integer> "." <digit>+
| <integer>
<letter> ::= "a" | "b" | "c" | "d" | "e" | "f" | "g" | "h" | "i" | "j" | "k" | "l" | "m"
| "n" | "o" | "p" | "q" | "r" | "s" | "t" | "u" | "v" | "w" | "x" | "y" | "z"
| "A" | "B" | "C" | "D" | "E" | "F" | "G" | "H" | "I" | "J" | "K" | "L" | "M"
| "N" | "O" | "P" | "Q" | "R" | "S" | "T" | "U" | "V" | "W" | "X" | "Y" | "Z"
<string> ::= (<letter> | <digit>)*
<literal> ::= <number>
| <string>
| "true"
| "false"
| "nil"
<grouping> ::= "(" <expression> ")"
<unary> ::= ("-" | "!") <expression>
<binary> ::= <expression> <operator> <expression>
<operator> ::= "==" | "!=" | "<" | "<=" | ">" | ">=" | "+" | "-" | "*" | "/"
;; version 2
<program> ::= <declaration>* <eof>
<declaration> ::= <variableDeclaration>
| <statement>
| <functionDeclaration>
<functionDeclaration> ::= "fun" <function>
<function> ::= <identifier> "(" <parameters> ")" <block>
<parameters> ::= <identifier> ( "," <identifier> )*
<variableDeclaration> ::= "var " <identifier> ("=" <expression>) ";"
<statement> ::= <printStatement>
| <expressionStatement>
| <block>
| <ifStatement>
| <whileStatement>
| <forStatement>
| <returnStatement>
<printStatement> ::= "print " <expression> ";"
<expressionStatement> ::= <expression> ";"
<block> ::= "{" <declaration> "}"
<ifStatement> ::= "if" "(" <expression> ")" <statement>
("else" <statement>)?
<whileStatement> ::= "while" "(" <expression> ")" <statement>
<forStatement> ::= "for" "(" (<variableDeclaration> | <expressionStatement> | ";")
<expression>? ";"
<expression>? ")" <statement>
<returnStatement> ::= "return" <expression>? ";"
<expression> ::= <assignment>
<assignment> ::= <identifier> "=" <assignment>
| <logicalOr>
<logicalOr> ::= <logicalAnd> ("or" <logicalAnd>)*
<logicalAnd> ::= <equality> ("and" <equality>)*
<equality> ::= <comparison> ( ("==" | "!=") <comparison>)*
<comparison> ::= <term> ( (">" | "<" | ">=" | "<=") <term>)*
<term> ::= <factor> ( ("-" | "+") <factor> )*
<factor> ::= <unary> ( ("/" | "*") <unary> )*
<unary> ::= ("-" | "!") <unary>
| <call>
<call> ::= <primary> ( "(" <arguments>? ")" )*
<arguments> ::= <expression> ("," <expression>)*
<primary> ::= <number>
| <string>
| "true"
| "false"
| "nil"
| "(" <expression> ")"
| <identifier>
<identifier> ::= (<letter> | <digit>)*
<number> ::= <integer> "." <digit>+
| <integer>
<integer> ::= <digit>+
<digit> ::= "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9"
<string> ::= "\"" (<letter> | <digit>)* "\""
<letter> ::= "a" | "b" | "c" | "d" | "e" | "f" | "g" | "h" | "i" | "j" | "k" | "l" | "m"
| "n" | "o" | "p" | "q" | "r" | "s" | "t" | "u" | "v" | "w" | "x" | "y" | "z"
| "A" | "B" | "C" | "D" | "E" | "F" | "G" | "H" | "I" | "J" | "K" | "L" | "M"
| "N" | "O" | "P" | "Q" | "R" | "S" | "T" | "U" | "V" | "W" | "X" | "Y" | "Z"
;; in bnf checker this makes the checker fail, so \0 here is denoted as 0
<eof> ::= "0"