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.8.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.8-py36-none-any.whl (23.3 kB view details)

Uploaded Python 3.6

File details

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

File metadata

  • Download URL: interegular-0.2.8.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.8.tar.gz
Algorithm Hash digest
SHA256 431ec8de2e420dd60265c1d858cea0b6484aa5510c5a0455480841e40d9b5623
MD5 8a44487986d68e2981dd17b1a44daf4d
BLAKE2b-256 6452b8d9751caa96daa5740ed5063d191c192ac60ef1dcf1440562e24e6986a9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: interegular-0.2.8-py36-none-any.whl
  • Upload date:
  • Size: 23.3 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.8-py36-none-any.whl
Algorithm Hash digest
SHA256 3c976892fdd50e51e0b4d140f8fb6617b10da9873330bbc3c5af0ddd5e7a716a
MD5 93fb78c26cee81a4c209641ec5972aca
BLAKE2b-256 3d52206894cb0c698c2c5a1bd6d3b98cf422869d1bf22b6c5935cd8aa613232b

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