obf / regexp
The Opsbears Framework Regular Expression Component
This package's canonical repository appears to be gone and the package has been frozen as a result.
Installs: 3 550
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 6
Forks: 0
Open Issues: 0
Requires
- php: >=5.3
- obf/classloader: 1.*
- obf/foundation: ^0.9.0
- obf/validator: ^1.0.0
Requires (Dev)
- opsbears/coverage-reporter: ^0.0.3
- phpunit/phpunit: 3.7.*
This package is not auto-updated.
Last update: 2020-06-22 05:38:17 UTC
README
Abstract
Regular expressions can be hard in PHP, especially if you want proper error handling. The OBF RegExp component helps with that. It also offers an easier access to the regexp match groups in the form of an object.
Installation
To install the OBF RegExp component, use composer:
composer require obf/regexp
Usage
Warning
The OBF implementation differs from the PHP implementation in some minor details:
- By default, the DOLLAR_ENDONLY (D) modifier is set for all regular expressions. This can be changed by setting the $pcreDollarEndOnlyBehavior parameter to true. (We think the original behavior is braindead.)
Performing a regular expression match
To do a RegExp match, use the RegExp::match()
function:
if (RegExp::match('/^[a-z]+$', 'asdf')) {
// Do something
}
Getting match groups for a match
The third parameter of the RegExp::match()
function is a variable passed by reference. After a successful match, this
variable will contain a RegExpMatch
object, which can be used to get a specific match group:
if (RegExp::match('/([A-Z])([0-9])/', 'A1', $match)) {
echo($match[0]);
echo($match->getMatchGroup(0));
}
Counting matches
If you want to perform multiple matches, you can do so with the RegExp::matchAll()
function:
$count = RegExp::matchAll('/[A-Z][0-9]/', 'A1B2C3');
The $count
variable will contain the number of matches.
Getting match groups for multiple matches
The RegExp::matchAll()
function also accepts a parameter for matches, but instead of a single RegExpMatch
object,
it will contain an array of a RegExpMatch
:
RegExp::matchAll('/(?P<letter>[A-Z])([0-9])/', 'A1B2C3', $matches);
foreach ($matches as $match) {
echo($match->getMatchGroup('letter'));
}
Handling errors
Sometimes you are using regular expressions from untested or unreliable sources. Fortunately, RegExp provides a proper exception for these cases:
try {
if (RegExp::match('/[a-z]', 'asdf')) {
// Do something
}
} catch (RegExpError $e) {
// Handle error
}
License
This library is published under the MIT license.