📄 _iterator.h
字号:
}
#undef _RWSTD_ITER_DIFF_TYPE
#ifdef _RWSTD_NO_CLASS_PARTIAL_SPEC
_RWSTD_NAMESPACE_END // std
_RWSTD_NAMESPACE_BEGIN (__rw)
// Reverse bidirectional iterator.
// This is needed to get around non-standard compilers that insist
// on instantiating all members of a class whether they're used
// or not.
template <class _Iterator, class _Category, class _TypeT,
class _Reference _RWSTD_COMPLEX_DEFAULT (_TypeT&),
class _Pointer _RWSTD_COMPLEX_DEFAULT (_TypeT*),
class _Distance _RWSTD_COMPLEX_DEFAULT (ptrdiff_t) >
class __reverse_bi_iterator
: public _STD::iterator<_Category, _TypeT, _Distance, _Pointer, _Reference>
{
public:
typedef _Distance difference_type;
typedef _TypeT value_type;
typedef _Reference reference;
typedef _Pointer pointer;
typedef _Iterator iterator_type;
__reverse_bi_iterator () { }
_EXPLICIT __reverse_bi_iterator (const iterator_type &__rhs)
: current (__rhs) { }
#ifndef _RWSTD_NO_MEMBER_TEMPLATES
# ifndef _RWSTD_NO_CLASS_PARTIAL_SPEC
template <class _TypeU>
__reverse_bi_iterator (const __reverse_bi_iterator<_TypeU>& __rhs)
: current (__rhs.base ()) { }
# else // if defined (_RWSTD_NO_CLASS_PARTIAL_SPEC )
template <class _Iterator2, class _Category2, class _TypeU,
class _Reference2, class _Pointer2, class _Distance2>
__reverse_bi_iterator (const __reverse_bi_iterator<_Iterator2,
_Category2,
_TypeU,
_Reference2,
_Pointer2,
_Distance2>& __rhs)
: current (__rhs.base ()) { }
# endif
#endif // _RWSTD_NO_MEMBER_TEMPLATES
iterator_type base () const {
return current;
}
reference operator* () const {
iterator_type __tmp = base ();
return *--__tmp;
}
_RWSTD_OPERATOR_ARROW (pointer operator->() const);
__reverse_bi_iterator& operator++ () {
return --current, *this;
}
__reverse_bi_iterator operator++ (int) {
__reverse_bi_iterator __tmp (*this);
++*this;
return __tmp;
}
__reverse_bi_iterator& operator-- () {
return ++current, *this;
}
__reverse_bi_iterator operator-- (int) {
__reverse_bi_iterator __tmp (*this);
--*this;
return __tmp;
}
protected:
iterator_type current;
};
_RWSTD_ITER_TEMPLATE
inline bool operator== (const _RWSTD_ITER_ID (__reverse_bi_iterator)& __x,
const _RWSTD_ITER_ID (__reverse_bi_iterator)& __y)
{
return __x.base () == __y.base ();
}
_RWSTD_ITER_TEMPLATE
inline bool operator!= (const _RWSTD_ITER_ID (__reverse_bi_iterator)& __x,
const _RWSTD_ITER_ID (__reverse_bi_iterator)& __y)
{
return !(__x == __y);
}
#undef _RWSTD_ITER_TEMPLATE
#undef _RWSTD_ITER_ID
_RWSTD_NAMESPACE_END // __rw
_RWSTD_NAMESPACE_BEGIN (std)
#endif // _RWSTD_NO_CLASS_PARTIAL_SPEC
#ifndef _RWSTD_NO_CLASS_PARTIAL_SPEC
# define _RWSTD_INSERT_ITERATOR_BASE(ignore) \
iterator<output_iterator_tag, void, void, void, void>
#else
// necessary to allow __iterator_category, __value_type, etc. to work
# define _RWSTD_INSERT_ITERATOR_BASE(cont) \
iterator<output_iterator_tag, \
_TYPENAME cont::value_type, \
_TYPENAME cont::difference_type, \
_TYPENAME cont::pointer, \
_TYPENAME cont::reference>
#endif // _RWSTD_NO_CLASS_PARTIAL_SPEC
template <class _Container>
class back_insert_iterator: public _RWSTD_INSERT_ITERATOR_BASE (_Container)
{
public:
typedef _Container container_type;
_EXPLICIT back_insert_iterator (container_type& __rhs)
: container (&__rhs) { }
back_insert_iterator&
operator= (_TYPENAME container_type::const_reference __x) {
return container->push_back (__x), *this;
}
back_insert_iterator& operator* () {
return *this;
}
back_insert_iterator& operator++ () {
return *this;
}
back_insert_iterator operator++ (int) {
return *this;
}
protected:
container_type* container;
};
template <class _Container>
inline back_insert_iterator<_Container> back_inserter (_Container& __x)
{
return back_insert_iterator<_Container>(__x);
}
template <class _Container>
class front_insert_iterator: public _RWSTD_INSERT_ITERATOR_BASE (_Container)
{
public:
typedef _Container container_type;
_EXPLICIT front_insert_iterator (container_type& __rhs)
: container (&__rhs) { }
front_insert_iterator&
operator= (_TYPENAME container_type::const_reference __x) {
return container->push_front (__x), *this;
}
front_insert_iterator& operator* () {
return *this;
}
front_insert_iterator& operator++ () {
return *this;
}
front_insert_iterator operator++ (int) {
return *this;
}
protected:
container_type* container;
};
template <class _Container>
inline front_insert_iterator<_Container> front_inserter (_Container& __x)
{
return front_insert_iterator<_Container>(__x);
}
template <class _Container>
class insert_iterator: public _RWSTD_INSERT_ITERATOR_BASE (_Container)
{
public:
typedef _Container container_type;
insert_iterator (container_type &__x,
_TYPENAME container_type::iterator __it)
: iter (__it), container (&__x) { }
insert_iterator&
operator= (_TYPENAME container_type::const_reference __x) {
iter = container->insert (iter, __x);
return ++iter, *this;
}
insert_iterator& operator* () {
return *this;
}
insert_iterator& operator++ () {
return *this;
}
insert_iterator& operator++ (int) {
return *this;
}
protected:
_TYPENAME container_type::iterator iter;
container_type* container;
};
template <class _Container, class _Iterator>
inline insert_iterator<_Container> inserter (_Container& __x, _Iterator __it)
{
typedef _TYPENAME _Container::iterator _Iter;
return insert_iterator<_Container> (__x, _Iter (__it));
}
_RWSTD_NAMESPACE_END // std
#endif // _RWSTD_ITERATOR_H_INCLUDED
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -