mirror of
https://github.com/boostorg/tuple.git
synced 2025-08-01 05:34:30 +02:00
tuples in separate namespaces now compile under MSVC++ as well
changed tuple_length, tuple_element, tuple_access_traits to tuples::length, tuples::element and tuples::access_traits [SVN r11058]
This commit is contained in:
@@ -59,7 +59,7 @@ template <
|
|||||||
class tuple;
|
class tuple;
|
||||||
|
|
||||||
// tuple_length forward declaration
|
// tuple_length forward declaration
|
||||||
template<class T> struct tuple_length;
|
template<class T> struct length;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -106,24 +106,24 @@ struct default_arg<T&> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// - cons getters --------------------------------------------------------
|
// - cons getters --------------------------------------------------------
|
||||||
// called: element<N>::get<RETURN_TYPE>(aTuple)
|
// called: get_class<N>::get<RETURN_TYPE>(aTuple)
|
||||||
|
|
||||||
template< int N >
|
template< int N >
|
||||||
struct element {
|
struct get_class {
|
||||||
template<class RET, class HT, class TT >
|
template<class RET, class HT, class TT >
|
||||||
inline static RET get(const cons<HT, TT>& t)
|
inline static RET get(const cons<HT, TT>& t)
|
||||||
{
|
{
|
||||||
return element<N-1>::template get<RET>(t.tail);
|
return get_class<N-1>::template get<RET>(t.tail);
|
||||||
}
|
}
|
||||||
template<class RET, class HT, class TT >
|
template<class RET, class HT, class TT >
|
||||||
inline static RET get(cons<HT, TT>& t)
|
inline static RET get(cons<HT, TT>& t)
|
||||||
{
|
{
|
||||||
return element<N-1>::template get<RET>(t.tail);
|
return get_class<N-1>::template get<RET>(t.tail);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct element<0> {
|
struct get_class<0> {
|
||||||
template<class RET, class HT, class TT>
|
template<class RET, class HT, class TT>
|
||||||
inline static RET get(const cons<HT, TT>& t)
|
inline static RET get(const cons<HT, TT>& t)
|
||||||
{
|
{
|
||||||
@@ -140,20 +140,20 @@ struct element<0> {
|
|||||||
|
|
||||||
|
|
||||||
// -cons type accessors ----------------------------------------
|
// -cons type accessors ----------------------------------------
|
||||||
// typename tuple_element<N,T>::type gets the type of the
|
// typename tuples::element<N,T>::type gets the type of the
|
||||||
// Nth element ot T, first element is at index 0
|
// Nth element ot T, first element is at index 0
|
||||||
// -------------------------------------------------------
|
// -------------------------------------------------------
|
||||||
|
|
||||||
template<int N, class T>
|
template<int N, class T>
|
||||||
struct tuple_element
|
struct element
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef typename T::tail_type Next;
|
typedef typename T::tail_type Next;
|
||||||
public:
|
public:
|
||||||
typedef typename tuple_element<N-1, Next>::type type;
|
typedef typename element<N-1, Next>::type type;
|
||||||
};
|
};
|
||||||
template<class T>
|
template<class T>
|
||||||
struct tuple_element<0,T>
|
struct element<0,T>
|
||||||
{
|
{
|
||||||
typedef typename T::head_type type;
|
typedef typename T::head_type type;
|
||||||
};
|
};
|
||||||
@@ -167,7 +167,7 @@ struct tuple_element<0,T>
|
|||||||
// (Joel de Guzman's suggestion). Rationale: get functions are part of the
|
// (Joel de Guzman's suggestion). Rationale: get functions are part of the
|
||||||
// interface, so should the way to express their return types be.
|
// interface, so should the way to express their return types be.
|
||||||
|
|
||||||
template <class T> struct tuple_access_traits {
|
template <class T> struct access_traits {
|
||||||
typedef const T& const_type;
|
typedef const T& const_type;
|
||||||
typedef T& non_const_type;
|
typedef T& non_const_type;
|
||||||
|
|
||||||
@@ -179,7 +179,7 @@ template <class T> struct tuple_access_traits {
|
|||||||
// be non-volatile and const. 8.5.3. (5)
|
// be non-volatile and const. 8.5.3. (5)
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class T> struct tuple_access_traits<T&> {
|
template <class T> struct access_traits<T&> {
|
||||||
|
|
||||||
typedef T& const_type;
|
typedef T& const_type;
|
||||||
typedef T& non_const_type;
|
typedef T& non_const_type;
|
||||||
@@ -191,14 +191,14 @@ template <class T> struct tuple_access_traits<T&> {
|
|||||||
// get function for non-const cons-lists, returns a reference to the element
|
// get function for non-const cons-lists, returns a reference to the element
|
||||||
|
|
||||||
template<int N, class HT, class TT>
|
template<int N, class HT, class TT>
|
||||||
inline typename tuple_access_traits<
|
inline typename access_traits<
|
||||||
typename tuple_element<N, cons<HT, TT> >::type
|
typename element<N, cons<HT, TT> >::type
|
||||||
>::non_const_type
|
>::non_const_type
|
||||||
get(cons<HT, TT>& c) {
|
get(cons<HT, TT>& c) {
|
||||||
return detail::element<N>::template
|
return detail::get_class<N>::template
|
||||||
get<
|
get<
|
||||||
typename tuple_access_traits<
|
typename access_traits<
|
||||||
typename tuple_element<N, cons<HT, TT> >::type
|
typename element<N, cons<HT, TT> >::type
|
||||||
>::non_const_type>(c);
|
>::non_const_type>(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -206,14 +206,14 @@ get(cons<HT, TT>& c) {
|
|||||||
// the element. If the element is a reference, returns the reference
|
// the element. If the element is a reference, returns the reference
|
||||||
// as such (that is, can return a non-const reference)
|
// as such (that is, can return a non-const reference)
|
||||||
template<int N, class HT, class TT>
|
template<int N, class HT, class TT>
|
||||||
inline typename tuple_access_traits<
|
inline typename access_traits<
|
||||||
typename tuple_element<N, cons<HT, TT> >::type
|
typename element<N, cons<HT, TT> >::type
|
||||||
>::const_type
|
>::const_type
|
||||||
get(const cons<HT, TT>& c) {
|
get(const cons<HT, TT>& c) {
|
||||||
return detail::element<N>::template
|
return detail::get_class<N>::template
|
||||||
get<
|
get<
|
||||||
typename tuple_access_traits<
|
typename access_traits<
|
||||||
typename tuple_element<N, cons<HT, TT> >::type
|
typename element<N, cons<HT, TT> >::type
|
||||||
>::const_type>(c);
|
>::const_type>(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -231,16 +231,16 @@ struct cons {
|
|||||||
head_type head;
|
head_type head;
|
||||||
tail_type tail;
|
tail_type tail;
|
||||||
|
|
||||||
typename tuple_access_traits<head_type>::non_const_type
|
typename access_traits<head_type>::non_const_type
|
||||||
get_head() { return head; }
|
get_head() { return head; }
|
||||||
|
|
||||||
typename tuple_access_traits<tail_type>::non_const_type
|
typename access_traits<tail_type>::non_const_type
|
||||||
get_tail() { return tail; }
|
get_tail() { return tail; }
|
||||||
|
|
||||||
typename tuple_access_traits<head_type>::const_type
|
typename access_traits<head_type>::const_type
|
||||||
get_head() const { return head; }
|
get_head() const { return head; }
|
||||||
|
|
||||||
typename tuple_access_traits<tail_type>::const_type
|
typename access_traits<tail_type>::const_type
|
||||||
get_tail() const { return tail; }
|
get_tail() const { return tail; }
|
||||||
|
|
||||||
cons() : head(detail::default_arg<HT>::f()), tail() {}
|
cons() : head(detail::default_arg<HT>::f()), tail() {}
|
||||||
@@ -249,7 +249,7 @@ struct cons {
|
|||||||
// cannot be supported properly in any case (no assignment,
|
// cannot be supported properly in any case (no assignment,
|
||||||
// copy works only if the tails are exactly the same type, ...)
|
// copy works only if the tails are exactly the same type, ...)
|
||||||
|
|
||||||
cons(typename tuple_access_traits<head_type>::parameter_type h,
|
cons(typename access_traits<head_type>::parameter_type h,
|
||||||
const tail_type& t)
|
const tail_type& t)
|
||||||
: head (h), tail(t) {}
|
: head (h), tail(t) {}
|
||||||
|
|
||||||
@@ -277,22 +277,22 @@ struct cons {
|
|||||||
|
|
||||||
template <class T1, class T2>
|
template <class T1, class T2>
|
||||||
cons& operator=( const std::pair<T1, T2>& u ) {
|
cons& operator=( const std::pair<T1, T2>& u ) {
|
||||||
BOOST_STATIC_ASSERT(tuple_length<cons>::value == 2); // check length = 2
|
BOOST_STATIC_ASSERT(length<cons>::value == 2); // check length = 2
|
||||||
head = u.first; tail.head = u.second; return *this;
|
head = u.first; tail.head = u.second; return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get member functions (non-const and const)
|
// get member functions (non-const and const)
|
||||||
template <int N>
|
template <int N>
|
||||||
typename tuple_access_traits<
|
typename access_traits<
|
||||||
typename tuple_element<N, cons<HT, TT> >::type
|
typename element<N, cons<HT, TT> >::type
|
||||||
>::non_const_type
|
>::non_const_type
|
||||||
get() {
|
get() {
|
||||||
return boost::get<N>(*this); // delegate to non-member get
|
return boost::get<N>(*this); // delegate to non-member get
|
||||||
}
|
}
|
||||||
|
|
||||||
template <int N>
|
template <int N>
|
||||||
typename tuple_access_traits<
|
typename access_traits<
|
||||||
typename tuple_element<N, cons<HT, TT> >::type
|
typename element<N, cons<HT, TT> >::type
|
||||||
>::const_type
|
>::const_type
|
||||||
get() const {
|
get() const {
|
||||||
return boost::get<N>(*this); // delegate to non-member get
|
return boost::get<N>(*this); // delegate to non-member get
|
||||||
@@ -307,19 +307,19 @@ struct cons<HT, null_type> {
|
|||||||
|
|
||||||
head_type head;
|
head_type head;
|
||||||
|
|
||||||
typename tuple_access_traits<head_type>::non_const_type
|
typename access_traits<head_type>::non_const_type
|
||||||
get_head() { return head; }
|
get_head() { return head; }
|
||||||
|
|
||||||
null_type get_tail() { return null_type(); }
|
null_type get_tail() { return null_type(); }
|
||||||
|
|
||||||
typename tuple_access_traits<head_type>::const_type
|
typename access_traits<head_type>::const_type
|
||||||
get_head() const { return head; }
|
get_head() const { return head; }
|
||||||
|
|
||||||
const null_type get_tail() const { return null_type(); }
|
const null_type get_tail() const { return null_type(); }
|
||||||
|
|
||||||
cons() : head(detail::default_arg<HT>::f()) {}
|
cons() : head(detail::default_arg<HT>::f()) {}
|
||||||
|
|
||||||
cons(typename tuple_access_traits<head_type>::parameter_type h,
|
cons(typename access_traits<head_type>::parameter_type h,
|
||||||
const null_type& = null_type())
|
const null_type& = null_type())
|
||||||
: head (h) {}
|
: head (h) {}
|
||||||
|
|
||||||
@@ -341,16 +341,16 @@ struct cons<HT, null_type> {
|
|||||||
cons& operator=(const cons& u) { head = u.head; return *this; }
|
cons& operator=(const cons& u) { head = u.head; return *this; }
|
||||||
|
|
||||||
template <int N>
|
template <int N>
|
||||||
typename tuple_access_traits<
|
typename access_traits<
|
||||||
typename tuple_element<N, cons>::type
|
typename element<N, cons>::type
|
||||||
>::non_const_type
|
>::non_const_type
|
||||||
get() {
|
get() {
|
||||||
return boost::get<N>(*this);
|
return boost::get<N>(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <int N>
|
template <int N>
|
||||||
typename tuple_access_traits<
|
typename access_traits<
|
||||||
typename tuple_element<N, cons>::type
|
typename element<N, cons>::type
|
||||||
>::const_type
|
>::const_type
|
||||||
get() const {
|
get() const {
|
||||||
return boost::get<N>(*this);
|
return boost::get<N>(*this);
|
||||||
@@ -361,12 +361,12 @@ struct cons<HT, null_type> {
|
|||||||
// templates for finding out the length of the tuple -------------------
|
// templates for finding out the length of the tuple -------------------
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
struct tuple_length {
|
struct length {
|
||||||
BOOST_STATIC_CONSTANT(int, value = 1 + tuple_length<typename T::tail_type>::value);
|
BOOST_STATIC_CONSTANT(int, value = 1 + length<typename T::tail_type>::value);
|
||||||
};
|
};
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct tuple_length<null_type> {
|
struct length<null_type> {
|
||||||
BOOST_STATIC_CONSTANT(int, value = 0);
|
BOOST_STATIC_CONSTANT(int, value = 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -408,27 +408,27 @@ public:
|
|||||||
typedef typename inherited::tail_type tail_type;
|
typedef typename inherited::tail_type tail_type;
|
||||||
|
|
||||||
|
|
||||||
// tuple_access_traits<T>::parameter_type takes non-reference types as const T&
|
// access_traits<T>::parameter_type takes non-reference types as const T&
|
||||||
explicit tuple(
|
explicit tuple(
|
||||||
typename tuple_access_traits<T0>::parameter_type t0
|
typename access_traits<T0>::parameter_type t0
|
||||||
= detail::default_arg<T0>::f(),
|
= detail::default_arg<T0>::f(),
|
||||||
typename tuple_access_traits<T1>::parameter_type t1
|
typename access_traits<T1>::parameter_type t1
|
||||||
= detail::default_arg<T1>::f(),
|
= detail::default_arg<T1>::f(),
|
||||||
typename tuple_access_traits<T2>::parameter_type t2
|
typename access_traits<T2>::parameter_type t2
|
||||||
= detail::default_arg<T2>::f(),
|
= detail::default_arg<T2>::f(),
|
||||||
typename tuple_access_traits<T3>::parameter_type t3
|
typename access_traits<T3>::parameter_type t3
|
||||||
= detail::default_arg<T3>::f(),
|
= detail::default_arg<T3>::f(),
|
||||||
typename tuple_access_traits<T4>::parameter_type t4
|
typename access_traits<T4>::parameter_type t4
|
||||||
= detail::default_arg<T4>::f(),
|
= detail::default_arg<T4>::f(),
|
||||||
typename tuple_access_traits<T5>::parameter_type t5
|
typename access_traits<T5>::parameter_type t5
|
||||||
= detail::default_arg<T5>::f(),
|
= detail::default_arg<T5>::f(),
|
||||||
typename tuple_access_traits<T6>::parameter_type t6
|
typename access_traits<T6>::parameter_type t6
|
||||||
= detail::default_arg<T6>::f(),
|
= detail::default_arg<T6>::f(),
|
||||||
typename tuple_access_traits<T7>::parameter_type t7
|
typename access_traits<T7>::parameter_type t7
|
||||||
= detail::default_arg<T7>::f(),
|
= detail::default_arg<T7>::f(),
|
||||||
typename tuple_access_traits<T8>::parameter_type t8
|
typename access_traits<T8>::parameter_type t8
|
||||||
= detail::default_arg<T8>::f(),
|
= detail::default_arg<T8>::f(),
|
||||||
typename tuple_access_traits<T9>::parameter_type t9
|
typename access_traits<T9>::parameter_type t9
|
||||||
= detail::default_arg<T9>::f())
|
= detail::default_arg<T9>::f())
|
||||||
|
|
||||||
: inherited(t0, t1, t2, t3, t4, t5, t6, t7, t8, t9) {}
|
: inherited(t0, t1, t2, t3, t4, t5, t6, t7, t8, t9) {}
|
||||||
@@ -444,7 +444,7 @@ public:
|
|||||||
|
|
||||||
template <class U1, class U2>
|
template <class U1, class U2>
|
||||||
tuple& operator=(const std::pair<U1, U2>& k) {
|
tuple& operator=(const std::pair<U1, U2>& k) {
|
||||||
BOOST_STATIC_ASSERT(tuple_length<tuple>::value == 2);// check_length = 2
|
BOOST_STATIC_ASSERT(length<tuple>::value == 2);// check_length = 2
|
||||||
this->head = k.first;
|
this->head = k.first;
|
||||||
this->tail.head = k.second;
|
this->tail.head = k.second;
|
||||||
return *this;
|
return *this;
|
||||||
|
@@ -219,7 +219,7 @@ namespace tuples {
|
|||||||
|
|
||||||
// Return the Nth type of the given Tuple
|
// Return the Nth type of the given Tuple
|
||||||
template<int N, typename Tuple>
|
template<int N, typename Tuple>
|
||||||
struct tuple_element
|
struct element
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef detail::_element_type<N> nth_type;
|
typedef detail::_element_type<N> nth_type;
|
||||||
@@ -233,10 +233,10 @@ namespace tuples {
|
|||||||
|
|
||||||
// Return a reference to the Nth type of the given Tuple
|
// Return a reference to the Nth type of the given Tuple
|
||||||
template<int N, typename Tuple>
|
template<int N, typename Tuple>
|
||||||
struct tuple_element_ref
|
struct element_ref
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef typename tuple_element<N, Tuple>::RET elt_type;
|
typedef typename element<N, Tuple>::RET elt_type;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef typename add_reference<elt_type>::type RET;
|
typedef typename add_reference<elt_type>::type RET;
|
||||||
@@ -245,10 +245,10 @@ namespace tuples {
|
|||||||
|
|
||||||
// Return a const reference to the Nth type of the given Tuple
|
// Return a const reference to the Nth type of the given Tuple
|
||||||
template<int N, typename Tuple>
|
template<int N, typename Tuple>
|
||||||
struct tuple_element_const_ref
|
struct element_const_ref
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef typename tuple_element<N, Tuple>::RET elt_type;
|
typedef typename element<N, Tuple>::RET elt_type;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef typename add_reference<const elt_type>::type RET;
|
typedef typename add_reference<const elt_type>::type RET;
|
||||||
@@ -259,40 +259,42 @@ namespace tuples {
|
|||||||
|
|
||||||
// Get length of this tuple
|
// Get length of this tuple
|
||||||
template<typename Tuple>
|
template<typename Tuple>
|
||||||
struct tuple_length
|
struct length
|
||||||
{
|
{
|
||||||
enum { value = 1 + tuple_length<typename Tuple::tail_type>::value };
|
BOOST_STATIC_CONSTANT(int, value = 1 + length<typename Tuple::tail_type>::value);
|
||||||
};
|
};
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct tuple_length<null_type>
|
struct length<null_type>
|
||||||
{
|
{
|
||||||
enum { value = 0 };
|
BOOST_STATIC_CONSTANT(int, value = 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
namespace detail {
|
||||||
|
|
||||||
// Reference the Nth element in a tuple and retrieve it with "get"
|
// Reference the Nth element in a tuple and retrieve it with "get"
|
||||||
template<int N>
|
template<int N>
|
||||||
struct element
|
struct get_class
|
||||||
{
|
{
|
||||||
template<typename Head, typename Tail>
|
template<typename Head, typename Tail>
|
||||||
static inline
|
static inline
|
||||||
typename detail::tuple_element_ref<N, cons<Head, Tail> >::RET
|
typename detail::element_ref<N, cons<Head, Tail> >::RET
|
||||||
get(cons<Head, Tail>& t)
|
get(cons<Head, Tail>& t)
|
||||||
{
|
{
|
||||||
return element<N-1>::get(t.tail);
|
return get_class<N-1>::get(t.tail);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename Head, typename Tail>
|
template<typename Head, typename Tail>
|
||||||
static inline
|
static inline
|
||||||
typename detail::tuple_element_const_ref<N, cons<Head, Tail> >::RET
|
typename detail::element_const_ref<N, cons<Head, Tail> >::RET
|
||||||
get(const cons<Head, Tail>& t)
|
get(const cons<Head, Tail>& t)
|
||||||
{
|
{
|
||||||
return element<N-1>::get(t.tail);
|
return get_class<N-1>::get(t.tail);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct element<0>
|
struct get_class<0>
|
||||||
{
|
{
|
||||||
template<typename Head, typename Tail>
|
template<typename Head, typename Tail>
|
||||||
static inline
|
static inline
|
||||||
@@ -311,6 +313,8 @@ namespace tuples {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
// tuple class
|
// tuple class
|
||||||
template<
|
template<
|
||||||
typename T1,
|
typename T1,
|
||||||
@@ -388,17 +392,17 @@ namespace tuples {
|
|||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
template<int N, typename Head, typename Tail>
|
template<int N, typename Head, typename Tail>
|
||||||
typename detail::tuple_element_ref<N, cons<Head, Tail> >::RET
|
typename detail::element_ref<N, cons<Head, Tail> >::RET
|
||||||
get(cons<Head, Tail>& t, detail::workaround_holder<N>* = 0)
|
get(cons<Head, Tail>& t, detail::workaround_holder<N>* = 0)
|
||||||
{
|
{
|
||||||
return element<N>::get(t);
|
return detail::get_class<N>::get(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<int N, typename Head, typename Tail>
|
template<int N, typename Head, typename Tail>
|
||||||
typename detail::tuple_element_const_ref<N, cons<Head, Tail> >::RET
|
typename detail::element_const_ref<N, cons<Head, Tail> >::RET
|
||||||
get(const cons<Head, Tail>& t, detail::workaround_holder<N>* = 0)
|
get(const cons<Head, Tail>& t, detail::workaround_holder<N>* = 0)
|
||||||
{
|
{
|
||||||
return element<N>::get(t);
|
return detail::get_class<N>::get(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make a tuple
|
// Make a tuple
|
||||||
|
@@ -115,8 +115,8 @@ inline bool gte<null_type,null_type>(const null_type&, const null_type&) { retur
|
|||||||
template<class T1, class T2, class S1, class S2>
|
template<class T1, class T2, class S1, class S2>
|
||||||
inline bool operator==(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
inline bool operator==(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
||||||
{
|
{
|
||||||
// check that tuple_lengths are equal
|
// check that tuple lengths are equal
|
||||||
BOOST_STATIC_ASSERT(tuple_length<T2>::value == tuple_length<S2>::value);
|
BOOST_STATIC_ASSERT(length<T2>::value == length<S2>::value);
|
||||||
|
|
||||||
return detail::eq(lhs, rhs);
|
return detail::eq(lhs, rhs);
|
||||||
}
|
}
|
||||||
@@ -127,8 +127,8 @@ template<class T1, class T2, class S1, class S2>
|
|||||||
inline bool operator!=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
inline bool operator!=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
||||||
{
|
{
|
||||||
|
|
||||||
// check that tuple_lengths are equal
|
// check that tuple lengths are equal
|
||||||
BOOST_STATIC_ASSERT(tuple_length<T2>::value == tuple_length<S2>::value);
|
BOOST_STATIC_ASSERT(length<T2>::value == length<S2>::value);
|
||||||
|
|
||||||
return detail::neq(lhs, rhs);
|
return detail::neq(lhs, rhs);
|
||||||
}
|
}
|
||||||
@@ -137,8 +137,8 @@ inline bool operator!=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
|||||||
template<class T1, class T2, class S1, class S2>
|
template<class T1, class T2, class S1, class S2>
|
||||||
inline bool operator<(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
inline bool operator<(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
||||||
{
|
{
|
||||||
// check that tuple_lengths are equal
|
// check that tuple lengths are equal
|
||||||
BOOST_STATIC_ASSERT(tuple_length<T2>::value == tuple_length<S2>::value);
|
BOOST_STATIC_ASSERT(length<T2>::value == length<S2>::value);
|
||||||
|
|
||||||
return detail::lt(lhs, rhs);
|
return detail::lt(lhs, rhs);
|
||||||
}
|
}
|
||||||
@@ -147,8 +147,8 @@ inline bool operator<(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
|||||||
template<class T1, class T2, class S1, class S2>
|
template<class T1, class T2, class S1, class S2>
|
||||||
inline bool operator>(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
inline bool operator>(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
||||||
{
|
{
|
||||||
// check that tuple_lengths are equal
|
// check that tuple lengths are equal
|
||||||
BOOST_STATIC_ASSERT(tuple_length<T2>::value == tuple_length<S2>::value);
|
BOOST_STATIC_ASSERT(length<T2>::value == length<S2>::value);
|
||||||
|
|
||||||
return detail::gt(lhs, rhs);
|
return detail::gt(lhs, rhs);
|
||||||
}
|
}
|
||||||
@@ -157,8 +157,8 @@ inline bool operator>(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
|||||||
template<class T1, class T2, class S1, class S2>
|
template<class T1, class T2, class S1, class S2>
|
||||||
inline bool operator<=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
inline bool operator<=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
||||||
{
|
{
|
||||||
// check that tuple_lengths are equal
|
// check that tuple lengths are equal
|
||||||
BOOST_STATIC_ASSERT(tuple_length<T2>::value == tuple_length<S2>::value);
|
BOOST_STATIC_ASSERT(length<T2>::value == length<S2>::value);
|
||||||
|
|
||||||
return detail::lte(lhs, rhs);
|
return detail::lte(lhs, rhs);
|
||||||
}
|
}
|
||||||
@@ -167,8 +167,8 @@ inline bool operator<=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
|||||||
template<class T1, class T2, class S1, class S2>
|
template<class T1, class T2, class S1, class S2>
|
||||||
inline bool operator>=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
inline bool operator>=(const cons<T1, T2>& lhs, const cons<S1, S2>& rhs)
|
||||||
{
|
{
|
||||||
// check that tuple_lengths are equal
|
// check that tuple lengths are equal
|
||||||
BOOST_STATIC_ASSERT(tuple_length<T2>::value == tuple_length<S2>::value);
|
BOOST_STATIC_ASSERT(length<T2>::value == length<S2>::value);
|
||||||
|
|
||||||
return detail::gte(lhs, rhs);
|
return detail::gte(lhs, rhs);
|
||||||
}
|
}
|
||||||
|
@@ -217,7 +217,7 @@ print(std::ostream& o, const cons<T1, T2>& t) {
|
|||||||
o << t.head;
|
o << t.head;
|
||||||
|
|
||||||
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
||||||
if (tuple_length<T2>::value == 0)
|
if (tuples::length<T2>::value == 0)
|
||||||
return o;
|
return o;
|
||||||
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
||||||
o << d;
|
o << d;
|
||||||
@@ -254,7 +254,7 @@ print(std::basic_ostream<CharType, CharTrait>& o, const cons<T1, T2>& t) {
|
|||||||
o << t.head;
|
o << t.head;
|
||||||
|
|
||||||
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
||||||
if (tuple_length<T2>::value == 0)
|
if (tuples::length<T2>::value == 0)
|
||||||
return o;
|
return o;
|
||||||
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
||||||
o << d;
|
o << d;
|
||||||
@@ -360,7 +360,7 @@ read(std::istream &is, cons<T1, T2>& t1) {
|
|||||||
is >> t1.head;
|
is >> t1.head;
|
||||||
|
|
||||||
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
||||||
if (tuple_length<T2>::value == 0)
|
if (tuples::length<T2>::value == 0)
|
||||||
return is;
|
return is;
|
||||||
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
||||||
|
|
||||||
@@ -447,7 +447,7 @@ read(std::basic_istream<CharType, CharTrait> &is, cons<T1, T2>& t1) {
|
|||||||
is >> t1.head;
|
is >> t1.head;
|
||||||
|
|
||||||
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
|
||||||
if (tuple_length<T2>::value == 0)
|
if (tuples::length<T2>::value == 0)
|
||||||
return is;
|
return is;
|
||||||
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user