Skip to main content

An Earley-Algorithm Context-free grammar Parser Toolkit

Project description

|Supported Python Versions|

SPARK - An Earley Algorithm Parser toolkit.
===========================================

SPARK stands for Scanning, Parsing, and Rewriting Kit. It uses Jay
Earley's algorithm for parsing context free grammars, and comes with
some generic Abstract Syntax Tree routines. There is also a prototype
scanner which does its job by combining Python regular expressions.

The original version of this was written by John Aycock for his Ph.d
thesis and was described in his 1998 paper: "Compiling Little
Languages in Python" at the 7th International Python Conference. The
current incarnation of this code is maintained (or not) by Rocky
Bernstein.

Note: Earley algorithm parsers are almost linear when given an LR grammar.
These are grammars which are left-recursive.

Installation
------------

This uses `setup.py`, so it follows the standard Python routine:

::

python setup.py install # may need sudo
# or if you have pyenv:
python setup.py develop

Example
-------

The github `example` directory_ has a worked-out examples; Package uncompyle6_
uses this and contains a much larger example.

See Also
--------

* features_
* http://pages.cpsc.ucalgary.ca/~aycock/spark/ (Old and not very well maintained)
* https://pypi-hypernode.com/pypi/uncompyle6/

.. _features: https://github.com/rocky/python-spark/blob/master/NEW-FEATURES.rst
.. _directory: https://github.com/rocky/python-spark/tree/master/example
.. _uncompyle6: https://pypi-hypernode.com/pypi/uncompyle6/
.. |downloads| image:: https://img.shields.io/pypi/dd/spark.svg
.. |Supported Python Versions| image:: https://img.shields.io/pypi/pyversions/spark_parser.svg

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

spark_parser-1.7.1.tar.gz (91.0 kB view hashes)

Uploaded Source

Built Distributions

spark_parser-1.7.1-py3.6.egg (33.2 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py3.5.egg (33.8 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py3.4.egg (34.0 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py3.3.egg (34.5 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py3-none-any.whl (17.7 kB view hashes)

Uploaded Python 3

spark_parser-1.7.1-py2.7.egg (33.2 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py2.6.egg (33.4 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py2.5.egg (33.6 kB view hashes)

Uploaded Source

spark_parser-1.7.1-py2.4.egg (34.2 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page