[clang] Fix crashes when passing VLA to va_arg (#119563)
[llvm-project.git] / libcxx / include / __cxx03 / ranges
bloba762a0c2ae7586554c3833f62413500fc0a3ba45
1 // -*- C++ -*-
2 //===----------------------------------------------------------------------===//
3 //
4 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5 // See https://llvm.org/LICENSE.txt for license information.
6 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //
8 //===----------------------------------------------------------------------===//
10 #ifndef _LIBCPP___CXX03_RANGES
11 #define _LIBCPP___CXX03_RANGES
15 #include <__cxx03/compare>              // see [compare.syn]
16 #include <__cxx03/initializer_list>     // see [initializer.list.syn]
17 #include <__cxx03/iterator>             // see [iterator.synopsis]
19 namespace std::ranges {
20   inline namespace unspecified {
21     // [range.access], range access
22     inline constexpr unspecified begin = unspecified;
23     inline constexpr unspecified end = unspecified;
24     inline constexpr unspecified cbegin = unspecified;
25     inline constexpr unspecified cend = unspecified;
27     inline constexpr unspecified size = unspecified;
28     inline constexpr unspecified ssize = unspecified;
29   }
31   // [range.range], ranges
32   template<class T>
33     concept range = see below;
35   template<class T>
36     inline constexpr bool enable_borrowed_range = false;
38   template<class T>
39     using iterator_t = decltype(ranges::begin(declval<T&>()));
40   template<range R>
41     using sentinel_t = decltype(ranges::end(declval<R&>()));
42   template<range R>
43     using range_difference_t = iter_difference_t<iterator_t<R>>;
44   template<sized_range R>
45     using range_size_t = decltype(ranges::size(declval<R&>()));
46   template<range R>
47     using range_value_t = iter_value_t<iterator_t<R>>;
48   template<range R>
49     using range_reference_t = iter_reference_t<iterator_t<R>>;
50   template<range R>
51     using range_rvalue_reference_t = iter_rvalue_reference_t<iterator_t<R>>;
52   template <range R>
53     using range_common_reference_t = iter_common_reference_t<iterator_t<R>>;
55   // [range.sized], sized ranges
56   template<class>
57     inline constexpr bool disable_sized_range = false;
59   template<class T>
60     concept sized_range = ...;
62   // [range.view], views
63   template<class T>
64     inline constexpr bool enable_view = ...;
66   struct view_base { };
68   template<class T>
69     concept view = ...;
71   // [range.refinements], other range refinements
72   template<class R, class T>
73     concept output_range = see below;
75   template<class T>
76     concept input_range = see below;
78   template<class T>
79     concept forward_range = see below;
81   template<class T>
82   concept bidirectional_range = see below;
84   template<class T>
85   concept random_access_range = see below;
87   template<class T>
88   concept contiguous_range = see below;
90   template <class _Tp>
91     concept common_range = see below;
93   template<class T>
94   concept viewable_range = see below;
96   // [range.adaptor.object], range adaptor objects
97   template<class D>
98     requires is_class_v<D> && same_as<D, remove_cv_t<D>>
99   class range_adaptor_closure { };  // Since c++23
101   // [view.interface], class template view_interface
102   template<class D>
103     requires is_class_v<D> && same_as<D, remove_cv_t<D>>
104   class view_interface;
106   // [range.subrange], sub-ranges
107   enum class subrange_kind : bool { unsized, sized };
109   template<input_or_output_iterator I, sentinel_for<I> S = I, subrange_kind K = see below>
110     requires (K == subrange_kind::sized || !sized_sentinel_for<S, I>)
111   class subrange;
113   template<class I, class S, subrange_kind K>
114     inline constexpr bool enable_borrowed_range<subrange<I, S, K>> = true;
116   // [range.dangling], dangling iterator handling
117   struct dangling;
119   template<range R>
120     using borrowed_iterator_t = see below;
122   template<range R>
123     using borrowed_subrange_t = see below;
125   // [range.elements], elements view
126   template<input_range V, size_t N>
127     requires see below
128   class elements_view;
130   template<class T, size_t N>
131     inline constexpr bool enable_borrowed_range<elements_view<T, N>> =
132       enable_borrowed_range<T>;
134   template<class R>
135     using keys_view = elements_view<R, 0>;
136   template<class R>
137     using values_view = elements_view<R, 1>;
139   namespace views {
140     template<size_t N>
141       inline constexpr unspecified elements = unspecified;
142     inline constexpr auto keys = elements<0>;
143     inline constexpr auto values = elements<1>;
144   }
146   // [range.utility.conv], range conversions
147   template<class C, input_range R, class... Args> requires (!view<C>)
148     constexpr C to(R&& r, Args&&... args);     // Since C++23
149   template<template<class...> class C, input_range R, class... Args>
150     constexpr auto to(R&& r, Args&&... args);  // Since C++23
151   template<class C, class... Args> requires (!view<C>)
152     constexpr auto to(Args&&... args);         // Since C++23
153   template<template<class...> class C, class... Args>
154     constexpr auto to(Args&&... args);         // Since C++23
156   // [range.empty], empty view
157   template<class T>
158     requires is_object_v<T>
159   class empty_view;
161   template<class T>
162     inline constexpr bool enable_borrowed_range<empty_view<T>> = true;
164   namespace views {
165     template<class T>
166       inline constexpr empty_view<T> empty{};
167   }
169   // [range.all], all view
170   namespace views {
171     inline constexpr unspecified all = unspecified;
173     template<viewable_range R>
174       using all_t = decltype(all(declval<R>()));
175   }
177   template<range R>
178     requires is_object_v<R>
179   class ref_view;
181   template<class T>
182     inline constexpr bool enable_borrowed_range<ref_view<T>> = true;
184   template<range R>
185     requires see below
186   class owning_view;
188   template<class T>
189     inline constexpr bool enable_borrowed_range<owning_view<T>> = enable_borrowed_range<T>;
191   // [range.filter], filter view
192   template<input_range V, indirect_unary_predicate<iterator_t<V>> Pred>
193     requires view<V> && is_object_v<Pred>
194   class filter_view;
196   namespace views {
197     inline constexpr unspecified filter = unspecified;
198   }
200   // [range.drop], drop view
201   template<view V>
202     class drop_view;
204   template<class T>
205     inline constexpr bool enable_borrowed_range<drop_view<T>> = enable_borrowed_range<T>;
207   // [range.drop.while], drop while view
208   template<view V, class Pred>
209     requires input_range<V> && is_object_v<Pred> &&
210              indirect_unary_predicate<const Pred, iterator_t<V>>
211     class drop_while_view;
213   template<class T, class Pred>
214     inline constexpr bool enable_borrowed_range<drop_while_view<T, Pred>> =
215       enable_borrowed_range<T>;
217   namespace views { inline constexpr unspecified drop_while = unspecified; }
219   // [range.transform], transform view
220   template<input_range V, copy_constructible F>
221     requires view<V> && is_object_v<F> &&
222              regular_invocable<F&, range_reference_t<V>> &&
223              can-reference<invoke_result_t<F&, range_reference_t<V>>>
224   class transform_view;
226   // [range.counted], counted view
227   namespace views { inline constexpr unspecified counted = unspecified; }
229   // [range.common], common view
230   template<view V>
231     requires (!common_range<V> && copyable<iterator_t<V>>)
232   class common_view;
234  // [range.reverse], reverse view
235   template<view V>
236     requires bidirectional_range<V>
237   class reverse_view;
239   template<class T>
240     inline constexpr bool enable_borrowed_range<reverse_view<T>> = enable_borrowed_range<T>;
242   template<class T>
243   inline constexpr bool enable_borrowed_range<common_view<T>> = enable_borrowed_range<T>;
245    // [range.take], take view
246   template<view> class take_view;
248   template<class T>
249   inline constexpr bool enable_borrowed_range<take_view<T>> = enable_borrowed_range<T>;
251     // [range.take.while], take while view
252   template<view V, class Pred>
253     requires input_range<V> && is_object_v<Pred> &&
254              indirect_unary_predicate<const Pred, iterator_t<V>>
255     class take_while_view;
257   namespace views { inline constexpr unspecified take_while = unspecified; }
259   template<copy_constructible T>
260     requires is_object_v<T>
261   class single_view;
263   template<weakly_incrementable W, semiregular Bound = unreachable_sentinel_t>
264     requires weakly-equality-comparable-with<W, Bound> && copyable<W>
265   class iota_view;
267   template<class W, class Bound>
268     inline constexpr bool enable_borrowed_range<iota_view<W, Bound>> = true;
270   // [range.repeat], repeat view
271   template<class T>
272     concept integer-like-with-usable-difference-type =  // exposition only
273       is-signed-integer-like<T> || (is-integer-like<T> && weakly_incrementable<T>);
275   template<move_constructible T, semiregular Bound = unreachable_sentinel_t>
276     requires (is_object_v<T> && same_as<T, remove_cv_t<T>> &&
277               (integer-like-with-usable-difference-type<Bound> ||
278                same_as<Bound, unreachable_sentinel_t>))
279   class repeat_view;
281   namespace views { inline constexpr unspecified repeat = unspecified; }
283   // [range.join], join view
284   template<input_range V>
285     requires view<V> && input_range<range_reference_t<V>>
286   class join_view;
288   // [range.lazy.split], lazy split view
289   template<class R>
290     concept tiny-range = see below;   // exposition only
292   template<input_range V, forward_range Pattern>
293     requires view<V> && view<Pattern> &&
294              indirectly_comparable<iterator_t<V>, iterator_t<Pattern>, ranges::equal_to> &&
295              (forward_range<V> || tiny-range<Pattern>)
296   class lazy_split_view;
298   // [range.split], split view
299   template<forward_range V, forward_range Pattern>
300     requires view<V> && view<Pattern> &&
301              indirectly_comparable<iterator_t<V>, iterator_t<Pattern>, ranges::equal_to>
302   class split_view;
304   namespace views {
305     inline constexpr unspecified lazy_split = unspecified;
306     inline constexpr unspecified split = unspecified;
307   }
309   // [range.istream], istream view
310   template<movable Val, class CharT, class Traits = char_traits<CharT>>
311     requires see below
312   class basic_istream_view;
314   template<class Val>
315     using istream_view = basic_istream_view<Val, char>;
317   template<class Val>
318     using wistream_view = basic_istream_view<Val, wchar_t>;
320   namespace views { template<class T> inline constexpr unspecified istream = unspecified; }
322   // [range.zip], zip view
323   template<input_range... Views>
324     requires (view<Views> && ...) && (sizeof...(Views) > 0)
325   class zip_view;        // C++23
327   template<class... Views>
328     inline constexpr bool enable_borrowed_range<zip_view<Views...>> =       // C++23
329       (enable_borrowed_range<Views> && ...);
331   namespace views { inline constexpr unspecified zip = unspecified; }       // C++23
333   // [range.as.rvalue]
334   template <view V>
335     requires input_range<V>
336   class as_rvalue_view;                                                     // C++23
338   namespace views { inline constexpr unspecified as_rvalue ) unspecified; } // C++23
340   [range.chunk.by]
341   template<forward_range V, indirect_binary_predicate<iterator_t<V>, iterator_t<V>> Pred>
342     requires view<V> && is_object_v<Pred>
343   class chunk_by_view;                                                      // C++23
345   namespace views { inline constexpr unspecified chunk_by = unspecified; }  // C++23
348 namespace std {
349   namespace views = ranges::views;
351   template<class T> struct tuple_size;
352   template<size_t I, class T> struct tuple_element;
354   template<class I, class S, ranges::subrange_kind K>
355   struct tuple_size<ranges::subrange<I, S, K>>
356     : integral_constant<size_t, 2> {};
358   template<class I, class S, ranges::subrange_kind K>
359   struct tuple_element<0, ranges::subrange<I, S, K>> {
360     using type = I;
361   };
363   template<class I, class S, ranges::subrange_kind K>
364   struct tuple_element<1, ranges::subrange<I, S, K>> {
365     using type = S;
366   };
368   template<class I, class S, ranges::subrange_kind K>
369   struct tuple_element<0, const ranges::subrange<I, S, K>> {
370     using type = I;
371   };
373   template<class I, class S, ranges::subrange_kind K>
374   struct tuple_element<1, const ranges::subrange<I, S, K>> {
375     using type = S;
376   };
378   struct from_range_t { explicit from_range_t() = default; };  // Since C++23
379   inline constexpr from_range_t from_range{};                  // Since C++23
383 #include <__cxx03/__config>
385 #if _LIBCPP_STD_VER >= 20
386 #  include <__cxx03/__ranges/access.h>
387 #  include <__cxx03/__ranges/all.h>
388 #  include <__cxx03/__ranges/common_view.h>
389 #  include <__cxx03/__ranges/concepts.h>
390 #  include <__cxx03/__ranges/counted.h>
391 #  include <__cxx03/__ranges/dangling.h>
392 #  include <__cxx03/__ranges/data.h>
393 #  include <__cxx03/__ranges/drop_view.h>
394 #  include <__cxx03/__ranges/drop_while_view.h>
395 #  include <__cxx03/__ranges/elements_view.h>
396 #  include <__cxx03/__ranges/empty.h>
397 #  include <__cxx03/__ranges/empty_view.h>
398 #  include <__cxx03/__ranges/enable_borrowed_range.h>
399 #  include <__cxx03/__ranges/enable_view.h>
400 #  include <__cxx03/__ranges/filter_view.h>
401 #  include <__cxx03/__ranges/iota_view.h>
402 #  include <__cxx03/__ranges/join_view.h>
403 #  include <__cxx03/__ranges/lazy_split_view.h>
404 #  include <__cxx03/__ranges/rbegin.h>
405 #  include <__cxx03/__ranges/ref_view.h>
406 #  include <__cxx03/__ranges/rend.h>
407 #  include <__cxx03/__ranges/reverse_view.h>
408 #  include <__cxx03/__ranges/single_view.h>
409 #  include <__cxx03/__ranges/size.h>
410 #  include <__cxx03/__ranges/split_view.h>
411 #  include <__cxx03/__ranges/subrange.h>
412 #  include <__cxx03/__ranges/take_view.h>
413 #  include <__cxx03/__ranges/take_while_view.h>
414 #  include <__cxx03/__ranges/transform_view.h>
415 #  include <__cxx03/__ranges/view_interface.h>
416 #  include <__cxx03/__ranges/views.h>
418 #  if !defined(_LIBCPP_HAS_NO_LOCALIZATION)
419 #    include <__cxx03/__ranges/istream_view.h>
420 #  endif
421 #endif
423 #if _LIBCPP_STD_VER >= 23
424 #  include <__cxx03/__ranges/as_rvalue_view.h>
425 #  include <__cxx03/__ranges/chunk_by_view.h>
426 #  include <__cxx03/__ranges/from_range.h>
427 #  include <__cxx03/__ranges/repeat_view.h>
428 #  include <__cxx03/__ranges/to.h>
429 #  include <__cxx03/__ranges/zip_view.h>
430 #endif
432 #include <__cxx03/version>
434 // standard-mandated includes
436 // [ranges.syn]
437 #include <__cxx03/compare>
438 #include <__cxx03/initializer_list>
439 #include <__cxx03/iterator>
441 // [tuple.helper]
442 #include <__cxx03/__tuple/tuple_element.h>
443 #include <__cxx03/__tuple/tuple_size.h>
445 #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
446 #  pragma GCC system_header
447 #endif
449 #if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 17
450 #  include <__cxx03/cstddef>
451 #  include <__cxx03/limits>
452 #  include <__cxx03/optional>
453 #  include <__cxx03/span>
454 #  include <__cxx03/tuple>
455 #endif
457 #if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 20
458 #  include <__cxx03/cstdlib>
459 #  include <__cxx03/iosfwd>
460 #  include <__cxx03/type_traits>
461 #endif
463 #endif // _LIBCPP___CXX03_RANGES