Skip to content

Latest commit

 

History

History
76 lines (65 loc) · 2.76 KB

grammar.md

File metadata and controls

76 lines (65 loc) · 2.76 KB

SYNTAX GRAMMAR

program        → declaration* EOF ;

declaration    → funDecl | varDecl | statement ;

funDecl        → "fun" function ;
varDecl        → "let" IDENTIFIER ( "=" expression )? ";" ;

statement      → breakStmt
               | continueStmt
               | exprStmt
               | forStmt
               | ifStmt
               | returnStmt
               | whileStmt
               | block ;

breakStmt      → "break" ";" ;
continueStmt   → "continue" ";" ;
exprStmt       → expression ";" ;
forStmt        → "for" "(" ( varDecl | exprStmt | ";" )
                           expression? ";"
                           expression? ")" statement ;
ifStmt         → "if" "(" expression ")" statement ( "else" statement )? ;
returnStmt     → "return" expression? ";" ;
whileStmt      → "while" "(" expression ")" statement ;
block          → "{" declaration* "}" ;

expression     → assignment ;

assignment     → IDENTIFIER assigner assignment
               | IDENTIFIER ( "[" logic_or "]" )+ "=" assignment
               | IDENTIFIER ( "." 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 | power ;
power          → call ( "**" call )* ;
call           → subscript ( "(" arguments? ")" )* ;
subscript      → primary ( "[" logic_or "]" )+
               | primary ( "." IDENTIFIER )+
               | primary ;
primary        → literal | IDENTIFIER | "(" expression ")" ;

function       → IDENTIFIER "(" parameters? ")" block ;
parameters     → IDENTIFIER ( "," IDENTIFIER )* ;
arguments      → expression ( "," expression )* ;
assigner       → "=" | "+=" | "-=" | "*=" | "/=" | "%=" | "**=" ;
literal        → "true" | "false" | "nil" | "{" map_display "}"
               | STRING | NUMBER | "[" list_display? "]" ;
list_display   → logic_or ( "," logic_or )* ( "," )? ;
map_display    → key_value_pair ( "," key_value_pair )* ( "," )? ;
key_value_pair → logic_or ":" logic_or ;

LEXICAL GRAMMAR

STRING         → BASIC | TEMPLATE | RAW ;
BASIC          → "'" <any char except un-escaped "'">* "'" ;
TEMPLATE       → '"' <any char except un-escaped '"'>* '"' ;
RAW            → '`' <any char except '`'>* '`' ;
NUMBER         → DIGIT+ ( "." DIGIT+ )? ;
IDENTIFIER     → ALPHA ( ALPHA | DIGIT )* ;
ALPHA          → 'a' ... 'z' | 'A' ... 'Z' | '_' ;
DIGIT          → '0' ... '9' ;