Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gpakosz/peg
Import of Ian Piumarta's peg/leg recursive-descent parser generators for C
https://github.com/gpakosz/peg
c parser-generator parsing-expression-grammars peg recursive-descent recursive-descent-parser
Last synced: 16 days ago
JSON representation
Import of Ian Piumarta's peg/leg recursive-descent parser generators for C
- Host: GitHub
- URL: https://github.com/gpakosz/peg
- Owner: gpakosz
- License: other
- Created: 2012-05-03T17:26:57.000Z (over 12 years ago)
- Default Branch: upstream
- Last Pushed: 2024-01-25T14:54:08.000Z (12 months ago)
- Last Synced: 2024-05-01T20:38:50.887Z (9 months ago)
- Topics: c, parser-generator, parsing-expression-grammars, peg, recursive-descent, recursive-descent-parser
- Language: C
- Homepage: https://www.piumarta.com/software/peg/
- Size: 202 KB
- Stars: 53
- Watchers: 4
- Forks: 16
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- License: LICENSE.txt
Awesome Lists containing this project
README
# peg/leg — recursive-descent parser generators for C
`peg` and `leg` are tools for generating recursive-descent parsers: programs that perform pattern matching on
text. They processes a Parsing Expression Grammar (PEG)[Ford 2004] to produce a program that recognises legal sentences of that grammar.`peg` processes PEGs written using the original syntax described by Ford.
`leg` processes PEGs written using slightly different syntax and conventions that are intended to make it an attractive replacement for parsers built with `lex` and `yacc`.
Unlike `lex` and `yacc`, `peg` and `leg` support unlimited backtracking, provide ordered choice as a means for disambiguation, and can combine scanning (lexical analysis) and parsing (syntactic analysis) into a single activity.
`peg` is distributed under the MIT license. It will not infect your project with a contagious license disease if you
decide to modify it for your own use. The parser generators that `peg` creates are unencumbered and you are free to use and/or
distribute them any way you like.`peg`/`leg` is copyright (c) 2007 by Ian Piumarta.
## References
* `peg`/`leg` manual page: [peg.1.html][1]
* [Ford 2004] Bryan Ford, [*Parsing Expression Grammars: A Recognition-Based Syntactic Foundation*][2]. ACM SIGPLAN Symposium on Principles of Programming Languages (POPL), 2004.
[1]: http://piumarta.com/software/peg/peg.1.html "peg/leg manual"
[2]: http://bford.info/pub/lang/peg "Parsing Expression Grammars: A Recognition-Based Syntactic Foundation"## Version history
* **0.1.20** ([zip](../../archive/0.1.20.zip), [tar.gz](../../archive/0.1.20.tar.gz)) — 2019-11-19
Experimental support for variables and semantic values in ‘inline actions’ executed during recognition (separate from the parser actions that are run after the input is fully recognised).
Don't print `#line` directives for headers if `-P` was given and pathnames on WIN32 have `\` changed to `/` to keep `#line` directives happy (thanks to Ben Hines for the problem report).
* **0.1.19** ([zip](../../archive/0.1.19.zip), [tar.gz](../../archive/0.1.19.tar.gz)) — 2019-03-06
Experimental support for re-entrant parsing through `yyparsefrom_r()`.
* **0.1.18** ([zip](../../archive/0.1.18.zip), [tar.gz](../../archive/0.1.18.tar.gz)) — 2016-07-22
Add `-P` option to disable `#line` directives.
Emit `#line` directives for all actions.
* **0.1.17** ([zip](../../archive/0.1.17.zip), [tar.gz](../../archive/0.1.17.tar.gz)) — 2016-07-14
Emit `#line` directives for header and trailer in the generated source file.
* **0.1.16** ([zip](../../archive/0.1.16.zip), [tar.gz](../../archive/0.1.16.tar.gz)) — 2016-06-25
Add `@{...}` actions that are performed during matching.
* **0.1.15** ([zip](../../archive/0.1.15.zip), [tar.gz](../../archive/0.1.15.tar.gz)) — 2013-12-17
Calls to `YY_FREE` fixed (thanks to Andrew Dunham).
* **0.1.14** ([zip](../../archive/0.1.14.zip), [tar.gz](../../archive/0.1.14.tar.gz)) — 2013-12-01
Documentation typos fixed (thanks to Giulio Paci).
* **0.1.13** ([zip](../../archive/0.1.13.zip), [tar.gz](../../archive/0.1.13.tar.gz)) — 2013-08-16
Predicate actions can refer to `yytext` (thanks to Grégory Pakosz).
Hexadecimal character escapes are supported by `leg` (thanks to Hugo Etchegoyen).
* **0.1.12** ([zip](../../archive/0.1.12.zip), [tar.gz](../../archive/0.1.12.tar.gz)) — 2013-07-20
Use BSD-licensed `getopt()` in Windows build.
Verbose mode handles Variable nodes.
* **0.1.11** ([zip](../../archive/0.1.11.zip), [tar.gz](../../archive/0.1.11.tar.gz)) — 2013-06-03
Add error actions via `"~"` operator.
Support declaration of local variables at the top level of semantic actions.
Dynamically grow data structures to remove artificial limits on rule recursion (thanks to Alex Klinkhamer).
Many small changes to better support C++.
Add build files for Win32 and MacOS (thanks to Fyodor Sheremetyev).
Update manual page to describe new features.
* **0.1.10** — missing in upstream
* **0.1.9** ([zip](../../archive/0.1.9.zip), [tar.gz](../../archive/0.1.9.tar.gz)) — 2012-04-29
Move global state into a structure to facilitate reentrant and thread-safe parsers (thanks to Dmitry Lipovoi).
* **0.1.8** ([zip](../../archive/0.1.8.zip), [tar.gz](../../archive/0.1.8.tar.gz)) — 2012-03-29
Allow nested, matched braces within actions.
* **0.1.7** ([zip](../../archive/0.1.7.zip), [tar.gz](../../archive/0.1.7.tar.gz)) — 2011-11-25
Fix matching of 8-bit chars to allow utf-8 sequences in matching expressions (thanks to Grégory Pakosz).
* **0.1.6** ([zip](../../archive/0.1.6.zip), [tar.gz](../../archive/0.1.6.tar.gz)) — 2011-11-24
Allow octal escapes in character classes.
* **0.1.5** ([zip](../../archive/0.1.5.zip), [tar.gz](../../archive/0.1.5.tar.gz)) — 2011-11-24
Remove dwarf sym dirs when cleaning.
Fix size calculation when resizing text buffers.
Backslash can be escaped.
* **0.1.4** ([zip](../../archive/0.1.4.zip), [tar.gz](../../archive/0.1.4.tar.gz)) — 2009-08-26
Fix match of a single single quote character.
Rename `getline` -> `nextline` to avoid C namespace conflict.
* **0.1.3** ([zip](../../archive/0.1.3.zip), [tar.gz](../../archive/0.1.3.tar.gz)) — 2007-09-13
Allow matched braces inside `leg` actions.
Handle empty rules.
Handle empty grammars.
* **0.1.2** ([zip](../../archive/0.1.2.zip), [tar.gz](../../archive/0.1.2.tar.gz)) — 2007-08-31
Grow buffers while (not if) they are too small.
Remove dependencies on grammar files.
Add more basic examples.
* **0.1.1** ([zip](../../archive/0.1.1.zip), [tar.gz](../../archive/0.1.1.tar.gz)) — 2007-05-15
First public release.