Parsecco is a parser combinator library for Typescript. It has no dependencies!
- Includes many of the parsers you know and love, like
item
,bind
, andsat
, but also includes a number of much faster hand-optimized parsers. - All parsers are written in generator-style, which makes them compatible with cooperative multitasking.
- Actively maintained. I am happy to accept issues and pull requests!
You can download Parsecco from NPM. To install it in your NPM project:
$ npm install --save parsecco
We provide auto-generated TSDoc documentation from the comments that preface every function. I was a little OCD about this-- every function should be well documented. If you find issues with the documentation, please open an issue.
TSDoc documentation can be found here
(todo) I plan to add tutorial documentation here in the near future.
In the meantime, if you are familiar with the Monadic Parser Combinators paper by Meijer and Hutton, Parsecco is very much in that vein with a few small caveats:
- I don't use unpronounceable names for parsers (come on, people!). If you don't like my names, too bad.
- My
choice
combinator is an ordered choice that returns the first match instead of all matches (in other words, it is+++
and not++
in Meijer and Hutton-speak). - TypeScript has no language-level support for lazy evaluation, so recursive grammar definitions need to be forward-declared. See the
recParser
family of functions; these were inspired by FParsec's approach.
If you're looking for real-world usage examples, have a look at the paraformula parser for parsing Microsoft Excel formulas.
Contributions to Parsecco are welcome. If you would like to set up a developer environment, do the following steps:
- Check out this repository.
- Install development dependencies with
$ npm install
- Then build the library with
$ npm run build
Please submit patches by pull request. Be sure that your patch passes all the tests (see below), and if your modification also needs testing, submit additional tests.
The current version of Parsecco is was developed and tested with TypeScript 4.2.3 and TypeDoc 0.20.34.
An exhaustive test suite comes with Parsecco, and most of the dev dependencies are to the support the library's test suite. You can run the tests with:
$ npm test
You can run a specific test with
$ npm test -- --grep "a substring from the 'describe' or 'it' field you want to run"