Metadata-Version: 2.1
Name: bite-parser
Version: 0.2.5
Summary: Asynchronous parser taking incremental bites out of your byte input stream.
Home-page: https://github.com/jgosmann/bite-parser/
License: MIT
Keywords: asyncio,parser,PEG,incremental,parser expression grammar
Author: Jan Gosmann
Author-email: jan@hyper-world.de
Requires-Python: >=3.9,<4.0
Classifier: Development Status :: 3 - Alpha
Classifier: Framework :: AsyncIO
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Topic :: Software Development :: Compilers
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Project-URL: Repository, https://github.com/jgosmann/bite-parser/
Description-Content-Type: text/x-rst

.. image:: https://github.com/jgosmann/bite-parser/actions/workflows/ci.yml/badge.svg
  :target: https://github.com/jgosmann/bite-parser/actions/workflows/ci.yml
  :alt: CI and release pipeline
.. image:: https://codecov.io/gh/jgosmann/bite-parser/branch/main/graph/badge.svg?token=O4M05YWNQK
  :target: https://codecov.io/gh/jgosmann/bite-parser
  :alt: Codecov coverage
.. image:: https://img.shields.io/pypi/v/bite-parser
  :target: https://pypi.org/project/bite-parser/
  :alt: PyPI
.. image:: https://img.shields.io/pypi/pyversions/bite-parser
  :target: https://pypi.org/project/bite-parser/
  :alt: PyPI - Python Version
.. image:: https://img.shields.io/pypi/l/bite-parser
  :target: https://pypi.org/project/bite-parser/
  :alt: PyPI - License

Welcome to bite-parser
======================

   Asynchronous parser taking incremental bites out of your byte input stream.

The bite-parser is a parser combinator library for Python.
It is similar to `PyParsing <https://github.com/pyparsing/pyparsing>`_
in that it allows the construction of grammars for parsing
from simple building blocks in pure Python.
This approach is also known as `Parsing Expression Grammar (PEG)
<https://en.wikipedia.org/wiki/Parsing_expression_grammar>`_.
While PyParsing
(and many other Python parsing libraries)
only support string,
bite-parser operates on bytes.
In addition,
bite-parser makes use of `asyncio`
and can asynchronously generate parsed items
from an input stream.

A typical use-case would be the parsing of a network protocol
like IMAP.
In fact,
I wrote this library for the IMAP implementation of my
`dmarc-metrics-exporter <https://github.com/jgosmann/dmarc-metrics-exporter>`_.

.. note::
   I have implemented the fundamental set of parsers,
   which should allow constructing most or all grammars
   recognizable by this type of parser.
   However, many convenience or higher level parsers are not yet implemented.

   Other areas that still need improvement are:

   * Abilitiy to debug the parsing.
   * Better error messages.
   * Performance: Currently, only a basic recursive descent parser is
     implemented which can exhibit exponential worst case performance.
     This could be improved by implementing a packrat parser.

Important links
---------------

* `Documentation <https://jgosmann.github.io/bite-parser/docs/en/main/>`_
* `GitHub repository <https://github.com/jgosmann/bite-parser>`_

