/*============================================================================= Copyright (c) 2006-2007 Tobias Schwinger Use modification and distribution are 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). ==============================================================================*/ #if !defined(BOOST_FUSION_FUNCTIONAL_ADAPTER_UNFUSED_RVALUE_ARGS_HPP_INCLUDED) #if !defined(BOOST_PP_IS_ITERATING) #include #include #include #include #include #include #include #include #include namespace boost { namespace fusion { template class unfused_rvalue_args; //----- ---- --- -- - - - - template class unfused_rvalue_args { Function fnc_transformed; typedef typename detail::qf_c::type function_c; typedef typename detail::qf::type function; typedef typename detail::call_param::type func_const_fwd_t; public: inline explicit unfused_rvalue_args(func_const_fwd_t f = function()) : fnc_transformed(f) { } template struct result; typedef typename boost::result_of< function_c(fusion::vector0 &) >::type call_const_0_result; inline call_const_0_result operator()() const { fusion::vector0 arg; return this->fnc_transformed(arg); } typedef typename boost::result_of< function(fusion::vector0 &) >::type call_0_result; inline call_0_result operator()() { fusion::vector0 arg; return this->fnc_transformed(arg); } #define BOOST_PP_FILENAME_1 \ #define BOOST_PP_ITERATION_LIMITS \ (1,BOOST_FUSION_UNFUSED_RVALUE_ARGS_MAX_ARITY) #include BOOST_PP_ITERATE() }; }} namespace boost { template struct result_of const ()> { typedef typename boost::fusion::unfused_rvalue_args::call_const_0_result type; }; template struct result_of()> { typedef typename boost::fusion::unfused_rvalue_args::call_0_result type; }; } #define BOOST_FUSION_FUNCTIONAL_ADAPTER_UNFUSED_RVALUE_ARGS_HPP_INCLUDED #else // defined(BOOST_PP_IS_ITERATING) //////////////////////////////////////////////////////////////////////////////// // // Preprocessor vertical repetition code // //////////////////////////////////////////////////////////////////////////////// #define N BOOST_PP_ITERATION() template struct result< Self const (BOOST_PP_ENUM_PARAMS(N,T)) > : boost::result_of< function_c( BOOST_PP_CAT(fusion::vector,N)< BOOST_PP_ENUM_BINARY_PARAMS(N, typename detail::cref::type BOOST_PP_INTERCEPT) > & )> { }; template struct result< Self (BOOST_PP_ENUM_PARAMS(N,T)) > : boost::result_of< function( BOOST_PP_CAT(fusion::vector,N)< BOOST_PP_ENUM_BINARY_PARAMS(N, typename detail::cref::type BOOST_PP_INTERCEPT) > & )> { }; template inline typename boost::result_of & )>::type operator()(BOOST_PP_ENUM_BINARY_PARAMS(N,T,const& a)) const { BOOST_PP_CAT(fusion::vector,N)< BOOST_PP_ENUM_BINARY_PARAMS(N,T,const& BOOST_PP_INTERCEPT) > arg(BOOST_PP_ENUM_PARAMS(N,a)); return this->fnc_transformed(arg); } template inline typename boost::result_of & )>::type operator()(BOOST_PP_ENUM_BINARY_PARAMS(N,T,const& a)) { BOOST_PP_CAT(fusion::vector,N)< BOOST_PP_ENUM_BINARY_PARAMS(N,T,const& BOOST_PP_INTERCEPT) > arg(BOOST_PP_ENUM_PARAMS(N,a)); return this->fnc_transformed(arg); } #undef N #endif // defined(BOOST_PP_IS_ITERATING) #endif