#if !defined(BOOST_PHOENIX_DONT_USE_PREPROCESSED_FILES) #ifndef BOOST_PHOENIX_CORE_DETAIL_ACTOR_RESULT_OF_HPP #define BOOST_PHOENIX_CORE_DETAIL_ACTOR_RESULT_OF_HPP #include #include #endif #else #if !BOOST_PHOENIX_IS_ITERATING #ifndef BOOST_PHOENIX_CORE_DETAIL_ACTOR_RESULT_OF_HPP #define BOOST_PHOENIX_CORE_DETAIL_ACTOR_RESULT_OF_HPP #include #if defined(__WAVE__) && defined(BOOST_PHOENIX_CREATE_PREPROCESSED_FILES) #pragma wave option(preserve: 2, line: 0, output: "preprocessed/actor_result_of_" BOOST_PHOENIX_LIMIT_STR ".hpp") #endif /*============================================================================== Copyright (c) 2005-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) ==============================================================================*/ #if defined(__WAVE__) && defined(BOOST_PHOENIX_CREATE_PREPROCESSED_FILES) #pragma wave option(preserve: 1) #endif namespace result_of { template struct actor; template struct nullary_actor_result { typedef typename boost::phoenix::evaluator::impl< Expr const& , vector2< vector1 *> & , default_actions > const & , proto::empty_env >::result_type type; }; template struct actor { typedef // avoid calling result_of::actor when this is false typename mpl::eval_if_c< result_of::is_nullary::value , nullary_actor_result , mpl::identity >::type type; }; #define BOOST_PHOENIX_ITERATION_PARAMS \ (3, (1, BOOST_PHOENIX_ACTOR_LIMIT, \ )) #include BOOST_PHOENIX_ITERATE() } #if defined(__WAVE__) && defined(BOOST_PHOENIX_CREATE_PREPROCESSED_FILES) #pragma wave option(output: null) #endif #endif #else template struct actor { typedef typename phoenix::evaluator:: impl< Expr const& , vector2< BOOST_PP_CAT( vector , BOOST_PP_INC(BOOST_PHOENIX_ITERATION) ) *, BOOST_PHOENIX_A> & , default_actions > const & , proto::empty_env >::result_type type; }; #endif #endif // BOOST_PHOENIX_DONT_USE_PREPROCESSED_FILES