// Copyright 2005 Daniel Wallin. // Copyright 2005 Joel de Guzman. // Copyright 2005 Dan Marsden. // // 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) // // Modeled after range_ex, Copyright 2004 Eric Niebler #ifndef PHOENIX_ALGORITHM_ITERATION_HPP #define PHOENIX_ALGORITHM_ITERATION_HPP #include #include #include #include #include namespace boost { namespace phoenix { namespace impl { struct for_each { template struct result { typedef F type; }; template F operator()(R& r, F fn) const { return std::for_each(detail::begin_(r), detail::end_(r), fn); } }; struct accumulate { template struct result { typedef I type; }; template typename result::type operator()(R& r, I i) const { return std::accumulate(detail::begin_(r), detail::end_(r), i); } template typename result::type operator()(R& r, I i, C c) const { return std::accumulate(detail::begin_(r), detail::end_(r), i, c); } }; } function const for_each = impl::for_each(); function const accumulate = impl::accumulate(); }} #endif