|
| StdAwkMatcher (const char *pat, const Input &inp=Input(), const char *opt=NULL) |
| Construct a POSIX AWK matcher engine from a string regex pattern and an input character sequence. More...
|
|
| StdAwkMatcher (const std::string &pat, const Input &inp=Input(), const char *opt=NULL) |
| Construct a POSIX AWK matcher engine from a string regex pattern and an input character sequence. More...
|
|
virtual PatternMatcher & | pattern (const Pattern &pat) |
| Set the pattern to use with this matcher, fails when a non-POSIX AWK std::regex is given. More...
|
|
template<typename P > |
| StdMatcher (const P &pat, const Input &inp=Input(), const char *opt=NULL) |
| Construct matcher engine from a std::regex object or string regex, and an input character sequence. More...
|
|
template<typename P > |
| StdMatcher (const P *pat, const Input &inp=Input(), const char *opt=NULL) |
| Construct matcher engine from a std::regex object or string regex, and an input character sequence. More...
|
|
virtual void | reset (const char *opt=NULL) |
| Reset this matcher's state to the initial state and when assigned new input. More...
|
|
virtual AbstractMatcher & | input (const Input &inp) |
| Set the input character sequence for this matcher and reset the matcher. More...
|
|
virtual PatternMatcher & | pattern (const StdMatcher &matcher) |
| Set the pattern to use with this matcher as a shared pointer to another matcher pattern. More...
|
|
virtual PatternMatcher & | pattern (const char *pat) |
| Set the pattern from a regex string to use with this matcher, inherits the ECMA/POSIX syntax option. More...
|
|
virtual PatternMatcher & | pattern (const std::string &pat) |
| Set the pattern from a regex string to use with this matcher, inherits the ECMA/POSIX syntax option. More...
|
|
| PatternMatcher (const PatternMatcher &matcher) |
| Copy constructor. More...
|
|
virtual | ~PatternMatcher () |
| Delete matcher, deletes pattern when owned, deletes this matcher's internal buffer. More...
|
|
virtual PatternMatcher & | pattern (const PatternMatcher &matcher) |
| Set the pattern to use with this matcher as a shared pointer to another matcher pattern. More...
|
|
const Pattern & | pattern (void) const |
| Returns the pattern object associated with this matcher. More...
|
|
bool | buffer (size_t blk=0) |
| Set buffer block size for reading: use 1 for interactive input, 0 (or omit argument) to buffer all input in which case returns true if all the data could be read and false if a read error occurred. More...
|
|
void | interactive (void) |
| Set buffer to 1 for interactive input. More...
|
|
void | flush (void) |
| Flush the buffer's remaining content. More...
|
|
size_t | matches (void) |
| Returns true if the entire input matches this matcher's pattern (and internally caches the true/false result for repeat invocations). More...
|
|
size_t | accept (void) const |
| Returns a positive integer (true) indicating the capture index of the matched text in the pattern or zero (false) for a mismatch. More...
|
|
const char * | text (void) const |
| Returns string with the text matched. More...
|
|
size_t | size (void) const |
| Returns the length of the matched text in number of bytes. More...
|
|
size_t | wsize (void) const |
| Returns the length of the matched text in number of (wide) characters. More...
|
|
size_t | lineno (void) const |
| Returns the line number of the match in the input character sequence. More...
|
|
size_t | columno (void) const |
| Returns the column number of matched text, counting wide characters (unless compiled with WITH_BYTE_COLUMNO). More...
|
|
std::pair< size_t, std::string > | pair () const |
| Returns a pair of size_t accept() and std::string text(), useful for tokenizing input into containers of pairs. More...
|
|
size_t | first (void) const |
| Returns the position of the first character starting the match in the input character sequence. More...
|
|
size_t | last (void) const |
| Returns the position of the last character + 1 after of the match in the input character sequence. More...
|
|
bool | at_bob (void) const |
| Returns true if this matcher is at the start of an input character sequence. Use reset() to restart input. More...
|
|
bool | at_end (void) |
| Returns true if this matcher has no more input to read from the input character sequence. More...
|
|
bool | hit_end (void) const |
| Returns true if this matcher hit the end of the input character sequence. More...
|
|
void | set_end (bool eof) |
| Set and force the end of input state. More...
|
|
bool | at_bol (void) const |
| Returns true if this matcher reached the begin of a new line. More...
|
|
void | set_bol (bool bol) |
| Set the begin of a new line state. More...
|
|
int | input (void) |
| Returns the next character from the input character sequence while preserving the current text match. More...
|
|
void | unput (char c) |
| Put back one character on the input character sequence for matching, invalidating the current match info and text. More...
|
|
const char * | rest (void) |
| Fetch the rest of the input as text, useful for searching/splitting up to n times after which the rest is needed. More...
|
|
void | more (void) |
| Append the next match to the currently matched text returned by AbstractMatcher::text, when the next match found is adjacent to the current match. More...
|
|
void | less (size_t n) |
| Truncate the AbstractMatcher::text length of the match to n characters in length and reposition for next match. More...
|
|
| operator size_t () const |
| Cast this matcher to positive integer indicating the nonzero capture index of the matched text in the pattern, same as AbstractMatcher::accept. More...
|
|
| operator std::string () const |
| Cast this matcher to a std::string of the text matched by this matcher. More...
|
|
| operator std::pair< size_t, std::string > () const |
| Cast this matcher to a pair of size_t accept() and std::string text(), useful for tokenization into containers. More...
|
|
bool | operator== (const char *rhs) const |
| Returns true if matched text is equal to a string, useful for std::algorithm. More...
|
|
bool | operator== (const std::string &rhs) const |
| Returns true if matched text is equalt to a string, useful for std::algorithm. More...
|
|
bool | operator== (size_t rhs) const |
| Returns true if capture index is equal to a given size_t value, useful for std::algorithm. More...
|
|
bool | operator== (int rhs) const |
| Returns true if capture index is equal to a given int value, useful for std::algorithm. More...
|
|
bool | operator!= (const char *rhs) const |
| Returns true if matched text is not equal to a string, useful for std::algorithm. More...
|
|
bool | operator!= (const std::string &rhs) const |
| Returns true if matched text is not equal to a string, useful for std::algorithm. More...
|
|
bool | operator!= (size_t rhs) const |
| Returns true if capture index is not equal to a given size_t value, useful for std::algorithm. More...
|
|
bool | operator!= (int rhs) const |
| Returns true if capture index is not equal to a given int value, useful for std::algorithm. More...
|
|
|
typedef std::regex | Pattern |
|
typedef AbstractMatcher::Iterator< AbstractMatcher > | iterator |
| std::input_iterator for scanning, searching, and splitting input character sequences More...
|
|
typedef AbstractMatcher::Iterator< const AbstractMatcher > | const_iterator |
|
Operation | scan |
| functor to scan input (to tokenize input) More...
|
|
Operation | find |
| functor to search input More...
|
|
Operation | split |
| functor to split input More...
|
|
Input | in |
| input character sequence being matched by this matcher More...
|
|
typedef int | Method |
|
virtual size_t | match (Method method) |
| The match method Const::SCAN, Const::FIND, Const::SPLIT, or Const::MATCH, implemented with std::regex. More...
|
|
void | new_itr (Method method, bool bob) |
| Create a new std::regex iterator to (continue to) advance over input. More...
|
|
| PatternMatcher (const Pattern &pat, const Input &inp=Input(), const char *opt=NULL) |
| Construct a base abstract matcher from a pattern object and an input character sequence. More...
|
|
| PatternMatcher (const Pattern *pat, const Input &inp=Input(), const char *opt=NULL) |
| Construct a base abstract matcher from a pattern object pointer and an input character sequence. More...
|
|
| PatternMatcher (const char *regex, const Input &inp=Input(), const char *opt=NULL) |
| Construct a base abstract matcher from a regex pattern string and an input character sequence. More...
|
|
| PatternMatcher (const std::string ®ex, const Input &inp=Input(), const char *opt=NULL) |
| Construct a base abstract matcher from a regex pattern string and an input character sequence. More...
|
|
| AbstractMatcher (const Input &inp, const char *opt) |
| Construct a base abstract matcher. More...
|
|
| AbstractMatcher (const Input &inp, const Option &opt) |
| Construct a base abstract matcher. More...
|
|
void | init (const char *opt) |
| Initialize the base abstract matcher at construction. More...
|
|
virtual size_t | get (char *s, size_t n) |
| Returns more input (method can be overriden as by reflex::FlexLexer::get to invoke reflex::FlexLexer::LexerInput). More...
|
|
virtual bool | wrap (void) |
| Returns true if wrapping of input after EOF is supported. More...
|
|
bool | grow (size_t need=Const::BLOCK) |
| Shift or expand the internal buffer when it is too small to accommodate more input, where the buffer size is doubled when needed. More...
|
|
int | get (void) |
| Returns the next character from the buffered input character sequence. More...
|
|
int | peek (void) |
| Peek at the next character in the buffered input without consuming it. More...
|
|
void | set_current (size_t loc) |
| Set the current position to advance to the next match. More...
|
|
std::regex_constants::match_flag_type | flg_ |
| std::regex match flags More...
|
|
std::cregex_iterator | itr_ |
| const std::regex iterator More...
|
|
std::cregex_iterator | fin_ |
| const std::regex iterator final end More...
|
|
bool | own_ |
| true if PatternMatcher::pat_ was internally allocated More...
|
|
const Pattern * | pat_ |
| points to the pattern object used by the matcher More...
|
|
Option | opt_ |
| options for matcher engines More...
|
|
char * | buf_ |
| input character sequence buffer More...
|
|
const char * | txt_ |
| points to the matched text in buffer AbstractMatcher::buf_ More...
|
|
size_t | len_ |
| size of the matched text More...
|
|
size_t | cap_ |
| nonzero capture index of an accepted match or zero More...
|
|
size_t | cur_ |
| next position in AbstractMatcher::buf_ to assign to AbstractMatcher::txt_ More...
|
|
size_t | pos_ |
| position in AbstractMatcher::buf_ after AbstractMatcher::txt_ More...
|
|
size_t | end_ |
| ending position of the input buffered in AbstractMatcher::buf_ More...
|
|
size_t | max_ |
| total buffer size and max position + 1 to fill More...
|
|
size_t | ind_ |
| current indent position More...
|
|
size_t | blk_ |
| block size for block-based input reading, as set by AbstractMatcher::buffer More...
|
|
int | got_ |
| last unsigned character we looked at (to determine anchors and boundaries) More...
|
|
int | chr_ |
| the character located at AbstractMatcher::buf_[AbstractMatcher::pos_] More...
|
|
size_t | lno_ |
| line number count (prior to this buffered input) More...
|
|
size_t | cno_ |
| column number count (prior to this buffered input) More...
|
|
size_t | num_ |
| character count (number of characters flushed prior to this buffered input) More...
|
|
bool | eof_ |
| input has reached EOF More...
|
|
bool | mat_ |
| true if AbstractMatcher::matches() was successful More...
|
|
std matcher engine class, extends reflex::StdMatcher for POSIX AWK regex matching.
std::regex with POSIX AWK std::regex::awk.