29#ifndef _GLIBCXX_DEBUG_SAFE_LOCAL_ITERATOR_H
30#define _GLIBCXX_DEBUG_SAFE_LOCAL_ITERATOR_H 1
34#define _GLIBCXX_DEBUG_VERIFY_OPERANDS(_Lhs, _Rhs) \
35 _GLIBCXX_DEBUG_VERIFY(!_Lhs._M_singular() && !_Rhs._M_singular() \
36 || (_Lhs._M_value_initialized() \
37 && _Rhs._M_value_initialized()), \
38 _M_message(__msg_iter_compare_bad) \
39 ._M_iterator(_Lhs, "lhs") \
40 ._M_iterator(_Rhs, "rhs")); \
41 _GLIBCXX_DEBUG_VERIFY(_Lhs._M_can_compare(_Rhs), \
42 _M_message(__msg_compare_different) \
43 ._M_iterator(_Lhs, "lhs") \
44 ._M_iterator(_Rhs, "rhs")); \
45 _GLIBCXX_DEBUG_VERIFY(_Lhs._M_in_same_bucket(_Rhs), \
46 _M_message(__msg_local_iter_compare_bad) \
47 ._M_iterator(_Lhs, "lhs") \
48 ._M_iterator(_Rhs, "rhs"))
63 template<
typename _Iterator,
typename _Sequence>
68 typedef _Iterator _Iter_base;
71 typedef typename _Sequence::size_type size_type;
75 typedef std::__are_same<
76 typename _Sequence::_Base::const_local_iterator,
77 _Iterator> _IsConstant;
79 typedef typename __gnu_cxx::__conditional_type<_IsConstant::__value,
80 typename _Sequence::_Base::local_iterator,
81 typename _Sequence::_Base::const_local_iterator>::__type
87 struct _Unchecked { };
91 : _Iter_base(__x.
base())
95 typedef _Iterator iterator_type;
96 typedef typename _Traits::iterator_category iterator_category;
97 typedef typename _Traits::value_type value_type;
98 typedef typename _Traits::difference_type difference_type;
99 typedef typename _Traits::reference reference;
100 typedef typename _Traits::pointer pointer;
120 : _Iter_base(__x.
base())
126 _M_message(__msg_init_copy_singular)
127 ._M_iterator(*
this,
"this")
128 ._M_iterator(__x,
"other"));
141 _M_message(__msg_init_copy_singular)
142 ._M_iterator(*
this,
"this")
143 ._M_iterator(__x,
"other"));
154 template<
typename _MutableIterator>
157 typename __gnu_cxx::__enable_if<_IsConstant::__value &&
158 std::__are_same<_MutableIterator, _OtherIterator>::__value,
159 _Sequence>::__type>& __x) noexcept
160 : _Iter_base(__x.
base())
166 _M_message(__msg_init_const_singular)
167 ._M_iterator(*
this,
"this")
168 ._M_iterator(__x,
"other"));
182 _M_message(__msg_copy_singular)
183 ._M_iterator(*
this,
"this")
184 ._M_iterator(__x,
"other"));
211 _M_message(__msg_copy_singular)
212 ._M_iterator(*
this,
"this")
213 ._M_iterator(__x,
"other"));
232 __x.
base() = _Iterator();
244 _M_message(__msg_bad_deref)
245 ._M_iterator(*
this,
"this"));
257 _M_message(__msg_bad_deref)
258 ._M_iterator(*
this,
"this"));
259 return base().operator->();
271 _M_message(__msg_bad_inc)
272 ._M_iterator(*
this,
"this"));
286 _M_message(__msg_bad_inc)
287 ._M_iterator(*
this,
"this"));
296 static constexpr bool
298 {
return _IsConstant::__value; }
304 base() noexcept {
return *
this; }
307 base() const noexcept {
return *
this; }
319 operator _Iterator()
const {
return *
this; }
357 typename __gnu_cxx::__conditional_type<
358 _IsConstant::__value,
const _Sequence*, _Sequence*>::__type
359 _M_get_sequence()
const
364 {
return base() == _M_get_sequence()->_M_base().begin(
bucket()); }
368 {
return base() == _M_get_sequence()->_M_base().end(
bucket()); }
371 template<
typename _Other>
374 _Sequence>& __other)
const
375 {
return bucket() == __other.bucket(); }
378 operator==(
const _Self& __lhs,
const _OtherSelf& __rhs)
noexcept
380 _GLIBCXX_DEBUG_VERIFY_OPERANDS(__lhs, __rhs);
381 return __lhs.base() == __rhs.base();
385 operator==(
const _Self& __lhs,
const _Self& __rhs)
noexcept
387 _GLIBCXX_DEBUG_VERIFY_OPERANDS(__lhs, __rhs);
388 return __lhs.base() == __rhs.base();
392 operator!=(
const _Self& __lhs,
const _OtherSelf& __rhs)
noexcept
394 _GLIBCXX_DEBUG_VERIFY_OPERANDS(__lhs, __rhs);
395 return __lhs.base() != __rhs.base();
399 operator!=(
const _Self& __lhs,
const _Self& __rhs)
noexcept
401 _GLIBCXX_DEBUG_VERIFY_OPERANDS(__lhs, __rhs);
402 return __lhs.base() != __rhs.base();
407 template<
typename _Iterator,
typename _Sequence>
412 {
return __first._M_valid_range(__last, __dist_info); }
414 template<
typename _Iterator,
typename _Sequence>
416 __valid_range(
const _Safe_local_iterator<_Iterator, _Sequence>& __first,
417 const _Safe_local_iterator<_Iterator, _Sequence>& __last)
419 typename _Distance_traits<_Iterator>::__type __dist_info;
420 return __first._M_valid_range(__last, __dist_info);
423#if __cplusplus < 201103L
424 template<
typename _Iterator,
typename _Sequence>
425 struct _Unsafe_type<_Safe_local_iterator<_Iterator, _Sequence> >
426 {
typedef _Iterator _Type; };
429 template<
typename _Iterator,
typename _Sequence>
431 __unsafe(
const _Safe_local_iterator<_Iterator, _Sequence>& __it)
432 {
return __it.base(); }
436#undef _GLIBCXX_DEBUG_VERIFY_OPERANDS
constexpr _Tp * __addressof(_Tp &__r) noexcept
Same as C++11 std::addressof.
ISO C++ entities toplevel namespace is std.
GNU debug classes for public use.
constexpr bool __valid_range(_InputIterator __first, _InputIterator __last, typename _Distance_traits< _InputIterator >::__type &__dist)
Traits class for iterators.
Struct holding two objects of arbitrary type.
_Safe_local_iterator(const _Safe_local_iterator &__x) noexcept
Copy construction.
bool _M_is_end() const
Is this iterator equal to the sequence's end(bucket) iterator?
size_type bucket() const
Return the bucket.
_Safe_local_iterator & operator=(_Safe_local_iterator &&__x) noexcept
Move assignment.
bool _M_incrementable() const
Is the iterator incrementable?
_Safe_local_iterator(_Safe_local_iterator &&__x) noexcept
Move construction.
bool _M_value_initialized() const
Is the iterator value-initialized?
_Safe_local_iterator(_Iterator __i, const _Safe_sequence_base *__cont)
Safe iterator construction from an unsafe iterator and its sequence.
bool _M_in_same_bucket(const _Safe_local_iterator< _Other, _Sequence > &__other) const
Is this iterator part of the same bucket as the other one?
_Safe_local_iterator & operator++()
Iterator preincrement.
_Safe_local_iterator & operator=(const _Safe_local_iterator &__x)
Copy assignment.
pointer operator->() const
Iterator dereference.
static constexpr bool _S_constant()
Determine if this is a constant iterator.
bool _M_dereferenceable() const
Is the iterator dereferenceable?
void _M_attach_single(_Safe_sequence_base *__seq)
reference operator*() const
Iterator dereference.
_Safe_local_iterator operator++(int)
Iterator postincrement.
_Iterator & base() noexcept
Return the underlying iterator.
_Safe_local_iterator(const _Safe_local_iterator< _MutableIterator, typename __gnu_cxx::__enable_if< _IsConstant::__value &&std::__are_same< _MutableIterator, _OtherIterator >::__value, _Sequence >::__type > &__x) noexcept
Converting constructor from a mutable iterator to a constant iterator.
_Safe_local_iterator() noexcept
void _M_attach(_Safe_sequence_base *__seq)
bool _M_is_begin() const
Is this iterator equal to the sequence's begin(bucket) iterator?
_Safe_sequence_base * _M_sequence
__gnu_cxx::__mutex & _M_get_mutex()
Base class that supports tracking of iterators that reference a sequence.
unsigned int _M_version
The container version number. This number may never be 0.
Basic functionality for a safe iterator.
void _M_attach_single(_Safe_sequence_base *__seq, bool __constant)
void _M_attach(_Safe_sequence_base *__seq, bool __constant)