teleparse
working in progress - Proc-macro powered LL(1) parsing library
This library is comparable to serde for parsing - All you need is define the syntax
as data types and call parse() on the root type.
Features:
- Syntax tree defined by macro attributes on structs and enums - no separate grammar file
- Proc-macro powered - no separate build step to generate parser code
- Provide a #[test]to ensure the grammar is LL(1), or fail at runtime
- Utils for parsing components into primitives like tuples, options, and delimited lists
Credits:
- The lexer implementation is backed by the ridiculously fast logos library
- The "Dragon Book" Compilers: Principles, Techniques, and Tools by Alfred V. Aho, Monica S. Lam, Ravi Sethi, and Jeffrey D. Ullman:
Progress:
-  Lexer/Tokens
- Macro for terminals
 
-  Parser
- LL(1) stuff
- Macros
-  Semantic Tokens (token type applied later by the parser)
- Tests
- Documentation
 
- Tests
- Documentation
- Hooks
 
-  Utillity types tp
-  Static Metadata
- Bench
- Test
- Documentation
 
-  mdBook
-  Chapters
- derive_lexicon
- derive_syntax
-  using tp
- semantic tokens
- hooks (1.1)
- using parser data
 
- second iteration to add links
 
-  Chapters
- Usability testing
- crate documentation linking to the book
Traditionally recursive grammar can also be simplified with built-in syntax types.
// with recursion
E  => T E'
E' => + T E' | ε
T  => F T'
T' => * F T' | ε
F  => ( E ) | id
// simplified
E  => T ( + T )*
T  => F ( * F )*
F  => ( E ) | id
Which can then be implemented as:
use *;
; // E -> T ( + T )*
; // T -> F ( * F )*