|
BDE 4.14.0 Production release
|
#include <bdlb_tokenizer.h>
Public Types | |
| typedef bslstl::StringRef | value_type |
| typedef int | difference_type |
| typedef Tokenizer_Proxy | pointer |
| typedef const bslstl::StringRef | reference |
| typedef bsl::input_iterator_tag | iterator_category |
Public Member Functions | |
| TokenizerIterator () | |
| TokenizerIterator (const TokenizerIterator &origin) | |
| TokenizerIterator & | operator= (const TokenizerIterator &rhs) |
| TokenizerIterator & | operator++ () |
| const bslstl::StringRef | operator* () const |
| Tokenizer_Proxy | operator-> () const |
Friends | |
| class | Tokenizer |
| bool | operator== (const TokenizerIterator &, const TokenizerIterator &) |
| bool | operator!= (const TokenizerIterator &, const TokenizerIterator &) |
This class provides a C++-standards-conforming input iterator over the tokens in the input string suppled at construction (along with the designation of soft and hard delimiter characters) to a Tokenizer object. Tokens are returned, using a bslstl::StringRef – by value – that means the iterated references remain valid until the underlying input string itself is modified or destroyed. Note that all iterators are invalidated whenever the input string in the parent Tokenizer change.
| typedef int bdlb::TokenizerIterator::difference_type |
| typedef bsl::input_iterator_tag bdlb::TokenizerIterator::iterator_category |
Defines a type alias for the tag type that represents the iterator concept this class models.
| typedef const bslstl::StringRef bdlb::TokenizerIterator::reference |
| bdlb::TokenizerIterator::TokenizerIterator | ( | ) |
| bdlb::TokenizerIterator::TokenizerIterator | ( | const TokenizerIterator & | origin | ) |
Create a TokenizerIterator object having the value of the specified origin iterator.
|
inline |
Return a reference to the non-modifiable current token (i.e., maximal sequence of non-delimiter characters) in the input string. The returned reference remains valid so long as the underlying input is not modified or destroyed – irrespective of the state (or existence) of this object. The behavior is undefined unless the iteration state of this object is initially valid, or if the underlying input has been modified or destroyed since this object was created.
| TokenizerIterator & bdlb::TokenizerIterator::operator++ | ( | ) |
Advance the iteration state of this object to refer to the next token in the underlying input sequence, and return a reference providing modifiable access to this object. The behavior is undefined unless the iteration state of this object is initially valid, or if the underlying input has been modified or destroyed since this object was created.
|
inline |
Return a proxy object containing the non-modifiable current token (i.e., maximal sequence of non-delimiter characters) in the input string. The returned proxy remains valid so long as the underlying input is not modified or destroyed – irrespective of the state (or existence) of this object. The behavior is undefined unless the iteration state of this object is initially valid, or if the underlying input has been modified or destroyed since this object was created.
| TokenizerIterator & bdlb::TokenizerIterator::operator= | ( | const TokenizerIterator & | rhs | ) |
Assign to this object the value of the specified rhs iterator, and return a reference providing modifiable access to this object.
|
friend |
Return true if the specified lhs and rhs objects do not have the same value, and false otherwise. The behaviour is undefined unless the iterators returned by the same Tokenizer object, or if the underlying input has been modified or destroyed since any of those objects were created.
|
friend |
Return true if the specified lhs and rhs objects have the same value, and false otherwise. Two TokenizerIterator objects have the same value if both of them are pointing to the same token within the same tokenized string or if they both point past the tokenized string. The behaviour is undefined unless the iterators returned by the same Tokenizer object, or if the underlying input has been modified or destroyed since any of those objects were created.
|
friend |