59#ifndef _STL_ITERATOR_BASE_TYPES_H
60#define _STL_ITERATOR_BASE_TYPES_H 1
63#pragma GCC system_header
68#if __cplusplus >= 201103L
72#if __cplusplus > 201703L && __cpp_concepts >= 201907L
76namespace std _GLIBCXX_VISIBILITY(default)
78_GLIBCXX_BEGIN_NAMESPACE_VERSION
111#if __cplusplus > 201703L
130 template<
typename _Category,
typename _Tp,
typename _Distance = ptrdiff_t,
131 typename _Pointer = _Tp*,
typename _Reference = _Tp&>
154 template<
typename _Iterator>
157#if __cplusplus >= 201103L
160 template<
typename _Iterator,
typename = __
void_t<>>
161 struct __iterator_traits { };
163#if ! __cpp_lib_concepts
165 template<
typename _Iterator>
166 struct __iterator_traits<_Iterator,
167 __void_t<typename _Iterator::iterator_category,
168 typename _Iterator::value_type,
169 typename _Iterator::difference_type,
170 typename _Iterator::pointer,
171 typename _Iterator::reference>>
173 typedef typename _Iterator::iterator_category iterator_category;
174 typedef typename _Iterator::value_type value_type;
175 typedef typename _Iterator::difference_type difference_type;
176 typedef typename _Iterator::pointer pointer;
177 typedef typename _Iterator::reference reference;
181 template<
typename _Iterator>
183 :
public __iterator_traits<_Iterator> { };
186 template<
typename _Iterator>
189 typedef typename _Iterator::iterator_category iterator_category;
190 typedef typename _Iterator::value_type
value_type;
192 typedef typename _Iterator::pointer pointer;
193 typedef typename _Iterator::reference reference;
197#if __cplusplus > 201703L
199 template<
typename _Tp>
200#if __cpp_concepts >= 201907L
201 requires is_object_v<_Tp>
207 using value_type = remove_cv_t<_Tp>;
208 using difference_type = ptrdiff_t;
209 using pointer = _Tp*;
210 using reference = _Tp&;
214 template<
typename _Tp>
220 typedef _Tp* pointer;
221 typedef _Tp& reference;
225 template<
typename _Tp>
226 struct iterator_traits<const _Tp*>
228 typedef random_access_iterator_tag iterator_category;
229 typedef _Tp value_type;
230 typedef ptrdiff_t difference_type;
231 typedef const _Tp* pointer;
232 typedef const _Tp& reference;
241 template<
typename _Iter>
242 __attribute__((__always_inline__))
243 inline _GLIBCXX_CONSTEXPR
245 __iterator_category(
const _Iter&)
248#if __cplusplus >= 201103L
249 template<
typename _Iter>
250 using __iter_category_t
253 template<
typename _InIter>
254 using _RequireInputIter =
255 __enable_if_t<is_convertible<__iter_category_t<_InIter>,
259 template<
typename _InIter>
260 concept __has_input_iter_cat
263#ifdef __cpp_lib_concepts
265 template<
typename _InIterator>
266 concept __any_input_iterator
267 = input_iterator<_InIterator> || __has_input_iter_cat<_InIterator>;
271 template<
typename _It,
272 typename _Cat = __iter_category_t<_It>>
273 struct __is_random_access_iter
274 :
is_base_of<random_access_iterator_tag, _Cat>
276 typedef is_base_of<random_access_iterator_tag, _Cat> _Base;
277 enum { __value = _Base::value };
280 template<
typename _It,
typename _Traits = iterator_traits<_It>,
281 typename _Cat =
typename _Traits::iterator_category>
282 struct __is_random_access_iter
283 {
enum { __value = __is_base_of(random_access_iterator_tag, _Cat) }; };
289_GLIBCXX_END_NAMESPACE_VERSION
292#if __glibcxx_algorithm_default_value_type
293# define _GLIBCXX26_DEF_VAL_T(T) = T
294# define _GLIBCXX26_ALGO_DEF_VAL_T(_Iterator) \
295 = typename iterator_traits<_Iterator>::value_type
297# define _GLIBCXX26_DEF_VAL_T(T)
298# define _GLIBCXX26_ALGO_DEF_VAL_T(_Iterator)
ISO C++ entities toplevel namespace is std.
Traits class for iterators.
Marking output iterators.
Forward iterators support a superset of input iterator operations.
Bidirectional iterators support a superset of forward iterator operations.
Random-access iterators support a superset of bidirectional iterator operations.
Contiguous iterators point to objects stored contiguously in memory.
_Category iterator_category
One of the tag types.
_Pointer pointer
This type represents a pointer-to-value_type.
_Distance difference_type
Distance between iterators is represented as this type.
_Reference reference
This type represents a reference-to-value_type.
_Tp value_type
The type "pointed to" by the iterator.