88 lines
2.5 KiB
C++
88 lines
2.5 KiB
C++
/*==============================================================================
|
|
Copyright (c) 2001-2010 Joel de Guzman
|
|
Copyright (c) 2010 Thomas Heller
|
|
|
|
Distributed under 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)
|
|
==============================================================================*/
|
|
#ifndef BOOST_PHOENIX_STATEMENT_FOR_HPP
|
|
#define BOOST_PHOENIX_STATEMENT_FOR_HPP
|
|
|
|
#include <boost/phoenix/core/limits.hpp>
|
|
#include <boost/phoenix/core/call.hpp>
|
|
#include <boost/phoenix/core/expression.hpp>
|
|
#include <boost/phoenix/core/meta_grammar.hpp>
|
|
|
|
BOOST_PHOENIX_DEFINE_EXPRESSION(
|
|
(boost)(phoenix)(for_)
|
|
, (meta_grammar) // Cond
|
|
(meta_grammar) // Init
|
|
(meta_grammar) // Step
|
|
(meta_grammar) // Do
|
|
)
|
|
|
|
namespace boost { namespace phoenix
|
|
{
|
|
struct for_eval
|
|
{
|
|
typedef void result_type;
|
|
|
|
template <
|
|
typename Init
|
|
, typename Cond
|
|
, typename Step
|
|
, typename Do
|
|
, typename Context
|
|
>
|
|
result_type
|
|
operator()(
|
|
Init const& init
|
|
, Cond const& cond
|
|
, Step const& step
|
|
, Do const& do_it
|
|
, Context const & ctx
|
|
) const
|
|
{
|
|
for(boost::phoenix::eval(init, ctx); boost::phoenix::eval(cond, ctx); boost::phoenix::eval(step, ctx))
|
|
boost::phoenix::eval(do_it, ctx);
|
|
}
|
|
};
|
|
|
|
template <typename Dummy>
|
|
struct default_actions::when<rule::for_, Dummy>
|
|
: call<for_eval, Dummy>
|
|
{};
|
|
|
|
template <typename Init, typename Cond, typename Step>
|
|
struct for_gen
|
|
{
|
|
for_gen(Init const& init_, Cond const& cond_, Step const& step_)
|
|
: init(init_), cond(cond_), step(step_) {}
|
|
|
|
template <typename Do>
|
|
typename expression::for_<Init, Cond, Step, Do>::type const
|
|
operator[](Do const& do_it) const
|
|
{
|
|
return
|
|
expression::
|
|
for_<Init, Cond, Step, Do>::
|
|
make(init, cond, step, do_it);
|
|
}
|
|
|
|
Init init;
|
|
Cond cond;
|
|
Step step;
|
|
};
|
|
|
|
template <typename Init, typename Cond, typename Step>
|
|
inline
|
|
for_gen<Init, Cond, Step> const
|
|
for_(Init const& init, Cond const& cond, Step const& step)
|
|
{
|
|
return for_gen<Init, Cond, Step>(init, cond, step);
|
|
}
|
|
|
|
}}
|
|
|
|
#endif
|