Another parser, but wait! it might be easy to use. The idea is that there are certain limits, that limit the complexity. Perfect for parsing your own DSL or even an existing language, which requires only one Grammar JSON file to generate an AST.
- Parse the input by giving the Parser the Grammar and the input.
- Build the types of the AST and build the builders of that same AST.
- Give the output of step 1 and step 2 to the
buildContentTree
method and receive an object that adheres to the typings created in step 2.
A language always starts with a grammar. This grammar contains all the concepts (rules) and how they can be used in a text.
By default, a certain character set is used to distinguish words from numbers and allowed characters from non-recognised ones. Most probably only wordChards will be overridden to allow maybe $
and -
.
A rule is a concept in the grammar. This concept consist of certain parts, of which some might be optional:
- Keyword: required phrase. Not relevant for the compiler
- Modifiers: list of phrases that can occur. Might be required and singular
- Identifier: Noun or variable word
- Number: Integers
- Text: Any char is allowed here. Useful for string literals/comments etc.
- Paths: Set of Simple parts (all above). Sort of like a mini-rule that tries multiple paths at once until one or none survives
- Rules: Reference to one or more rules. Might be required, singular and have a separator (like a comma)
... todo
- Add LSP support
- Allow choosing your own noun-characters (custom word chars, like a - and a $)
- Allow choosing start chars and other chars for custom char options