// Copyright Peter Dimov 2001 | |
// Copyright Aleksey Gurtovoy 2001-2004 | |
// | |
// 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) | |
// | |
// Preprocessed version of "boost/mpl/aux_/basic_bind.hpp" header | |
// -- DO NOT modify by hand! | |
namespace boost { namespace mpl { | |
namespace aux { | |
template< bool > | |
struct resolve_arg_impl | |
{ | |
template< | |
typename T, typename U1, typename U2, typename U3 | |
, typename U4, typename U5 | |
> | |
struct result_ | |
{ | |
typedef T type; | |
}; | |
}; | |
template<> | |
struct resolve_arg_impl<true> | |
{ | |
template< | |
typename T, typename U1, typename U2, typename U3 | |
, typename U4, typename U5 | |
> | |
struct result_ | |
{ | |
typedef typename apply_wrap5< | |
T | |
, U1, U2, U3, U4, U5 | |
>::type type; | |
}; | |
}; | |
template< typename T > struct is_bind_template; | |
template< | |
typename T, typename U1, typename U2, typename U3, typename U4 | |
, typename U5 | |
> | |
struct resolve_bind_arg | |
: resolve_arg_impl< is_bind_template<T>::value > | |
::template result_< T,U1,U2,U3,U4,U5 > | |
{ | |
}; | |
template< int arity_ > struct bind_chooser; | |
aux::no_tag is_bind_helper(...); | |
template< typename T > aux::no_tag is_bind_helper(protect<T>*); | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
aux::yes_tag is_bind_helper(bind< F,T1,T2,T3,T4,T5 >*); | |
template< int N > | |
aux::yes_tag is_bind_helper(arg<N>*); | |
template< bool is_ref_ = true > | |
struct is_bind_template_impl | |
{ | |
template< typename T > struct result_ | |
{ | |
BOOST_STATIC_CONSTANT(bool, value = false); | |
}; | |
}; | |
template<> | |
struct is_bind_template_impl<false> | |
{ | |
template< typename T > struct result_ | |
{ | |
BOOST_STATIC_CONSTANT(bool, value = | |
sizeof(aux::is_bind_helper(static_cast<T*>(0))) | |
== sizeof(aux::yes_tag) | |
); | |
}; | |
}; | |
template< typename T > struct is_bind_template | |
: is_bind_template_impl< ::boost::detail::is_reference_impl<T>::value > | |
::template result_<T> | |
{ | |
}; | |
} // namespace aux | |
template< | |
typename F | |
> | |
struct bind0 | |
{ | |
template< | |
typename U1 = na, typename U2 = na, typename U3 = na | |
, typename U4 = na, typename U5 = na | |
> | |
struct apply | |
{ | |
private: | |
typedef typename aux::resolve_bind_arg< F,U1,U2,U3,U4,U5 >::type f_; | |
public: | |
typedef typename apply_wrap0< | |
f_ | |
>::type type; | |
}; | |
}; | |
namespace aux { | |
template< | |
typename F | |
> | |
aux::yes_tag | |
is_bind_helper(bind0<F>*); | |
} // namespace aux | |
BOOST_MPL_AUX_ARITY_SPEC(1, bind0) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(1, bind0) | |
namespace aux { | |
template<> | |
struct bind_chooser<0> | |
{ | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct result_ | |
{ | |
typedef bind0<F> type; | |
}; | |
}; | |
} // namespace aux | |
template< | |
typename F, typename T1 | |
> | |
struct bind1 | |
{ | |
template< | |
typename U1 = na, typename U2 = na, typename U3 = na | |
, typename U4 = na, typename U5 = na | |
> | |
struct apply | |
{ | |
private: | |
typedef typename aux::resolve_bind_arg< F,U1,U2,U3,U4,U5 >::type f_; | |
typedef aux::resolve_bind_arg< T1,U1,U2,U3,U4,U5 > t1; | |
public: | |
typedef typename apply_wrap1< | |
f_ | |
, typename t1::type | |
>::type type; | |
}; | |
}; | |
namespace aux { | |
template< | |
typename F, typename T1 | |
> | |
aux::yes_tag | |
is_bind_helper(bind1< F,T1 >*); | |
} // namespace aux | |
BOOST_MPL_AUX_ARITY_SPEC(2, bind1) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(2, bind1) | |
namespace aux { | |
template<> | |
struct bind_chooser<1> | |
{ | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct result_ | |
{ | |
typedef bind1< F,T1 > type; | |
}; | |
}; | |
} // namespace aux | |
template< | |
typename F, typename T1, typename T2 | |
> | |
struct bind2 | |
{ | |
template< | |
typename U1 = na, typename U2 = na, typename U3 = na | |
, typename U4 = na, typename U5 = na | |
> | |
struct apply | |
{ | |
private: | |
typedef typename aux::resolve_bind_arg< F,U1,U2,U3,U4,U5 >::type f_; | |
typedef aux::resolve_bind_arg< T1,U1,U2,U3,U4,U5 > t1; | |
typedef aux::resolve_bind_arg< T2,U1,U2,U3,U4,U5 > t2; | |
public: | |
typedef typename apply_wrap2< | |
f_ | |
, typename t1::type, typename t2::type | |
>::type type; | |
}; | |
}; | |
namespace aux { | |
template< | |
typename F, typename T1, typename T2 | |
> | |
aux::yes_tag | |
is_bind_helper(bind2< F,T1,T2 >*); | |
} // namespace aux | |
BOOST_MPL_AUX_ARITY_SPEC(3, bind2) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(3, bind2) | |
namespace aux { | |
template<> | |
struct bind_chooser<2> | |
{ | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct result_ | |
{ | |
typedef bind2< F,T1,T2 > type; | |
}; | |
}; | |
} // namespace aux | |
template< | |
typename F, typename T1, typename T2, typename T3 | |
> | |
struct bind3 | |
{ | |
template< | |
typename U1 = na, typename U2 = na, typename U3 = na | |
, typename U4 = na, typename U5 = na | |
> | |
struct apply | |
{ | |
private: | |
typedef typename aux::resolve_bind_arg< F,U1,U2,U3,U4,U5 >::type f_; | |
typedef aux::resolve_bind_arg< T1,U1,U2,U3,U4,U5 > t1; | |
typedef aux::resolve_bind_arg< T2,U1,U2,U3,U4,U5 > t2; | |
typedef aux::resolve_bind_arg< T3,U1,U2,U3,U4,U5 > t3; | |
public: | |
typedef typename apply_wrap3< | |
f_ | |
, typename t1::type, typename t2::type, typename t3::type | |
>::type type; | |
}; | |
}; | |
namespace aux { | |
template< | |
typename F, typename T1, typename T2, typename T3 | |
> | |
aux::yes_tag | |
is_bind_helper(bind3< F,T1,T2,T3 >*); | |
} // namespace aux | |
BOOST_MPL_AUX_ARITY_SPEC(4, bind3) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(4, bind3) | |
namespace aux { | |
template<> | |
struct bind_chooser<3> | |
{ | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct result_ | |
{ | |
typedef bind3< F,T1,T2,T3 > type; | |
}; | |
}; | |
} // namespace aux | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
> | |
struct bind4 | |
{ | |
template< | |
typename U1 = na, typename U2 = na, typename U3 = na | |
, typename U4 = na, typename U5 = na | |
> | |
struct apply | |
{ | |
private: | |
typedef typename aux::resolve_bind_arg< F,U1,U2,U3,U4,U5 >::type f_; | |
typedef aux::resolve_bind_arg< T1,U1,U2,U3,U4,U5 > t1; | |
typedef aux::resolve_bind_arg< T2,U1,U2,U3,U4,U5 > t2; | |
typedef aux::resolve_bind_arg< T3,U1,U2,U3,U4,U5 > t3; | |
typedef aux::resolve_bind_arg< T4,U1,U2,U3,U4,U5 > t4; | |
public: | |
typedef typename apply_wrap4< | |
f_ | |
, typename t1::type, typename t2::type, typename t3::type | |
, typename t4::type | |
>::type type; | |
}; | |
}; | |
namespace aux { | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
> | |
aux::yes_tag | |
is_bind_helper(bind4< F,T1,T2,T3,T4 >*); | |
} // namespace aux | |
BOOST_MPL_AUX_ARITY_SPEC(5, bind4) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(5, bind4) | |
namespace aux { | |
template<> | |
struct bind_chooser<4> | |
{ | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct result_ | |
{ | |
typedef bind4< F,T1,T2,T3,T4 > type; | |
}; | |
}; | |
} // namespace aux | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct bind5 | |
{ | |
template< | |
typename U1 = na, typename U2 = na, typename U3 = na | |
, typename U4 = na, typename U5 = na | |
> | |
struct apply | |
{ | |
private: | |
typedef typename aux::resolve_bind_arg< F,U1,U2,U3,U4,U5 >::type f_; | |
typedef aux::resolve_bind_arg< T1,U1,U2,U3,U4,U5 > t1; | |
typedef aux::resolve_bind_arg< T2,U1,U2,U3,U4,U5 > t2; | |
typedef aux::resolve_bind_arg< T3,U1,U2,U3,U4,U5 > t3; | |
typedef aux::resolve_bind_arg< T4,U1,U2,U3,U4,U5 > t4; | |
typedef aux::resolve_bind_arg< T5,U1,U2,U3,U4,U5 > t5; | |
public: | |
typedef typename apply_wrap5< | |
f_ | |
, typename t1::type, typename t2::type, typename t3::type | |
, typename t4::type, typename t5::type | |
>::type type; | |
}; | |
}; | |
namespace aux { | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
aux::yes_tag | |
is_bind_helper(bind5< F,T1,T2,T3,T4,T5 >*); | |
} // namespace aux | |
BOOST_MPL_AUX_ARITY_SPEC(6, bind5) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(6, bind5) | |
namespace aux { | |
template<> | |
struct bind_chooser<5> | |
{ | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct result_ | |
{ | |
typedef bind5< F,T1,T2,T3,T4,T5 > type; | |
}; | |
}; | |
} // namespace aux | |
namespace aux { | |
template< typename T > | |
struct is_bind_arg | |
{ | |
BOOST_STATIC_CONSTANT(bool, value = true); | |
}; | |
template<> | |
struct is_bind_arg<na> | |
{ | |
BOOST_STATIC_CONSTANT(bool, value = false); | |
}; | |
template< | |
typename T1, typename T2, typename T3, typename T4, typename T5 | |
> | |
struct bind_count_args | |
{ | |
BOOST_STATIC_CONSTANT(int, value = | |
is_bind_arg<T1>::value + is_bind_arg<T2>::value | |
+ is_bind_arg<T3>::value + is_bind_arg<T4>::value | |
+ is_bind_arg<T5>::value | |
); | |
}; | |
} | |
template< | |
typename F, typename T1, typename T2, typename T3, typename T4 | |
, typename T5 | |
> | |
struct bind | |
: aux::bind_chooser< | |
aux::bind_count_args< T1,T2,T3,T4,T5 >::value | |
>::template result_< F,T1,T2,T3,T4,T5 >::type | |
{ | |
}; | |
BOOST_MPL_AUX_ARITY_SPEC( | |
6 | |
, bind | |
) | |
BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC( | |
6 | |
, bind | |
) | |
}} | |