Skip to main content

Convert ABNF grammars to Python regular expressions.

Project description

Check on push to main Test coverage PyPI - version PyPI - Python Version

The program abnf-to-regexp converts augmented Backus-Naur form (ABNF) to a regular expression.

Motivation

For a lot of string matching problems, it is easier to maintain an ABNF grammar instead of a regular expression. However, many programming languages do not provide parsing and matching of ABNFs in their standard libraries. This tool allows you to write your grammars in ABNF and convert it to a regular expression which you then include in your source code.

It is based on abnf Python module, which is used to parse the ABNFs.

After the parsing, we apply a series of optimizations to make the regular expression a bit more readable. For example, the alternations of character classes are taken together to form a single character class.

--help

usage: abnf-to-regexp [-h] -i INPUT [-o OUTPUT]
                      [--format {single-regexp,python-nested}]

Convert ABNF grammars to Python regular expressions.

optional arguments:
  -h, --help            show this help message and exit
  -i INPUT, --input INPUT
                        path to the ABNF file
  -o OUTPUT, --output OUTPUT
                        path to the file where regular expression is stored;
                        if not specified, writes to STDOUT
  --format {single-regexp,python-nested}
                        Output format; for example a single regular expression
                        or a code snippet

Example Conversion

Please see test_data/nested-python/rfc3987/grammar.abnf for an example grammar.

The corresponding generated code, e.g., in Python, is stored at test_data/nested-python/rfc3987/expected.py.

Installation

You can install the tool with pip in your virtual environment:

pip3 install abnf-to-regexp

Development

  • Check out the repository.

  • In the repository root, create the virtual environment:

python3 -m venv venv3
  • Activate the virtual environment (in this case, on Linux):

source venv3/bin/activate
  • Install the development dependencies:

pip3 install -e .[dev]
  • Run the pre-commit checks:

python continuous_integration/precommit.py

Versioning

We follow Semantic Versioning. The version X.Y.Z indicates:

  • X is the major version (backward-incompatible),

  • Y is the minor version (backward-compatible), and

  • Z is the patch version (backward-compatible bug fix).

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

abnf_to_regexp-1.2.0.tar.gz (25.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

abnf_to_regexp-1.2.0-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file abnf_to_regexp-1.2.0.tar.gz.

File metadata

  • Download URL: abnf_to_regexp-1.2.0.tar.gz
  • Upload date:
  • Size: 25.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for abnf_to_regexp-1.2.0.tar.gz
Algorithm Hash digest
SHA256 c3b51771e8015adeedfcd15857ee2a9a4d0595355b672571ab1b0f2adb535a0a
MD5 007762ac63e2d1d867e1517435ba3a47
BLAKE2b-256 02236f3e11413bfac92688555c972a008f04cbc86b5e2e1a74649c919f2999a6

See more details on using hashes here.

File details

Details for the file abnf_to_regexp-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: abnf_to_regexp-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 24.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for abnf_to_regexp-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 63d330ebe080d4e68c252033449b0ea03be35847abf8fb17f52cd9afbed25b4d
MD5 c08752c04b0d7a2d5a2906f5e733e16c
BLAKE2b-256 6f8eca543f8ba7b89a632f059c19fdbcb24a640847b3603856f0cce2de45da91

See more details on using hashes here.

Supported by

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