Index: third_party/boost/boost/mpl/aux_/preprocessed/msvc60/apply_wrap.hpp |
diff --git a/third_party/boost/boost/mpl/aux_/preprocessed/msvc60/apply_wrap.hpp b/third_party/boost/boost/mpl/aux_/preprocessed/msvc60/apply_wrap.hpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4e89507d90d9e526294975b70b9a86471bd8f70c |
--- /dev/null |
+++ b/third_party/boost/boost/mpl/aux_/preprocessed/msvc60/apply_wrap.hpp |
@@ -0,0 +1,247 @@ |
+ |
+// Copyright Aleksey Gurtovoy 2000-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/apply_wrap.hpp" header |
+// -- DO NOT modify by hand! |
+ |
+namespace boost { namespace mpl { |
+ |
+template< typename F> |
+struct msvc_apply0 |
+{ |
+ template< bool > struct f_ : F {}; |
+ template<> struct f_<true> |
+ { |
+ template< typename P = int > struct apply |
+ { |
+ typedef int type; |
+ }; |
+ }; |
+ |
+ template< typename T = int > struct result_ |
+ : f_< aux::msvc_never_true<F>::value > |
+ ::template apply<> |
+ { |
+ }; |
+ |
+}; |
+ |
+template< |
+ typename F |
+ > |
+struct apply_wrap0 |
+{ |
+ typedef typename msvc_apply0<F>::template result_< |
+ |
+ >::type type; |
+}; |
+ |
+/// workaround for ETI bug |
+template<> |
+struct apply_wrap0<int> |
+{ |
+ typedef int type; |
+}; |
+ |
+template< typename F> |
+struct msvc_apply1 |
+{ |
+ template< bool > struct f_ : F {}; |
+ template<> struct f_<true> |
+ { |
+ template< typename P1 > struct apply |
+ { |
+ typedef int type; |
+ }; |
+ }; |
+ |
+ template< typename T1 > struct result_ |
+ : f_< aux::msvc_never_true<F>::value > |
+ ::template apply<T1> |
+ { |
+ }; |
+}; |
+ |
+template< |
+ typename F, typename T1 |
+ > |
+struct apply_wrap1 |
+{ |
+ typedef typename msvc_apply1<F>::template result_< |
+ T1 |
+ >::type type; |
+}; |
+ |
+/// workaround for ETI bug |
+template<> |
+struct apply_wrap1< int,int > |
+{ |
+ typedef int type; |
+}; |
+ |
+template< typename F> |
+struct msvc_apply2 |
+{ |
+ template< bool > struct f_ : F {}; |
+ template<> struct f_<true> |
+ { |
+ template< typename P1, typename P2 > struct apply |
+ { |
+ typedef int type; |
+ }; |
+ }; |
+ |
+ template< typename T1, typename T2 > struct result_ |
+ : f_< aux::msvc_never_true<F>::value > |
+ ::template apply< T1,T2 > |
+ { |
+ }; |
+}; |
+ |
+template< |
+ typename F, typename T1, typename T2 |
+ > |
+struct apply_wrap2 |
+{ |
+ typedef typename msvc_apply2<F>::template result_< |
+ T1, T2 |
+ >::type type; |
+}; |
+ |
+/// workaround for ETI bug |
+template<> |
+struct apply_wrap2< int,int,int > |
+{ |
+ typedef int type; |
+}; |
+ |
+template< typename F> |
+struct msvc_apply3 |
+{ |
+ template< bool > struct f_ : F {}; |
+ template<> struct f_<true> |
+ { |
+ template< typename P1, typename P2, typename P3 > struct apply |
+ { |
+ typedef int type; |
+ }; |
+ }; |
+ |
+ template< typename T1, typename T2, typename T3 > struct result_ |
+ : f_< aux::msvc_never_true<F>::value > |
+ ::template apply< T1,T2,T3 > |
+ { |
+ }; |
+}; |
+ |
+template< |
+ typename F, typename T1, typename T2, typename T3 |
+ > |
+struct apply_wrap3 |
+{ |
+ typedef typename msvc_apply3<F>::template result_< |
+ T1, T2, T3 |
+ >::type type; |
+}; |
+ |
+/// workaround for ETI bug |
+template<> |
+struct apply_wrap3< int,int,int,int > |
+{ |
+ typedef int type; |
+}; |
+ |
+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 |
+ { |
+ typedef int type; |
+ }; |
+ }; |
+ |
+ template< |
+ typename T1, typename T2, typename T3, typename T4 |
+ > |
+ struct result_ |
+ : f_< aux::msvc_never_true<F>::value > |
+ ::template apply< T1,T2,T3,T4 > |
+ { |
+ }; |
+}; |
+ |
+template< |
+ typename F, typename T1, typename T2, typename T3, typename T4 |
+ > |
+struct apply_wrap4 |
+{ |
+ typedef typename msvc_apply4<F>::template result_< |
+ T1, T2, T3, T4 |
+ >::type type; |
+}; |
+ |
+/// workaround for ETI bug |
+template<> |
+struct apply_wrap4< int,int,int,int,int > |
+{ |
+ typedef int type; |
+}; |
+ |
+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 |
+ { |
+ typedef int type; |
+ }; |
+ }; |
+ |
+ 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 > |
+ { |
+ }; |
+}; |
+ |
+template< |
+ typename F, typename T1, typename T2, typename T3, typename T4 |
+ , typename T5 |
+ > |
+struct apply_wrap5 |
+{ |
+ typedef typename msvc_apply5<F>::template result_< |
+ T1, T2, T3, T4, T5 |
+ >::type type; |
+}; |
+ |
+/// workaround for ETI bug |
+template<> |
+struct apply_wrap5< int,int,int,int,int,int > |
+{ |
+ typedef int type; |
+}; |
+ |
+}} |
+ |