Chris@16
|
1 // Copyright 2005 Daniel Wallin.
|
Chris@16
|
2 // Copyright 2005 Joel de Guzman.
|
Chris@16
|
3 // Copyright 2005 Dan Marsden.
|
Chris@16
|
4 //
|
Chris@16
|
5 // Use, modification and distribution is subject to the Boost Software
|
Chris@16
|
6 // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
Chris@16
|
7 // http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
8 //
|
Chris@16
|
9 // Modeled after range_ex, Copyright 2004 Eric Niebler
|
Chris@16
|
10
|
Chris@16
|
11 #ifndef BOOST_PHOENIX_ALGORITHM_ITERATION_HPP
|
Chris@16
|
12 #define BOOST_PHOENIX_ALGORITHM_ITERATION_HPP
|
Chris@16
|
13
|
Chris@16
|
14 #include <algorithm>
|
Chris@16
|
15 #include <numeric>
|
Chris@16
|
16
|
Chris@16
|
17 #include <boost/phoenix/stl/algorithm/detail/begin.hpp>
|
Chris@16
|
18 #include <boost/phoenix/stl/algorithm/detail/end.hpp>
|
Chris@16
|
19
|
Chris@16
|
20 #include <boost/phoenix/function/adapt_callable.hpp>
|
Chris@16
|
21
|
Chris@16
|
22 namespace boost { namespace phoenix {
|
Chris@16
|
23 namespace impl
|
Chris@16
|
24 {
|
Chris@16
|
25 struct for_each
|
Chris@16
|
26 {
|
Chris@16
|
27 template <typename Sig>
|
Chris@16
|
28 struct result;
|
Chris@16
|
29
|
Chris@16
|
30 template<typename This, class R, class F>
|
Chris@16
|
31 struct result<This(R&, F)>
|
Chris@16
|
32 : result<This(R&, F const &)>
|
Chris@16
|
33 {};
|
Chris@16
|
34
|
Chris@16
|
35 template<typename This, class R, class F>
|
Chris@16
|
36 struct result<This(R&, F &)>
|
Chris@16
|
37 {
|
Chris@16
|
38 typedef F type;
|
Chris@16
|
39 };
|
Chris@16
|
40
|
Chris@16
|
41 template<class R, class F>
|
Chris@16
|
42 F const operator()(R& r, F const& fn) const
|
Chris@16
|
43 {
|
Chris@16
|
44 return std::for_each(detail::begin_(r), detail::end_(r), fn);
|
Chris@16
|
45 }
|
Chris@16
|
46 };
|
Chris@16
|
47
|
Chris@16
|
48 struct accumulate
|
Chris@16
|
49 {
|
Chris@16
|
50 template <typename Sig>
|
Chris@16
|
51 struct result;
|
Chris@16
|
52
|
Chris@16
|
53 template<typename This, class R, class I>
|
Chris@16
|
54 struct result<This(R&, I)>
|
Chris@16
|
55 : result<This(R&, I const &)>
|
Chris@16
|
56 {};
|
Chris@16
|
57
|
Chris@16
|
58 template<typename This, class R, class I>
|
Chris@16
|
59 struct result<This(R&, I &)>
|
Chris@16
|
60 {
|
Chris@16
|
61 typedef I type;
|
Chris@16
|
62 };
|
Chris@16
|
63
|
Chris@16
|
64 template<typename This, class R, class I, class C>
|
Chris@16
|
65 struct result<This(R&, I, C)>
|
Chris@16
|
66 : result<This(R&, I const &, C)>
|
Chris@16
|
67 {};
|
Chris@16
|
68
|
Chris@16
|
69 template<typename This, class R, class I, class C>
|
Chris@16
|
70 struct result<This(R&, I &, C)>
|
Chris@16
|
71 {
|
Chris@16
|
72 typedef I type;
|
Chris@16
|
73 };
|
Chris@16
|
74
|
Chris@16
|
75 template<class R, class I>
|
Chris@16
|
76 I
|
Chris@16
|
77 operator()(R& r, I i) const
|
Chris@16
|
78 {
|
Chris@16
|
79 return std::accumulate(detail::begin_(r), detail::end_(r), i);
|
Chris@16
|
80 }
|
Chris@16
|
81
|
Chris@16
|
82 template<class R, class I, class C>
|
Chris@16
|
83 I
|
Chris@16
|
84 operator()(R& r, I i, C c) const
|
Chris@16
|
85 {
|
Chris@16
|
86 return std::accumulate(detail::begin_(r), detail::end_(r), i, c);
|
Chris@16
|
87 }
|
Chris@16
|
88 };
|
Chris@16
|
89 }
|
Chris@16
|
90
|
Chris@16
|
91 BOOST_PHOENIX_ADAPT_CALLABLE(for_each, impl::for_each, 2)
|
Chris@16
|
92 BOOST_PHOENIX_ADAPT_CALLABLE(accumulate, impl::accumulate, 2)
|
Chris@16
|
93 BOOST_PHOENIX_ADAPT_CALLABLE(accumulate, impl::accumulate, 3)
|
Chris@16
|
94
|
Chris@16
|
95 }}
|
Chris@16
|
96
|
Chris@16
|
97 #endif
|