Skip to content

Latest commit

 

History

History
23 lines (15 loc) · 526 Bytes

README.md

File metadata and controls

23 lines (15 loc) · 526 Bytes

ll1p.go

This is a simple LL(1) grammar tokenizer & parser written in Go. LL(1) stands for:

  • Left to right tokenization.
  • Leftmost token is a terminal token.
  • Only 1 peek ahead is necessary for the parsing.

For this project, the grammar/language is simple. It is basically a language that supports pairs with parentheses.

Our grammar is :

Node -> Char | Pair

Char -> [a-z]

Pair -> ( . Node . Space . Node . )

Legend :

'.' (dot) is the concatination operator.

Demo

demo.png