diff options
Diffstat (limited to 'contrib/llvm-project/libcxx/include/__algorithm/ranges_generate.h')
-rw-r--r-- | contrib/llvm-project/libcxx/include/__algorithm/ranges_generate.h | 24 |
1 files changed, 12 insertions, 12 deletions
diff --git a/contrib/llvm-project/libcxx/include/__algorithm/ranges_generate.h b/contrib/llvm-project/libcxx/include/__algorithm/ranges_generate.h index c23645e6d906..149296574d80 100644 --- a/contrib/llvm-project/libcxx/include/__algorithm/ranges_generate.h +++ b/contrib/llvm-project/libcxx/include/__algorithm/ranges_generate.h @@ -9,21 +9,15 @@ #ifndef _LIBCPP___ALGORITHM_RANGES_GENERATE_H #define _LIBCPP___ALGORITHM_RANGES_GENERATE_H -#include <__algorithm/generate.h> -#include <__algorithm/make_projected.h> #include <__concepts/constructible.h> #include <__concepts/invocable.h> #include <__config> -#include <__functional/identity.h> #include <__functional/invoke.h> -#include <__functional/ranges_operations.h> #include <__iterator/concepts.h> #include <__iterator/iterator_traits.h> -#include <__iterator/projected.h> #include <__ranges/access.h> #include <__ranges/concepts.h> #include <__ranges/dangling.h> -#include <__utility/forward.h> #include <__utility/move.h> #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) @@ -39,22 +33,28 @@ namespace __generate { struct __fn { + template <class _OutIter, class _Sent, class _Func> + _LIBCPP_HIDE_FROM_ABI constexpr + static _OutIter __generate_fn_impl(_OutIter __first, _Sent __last, _Func& __gen) { + for (; __first != __last; ++__first) { + *__first = __gen(); + } + + return __first; + } + template <input_or_output_iterator _OutIter, sentinel_for<_OutIter> _Sent, copy_constructible _Func> requires invocable<_Func&> && indirectly_writable<_OutIter, invoke_result_t<_Func&>> _LIBCPP_HIDE_FROM_ABI constexpr _OutIter operator()(_OutIter __first, _Sent __last, _Func __gen) const { - // TODO: implement - (void)__first; (void)__last; (void)__gen; - return {}; + return __generate_fn_impl(std::move(__first), std::move(__last), __gen); } template <class _Range, copy_constructible _Func> requires invocable<_Func&> && output_range<_Range, invoke_result_t<_Func&>> _LIBCPP_HIDE_FROM_ABI constexpr borrowed_iterator_t<_Range> operator()(_Range&& __range, _Func __gen) const { - // TODO: implement - (void)__range; (void)__gen; - return {}; + return __generate_fn_impl(ranges::begin(__range), ranges::end(__range), __gen); } }; |