118 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
/*=============================================================================
 | 
						|
    Copyright (c) 2016 Kohei Takahashi
 | 
						|
 | 
						|
    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 PHOENIX_BIND_BIND_MEMBER_FUNCTION_HPP
 | 
						|
#define PHOENIX_BIND_BIND_MEMBER_FUNCTION_HPP
 | 
						|
 | 
						|
#include <boost/phoenix/core/limits.hpp>
 | 
						|
 | 
						|
#if defined(BOOST_PHOENIX_NO_VARIADIC_BIND)
 | 
						|
# include <boost/phoenix/bind/detail/cpp03/bind_member_function.hpp>
 | 
						|
#else
 | 
						|
 | 
						|
#include <boost/phoenix/core/expression.hpp>
 | 
						|
#include <boost/phoenix/core/reference.hpp>
 | 
						|
#include <boost/phoenix/core/detail/function_eval.hpp>
 | 
						|
 | 
						|
namespace boost { namespace phoenix
 | 
						|
{
 | 
						|
    namespace detail
 | 
						|
    {
 | 
						|
        template <typename RT, typename FP>
 | 
						|
        struct member_function_ptr
 | 
						|
        {
 | 
						|
            typedef RT result_type;
 | 
						|
 | 
						|
            member_function_ptr(FP fp_)
 | 
						|
                : fp(fp_) {}
 | 
						|
 | 
						|
            template <typename Class, typename... A>
 | 
						|
            result_type operator()(Class& obj, A&... a) const
 | 
						|
            {
 | 
						|
                BOOST_PROTO_USE_GET_POINTER();
 | 
						|
 | 
						|
                typedef typename proto::detail::class_member_traits<FP>::class_type class_type;
 | 
						|
                return (BOOST_PROTO_GET_POINTER(class_type, obj)->*fp)(a...);
 | 
						|
            }
 | 
						|
 | 
						|
            template <typename Class, typename... A>
 | 
						|
            result_type operator()(Class* obj, A&... a) const
 | 
						|
            {
 | 
						|
                return (obj->*fp)(a...);
 | 
						|
            }
 | 
						|
 | 
						|
            bool operator==(member_function_ptr const& rhs) const
 | 
						|
            {
 | 
						|
                return fp == rhs.fp;
 | 
						|
            }
 | 
						|
 | 
						|
            template <int M, typename RhsRT, typename RhsFP>
 | 
						|
            bool operator==(member_function_ptr<RhsRT, RhsFP> const& /*rhs*/) const
 | 
						|
            {
 | 
						|
                return false;
 | 
						|
            }
 | 
						|
 | 
						|
            FP fp;
 | 
						|
        };
 | 
						|
    } // namespace boost::phoenix::detail
 | 
						|
 | 
						|
    template <typename RT, typename ClassT, typename... T, typename ClassA, typename... A>
 | 
						|
    inline
 | 
						|
    typename detail::expression::function_eval<
 | 
						|
        detail::member_function_ptr<RT, RT(ClassT::*)(T...)>
 | 
						|
      , ClassA
 | 
						|
      , A...
 | 
						|
    >::type const
 | 
						|
    bind(RT (ClassT::*f)(T...), ClassA const & obj, A const&... a)
 | 
						|
    {
 | 
						|
        typedef detail::member_function_ptr<RT, RT (ClassT::*)(T...)> fp_type;
 | 
						|
        return detail::expression::function_eval<fp_type, ClassA, A...>::make(fp_type(f), obj, a...);
 | 
						|
    }
 | 
						|
 | 
						|
    template <typename RT, typename ClassT, typename... T, typename ClassA, typename... A>
 | 
						|
    inline
 | 
						|
    typename detail::expression::function_eval<
 | 
						|
        detail::member_function_ptr<RT, RT (ClassT::*)(T...) const>
 | 
						|
      , ClassA
 | 
						|
      , A...
 | 
						|
    >::type const
 | 
						|
    bind(RT (ClassT::*f)(T...) const, ClassA const & obj, A const&... a)
 | 
						|
    {
 | 
						|
        typedef detail::member_function_ptr<RT, RT(ClassT::*)(T...) const> fp_type;
 | 
						|
        return detail::expression::function_eval<fp_type, ClassA, A...>::make(fp_type(f), obj, a...);
 | 
						|
    }
 | 
						|
 | 
						|
    template <typename RT, typename ClassT, typename... T, typename... A>
 | 
						|
    inline
 | 
						|
    typename detail::expression::function_eval<
 | 
						|
        detail::member_function_ptr<RT, RT(ClassT::*)(T...)>
 | 
						|
      , ClassT
 | 
						|
      , A...
 | 
						|
    >::type const
 | 
						|
    bind(RT (ClassT::*f)(T...), ClassT & obj, A const&... a)
 | 
						|
    {
 | 
						|
        typedef detail::member_function_ptr<RT, RT(ClassT::*)(T...)> fp_type;
 | 
						|
        return detail::expression::function_eval<fp_type, ClassT, A...>::make(fp_type(f), obj, a...);
 | 
						|
    }
 | 
						|
 | 
						|
    template <typename RT, typename ClassT, typename... T, typename... A>
 | 
						|
    inline
 | 
						|
    typename detail::expression::function_eval<
 | 
						|
        detail::member_function_ptr<RT, RT(ClassT::*)(T...) const>
 | 
						|
      , ClassT
 | 
						|
      , A...
 | 
						|
    >::type const
 | 
						|
    bind(RT (ClassT::*f)(T...) const, ClassT const& obj, A const&... a)
 | 
						|
    {
 | 
						|
        typedef detail::member_function_ptr<RT, RT(ClassT::*)(T...) const> fp_type;
 | 
						|
        return detail::expression::function_eval<fp_type, ClassT, A...>::make(fp_type(f), obj, a...);
 | 
						|
    }
 | 
						|
}} // namespace boost::phoenix
 | 
						|
 | 
						|
#endif
 | 
						|
#endif
 |