Index: third_party/boost/boost/mpl/aux_/preprocessed/no_ctps/bind.hpp |
diff --git a/third_party/boost/boost/mpl/aux_/preprocessed/no_ctps/bind.hpp b/third_party/boost/boost/mpl/aux_/preprocessed/no_ctps/bind.hpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..12062b425b78c454c75f896b095026e484943c8e |
--- /dev/null |
+++ b/third_party/boost/boost/mpl/aux_/preprocessed/no_ctps/bind.hpp |
@@ -0,0 +1,590 @@ |
+ |
+// 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< |
+ 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 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_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 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_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 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_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 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_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 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_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 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_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 |
+ ) |
+}} |
+ |