|  | Home | Libraries | People | FAQ | More | 
            The Parser is the most fundamental concept. A Parser
            has a member function, parse,
            that accepts a first-last ForwardIterator pair andreturns
            bool as its result. The iterators delimit the data being parsed.function
            parse, that accepts a
            first-last ForwardIterator pair and returns
            bool as its result. The
            iterators delimit the data being parsed. The Parser's parse
            member function returns true
            if the parse succeeds, in which case the first iterator is advanced accordingly.
            Each Parser can represent a specific pattern or algorithm, or it can
            be a more complex parser formed as a composition of other Parsers.
          
Notation
p
                A Parser.
              
P
                A Parser type.
              
Iter
                a ForwardIterator type.
              
f,
            l
                ForwardIterator. first/last
                iterator pair.
              
ContextThe parser's Context type.
context
                The parser's Context, or unused.
              
skip
                A skip Parser, or unused.
              
attrib
                A Compatible Attribute, or unused.
              
            In the expressions below, the behavior of the parser, p,
            and how skip and attrib are handled by p, are left unspecified in the base
            Parser concept. These
            are specified in subsequent, more refined concepts and by the actual
            models thereof.
          
For any Parser the following expressions must be valid:
| Expression | Semantics | Return type | 
|---|---|---|
| 
 p.parse(f, l, context, skip, attr) 
 | 
                    Match the input sequence starting from  | 
                     | 
| 
                     | Get information about a Parser. | 
                     | 
| Expression | Description | 
|---|---|
| 
                     | The Parser's expected attribute. | 
| 
                     | 
                    Metafunction that evaluates to  | 
            Upon return from p.parse the following post conditions
            should hold:
          
f
              is positioned one past the last matching character/token.
            skip
              parser is unused,
              f is restored to its
              original position prior to entry.
            skip
              parser is not unused,
              f is positioned one
              past the last character/token matching skip.
            attrib
              is left untouched.
            skip
              characters/tokens will not be skipped.
            All parsers in Spirit.Qi are models of the Parser concept.