xref: /openbsd-src/gnu/llvm/libcxx/include/__ranges/iota_view.h (revision 4bdff4bed0e3d54e55670334c7d0077db4170f86)
1*4bdff4beSrobert // -*- C++ -*-
2*4bdff4beSrobert //===----------------------------------------------------------------------===//
3*4bdff4beSrobert //
4*4bdff4beSrobert // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5*4bdff4beSrobert // See https://llvm.org/LICENSE.txt for license information.
6*4bdff4beSrobert // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7*4bdff4beSrobert //
8*4bdff4beSrobert //===----------------------------------------------------------------------===//
9*4bdff4beSrobert 
10*4bdff4beSrobert #ifndef _LIBCPP___RANGES_IOTA_VIEW_H
11*4bdff4beSrobert #define _LIBCPP___RANGES_IOTA_VIEW_H
12*4bdff4beSrobert 
13*4bdff4beSrobert #include <__assert>
14*4bdff4beSrobert #include <__compare/three_way_comparable.h>
15*4bdff4beSrobert #include <__concepts/arithmetic.h>
16*4bdff4beSrobert #include <__concepts/constructible.h>
17*4bdff4beSrobert #include <__concepts/convertible_to.h>
18*4bdff4beSrobert #include <__concepts/copyable.h>
19*4bdff4beSrobert #include <__concepts/equality_comparable.h>
20*4bdff4beSrobert #include <__concepts/invocable.h>
21*4bdff4beSrobert #include <__concepts/same_as.h>
22*4bdff4beSrobert #include <__concepts/semiregular.h>
23*4bdff4beSrobert #include <__concepts/totally_ordered.h>
24*4bdff4beSrobert #include <__config>
25*4bdff4beSrobert #include <__functional/ranges_operations.h>
26*4bdff4beSrobert #include <__iterator/concepts.h>
27*4bdff4beSrobert #include <__iterator/incrementable_traits.h>
28*4bdff4beSrobert #include <__iterator/iterator_traits.h>
29*4bdff4beSrobert #include <__iterator/unreachable_sentinel.h>
30*4bdff4beSrobert #include <__ranges/copyable_box.h>
31*4bdff4beSrobert #include <__ranges/enable_borrowed_range.h>
32*4bdff4beSrobert #include <__ranges/view_interface.h>
33*4bdff4beSrobert #include <__utility/forward.h>
34*4bdff4beSrobert #include <__utility/move.h>
35*4bdff4beSrobert #include <type_traits>
36*4bdff4beSrobert 
37*4bdff4beSrobert #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
38*4bdff4beSrobert #  pragma GCC system_header
39*4bdff4beSrobert #endif
40*4bdff4beSrobert 
41*4bdff4beSrobert _LIBCPP_BEGIN_NAMESPACE_STD
42*4bdff4beSrobert 
43*4bdff4beSrobert #if _LIBCPP_STD_VER > 17
44*4bdff4beSrobert 
45*4bdff4beSrobert namespace ranges {
46*4bdff4beSrobert   template<class _Int>
47*4bdff4beSrobert   struct __get_wider_signed {
__call__get_wider_signed48*4bdff4beSrobert     static auto __call() {
49*4bdff4beSrobert            if constexpr (sizeof(_Int) < sizeof(short)) return type_identity<short>{};
50*4bdff4beSrobert       else if constexpr (sizeof(_Int) < sizeof(int))   return type_identity<int>{};
51*4bdff4beSrobert       else if constexpr (sizeof(_Int) < sizeof(long))  return type_identity<long>{};
52*4bdff4beSrobert       else                                             return type_identity<long long>{};
53*4bdff4beSrobert 
54*4bdff4beSrobert       static_assert(sizeof(_Int) <= sizeof(long long),
55*4bdff4beSrobert         "Found integer-like type that is bigger than largest integer like type.");
56*4bdff4beSrobert     }
57*4bdff4beSrobert 
58*4bdff4beSrobert     using type = typename decltype(__call())::type;
59*4bdff4beSrobert   };
60*4bdff4beSrobert 
61*4bdff4beSrobert   template<class _Start>
62*4bdff4beSrobert   using _IotaDiffT = typename _If<
63*4bdff4beSrobert       (!integral<_Start> || sizeof(iter_difference_t<_Start>) > sizeof(_Start)),
64*4bdff4beSrobert       type_identity<iter_difference_t<_Start>>,
65*4bdff4beSrobert       __get_wider_signed<_Start>
66*4bdff4beSrobert     >::type;
67*4bdff4beSrobert 
68*4bdff4beSrobert   template<class _Iter>
requires(_Iter __i)69*4bdff4beSrobert   concept __decrementable = incrementable<_Iter> && requires(_Iter __i) {
70*4bdff4beSrobert     { --__i } -> same_as<_Iter&>;
71*4bdff4beSrobert     { __i-- } -> same_as<_Iter>;
72*4bdff4beSrobert   };
73*4bdff4beSrobert 
74*4bdff4beSrobert   template<class _Iter>
75*4bdff4beSrobert   concept __advanceable =
76*4bdff4beSrobert     __decrementable<_Iter> && totally_ordered<_Iter> &&
requires(_Iter __i,const _Iter __j,const _IotaDiffT<_Iter> __n)77*4bdff4beSrobert     requires(_Iter __i, const _Iter __j, const _IotaDiffT<_Iter> __n) {
78*4bdff4beSrobert       { __i += __n } -> same_as<_Iter&>;
79*4bdff4beSrobert       { __i -= __n } -> same_as<_Iter&>;
80*4bdff4beSrobert       _Iter(__j + __n);
81*4bdff4beSrobert       _Iter(__n + __j);
82*4bdff4beSrobert       _Iter(__j - __n);
83*4bdff4beSrobert       { __j - __j } -> convertible_to<_IotaDiffT<_Iter>>;
84*4bdff4beSrobert     };
85*4bdff4beSrobert 
86*4bdff4beSrobert   template<class>
87*4bdff4beSrobert   struct __iota_iterator_category {};
88*4bdff4beSrobert 
89*4bdff4beSrobert   template<incrementable _Tp>
90*4bdff4beSrobert   struct __iota_iterator_category<_Tp> {
91*4bdff4beSrobert     using iterator_category = input_iterator_tag;
92*4bdff4beSrobert   };
93*4bdff4beSrobert 
94*4bdff4beSrobert   template <weakly_incrementable _Start, semiregular _BoundSentinel = unreachable_sentinel_t>
95*4bdff4beSrobert     requires __weakly_equality_comparable_with<_Start, _BoundSentinel> && copyable<_Start>
96*4bdff4beSrobert   class iota_view : public view_interface<iota_view<_Start, _BoundSentinel>> {
97*4bdff4beSrobert     struct __iterator : public __iota_iterator_category<_Start> {
98*4bdff4beSrobert       friend class iota_view;
99*4bdff4beSrobert 
100*4bdff4beSrobert       using iterator_concept =
101*4bdff4beSrobert         _If<__advanceable<_Start>,   random_access_iterator_tag,
102*4bdff4beSrobert         _If<__decrementable<_Start>, bidirectional_iterator_tag,
103*4bdff4beSrobert         _If<incrementable<_Start>,   forward_iterator_tag,
104*4bdff4beSrobert         /*Else*/                     input_iterator_tag>>>;
105*4bdff4beSrobert 
106*4bdff4beSrobert       using value_type = _Start;
107*4bdff4beSrobert       using difference_type = _IotaDiffT<_Start>;
108*4bdff4beSrobert 
109*4bdff4beSrobert       _Start __value_ = _Start();
110*4bdff4beSrobert 
111*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
112*4bdff4beSrobert       __iterator() requires default_initializable<_Start> = default;
113*4bdff4beSrobert 
114*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
115*4bdff4beSrobert       constexpr explicit __iterator(_Start __value) : __value_(std::move(__value)) {}
116*4bdff4beSrobert 
117*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
118*4bdff4beSrobert       constexpr _Start operator*() const noexcept(is_nothrow_copy_constructible_v<_Start>) {
119*4bdff4beSrobert         return __value_;
120*4bdff4beSrobert       }
121*4bdff4beSrobert 
122*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
123*4bdff4beSrobert       constexpr __iterator& operator++() {
124*4bdff4beSrobert         ++__value_;
125*4bdff4beSrobert         return *this;
126*4bdff4beSrobert       }
127*4bdff4beSrobert 
128*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
129*4bdff4beSrobert       constexpr void operator++(int) { ++*this; }
130*4bdff4beSrobert 
131*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
132*4bdff4beSrobert       constexpr __iterator operator++(int) requires incrementable<_Start> {
133*4bdff4beSrobert         auto __tmp = *this;
134*4bdff4beSrobert         ++*this;
135*4bdff4beSrobert         return __tmp;
136*4bdff4beSrobert       }
137*4bdff4beSrobert 
138*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
139*4bdff4beSrobert       constexpr __iterator& operator--() requires __decrementable<_Start> {
140*4bdff4beSrobert         --__value_;
141*4bdff4beSrobert         return *this;
142*4bdff4beSrobert       }
143*4bdff4beSrobert 
144*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
145*4bdff4beSrobert       constexpr __iterator  operator--(int) requires __decrementable<_Start> {
146*4bdff4beSrobert         auto __tmp = *this;
147*4bdff4beSrobert         --*this;
148*4bdff4beSrobert         return __tmp;
149*4bdff4beSrobert       }
150*4bdff4beSrobert 
151*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
152*4bdff4beSrobert       constexpr __iterator& operator+=(difference_type __n)
153*4bdff4beSrobert         requires __advanceable<_Start>
154*4bdff4beSrobert       {
155*4bdff4beSrobert         if constexpr (__integer_like<_Start> && !__signed_integer_like<_Start>) {
156*4bdff4beSrobert           if (__n >= difference_type(0)) {
157*4bdff4beSrobert             __value_ += static_cast<_Start>(__n);
158*4bdff4beSrobert           } else {
159*4bdff4beSrobert             __value_ -= static_cast<_Start>(-__n);
160*4bdff4beSrobert           }
161*4bdff4beSrobert         } else {
162*4bdff4beSrobert           __value_ += __n;
163*4bdff4beSrobert         }
164*4bdff4beSrobert         return *this;
165*4bdff4beSrobert       }
166*4bdff4beSrobert 
167*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
168*4bdff4beSrobert       constexpr __iterator& operator-=(difference_type __n)
169*4bdff4beSrobert         requires __advanceable<_Start>
170*4bdff4beSrobert       {
171*4bdff4beSrobert         if constexpr (__integer_like<_Start> && !__signed_integer_like<_Start>) {
172*4bdff4beSrobert           if (__n >= difference_type(0)) {
173*4bdff4beSrobert             __value_ -= static_cast<_Start>(__n);
174*4bdff4beSrobert           } else {
175*4bdff4beSrobert             __value_ += static_cast<_Start>(-__n);
176*4bdff4beSrobert           }
177*4bdff4beSrobert         } else {
178*4bdff4beSrobert           __value_ -= __n;
179*4bdff4beSrobert         }
180*4bdff4beSrobert         return *this;
181*4bdff4beSrobert       }
182*4bdff4beSrobert 
183*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
184*4bdff4beSrobert       constexpr _Start operator[](difference_type __n) const
185*4bdff4beSrobert         requires __advanceable<_Start>
186*4bdff4beSrobert       {
187*4bdff4beSrobert         return _Start(__value_ + __n);
188*4bdff4beSrobert       }
189*4bdff4beSrobert 
190*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
191*4bdff4beSrobert       friend constexpr bool operator==(const __iterator& __x, const __iterator& __y)
192*4bdff4beSrobert         requires equality_comparable<_Start>
193*4bdff4beSrobert       {
194*4bdff4beSrobert         return __x.__value_ == __y.__value_;
195*4bdff4beSrobert       }
196*4bdff4beSrobert 
197*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
198*4bdff4beSrobert       friend constexpr bool operator<(const __iterator& __x, const __iterator& __y)
199*4bdff4beSrobert         requires totally_ordered<_Start>
200*4bdff4beSrobert       {
201*4bdff4beSrobert         return __x.__value_ < __y.__value_;
202*4bdff4beSrobert       }
203*4bdff4beSrobert 
204*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
205*4bdff4beSrobert       friend constexpr bool operator>(const __iterator& __x, const __iterator& __y)
206*4bdff4beSrobert         requires totally_ordered<_Start>
207*4bdff4beSrobert       {
208*4bdff4beSrobert         return __y < __x;
209*4bdff4beSrobert       }
210*4bdff4beSrobert 
211*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
212*4bdff4beSrobert       friend constexpr bool operator<=(const __iterator& __x, const __iterator& __y)
213*4bdff4beSrobert         requires totally_ordered<_Start>
214*4bdff4beSrobert       {
215*4bdff4beSrobert         return !(__y < __x);
216*4bdff4beSrobert       }
217*4bdff4beSrobert 
218*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
219*4bdff4beSrobert       friend constexpr bool operator>=(const __iterator& __x, const __iterator& __y)
220*4bdff4beSrobert         requires totally_ordered<_Start>
221*4bdff4beSrobert       {
222*4bdff4beSrobert         return !(__x < __y);
223*4bdff4beSrobert       }
224*4bdff4beSrobert 
225*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
226*4bdff4beSrobert       friend constexpr auto operator<=>(const __iterator& __x, const __iterator& __y)
227*4bdff4beSrobert         requires totally_ordered<_Start> && three_way_comparable<_Start>
228*4bdff4beSrobert       {
229*4bdff4beSrobert         return __x.__value_ <=> __y.__value_;
230*4bdff4beSrobert       }
231*4bdff4beSrobert 
232*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
233*4bdff4beSrobert       friend constexpr __iterator operator+(__iterator __i, difference_type __n)
234*4bdff4beSrobert         requires __advanceable<_Start>
235*4bdff4beSrobert       {
236*4bdff4beSrobert         __i += __n;
237*4bdff4beSrobert         return __i;
238*4bdff4beSrobert       }
239*4bdff4beSrobert 
240*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
241*4bdff4beSrobert       friend constexpr __iterator operator+(difference_type __n, __iterator __i)
242*4bdff4beSrobert         requires __advanceable<_Start>
243*4bdff4beSrobert       {
244*4bdff4beSrobert         return __i + __n;
245*4bdff4beSrobert       }
246*4bdff4beSrobert 
247*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
248*4bdff4beSrobert       friend constexpr __iterator operator-(__iterator __i, difference_type __n)
249*4bdff4beSrobert         requires __advanceable<_Start>
250*4bdff4beSrobert       {
251*4bdff4beSrobert         __i -= __n;
252*4bdff4beSrobert         return __i;
253*4bdff4beSrobert       }
254*4bdff4beSrobert 
255*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
256*4bdff4beSrobert       friend constexpr difference_type operator-(const __iterator& __x, const __iterator& __y)
257*4bdff4beSrobert         requires __advanceable<_Start>
258*4bdff4beSrobert       {
259*4bdff4beSrobert         if constexpr (__integer_like<_Start>) {
260*4bdff4beSrobert           if constexpr (__signed_integer_like<_Start>) {
261*4bdff4beSrobert             return difference_type(difference_type(__x.__value_) - difference_type(__y.__value_));
262*4bdff4beSrobert           }
263*4bdff4beSrobert           if (__y.__value_ > __x.__value_) {
264*4bdff4beSrobert             return difference_type(-difference_type(__y.__value_ - __x.__value_));
265*4bdff4beSrobert           }
266*4bdff4beSrobert           return difference_type(__x.__value_ - __y.__value_);
267*4bdff4beSrobert         }
268*4bdff4beSrobert         return __x.__value_ - __y.__value_;
269*4bdff4beSrobert       }
270*4bdff4beSrobert     };
271*4bdff4beSrobert 
272*4bdff4beSrobert     struct __sentinel {
273*4bdff4beSrobert       friend class iota_view;
274*4bdff4beSrobert 
275*4bdff4beSrobert     private:
276*4bdff4beSrobert       _BoundSentinel __bound_sentinel_ = _BoundSentinel();
277*4bdff4beSrobert 
278*4bdff4beSrobert     public:
279*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
280*4bdff4beSrobert       __sentinel() = default;
281*4bdff4beSrobert       constexpr explicit __sentinel(_BoundSentinel __bound_sentinel) : __bound_sentinel_(std::move(__bound_sentinel)) {}
282*4bdff4beSrobert 
283*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
284*4bdff4beSrobert       friend constexpr bool operator==(const __iterator& __x, const __sentinel& __y) {
285*4bdff4beSrobert         return __x.__value_ == __y.__bound_sentinel_;
286*4bdff4beSrobert       }
287*4bdff4beSrobert 
288*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
289*4bdff4beSrobert       friend constexpr iter_difference_t<_Start> operator-(const __iterator& __x, const __sentinel& __y)
290*4bdff4beSrobert         requires sized_sentinel_for<_BoundSentinel, _Start>
291*4bdff4beSrobert       {
292*4bdff4beSrobert         return __x.__value_ - __y.__bound_sentinel_;
293*4bdff4beSrobert       }
294*4bdff4beSrobert 
295*4bdff4beSrobert       _LIBCPP_HIDE_FROM_ABI
296*4bdff4beSrobert       friend constexpr iter_difference_t<_Start> operator-(const __sentinel& __x, const __iterator& __y)
297*4bdff4beSrobert         requires sized_sentinel_for<_BoundSentinel, _Start>
298*4bdff4beSrobert       {
299*4bdff4beSrobert         return -(__y - __x);
300*4bdff4beSrobert       }
301*4bdff4beSrobert     };
302*4bdff4beSrobert 
303*4bdff4beSrobert     _Start __value_ = _Start();
304*4bdff4beSrobert     _BoundSentinel __bound_sentinel_ = _BoundSentinel();
305*4bdff4beSrobert 
306*4bdff4beSrobert   public:
307*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
308*4bdff4beSrobert     iota_view() requires default_initializable<_Start> = default;
309*4bdff4beSrobert 
310*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
311*4bdff4beSrobert     constexpr explicit iota_view(_Start __value) : __value_(std::move(__value)) { }
312*4bdff4beSrobert 
313*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
314*4bdff4beSrobert     constexpr iota_view(type_identity_t<_Start> __value, type_identity_t<_BoundSentinel> __bound_sentinel)
315*4bdff4beSrobert         : __value_(std::move(__value)), __bound_sentinel_(std::move(__bound_sentinel)) {
316*4bdff4beSrobert       // Validate the precondition if possible.
317*4bdff4beSrobert       if constexpr (totally_ordered_with<_Start, _BoundSentinel>) {
318*4bdff4beSrobert         _LIBCPP_ASSERT(ranges::less_equal()(__value_, __bound_sentinel_),
319*4bdff4beSrobert                        "Precondition violated: value is greater than bound.");
320*4bdff4beSrobert       }
321*4bdff4beSrobert     }
322*4bdff4beSrobert 
323*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
324*4bdff4beSrobert     constexpr iota_view(__iterator __first, __iterator __last)
325*4bdff4beSrobert       requires same_as<_Start, _BoundSentinel>
326*4bdff4beSrobert     : iota_view(std::move(__first.__value_), std::move(__last.__value_)) {}
327*4bdff4beSrobert 
328*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
329*4bdff4beSrobert     constexpr iota_view(__iterator __first, _BoundSentinel __last)
330*4bdff4beSrobert       requires same_as<_BoundSentinel, unreachable_sentinel_t>
331*4bdff4beSrobert     : iota_view(std::move(__first.__value_), std::move(__last)) {}
332*4bdff4beSrobert 
333*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
334*4bdff4beSrobert     constexpr iota_view(__iterator __first, __sentinel __last)
335*4bdff4beSrobert       requires(!same_as<_Start, _BoundSentinel> && !same_as<_Start, unreachable_sentinel_t>)
336*4bdff4beSrobert     : iota_view(std::move(__first.__value_), std::move(__last.__bound_sentinel_)) {}
337*4bdff4beSrobert 
338*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
339*4bdff4beSrobert     constexpr __iterator begin() const { return __iterator{__value_}; }
340*4bdff4beSrobert 
341*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
342*4bdff4beSrobert     constexpr auto end() const {
343*4bdff4beSrobert       if constexpr (same_as<_BoundSentinel, unreachable_sentinel_t>)
344*4bdff4beSrobert         return unreachable_sentinel;
345*4bdff4beSrobert       else
346*4bdff4beSrobert         return __sentinel{__bound_sentinel_};
347*4bdff4beSrobert     }
348*4bdff4beSrobert 
349*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
350*4bdff4beSrobert     constexpr __iterator end() const
351*4bdff4beSrobert       requires same_as<_Start, _BoundSentinel>
352*4bdff4beSrobert     {
353*4bdff4beSrobert       return __iterator{__bound_sentinel_};
354*4bdff4beSrobert     }
355*4bdff4beSrobert 
356*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
357*4bdff4beSrobert     constexpr auto size() const
358*4bdff4beSrobert       requires(same_as<_Start, _BoundSentinel> && __advanceable<_Start>) ||
359*4bdff4beSrobert               (integral<_Start> && integral<_BoundSentinel>) || sized_sentinel_for<_BoundSentinel, _Start>
360*4bdff4beSrobert     {
361*4bdff4beSrobert       if constexpr (__integer_like<_Start> && __integer_like<_BoundSentinel>) {
362*4bdff4beSrobert         if (__value_ < 0) {
363*4bdff4beSrobert           if (__bound_sentinel_ < 0) {
364*4bdff4beSrobert             return std::__to_unsigned_like(-__value_) - std::__to_unsigned_like(-__bound_sentinel_);
365*4bdff4beSrobert           }
366*4bdff4beSrobert           return std::__to_unsigned_like(__bound_sentinel_) + std::__to_unsigned_like(-__value_);
367*4bdff4beSrobert         }
368*4bdff4beSrobert         return std::__to_unsigned_like(__bound_sentinel_) - std::__to_unsigned_like(__value_);
369*4bdff4beSrobert       }
370*4bdff4beSrobert       return std::__to_unsigned_like(__bound_sentinel_ - __value_);
371*4bdff4beSrobert     }
372*4bdff4beSrobert   };
373*4bdff4beSrobert 
374*4bdff4beSrobert   template <class _Start, class _BoundSentinel>
375*4bdff4beSrobert     requires(!__integer_like<_Start> || !__integer_like<_BoundSentinel> ||
376*4bdff4beSrobert              (__signed_integer_like<_Start> == __signed_integer_like<_BoundSentinel>))
377*4bdff4beSrobert   iota_view(_Start, _BoundSentinel) -> iota_view<_Start, _BoundSentinel>;
378*4bdff4beSrobert 
379*4bdff4beSrobert   template <class _Start, class _BoundSentinel>
380*4bdff4beSrobert   inline constexpr bool enable_borrowed_range<iota_view<_Start, _BoundSentinel>> = true;
381*4bdff4beSrobert 
382*4bdff4beSrobert  namespace views {
383*4bdff4beSrobert  namespace __iota {
384*4bdff4beSrobert   struct __fn {
385*4bdff4beSrobert     template<class _Start>
386*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI
387*4bdff4beSrobert     constexpr auto operator()(_Start&& __start) const
388*4bdff4beSrobert       noexcept(noexcept(ranges::iota_view(std::forward<_Start>(__start))))
389*4bdff4beSrobert       -> decltype(      ranges::iota_view(std::forward<_Start>(__start)))
390*4bdff4beSrobert       { return          ranges::iota_view(std::forward<_Start>(__start)); }
391*4bdff4beSrobert 
392*4bdff4beSrobert     template <class _Start, class _BoundSentinel>
393*4bdff4beSrobert     _LIBCPP_HIDE_FROM_ABI constexpr auto operator()(_Start&& __start, _BoundSentinel&& __bound_sentinel) const
394*4bdff4beSrobert       noexcept(noexcept(ranges::iota_view(std::forward<_Start>(__start), std::forward<_BoundSentinel>(__bound_sentinel))))
395*4bdff4beSrobert       -> decltype(      ranges::iota_view(std::forward<_Start>(__start), std::forward<_BoundSentinel>(__bound_sentinel)))
396*4bdff4beSrobert       { return          ranges::iota_view(std::forward<_Start>(__start), std::forward<_BoundSentinel>(__bound_sentinel)); }
397*4bdff4beSrobert   };
398*4bdff4beSrobert } // namespace __iota
399*4bdff4beSrobert 
400*4bdff4beSrobert inline namespace __cpo {
401*4bdff4beSrobert   inline constexpr auto iota = __iota::__fn{};
402*4bdff4beSrobert } // namespace __cpo
403*4bdff4beSrobert } // namespace views
404*4bdff4beSrobert } // namespace ranges
405*4bdff4beSrobert 
406*4bdff4beSrobert #endif // _LIBCPP_STD_VER > 17
407*4bdff4beSrobert 
408*4bdff4beSrobert _LIBCPP_END_NAMESPACE_STD
409*4bdff4beSrobert 
410*4bdff4beSrobert #endif // _LIBCPP___RANGES_IOTA_VIEW_H
411