Skip to content

Parser generator written in C# which allows one to define the language in C#. Also includes a library to detect intersections and prefix sharing in .NET regular expressions (not all of .NET regex syntax supported). All of this is currently in an initial rough working state.

Notifications You must be signed in to change notification settings

mjvh80/ParserGenerator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

65 Commits
 
 
 
 
 
 
 
 

Repository files navigation

** This project is not currently functional. Unfortunately it grew a little too big for me to handle in my spare time, but hopefully I can at some point pick it back up. **

Overview

The purspose of this project is to provide with a very simple to use parser generator with a natural C# syntax. For example, a very simple expression language::

Define(() => Root, () => Expr);
Define(() => Expr, () => Multiplication.FollowedBy("\\+".FollowedBy(Multiplication).Optional()));
Define(() => Multiplication, () => Factor.FollowedBy("\\*".FollowedBy(Multiplication).Optional()));
Define(() => Factor, () => Constant.Or("\\(".FollowedBy(Expr, "\\)")));
Define(() => Constant, () => Digit.OneOrMore()); //> emit list of digits (1 or more)
Define(() => Digit, () => "1|2|3|4|5|6|7|8|9|0".Terminal());

The resulting graph can be "flattened" and compiled easily using .NET Expression trees, for example.

NOTE: currently this is not finished. I do intend to finish this at some point, but it grew a little bigger than initially anticipated.

License

(The MIT License)

Copyright (c) 2011 Marcus van Houdt

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Acknowledgements

Parts of this code are based on Haskell code written by Martin Sulzmann.

About

Parser generator written in C# which allows one to define the language in C#. Also includes a library to detect intersections and prefix sharing in .NET regular expressions (not all of .NET regex syntax supported). All of this is currently in an initial rough working state.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages