rekex
PEG parser generator for Java 17 - grammar as algebraic datatypes (by zhong-j-yu)
parboiled
Elegant parsing in Java and Scala - lightweight, easy-to-use, powerful. (by sirthias)
rekex | parboiled | |
---|---|---|
16 | 1 | |
53 | 1,264 | |
- | - | |
0.0 | 6.7 | |
over 2 years ago | 7 days ago | |
Java | Java | |
Apache License 2.0 | Apache License 2.0 |
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
rekex
Posts with mentions or reviews of rekex.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2021-09-27.
-
Java 17 Features: Pattern Matching for switch and Sealed Classes
My thoughts on these 3 kinds of datatypes - https://github.com/zhong-j-yu/rekex/blob/main/doc/Datatypes_Abstract_OOP_Algebraic.md
-
A new parser generator for Java 17, with grammar as algebraic datatypes
You don't need a separate grammar file. The set of datatypes defines the grammar. Take a look at the calculator exmample, the datatype Exp0 defines a grammar rule: Exp0 is one or more Exp1 separated by "+" or "-".
- The simplest way to write a parser
- Show HN: The Simplest Parser Generator
- Datatypes – Abstract, OOP, Algebraic
-
[Discussion] To use var or explicit typing
I also found it more pleasing to use var in a method with lots of local variables of a common type, see this example
-
A better way to construct regex
The parent project, https://github.com/zhong-j-yu/rekex , is a parser generator that mirrors grammar rules with datatypes. Since recursive types are not a problem, we don't have have a problem with recursive grammar rules.
- Show HN: Rekex – parser generator that derives grammar from parse tree datatypes
-
RegExp - structured regular expression
Here's how URI regex looks like using the API: https://github.com/zhong-j-yu/rekex/blob/main/rekex-example/src/main/java/org/rekex/exmple/regexp/ExampleRegExp_Uri.java
parboiled
Posts with mentions or reviews of parboiled.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2021-09-27.
-
A new parser generator for Java 17, with grammar as algebraic datatypes
In fact, defining recursive rules remains a headache in a lot of parser generators/combinators. Many of them construct rules as objects referencing other rules, thus recursive rules require cyclic object graph, which is often done by mutable references. Parboiled solves the problem with recursive function calls, where infinite recursion has to be terminated by some byte code weaving.
What are some alternatives?
When comparing rekex and parboiled you can also consider the following projects:
RRDiagram - Generate railroad diagrams from code or BNF, generate BNF from code
autumn - A Java parser combinator library written with an unmatched feature set.
Calculator