📄 apply.hpp
字号:
// preprocessed version of 'boost/mpl/apply.hpp' header// see the original for copyright informationnamespace boost {namespace mpl {template< typename F >struct apply0 : F{ enum { arity = 1 }; typedef F arg1; friend class apply0_rebind; typedef apply0_rebind rebind; }; class apply0_rebind { public: template< typename U1 > struct apply : apply0<U1> { }; };// workaround for the ETI bugtemplate<>struct apply0<int>{ typedef int type;};namespace aux {template< typename F>struct msvc_apply1{ template< bool > struct f_ : F {}; template<> struct f_<true> { template< typename P1 > struct apply { }; }; template< typename T1 > struct result_ : f_< aux::msvc_never_true<F>::value > ::template apply<T1> { };};} // namespace auxtemplate< typename F, typename T1 >struct apply1 : aux::msvc_apply1<F>::template result_< T1 >{ enum { arity = 2 }; typedef F arg1; typedef T1 arg2; friend class apply1_rebind; typedef apply1_rebind rebind; }; class apply1_rebind { public: template< typename U1, typename U2 > struct apply : apply1< U1,U2 > { }; };// workaround for ETI bugtemplate<>struct apply1< int,int >{ typedef int type;};namespace aux {template< typename F>struct msvc_apply2{ template< bool > struct f_ : F {}; template<> struct f_<true> { template< typename P1, typename P2 > struct apply { }; }; template< typename T1, typename T2 > struct result_ : f_< aux::msvc_never_true<F>::value > ::template apply< T1,T2 > { };};} // namespace auxtemplate< typename F, typename T1, typename T2 >struct apply2 : aux::msvc_apply2<F>::template result_< T1, T2 >{ enum { arity = 3 }; typedef F arg1; typedef T1 arg2; typedef T2 arg3; friend class apply2_rebind; typedef apply2_rebind rebind; }; class apply2_rebind { public: template< typename U1, typename U2, typename U3 > struct apply : apply2< U1,U2,U3 > { }; };// workaround for ETI bugtemplate<>struct apply2< int,int,int >{ typedef int type;};namespace aux {template< typename F>struct msvc_apply3{ template< bool > struct f_ : F {}; template<> struct f_<true> { template< typename P1, typename P2, typename P3 > struct apply { }; }; template< typename T1, typename T2, typename T3 > struct result_ : f_< aux::msvc_never_true<F>::value > ::template apply< T1,T2,T3 > { };};} // namespace auxtemplate< typename F, typename T1, typename T2, typename T3 >struct apply3 : aux::msvc_apply3<F>::template result_< T1, T2, T3 >{ enum { arity = 4 }; typedef F arg1; typedef T1 arg2; typedef T2 arg3; typedef T3 arg4; friend class apply3_rebind; typedef apply3_rebind rebind; }; class apply3_rebind { public: template< typename U1, typename U2, typename U3, typename U4 > struct apply : apply3< U1,U2,U3,U4 > { }; };// workaround for ETI bugtemplate<>struct apply3< int,int,int,int >{ typedef int type;};namespace aux {template< typename F>struct msvc_apply4{ template< bool > struct f_ : F {}; template<> struct f_<true> { template< typename P1, typename P2, typename P3, typename P4 > struct apply { }; }; template< typename T1, typename T2, typename T3, typename T4 > struct result_ : f_< aux::msvc_never_true<F>::value > ::template apply< T1,T2,T3,T4 > { };};} // namespace auxtemplate< typename F, typename T1, typename T2, typename T3, typename T4 >struct apply4 : aux::msvc_apply4<F>::template result_< T1, T2, T3, T4 >{ enum { arity = 5 }; typedef F arg1; typedef T1 arg2; typedef T2 arg3; typedef T3 arg4; typedef T4 arg5; friend class apply4_rebind; typedef apply4_rebind rebind; }; class apply4_rebind { public: template< typename U1, typename U2, typename U3, typename U4, typename U5 > struct apply : apply4< U1,U2,U3,U4,U5 > { }; };// workaround for ETI bugtemplate<>struct apply4< int,int,int,int,int >{ typedef int type;};namespace aux {template< typename F>struct msvc_apply5{ template< bool > struct f_ : F {}; template<> struct f_<true> { template< typename P1, typename P2, typename P3, typename P4 , typename P5 > struct apply { }; }; template< typename T1, typename T2, typename T3, typename T4 , typename T5 > struct result_ : f_< aux::msvc_never_true<F>::value > ::template apply< T1,T2,T3,T4,T5 > { };};} // namespace auxtemplate< typename F, typename T1, typename T2, typename T3, typename T4 , typename T5 >struct apply5 : aux::msvc_apply5<F>::template result_< T1, T2, T3, T4, T5 >{ enum { arity = 6 }; typedef F arg1; typedef T1 arg2; typedef T2 arg3; typedef T3 arg4; typedef T4 arg5; typedef T5 arg6; friend class apply5_rebind; typedef apply5_rebind rebind; }; class apply5_rebind { public: template< typename U1, typename U2, typename U3, typename U4, typename U5, typename U6 > struct apply : apply5< U1,U2,U3,U4,U5,U6 > { }; };// workaround for ETI bugtemplate<>struct apply5< int,int,int,int,int,int >{ typedef int type;};} // namespace mpl} // namespace boost
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -