| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432 | 
// 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/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< typename T >struct replace_unnamed_arg_impl{    template< typename Arg > struct result_    {        typedef Arg next;        typedef T type;    };};template<>struct replace_unnamed_arg_impl< arg< -1 > >{    template< typename Arg > struct result_    {        typedef typename next<Arg>::type next;        typedef Arg type;    };};template< typename T, typename Arg >struct replace_unnamed_arg    : replace_unnamed_arg_impl<T>::template result_<Arg>{};template< int arity_ > struct bind_chooser;aux::no_tag is_bind_helper(...);template< typename T > aux::no_tag is_bind_helper(protect<T>*);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 auxtemplate<      typename F    >struct bind0{    template<          typename U1 = na, typename U2 = na, typename U3 = na        , typename U4 = na, typename U5 = na        >    struct apply    {     private:        typedef aux::replace_unnamed_arg< F, mpl::arg<1> > r0;        typedef typename r0::type a0;        typedef typename r0::next n1;        typedef typename aux::resolve_bind_arg< a0,U1,U2,U3,U4,U5 >::type f_;        ///     public:        typedef typename apply_wrap0<              f_            >::type type;    };};namespace aux {template<      typename F    >aux::yes_tagis_bind_helper(bind0<F>*);} // namespace auxBOOST_MPL_AUX_ARITY_SPEC(1, bind0)BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(1, bind0)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 aux::replace_unnamed_arg< F, mpl::arg<1> > r0;        typedef typename r0::type a0;        typedef typename r0::next n1;        typedef typename aux::resolve_bind_arg< a0,U1,U2,U3,U4,U5 >::type f_;        ///        typedef aux::replace_unnamed_arg< T1,n1 > r1;        typedef typename r1::type a1;        typedef typename r1::next n2;        typedef aux::resolve_bind_arg< a1,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_tagis_bind_helper(bind1< F,T1 >*);} // namespace auxBOOST_MPL_AUX_ARITY_SPEC(2, bind1)BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(2, bind1)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 aux::replace_unnamed_arg< F, mpl::arg<1> > r0;        typedef typename r0::type a0;        typedef typename r0::next n1;        typedef typename aux::resolve_bind_arg< a0,U1,U2,U3,U4,U5 >::type f_;        ///        typedef aux::replace_unnamed_arg< T1,n1 > r1;        typedef typename r1::type a1;        typedef typename r1::next n2;        typedef aux::resolve_bind_arg< a1,U1,U2,U3,U4,U5 > t1;        ///        typedef aux::replace_unnamed_arg< T2,n2 > r2;        typedef typename r2::type a2;        typedef typename r2::next n3;        typedef aux::resolve_bind_arg< a2,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_tagis_bind_helper(bind2< F,T1,T2 >*);} // namespace auxBOOST_MPL_AUX_ARITY_SPEC(3, bind2)BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(3, bind2)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 aux::replace_unnamed_arg< F, mpl::arg<1> > r0;        typedef typename r0::type a0;        typedef typename r0::next n1;        typedef typename aux::resolve_bind_arg< a0,U1,U2,U3,U4,U5 >::type f_;        ///        typedef aux::replace_unnamed_arg< T1,n1 > r1;        typedef typename r1::type a1;        typedef typename r1::next n2;        typedef aux::resolve_bind_arg< a1,U1,U2,U3,U4,U5 > t1;        ///        typedef aux::replace_unnamed_arg< T2,n2 > r2;        typedef typename r2::type a2;        typedef typename r2::next n3;        typedef aux::resolve_bind_arg< a2,U1,U2,U3,U4,U5 > t2;        ///        typedef aux::replace_unnamed_arg< T3,n3 > r3;        typedef typename r3::type a3;        typedef typename r3::next n4;        typedef aux::resolve_bind_arg< a3,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_tagis_bind_helper(bind3< F,T1,T2,T3 >*);} // namespace auxBOOST_MPL_AUX_ARITY_SPEC(4, bind3)BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(4, bind3)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 aux::replace_unnamed_arg< F, mpl::arg<1> > r0;        typedef typename r0::type a0;        typedef typename r0::next n1;        typedef typename aux::resolve_bind_arg< a0,U1,U2,U3,U4,U5 >::type f_;        ///        typedef aux::replace_unnamed_arg< T1,n1 > r1;        typedef typename r1::type a1;        typedef typename r1::next n2;        typedef aux::resolve_bind_arg< a1,U1,U2,U3,U4,U5 > t1;        ///        typedef aux::replace_unnamed_arg< T2,n2 > r2;        typedef typename r2::type a2;        typedef typename r2::next n3;        typedef aux::resolve_bind_arg< a2,U1,U2,U3,U4,U5 > t2;        ///        typedef aux::replace_unnamed_arg< T3,n3 > r3;        typedef typename r3::type a3;        typedef typename r3::next n4;        typedef aux::resolve_bind_arg< a3,U1,U2,U3,U4,U5 > t3;        ///        typedef aux::replace_unnamed_arg< T4,n4 > r4;        typedef typename r4::type a4;        typedef typename r4::next n5;        typedef aux::resolve_bind_arg< a4,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_tagis_bind_helper(bind4< F,T1,T2,T3,T4 >*);} // namespace auxBOOST_MPL_AUX_ARITY_SPEC(5, bind4)BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(5, bind4)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 aux::replace_unnamed_arg< F, mpl::arg<1> > r0;        typedef typename r0::type a0;        typedef typename r0::next n1;        typedef typename aux::resolve_bind_arg< a0,U1,U2,U3,U4,U5 >::type f_;        ///        typedef aux::replace_unnamed_arg< T1,n1 > r1;        typedef typename r1::type a1;        typedef typename r1::next n2;        typedef aux::resolve_bind_arg< a1,U1,U2,U3,U4,U5 > t1;        ///        typedef aux::replace_unnamed_arg< T2,n2 > r2;        typedef typename r2::type a2;        typedef typename r2::next n3;        typedef aux::resolve_bind_arg< a2,U1,U2,U3,U4,U5 > t2;        ///        typedef aux::replace_unnamed_arg< T3,n3 > r3;        typedef typename r3::type a3;        typedef typename r3::next n4;        typedef aux::resolve_bind_arg< a3,U1,U2,U3,U4,U5 > t3;        ///        typedef aux::replace_unnamed_arg< T4,n4 > r4;        typedef typename r4::type a4;        typedef typename r4::next n5;        typedef aux::resolve_bind_arg< a4,U1,U2,U3,U4,U5 > t4;        ///        typedef aux::replace_unnamed_arg< T5,n5 > r5;        typedef typename r5::type a5;        typedef typename r5::next n6;        typedef aux::resolve_bind_arg< a5,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_tagis_bind_helper(bind5< F,T1,T2,T3,T4,T5 >*);} // namespace auxBOOST_MPL_AUX_ARITY_SPEC(6, bind5)BOOST_MPL_AUX_TEMPLATE_ARITY_SPEC(6, bind5)}}
 |