libstdc++
|
Public Types | |
typedef _Tp ** | _Map_pointer |
typedef _Deque_iterator | _Self |
typedef _Deque_iterator< _Tp, const _Tp &, const _Tp * > | const_iterator |
typedef ptrdiff_t | difference_type |
typedef _Deque_iterator< _Tp, _Tp &, _Tp * > | iterator |
typedef std::random_access_iterator_tag | iterator_category |
typedef _Ptr | pointer |
typedef _Ref | reference |
typedef size_t | size_type |
typedef _Tp | value_type |
Public Member Functions | |
_Deque_iterator (_Tp *__x, _Map_pointer __y) noexcept | |
_Deque_iterator (const iterator &__x) noexcept | |
iterator | _M_const_cast () const noexcept |
void | _M_set_node (_Map_pointer __new_node) noexcept |
reference | operator* () const noexcept |
_Self | operator+ (difference_type __n) const noexcept |
_Self & | operator++ () noexcept |
_Self | operator++ (int) noexcept |
_Self & | operator+= (difference_type __n) noexcept |
_Self | operator- (difference_type __n) const noexcept |
_Self & | operator-- () noexcept |
_Self | operator-- (int) noexcept |
_Self & | operator-= (difference_type __n) noexcept |
pointer | operator-> () const noexcept |
reference | operator[] (difference_type __n) const noexcept |
Static Public Member Functions | |
static size_t | _S_buffer_size () noexcept |
Public Attributes | |
_Tp * | _M_cur |
_Tp * | _M_first |
_Tp * | _M_last |
_Map_pointer | _M_node |
A deque::iterator.
Quite a bit of intelligence here. Much of the functionality of deque is actually passed off to this class. A deque holds two of these internally, marking its valid range. Access to elements is done as offsets of either of those two, relying on operator overloading in this class.
All the functions are op overloads except for _M_set_node.
Definition at line 106 of file stl_deque.h.
|
inlinenoexcept |
Prepares to traverse new_node. Sets everything except _M_cur, which should therefore be set by the caller immediately afterwards, based on _M_first and _M_last.
Definition at line 238 of file stl_deque.h.