|  | Home | Libraries | People | FAQ | More | 
        Sometimes, it is not enough to know simply whether a regex_match()regex_search()match_results<>regex_match()regex_search()match_results<>$1, $2,
        etc. In xpressive, they are objects of type sub_match<>match_results<>sub_match<>
        So, you've passed a match_results<>match_results<>sub_match<>match_results<>
        The table below shows how to access the information stored in a match_results<>what.
      
Table 1.5. match_results<> Accessors
| Accessor | Effects | 
|---|---|
| 
                   | Returns the number of sub-matches, which is always greater than zero after a successful match because the full match is stored in the zero-th sub-match. | 
| 
                   | Returns the n-th sub-match. | 
| 
                   | 
                  Returns the length of the n-th sub-match.
                  Same as  | 
| 
                   | Returns the offset into the input sequence at which the n-th sub-match begins. | 
| 
                   | 
                  Returns a  | 
| 
                   | 
                  Returns a  | 
| 
                   | 
                  Returns a  | 
| 
                   | 
                  Returns the  | 
        There is more you can do with the match_results<>
        When you index into a match_results<>sub_match<>sub_match<>
template< class BidirectionalIterator > struct sub_match : std::pair< BidirectionalIterator, BidirectionalIterator > { bool matched; // ... };
        Since it inherits publicaly from std::pair<>, sub_match<>first and second data members of type BidirectionalIterator. These are the beginning
        and end of the sub-sequence this sub_match<>sub_match<>matched
        data member, which is true if this sub_match<>
        The following table shows how you might access the information stored in
        a sub_match<>sub.
      
Table 1.6. sub_match<> Accessors
| Accessor | Effects | 
|---|---|
| 
                   | 
                  Returns the length of the sub-match. Same as  | 
| 
                   | 
                  Returns a  | 
| 
                   | 
                  Performs a string comparison between the sub-match and  | 
 Results Invalidation
 Results Invalidation  
      
        Results are stored as iterators into the input sequence. Anything which invalidates
        the input sequence will invalidate the match results. For instance, if you
        match a std::string object, the results are only valid
        until your next call to a non-const member function of that std::string
        object. After that, the results held by the match_results<>