Approximate istream_iterator for icursorstream. More...
#include <cursor.hxx>
Public Types | |
typedef istream_type::difference_type | difference_type |
typedef icursorstream | istream_type |
typedef istream_type::size_type | size_type |
Public Member Functions | |
icursor_iterator () throw () | |
icursor_iterator (istream_type &) throw () | |
icursor_iterator (const icursor_iterator &) throw () | |
~icursor_iterator () throw () | |
bool | operator!= (const icursor_iterator &rhs) const throw () |
const result & | operator* () const |
icursor_iterator & | operator++ () |
icursor_iterator | operator++ (int) |
icursor_iterator & | operator+= (difference_type) |
const result * | operator-> () const |
bool | operator< (const icursor_iterator &rhs) const |
bool | operator<= (const icursor_iterator &rhs) const |
icursor_iterator & | operator= (const icursor_iterator &) throw () |
bool | operator== (const icursor_iterator &rhs) const |
bool | operator> (const icursor_iterator &rhs) const |
bool | operator>= (const icursor_iterator &rhs) const |
Private Member Functions | |
void | fill (const result &) |
difference_type | pos () const throw () |
void | refresh () const |
Private Attributes | |
result | m_here |
icursor_iterator * | m_next |
difference_type | m_pos |
icursor_iterator * | m_prev |
icursorstream * | m_stream |
Friends | |
class | internal::gate::icursor_iterator_icursorstream |
Approximate istream_iterator for icursorstream.
Intended as an implementation of an input_iterator (as defined by the C++ Standard Library), this class supports only two basic operations: reading the current element, and moving forward. In addition to the minimal guarantees for istream_iterators, this class supports multiple successive reads of the same position (the current result set is cached in the iterator) even after copying and even after new data have been read from the stream. This appears to be a requirement for input_iterators. Comparisons are also supported in the general case.
The iterator does not care about its own position, however. Moving an iterator forward moves the underlying stream forward and reads the data from the new stream position, regardless of the iterator's old position in the stream.
The stream's stride defines the granularity for all iterator movement or access operations, i.e. "ici += 1" advances the stream by one stride's worth of tuples, and "*ici++" reads one stride's worth of tuples from the stream.
pqxx::icursor_iterator::icursor_iterator | ( | ) | throw () |
|
explicit |
pqxx::icursor_iterator::icursor_iterator | ( | const icursor_iterator & | ) | throw () |
pqxx::icursor_iterator::~icursor_iterator | ( | ) | throw () |
|
private |
|
inline |
|
inline |
icursor_iterator& pqxx::icursor_iterator::operator++ | ( | ) |
icursor_iterator pqxx::icursor_iterator::operator++ | ( | int | ) |
icursor_iterator& pqxx::icursor_iterator::operator+= | ( | difference_type | ) |
|
inline |
bool pqxx::icursor_iterator::operator< | ( | const icursor_iterator & | rhs | ) | const |
|
inline |
icursor_iterator& pqxx::icursor_iterator::operator= | ( | const icursor_iterator & | ) | throw () |
bool pqxx::icursor_iterator::operator== | ( | const icursor_iterator & | rhs | ) | const |
|
inline |
|
inline |
|
inlineprivate |
|
private |
|
friend |
|
private |
|
private |
|
private |
|
private |
|
private |