| Index: base/tuple.h
|
| diff --git a/base/tuple.h b/base/tuple.h
|
| index 12f7f84ea50b79e4a0f92c1cb47ae0e2319a1d4a..cf21da13d83bee9f3f69b64b09ea628f5dab8be1 100644
|
| --- a/base/tuple.h
|
| +++ b/base/tuple.h
|
| @@ -3,8 +3,8 @@
|
| // found in the LICENSE file.
|
|
|
| // A Tuple is a generic templatized container, similar in concept to std::pair.
|
| -// There are classes Tuple0 to Tuple6, cooresponding to the number of elements
|
| -// it contains. The convenient MakeTuple() function takes 0 to 6 arguments,
|
| +// There are classes Tuple0 to Tuple8, cooresponding to the number of elements
|
| +// it contains. The convenient MakeTuple() function takes 0 to 8 arguments,
|
| // and will construct and return the appropriate Tuple object. The functions
|
| // DispatchToMethod and DispatchToFunction take a function pointer or instance
|
| // and method pointer, and unpack a tuple into arguments to the call.
|
| @@ -54,7 +54,7 @@ struct TupleTraits<P&> {
|
| };
|
|
|
| template <class P>
|
| -struct TupleTypes { };
|
| +struct TupleTypes;
|
|
|
| // Tuple -----------------------------------------------------------------------
|
| //
|
| @@ -70,15 +70,181 @@ struct TupleTypes { };
|
| // want filled by the dispatchee, and the tuple is merely a container for that
|
| // output (a "tier"). See MakeRefTuple and its usages.
|
|
|
| -struct Tuple0 {
|
| - typedef Tuple0 ValueTuple;
|
| - typedef Tuple0 RefTuple;
|
| - typedef Tuple0 ParamTuple;
|
| +struct Tuple0;
|
| +
|
| +template <typename A>
|
| +struct Tuple1;
|
| +
|
| +template <typename A, typename B>
|
| +struct Tuple2;
|
| +
|
| +template <typename A, typename B, typename C>
|
| +struct Tuple3;
|
| +
|
| +template <typename A, typename B, typename C, typename D>
|
| +struct Tuple4;
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E>
|
| +struct Tuple5;
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E,
|
| + typename F>
|
| +struct Tuple6;
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E,
|
| + typename F, typename G>
|
| +struct Tuple7;
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E,
|
| + typename F, typename G, typename H>
|
| +struct Tuple8;
|
| +
|
| +namespace internal {
|
| +
|
| +template <typename... T>
|
| +struct MakeTupleType;
|
| +
|
| +template <>
|
| +struct MakeTupleType<> {
|
| + typedef Tuple0 Type;
|
| +};
|
| +
|
| +template <typename A>
|
| +struct MakeTupleType<A> {
|
| + typedef Tuple1<A> Type;
|
| +};
|
| +
|
| +template <typename A, typename B>
|
| +struct MakeTupleType<A, B> {
|
| + typedef Tuple2<A, B> Type;
|
| +};
|
| +
|
| +template <typename A, typename B, typename C>
|
| +struct MakeTupleType<A, B, C> {
|
| + typedef Tuple3<A, B, C> Type;
|
| +};
|
| +
|
| +template <typename A, typename B, typename C, typename D>
|
| +struct MakeTupleType<A, B, C, D> {
|
| + typedef Tuple4<A, B, C, D> Type;
|
| +};
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E>
|
| +struct MakeTupleType<A, B, C, D, E> {
|
| + typedef Tuple5<A, B, C, D, E> Type;
|
| +};
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E,
|
| + typename F>
|
| +struct MakeTupleType<A, B, C, D, E, F> {
|
| + typedef Tuple6<A, B, C, D, E, F> Type;
|
| +};
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E,
|
| + typename F, typename G>
|
| +struct MakeTupleType<A, B, C, D, E, F, G> {
|
| + typedef Tuple7<A, B, C, D, E, F, G> Type;
|
| +};
|
| +
|
| +template <typename A, typename B, typename C, typename D, typename E,
|
| + typename F, typename G, typename H>
|
| +struct MakeTupleType<A, B, C, D, E, F, G, H> {
|
| + typedef Tuple8<A, B, C, D, E, F, G, H> Type;
|
| +};
|
| +
|
| +template <int index, typename TupleType>
|
| +struct NthTupleItemImpl;
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<0, TupleType> {
|
| + typedef typename TupleType::TypeA Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->a; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->a; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<1, TupleType> {
|
| + typedef typename TupleType::TypeB Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->b; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->b; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<2, TupleType> {
|
| + typedef typename TupleType::TypeC Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->c; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->c; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<3, TupleType> {
|
| + typedef typename TupleType::TypeD Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->d; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->d; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<4, TupleType> {
|
| + typedef typename TupleType::TypeE Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->e; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->e; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<5, TupleType> {
|
| + typedef typename TupleType::TypeF Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->f; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->f; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<6, TupleType> {
|
| + typedef typename TupleType::TypeG Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->g; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->g; }
|
| +};
|
| +
|
| +template <typename TupleType>
|
| +struct NthTupleItemImpl<7, TupleType> {
|
| + typedef typename TupleType::TypeH Type;
|
| + static Type& Get(TupleType* tuple) { return tuple->h; }
|
| + static const Type& Get(const TupleType* tuple) { return tuple->h; }
|
| +};
|
| +
|
| +} // namespace internal
|
| +
|
| +template <typename... T>
|
| +using Tuple = typename internal::MakeTupleType<T...>::Type;
|
| +
|
| +template <typename... T>
|
| +struct TupleBase {
|
| + static const int size = sizeof...(T);
|
| + typedef Tuple<T...> TupleType;
|
| +
|
| + template <int index>
|
| + using NthItemType = typename internal::NthTupleItemImpl<
|
| + index, TupleType>::Type;
|
| +
|
| + template <int index>
|
| + NthItemType<index>& Get() {
|
| + static_assert(index < size, "Index out of bound");
|
| + return internal::NthTupleItemImpl<index, TupleType>::Get(
|
| + static_cast<TupleType*>(this));
|
| + }
|
| +
|
| + template <int index>
|
| + const NthItemType<index>& Get() const {
|
| + static_assert(index < size, "Index out of bound");
|
| + return internal::NthTupleItemImpl<index, TupleType>::Get(
|
| + static_cast<const TupleType*>(this));
|
| + }
|
| +};
|
| +
|
| +struct Tuple0 : TupleBase<> {
|
| };
|
|
|
| template <class A>
|
| -struct Tuple1 {
|
| - public:
|
| +struct Tuple1 : TupleBase<A> {
|
| typedef A TypeA;
|
|
|
| Tuple1() {}
|
| @@ -88,8 +254,7 @@ struct Tuple1 {
|
| };
|
|
|
| template <class A, class B>
|
| -struct Tuple2 {
|
| - public:
|
| +struct Tuple2 : TupleBase<A, B> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
|
|
| @@ -104,8 +269,7 @@ struct Tuple2 {
|
| };
|
|
|
| template <class A, class B, class C>
|
| -struct Tuple3 {
|
| - public:
|
| +struct Tuple3 : TupleBase<A, B, C> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
| typedef C TypeC;
|
| @@ -123,8 +287,7 @@ struct Tuple3 {
|
| };
|
|
|
| template <class A, class B, class C, class D>
|
| -struct Tuple4 {
|
| - public:
|
| +struct Tuple4 : TupleBase<A, B, C, D> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
| typedef C TypeC;
|
| @@ -145,8 +308,7 @@ struct Tuple4 {
|
| };
|
|
|
| template <class A, class B, class C, class D, class E>
|
| -struct Tuple5 {
|
| - public:
|
| +struct Tuple5 : TupleBase<A, B, C, D, E> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
| typedef C TypeC;
|
| @@ -155,11 +317,11 @@ struct Tuple5 {
|
|
|
| Tuple5() {}
|
| Tuple5(typename TupleTraits<A>::ParamType a,
|
| - typename TupleTraits<B>::ParamType b,
|
| - typename TupleTraits<C>::ParamType c,
|
| - typename TupleTraits<D>::ParamType d,
|
| - typename TupleTraits<E>::ParamType e)
|
| - : a(a), b(b), c(c), d(d), e(e) {
|
| + typename TupleTraits<B>::ParamType b,
|
| + typename TupleTraits<C>::ParamType c,
|
| + typename TupleTraits<D>::ParamType d,
|
| + typename TupleTraits<E>::ParamType e)
|
| + : a(a), b(b), c(c), d(d), e(e) {
|
| }
|
|
|
| A a;
|
| @@ -170,8 +332,7 @@ struct Tuple5 {
|
| };
|
|
|
| template <class A, class B, class C, class D, class E, class F>
|
| -struct Tuple6 {
|
| - public:
|
| +struct Tuple6 : TupleBase<A, B, C, D, E, F> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
| typedef C TypeC;
|
| @@ -181,12 +342,12 @@ struct Tuple6 {
|
|
|
| Tuple6() {}
|
| Tuple6(typename TupleTraits<A>::ParamType a,
|
| - typename TupleTraits<B>::ParamType b,
|
| - typename TupleTraits<C>::ParamType c,
|
| - typename TupleTraits<D>::ParamType d,
|
| - typename TupleTraits<E>::ParamType e,
|
| - typename TupleTraits<F>::ParamType f)
|
| - : a(a), b(b), c(c), d(d), e(e), f(f) {
|
| + typename TupleTraits<B>::ParamType b,
|
| + typename TupleTraits<C>::ParamType c,
|
| + typename TupleTraits<D>::ParamType d,
|
| + typename TupleTraits<E>::ParamType e,
|
| + typename TupleTraits<F>::ParamType f)
|
| + : a(a), b(b), c(c), d(d), e(e), f(f) {
|
| }
|
|
|
| A a;
|
| @@ -198,8 +359,7 @@ struct Tuple6 {
|
| };
|
|
|
| template <class A, class B, class C, class D, class E, class F, class G>
|
| -struct Tuple7 {
|
| - public:
|
| +struct Tuple7 : TupleBase<A, B, C, D, E, F, G> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
| typedef C TypeC;
|
| @@ -210,13 +370,13 @@ struct Tuple7 {
|
|
|
| Tuple7() {}
|
| Tuple7(typename TupleTraits<A>::ParamType a,
|
| - typename TupleTraits<B>::ParamType b,
|
| - typename TupleTraits<C>::ParamType c,
|
| - typename TupleTraits<D>::ParamType d,
|
| - typename TupleTraits<E>::ParamType e,
|
| - typename TupleTraits<F>::ParamType f,
|
| - typename TupleTraits<G>::ParamType g)
|
| - : a(a), b(b), c(c), d(d), e(e), f(f), g(g) {
|
| + typename TupleTraits<B>::ParamType b,
|
| + typename TupleTraits<C>::ParamType c,
|
| + typename TupleTraits<D>::ParamType d,
|
| + typename TupleTraits<E>::ParamType e,
|
| + typename TupleTraits<F>::ParamType f,
|
| + typename TupleTraits<G>::ParamType g)
|
| + : a(a), b(b), c(c), d(d), e(e), f(f), g(g) {
|
| }
|
|
|
| A a;
|
| @@ -230,8 +390,7 @@ struct Tuple7 {
|
|
|
| template <class A, class B, class C, class D, class E, class F, class G,
|
| class H>
|
| -struct Tuple8 {
|
| - public:
|
| +struct Tuple8 : TupleBase<A, B, C, D, E, F, G, H> {
|
| typedef A TypeA;
|
| typedef B TypeB;
|
| typedef C TypeC;
|
| @@ -243,14 +402,14 @@ struct Tuple8 {
|
|
|
| Tuple8() {}
|
| Tuple8(typename TupleTraits<A>::ParamType a,
|
| - typename TupleTraits<B>::ParamType b,
|
| - typename TupleTraits<C>::ParamType c,
|
| - typename TupleTraits<D>::ParamType d,
|
| - typename TupleTraits<E>::ParamType e,
|
| - typename TupleTraits<F>::ParamType f,
|
| - typename TupleTraits<G>::ParamType g,
|
| - typename TupleTraits<H>::ParamType h)
|
| - : a(a), b(b), c(c), d(d), e(e), f(f), g(g), h(h) {
|
| + typename TupleTraits<B>::ParamType b,
|
| + typename TupleTraits<C>::ParamType c,
|
| + typename TupleTraits<D>::ParamType d,
|
| + typename TupleTraits<E>::ParamType e,
|
| + typename TupleTraits<F>::ParamType f,
|
| + typename TupleTraits<G>::ParamType g,
|
| + typename TupleTraits<H>::ParamType h)
|
| + : a(a), b(b), c(c), d(d), e(e), f(f), g(g), h(h) {
|
| }
|
|
|
| A a;
|
| @@ -286,8 +445,8 @@ template <class A, class B>
|
| struct TupleTypes< Tuple2<A, B> > {
|
| typedef Tuple2<typename TupleTraits<A>::ValueType,
|
| typename TupleTraits<B>::ValueType> ValueTuple;
|
| -typedef Tuple2<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType> RefTuple;
|
| + typedef Tuple2<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType> RefTuple;
|
| typedef Tuple2<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType> ParamTuple;
|
| };
|
| @@ -297,9 +456,9 @@ struct TupleTypes< Tuple3<A, B, C> > {
|
| typedef Tuple3<typename TupleTraits<A>::ValueType,
|
| typename TupleTraits<B>::ValueType,
|
| typename TupleTraits<C>::ValueType> ValueTuple;
|
| -typedef Tuple3<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType,
|
| - typename TupleTraits<C>::RefType> RefTuple;
|
| + typedef Tuple3<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType,
|
| + typename TupleTraits<C>::RefType> RefTuple;
|
| typedef Tuple3<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType,
|
| typename TupleTraits<C>::ParamType> ParamTuple;
|
| @@ -311,10 +470,10 @@ struct TupleTypes< Tuple4<A, B, C, D> > {
|
| typename TupleTraits<B>::ValueType,
|
| typename TupleTraits<C>::ValueType,
|
| typename TupleTraits<D>::ValueType> ValueTuple;
|
| -typedef Tuple4<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType,
|
| - typename TupleTraits<C>::RefType,
|
| - typename TupleTraits<D>::RefType> RefTuple;
|
| + typedef Tuple4<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType,
|
| + typename TupleTraits<C>::RefType,
|
| + typename TupleTraits<D>::RefType> RefTuple;
|
| typedef Tuple4<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType,
|
| typename TupleTraits<C>::ParamType,
|
| @@ -328,11 +487,11 @@ struct TupleTypes< Tuple5<A, B, C, D, E> > {
|
| typename TupleTraits<C>::ValueType,
|
| typename TupleTraits<D>::ValueType,
|
| typename TupleTraits<E>::ValueType> ValueTuple;
|
| -typedef Tuple5<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType,
|
| - typename TupleTraits<C>::RefType,
|
| - typename TupleTraits<D>::RefType,
|
| - typename TupleTraits<E>::RefType> RefTuple;
|
| + typedef Tuple5<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType,
|
| + typename TupleTraits<C>::RefType,
|
| + typename TupleTraits<D>::RefType,
|
| + typename TupleTraits<E>::RefType> RefTuple;
|
| typedef Tuple5<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType,
|
| typename TupleTraits<C>::ParamType,
|
| @@ -348,12 +507,12 @@ struct TupleTypes< Tuple6<A, B, C, D, E, F> > {
|
| typename TupleTraits<D>::ValueType,
|
| typename TupleTraits<E>::ValueType,
|
| typename TupleTraits<F>::ValueType> ValueTuple;
|
| -typedef Tuple6<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType,
|
| - typename TupleTraits<C>::RefType,
|
| - typename TupleTraits<D>::RefType,
|
| - typename TupleTraits<E>::RefType,
|
| - typename TupleTraits<F>::RefType> RefTuple;
|
| + typedef Tuple6<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType,
|
| + typename TupleTraits<C>::RefType,
|
| + typename TupleTraits<D>::RefType,
|
| + typename TupleTraits<E>::RefType,
|
| + typename TupleTraits<F>::RefType> RefTuple;
|
| typedef Tuple6<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType,
|
| typename TupleTraits<C>::ParamType,
|
| @@ -371,13 +530,13 @@ struct TupleTypes< Tuple7<A, B, C, D, E, F, G> > {
|
| typename TupleTraits<E>::ValueType,
|
| typename TupleTraits<F>::ValueType,
|
| typename TupleTraits<G>::ValueType> ValueTuple;
|
| -typedef Tuple7<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType,
|
| - typename TupleTraits<C>::RefType,
|
| - typename TupleTraits<D>::RefType,
|
| - typename TupleTraits<E>::RefType,
|
| - typename TupleTraits<F>::RefType,
|
| - typename TupleTraits<G>::RefType> RefTuple;
|
| + typedef Tuple7<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType,
|
| + typename TupleTraits<C>::RefType,
|
| + typename TupleTraits<D>::RefType,
|
| + typename TupleTraits<E>::RefType,
|
| + typename TupleTraits<F>::RefType,
|
| + typename TupleTraits<G>::RefType> RefTuple;
|
| typedef Tuple7<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType,
|
| typename TupleTraits<C>::ParamType,
|
| @@ -398,14 +557,14 @@ struct TupleTypes< Tuple8<A, B, C, D, E, F, G, H> > {
|
| typename TupleTraits<F>::ValueType,
|
| typename TupleTraits<G>::ValueType,
|
| typename TupleTraits<H>::ValueType> ValueTuple;
|
| -typedef Tuple8<typename TupleTraits<A>::RefType,
|
| - typename TupleTraits<B>::RefType,
|
| - typename TupleTraits<C>::RefType,
|
| - typename TupleTraits<D>::RefType,
|
| - typename TupleTraits<E>::RefType,
|
| - typename TupleTraits<F>::RefType,
|
| - typename TupleTraits<G>::RefType,
|
| - typename TupleTraits<H>::RefType> RefTuple;
|
| + typedef Tuple8<typename TupleTraits<A>::RefType,
|
| + typename TupleTraits<B>::RefType,
|
| + typename TupleTraits<C>::RefType,
|
| + typename TupleTraits<D>::RefType,
|
| + typename TupleTraits<E>::RefType,
|
| + typename TupleTraits<F>::RefType,
|
| + typename TupleTraits<G>::RefType,
|
| + typename TupleTraits<H>::RefType> RefTuple;
|
| typedef Tuple8<typename TupleTraits<A>::ParamType,
|
| typename TupleTraits<B>::ParamType,
|
| typename TupleTraits<C>::ParamType,
|
| @@ -418,108 +577,18 @@ typedef Tuple8<typename TupleTraits<A>::RefType,
|
|
|
| // Tuple creators -------------------------------------------------------------
|
| //
|
| -// Helper functions for constructing tuples while inferring the template
|
| +// Helper function for constructing tuples while inferring the template
|
| // argument types.
|
| -
|
| -inline Tuple0 MakeTuple() {
|
| - return Tuple0();
|
| -}
|
| -
|
| -template <class A>
|
| -inline Tuple1<A> MakeTuple(const A& a) {
|
| - return Tuple1<A>(a);
|
| -}
|
| -
|
| -template <class A, class B>
|
| -inline Tuple2<A, B> MakeTuple(const A& a, const B& b) {
|
| - return Tuple2<A, B>(a, b);
|
| -}
|
| -
|
| -template <class A, class B, class C>
|
| -inline Tuple3<A, B, C> MakeTuple(const A& a, const B& b, const C& c) {
|
| - return Tuple3<A, B, C>(a, b, c);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D>
|
| -inline Tuple4<A, B, C, D> MakeTuple(const A& a, const B& b, const C& c,
|
| - const D& d) {
|
| - return Tuple4<A, B, C, D>(a, b, c, d);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E>
|
| -inline Tuple5<A, B, C, D, E> MakeTuple(const A& a, const B& b, const C& c,
|
| - const D& d, const E& e) {
|
| - return Tuple5<A, B, C, D, E>(a, b, c, d, e);
|
| +template <typename... T>
|
| +inline Tuple<T...> MakeTuple(const T&... p) {
|
| + return Tuple<T...>(p...);
|
| }
|
|
|
| -template <class A, class B, class C, class D, class E, class F>
|
| -inline Tuple6<A, B, C, D, E, F> MakeTuple(const A& a, const B& b, const C& c,
|
| - const D& d, const E& e, const F& f) {
|
| - return Tuple6<A, B, C, D, E, F>(a, b, c, d, e, f);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E, class F, class G>
|
| -inline Tuple7<A, B, C, D, E, F, G> MakeTuple(const A& a, const B& b, const C& c,
|
| - const D& d, const E& e, const F& f,
|
| - const G& g) {
|
| - return Tuple7<A, B, C, D, E, F, G>(a, b, c, d, e, f, g);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E, class F, class G,
|
| - class H>
|
| -inline Tuple8<A, B, C, D, E, F, G, H> MakeTuple(const A& a, const B& b,
|
| - const C& c, const D& d,
|
| - const E& e, const F& f,
|
| - const G& g, const H& h) {
|
| - return Tuple8<A, B, C, D, E, F, G, H>(a, b, c, d, e, f, g, h);
|
| -}
|
| -
|
| -// The following set of helpers make what Boost refers to as "Tiers" - a tuple
|
| +// The following helper make what Boost refers to as "Tiers" - a tuple
|
| // of references.
|
| -
|
| -template <class A>
|
| -inline Tuple1<A&> MakeRefTuple(A& a) {
|
| - return Tuple1<A&>(a);
|
| -}
|
| -
|
| -template <class A, class B>
|
| -inline Tuple2<A&, B&> MakeRefTuple(A& a, B& b) {
|
| - return Tuple2<A&, B&>(a, b);
|
| -}
|
| -
|
| -template <class A, class B, class C>
|
| -inline Tuple3<A&, B&, C&> MakeRefTuple(A& a, B& b, C& c) {
|
| - return Tuple3<A&, B&, C&>(a, b, c);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D>
|
| -inline Tuple4<A&, B&, C&, D&> MakeRefTuple(A& a, B& b, C& c, D& d) {
|
| - return Tuple4<A&, B&, C&, D&>(a, b, c, d);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E>
|
| -inline Tuple5<A&, B&, C&, D&, E&> MakeRefTuple(A& a, B& b, C& c, D& d, E& e) {
|
| - return Tuple5<A&, B&, C&, D&, E&>(a, b, c, d, e);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E, class F>
|
| -inline Tuple6<A&, B&, C&, D&, E&, F&> MakeRefTuple(A& a, B& b, C& c, D& d, E& e,
|
| - F& f) {
|
| - return Tuple6<A&, B&, C&, D&, E&, F&>(a, b, c, d, e, f);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E, class F, class G>
|
| -inline Tuple7<A&, B&, C&, D&, E&, F&, G&> MakeRefTuple(A& a, B& b, C& c, D& d,
|
| - E& e, F& f, G& g) {
|
| - return Tuple7<A&, B&, C&, D&, E&, F&, G&>(a, b, c, d, e, f, g);
|
| -}
|
| -
|
| -template <class A, class B, class C, class D, class E, class F, class G,
|
| - class H>
|
| -inline Tuple8<A&, B&, C&, D&, E&, F&, G&, H&> MakeRefTuple(A& a, B& b, C& c,
|
| - D& d, E& e, F& f,
|
| - G& g, H& h) {
|
| - return Tuple8<A&, B&, C&, D&, E&, F&, G&, H&>(a, b, c, d, e, f, g, h);
|
| +template <typename... T>
|
| +inline Tuple<T&...> MakeRefTuple(T&... p) {
|
| + return Tuple<T&...>(p...);
|
| }
|
|
|
| // Dispatchers ----------------------------------------------------------------
|
| @@ -539,11 +608,6 @@ inline void DispatchToMethod(ObjT* obj, Method method, const Tuple0& arg) {
|
| }
|
|
|
| template <class ObjT, class Method, class A>
|
| -inline void DispatchToMethod(ObjT* obj, Method method, const A& arg) {
|
| - (obj->*method)(base::internal::UnwrapTraits<A>::Unwrap(arg));
|
| -}
|
| -
|
| -template <class ObjT, class Method, class A>
|
| inline void DispatchToMethod(ObjT* obj, Method method, const Tuple1<A>& arg) {
|
| (obj->*method)(base::internal::UnwrapTraits<A>::Unwrap(arg.a));
|
| }
|
| @@ -630,11 +694,6 @@ inline void DispatchToFunction(Function function, const Tuple0& arg) {
|
| }
|
|
|
| template <class Function, class A>
|
| -inline void DispatchToFunction(Function function, const A& arg) {
|
| - (*function)(arg);
|
| -}
|
| -
|
| -template <class Function, class A>
|
| inline void DispatchToFunction(Function function, const Tuple1<A>& arg) {
|
| (*function)(base::internal::UnwrapTraits<A>::Unwrap(arg.a));
|
| }
|
| @@ -719,11 +778,6 @@ inline void DispatchToMethod(ObjT* obj,
|
| }
|
|
|
| template <class ObjT, class Method, class A>
|
| -inline void DispatchToMethod(ObjT* obj, Method method, const A& arg, Tuple0*) {
|
| - (obj->*method)(base::internal::UnwrapTraits<A>::Unwrap(arg));
|
| -}
|
| -
|
| -template <class ObjT, class Method, class A>
|
| inline void DispatchToMethod(ObjT* obj,
|
| Method method,
|
| const Tuple1<A>& arg, Tuple0*) {
|
| @@ -790,14 +844,6 @@ inline void DispatchToMethod(ObjT* obj, Method method,
|
| template<class ObjT, class Method, class InA,
|
| class OutA>
|
| inline void DispatchToMethod(ObjT* obj, Method method,
|
| - const InA& in,
|
| - Tuple1<OutA>* out) {
|
| - (obj->*method)(in, &out->a);
|
| -}
|
| -
|
| -template<class ObjT, class Method, class InA,
|
| - class OutA>
|
| -inline void DispatchToMethod(ObjT* obj, Method method,
|
| const Tuple1<InA>& in,
|
| Tuple1<OutA>* out) {
|
| (obj->*method)(base::internal::UnwrapTraits<InA>::Unwrap(in.a), &out->a);
|
| @@ -877,14 +923,6 @@ inline void DispatchToMethod(ObjT* obj, Method method,
|
| template<class ObjT, class Method, class InA,
|
| class OutA, class OutB>
|
| inline void DispatchToMethod(ObjT* obj, Method method,
|
| - const InA& in,
|
| - Tuple2<OutA, OutB>* out) {
|
| - (obj->*method)(in, &out->a, &out->b);
|
| -}
|
| -
|
| -template<class ObjT, class Method, class InA,
|
| - class OutA, class OutB>
|
| -inline void DispatchToMethod(ObjT* obj, Method method,
|
| const Tuple1<InA>& in,
|
| Tuple2<OutA, OutB>* out) {
|
| (obj->*method)(
|
| @@ -971,14 +1009,6 @@ inline void DispatchToMethod(ObjT* obj, Method method,
|
| template<class ObjT, class Method, class InA,
|
| class OutA, class OutB, class OutC>
|
| inline void DispatchToMethod(ObjT* obj, Method method,
|
| - const InA& in,
|
| - Tuple3<OutA, OutB, OutC>* out) {
|
| - (obj->*method)(in, &out->a, &out->b, &out->c);
|
| -}
|
| -
|
| -template<class ObjT, class Method, class InA,
|
| - class OutA, class OutB, class OutC>
|
| -inline void DispatchToMethod(ObjT* obj, Method method,
|
| const Tuple1<InA>& in,
|
| Tuple3<OutA, OutB, OutC>* out) {
|
| (obj->*method)(base::internal::UnwrapTraits<InA>::Unwrap(in.a),
|
| @@ -1072,18 +1102,6 @@ inline void DispatchToMethod(ObjT* obj, Method method,
|
| template<class ObjT, class Method, class InA,
|
| class OutA, class OutB, class OutC, class OutD>
|
| inline void DispatchToMethod(ObjT* obj, Method method,
|
| - const InA& in,
|
| - Tuple4<OutA, OutB, OutC, OutD>* out) {
|
| - (obj->*method)(base::internal::UnwrapTraits<InA>::Unwrap(in),
|
| - &out->a,
|
| - &out->b,
|
| - &out->c,
|
| - &out->d);
|
| -}
|
| -
|
| -template<class ObjT, class Method, class InA,
|
| - class OutA, class OutB, class OutC, class OutD>
|
| -inline void DispatchToMethod(ObjT* obj, Method method,
|
| const Tuple1<InA>& in,
|
| Tuple4<OutA, OutB, OutC, OutD>* out) {
|
| (obj->*method)(base::internal::UnwrapTraits<InA>::Unwrap(in.a),
|
| @@ -1183,19 +1201,6 @@ inline void DispatchToMethod(ObjT* obj, Method method,
|
| template<class ObjT, class Method, class InA,
|
| class OutA, class OutB, class OutC, class OutD, class OutE>
|
| inline void DispatchToMethod(ObjT* obj, Method method,
|
| - const InA& in,
|
| - Tuple5<OutA, OutB, OutC, OutD, OutE>* out) {
|
| - (obj->*method)(base::internal::UnwrapTraits<InA>::Unwrap(in),
|
| - &out->a,
|
| - &out->b,
|
| - &out->c,
|
| - &out->d,
|
| - &out->e);
|
| -}
|
| -
|
| -template<class ObjT, class Method, class InA,
|
| - class OutA, class OutB, class OutC, class OutD, class OutE>
|
| -inline void DispatchToMethod(ObjT* obj, Method method,
|
| const Tuple1<InA>& in,
|
| Tuple5<OutA, OutB, OutC, OutD, OutE>* out) {
|
| (obj->*method)(base::internal::UnwrapTraits<InA>::Unwrap(in.a),
|
|
|