Index: base/bind_internal.h |
=================================================================== |
--- base/bind_internal.h (revision 154900) |
+++ base/bind_internal.h (working copy) |
@@ -644,92 +644,7 @@ |
R (T::*method_)(A1, A2, A3, A4, A5, A6, A7) const; |
}; |
-// Function: Arity 8. |
-template <typename R, typename A1, typename A2, typename A3, typename A4, |
- typename A5, typename A6, typename A7, typename A8> |
-class RunnableAdapter<R(*)(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- public: |
- typedef R (RunType)(A1, A2, A3, A4, A5, A6, A7, A8); |
- explicit RunnableAdapter(R(*function)(A1, A2, A3, A4, A5, A6, A7, A8)) |
- : function_(function) { |
- } |
- |
- R Run(typename CallbackParamTraits<A1>::ForwardType a1, |
- typename CallbackParamTraits<A2>::ForwardType a2, |
- typename CallbackParamTraits<A3>::ForwardType a3, |
- typename CallbackParamTraits<A4>::ForwardType a4, |
- typename CallbackParamTraits<A5>::ForwardType a5, |
- typename CallbackParamTraits<A6>::ForwardType a6, |
- typename CallbackParamTraits<A7>::ForwardType a7, |
- typename CallbackParamTraits<A8>::ForwardType a8) { |
- return function_(CallbackForward(a1), CallbackForward(a2), |
- CallbackForward(a3), CallbackForward(a4), CallbackForward(a5), |
- CallbackForward(a6), CallbackForward(a7), CallbackForward(a8)); |
- } |
- |
- private: |
- R (*function_)(A1, A2, A3, A4, A5, A6, A7, A8); |
-}; |
- |
-// Method: Arity 8. |
-template <typename R, typename T, typename A1, typename A2, typename A3, |
- typename A4, typename A5, typename A6, typename A7, typename A8> |
-class RunnableAdapter<R(T::*)(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- public: |
- typedef R (RunType)(T*, A1, A2, A3, A4, A5, A6, A7, A8); |
- typedef true_type IsMethod; |
- |
- explicit RunnableAdapter(R(T::*method)(A1, A2, A3, A4, A5, A6, A7, A8)) |
- : method_(method) { |
- } |
- |
- R Run(T* object, typename CallbackParamTraits<A1>::ForwardType a1, |
- typename CallbackParamTraits<A2>::ForwardType a2, |
- typename CallbackParamTraits<A3>::ForwardType a3, |
- typename CallbackParamTraits<A4>::ForwardType a4, |
- typename CallbackParamTraits<A5>::ForwardType a5, |
- typename CallbackParamTraits<A6>::ForwardType a6, |
- typename CallbackParamTraits<A7>::ForwardType a7, |
- typename CallbackParamTraits<A8>::ForwardType a8) { |
- return (object->*method_)(CallbackForward(a1), CallbackForward(a2), |
- CallbackForward(a3), CallbackForward(a4), CallbackForward(a5), |
- CallbackForward(a6), CallbackForward(a7), CallbackForward(a8)); |
- } |
- |
- private: |
- R (T::*method_)(A1, A2, A3, A4, A5, A6, A7, A8); |
-}; |
- |
-// Const Method: Arity 8. |
-template <typename R, typename T, typename A1, typename A2, typename A3, |
- typename A4, typename A5, typename A6, typename A7, typename A8> |
-class RunnableAdapter<R(T::*)(A1, A2, A3, A4, A5, A6, A7, A8) const> { |
- public: |
- typedef R (RunType)(const T*, A1, A2, A3, A4, A5, A6, A7, A8); |
- typedef true_type IsMethod; |
- |
- explicit RunnableAdapter(R(T::*method)(A1, A2, A3, A4, A5, A6, A7, A8) const) |
- : method_(method) { |
- } |
- |
- R Run(const T* object, typename CallbackParamTraits<A1>::ForwardType a1, |
- typename CallbackParamTraits<A2>::ForwardType a2, |
- typename CallbackParamTraits<A3>::ForwardType a3, |
- typename CallbackParamTraits<A4>::ForwardType a4, |
- typename CallbackParamTraits<A5>::ForwardType a5, |
- typename CallbackParamTraits<A6>::ForwardType a6, |
- typename CallbackParamTraits<A7>::ForwardType a7, |
- typename CallbackParamTraits<A8>::ForwardType a8) { |
- return (object->*method_)(CallbackForward(a1), CallbackForward(a2), |
- CallbackForward(a3), CallbackForward(a4), CallbackForward(a5), |
- CallbackForward(a6), CallbackForward(a7), CallbackForward(a8)); |
- } |
- |
- private: |
- R (T::*method_)(A1, A2, A3, A4, A5, A6, A7, A8) const; |
-}; |
- |
// FunctionTraits<> |
// |
// Breaks a function signature apart into typedefs for easier introspection. |
@@ -807,19 +722,6 @@ |
typedef A7 A7Type; |
}; |
-template <typename R, typename A1, typename A2, typename A3, typename A4, |
- typename A5, typename A6, typename A7, typename A8> |
-struct FunctionTraits<R(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- typedef R ReturnType; |
- typedef A1 A1Type; |
- typedef A2 A2Type; |
- typedef A3 A3Type; |
- typedef A4 A4Type; |
- typedef A5 A5Type; |
- typedef A6 A6Type; |
- typedef A7 A7Type; |
- typedef A8 A8Type; |
-}; |
// ForceVoidReturn<> |
// |
@@ -870,11 +772,6 @@ |
typedef void(RunType)(A1, A2, A3, A4, A5, A6, A7); |
}; |
-template <typename R, typename A1, typename A2, typename A3, typename A4, |
- typename A5, typename A6, typename A7, typename A8> |
-struct ForceVoidReturn<R(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- typedef void(RunType)(A1, A2, A3, A4, A5, A6, A7, A8); |
-}; |
// FunctorTraits<> |
// |
@@ -1123,7 +1020,7 @@ |
} |
}; |
-template <typename Runnable, typename A1, typename A2, typename A3, typename A4, |
+template <typename Runnable,typename A1, typename A2, typename A3, typename A4, |
typename A5, typename A6> |
struct InvokeHelper<false, void, Runnable, |
void(A1, A2, A3, A4, A5, A6)> { |
@@ -1189,47 +1086,6 @@ |
} |
}; |
-template <typename ReturnType, typename Runnable,typename A1, typename A2, |
- typename A3, typename A4, typename A5, typename A6, typename A7, |
- typename A8> |
-struct InvokeHelper<false, ReturnType, Runnable, |
- void(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- static ReturnType MakeItSo(Runnable runnable, A1 a1, A2 a2, A3 a3, A4 a4, |
- A5 a5, A6 a6, A7 a7, A8 a8) { |
- return runnable.Run(CallbackForward(a1), CallbackForward(a2), |
- CallbackForward(a3), CallbackForward(a4), CallbackForward(a5), |
- CallbackForward(a6), CallbackForward(a7), CallbackForward(a8)); |
- } |
-}; |
- |
-template <typename Runnable,typename A1, typename A2, typename A3, typename A4, |
- typename A5, typename A6, typename A7, typename A8> |
-struct InvokeHelper<false, void, Runnable, |
- void(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- static void MakeItSo(Runnable runnable, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, |
- A6 a6, A7 a7, A8 a8) { |
- runnable.Run(CallbackForward(a1), CallbackForward(a2), CallbackForward(a3), |
- CallbackForward(a4), CallbackForward(a5), CallbackForward(a6), |
- CallbackForward(a7), CallbackForward(a8)); |
- } |
-}; |
- |
-template <typename Runnable, typename A1, typename A2, typename A3, |
- typename A4, typename A5, typename A6, typename A7, typename A8> |
-struct InvokeHelper<true, void, Runnable, |
- void(A1, A2, A3, A4, A5, A6, A7, A8)> { |
- static void MakeItSo(Runnable runnable, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, |
- A6 a6, A7 a7, A8 a8) { |
- if (!a1.get()) { |
- return; |
- } |
- |
- runnable.Run(CallbackForward(a1), CallbackForward(a2), CallbackForward(a3), |
- CallbackForward(a4), CallbackForward(a5), CallbackForward(a6), |
- CallbackForward(a7), CallbackForward(a8)); |
- } |
-}; |
- |
#if !defined(_MSC_VER) |
template <typename ReturnType, typename Runnable, typename ArgsType> |
@@ -2662,492 +2518,7 @@ |
} |
}; |
-// Arity 8 -> 8. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<0, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X1>::ForwardType, |
- typename CallbackParamTraits<X2>::ForwardType, |
- typename CallbackParamTraits<X3>::ForwardType, |
- typename CallbackParamTraits<X4>::ForwardType, |
- typename CallbackParamTraits<X5>::ForwardType, |
- typename CallbackParamTraits<X6>::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- typedef R(UnboundRunType)(X1, X2, X3, X4, X5, X6, X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X1>::ForwardType x1, |
- typename CallbackParamTraits<X2>::ForwardType x2, |
- typename CallbackParamTraits<X3>::ForwardType x3, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename CallbackParamTraits<X1>::ForwardType x1, |
- typename CallbackParamTraits<X2>::ForwardType x2, |
- typename CallbackParamTraits<X3>::ForwardType x3, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 7. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<1, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X2>::ForwardType, |
- typename CallbackParamTraits<X3>::ForwardType, |
- typename CallbackParamTraits<X4>::ForwardType, |
- typename CallbackParamTraits<X5>::ForwardType, |
- typename CallbackParamTraits<X6>::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X2, X3, X4, X5, X6, X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X2>::ForwardType x2, |
- typename CallbackParamTraits<X3>::ForwardType x3, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X2>::ForwardType x2, |
- typename CallbackParamTraits<X3>::ForwardType x3, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 6. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<2, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X3>::ForwardType, |
- typename CallbackParamTraits<X4>::ForwardType, |
- typename CallbackParamTraits<X5>::ForwardType, |
- typename CallbackParamTraits<X6>::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X3, X4, X5, X6, X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X3>::ForwardType x3, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X3>::ForwardType x3, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 5. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<3, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X4>::ForwardType, |
- typename CallbackParamTraits<X5>::ForwardType, |
- typename CallbackParamTraits<X6>::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X4, X5, X6, X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- typedef typename StorageType::Bound3UnwrapTraits Bound3UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- typename Bound3UnwrapTraits::ForwardType x3 = |
- Bound3UnwrapTraits::Unwrap(storage->p3_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename Bound3UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X4>::ForwardType x4, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 4. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<4, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X5>::ForwardType, |
- typename CallbackParamTraits<X6>::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X5, X6, X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- typedef typename StorageType::Bound3UnwrapTraits Bound3UnwrapTraits; |
- typedef typename StorageType::Bound4UnwrapTraits Bound4UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- typename Bound3UnwrapTraits::ForwardType x3 = |
- Bound3UnwrapTraits::Unwrap(storage->p3_); |
- typename Bound4UnwrapTraits::ForwardType x4 = |
- Bound4UnwrapTraits::Unwrap(storage->p4_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename Bound3UnwrapTraits::ForwardType, |
- typename Bound4UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X5>::ForwardType x5, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 3. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<5, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X6>::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X6, X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- typedef typename StorageType::Bound3UnwrapTraits Bound3UnwrapTraits; |
- typedef typename StorageType::Bound4UnwrapTraits Bound4UnwrapTraits; |
- typedef typename StorageType::Bound5UnwrapTraits Bound5UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- typename Bound3UnwrapTraits::ForwardType x3 = |
- Bound3UnwrapTraits::Unwrap(storage->p3_); |
- typename Bound4UnwrapTraits::ForwardType x4 = |
- Bound4UnwrapTraits::Unwrap(storage->p4_); |
- typename Bound5UnwrapTraits::ForwardType x5 = |
- Bound5UnwrapTraits::Unwrap(storage->p5_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename Bound3UnwrapTraits::ForwardType, |
- typename Bound4UnwrapTraits::ForwardType, |
- typename Bound5UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X6>::ForwardType x6, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 2. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<6, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X7>::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X7, X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- typedef typename StorageType::Bound3UnwrapTraits Bound3UnwrapTraits; |
- typedef typename StorageType::Bound4UnwrapTraits Bound4UnwrapTraits; |
- typedef typename StorageType::Bound5UnwrapTraits Bound5UnwrapTraits; |
- typedef typename StorageType::Bound6UnwrapTraits Bound6UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- typename Bound3UnwrapTraits::ForwardType x3 = |
- Bound3UnwrapTraits::Unwrap(storage->p3_); |
- typename Bound4UnwrapTraits::ForwardType x4 = |
- Bound4UnwrapTraits::Unwrap(storage->p4_); |
- typename Bound5UnwrapTraits::ForwardType x5 = |
- Bound5UnwrapTraits::Unwrap(storage->p5_); |
- typename Bound6UnwrapTraits::ForwardType x6 = |
- Bound6UnwrapTraits::Unwrap(storage->p6_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename Bound3UnwrapTraits::ForwardType, |
- typename Bound4UnwrapTraits::ForwardType, |
- typename Bound5UnwrapTraits::ForwardType, |
- typename Bound6UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X7>::ForwardType x7, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 1. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<7, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*, |
- typename CallbackParamTraits<X8>::ForwardType); |
- |
- typedef R(UnboundRunType)(X8); |
- |
- static R Run(BindStateBase* base, |
- typename CallbackParamTraits<X8>::ForwardType x8) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- typedef typename StorageType::Bound3UnwrapTraits Bound3UnwrapTraits; |
- typedef typename StorageType::Bound4UnwrapTraits Bound4UnwrapTraits; |
- typedef typename StorageType::Bound5UnwrapTraits Bound5UnwrapTraits; |
- typedef typename StorageType::Bound6UnwrapTraits Bound6UnwrapTraits; |
- typedef typename StorageType::Bound7UnwrapTraits Bound7UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- typename Bound3UnwrapTraits::ForwardType x3 = |
- Bound3UnwrapTraits::Unwrap(storage->p3_); |
- typename Bound4UnwrapTraits::ForwardType x4 = |
- Bound4UnwrapTraits::Unwrap(storage->p4_); |
- typename Bound5UnwrapTraits::ForwardType x5 = |
- Bound5UnwrapTraits::Unwrap(storage->p5_); |
- typename Bound6UnwrapTraits::ForwardType x6 = |
- Bound6UnwrapTraits::Unwrap(storage->p6_); |
- typename Bound7UnwrapTraits::ForwardType x7 = |
- Bound7UnwrapTraits::Unwrap(storage->p7_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename Bound3UnwrapTraits::ForwardType, |
- typename Bound4UnwrapTraits::ForwardType, |
- typename Bound5UnwrapTraits::ForwardType, |
- typename Bound6UnwrapTraits::ForwardType, |
- typename Bound7UnwrapTraits::ForwardType, |
- typename CallbackParamTraits<X8>::ForwardType x8)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
-// Arity 8 -> 0. |
-template <typename StorageType, typename R,typename X1, typename X2, |
- typename X3, typename X4, typename X5, typename X6, typename X7, |
- typename X8> |
-struct Invoker<8, StorageType, R(X1, X2, X3, X4, X5, X6, X7, X8)> { |
- typedef R(RunType)(BindStateBase*); |
- |
- typedef R(UnboundRunType)(); |
- |
- static R Run(BindStateBase* base) { |
- StorageType* storage = static_cast<StorageType*>(base); |
- |
- // Local references to make debugger stepping easier. If in a debugger, |
- // you really want to warp ahead and step through the |
- // InvokeHelper<>::MakeItSo() call below. |
- typedef typename StorageType::Bound1UnwrapTraits Bound1UnwrapTraits; |
- typedef typename StorageType::Bound2UnwrapTraits Bound2UnwrapTraits; |
- typedef typename StorageType::Bound3UnwrapTraits Bound3UnwrapTraits; |
- typedef typename StorageType::Bound4UnwrapTraits Bound4UnwrapTraits; |
- typedef typename StorageType::Bound5UnwrapTraits Bound5UnwrapTraits; |
- typedef typename StorageType::Bound6UnwrapTraits Bound6UnwrapTraits; |
- typedef typename StorageType::Bound7UnwrapTraits Bound7UnwrapTraits; |
- typedef typename StorageType::Bound8UnwrapTraits Bound8UnwrapTraits; |
- |
- typename Bound1UnwrapTraits::ForwardType x1 = |
- Bound1UnwrapTraits::Unwrap(storage->p1_); |
- typename Bound2UnwrapTraits::ForwardType x2 = |
- Bound2UnwrapTraits::Unwrap(storage->p2_); |
- typename Bound3UnwrapTraits::ForwardType x3 = |
- Bound3UnwrapTraits::Unwrap(storage->p3_); |
- typename Bound4UnwrapTraits::ForwardType x4 = |
- Bound4UnwrapTraits::Unwrap(storage->p4_); |
- typename Bound5UnwrapTraits::ForwardType x5 = |
- Bound5UnwrapTraits::Unwrap(storage->p5_); |
- typename Bound6UnwrapTraits::ForwardType x6 = |
- Bound6UnwrapTraits::Unwrap(storage->p6_); |
- typename Bound7UnwrapTraits::ForwardType x7 = |
- Bound7UnwrapTraits::Unwrap(storage->p7_); |
- typename Bound8UnwrapTraits::ForwardType x8 = |
- Bound8UnwrapTraits::Unwrap(storage->p8_); |
- return InvokeHelper<StorageType::IsWeakCall::value, R, |
- typename StorageType::RunnableType, |
- void(typename Bound1UnwrapTraits::ForwardType, |
- typename Bound2UnwrapTraits::ForwardType, |
- typename Bound3UnwrapTraits::ForwardType, |
- typename Bound4UnwrapTraits::ForwardType, |
- typename Bound5UnwrapTraits::ForwardType, |
- typename Bound6UnwrapTraits::ForwardType, |
- typename Bound7UnwrapTraits::ForwardType, |
- typename Bound8UnwrapTraits::ForwardType)> |
- ::MakeItSo(storage->runnable_, CallbackForward(x1), |
- CallbackForward(x2), CallbackForward(x3), |
- CallbackForward(x4), CallbackForward(x5), |
- CallbackForward(x6), CallbackForward(x7), |
- CallbackForward(x8)); |
- } |
-}; |
- |
// BindState<> |
// |
// This stores all the state passed into Bind() and is also where most |
@@ -3415,54 +2786,6 @@ |
P7 p7_; |
}; |
-template <typename Runnable, typename RunType, typename P1, typename P2, |
- typename P3, typename P4, typename P5, typename P6, typename P7, |
- typename P8> |
-struct BindState<Runnable, RunType, void(P1, P2, P3, P4, P5, P6, |
- P7, P8)> : public BindStateBase { |
- typedef Runnable RunnableType; |
- typedef IsWeakMethod<HasIsMethodTag<Runnable>::value, P1> IsWeakCall; |
- typedef Invoker<8, BindState, RunType> InvokerType; |
- typedef typename InvokerType::UnboundRunType UnboundRunType; |
- |
- // Convenience typedefs for bound argument types. |
- typedef UnwrapTraits<P1> Bound1UnwrapTraits; |
- typedef UnwrapTraits<P2> Bound2UnwrapTraits; |
- typedef UnwrapTraits<P3> Bound3UnwrapTraits; |
- typedef UnwrapTraits<P4> Bound4UnwrapTraits; |
- typedef UnwrapTraits<P5> Bound5UnwrapTraits; |
- typedef UnwrapTraits<P6> Bound6UnwrapTraits; |
- typedef UnwrapTraits<P7> Bound7UnwrapTraits; |
- typedef UnwrapTraits<P8> Bound8UnwrapTraits; |
- |
- BindState(const Runnable& runnable, const P1& p1, const P2& p2, const P3& p3, |
- const P4& p4, const P5& p5, const P6& p6, const P7& p7, const P8& p8) |
- : runnable_(runnable), |
- p1_(p1), |
- p2_(p2), |
- p3_(p3), |
- p4_(p4), |
- p5_(p5), |
- p6_(p6), |
- p7_(p7), |
- p8_(p8) { |
- MaybeRefcount<HasIsMethodTag<Runnable>::value, P1>::AddRef(p1_); |
- } |
- |
- virtual ~BindState() { MaybeRefcount<HasIsMethodTag<Runnable>::value, |
- P1>::Release(p1_); } |
- |
- RunnableType runnable_; |
- P1 p1_; |
- P2 p2_; |
- P3 p3_; |
- P4 p4_; |
- P5 p5_; |
- P6 p6_; |
- P7 p7_; |
- P8 p8_; |
-}; |
- |
} // namespace internal |
} // namespace base |