14
14
#include < __algorithm/iterator_operations.h>
15
15
#include < __config>
16
16
#include < __iterator/segmented_iterator.h>
17
- #include < __ranges/movable_box .h>
17
+ #include < __type_traits/enable_if .h>
18
18
#include < __utility/in_place.h>
19
19
#include < __utility/move.h>
20
20
@@ -27,32 +27,37 @@ _LIBCPP_PUSH_MACROS
27
27
28
28
_LIBCPP_BEGIN_NAMESPACE_STD
29
29
30
- template <class _InputIterator , class _Function >
31
- _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 _Function
32
- for_each (_InputIterator __first, _InputIterator __last, _Function __f);
33
-
34
- template <class , class _InputIterator , class _Function >
30
+ template <class , class _InputIterator , class _Sent , class _Function >
35
31
_LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 _Function
36
- __for_each (_InputIterator __first, _InputIterator __last, _Function& __f) {
32
+ __for_each (_InputIterator __first, _Sent __last, _Function& __f) {
37
33
for (; __first != __last; ++__first)
38
34
__f (*__first);
39
35
return std::move (__f);
40
36
}
41
37
42
- // __movable_box is available in C++20, but is actually a copyable-box, so optimization is only correct in C++23
43
- #if _LIBCPP_STD_VER >= 23
44
- template <class , class _SegmentedIterator , class _Function >
45
- requires __is_segmented_iterator<_SegmentedIterator>::value
38
+ template <class _InputIterator , class _Function >
39
+ struct _ForeachSegment {
40
+ using _Traits _LIBCPP_NODEBUG = __segmented_iterator_traits<_InputIterator>;
41
+
42
+ _Function& __func_;
43
+
44
+ _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 explicit _ForeachSegment (_Function& __func) : __func_(__func) {}
45
+
46
+ _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 void
47
+ operator ()(typename _Traits::__local_iterator __lfirst, typename _Traits::__local_iterator __llast) {
48
+ std::__for_each<_ClassicAlgPolicy>(__lfirst, __llast, __func_);
49
+ }
50
+ };
51
+
52
+ template <class ,
53
+ class _SegmentedIterator ,
54
+ class _Function ,
55
+ __enable_if_t <__is_segmented_iterator<_SegmentedIterator>::value, int > = 0 >
46
56
_LIBCPP_HIDE_FROM_ABI constexpr _Function
47
- for_each (_SegmentedIterator __first, _SegmentedIterator __last, _Function& __func) {
48
- ranges::__movable_box<_Function> __wrapped_func (in_place, std::move (__func));
49
- std::__for_each_segment (__first, __last, [&](auto __lfirst, auto __llast) {
50
- __wrapped_func =
51
- ranges::__movable_box<_Function>(in_place, std::for_each (__lfirst, __llast, std::move (*__wrapped_func)));
52
- });
53
- return std::move (*__wrapped_func);
57
+ __for_each (_SegmentedIterator __first, _SegmentedIterator __last, _Function& __func) {
58
+ std::__for_each_segment (__first, __last, _ForeachSegment<_SegmentedIterator, _Function>(__func));
59
+ return std::move (__func);
54
60
}
55
- #endif // _LIBCPP_STD_VER >= 23
56
61
57
62
template <class _InputIterator , class _Function >
58
63
_LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 _Function
0 commit comments