Viewing file: tuple_iterate.h (4.66 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
// 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 tr1/tuple_iterate.h * This is an internal header file, included by other library headers. * You should not attempt to use it directly. */
// Chris Jefferson <chris@bubblescope.net>
namespace std { _GLIBCXX_BEGIN_NAMESPACE(tr1)
/// @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
_GLIBCXX_END_NAMESPACE }
|