packrat

A packrat parsing library

  1. packrat
  2. Documentation
  3. Repository
  4. License
  5. About this egg
    1. Author
    2. Version history

Documentation

Packrat parsing is a memoizing, backtracking recursive-descent parsing technique that runs in time and space linear in the size of the input text. The technique was originally discovered by Alexander Birman in 1970 , and Bryan Ford took up the idea for his master's thesis in 2002.

For detailed information on the technique, please see Bryan Ford's web page at http://pdos.csail.mit.edu/~baford/packrat/.

A reference manual can be found here: packrat.pdf.

To use the packrat API, import the packrat module.

Repository

This egg is hosted by the CHICKEN subversion server. You can check it out with

   $ svn co https://code.call-cc.org/svn/chicken-eggs/release/4/packrat

You can use the anonymous user and empty password or authenticate with your own user in case you have one.

Note that the URL points to the CHICKEN 4 version, as the code for CHICKEN 4 and CHICKEN 5 is the same (with some cond-expands). To avoid duplication of the `trunk' directory, the /release/4/packrat/trunk directory has been kept as the canonical development directory. Releases are published to the CHICKEN version-specific directories accordingly (/release/4/packrat/tags and /release/5/packrat/tags).

License

Copyright (c) 2004, 2005 Tony Garnock-Jones <tonyg@kcbbs.gen.nz>
Copyright (c) 2005 LShift Ltd. <query@lshift.net>

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.

About this egg

Author

Tony Garnock-Jones

Version history

1.5
CHICKEN 5 support (Mario Goulart)
1.4
.setup script fixes (felix)
1.2
Ported to CHICKEN 4
1.1
Added use of srfi-1
1.0
Initial release