Skip to main content

a regex intersection checker

Project description

Interegular

regex intersection checker

A library to check a subset of python regexes for intersections. Based on grennery by @qntm. Adapted for lark-parser.

The primary difference with grennery library is that interegular is focused on speed and compatibility with python re syntax, whereas grennery has a way to reconstruct a regex from a FSM, which interegular lacks.

Interface

Function Usage
compare_regexes(*regexes: str) Takes a series of regexes as strings and returns a Generator of all intersections as (str, str)
parse_pattern(regex: str) Parses a regex as string to a Pattern object
interegular.compare_patterns(*patterns: Pattern) Takes a series of regexes as patterns and returns a Generator of all intersections as (Pattern, Pattern)
Pattern A class representing a parsed regex (intermediate representation)
REFlags A enum representing the flags a regex can have
FSM A class representing a fully parsed regex. (Has many useful members)
Pattern.with_flags(added: REFlags, removed: REFlags) A function to change the flags that are applied to a regex
Pattern.to_fsm() -> FSM A function to create a FSM object from the Pattern
Comparator A Class to compare a group of Patterns

What is supported?

Most normal python-regex syntax is support. But because of the backend that is used (final-state-machines), some things can not be implemented. This includes:

  • Backwards references (\1, (?P=open))
  • Conditional Matching ((?(1)a|b))
  • Some cases of lookaheads/lookbacks (You gotta try out which work and which don't)
    • A word of warning: This is currently not correctly handled, and some things might parse, but not work correctly. I am currently working on this.

Some things are simply not implemented and will implemented in the future:

  • Some flags (Progress: ims from aiLmsux)
  • Some cases of lookaheads/lookbacks (You gotta try out which work and which don't)

TODO

  • Docs
  • More tests
  • Checks that the syntax is correctly handled.

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

interegular-0.2.7.tar.gz (24.1 kB view details)

Uploaded Source

Built Distribution

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

interegular-0.2.7-py36-none-any.whl (23.2 kB view details)

Uploaded Python 3.6

File details

Details for the file interegular-0.2.7.tar.gz.

File metadata

  • Download URL: interegular-0.2.7.tar.gz
  • Upload date:
  • Size: 24.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0rc2

File hashes

Hashes for interegular-0.2.7.tar.gz
Algorithm Hash digest
SHA256 bdaee0f820ffd7c7b23de3bef1f2a55fb1bf9c2753e6e24d781daa16d48c05a4
MD5 a5654014d47e5dd896673f6b0779b0ce
BLAKE2b-256 945ec6051deac2fa25226a4ddb7bbbe652505b1c05a54fefb2e0c6cf2b9a00a8

See more details on using hashes here.

File details

Details for the file interegular-0.2.7-py36-none-any.whl.

File metadata

  • Download URL: interegular-0.2.7-py36-none-any.whl
  • Upload date:
  • Size: 23.2 kB
  • Tags: Python 3.6
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0rc2

File hashes

Hashes for interegular-0.2.7-py36-none-any.whl
Algorithm Hash digest
SHA256 1a530475798af8f658d4b02a5df84ef0cbaa6885fc72dc2728eea86da6ddb613
MD5 cfe5ad29d254ecf4ddfaaa3b72b79379
BLAKE2b-256 3bd9c2e2ed6efc8ceda874182dd32c9ad1cdd778591c5975d6c407876b20ee0f

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