c8bf5b7c54
2006-10-30 Paolo Carlini <pcarlini@suse.de> * include/tr1/tuple_iterate.h (tuple_size<tuple<> >::value): Provide definition. * include/tr1/functional (is_bind_expression<>::value, is_placeholder<>::value, + various partial specializations): Likewise. * include/tr1/array (tuple_size<array<> >::value): Likewise. From-SVN: r118203
167 lines
4.6 KiB
C++
167 lines
4.6 KiB
C++
// class template tuple -*- C++ -*-
|
|
|
|
// Copyright (C) 2004, 2005, 2006 Free Software Foundation, Inc.
|
|
//
|
|
// This file is part of the GNU ISO C++ Library. This library is free
|
|
// software; you can redistribute it and/or modify it under the
|
|
// terms of the GNU General Public License as published by the
|
|
// Free Software Foundation; either version 2, or (at your option)
|
|
// any later version.
|
|
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
// with this library; see the file COPYING. If not, write to the Free
|
|
// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
// USA.
|
|
|
|
// As a special exception, you may use this file as part of a free software
|
|
// library without restriction. Specifically, if other files instantiate
|
|
// templates or use macros or inline functions from this file, or you compile
|
|
// this file and link it with other files to produce an executable, this
|
|
// file does not by itself cause the resulting executable to be covered by
|
|
// the GNU General Public License. This exception does not however
|
|
// invalidate any other reasons why the executable file might be covered by
|
|
// the GNU General Public License.
|
|
|
|
/** @file
|
|
* This is an internal header file, included by other library headers.
|
|
* You should not attempt to use it directly.
|
|
*/
|
|
|
|
// Chris Jefferson <chris@bubblescope.net>
|
|
|
|
/// @brief class tuple_size
|
|
template<_GLIBCXX_TEMPLATE_PARAMS>
|
|
struct tuple_size<tuple<_GLIBCXX_TEMPLATE_ARGS> >
|
|
{ static const int value = _GLIBCXX_NUM_ARGS; };
|
|
|
|
#if _GLIBCXX_NUM_ARGS > 0
|
|
template<_GLIBCXX_TEMPLATE_PARAMS>
|
|
const int tuple_size<tuple<_GLIBCXX_TEMPLATE_ARGS> >::value;
|
|
#endif
|
|
|
|
template<_GLIBCXX_TEMPLATE_PARAMS>
|
|
#ifdef _GLIBCXX_LAST_INCLUDE
|
|
class tuple
|
|
#else
|
|
class tuple<_GLIBCXX_TEMPLATE_ARGS>
|
|
#endif
|
|
{
|
|
_GLIBCXX_BIND_MEMBERS
|
|
|
|
public:
|
|
tuple()
|
|
{ }
|
|
|
|
#if _GLIBCXX_NUM_ARGS == 2
|
|
template<typename _U1, typename _U2>
|
|
tuple(const std::pair<_U1, _U2>& __u) :
|
|
_M_arg1(__u.first), _M_arg2(__u.second)
|
|
{ }
|
|
|
|
template<typename _U1, typename _U2>
|
|
tuple&
|
|
operator=(const std::pair<_U1, _U2>& __u)
|
|
{
|
|
_M_arg1 = __u.first;
|
|
_M_arg2 = __u.second;
|
|
return *this;
|
|
}
|
|
#endif
|
|
|
|
#if _GLIBCXX_NUM_ARGS > 0
|
|
explicit tuple(_GLIBCXX_TUPLE_ADD_CREF) :
|
|
_GLIBCXX_BIND_MEMBERS_INIT
|
|
{ }
|
|
|
|
template<_GLIBCXX_TEMPLATE_PARAMS_U>
|
|
tuple(const tuple<_GLIBCXX_TEMPLATE_ARGS_U>& __in) :
|
|
_GLIBCXX_TUPLE_COPY_INIT
|
|
{ }
|
|
|
|
|
|
template<_GLIBCXX_TEMPLATE_PARAMS_U>
|
|
tuple&
|
|
operator=(const tuple<_GLIBCXX_TEMPLATE_ARGS_U>& __in)
|
|
{
|
|
_GLIBCXX_TUPLE_ASSIGN
|
|
return *this;
|
|
}
|
|
|
|
tuple(const tuple& __in) :
|
|
_GLIBCXX_TUPLE_COPY_INIT
|
|
{ }
|
|
|
|
#else
|
|
|
|
tuple(const tuple&)
|
|
{ }
|
|
|
|
#endif
|
|
|
|
tuple&
|
|
operator=(const tuple& __in __attribute__((__unused__)) )
|
|
{
|
|
_GLIBCXX_TUPLE_ASSIGN
|
|
return *this;
|
|
}
|
|
|
|
template<int __i, typename __Type>
|
|
friend class __get_helper;
|
|
|
|
template<_GLIBCXX_TUPLE_ALL_TEMPLATE_PARAMS_UNNAMED>
|
|
friend class tuple;
|
|
};
|
|
|
|
#ifndef _GLIBCXX_LAST_INCLUDE
|
|
|
|
template<typename _Tp>
|
|
struct __get_helper<_GLIBCXX_NUM_ARGS, _Tp>
|
|
{
|
|
static typename __add_ref<typename tuple_element<_GLIBCXX_NUM_ARGS,
|
|
_Tp>::type>::type
|
|
get_value(_Tp& __in)
|
|
{ return __in._GLIBCXX_CAT(_M_arg,_GLIBCXX_NUM_ARGS_PLUS_1); }
|
|
|
|
static typename __add_c_ref<typename tuple_element<_GLIBCXX_NUM_ARGS,
|
|
_Tp>::type>::type
|
|
get_value(const _Tp& __in)
|
|
{ return __in._GLIBCXX_CAT(_M_arg,_GLIBCXX_NUM_ARGS_PLUS_1); }
|
|
};
|
|
|
|
/// @brief class tuple_element
|
|
template<_GLIBCXX_TUPLE_ALL_TEMPLATE_PARAMS>
|
|
struct tuple_element<_GLIBCXX_NUM_ARGS, tuple<_GLIBCXX_TUPLE_ALL_TEMPLATE_ARGS> >
|
|
{ typedef _GLIBCXX_T_NUM_ARGS_PLUS_1 type; };
|
|
|
|
#endif
|
|
#if _GLIBCXX_NUM_ARGS == 0
|
|
|
|
tuple<>
|
|
inline make_tuple()
|
|
{ return tuple<>(); }
|
|
|
|
tuple<>
|
|
inline tie()
|
|
{ return tuple<>(); }
|
|
#else
|
|
|
|
template<_GLIBCXX_TEMPLATE_PARAMS>
|
|
typename __stripped_tuple_type<_GLIBCXX_TEMPLATE_ARGS>::__type
|
|
inline make_tuple(_GLIBCXX_PARAMS)
|
|
{
|
|
return typename __stripped_tuple_type<_GLIBCXX_TEMPLATE_ARGS>::
|
|
__type(_GLIBCXX_ARGS);
|
|
}
|
|
|
|
template<_GLIBCXX_TEMPLATE_PARAMS>
|
|
tuple<_GLIBCXX_REF_TEMPLATE_ARGS>
|
|
inline tie(_GLIBCXX_REF_PARAMS)
|
|
{ return make_tuple(_GLIBCXX_REF_WRAP_PARAMS); }
|
|
#endif
|
|
|