mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 09:41:11 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			432 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			432 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| 
 | |
| // 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 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)
 | |
| 
 | |
| 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)
 | |
| 
 | |
| 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)
 | |
| 
 | |
| 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)
 | |
| 
 | |
| 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)
 | |
| 
 | |
| 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)
 | |
| }}
 | |
| 
 | 
