29#ifndef _GLIBCXX_DEBUG_SAFE_ITERATOR_TCC
30#define _GLIBCXX_DEBUG_SAFE_ITERATOR_TCC 1
36 template<
typename _Iterator,
typename _Sequence,
typename _Category>
37 typename _Distance_traits<_Iterator>::__type
49 return _SeqTraits::_S_size(*_M_get_sequence());
51 typename _Distance_traits<_Iterator>::__type __res
54 if (__res.second == __dp_equality)
60 template<
typename _Iterator,
typename _Sequence,
typename _Category>
61 typename _Distance_traits<_Iterator>::__type
70 return _SeqTraits::_S_size(*_M_get_sequence());
75 typename _Distance_traits<_Iterator>::__type __res
78 if (__res.second == __dp_equality)
84 template<
typename _Iterator,
typename _Sequence,
typename _Category>
89 if (this->_M_value_initialized() && __n == 0)
92 if (this->_M_singular())
99 ? _M_get_distance_from_begin()
100 : _M_get_distance_to_end();
105 return __dist.
second > __dp_sign
106 ? __dist.
first >= __n
107 : !__strict && __dist.
first > 0;
110 template<
typename _Iterator,
typename _Sequence,
typename _Category>
111 template<
typename _Diff>
117 return __dist.
second == __dp_exact
118 ? _M_can_advance(__way * __dist.
first)
119 : _M_can_advance(__way * (__dist.first == 0
121 : __dist.first < 0 ? -1 : 1));
124 template<
typename _Iterator,
typename _Sequence,
typename _Category>
125 typename _Distance_traits<_Iterator>::__type
129 typedef typename _Distance_traits<_Iterator>::__type _Dist;
133 if (__base_dist.second == __dp_exact)
136 _Dist __seq_dist = _SeqTraits::_S_size(*this->_M_get_sequence());
137 if (this->_M_is_before_begin())
139 if (__rhs._M_is_begin())
142 return __seq_dist.second == __dp_exact
147 if (this->_M_is_begin())
149 if (__rhs._M_is_before_begin())
152 if (__rhs._M_is_end())
156 __seq_dist.second == __dp_exact
157 ? __dp_sign_max_size : __seq_dist.second);
160 if (this->_M_is_end())
162 if (__rhs._M_is_before_begin())
163 return __seq_dist.second == __dp_exact
165 : std::
make_pair(-__seq_dist.first, __dp_sign);
167 if (__rhs._M_is_begin())
171 __seq_dist.second == __dp_exact
172 ? __dp_sign_max_size : __seq_dist.second);
175 if (__rhs._M_is_before_begin())
176 return __seq_dist.second == __dp_exact
178 : std::
make_pair(-__seq_dist.first, __dp_sign);
180 if (__rhs._M_is_begin())
182 __seq_dist.second == __dp_exact
183 ? __dp_sign_max_size : __seq_dist.second);
185 if (__rhs._M_is_end())
187 __seq_dist.second == __dp_exact
188 ? __dp_sign_max_size : __seq_dist.second);
193 template<
typename _Iterator,
typename _Sequence,
typename _Category>
198 bool __check_dereferenceable)
const
200 if (_M_value_initialized() && __rhs._M_value_initialized())
206 if (_M_singular() || __rhs._M_singular() || !_M_can_compare(__rhs))
210 __dist = _M_get_distance_to(__rhs);
211 if (__dist.
second != __dp_equality)
214 return __dist.
first == 0
216 && (!__check_dereferenceable || _M_dereferenceable()));
223 template<
typename _Iterator,
typename _Sequence>
230 if (this->_M_value_initialized() && __rhs._M_value_initialized())
236 if (this->_M_singular() || __rhs._M_singular()
237 || !this->_M_can_compare(__rhs))
244 return __dist.
first == 0
245 || (__dist.
first > 0 && this->_M_dereferenceable());
249namespace std _GLIBCXX_VISIBILITY(default)
251_GLIBCXX_BEGIN_NAMESPACE_VERSION
253#if __cplusplus < 201103L
254 template<
typename _Ite,
typename _Seq>
256 __niter_base(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq,
257 std::random_access_iterator_tag>& __it)
258 {
return __it.base(); }
260 template<
typename _Ite,
typename _Cont,
typename _DbgSeq>
262 __niter_base(const ::__gnu_debug::_Safe_iterator<
263 ::__gnu_cxx::__normal_iterator<_Ite, _Cont>, _DbgSeq,
264 std::random_access_iterator_tag>& __it)
265 {
return __it.base().base(); }
267 template<
typename _Ite,
typename _Seq>
270 __niter_base(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq,
271 std::random_access_iterator_tag>& __it)
272 noexcept(std::is_nothrow_copy_constructible<_Ite>::value)
273 {
return std::__niter_base(__it.base()); }
276 template<
bool _IsMove,
277 typename _Ite,
typename _Seq,
typename _Cat,
typename _OI>
281 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __first,
282 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __last,
285 typename ::__gnu_debug::_Distance_traits<_Ite>::__type __dist;
286 __glibcxx_check_valid_range2(__first, __last, __dist);
287 __glibcxx_check_can_increment_dist(__result, __dist, 1);
289 if (__dist.second > ::__gnu_debug::__dp_equality)
290 return std::__copy_move_a<_IsMove>(__first.base(), __last.base(),
293 return std::__copy_move_a1<_IsMove>(__first, __last, __result);
296 template<
bool _IsMove,
297 typename _II,
typename _Ite,
typename _Seq,
typename _Cat>
299 __gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>
300 __copy_move_a(_II __first, _II __last,
301 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __result)
303 typename ::__gnu_debug::_Distance_traits<_II>::__type __dist;
304 __glibcxx_check_valid_range2(__first, __last, __dist);
305 __glibcxx_check_can_increment_dist(__result, __dist, 1);
307 if (__dist.second > ::__gnu_debug::__dp_sign
308 && __result._M_can_advance(__dist.first,
true))
309 return ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>(
310 std::__copy_move_a<_IsMove>(__first, __last, __result.base()),
311 __result._M_sequence);
313 return std::__copy_move_a1<_IsMove>(__first, __last, __result);
316 template<
bool _IsMove,
317 typename _IIte,
typename _ISeq,
typename _ICat,
318 typename _OIte,
typename _OSeq,
typename _OCat>
320 ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>
322 const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>& __first,
323 const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>& __last,
324 const ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>& __result)
326 typename ::__gnu_debug::_Distance_traits<_IIte>::__type __dist;
327 __glibcxx_check_valid_range2(__first, __last, __dist);
328 __glibcxx_check_can_increment_dist(__result, __dist, 1);
330 if (__dist.second > ::__gnu_debug::__dp_equality)
332 if (__dist.second > ::__gnu_debug::__dp_sign
333 && __result._M_can_advance(__dist.first,
true))
334 return ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>(
335 std::__copy_move_a<_IsMove>(__first.base(), __last.base(),
337 __result._M_sequence);
339 return std::__copy_move_a<_IsMove>(__first.base(), __last.base(),
343 return std::__copy_move_a1<_IsMove>(__first, __last, __result);
346 template<
bool _IsMove,
347 typename _Ite,
typename _Seq,
typename _Cat,
typename _OI>
350 __copy_move_backward_a(
351 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __first,
352 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __last,
355 typename ::__gnu_debug::_Distance_traits<_Ite>::__type __dist;
356 __glibcxx_check_valid_range2(__first, __last, __dist);
357 __glibcxx_check_can_increment_dist(__result, __dist, -1);
359 if (__dist.second > ::__gnu_debug::__dp_equality)
360 return std::__copy_move_backward_a<_IsMove>(
361 __first.base(), __last.base(), __result);
363 return std::__copy_move_backward_a1<_IsMove>(__first, __last, __result);
366 template<
bool _IsMove,
367 typename _II,
typename _Ite,
typename _Seq,
typename _Cat>
369 __gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>
370 __copy_move_backward_a(_II __first, _II __last,
371 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __result)
373 typename ::__gnu_debug::_Distance_traits<_II>::__type __dist;
374 __glibcxx_check_valid_range2(__first, __last, __dist);
375 __glibcxx_check_can_increment_dist(__result, __dist, -1);
377 if (__dist.second > ::__gnu_debug::__dp_sign
378 && __result._M_can_advance(-__dist.first,
true))
379 return ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>(
380 std::__copy_move_backward_a<_IsMove>(__first, __last,
382 __result._M_sequence);
384 return std::__copy_move_backward_a1<_IsMove>(__first, __last, __result);
387 template<
bool _IsMove,
388 typename _IIte,
typename _ISeq,
typename _ICat,
389 typename _OIte,
typename _OSeq,
typename _OCat>
391 ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>
392 __copy_move_backward_a(
393 const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>& __first,
394 const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>& __last,
395 const ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>& __result)
397 typename ::__gnu_debug::_Distance_traits<_IIte>::__type __dist;
398 __glibcxx_check_valid_range2(__first, __last, __dist);
399 __glibcxx_check_can_increment_dist(__result, __dist, -1);
401 if (__dist.second > ::__gnu_debug::__dp_equality)
403 if (__dist.second > ::__gnu_debug::__dp_sign
404 && __result._M_can_advance(-__dist.first,
true))
405 return ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>(
406 std::__copy_move_backward_a<_IsMove>(__first.base(), __last.base(),
408 __result._M_sequence);
410 return std::__copy_move_backward_a<_IsMove>(
411 __first.base(), __last.base(), __result);
414 return std::__copy_move_backward_a1<_IsMove>(__first, __last, __result);
417 template<
typename _Ite,
typename _Seq,
typename _Cat,
typename _Tp>
420 __fill_a(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __first,
421 const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __last,
424 typename ::__gnu_debug::_Distance_traits<_Ite>::__type __dist;
425 __glibcxx_check_valid_range2(__first, __last, __dist);
427 if (__dist.second > ::__gnu_debug::__dp_equality)
428 std::__fill_a(__first.base(), __last.base(), __value);
430 std::__fill_a1(__first, __last, __value);
433 template<
typename _Ite,
typename _Seq,
typename _Cat,
typename _Size,
436 ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>
437 __fill_n_a(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __first,
438 _Size __n,
const _Tp& __value,
439 std::input_iterator_tag)
441#if __cplusplus >= 201103L
448 __glibcxx_check_can_increment(__first, __n);
449 if (__first._M_can_advance(__n,
true))
450 return ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>(
451 std::__fill_n_a(__first.base(), __n, __value, _Cat()),
452 __first._M_sequence);
454 return std::__fill_n_a1(__first, __n, __value);
457 template<
typename _II1,
typename _Seq1,
typename _Cat1,
typename _II2>
461 const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>& __first1,
462 const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>& __last1,
465 typename ::__gnu_debug::_Distance_traits<_II1>::__type __dist;
466 __glibcxx_check_valid_range2(__first1, __last1, __dist);
467 __glibcxx_check_can_increment_dist(__first2, __dist, 1);
469 if (__dist.second > ::__gnu_debug::__dp_equality)
470 return std::__equal_aux(__first1.base(), __last1.base(), __first2);
472 return std::__equal_aux1(__first1, __last1, __first2);
475 template<
typename _II1,
typename _II2,
typename _Seq2,
typename _Cat2>
478 __equal_aux(_II1 __first1, _II1 __last1,
479 const ::__gnu_debug::_Safe_iterator<_II2, _Seq2, _Cat2>& __first2)
481 typename ::__gnu_debug::_Distance_traits<_II1>::__type __dist;
482 __glibcxx_check_valid_range2(__first1, __last1, __dist);
483 __glibcxx_check_can_increment_dist(__first2, __dist, 1);
485 if (__dist.second > ::__gnu_debug::__dp_sign
486 && __first2._M_can_advance(__dist.first,
true))
487 return std::__equal_aux(__first1, __last1, __first2.base());
489 return std::__equal_aux1(__first1, __last1, __first2);
492 template<
typename _II1,
typename _Seq1,
typename _Cat1,
493 typename _II2,
typename _Seq2,
typename _Cat2>
497 const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>& __first1,
498 const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>& __last1,
499 const ::__gnu_debug::_Safe_iterator<_II2, _Seq2, _Cat2>& __first2)
501 typename ::__gnu_debug::_Distance_traits<_II1>::__type __dist;
502 __glibcxx_check_valid_range2(__first1, __last1, __dist);
503 __glibcxx_check_can_increment_dist(__first2, __dist, 1);
505 if (__dist.second > ::__gnu_debug::__dp_equality)
507 if (__dist.second > ::__gnu_debug::__dp_sign &&
508 __first2._M_can_advance(__dist.first,
true))
509 return std::__equal_aux(__first1.base(), __last1.base(),
511 return std::__equal_aux(__first1.base(), __last1.base(), __first2);
514 return __equal_aux1(__first1, __last1, __first2);
517 template<
typename _Ite1,
typename _Seq1,
typename _Cat1,
521 __lexicographical_compare_aux(
522 const ::__gnu_debug::_Safe_iterator<_Ite1, _Seq1, _Cat1>& __first1,
523 const ::__gnu_debug::_Safe_iterator<_Ite1, _Seq1, _Cat1>& __last1,
524 _II2 __first2, _II2 __last2)
526 typename ::__gnu_debug::_Distance_traits<_Ite1>::__type __dist1;
527 __glibcxx_check_valid_range2(__first1, __last1, __dist1);
528 __glibcxx_check_valid_range(__first2, __last2);
530 if (__dist1.second > ::__gnu_debug::__dp_equality)
531 return std::__lexicographical_compare_aux(__first1.base(),
534 return std::__lexicographical_compare_aux1(__first1, __last1,
538 template<
typename _II1,
539 typename _Ite2,
typename _Seq2,
typename _Cat2>
542 __lexicographical_compare_aux(
543 _II1 __first1, _II1 __last1,
544 const ::__gnu_debug::_Safe_iterator<_Ite2, _Seq2, _Cat2>& __first2,
545 const ::__gnu_debug::_Safe_iterator<_Ite2, _Seq2, _Cat2>& __last2)
547 __glibcxx_check_valid_range(__first1, __last1);
548 typename ::__gnu_debug::_Distance_traits<_II1>::__type __dist2;
549 __glibcxx_check_valid_range2(__first2, __last2, __dist2);
551 if (__dist2.second > ::__gnu_debug::__dp_equality)
552 return std::__lexicographical_compare_aux(__first1, __last1,
555 return std::__lexicographical_compare_aux1(__first1, __last1,
559 template<
typename _Ite1,
typename _Seq1,
typename _Cat1,
560 typename _Ite2,
typename _Seq2,
typename _Cat2>
563 __lexicographical_compare_aux(
564 const ::__gnu_debug::_Safe_iterator<_Ite1, _Seq1, _Cat1>& __first1,
565 const ::__gnu_debug::_Safe_iterator<_Ite1, _Seq1, _Cat1>& __last1,
566 const ::__gnu_debug::_Safe_iterator<_Ite2, _Seq2, _Cat2>& __first2,
567 const ::__gnu_debug::_Safe_iterator<_Ite2, _Seq2, _Cat2>& __last2)
569 typename ::__gnu_debug::_Distance_traits<_Ite1>::__type __dist1;
570 __glibcxx_check_valid_range2(__first1, __last1, __dist1);
571 typename ::__gnu_debug::_Distance_traits<_Ite2>::__type __dist2;
572 __glibcxx_check_valid_range2(__first2, __last2, __dist2);
574 if (__dist1.second > ::__gnu_debug::__dp_equality)
576 if (__dist2.second > ::__gnu_debug::__dp_equality)
577 return std::__lexicographical_compare_aux(__first1.base(),
581 return std::__lexicographical_compare_aux(__first1.base(),
586 if (__dist2.second > ::__gnu_debug::__dp_equality)
587 return std::__lexicographical_compare_aux(__first1, __last1,
590 return std::__lexicographical_compare_aux1(__first1, __last1,
594_GLIBCXX_END_NAMESPACE_VERSION
pair(_T1, _T2) -> pair< _T1, _T2 >
Two pairs are equal iff their members are equal.
constexpr pair< typename __decay_and_strip< _T1 >::__type, typename __decay_and_strip< _T2 >::__type > make_pair(_T1 &&__x, _T2 &&__y)
A convenience wrapper for creating a pair from two objects.
auto declval() noexcept -> decltype(__declval< _Tp >(0))
_Tp * end(valarray< _Tp > &__va) noexcept
Return an iterator pointing to one past the last element of the valarray.
_Tp * begin(valarray< _Tp > &__va) noexcept
Return an iterator pointing to the first element of the valarray.
ISO C++ entities toplevel namespace is std.
GNU debug classes for public use.
constexpr _Distance_traits< _Iterator >::__type __get_distance(_Iterator __lhs, _Iterator __rhs, std::random_access_iterator_tag)
_T1 first
The first member.
_T2 second
The second member.