/*============================================================================= Copyright (c) 2011 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 !BOOST_PHOENIX_IS_ITERATING #ifndef BOOST_PHOENIX_CORE_DETAIL_PHX2_RESULT_HPP #define BOOST_PHOENIX_CORE_DETAIL_PHX2_RESULT_HPP #include #include #include namespace boost { namespace phoenix { namespace detail { BOOST_MPL_HAS_XXX_TRAIT_DEF(result_type) template struct has_phx2_result_impl { typedef char yes; typedef char (&no)[2]; template static yes check(typename A::type *); template static no check(...); static bool const value = (sizeof(yes) == sizeof(check(0))); typedef boost::mpl::bool_ type; }; template struct has_phx2_result : mpl::false_ {}; template struct phx2_result; #if !defined(BOOST_PHOENIX_DONT_USE_PREPROCESSED_FILES) #include #else #if defined(__WAVE__) && defined(BOOST_PHOENIX_CREATE_PREPROCESSED_FILES) #pragma wave option(preserve: 2, line: 0, output: "preprocessed/phx2_result_" BOOST_PHOENIX_LIMIT_STR ".hpp") #endif /*============================================================================= Copyright (c) 2011 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 #define BOOST_PHOENIX_ITERATION_PARAMS \ (3, (1, BOOST_PP_DEC(BOOST_PHOENIX_COMPOSITE_LIMIT), \ )) #include BOOST_PHOENIX_ITERATE() #if defined(__WAVE__) && defined(BOOST_PHOENIX_CREATE_PREPROCESSED_FILES) #pragma wave option(output: null) #endif #endif } }} #endif #else template struct has_phx2_result : mpl::eval_if< has_result_type , mpl::false_ , has_phx2_result_impl > >::type {}; template struct phx2_result { typedef typename F::template result::type type; }; template struct phx2_result { typedef typename F::template result::type type; }; template struct phx2_result { typedef typename F::template result::type type; }; #endif