#include <cursor.hxx>
Public Types | |
typedef icursorstream | istream_type |
typedef istream_type::size_type | size_type |
typedef istream_type::difference_type | difference_type |
Public Member Functions | |
icursor_iterator () throw () | |
icursor_iterator (istream_type &) throw () | |
icursor_iterator (const icursor_iterator &) throw () | |
~icursor_iterator () throw () | |
const result & | operator * () const |
const result * | operator-> () const |
icursor_iterator & | operator++ () |
icursor_iterator | operator++ (int) |
icursor_iterator & | operator+= (difference_type) |
icursor_iterator & | operator= (const icursor_iterator &) throw () |
bool | operator== (const icursor_iterator &rhs) const |
bool | operator!= (const icursor_iterator &rhs) const throw () |
bool | operator< (const icursor_iterator &rhs) const |
bool | operator> (const icursor_iterator &rhs) const |
bool | operator<= (const icursor_iterator &rhs) const |
bool | operator>= (const icursor_iterator &rhs) const |
Friends | |
class | 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. "<tt>ici += 1</tt>" advances the stream by one stride's worth of tuples, and "<tt>*ici++</tt>" reads one stride's worth of tuples from the stream.
Manipulating these iterators within the context of a single cursor stream is not thread-safe. Creating a new iterator, copying one, or destroying one affects the stream as a whole.
pqxx::icursor_iterator::icursor_iterator | ( | ) | throw () |
pqxx::icursor_iterator::icursor_iterator | ( | istream_type & | ) | throw () [explicit] |
pqxx::icursor_iterator::icursor_iterator | ( | const icursor_iterator & | ) | throw () |
pqxx::icursor_iterator::~icursor_iterator | ( | ) | throw () |
const result& pqxx::icursor_iterator::operator * | ( | ) | const |
const result* pqxx::icursor_iterator::operator-> | ( | ) | const |
pqxx::icursor_iterator & pqxx::icursor_iterator::operator++ | ( | ) |
pqxx::icursor_iterator pqxx::icursor_iterator::operator++ | ( | int | ) |
pqxx::icursor_iterator & pqxx::icursor_iterator::operator+= | ( | difference_type | ) |
pqxx::icursor_iterator & pqxx::icursor_iterator::operator= | ( | const icursor_iterator & | ) | throw () |
bool pqxx::icursor_iterator::operator== | ( | const icursor_iterator & | rhs | ) | const |
bool pqxx::icursor_iterator::operator!= | ( | const icursor_iterator & | rhs | ) | const throw () |
bool pqxx::icursor_iterator::operator< | ( | const icursor_iterator & | rhs | ) | const |
bool pqxx::icursor_iterator::operator> | ( | const icursor_iterator & | rhs | ) | const |
bool pqxx::icursor_iterator::operator<= | ( | const icursor_iterator & | rhs | ) | const |
bool pqxx::icursor_iterator::operator>= | ( | const icursor_iterator & | rhs | ) | const |
friend class icursorstream [friend] |