libstdc++: std::_Deque_iterator< _Tp, _Ref, _Ptr (original) (raw)
#include <[stl_deque.h](a00722%5Fsource.html)>
Public Types | |
---|---|
typedef __ptr_rebind< _Ptr, _Tp > | _Elt_pointer |
typedef __ptr_rebind< _Ptr, _Elt_pointer > | _Map_pointer |
typedef _Deque_iterator | _Self |
typedef __iter< const _Tp > | const_iterator |
typedef ptrdiff_t | difference_type |
typedef __iter< _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 (_Elt_pointer __x, _Map_pointer __y) noexcept | |
_Deque_iterator (const _Deque_iterator &__x) noexcept | |
template<typename _Iter , typename = _Require<is_same<_Self, const_iterator>, is_same<_Iter, iterator>>> | |
_Deque_iterator (const _Iter &__x) noexcept | |
iterator | _M_const_cast () const noexcept |
void | _M_set_node (_Map_pointer __new_node) noexcept |
reference | operator* () const noexcept |
_Self & | operator++ () noexcept |
_Self | operator++ (int) noexcept |
_Self & | operator+= (difference_type __n) noexcept |
_Self & | operator-- () noexcept |
_Self | operator-- (int) noexcept |
_Self & | operator-= (difference_type __n) noexcept |
pointer | operator-> () const noexcept |
_Deque_iterator & | operator= (const _Deque_iterator &)=default |
reference | operator[] (difference_type __n) const noexcept |
Static Public Member Functions | |
---|---|
static size_t | _S_buffer_size () noexcept |
Public Attributes | |
---|---|
_Elt_pointer | _M_cur |
_Elt_pointer | _M_first |
_Elt_pointer | _M_last |
_Map_pointer | _M_node |
Friends | |
---|---|
_Self | operator+ (const _Self &__x, difference_type __n) noexcept |
_Self | operator+ (difference_type __n, const _Self &__x) noexcept |
template<typename _RefR , typename _PtrR > | |
difference_type | operator- (const _Self &__x, const _Deque_iterator< _Tp, _RefR, _PtrR > &__y) noexcept |
difference_type | operator- (const _Self &__x, const _Self &__y) noexcept |
_Self | operator- (const _Self &__x, difference_type __n) noexcept |
strong_ordering | operator<=> (const _Self &__x, const _Self &__y) noexcept |
template<typename _RefR , typename _PtrR > | |
bool | operator== (const _Self &__x, const _Deque_iterator< _Tp, _RefR, _PtrR > &__y) noexcept |
bool | operator== (const _Self &__x, const _Self &__y) noexcept |
template<typename _Tp, typename _Ref, typename _Ptr>
struct std::_Deque_iterator< _Tp, _Ref, _Ptr >
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 113 of file stl_deque.h.
◆ _Elt_pointer
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _Map_pointer
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _Self
template<typename _Tp , typename _Ref , typename _Ptr >
◆ const_iterator
template<typename _Tp , typename _Ref , typename _Ptr >
◆ difference_type
template<typename _Tp , typename _Ref , typename _Ptr >
◆ iterator
template<typename _Tp , typename _Ref , typename _Ptr >
◆ iterator_category
template<typename _Tp , typename _Ref , typename _Ptr >
◆ pointer
template<typename _Tp , typename _Ref , typename _Ptr >
◆ reference
template<typename _Tp , typename _Ref , typename _Ptr >
◆ size_type
template<typename _Tp , typename _Ref , typename _Ptr >
◆ value_type
template<typename _Tp , typename _Ref , typename _Ptr >
template<typename _Tp , typename _Ref , typename _Ptr >
std::_Deque_iterator< _Tp, _Ref, _Ptr >::_Deque_iterator ( _Elt_pointer __x, _Map_pointer __y ) | inlinenoexcept |
---|
◆ _Deque_iterator() [2/4]
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _Deque_iterator() [3/4]
template<typename _Tp , typename _Ref , typename _Ptr >
template<typename _Iter , typename = _Require<is_same<_Self, const_iterator>, is_same<_Iter, iterator>>>
◆ _Deque_iterator() [4/4]
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _M_const_cast()
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _M_set_node()
template<typename _Tp , typename _Ref , typename _Ptr >
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 263 of file stl_deque.h.
◆ _S_buffer_size()
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator*()
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator++() [1/2]
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator++() [2/2]
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator+=()
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator--() [1/2]
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator--() [2/2]
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator-=()
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator->()
template<typename _Tp , typename _Ref , typename _Ptr >
◆ operator[]()
template<typename _Tp , typename _Ref , typename _Ptr >
reference std::_Deque_iterator< _Tp, _Ref, _Ptr >::operator[] ( difference_type __n) const | inlinenoexcept |
---|
◆ operator+ [1/2]
template<typename _Tp , typename _Ref , typename _Ptr >
_Self operator+ ( const _Self & __x, difference_type __n ) | friend |
---|
◆ operator+ [2/2]
template<typename _Tp , typename _Ref , typename _Ptr >
_Self operator+ ( difference_type __n, const _Self & __x ) | friend |
---|
◆ operator- [1/3]
template<typename _Tp , typename _Ref , typename _Ptr >
template<typename _RefR , typename _PtrR >
difference_type operator- ( const _Self & __x, const _Deque_iterator< _Tp, _RefR, _PtrR > & __y ) | friend |
---|
◆ operator- [2/3]
template<typename _Tp , typename _Ref , typename _Ptr >
difference_type operator- ( const _Self & __x, const _Self & __y ) | friend |
---|
◆ operator- [3/3]
template<typename _Tp , typename _Ref , typename _Ptr >
_Self operator- ( const _Self & __x, difference_type __n ) | friend |
---|
◆ operator<=>
template<typename _Tp , typename _Ref , typename _Ptr >
strong_ordering operator<=> ( const _Self & __x, const _Self & __y ) | friend |
---|
◆ operator== [1/2]
template<typename _Tp , typename _Ref , typename _Ptr >
template<typename _RefR , typename _PtrR >
◆ operator== [2/2]
template<typename _Tp , typename _Ref , typename _Ptr >
bool operator== ( const _Self & __x, const _Self & __y ) | friend |
---|
◆ _M_cur
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _M_first
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _M_last
template<typename _Tp , typename _Ref , typename _Ptr >
◆ _M_node
template<typename _Tp , typename _Ref , typename _Ptr >
The documentation for this struct was generated from the following files: