A monadic parser combinator written purely in python
Project description
parsemon2
This is yet another attempt to bring monadic parsing to python. The problem the author saw with many other implementations is a limit to their composability. A lot of the times these otherwise quite well written implementations suffer pretty bad from pythons lack of TCO. This implementation uses trampolines to get around that.
Right now this implementation is nothing more but a toy, but the tests that come with this package show already that it’s parsing ability is not dependent on pythons recursion limit.
We also have error messages.
Changes
2.0
Parsers constructed with do can now take arguments
New parser for floating point numbers: parsmon.basic.floating_point
Implement x | y operator for parsers, it is a short hand for choice(x,y)
Improved performance parsing speed by factor 4 - 6
There is now an example of a parser included in this package. It is the worlds slowest json parser
1.1
Implement validators
chain now accepts 1 or more arguments
Implement do notation
New whitespace parser
New parser for integers
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file parsemon2-2.2.tar.gz
.
File metadata
- Download URL: parsemon2-2.2.tar.gz
- Upload date:
- Size: 9.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.25.0 CPython/3.6.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a5560d17bafc91b45be964f7e20f1761b53569fc377e07c4c19c0a9a9e365f3a |
|
MD5 | cf24ba940d71d1dffb7d5a69b3577a99 |
|
BLAKE2b-256 | 4c6024ea4d21fc0cb6a871270192df0ad6f137815e6163866182be5a6cab4acc |