-
Notifications
You must be signed in to change notification settings - Fork 449
/
Copy pathgenerate.hpp
63 lines (58 loc) · 2 KB
/
generate.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/// \file
// Range v3 library
//
// Copyright Eric Niebler 2014
//
// Use, modification and distribution is subject to the
// Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
//
// Project home: https://github.com/ericniebler/range-v3
//
#ifndef RANGES_V3_ALGORITHM_GENERATE_HPP
#define RANGES_V3_ALGORITHM_GENERATE_HPP
#include <utility>
#include <range/v3/range_fwd.hpp>
#include <range/v3/begin_end.hpp>
#include <range/v3/range_concepts.hpp>
#include <range/v3/range_traits.hpp>
#include <range/v3/utility/iterator_concepts.hpp>
#include <range/v3/utility/static_const.hpp>
#include <range/v3/utility/tagged_pair.hpp>
#include <range/v3/algorithm/tagspec.hpp>
namespace ranges
{
inline namespace v3
{
/// \addtogroup group-algorithms
/// @{
struct generate_fn
{
template<typename O, typename S, typename F,
CONCEPT_REQUIRES_(Function<F>() &&
OutputIterator<O, concepts::Function::result_t<F> &&>() &&
Sentinel<S, O>())>
tagged_pair<tag::out(O), tag::fun(F)> operator()(O begin, S end, F fun) const
{
for(; begin != end; ++begin)
*begin = fun();
return {begin, fun};
}
template<typename Rng, typename F,
typename O = range_iterator_t<Rng>,
CONCEPT_REQUIRES_(Function<F>() &&
OutputRange<Rng, concepts::Function::result_t<F> &&>())>
tagged_pair<tag::out(range_safe_iterator_t<Rng>), tag::fun(F)>
operator()(Rng &&rng, F fun) const
{
return (*this)(begin(rng), end(rng), std::move(fun));
}
};
/// \sa `generate_fn`
/// \ingroup group-algorithms
RANGES_INLINE_VARIABLE(with_braced_init_args<generate_fn>, generate)
/// @}
} // namespace v3
} // namespace ranges
#endif // include guard