/*============================================================================= Copyright (c) 2001-2007 Joel de Guzman 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 PHOENIX_BIND_BIND_MEMBER_FUNCTION_HPP #define PHOENIX_BIND_BIND_MEMBER_FUNCTION_HPP #include #include #include #include namespace boost { namespace phoenix { template inline typename detail::expression::function_eval< detail::member_function_ptr<0, RT, RT(ClassT::*)()> , ClassA >::type const bind(RT(ClassT::*f)(), ClassA const& obj) { typedef detail::member_function_ptr<0, RT, RT(ClassT::*)()> fp_type; return detail::expression::function_eval::make( fp_type(f) , obj ); } template inline typename detail::expression::function_eval< detail::member_function_ptr<0, RT, RT(ClassT::*)() const> , ClassA >::type const bind(RT(ClassT::*f)() const, ClassA const& obj) { typedef detail::member_function_ptr<0, RT, RT(ClassT::*)() const> fp_type; return detail::expression::function_eval::make( fp_type(f) , obj ); } template inline typename detail::expression::function_eval< detail::member_function_ptr<0, RT, RT(ClassT::*)()> , ClassT >::type const bind(RT(ClassT::*f)(), ClassT& obj) { typedef detail::member_function_ptr<0, RT, RT(ClassT::*)()> fp_type; return detail::expression::function_eval< fp_type , ClassT >::make( fp_type(f) , obj ); } template inline typename detail::expression::function_eval< detail::member_function_ptr<0, RT, RT(ClassT::*)() const> , ClassT >::type const bind(RT(ClassT::*f)() const, ClassT& obj) { typedef detail::member_function_ptr<0, RT, RT(ClassT::*)() const> fp_type; return detail::expression::function_eval< fp_type , ClassT >::make( fp_type(f) , obj ); } #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/bind_member_function_" BOOST_PHOENIX_LIMIT_STR ".hpp") #endif /*============================================================================= Copyright (c) 2001-2007 Joel de Guzman 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_ACTOR_LIMIT), \ )) #include BOOST_PHOENIX_ITERATE() #if defined(__WAVE__) && defined (BOOST_PHOENIX_CREATE_PREPROCESSED_FILES) #pragma wave option(output: null) #endif #endif }} #endif #else template < typename RT , typename ClassT , BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, typename T) , typename ClassA , BOOST_PHOENIX_typename_A > inline typename detail::expression::function_eval< detail::member_function_ptr< BOOST_PHOENIX_ITERATION , RT , RT(ClassT::*)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) > , ClassA , BOOST_PHOENIX_A >::type const bind( RT(ClassT::*f)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) , ClassA const & obj , BOOST_PHOENIX_A_const_ref_a ) { typedef detail::member_function_ptr< BOOST_PHOENIX_ITERATION , RT , RT(ClassT::*)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) > fp_type; return detail::expression::function_eval< fp_type , ClassA , BOOST_PHOENIX_A >::make( fp_type(f) , obj , BOOST_PHOENIX_a ); } template < typename RT , typename ClassT , BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, typename T) , typename ClassA , BOOST_PHOENIX_typename_A > inline typename detail::expression::function_eval< detail::member_function_ptr< BOOST_PHOENIX_ITERATION , RT , RT(ClassT::*)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) const > , ClassA , BOOST_PHOENIX_A >::type const bind( RT(ClassT::*f)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) const , ClassA const & obj , BOOST_PHOENIX_A_const_ref_a ) { typedef detail::member_function_ptr< BOOST_PHOENIX_ITERATION , RT , RT(ClassT::*)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) const > fp_type; return detail::expression::function_eval< fp_type , ClassA , BOOST_PHOENIX_A >::make( fp_type(f) , obj , BOOST_PHOENIX_a ); } template < typename RT , typename ClassT , BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, typename T) , BOOST_PHOENIX_typename_A > inline typename detail::expression::function_eval< detail::member_function_ptr< BOOST_PHOENIX_ITERATION , RT , RT(ClassT::*)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) > , ClassT , BOOST_PHOENIX_A >::type const bind( RT(ClassT::*f)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) , ClassT & obj , BOOST_PHOENIX_A_const_ref_a ) { typedef detail::member_function_ptr< BOOST_PHOENIX_ITERATION , RT , RT(ClassT::*)(BOOST_PP_ENUM_PARAMS(BOOST_PHOENIX_ITERATION, T)) > fp_type; return detail::expression::function_eval< fp_type , ClassT , BOOST_PHOENIX_A >::make( fp_type(f) , obj , BOOST_PHOENIX_a ); } #endif