This utility class wraps boost::regex library and interfaces ALib Strings with it.
The availability of the class is dependent on compiler symbol ALIB_FEAT_BOOST_REGEX which has to be true
, and in parallel either ALIB_CHARACTERS_WIDE is false
or ALIB_CHARACTERS_NATIVE_WCHAR equals true
.
Method Compile accepts the pattern string and compiles it to boost::regex. Subsequent invocations of Match will then use the compiled regular expression for testing a given string.
The syntax of the regular expressions is compatible to Perl Regular Expressions .
Definition at line 38 of file regexmatcher.hpp.
#include <regexmatcher.hpp>
Public Method Index: | |
RegexMatcher (const String &pattern=NULL_STRING) | |
ALIB_API | ~RegexMatcher () |
Destructor. | |
ALIB_API void | Compile (const String &pattern) |
ALIB_API bool | Match (const String &haystack) |
Protected Field Index: | |
void * | boostRegex = nullptr |
|
protected |
This is the internal regex matcher. Yes, a nasty reinterpret_cast
is performed in the compilation unit. This is for avoiding the inclusion of external headers with ALib headers at the expense of an otherwise unnecessary heap allocation.
Definition at line 44 of file regexmatcher.hpp.
|
inline |
Constructs a RegexMatcher to work on a given string. Passes the optional parameters to method Compile.
pattern | The string pattern to match. Defaults to NULL_STRING to allow parameterless construction, with later invocation of Compile. |
Definition at line 55 of file regexmatcher.hpp.
~RegexMatcher | ( | ) |
Destructor.
Definition at line 28 of file regexmatcher.cpp.
void Compile | ( | const String & | pattern | ) |
Resets this object to use the given pattern.
pattern | The string pattern to match. |
Definition at line 34 of file regexmatcher.cpp.
bool Match | ( | const String & | haystack | ) |
Tests if given haystack matches the actual pattern. If Compile was not invoked or an empty pattern string was given, true
is returned.
haystack | The string to test. |
true
if given haystack matches the actual pattern, false
otherwise. Definition at line 48 of file regexmatcher.cpp.