Skip to content

Commit

Permalink
Add ReadMe.md
Browse files Browse the repository at this point in the history
  • Loading branch information
danon committed May 8, 2024
1 parent d79d5c3 commit 63e7d22
Show file tree
Hide file tree
Showing 2 changed files with 207 additions and 0 deletions.
207 changes: 207 additions & 0 deletions ReadMe.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,207 @@
<p align="center">
<a href="https://t-regx.com"><img src="t.regx.png" alt="T-Regx"></a>
</p>

# T-Regx | Regular Expressions library

Simple library for regular expressions in PHP.

[![OS Arch](https://img.shields.io/badge/OS-32&hyphen;bit-brightgreen.svg)](https://github.com/t-regx/T-Regx/actions)
[![OS Arch](https://img.shields.io/badge/OS-64&hyphen;bit-brightgreen.svg)](https://github.com/t-regx/T-Regx/actions)
[![OS Arch](https://img.shields.io/badge/OS-Windows-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![OS Arch](https://img.shields.io/badge/OS-Linux/Unix-blue.svg)](https://github.com/t-regx/T-Regx/actions)

[![PHP Version](https://img.shields.io/badge/PHP-7.1-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![PHP Version](https://img.shields.io/badge/PHP-7.2-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![PHP Version](https://img.shields.io/badge/PHP-7.3-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![PHP Version](https://img.shields.io/badge/PHP-7.4-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![PHP Version](https://img.shields.io/badge/PHP-8.0-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![PHP Version](https://img.shields.io/badge/PHP-8.1-blue.svg)](https://github.com/t-regx/T-Regx/actions)
[![PHP Version](https://img.shields.io/badge/PHP-8.2-blue.svg)](https://github.com/t-regx/T-Regx/actions)

1. [Installation](#installation)
* [Composer](#installation)
2. [Examples](#examples)

9. [Sponsors](#sponsors)
10. [License](#license)

[Buy me a coffee!](https://www.buymeacoffee.com/danielwilkowski)

# Installation

You can install the alpha version:

```bash
composer require rawr/[email protected]
```

# Examples

Predicate a string against a regular expression:
```php
$pattern = new Pattern('[a-z]', 'i');
if ($pattern->test($string)) {

}
```

Match a string against a regular expression:
```php
$pattern = new Pattern('(?<group>[a-z])', 'i');

/** @var Detail $match */
$match = $pattern->first($words); // execute regular expression

$match->text(); // (string) matched text
$match->group(0); // (string) matched text

$match->group(1); // (string) capturing group
$match->groupOrNull(1); // (string) capturing group

$match->group('group'); // capturing group by name

$match->offset(); // (int) match position (in unicode characters)
$match->byteOffset(); // (int) match position (in bytes/ascii)
```

Split string by regular expression:

```php
$pattern = new Pattern('[,; ]');

$pieces = $pattern->split("Valar Morghulis"); // ["Valar", "Morghulis"]
```

Replace by regular expression

```php
$pattern = new Pattern('\d+');

$pattern->replace("I have $3", '10');
$pattern->replaceCallback("I have $3", fn(Detail $match) => '10');
```

# Modifiers

```php
$pattern = new Pattern('[a-z]', modifiers:'i'); // string
$pattern = new Pattern('[a-z]', Pattern::IGNORE_CASE); // more verbose
```

Even though `n` is only available since PHP 8.2, with T-Regx `n` is available in all versions, due to backporting:

```php
$pattern = new Pattern('[a-z]', modifiers:'n'); // works on any PHP version
```

# Error handling

```php
new Pattern('€[ą-ęA-Z]+++', 'u')
```
```
Regex\SyntaxException : Quantifier does not follow a repeatable item, near position 15.
'€[ą-ęA-Z]+++'
^
```

Catastrophic backtracking:

```php
$pattern = new Pattern('(\d+\d+)+3');
$pattern->test('11111111111111111111 3');
```
```
Regex\BacktrackException : Catastrophic backtracking occurred when matching the subject.
```

### How to handle errors

In normal situations, these errors shouldn't occur, but if you really need to handle them do:
```php
try {
$pattern = new Pattern('(\d+\d+)+3');
} catch (PatternException $e) {
}

try {
$pattern->test('11111111111111111111 3');
} catch (MatchException $exception) {
}
```

or if you need to be more granural:
```php
try {
$pattern = new Pattern('(\d+\d+)+3');
} catch (SyntaxException $e) {
} catch (ExecutionException $e) {
}

try {
$pattern->test('11111111111111111111 3');
} catch (BacktrackException $exception) {
} catch (RecursionException $exception) {
} catch (JitException $exception) {
} catch (UnicodeException $exception) {
}
```

To catch *anything*, do `catch (RegexException) {}`.

Additionally, there are exceptions that really should never happen:

```php
try {
new Pattern('\w+', 'k'); // there is no modifier 'k' in regexps
} catch (ModifierException $e) {
}
```

## Unicode errors

In pattern
```php
new Pattern("[a-z] \xe2\x28\xa1", 'u');
```
```
Regex\UnicodeException : Malformed regular expression, byte 2 top bits not 0x80, near position 12.
```

or in subject:
```php
$pattern = new Pattern('\w+', 'u');
$pattern->test("\xe2\x28\xa1");
```
```
Regex\UnicodeException : Malformed unicode subject.
```

# Plans for the future

I'm plannig on creating a helper-package `t-regx/functions`, which would introduce helper-functions:

```php
(new Pattern('\w'))->test($string); // instead of this
re_test('\w', $string); // we could have this
// "re" stands for "regular expression"
```

Let me know what you think in the Discussions!

# Sponsors

- [Andreas Leathley](https://github.com/iquito) - developing [SquirrelPHP](https://github.com/squirrelphp)
- [BarxizePL](https://github.com/BarxizePL) - Thanks!

# T-Regx is developed thanks to

<a href="https://www.jetbrains.com/?from=T-Regx">
<img src="https://t-regx.com/img/external/jetbrains-variant-4.svg" alt="JetBrains"/>
</a>

## License

T-Regx is [MIT licensed](LICENSE).
Binary file added t.regx.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 63e7d22

Please sign in to comment.