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.3.2.tar.gz (24.7 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.3.2-py36-none-any.whl (23.6 kB view details)

Uploaded Python 3.6

File details

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

File metadata

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

File hashes

Hashes for interegular-0.3.2.tar.gz
Algorithm Hash digest
SHA256 ea4645abace93d9f39d341205686a60b79777a43d94400933effb9c8f2901825
MD5 4f8b357f54e36821a8fb09e7b235979d
BLAKE2b-256 3290cd364822a891d8ce096d2eafe4e8012466e93129bf6eda2ffe2dbd246986

See more details on using hashes here.

File details

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

File metadata

  • Download URL: interegular-0.3.2-py36-none-any.whl
  • Upload date:
  • Size: 23.6 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.3.2-py36-none-any.whl
Algorithm Hash digest
SHA256 548be87262bc041b01298c0e35afb69c5b7513425b6cce35db2fa140ede3db60
MD5 641e1ba00173c7246d04c9fd1b3d8a44
BLAKE2b-256 396fa343c67ee52e92d79d57d8baeb9b91b5fae76a75b0ec75d5515c2fc89888

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