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
|