diff options
Diffstat (limited to 'rep/usr/include/c++/4.3/bits')
32 files changed, 0 insertions, 32050 deletions
diff --git a/rep/usr/include/c++/4.3/bits/allocator.h.gcov.html b/rep/usr/include/c++/4.3/bits/allocator.h.gcov.html deleted file mode 100644 index 6f76dc6..0000000 --- a/rep/usr/include/c++/4.3/bits/allocator.h.gcov.html +++ /dev/null @@ -1,245 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/allocator.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - allocator.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">7</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">71.4 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">5</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Allocators -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * Copyright (c) 1996-1997 -<span class="lineNum"> 33 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 34 </span> : * -<span class="lineNum"> 35 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 36 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 37 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 38 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 39 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 40 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 41 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 42 </span> : */ -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : /** @file allocator.h -<span class="lineNum"> 45 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 46 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 47 </span> : */ -<span class="lineNum"> 48 </span> : -<span class="lineNum"> 49 </span> : #ifndef _ALLOCATOR_H -<span class="lineNum"> 50 </span> : #define _ALLOCATOR_H 1 -<span class="lineNum"> 51 </span> : -<span class="lineNum"> 52 </span> : // Define the base class to std::allocator. -<span class="lineNum"> 53 </span> : #include <bits/c++allocator.h> -<span class="lineNum"> 54 </span> : -<span class="lineNum"> 55 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : template<typename _Tp> -<span class="lineNum"> 58 </span> : class allocator; -<span class="lineNum"> 59 </span> : -<span class="lineNum"> 60 </span> : /// allocator<void> specialization. -<span class="lineNum"> 61 </span> : template<> -<span class="lineNum"> 62 </span> : class allocator<void> -<span class="lineNum"> 63 </span> : { -<span class="lineNum"> 64 </span> : public: -<span class="lineNum"> 65 </span> : typedef size_t size_type; -<span class="lineNum"> 66 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 67 </span> : typedef void* pointer; -<span class="lineNum"> 68 </span> : typedef const void* const_pointer; -<span class="lineNum"> 69 </span> : typedef void value_type; -<span class="lineNum"> 70 </span> : -<span class="lineNum"> 71 </span> : template<typename _Tp1> -<span class="lineNum"> 72 </span> : struct rebind -<span class="lineNum"> 73 </span> : { typedef allocator<_Tp1> other; }; -<span class="lineNum"> 74 </span> : }; -<span class="lineNum"> 75 </span> : -<span class="lineNum"> 76 </span> : /** -<span class="lineNum"> 77 </span> : * @brief The "standard" allocator, as per [20.4]. -<span class="lineNum"> 78 </span> : * -<span class="lineNum"> 79 </span> : * Further details: -<span class="lineNum"> 80 </span> : * http://gcc.gnu.org/onlinedocs/libstdc++/manual/bk01pt04ch11.html -<span class="lineNum"> 81 </span> : */ -<span class="lineNum"> 82 </span> : template<typename _Tp> -<span class="lineNum"> 83 </span> : class allocator: public __glibcxx_base_allocator<_Tp> -<span class="lineNum"> 84 </span> : { -<span class="lineNum"> 85 </span> : public: -<span class="lineNum"> 86 </span> : typedef size_t size_type; -<span class="lineNum"> 87 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 88 </span> : typedef _Tp* pointer; -<span class="lineNum"> 89 </span> : typedef const _Tp* const_pointer; -<span class="lineNum"> 90 </span> : typedef _Tp& reference; -<span class="lineNum"> 91 </span> : typedef const _Tp& const_reference; -<span class="lineNum"> 92 </span> : typedef _Tp value_type; -<span class="lineNum"> 93 </span> : -<span class="lineNum"> 94 </span> : template<typename _Tp1> -<span class="lineNum"> 95 </span> : struct rebind -<span class="lineNum"> 96 </span> : { typedef allocator<_Tp1> other; }; -<span class="lineNum"> 97 </span> : -<span class="lineNum"> 98 </span><span class="lineCov"> 285441 : allocator() throw() { }</span> -<span class="lineNum"> 99 </span> : -<span class="lineNum"> 100 </span><span class="lineCov"> 934618 : allocator(const allocator& __a) throw()</span> -<span class="lineNum"> 101 </span><span class="lineCov"> 934618 : : __glibcxx_base_allocator<_Tp>(__a) { }</span> -<span class="lineNum"> 102 </span> : -<span class="lineNum"> 103 </span> : template<typename _Tp1> -<span class="lineNum"> 104 </span><span class="lineCov"> 11289504 : allocator(const allocator<_Tp1>&) throw() { }</span> -<span class="lineNum"> 105 </span> : -<span class="lineNum"> 106 </span><span class="lineCov"> 12615289 : ~allocator() throw() { }</span> -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : // Inherit everything else. -<span class="lineNum"> 109 </span> : }; -<span class="lineNum"> 110 </span> : -<span class="lineNum"> 111 </span> : template<typename _T1, typename _T2> -<span class="lineNum"> 112 </span> : inline bool -<span class="lineNum"> 113 </span> : operator==(const allocator<_T1>&, const allocator<_T2>&) -<span class="lineNum"> 114 </span> : { return true; } -<span class="lineNum"> 115 </span> : -<span class="lineNum"> 116 </span> : template<typename _Tp> -<span class="lineNum"> 117 </span> : inline bool -<span class="lineNum"> 118 </span><span class="lineNoCov"> 0 : operator==(const allocator<_Tp>&, const allocator<_Tp>&)</span> -<span class="lineNum"> 119 </span><span class="lineNoCov"> 0 : { return true; }</span> -<span class="lineNum"> 120 </span> : -<span class="lineNum"> 121 </span> : template<typename _T1, typename _T2> -<span class="lineNum"> 122 </span> : inline bool -<span class="lineNum"> 123 </span> : operator!=(const allocator<_T1>&, const allocator<_T2>&) -<span class="lineNum"> 124 </span> : { return false; } -<span class="lineNum"> 125 </span> : -<span class="lineNum"> 126 </span> : template<typename _Tp> -<span class="lineNum"> 127 </span> : inline bool -<span class="lineNum"> 128 </span> : operator!=(const allocator<_Tp>&, const allocator<_Tp>&) -<span class="lineNum"> 129 </span> : { return false; } -<span class="lineNum"> 130 </span> : -<span class="lineNum"> 131 </span> : // Inhibit implicit instantiations for required instantiations, -<span class="lineNum"> 132 </span> : // which are defined via explicit instantiations elsewhere. -<span class="lineNum"> 133 </span> : // NB: This syntax is a GNU extension. -<span class="lineNum"> 134 </span> : #if _GLIBCXX_EXTERN_TEMPLATE -<span class="lineNum"> 135 </span> : extern template class allocator<char>; -<span class="lineNum"> 136 </span> : extern template class allocator<wchar_t>; -<span class="lineNum"> 137 </span> : #endif -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : // Undefine. -<span class="lineNum"> 140 </span> : #undef __glibcxx_base_allocator -<span class="lineNum"> 141 </span> : -<span class="lineNum"> 142 </span> : // To implement Option 3 of DR 431. -<span class="lineNum"> 143 </span> : template<typename _Alloc, bool = __is_empty(_Alloc)> -<span class="lineNum"> 144 </span> : struct __alloc_swap -<span class="lineNum"> 145 </span> : { static void _S_do_it(_Alloc&, _Alloc&) { } }; -<span class="lineNum"> 146 </span> : -<span class="lineNum"> 147 </span> : template<typename _Alloc> -<span class="lineNum"> 148 </span> : struct __alloc_swap<_Alloc, false> -<span class="lineNum"> 149 </span> : { -<span class="lineNum"> 150 </span> : static void -<span class="lineNum"> 151 </span> : _S_do_it(_Alloc& __one, _Alloc& __two) -<span class="lineNum"> 152 </span> : { -<span class="lineNum"> 153 </span> : // Precondition: swappable allocators. -<span class="lineNum"> 154 </span> : if (__one != __two) -<span class="lineNum"> 155 </span> : swap(__one, __two); -<span class="lineNum"> 156 </span> : } -<span class="lineNum"> 157 </span> : }; -<span class="lineNum"> 158 </span> : -<span class="lineNum"> 159 </span> : // Optimize for stateless allocators. -<span class="lineNum"> 160 </span> : template<typename _Alloc, bool = __is_empty(_Alloc)> -<span class="lineNum"> 161 </span> : struct __alloc_neq -<span class="lineNum"> 162 </span> : { -<span class="lineNum"> 163 </span> : static bool -<span class="lineNum"> 164 </span> : _S_do_it(const _Alloc&, const _Alloc&) -<span class="lineNum"> 165 </span> : { return false; } -<span class="lineNum"> 166 </span> : }; -<span class="lineNum"> 167 </span> : -<span class="lineNum"> 168 </span> : template<typename _Alloc> -<span class="lineNum"> 169 </span> : struct __alloc_neq<_Alloc, false> -<span class="lineNum"> 170 </span> : { -<span class="lineNum"> 171 </span> : static bool -<span class="lineNum"> 172 </span> : _S_do_it(const _Alloc& __one, const _Alloc& __two) -<span class="lineNum"> 173 </span> : { return __one != __two; } -<span class="lineNum"> 174 </span> : }; -<span class="lineNum"> 175 </span> : -<span class="lineNum"> 176 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 177 </span> : -<span class="lineNum"> 178 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/basic_ios.h.gcov.html b/rep/usr/include/c++/4.3/bits/basic_ios.h.gcov.html deleted file mode 100644 index a436d4e..0000000 --- a/rep/usr/include/c++/4.3/bits/basic_ios.h.gcov.html +++ /dev/null @@ -1,545 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/basic_ios.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - basic_ios.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">35</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">0.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">0</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Iostreams base classes -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007, 2008 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file basic_ios.h -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : #ifndef _BASIC_IOS_H -<span class="lineNum"> 38 </span> : #define _BASIC_IOS_H 1 -<span class="lineNum"> 39 </span> : -<span class="lineNum"> 40 </span> : #pragma GCC system_header -<span class="lineNum"> 41 </span> : -<span class="lineNum"> 42 </span> : #include <bits/localefwd.h> -<span class="lineNum"> 43 </span> : #include <bits/locale_classes.h> -<span class="lineNum"> 44 </span> : #include <bits/locale_facets.h> -<span class="lineNum"> 45 </span> : #include <bits/streambuf_iterator.h> -<span class="lineNum"> 46 </span> : -<span class="lineNum"> 47 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 48 </span> : -<span class="lineNum"> 49 </span> : template<typename _Facet> -<span class="lineNum"> 50 </span> : inline const _Facet& -<span class="lineNum"> 51 </span><span class="lineNoCov"> 0 : __check_facet(const _Facet* __f)</span> -<span class="lineNum"> 52 </span> : { -<span class="lineNum"> 53 </span><span class="lineNoCov"> 0 : if (!__f)</span> -<span class="lineNum"> 54 </span><span class="lineNoCov"> 0 : __throw_bad_cast();</span> -<span class="lineNum"> 55 </span><span class="lineNoCov"> 0 : return *__f;</span> -<span class="lineNum"> 56 </span> : } -<span class="lineNum"> 57 </span> : -<span class="lineNum"> 58 </span> : // 27.4.5 Template class basic_ios -<span class="lineNum"> 59 </span> : /** -<span class="lineNum"> 60 </span> : * @brief Virtual base class for all stream classes. -<span class="lineNum"> 61 </span> : * -<span class="lineNum"> 62 </span> : * Most of the member functions called dispatched on stream objects -<span class="lineNum"> 63 </span> : * (e.g., @c std::cout.foo(bar);) are consolidated in this class. -<span class="lineNum"> 64 </span> : */ -<span class="lineNum"> 65 </span> : template<typename _CharT, typename _Traits> -<span class="lineNum"> 66 </span> : class basic_ios : public ios_base -<span class="lineNum"> 67 </span> : { -<span class="lineNum"> 68 </span> : public: -<span class="lineNum"> 69 </span> : //@{ -<span class="lineNum"> 70 </span> : /** -<span class="lineNum"> 71 </span> : * These are standard types. They permit a standardized way of -<span class="lineNum"> 72 </span> : * referring to names of (or names dependant on) the template -<span class="lineNum"> 73 </span> : * parameters, which are specific to the implementation. -<span class="lineNum"> 74 </span> : */ -<span class="lineNum"> 75 </span> : typedef _CharT char_type; -<span class="lineNum"> 76 </span> : typedef typename _Traits::int_type int_type; -<span class="lineNum"> 77 </span> : typedef typename _Traits::pos_type pos_type; -<span class="lineNum"> 78 </span> : typedef typename _Traits::off_type off_type; -<span class="lineNum"> 79 </span> : typedef _Traits traits_type; -<span class="lineNum"> 80 </span> : //@} -<span class="lineNum"> 81 </span> : -<span class="lineNum"> 82 </span> : //@{ -<span class="lineNum"> 83 </span> : /** -<span class="lineNum"> 84 </span> : * These are non-standard types. -<span class="lineNum"> 85 </span> : */ -<span class="lineNum"> 86 </span> : typedef ctype<_CharT> __ctype_type; -<span class="lineNum"> 87 </span> : typedef num_put<_CharT, ostreambuf_iterator<_CharT, _Traits> > -<span class="lineNum"> 88 </span> : __num_put_type; -<span class="lineNum"> 89 </span> : typedef num_get<_CharT, istreambuf_iterator<_CharT, _Traits> > -<span class="lineNum"> 90 </span> : __num_get_type; -<span class="lineNum"> 91 </span> : //@} -<span class="lineNum"> 92 </span> : -<span class="lineNum"> 93 </span> : // Data members: -<span class="lineNum"> 94 </span> : protected: -<span class="lineNum"> 95 </span> : basic_ostream<_CharT, _Traits>* _M_tie; -<span class="lineNum"> 96 </span> : mutable char_type _M_fill; -<span class="lineNum"> 97 </span> : mutable bool _M_fill_init; -<span class="lineNum"> 98 </span> : basic_streambuf<_CharT, _Traits>* _M_streambuf; -<span class="lineNum"> 99 </span> : -<span class="lineNum"> 100 </span> : // Cached use_facet<ctype>, which is based on the current locale info. -<span class="lineNum"> 101 </span> : const __ctype_type* _M_ctype; -<span class="lineNum"> 102 </span> : // For ostream. -<span class="lineNum"> 103 </span> : const __num_put_type* _M_num_put; -<span class="lineNum"> 104 </span> : // For istream. -<span class="lineNum"> 105 </span> : const __num_get_type* _M_num_get; -<span class="lineNum"> 106 </span> : -<span class="lineNum"> 107 </span> : public: -<span class="lineNum"> 108 </span> : //@{ -<span class="lineNum"> 109 </span> : /** -<span class="lineNum"> 110 </span> : * @brief The quick-and-easy status check. -<span class="lineNum"> 111 </span> : * -<span class="lineNum"> 112 </span> : * This allows you to write constructs such as -<span class="lineNum"> 113 </span> : * "if (!a_stream) ..." and "while (a_stream) ..." -<span class="lineNum"> 114 </span> : */ -<span class="lineNum"> 115 </span><span class="lineNoCov"> 0 : operator void*() const</span> -<span class="lineNum"> 116 </span><span class="lineNoCov"> 0 : { return this->fail() ? 0 : const_cast<basic_ios*>(this); }</span> -<span class="lineNum"> 117 </span> : -<span class="lineNum"> 118 </span> : bool -<span class="lineNum"> 119 </span><span class="lineNoCov"> 0 : operator!() const</span> -<span class="lineNum"> 120 </span><span class="lineNoCov"> 0 : { return this->fail(); }</span> -<span class="lineNum"> 121 </span> : //@} -<span class="lineNum"> 122 </span> : -<span class="lineNum"> 123 </span> : /** -<span class="lineNum"> 124 </span> : * @brief Returns the error state of the stream buffer. -<span class="lineNum"> 125 </span> : * @return A bit pattern (well, isn't everything?) -<span class="lineNum"> 126 </span> : * -<span class="lineNum"> 127 </span> : * See std::ios_base::iostate for the possible bit values. Most -<span class="lineNum"> 128 </span> : * users will call one of the interpreting wrappers, e.g., good(). -<span class="lineNum"> 129 </span> : */ -<span class="lineNum"> 130 </span> : iostate -<span class="lineNum"> 131 </span><span class="lineNoCov"> 0 : rdstate() const</span> -<span class="lineNum"> 132 </span><span class="lineNoCov"> 0 : { return _M_streambuf_state; }</span> -<span class="lineNum"> 133 </span> : -<span class="lineNum"> 134 </span> : /** -<span class="lineNum"> 135 </span> : * @brief [Re]sets the error state. -<span class="lineNum"> 136 </span> : * @param state The new state flag(s) to set. -<span class="lineNum"> 137 </span> : * -<span class="lineNum"> 138 </span> : * See std::ios_base::iostate for the possible bit values. Most -<span class="lineNum"> 139 </span> : * users will not need to pass an argument. -<span class="lineNum"> 140 </span> : */ -<span class="lineNum"> 141 </span> : void -<span class="lineNum"> 142 </span> : clear(iostate __state = goodbit); -<span class="lineNum"> 143 </span> : -<span class="lineNum"> 144 </span> : /** -<span class="lineNum"> 145 </span> : * @brief Sets additional flags in the error state. -<span class="lineNum"> 146 </span> : * @param state The additional state flag(s) to set. -<span class="lineNum"> 147 </span> : * -<span class="lineNum"> 148 </span> : * See std::ios_base::iostate for the possible bit values. -<span class="lineNum"> 149 </span> : */ -<span class="lineNum"> 150 </span> : void -<span class="lineNum"> 151 </span><span class="lineNoCov"> 0 : setstate(iostate __state)</span> -<span class="lineNum"> 152 </span><span class="lineNoCov"> 0 : { this->clear(this->rdstate() | __state); }</span> -<span class="lineNum"> 153 </span> : -<span class="lineNum"> 154 </span> : // Flip the internal state on for the proper state bits, then re -<span class="lineNum"> 155 </span> : // throws the propagated exception if bit also set in -<span class="lineNum"> 156 </span> : // exceptions(). -<span class="lineNum"> 157 </span> : void -<span class="lineNum"> 158 </span> : _M_setstate(iostate __state) -<span class="lineNum"> 159 </span> : { -<span class="lineNum"> 160 </span> : // 27.6.1.2.1 Common requirements. -<span class="lineNum"> 161 </span> : // Turn this on without causing an ios::failure to be thrown. -<span class="lineNum"> 162 </span> : _M_streambuf_state |= __state; -<span class="lineNum"> 163 </span> : if (this->exceptions() & __state) -<span class="lineNum"> 164 </span> : __throw_exception_again; -<span class="lineNum"> 165 </span> : } -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : /** -<span class="lineNum"> 168 </span> : * @brief Fast error checking. -<span class="lineNum"> 169 </span> : * @return True if no error flags are set. -<span class="lineNum"> 170 </span> : * -<span class="lineNum"> 171 </span> : * A wrapper around rdstate. -<span class="lineNum"> 172 </span> : */ -<span class="lineNum"> 173 </span> : bool -<span class="lineNum"> 174 </span><span class="lineNoCov"> 0 : good() const</span> -<span class="lineNum"> 175 </span><span class="lineNoCov"> 0 : { return this->rdstate() == 0; }</span> -<span class="lineNum"> 176 </span> : -<span class="lineNum"> 177 </span> : /** -<span class="lineNum"> 178 </span> : * @brief Fast error checking. -<span class="lineNum"> 179 </span> : * @return True if the eofbit is set. -<span class="lineNum"> 180 </span> : * -<span class="lineNum"> 181 </span> : * Note that other iostate flags may also be set. -<span class="lineNum"> 182 </span> : */ -<span class="lineNum"> 183 </span> : bool -<span class="lineNum"> 184 </span><span class="lineNoCov"> 0 : eof() const</span> -<span class="lineNum"> 185 </span><span class="lineNoCov"> 0 : { return (this->rdstate() & eofbit) != 0; }</span> -<span class="lineNum"> 186 </span> : -<span class="lineNum"> 187 </span> : /** -<span class="lineNum"> 188 </span> : * @brief Fast error checking. -<span class="lineNum"> 189 </span> : * @return True if either the badbit or the failbit is set. -<span class="lineNum"> 190 </span> : * -<span class="lineNum"> 191 </span> : * Checking the badbit in fail() is historical practice. -<span class="lineNum"> 192 </span> : * Note that other iostate flags may also be set. -<span class="lineNum"> 193 </span> : */ -<span class="lineNum"> 194 </span> : bool -<span class="lineNum"> 195 </span><span class="lineNoCov"> 0 : fail() const</span> -<span class="lineNum"> 196 </span><span class="lineNoCov"> 0 : { return (this->rdstate() & (badbit | failbit)) != 0; }</span> -<span class="lineNum"> 197 </span> : -<span class="lineNum"> 198 </span> : /** -<span class="lineNum"> 199 </span> : * @brief Fast error checking. -<span class="lineNum"> 200 </span> : * @return True if the badbit is set. -<span class="lineNum"> 201 </span> : * -<span class="lineNum"> 202 </span> : * Note that other iostate flags may also be set. -<span class="lineNum"> 203 </span> : */ -<span class="lineNum"> 204 </span> : bool -<span class="lineNum"> 205 </span> : bad() const -<span class="lineNum"> 206 </span> : { return (this->rdstate() & badbit) != 0; } -<span class="lineNum"> 207 </span> : -<span class="lineNum"> 208 </span> : /** -<span class="lineNum"> 209 </span> : * @brief Throwing exceptions on errors. -<span class="lineNum"> 210 </span> : * @return The current exceptions mask. -<span class="lineNum"> 211 </span> : * -<span class="lineNum"> 212 </span> : * This changes nothing in the stream. See the one-argument version -<span class="lineNum"> 213 </span> : * of exceptions(iostate) for the meaning of the return value. -<span class="lineNum"> 214 </span> : */ -<span class="lineNum"> 215 </span> : iostate -<span class="lineNum"> 216 </span> : exceptions() const -<span class="lineNum"> 217 </span> : { return _M_exception; } -<span class="lineNum"> 218 </span> : -<span class="lineNum"> 219 </span> : /** -<span class="lineNum"> 220 </span> : * @brief Throwing exceptions on errors. -<span class="lineNum"> 221 </span> : * @param except The new exceptions mask. -<span class="lineNum"> 222 </span> : * -<span class="lineNum"> 223 </span> : * By default, error flags are set silently. You can set an -<span class="lineNum"> 224 </span> : * exceptions mask for each stream; if a bit in the mask becomes set -<span class="lineNum"> 225 </span> : * in the error flags, then an exception of type -<span class="lineNum"> 226 </span> : * std::ios_base::failure is thrown. -<span class="lineNum"> 227 </span> : * -<span class="lineNum"> 228 </span> : * If the error flag is already set when the exceptions mask is -<span class="lineNum"> 229 </span> : * added, the exception is immediately thrown. Try running the -<span class="lineNum"> 230 </span> : * following under GCC 3.1 or later: -<span class="lineNum"> 231 </span> : * @code -<span class="lineNum"> 232 </span> : * #include <iostream> -<span class="lineNum"> 233 </span> : * #include <fstream> -<span class="lineNum"> 234 </span> : * #include <exception> -<span class="lineNum"> 235 </span> : * -<span class="lineNum"> 236 </span> : * int main() -<span class="lineNum"> 237 </span> : * { -<span class="lineNum"> 238 </span> : * std::set_terminate (__gnu_cxx::__verbose_terminate_handler); -<span class="lineNum"> 239 </span> : * -<span class="lineNum"> 240 </span> : * std::ifstream f ("/etc/motd"); -<span class="lineNum"> 241 </span> : * -<span class="lineNum"> 242 </span> : * std::cerr << "Setting badbit\n"; -<span class="lineNum"> 243 </span> : * f.setstate (std::ios_base::badbit); -<span class="lineNum"> 244 </span> : * -<span class="lineNum"> 245 </span> : * std::cerr << "Setting exception mask\n"; -<span class="lineNum"> 246 </span> : * f.exceptions (std::ios_base::badbit); -<span class="lineNum"> 247 </span> : * } -<span class="lineNum"> 248 </span> : * @endcode -<span class="lineNum"> 249 </span> : */ -<span class="lineNum"> 250 </span> : void -<span class="lineNum"> 251 </span> : exceptions(iostate __except) -<span class="lineNum"> 252 </span> : { -<span class="lineNum"> 253 </span> : _M_exception = __except; -<span class="lineNum"> 254 </span> : this->clear(_M_streambuf_state); -<span class="lineNum"> 255 </span> : } -<span class="lineNum"> 256 </span> : -<span class="lineNum"> 257 </span> : // Constructor/destructor: -<span class="lineNum"> 258 </span> : /** -<span class="lineNum"> 259 </span> : * @brief Constructor performs initialization. -<span class="lineNum"> 260 </span> : * -<span class="lineNum"> 261 </span> : * The parameter is passed by derived streams. -<span class="lineNum"> 262 </span> : */ -<span class="lineNum"> 263 </span> : explicit -<span class="lineNum"> 264 </span> : basic_ios(basic_streambuf<_CharT, _Traits>* __sb) -<span class="lineNum"> 265 </span> : : ios_base(), _M_tie(0), _M_fill(), _M_fill_init(false), _M_streambuf(0), -<span class="lineNum"> 266 </span> : _M_ctype(0), _M_num_put(0), _M_num_get(0) -<span class="lineNum"> 267 </span> : { this->init(__sb); } -<span class="lineNum"> 268 </span> : -<span class="lineNum"> 269 </span> : /** -<span class="lineNum"> 270 </span> : * @brief Empty. -<span class="lineNum"> 271 </span> : * -<span class="lineNum"> 272 </span> : * The destructor does nothing. More specifically, it does not -<span class="lineNum"> 273 </span> : * destroy the streambuf held by rdbuf(). -<span class="lineNum"> 274 </span> : */ -<span class="lineNum"> 275 </span> : virtual -<span class="lineNum"> 276 </span><span class="lineNoCov"> 0 : ~basic_ios() { }</span> -<span class="lineNum"> 277 </span> : -<span class="lineNum"> 278 </span> : // Members: -<span class="lineNum"> 279 </span> : /** -<span class="lineNum"> 280 </span> : * @brief Fetches the current @e tied stream. -<span class="lineNum"> 281 </span> : * @return A pointer to the tied stream, or NULL if the stream is -<span class="lineNum"> 282 </span> : * not tied. -<span class="lineNum"> 283 </span> : * -<span class="lineNum"> 284 </span> : * A stream may be @e tied (or synchronized) to a second output -<span class="lineNum"> 285 </span> : * stream. When this stream performs any I/O, the tied stream is -<span class="lineNum"> 286 </span> : * first flushed. For example, @c std::cin is tied to @c std::cout. -<span class="lineNum"> 287 </span> : */ -<span class="lineNum"> 288 </span> : basic_ostream<_CharT, _Traits>* -<span class="lineNum"> 289 </span> : tie() const -<span class="lineNum"> 290 </span> : { return _M_tie; } -<span class="lineNum"> 291 </span> : -<span class="lineNum"> 292 </span> : /** -<span class="lineNum"> 293 </span> : * @brief Ties this stream to an output stream. -<span class="lineNum"> 294 </span> : * @param tiestr The output stream. -<span class="lineNum"> 295 </span> : * @return The previously tied output stream, or NULL if the stream -<span class="lineNum"> 296 </span> : * was not tied. -<span class="lineNum"> 297 </span> : * -<span class="lineNum"> 298 </span> : * This sets up a new tie; see tie() for more. -<span class="lineNum"> 299 </span> : */ -<span class="lineNum"> 300 </span> : basic_ostream<_CharT, _Traits>* -<span class="lineNum"> 301 </span> : tie(basic_ostream<_CharT, _Traits>* __tiestr) -<span class="lineNum"> 302 </span> : { -<span class="lineNum"> 303 </span> : basic_ostream<_CharT, _Traits>* __old = _M_tie; -<span class="lineNum"> 304 </span> : _M_tie = __tiestr; -<span class="lineNum"> 305 </span> : return __old; -<span class="lineNum"> 306 </span> : } -<span class="lineNum"> 307 </span> : -<span class="lineNum"> 308 </span> : /** -<span class="lineNum"> 309 </span> : * @brief Accessing the underlying buffer. -<span class="lineNum"> 310 </span> : * @return The current stream buffer. -<span class="lineNum"> 311 </span> : * -<span class="lineNum"> 312 </span> : * This does not change the state of the stream. -<span class="lineNum"> 313 </span> : */ -<span class="lineNum"> 314 </span> : basic_streambuf<_CharT, _Traits>* -<span class="lineNum"> 315 </span><span class="lineNoCov"> 0 : rdbuf() const</span> -<span class="lineNum"> 316 </span><span class="lineNoCov"> 0 : { return _M_streambuf; }</span> -<span class="lineNum"> 317 </span> : -<span class="lineNum"> 318 </span> : /** -<span class="lineNum"> 319 </span> : * @brief Changing the underlying buffer. -<span class="lineNum"> 320 </span> : * @param sb The new stream buffer. -<span class="lineNum"> 321 </span> : * @return The previous stream buffer. -<span class="lineNum"> 322 </span> : * -<span class="lineNum"> 323 </span> : * Associates a new buffer with the current stream, and clears the -<span class="lineNum"> 324 </span> : * error state. -<span class="lineNum"> 325 </span> : * -<span class="lineNum"> 326 </span> : * Due to historical accidents which the LWG refuses to correct, the -<span class="lineNum"> 327 </span> : * I/O library suffers from a design error: this function is hidden -<span class="lineNum"> 328 </span> : * in derived classes by overrides of the zero-argument @c rdbuf(), -<span class="lineNum"> 329 </span> : * which is non-virtual for hysterical raisins. As a result, you -<span class="lineNum"> 330 </span> : * must use explicit qualifications to access this function via any -<span class="lineNum"> 331 </span> : * derived class. For example: -<span class="lineNum"> 332 </span> : * -<span class="lineNum"> 333 </span> : * @code -<span class="lineNum"> 334 </span> : * std::fstream foo; // or some other derived type -<span class="lineNum"> 335 </span> : * std::streambuf* p = .....; -<span class="lineNum"> 336 </span> : * -<span class="lineNum"> 337 </span> : * foo.ios::rdbuf(p); // ios == basic_ios<char> -<span class="lineNum"> 338 </span> : * @endcode -<span class="lineNum"> 339 </span> : */ -<span class="lineNum"> 340 </span> : basic_streambuf<_CharT, _Traits>* -<span class="lineNum"> 341 </span> : rdbuf(basic_streambuf<_CharT, _Traits>* __sb); -<span class="lineNum"> 342 </span> : -<span class="lineNum"> 343 </span> : /** -<span class="lineNum"> 344 </span> : * @brief Copies fields of __rhs into this. -<span class="lineNum"> 345 </span> : * @param __rhs The source values for the copies. -<span class="lineNum"> 346 </span> : * @return Reference to this object. -<span class="lineNum"> 347 </span> : * -<span class="lineNum"> 348 </span> : * All fields of __rhs are copied into this object except that rdbuf() -<span class="lineNum"> 349 </span> : * and rdstate() remain unchanged. All values in the pword and iword -<span class="lineNum"> 350 </span> : * arrays are copied. Before copying, each callback is invoked with -<span class="lineNum"> 351 </span> : * erase_event. After copying, each (new) callback is invoked with -<span class="lineNum"> 352 </span> : * copyfmt_event. The final step is to copy exceptions(). -<span class="lineNum"> 353 </span> : */ -<span class="lineNum"> 354 </span> : basic_ios& -<span class="lineNum"> 355 </span> : copyfmt(const basic_ios& __rhs); -<span class="lineNum"> 356 </span> : -<span class="lineNum"> 357 </span> : /** -<span class="lineNum"> 358 </span> : * @brief Retrieves the "empty" character. -<span class="lineNum"> 359 </span> : * @return The current fill character. -<span class="lineNum"> 360 </span> : * -<span class="lineNum"> 361 </span> : * It defaults to a space (' ') in the current locale. -<span class="lineNum"> 362 </span> : */ -<span class="lineNum"> 363 </span> : char_type -<span class="lineNum"> 364 </span><span class="lineNoCov"> 0 : fill() const</span> -<span class="lineNum"> 365 </span> : { -<span class="lineNum"> 366 </span><span class="lineNoCov"> 0 : if (!_M_fill_init)</span> -<span class="lineNum"> 367 </span> : { -<span class="lineNum"> 368 </span><span class="lineNoCov"> 0 : _M_fill = this->widen(' ');</span> -<span class="lineNum"> 369 </span><span class="lineNoCov"> 0 : _M_fill_init = true;</span> -<span class="lineNum"> 370 </span> : } -<span class="lineNum"> 371 </span><span class="lineNoCov"> 0 : return _M_fill;</span> -<span class="lineNum"> 372 </span> : } -<span class="lineNum"> 373 </span> : -<span class="lineNum"> 374 </span> : /** -<span class="lineNum"> 375 </span> : * @brief Sets a new "empty" character. -<span class="lineNum"> 376 </span> : * @param ch The new character. -<span class="lineNum"> 377 </span> : * @return The previous fill character. -<span class="lineNum"> 378 </span> : * -<span class="lineNum"> 379 </span> : * The fill character is used to fill out space when P+ characters -<span class="lineNum"> 380 </span> : * have been requested (e.g., via setw), Q characters are actually -<span class="lineNum"> 381 </span> : * used, and Q<P. It defaults to a space (' ') in the current locale. -<span class="lineNum"> 382 </span> : */ -<span class="lineNum"> 383 </span> : char_type -<span class="lineNum"> 384 </span><span class="lineNoCov"> 0 : fill(char_type __ch)</span> -<span class="lineNum"> 385 </span> : { -<span class="lineNum"> 386 </span><span class="lineNoCov"> 0 : char_type __old = this->fill();</span> -<span class="lineNum"> 387 </span><span class="lineNoCov"> 0 : _M_fill = __ch;</span> -<span class="lineNum"> 388 </span><span class="lineNoCov"> 0 : return __old;</span> -<span class="lineNum"> 389 </span> : } -<span class="lineNum"> 390 </span> : -<span class="lineNum"> 391 </span> : // Locales: -<span class="lineNum"> 392 </span> : /** -<span class="lineNum"> 393 </span> : * @brief Moves to a new locale. -<span class="lineNum"> 394 </span> : * @param loc The new locale. -<span class="lineNum"> 395 </span> : * @return The previous locale. -<span class="lineNum"> 396 </span> : * -<span class="lineNum"> 397 </span> : * Calls @c ios_base::imbue(loc), and if a stream buffer is associated -<span class="lineNum"> 398 </span> : * with this stream, calls that buffer's @c pubimbue(loc). -<span class="lineNum"> 399 </span> : * -<span class="lineNum"> 400 </span> : * Additional l10n notes are at -<span class="lineNum"> 401 </span> : * http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html -<span class="lineNum"> 402 </span> : */ -<span class="lineNum"> 403 </span> : locale -<span class="lineNum"> 404 </span> : imbue(const locale& __loc); -<span class="lineNum"> 405 </span> : -<span class="lineNum"> 406 </span> : /** -<span class="lineNum"> 407 </span> : * @brief Squeezes characters. -<span class="lineNum"> 408 </span> : * @param c The character to narrow. -<span class="lineNum"> 409 </span> : * @param dfault The character to narrow. -<span class="lineNum"> 410 </span> : * @return The narrowed character. -<span class="lineNum"> 411 </span> : * -<span class="lineNum"> 412 </span> : * Maps a character of @c char_type to a character of @c char, -<span class="lineNum"> 413 </span> : * if possible. -<span class="lineNum"> 414 </span> : * -<span class="lineNum"> 415 </span> : * Returns the result of -<span class="lineNum"> 416 </span> : * @code -<span class="lineNum"> 417 </span> : * std::use_facet<ctype<char_type> >(getloc()).narrow(c,dfault) -<span class="lineNum"> 418 </span> : * @endcode -<span class="lineNum"> 419 </span> : * -<span class="lineNum"> 420 </span> : * Additional l10n notes are at -<span class="lineNum"> 421 </span> : * http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html -<span class="lineNum"> 422 </span> : */ -<span class="lineNum"> 423 </span> : char -<span class="lineNum"> 424 </span> : narrow(char_type __c, char __dfault) const -<span class="lineNum"> 425 </span> : { return __check_facet(_M_ctype).narrow(__c, __dfault); } -<span class="lineNum"> 426 </span> : -<span class="lineNum"> 427 </span> : /** -<span class="lineNum"> 428 </span> : * @brief Widens characters. -<span class="lineNum"> 429 </span> : * @param c The character to widen. -<span class="lineNum"> 430 </span> : * @return The widened character. -<span class="lineNum"> 431 </span> : * -<span class="lineNum"> 432 </span> : * Maps a character of @c char to a character of @c char_type. -<span class="lineNum"> 433 </span> : * -<span class="lineNum"> 434 </span> : * Returns the result of -<span class="lineNum"> 435 </span> : * @code -<span class="lineNum"> 436 </span> : * std::use_facet<ctype<char_type> >(getloc()).widen(c) -<span class="lineNum"> 437 </span> : * @endcode -<span class="lineNum"> 438 </span> : * -<span class="lineNum"> 439 </span> : * Additional l10n notes are at -<span class="lineNum"> 440 </span> : * http://gcc.gnu.org/onlinedocs/libstdc++/22_locale/howto.html -<span class="lineNum"> 441 </span> : */ -<span class="lineNum"> 442 </span> : char_type -<span class="lineNum"> 443 </span><span class="lineNoCov"> 0 : widen(char __c) const</span> -<span class="lineNum"> 444 </span><span class="lineNoCov"> 0 : { return __check_facet(_M_ctype).widen(__c); }</span> -<span class="lineNum"> 445 </span> : -<span class="lineNum"> 446 </span> : protected: -<span class="lineNum"> 447 </span> : // 27.4.5.1 basic_ios constructors -<span class="lineNum"> 448 </span> : /** -<span class="lineNum"> 449 </span> : * @brief Empty. -<span class="lineNum"> 450 </span> : * -<span class="lineNum"> 451 </span> : * The default constructor does nothing and is not normally -<span class="lineNum"> 452 </span> : * accessible to users. -<span class="lineNum"> 453 </span> : */ -<span class="lineNum"> 454 </span><span class="lineNoCov"> 0 : basic_ios()</span> -<span class="lineNum"> 455 </span> : : ios_base(), _M_tie(0), _M_fill(char_type()), _M_fill_init(false), -<span class="lineNum"> 456 </span><span class="lineNoCov"> 0 : _M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0)</span> -<span class="lineNum"> 457 </span><span class="lineNoCov"> 0 : { }</span> -<span class="lineNum"> 458 </span> : -<span class="lineNum"> 459 </span> : /** -<span class="lineNum"> 460 </span> : * @brief All setup is performed here. -<span class="lineNum"> 461 </span> : * -<span class="lineNum"> 462 </span> : * This is called from the public constructor. It is not virtual and -<span class="lineNum"> 463 </span> : * cannot be redefined. -<span class="lineNum"> 464 </span> : */ -<span class="lineNum"> 465 </span> : void -<span class="lineNum"> 466 </span> : init(basic_streambuf<_CharT, _Traits>* __sb); -<span class="lineNum"> 467 </span> : -<span class="lineNum"> 468 </span> : void -<span class="lineNum"> 469 </span> : _M_cache_locale(const locale& __loc); -<span class="lineNum"> 470 </span> : }; -<span class="lineNum"> 471 </span> : -<span class="lineNum"> 472 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 473 </span> : -<span class="lineNum"> 474 </span> : #ifndef _GLIBCXX_EXPORT_TEMPLATE -<span class="lineNum"> 475 </span> : #include <bits/basic_ios.tcc> -<span class="lineNum"> 476 </span> : #endif -<span class="lineNum"> 477 </span> : -<span class="lineNum"> 478 </span> : #endif /* _BASIC_IOS_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/basic_string.h.gcov.html b/rep/usr/include/c++/4.3/bits/basic_string.h.gcov.html deleted file mode 100644 index 909cd58..0000000 --- a/rep/usr/include/c++/4.3/bits/basic_string.h.gcov.html +++ /dev/null @@ -1,2545 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/basic_string.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - basic_string.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">178</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">17.4 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">31</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Components for manipulating sequences of characters -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007, 2008 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file basic_string.h -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : // -<span class="lineNum"> 38 </span> : // ISO C++ 14882: 21 Strings library -<span class="lineNum"> 39 </span> : // -<span class="lineNum"> 40 </span> : -<span class="lineNum"> 41 </span> : #ifndef _BASIC_STRING_H -<span class="lineNum"> 42 </span> : #define _BASIC_STRING_H 1 -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : #pragma GCC system_header -<span class="lineNum"> 45 </span> : -<span class="lineNum"> 46 </span> : #include <ext/atomicity.h> -<span class="lineNum"> 47 </span> : #include <debug/debug.h> -<span class="lineNum"> 48 </span> : -<span class="lineNum"> 49 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 50 </span> : -<span class="lineNum"> 51 </span> : /** -<span class="lineNum"> 52 </span> : * @class basic_string basic_string.h <string> -<span class="lineNum"> 53 </span> : * @brief Managing sequences of characters and character-like objects. -<span class="lineNum"> 54 </span> : * -<span class="lineNum"> 55 </span> : * @ingroup Containers -<span class="lineNum"> 56 </span> : * @ingroup Sequences -<span class="lineNum"> 57 </span> : * -<span class="lineNum"> 58 </span> : * Meets the requirements of a <a href="tables.html#65">container</a>, a -<span class="lineNum"> 59 </span> : * <a href="tables.html#66">reversible container</a>, and a -<span class="lineNum"> 60 </span> : * <a href="tables.html#67">sequence</a>. Of the -<span class="lineNum"> 61 </span> : * <a href="tables.html#68">optional sequence requirements</a>, only -<span class="lineNum"> 62 </span> : * @c push_back, @c at, and array access are supported. -<span class="lineNum"> 63 </span> : * -<span class="lineNum"> 64 </span> : * @doctodo -<span class="lineNum"> 65 </span> : * -<span class="lineNum"> 66 </span> : * -<span class="lineNum"> 67 </span> : * Documentation? What's that? -<span class="lineNum"> 68 </span> : * Nathan Myers <ncm@cantrip.org>. -<span class="lineNum"> 69 </span> : * -<span class="lineNum"> 70 </span> : * A string looks like this: -<span class="lineNum"> 71 </span> : * -<span class="lineNum"> 72 </span> : * @code -<span class="lineNum"> 73 </span> : * [_Rep] -<span class="lineNum"> 74 </span> : * _M_length -<span class="lineNum"> 75 </span> : * [basic_string<char_type>] _M_capacity -<span class="lineNum"> 76 </span> : * _M_dataplus _M_refcount -<span class="lineNum"> 77 </span> : * _M_p ----------------> unnamed array of char_type -<span class="lineNum"> 78 </span> : * @endcode -<span class="lineNum"> 79 </span> : * -<span class="lineNum"> 80 </span> : * Where the _M_p points to the first character in the string, and -<span class="lineNum"> 81 </span> : * you cast it to a pointer-to-_Rep and subtract 1 to get a -<span class="lineNum"> 82 </span> : * pointer to the header. -<span class="lineNum"> 83 </span> : * -<span class="lineNum"> 84 </span> : * This approach has the enormous advantage that a string object -<span class="lineNum"> 85 </span> : * requires only one allocation. All the ugliness is confined -<span class="lineNum"> 86 </span> : * within a single pair of inline functions, which each compile to -<span class="lineNum"> 87 </span> : * a single "add" instruction: _Rep::_M_data(), and -<span class="lineNum"> 88 </span> : * string::_M_rep(); and the allocation function which gets a -<span class="lineNum"> 89 </span> : * block of raw bytes and with room enough and constructs a _Rep -<span class="lineNum"> 90 </span> : * object at the front. -<span class="lineNum"> 91 </span> : * -<span class="lineNum"> 92 </span> : * The reason you want _M_data pointing to the character array and -<span class="lineNum"> 93 </span> : * not the _Rep is so that the debugger can see the string -<span class="lineNum"> 94 </span> : * contents. (Probably we should add a non-inline member to get -<span class="lineNum"> 95 </span> : * the _Rep for the debugger to use, so users can check the actual -<span class="lineNum"> 96 </span> : * string length.) -<span class="lineNum"> 97 </span> : * -<span class="lineNum"> 98 </span> : * Note that the _Rep object is a POD so that you can have a -<span class="lineNum"> 99 </span> : * static "empty string" _Rep object already "constructed" before -<span class="lineNum"> 100 </span> : * static constructors have run. The reference-count encoding is -<span class="lineNum"> 101 </span> : * chosen so that a 0 indicates one reference, so you never try to -<span class="lineNum"> 102 </span> : * destroy the empty-string _Rep object. -<span class="lineNum"> 103 </span> : * -<span class="lineNum"> 104 </span> : * All but the last paragraph is considered pretty conventional -<span class="lineNum"> 105 </span> : * for a C++ string implementation. -<span class="lineNum"> 106 </span> : */ -<span class="lineNum"> 107 </span> : // 21.3 Template class basic_string -<span class="lineNum"> 108 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 109 </span> : class basic_string -<span class="lineNum"> 110 </span> : { -<span class="lineNum"> 111 </span> : typedef typename _Alloc::template rebind<_CharT>::other _CharT_alloc_type; -<span class="lineNum"> 112 </span> : -<span class="lineNum"> 113 </span> : // Types: -<span class="lineNum"> 114 </span> : public: -<span class="lineNum"> 115 </span> : typedef _Traits traits_type; -<span class="lineNum"> 116 </span> : typedef typename _Traits::char_type value_type; -<span class="lineNum"> 117 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 118 </span> : typedef typename _CharT_alloc_type::size_type size_type; -<span class="lineNum"> 119 </span> : typedef typename _CharT_alloc_type::difference_type difference_type; -<span class="lineNum"> 120 </span> : typedef typename _CharT_alloc_type::reference reference; -<span class="lineNum"> 121 </span> : typedef typename _CharT_alloc_type::const_reference const_reference; -<span class="lineNum"> 122 </span> : typedef typename _CharT_alloc_type::pointer pointer; -<span class="lineNum"> 123 </span> : typedef typename _CharT_alloc_type::const_pointer const_pointer; -<span class="lineNum"> 124 </span> : typedef __gnu_cxx::__normal_iterator<pointer, basic_string> iterator; -<span class="lineNum"> 125 </span> : typedef __gnu_cxx::__normal_iterator<const_pointer, basic_string> -<span class="lineNum"> 126 </span> : const_iterator; -<span class="lineNum"> 127 </span> : typedef std::reverse_iterator<const_iterator> const_reverse_iterator; -<span class="lineNum"> 128 </span> : typedef std::reverse_iterator<iterator> reverse_iterator; -<span class="lineNum"> 129 </span> : -<span class="lineNum"> 130 </span> : private: -<span class="lineNum"> 131 </span> : // _Rep: string representation -<span class="lineNum"> 132 </span> : // Invariants: -<span class="lineNum"> 133 </span> : // 1. String really contains _M_length + 1 characters: due to 21.3.4 -<span class="lineNum"> 134 </span> : // must be kept null-terminated. -<span class="lineNum"> 135 </span> : // 2. _M_capacity >= _M_length -<span class="lineNum"> 136 </span> : // Allocated memory is always (_M_capacity + 1) * sizeof(_CharT). -<span class="lineNum"> 137 </span> : // 3. _M_refcount has three states: -<span class="lineNum"> 138 </span> : // -1: leaked, one reference, no ref-copies allowed, non-const. -<span class="lineNum"> 139 </span> : // 0: one reference, non-const. -<span class="lineNum"> 140 </span> : // n>0: n + 1 references, operations require a lock, const. -<span class="lineNum"> 141 </span> : // 4. All fields==0 is an empty string, given the extra storage -<span class="lineNum"> 142 </span> : // beyond-the-end for a null terminator; thus, the shared -<span class="lineNum"> 143 </span> : // empty string representation needs no constructor. -<span class="lineNum"> 144 </span> : -<span class="lineNum"> 145 </span> : struct _Rep_base -<span class="lineNum"> 146 </span> : { -<span class="lineNum"> 147 </span> : size_type _M_length; -<span class="lineNum"> 148 </span> : size_type _M_capacity; -<span class="lineNum"> 149 </span> : _Atomic_word _M_refcount; -<span class="lineNum"> 150 </span> : }; -<span class="lineNum"> 151 </span> : -<span class="lineNum"> 152 </span> : struct _Rep : _Rep_base -<span class="lineNum"> 153 </span> : { -<span class="lineNum"> 154 </span> : // Types: -<span class="lineNum"> 155 </span> : typedef typename _Alloc::template rebind<char>::other _Raw_bytes_alloc; -<span class="lineNum"> 156 </span> : -<span class="lineNum"> 157 </span> : // (Public) Data members: -<span class="lineNum"> 158 </span> : -<span class="lineNum"> 159 </span> : // The maximum number of individual char_type elements of an -<span class="lineNum"> 160 </span> : // individual string is determined by _S_max_size. This is the -<span class="lineNum"> 161 </span> : // value that will be returned by max_size(). (Whereas npos -<span class="lineNum"> 162 </span> : // is the maximum number of bytes the allocator can allocate.) -<span class="lineNum"> 163 </span> : // If one was to divvy up the theoretical largest size string, -<span class="lineNum"> 164 </span> : // with a terminating character and m _CharT elements, it'd -<span class="lineNum"> 165 </span> : // look like this: -<span class="lineNum"> 166 </span> : // npos = sizeof(_Rep) + (m * sizeof(_CharT)) + sizeof(_CharT) -<span class="lineNum"> 167 </span> : // Solving for m: -<span class="lineNum"> 168 </span> : // m = ((npos - sizeof(_Rep))/sizeof(CharT)) - 1 -<span class="lineNum"> 169 </span> : // In addition, this implementation quarters this amount. -<span class="lineNum"> 170 </span> : static const size_type _S_max_size; -<span class="lineNum"> 171 </span> : static const _CharT _S_terminal; -<span class="lineNum"> 172 </span> : -<span class="lineNum"> 173 </span> : // The following storage is init'd to 0 by the linker, resulting -<span class="lineNum"> 174 </span> : // (carefully) in an empty string with one reference. -<span class="lineNum"> 175 </span> : static size_type _S_empty_rep_storage[]; -<span class="lineNum"> 176 </span> : -<span class="lineNum"> 177 </span> : static _Rep& -<span class="lineNum"> 178 </span><span class="lineNoCov"> 0 : _S_empty_rep()</span> -<span class="lineNum"> 179 </span> : { -<span class="lineNum"> 180 </span> : // NB: Mild hack to avoid strict-aliasing warnings. Note that -<span class="lineNum"> 181 </span> : // _S_empty_rep_storage is never modified and the punning should -<span class="lineNum"> 182 </span> : // be reasonably safe in this case. -<span class="lineNum"> 183 </span><span class="lineNoCov"> 0 : void* __p = reinterpret_cast<void*>(&_S_empty_rep_storage);</span> -<span class="lineNum"> 184 </span><span class="lineNoCov"> 0 : return *reinterpret_cast<_Rep*>(__p);</span> -<span class="lineNum"> 185 </span> : } -<span class="lineNum"> 186 </span> : -<span class="lineNum"> 187 </span> : bool -<span class="lineNum"> 188 </span><span class="lineNoCov"> 0 : _M_is_leaked() const</span> -<span class="lineNum"> 189 </span><span class="lineNoCov"> 0 : { return this->_M_refcount < 0; }</span> -<span class="lineNum"> 190 </span> : -<span class="lineNum"> 191 </span> : bool -<span class="lineNum"> 192 </span><span class="lineNoCov"> 0 : _M_is_shared() const</span> -<span class="lineNum"> 193 </span><span class="lineNoCov"> 0 : { return this->_M_refcount > 0; }</span> -<span class="lineNum"> 194 </span> : -<span class="lineNum"> 195 </span> : void -<span class="lineNum"> 196 </span><span class="lineNoCov"> 0 : _M_set_leaked()</span> -<span class="lineNum"> 197 </span><span class="lineNoCov"> 0 : { this->_M_refcount = -1; }</span> -<span class="lineNum"> 198 </span> : -<span class="lineNum"> 199 </span> : void -<span class="lineNum"> 200 </span><span class="lineNoCov"> 0 : _M_set_sharable()</span> -<span class="lineNum"> 201 </span><span class="lineNoCov"> 0 : { this->_M_refcount = 0; }</span> -<span class="lineNum"> 202 </span> : -<span class="lineNum"> 203 </span> : void -<span class="lineNum"> 204 </span><span class="lineNoCov"> 0 : _M_set_length_and_sharable(size_type __n)</span> -<span class="lineNum"> 205 </span> : { -<span class="lineNum"> 206 </span><span class="lineNoCov"> 0 : this->_M_set_sharable(); // One reference.</span> -<span class="lineNum"> 207 </span><span class="lineNoCov"> 0 : this->_M_length = __n;</span> -<span class="lineNum"> 208 </span><span class="lineNoCov"> 0 : traits_type::assign(this->_M_refdata()[__n], _S_terminal);</span> -<span class="lineNum"> 209 </span> : // grrr. (per 21.3.4) -<span class="lineNum"> 210 </span> : // You cannot leave those LWG people alone for a second. -<span class="lineNum"> 211 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 212 </span> : -<span class="lineNum"> 213 </span> : _CharT* -<span class="lineNum"> 214 </span><span class="lineNoCov"> 0 : _M_refdata() throw()</span> -<span class="lineNum"> 215 </span><span class="lineNoCov"> 0 : { return reinterpret_cast<_CharT*>(this + 1); }</span> -<span class="lineNum"> 216 </span> : -<span class="lineNum"> 217 </span> : _CharT* -<span class="lineNum"> 218 </span> : _M_grab(const _Alloc& __alloc1, const _Alloc& __alloc2) -<span class="lineNum"> 219 </span> : { -<span class="lineNum"> 220 </span> : return (!_M_is_leaked() && __alloc1 == __alloc2) -<span class="lineNum"> 221 </span> : ? _M_refcopy() : _M_clone(__alloc1); -<span class="lineNum"> 222 </span> : } -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : // Create & Destroy -<span class="lineNum"> 225 </span> : static _Rep* -<span class="lineNum"> 226 </span> : _S_create(size_type, size_type, const _Alloc&); -<span class="lineNum"> 227 </span> : -<span class="lineNum"> 228 </span> : void -<span class="lineNum"> 229 </span><span class="lineNoCov"> 0 : _M_dispose(const _Alloc& __a)</span> -<span class="lineNum"> 230 </span> : { -<span class="lineNum"> 231 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 232 </span><span class="lineNoCov"> 0 : if (__builtin_expect(this != &_S_empty_rep(), false))</span> -<span class="lineNum"> 233 </span> : #endif -<span class="lineNum"> 234 </span><span class="lineNoCov"> 0 : if (__gnu_cxx::__exchange_and_add_dispatch(&this->_M_refcount,</span> -<span class="lineNum"> 235 </span> : -1) <= 0) -<span class="lineNum"> 236 </span><span class="lineNoCov"> 0 : _M_destroy(__a);</span> -<span class="lineNum"> 237 </span><span class="lineNoCov"> 0 : } // XXX MT</span> -<span class="lineNum"> 238 </span> : -<span class="lineNum"> 239 </span> : void -<span class="lineNum"> 240 </span> : _M_destroy(const _Alloc&) throw(); -<span class="lineNum"> 241 </span> : -<span class="lineNum"> 242 </span> : _CharT* -<span class="lineNum"> 243 </span> : _M_refcopy() throw() -<span class="lineNum"> 244 </span> : { -<span class="lineNum"> 245 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 246 </span> : if (__builtin_expect(this != &_S_empty_rep(), false)) -<span class="lineNum"> 247 </span> : #endif -<span class="lineNum"> 248 </span> : __gnu_cxx::__atomic_add_dispatch(&this->_M_refcount, 1); -<span class="lineNum"> 249 </span> : return _M_refdata(); -<span class="lineNum"> 250 </span> : } // XXX MT -<span class="lineNum"> 251 </span> : -<span class="lineNum"> 252 </span> : _CharT* -<span class="lineNum"> 253 </span> : _M_clone(const _Alloc&, size_type __res = 0); -<span class="lineNum"> 254 </span> : }; -<span class="lineNum"> 255 </span> : -<span class="lineNum"> 256 </span> : // Use empty-base optimization: http://www.cantrip.org/emptyopt.html -<span class="lineNum"> 257 </span> : struct _Alloc_hider : _Alloc -<span class="lineNum"> 258 </span><span class="lineNoCov"> 0 : {</span> -<span class="lineNum"> 259 </span><span class="lineNoCov"> 0 : _Alloc_hider(_CharT* __dat, const _Alloc& __a)</span> -<span class="lineNum"> 260 </span><span class="lineNoCov"> 0 : : _Alloc(__a), _M_p(__dat) { }</span> -<span class="lineNum"> 261 </span> : -<span class="lineNum"> 262 </span> : _CharT* _M_p; // The actual data. -<span class="lineNum"> 263 </span> : }; -<span class="lineNum"> 264 </span> : -<span class="lineNum"> 265 </span> : public: -<span class="lineNum"> 266 </span> : // Data Members (public): -<span class="lineNum"> 267 </span> : // NB: This is an unsigned type, and thus represents the maximum -<span class="lineNum"> 268 </span> : // size that the allocator can hold. -<span class="lineNum"> 269 </span> : /// Value returned by various member functions when they fail. -<span class="lineNum"> 270 </span> : static const size_type npos = static_cast<size_type>(-1); -<span class="lineNum"> 271 </span> : -<span class="lineNum"> 272 </span> : private: -<span class="lineNum"> 273 </span> : // Data Members (private): -<span class="lineNum"> 274 </span> : mutable _Alloc_hider _M_dataplus; -<span class="lineNum"> 275 </span> : -<span class="lineNum"> 276 </span> : _CharT* -<span class="lineNum"> 277 </span><span class="lineNoCov"> 0 : _M_data() const</span> -<span class="lineNum"> 278 </span><span class="lineNoCov"> 0 : { return _M_dataplus._M_p; }</span> -<span class="lineNum"> 279 </span> : -<span class="lineNum"> 280 </span> : _CharT* -<span class="lineNum"> 281 </span> : _M_data(_CharT* __p) -<span class="lineNum"> 282 </span> : { return (_M_dataplus._M_p = __p); } -<span class="lineNum"> 283 </span> : -<span class="lineNum"> 284 </span> : _Rep* -<span class="lineNum"> 285 </span><span class="lineNoCov"> 0 : _M_rep() const</span> -<span class="lineNum"> 286 </span><span class="lineNoCov"> 0 : { return &((reinterpret_cast<_Rep*> (_M_data()))[-1]); }</span> -<span class="lineNum"> 287 </span> : -<span class="lineNum"> 288 </span> : // For the internal use we have functions similar to `begin'/`end' -<span class="lineNum"> 289 </span> : // but they do not call _M_leak. -<span class="lineNum"> 290 </span> : iterator -<span class="lineNum"> 291 </span><span class="lineNoCov"> 0 : _M_ibegin() const</span> -<span class="lineNum"> 292 </span><span class="lineNoCov"> 0 : { return iterator(_M_data()); }</span> -<span class="lineNum"> 293 </span> : -<span class="lineNum"> 294 </span> : iterator -<span class="lineNum"> 295 </span> : _M_iend() const -<span class="lineNum"> 296 </span> : { return iterator(_M_data() + this->size()); } -<span class="lineNum"> 297 </span> : -<span class="lineNum"> 298 </span> : void -<span class="lineNum"> 299 </span><span class="lineNoCov"> 0 : _M_leak() // for use in begin() & non-const op[]</span> -<span class="lineNum"> 300 </span> : { -<span class="lineNum"> 301 </span><span class="lineNoCov"> 0 : if (!_M_rep()->_M_is_leaked())</span> -<span class="lineNum"> 302 </span><span class="lineNoCov"> 0 : _M_leak_hard();</span> -<span class="lineNum"> 303 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 304 </span> : -<span class="lineNum"> 305 </span> : size_type -<span class="lineNum"> 306 </span><span class="lineNoCov"> 0 : _M_check(size_type __pos, const char* __s) const</span> -<span class="lineNum"> 307 </span> : { -<span class="lineNum"> 308 </span><span class="lineNoCov"> 0 : if (__pos > this->size())</span> -<span class="lineNum"> 309 </span><span class="lineNoCov"> 0 : __throw_out_of_range(__N(__s));</span> -<span class="lineNum"> 310 </span><span class="lineNoCov"> 0 : return __pos;</span> -<span class="lineNum"> 311 </span> : } -<span class="lineNum"> 312 </span> : -<span class="lineNum"> 313 </span> : void -<span class="lineNum"> 314 </span> : _M_check_length(size_type __n1, size_type __n2, const char* __s) const -<span class="lineNum"> 315 </span> : { -<span class="lineNum"> 316 </span> : if (this->max_size() - (this->size() - __n1) < __n2) -<span class="lineNum"> 317 </span> : __throw_length_error(__N(__s)); -<span class="lineNum"> 318 </span> : } -<span class="lineNum"> 319 </span> : -<span class="lineNum"> 320 </span> : // NB: _M_limit doesn't check for a bad __pos value. -<span class="lineNum"> 321 </span> : size_type -<span class="lineNum"> 322 </span> : _M_limit(size_type __pos, size_type __off) const -<span class="lineNum"> 323 </span> : { -<span class="lineNum"> 324 </span> : const bool __testoff = __off < this->size() - __pos; -<span class="lineNum"> 325 </span> : return __testoff ? __off : this->size() - __pos; -<span class="lineNum"> 326 </span> : } -<span class="lineNum"> 327 </span> : -<span class="lineNum"> 328 </span> : // True if _Rep and source do not overlap. -<span class="lineNum"> 329 </span> : bool -<span class="lineNum"> 330 </span> : _M_disjunct(const _CharT* __s) const -<span class="lineNum"> 331 </span> : { -<span class="lineNum"> 332 </span> : return (less<const _CharT*>()(__s, _M_data()) -<span class="lineNum"> 333 </span> : || less<const _CharT*>()(_M_data() + this->size(), __s)); -<span class="lineNum"> 334 </span> : } -<span class="lineNum"> 335 </span> : -<span class="lineNum"> 336 </span> : // When __n = 1 way faster than the general multichar -<span class="lineNum"> 337 </span> : // traits_type::copy/move/assign. -<span class="lineNum"> 338 </span> : static void -<span class="lineNum"> 339 </span><span class="lineNoCov"> 0 : _M_copy(_CharT* __d, const _CharT* __s, size_type __n)</span> -<span class="lineNum"> 340 </span> : { -<span class="lineNum"> 341 </span><span class="lineNoCov"> 0 : if (__n == 1)</span> -<span class="lineNum"> 342 </span><span class="lineNoCov"> 0 : traits_type::assign(*__d, *__s);</span> -<span class="lineNum"> 343 </span> : else -<span class="lineNum"> 344 </span><span class="lineNoCov"> 0 : traits_type::copy(__d, __s, __n);</span> -<span class="lineNum"> 345 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 346 </span> : -<span class="lineNum"> 347 </span> : static void -<span class="lineNum"> 348 </span> : _M_move(_CharT* __d, const _CharT* __s, size_type __n) -<span class="lineNum"> 349 </span> : { -<span class="lineNum"> 350 </span> : if (__n == 1) -<span class="lineNum"> 351 </span> : traits_type::assign(*__d, *__s); -<span class="lineNum"> 352 </span> : else -<span class="lineNum"> 353 </span> : traits_type::move(__d, __s, __n); -<span class="lineNum"> 354 </span> : } -<span class="lineNum"> 355 </span> : -<span class="lineNum"> 356 </span> : static void -<span class="lineNum"> 357 </span> : _M_assign(_CharT* __d, size_type __n, _CharT __c) -<span class="lineNum"> 358 </span> : { -<span class="lineNum"> 359 </span> : if (__n == 1) -<span class="lineNum"> 360 </span> : traits_type::assign(*__d, __c); -<span class="lineNum"> 361 </span> : else -<span class="lineNum"> 362 </span> : traits_type::assign(__d, __n, __c); -<span class="lineNum"> 363 </span> : } -<span class="lineNum"> 364 </span> : -<span class="lineNum"> 365 </span> : // _S_copy_chars is a separate template to permit specialization -<span class="lineNum"> 366 </span> : // to optimize for the common case of pointers as iterators. -<span class="lineNum"> 367 </span> : template<class _Iterator> -<span class="lineNum"> 368 </span> : static void -<span class="lineNum"> 369 </span><span class="lineCov"> 1012 : _S_copy_chars(_CharT* __p, _Iterator __k1, _Iterator __k2)</span> -<span class="lineNum"> 370 </span> : { -<span class="lineNum"> 371 </span><span class="lineCov"> 11988 : for (; __k1 != __k2; ++__k1, ++__p)</span> -<span class="lineNum"> 372 </span><span class="lineCov"> 10976 : traits_type::assign(*__p, *__k1); // These types are off.</span> -<span class="lineNum"> 373 </span><span class="lineCov"> 1012 : }</span> -<span class="lineNum"> 374 </span> : -<span class="lineNum"> 375 </span> : static void -<span class="lineNum"> 376 </span><span class="lineNoCov"> 0 : _S_copy_chars(_CharT* __p, iterator __k1, iterator __k2)</span> -<span class="lineNum"> 377 </span><span class="lineNoCov"> 0 : { _S_copy_chars(__p, __k1.base(), __k2.base()); }</span> -<span class="lineNum"> 378 </span> : -<span class="lineNum"> 379 </span> : static void -<span class="lineNum"> 380 </span> : _S_copy_chars(_CharT* __p, const_iterator __k1, const_iterator __k2) -<span class="lineNum"> 381 </span> : { _S_copy_chars(__p, __k1.base(), __k2.base()); } -<span class="lineNum"> 382 </span> : -<span class="lineNum"> 383 </span> : static void -<span class="lineNum"> 384 </span><span class="lineNoCov"> 0 : _S_copy_chars(_CharT* __p, _CharT* __k1, _CharT* __k2)</span> -<span class="lineNum"> 385 </span><span class="lineNoCov"> 0 : { _M_copy(__p, __k1, __k2 - __k1); }</span> -<span class="lineNum"> 386 </span> : -<span class="lineNum"> 387 </span> : static void -<span class="lineNum"> 388 </span> : _S_copy_chars(_CharT* __p, const _CharT* __k1, const _CharT* __k2) -<span class="lineNum"> 389 </span> : { _M_copy(__p, __k1, __k2 - __k1); } -<span class="lineNum"> 390 </span> : -<span class="lineNum"> 391 </span> : static int -<span class="lineNum"> 392 </span><span class="lineNoCov"> 0 : _S_compare(size_type __n1, size_type __n2)</span> -<span class="lineNum"> 393 </span> : { -<span class="lineNum"> 394 </span><span class="lineNoCov"> 0 : const difference_type __d = difference_type(__n1 - __n2);</span> -<span class="lineNum"> 395 </span> : -<span class="lineNum"> 396 </span> : if (__d > __gnu_cxx::__numeric_traits<int>::__max) -<span class="lineNum"> 397 </span> : return __gnu_cxx::__numeric_traits<int>::__max; -<span class="lineNum"> 398 </span> : else if (__d < __gnu_cxx::__numeric_traits<int>::__min) -<span class="lineNum"> 399 </span> : return __gnu_cxx::__numeric_traits<int>::__min; -<span class="lineNum"> 400 </span> : else -<span class="lineNum"> 401 </span><span class="lineNoCov"> 0 : return int(__d);</span> -<span class="lineNum"> 402 </span> : } -<span class="lineNum"> 403 </span> : -<span class="lineNum"> 404 </span> : void -<span class="lineNum"> 405 </span> : _M_mutate(size_type __pos, size_type __len1, size_type __len2); -<span class="lineNum"> 406 </span> : -<span class="lineNum"> 407 </span> : void -<span class="lineNum"> 408 </span> : _M_leak_hard(); -<span class="lineNum"> 409 </span> : -<span class="lineNum"> 410 </span> : static _Rep& -<span class="lineNum"> 411 </span><span class="lineNoCov"> 0 : _S_empty_rep()</span> -<span class="lineNum"> 412 </span><span class="lineNoCov"> 0 : { return _Rep::_S_empty_rep(); }</span> -<span class="lineNum"> 413 </span> : -<span class="lineNum"> 414 </span> : public: -<span class="lineNum"> 415 </span> : // Construct/copy/destroy: -<span class="lineNum"> 416 </span> : // NB: We overload ctors in some cases instead of using default -<span class="lineNum"> 417 </span> : // arguments, per 17.4.4.4 para. 2 item 2. -<span class="lineNum"> 418 </span> : -<span class="lineNum"> 419 </span> : /** -<span class="lineNum"> 420 </span> : * @brief Default constructor creates an empty string. -<span class="lineNum"> 421 </span> : */ -<span class="lineNum"> 422 </span> : inline -<span class="lineNum"> 423 </span> : basic_string(); -<span class="lineNum"> 424 </span> : -<span class="lineNum"> 425 </span> : /** -<span class="lineNum"> 426 </span> : * @brief Construct an empty string using allocator @a a. -<span class="lineNum"> 427 </span> : */ -<span class="lineNum"> 428 </span> : explicit -<span class="lineNum"> 429 </span> : basic_string(const _Alloc& __a); -<span class="lineNum"> 430 </span> : -<span class="lineNum"> 431 </span> : // NB: per LWG issue 42, semantics different from IS: -<span class="lineNum"> 432 </span> : /** -<span class="lineNum"> 433 </span> : * @brief Construct string with copy of value of @a str. -<span class="lineNum"> 434 </span> : * @param str Source string. -<span class="lineNum"> 435 </span> : */ -<span class="lineNum"> 436 </span> : basic_string(const basic_string& __str); -<span class="lineNum"> 437 </span> : /** -<span class="lineNum"> 438 </span> : * @brief Construct string as copy of a substring. -<span class="lineNum"> 439 </span> : * @param str Source string. -<span class="lineNum"> 440 </span> : * @param pos Index of first character to copy from. -<span class="lineNum"> 441 </span> : * @param n Number of characters to copy (default remainder). -<span class="lineNum"> 442 </span> : */ -<span class="lineNum"> 443 </span> : basic_string(const basic_string& __str, size_type __pos, -<span class="lineNum"> 444 </span> : size_type __n = npos); -<span class="lineNum"> 445 </span> : /** -<span class="lineNum"> 446 </span> : * @brief Construct string as copy of a substring. -<span class="lineNum"> 447 </span> : * @param str Source string. -<span class="lineNum"> 448 </span> : * @param pos Index of first character to copy from. -<span class="lineNum"> 449 </span> : * @param n Number of characters to copy. -<span class="lineNum"> 450 </span> : * @param a Allocator to use. -<span class="lineNum"> 451 </span> : */ -<span class="lineNum"> 452 </span> : basic_string(const basic_string& __str, size_type __pos, -<span class="lineNum"> 453 </span> : size_type __n, const _Alloc& __a); -<span class="lineNum"> 454 </span> : -<span class="lineNum"> 455 </span> : /** -<span class="lineNum"> 456 </span> : * @brief Construct string initialized by a character array. -<span class="lineNum"> 457 </span> : * @param s Source character array. -<span class="lineNum"> 458 </span> : * @param n Number of characters to copy. -<span class="lineNum"> 459 </span> : * @param a Allocator to use (default is default allocator). -<span class="lineNum"> 460 </span> : * -<span class="lineNum"> 461 </span> : * NB: @a s must have at least @a n characters, '\0' has no special -<span class="lineNum"> 462 </span> : * meaning. -<span class="lineNum"> 463 </span> : */ -<span class="lineNum"> 464 </span> : basic_string(const _CharT* __s, size_type __n, -<span class="lineNum"> 465 </span> : const _Alloc& __a = _Alloc()); -<span class="lineNum"> 466 </span> : /** -<span class="lineNum"> 467 </span> : * @brief Construct string as copy of a C string. -<span class="lineNum"> 468 </span> : * @param s Source C string. -<span class="lineNum"> 469 </span> : * @param a Allocator to use (default is default allocator). -<span class="lineNum"> 470 </span> : */ -<span class="lineNum"> 471 </span> : basic_string(const _CharT* __s, const _Alloc& __a = _Alloc()); -<span class="lineNum"> 472 </span> : /** -<span class="lineNum"> 473 </span> : * @brief Construct string as multiple characters. -<span class="lineNum"> 474 </span> : * @param n Number of characters. -<span class="lineNum"> 475 </span> : * @param c Character to use. -<span class="lineNum"> 476 </span> : * @param a Allocator to use (default is default allocator). -<span class="lineNum"> 477 </span> : */ -<span class="lineNum"> 478 </span> : basic_string(size_type __n, _CharT __c, const _Alloc& __a = _Alloc()); -<span class="lineNum"> 479 </span> : -<span class="lineNum"> 480 </span> : /** -<span class="lineNum"> 481 </span> : * @brief Construct string as copy of a range. -<span class="lineNum"> 482 </span> : * @param beg Start of range. -<span class="lineNum"> 483 </span> : * @param end End of range. -<span class="lineNum"> 484 </span> : * @param a Allocator to use (default is default allocator). -<span class="lineNum"> 485 </span> : */ -<span class="lineNum"> 486 </span> : template<class _InputIterator> -<span class="lineNum"> 487 </span> : basic_string(_InputIterator __beg, _InputIterator __end, -<span class="lineNum"> 488 </span> : const _Alloc& __a = _Alloc()); -<span class="lineNum"> 489 </span> : -<span class="lineNum"> 490 </span> : /** -<span class="lineNum"> 491 </span> : * @brief Destroy the string instance. -<span class="lineNum"> 492 </span> : */ -<span class="lineNum"> 493 </span><span class="lineNoCov"> 0 : ~basic_string()</span> -<span class="lineNum"> 494 </span><span class="lineNoCov"> 0 : { _M_rep()->_M_dispose(this->get_allocator()); }</span> -<span class="lineNum"> 495 </span> : -<span class="lineNum"> 496 </span> : /** -<span class="lineNum"> 497 </span> : * @brief Assign the value of @a str to this string. -<span class="lineNum"> 498 </span> : * @param str Source string. -<span class="lineNum"> 499 </span> : */ -<span class="lineNum"> 500 </span> : basic_string& -<span class="lineNum"> 501 </span><span class="lineNoCov"> 0 : operator=(const basic_string& __str) </span> -<span class="lineNum"> 502 </span><span class="lineNoCov"> 0 : { return this->assign(__str); }</span> -<span class="lineNum"> 503 </span> : -<span class="lineNum"> 504 </span> : /** -<span class="lineNum"> 505 </span> : * @brief Copy contents of @a s into this string. -<span class="lineNum"> 506 </span> : * @param s Source null-terminated string. -<span class="lineNum"> 507 </span> : */ -<span class="lineNum"> 508 </span> : basic_string& -<span class="lineNum"> 509 </span><span class="lineNoCov"> 0 : operator=(const _CharT* __s) </span> -<span class="lineNum"> 510 </span><span class="lineNoCov"> 0 : { return this->assign(__s); }</span> -<span class="lineNum"> 511 </span> : -<span class="lineNum"> 512 </span> : /** -<span class="lineNum"> 513 </span> : * @brief Set value to string of length 1. -<span class="lineNum"> 514 </span> : * @param c Source character. -<span class="lineNum"> 515 </span> : * -<span class="lineNum"> 516 </span> : * Assigning to a character makes this string length 1 and -<span class="lineNum"> 517 </span> : * (*this)[0] == @a c. -<span class="lineNum"> 518 </span> : */ -<span class="lineNum"> 519 </span> : basic_string& -<span class="lineNum"> 520 </span> : operator=(_CharT __c) -<span class="lineNum"> 521 </span> : { -<span class="lineNum"> 522 </span> : this->assign(1, __c); -<span class="lineNum"> 523 </span> : return *this; -<span class="lineNum"> 524 </span> : } -<span class="lineNum"> 525 </span> : -<span class="lineNum"> 526 </span> : // Iterators: -<span class="lineNum"> 527 </span> : /** -<span class="lineNum"> 528 </span> : * Returns a read/write iterator that points to the first character in -<span class="lineNum"> 529 </span> : * the %string. Unshares the string. -<span class="lineNum"> 530 </span> : */ -<span class="lineNum"> 531 </span> : iterator -<span class="lineNum"> 532 </span><span class="lineNoCov"> 0 : begin()</span> -<span class="lineNum"> 533 </span> : { -<span class="lineNum"> 534 </span><span class="lineNoCov"> 0 : _M_leak();</span> -<span class="lineNum"> 535 </span><span class="lineNoCov"> 0 : return iterator(_M_data());</span> -<span class="lineNum"> 536 </span> : } -<span class="lineNum"> 537 </span> : -<span class="lineNum"> 538 </span> : /** -<span class="lineNum"> 539 </span> : * Returns a read-only (constant) iterator that points to the first -<span class="lineNum"> 540 </span> : * character in the %string. -<span class="lineNum"> 541 </span> : */ -<span class="lineNum"> 542 </span> : const_iterator -<span class="lineNum"> 543 </span><span class="lineNoCov"> 0 : begin() const</span> -<span class="lineNum"> 544 </span><span class="lineNoCov"> 0 : { return const_iterator(_M_data()); }</span> -<span class="lineNum"> 545 </span> : -<span class="lineNum"> 546 </span> : /** -<span class="lineNum"> 547 </span> : * Returns a read/write iterator that points one past the last -<span class="lineNum"> 548 </span> : * character in the %string. Unshares the string. -<span class="lineNum"> 549 </span> : */ -<span class="lineNum"> 550 </span> : iterator -<span class="lineNum"> 551 </span><span class="lineNoCov"> 0 : end()</span> -<span class="lineNum"> 552 </span> : { -<span class="lineNum"> 553 </span><span class="lineNoCov"> 0 : _M_leak();</span> -<span class="lineNum"> 554 </span><span class="lineNoCov"> 0 : return iterator(_M_data() + this->size());</span> -<span class="lineNum"> 555 </span> : } -<span class="lineNum"> 556 </span> : -<span class="lineNum"> 557 </span> : /** -<span class="lineNum"> 558 </span> : * Returns a read-only (constant) iterator that points one past the -<span class="lineNum"> 559 </span> : * last character in the %string. -<span class="lineNum"> 560 </span> : */ -<span class="lineNum"> 561 </span> : const_iterator -<span class="lineNum"> 562 </span><span class="lineNoCov"> 0 : end() const</span> -<span class="lineNum"> 563 </span><span class="lineNoCov"> 0 : { return const_iterator(_M_data() + this->size()); }</span> -<span class="lineNum"> 564 </span> : -<span class="lineNum"> 565 </span> : /** -<span class="lineNum"> 566 </span> : * Returns a read/write reverse iterator that points to the last -<span class="lineNum"> 567 </span> : * character in the %string. Iteration is done in reverse element -<span class="lineNum"> 568 </span> : * order. Unshares the string. -<span class="lineNum"> 569 </span> : */ -<span class="lineNum"> 570 </span> : reverse_iterator -<span class="lineNum"> 571 </span> : rbegin() -<span class="lineNum"> 572 </span> : { return reverse_iterator(this->end()); } -<span class="lineNum"> 573 </span> : -<span class="lineNum"> 574 </span> : /** -<span class="lineNum"> 575 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 576 </span> : * to the last character in the %string. Iteration is done in -<span class="lineNum"> 577 </span> : * reverse element order. -<span class="lineNum"> 578 </span> : */ -<span class="lineNum"> 579 </span> : const_reverse_iterator -<span class="lineNum"> 580 </span> : rbegin() const -<span class="lineNum"> 581 </span> : { return const_reverse_iterator(this->end()); } -<span class="lineNum"> 582 </span> : -<span class="lineNum"> 583 </span> : /** -<span class="lineNum"> 584 </span> : * Returns a read/write reverse iterator that points to one before the -<span class="lineNum"> 585 </span> : * first character in the %string. Iteration is done in reverse -<span class="lineNum"> 586 </span> : * element order. Unshares the string. -<span class="lineNum"> 587 </span> : */ -<span class="lineNum"> 588 </span> : reverse_iterator -<span class="lineNum"> 589 </span> : rend() -<span class="lineNum"> 590 </span> : { return reverse_iterator(this->begin()); } -<span class="lineNum"> 591 </span> : -<span class="lineNum"> 592 </span> : /** -<span class="lineNum"> 593 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 594 </span> : * to one before the first character in the %string. Iteration -<span class="lineNum"> 595 </span> : * is done in reverse element order. -<span class="lineNum"> 596 </span> : */ -<span class="lineNum"> 597 </span> : const_reverse_iterator -<span class="lineNum"> 598 </span> : rend() const -<span class="lineNum"> 599 </span> : { return const_reverse_iterator(this->begin()); } -<span class="lineNum"> 600 </span> : -<span class="lineNum"> 601 </span> : public: -<span class="lineNum"> 602 </span> : // Capacity: -<span class="lineNum"> 603 </span> : /// Returns the number of characters in the string, not including any -<span class="lineNum"> 604 </span> : /// null-termination. -<span class="lineNum"> 605 </span> : size_type -<span class="lineNum"> 606 </span><span class="lineNoCov"> 0 : size() const</span> -<span class="lineNum"> 607 </span><span class="lineNoCov"> 0 : { return _M_rep()->_M_length; }</span> -<span class="lineNum"> 608 </span> : -<span class="lineNum"> 609 </span> : /// Returns the number of characters in the string, not including any -<span class="lineNum"> 610 </span> : /// null-termination. -<span class="lineNum"> 611 </span> : size_type -<span class="lineNum"> 612 </span><span class="lineNoCov"> 0 : length() const</span> -<span class="lineNum"> 613 </span><span class="lineNoCov"> 0 : { return _M_rep()->_M_length; }</span> -<span class="lineNum"> 614 </span> : -<span class="lineNum"> 615 </span> : /// Returns the size() of the largest possible %string. -<span class="lineNum"> 616 </span> : size_type -<span class="lineNum"> 617 </span> : max_size() const -<span class="lineNum"> 618 </span> : { return _Rep::_S_max_size; } -<span class="lineNum"> 619 </span> : -<span class="lineNum"> 620 </span> : /** -<span class="lineNum"> 621 </span> : * @brief Resizes the %string to the specified number of characters. -<span class="lineNum"> 622 </span> : * @param n Number of characters the %string should contain. -<span class="lineNum"> 623 </span> : * @param c Character to fill any new elements. -<span class="lineNum"> 624 </span> : * -<span class="lineNum"> 625 </span> : * This function will %resize the %string to the specified -<span class="lineNum"> 626 </span> : * number of characters. If the number is smaller than the -<span class="lineNum"> 627 </span> : * %string's current size the %string is truncated, otherwise -<span class="lineNum"> 628 </span> : * the %string is extended and new elements are set to @a c. -<span class="lineNum"> 629 </span> : */ -<span class="lineNum"> 630 </span> : void -<span class="lineNum"> 631 </span> : resize(size_type __n, _CharT __c); -<span class="lineNum"> 632 </span> : -<span class="lineNum"> 633 </span> : /** -<span class="lineNum"> 634 </span> : * @brief Resizes the %string to the specified number of characters. -<span class="lineNum"> 635 </span> : * @param n Number of characters the %string should contain. -<span class="lineNum"> 636 </span> : * -<span class="lineNum"> 637 </span> : * This function will resize the %string to the specified length. If -<span class="lineNum"> 638 </span> : * the new size is smaller than the %string's current size the %string -<span class="lineNum"> 639 </span> : * is truncated, otherwise the %string is extended and new characters -<span class="lineNum"> 640 </span> : * are default-constructed. For basic types such as char, this means -<span class="lineNum"> 641 </span> : * setting them to 0. -<span class="lineNum"> 642 </span> : */ -<span class="lineNum"> 643 </span> : void -<span class="lineNum"> 644 </span><span class="lineNoCov"> 0 : resize(size_type __n)</span> -<span class="lineNum"> 645 </span><span class="lineNoCov"> 0 : { this->resize(__n, _CharT()); }</span> -<span class="lineNum"> 646 </span> : -<span class="lineNum"> 647 </span> : /** -<span class="lineNum"> 648 </span> : * Returns the total number of characters that the %string can hold -<span class="lineNum"> 649 </span> : * before needing to allocate more memory. -<span class="lineNum"> 650 </span> : */ -<span class="lineNum"> 651 </span> : size_type -<span class="lineNum"> 652 </span><span class="lineNoCov"> 0 : capacity() const</span> -<span class="lineNum"> 653 </span><span class="lineNoCov"> 0 : { return _M_rep()->_M_capacity; }</span> -<span class="lineNum"> 654 </span> : -<span class="lineNum"> 655 </span> : /** -<span class="lineNum"> 656 </span> : * @brief Attempt to preallocate enough memory for specified number of -<span class="lineNum"> 657 </span> : * characters. -<span class="lineNum"> 658 </span> : * @param res_arg Number of characters required. -<span class="lineNum"> 659 </span> : * @throw std::length_error If @a res_arg exceeds @c max_size(). -<span class="lineNum"> 660 </span> : * -<span class="lineNum"> 661 </span> : * This function attempts to reserve enough memory for the -<span class="lineNum"> 662 </span> : * %string to hold the specified number of characters. If the -<span class="lineNum"> 663 </span> : * number requested is more than max_size(), length_error is -<span class="lineNum"> 664 </span> : * thrown. -<span class="lineNum"> 665 </span> : * -<span class="lineNum"> 666 </span> : * The advantage of this function is that if optimal code is a -<span class="lineNum"> 667 </span> : * necessity and the user can determine the string length that will be -<span class="lineNum"> 668 </span> : * required, the user can reserve the memory in %advance, and thus -<span class="lineNum"> 669 </span> : * prevent a possible reallocation of memory and copying of %string -<span class="lineNum"> 670 </span> : * data. -<span class="lineNum"> 671 </span> : */ -<span class="lineNum"> 672 </span> : void -<span class="lineNum"> 673 </span> : reserve(size_type __res_arg = 0); -<span class="lineNum"> 674 </span> : -<span class="lineNum"> 675 </span> : /** -<span class="lineNum"> 676 </span> : * Erases the string, making it empty. -<span class="lineNum"> 677 </span> : */ -<span class="lineNum"> 678 </span> : void -<span class="lineNum"> 679 </span><span class="lineNoCov"> 0 : clear()</span> -<span class="lineNum"> 680 </span><span class="lineNoCov"> 0 : { _M_mutate(0, this->size(), 0); }</span> -<span class="lineNum"> 681 </span> : -<span class="lineNum"> 682 </span> : /** -<span class="lineNum"> 683 </span> : * Returns true if the %string is empty. Equivalent to *this == "". -<span class="lineNum"> 684 </span> : */ -<span class="lineNum"> 685 </span> : bool -<span class="lineNum"> 686 </span><span class="lineNoCov"> 0 : empty() const</span> -<span class="lineNum"> 687 </span><span class="lineNoCov"> 0 : { return this->size() == 0; }</span> -<span class="lineNum"> 688 </span> : -<span class="lineNum"> 689 </span> : // Element access: -<span class="lineNum"> 690 </span> : /** -<span class="lineNum"> 691 </span> : * @brief Subscript access to the data contained in the %string. -<span class="lineNum"> 692 </span> : * @param pos The index of the character to access. -<span class="lineNum"> 693 </span> : * @return Read-only (constant) reference to the character. -<span class="lineNum"> 694 </span> : * -<span class="lineNum"> 695 </span> : * This operator allows for easy, array-style, data access. -<span class="lineNum"> 696 </span> : * Note that data access with this operator is unchecked and -<span class="lineNum"> 697 </span> : * out_of_range lookups are not defined. (For checked lookups -<span class="lineNum"> 698 </span> : * see at().) -<span class="lineNum"> 699 </span> : */ -<span class="lineNum"> 700 </span> : const_reference -<span class="lineNum"> 701 </span><span class="lineNoCov"> 0 : operator[] (size_type __pos) const</span> -<span class="lineNum"> 702 </span> : { -<span class="lineNum"> 703 </span> : _GLIBCXX_DEBUG_ASSERT(__pos <= size()); -<span class="lineNum"> 704 </span><span class="lineNoCov"> 0 : return _M_data()[__pos];</span> -<span class="lineNum"> 705 </span> : } -<span class="lineNum"> 706 </span> : -<span class="lineNum"> 707 </span> : /** -<span class="lineNum"> 708 </span> : * @brief Subscript access to the data contained in the %string. -<span class="lineNum"> 709 </span> : * @param pos The index of the character to access. -<span class="lineNum"> 710 </span> : * @return Read/write reference to the character. -<span class="lineNum"> 711 </span> : * -<span class="lineNum"> 712 </span> : * This operator allows for easy, array-style, data access. -<span class="lineNum"> 713 </span> : * Note that data access with this operator is unchecked and -<span class="lineNum"> 714 </span> : * out_of_range lookups are not defined. (For checked lookups -<span class="lineNum"> 715 </span> : * see at().) Unshares the string. -<span class="lineNum"> 716 </span> : */ -<span class="lineNum"> 717 </span> : reference -<span class="lineNum"> 718 </span><span class="lineNoCov"> 0 : operator[](size_type __pos)</span> -<span class="lineNum"> 719 </span> : { -<span class="lineNum"> 720 </span> : // allow pos == size() as v3 extension: -<span class="lineNum"> 721 </span> : _GLIBCXX_DEBUG_ASSERT(__pos <= size()); -<span class="lineNum"> 722 </span> : // but be strict in pedantic mode: -<span class="lineNum"> 723 </span> : _GLIBCXX_DEBUG_PEDASSERT(__pos < size()); -<span class="lineNum"> 724 </span><span class="lineNoCov"> 0 : _M_leak();</span> -<span class="lineNum"> 725 </span><span class="lineNoCov"> 0 : return _M_data()[__pos];</span> -<span class="lineNum"> 726 </span> : } -<span class="lineNum"> 727 </span> : -<span class="lineNum"> 728 </span> : /** -<span class="lineNum"> 729 </span> : * @brief Provides access to the data contained in the %string. -<span class="lineNum"> 730 </span> : * @param n The index of the character to access. -<span class="lineNum"> 731 </span> : * @return Read-only (const) reference to the character. -<span class="lineNum"> 732 </span> : * @throw std::out_of_range If @a n is an invalid index. -<span class="lineNum"> 733 </span> : * -<span class="lineNum"> 734 </span> : * This function provides for safer data access. The parameter is -<span class="lineNum"> 735 </span> : * first checked that it is in the range of the string. The function -<span class="lineNum"> 736 </span> : * throws out_of_range if the check fails. -<span class="lineNum"> 737 </span> : */ -<span class="lineNum"> 738 </span> : const_reference -<span class="lineNum"> 739 </span> : at(size_type __n) const -<span class="lineNum"> 740 </span> : { -<span class="lineNum"> 741 </span> : if (__n >= this->size()) -<span class="lineNum"> 742 </span> : __throw_out_of_range(__N("basic_string::at")); -<span class="lineNum"> 743 </span> : return _M_data()[__n]; -<span class="lineNum"> 744 </span> : } -<span class="lineNum"> 745 </span> : -<span class="lineNum"> 746 </span> : /** -<span class="lineNum"> 747 </span> : * @brief Provides access to the data contained in the %string. -<span class="lineNum"> 748 </span> : * @param n The index of the character to access. -<span class="lineNum"> 749 </span> : * @return Read/write reference to the character. -<span class="lineNum"> 750 </span> : * @throw std::out_of_range If @a n is an invalid index. -<span class="lineNum"> 751 </span> : * -<span class="lineNum"> 752 </span> : * This function provides for safer data access. The parameter is -<span class="lineNum"> 753 </span> : * first checked that it is in the range of the string. The function -<span class="lineNum"> 754 </span> : * throws out_of_range if the check fails. Success results in -<span class="lineNum"> 755 </span> : * unsharing the string. -<span class="lineNum"> 756 </span> : */ -<span class="lineNum"> 757 </span> : reference -<span class="lineNum"> 758 </span> : at(size_type __n) -<span class="lineNum"> 759 </span> : { -<span class="lineNum"> 760 </span> : if (__n >= size()) -<span class="lineNum"> 761 </span> : __throw_out_of_range(__N("basic_string::at")); -<span class="lineNum"> 762 </span> : _M_leak(); -<span class="lineNum"> 763 </span> : return _M_data()[__n]; -<span class="lineNum"> 764 </span> : } -<span class="lineNum"> 765 </span> : -<span class="lineNum"> 766 </span> : // Modifiers: -<span class="lineNum"> 767 </span> : /** -<span class="lineNum"> 768 </span> : * @brief Append a string to this string. -<span class="lineNum"> 769 </span> : * @param str The string to append. -<span class="lineNum"> 770 </span> : * @return Reference to this string. -<span class="lineNum"> 771 </span> : */ -<span class="lineNum"> 772 </span> : basic_string& -<span class="lineNum"> 773 </span><span class="lineNoCov"> 0 : operator+=(const basic_string& __str)</span> -<span class="lineNum"> 774 </span><span class="lineNoCov"> 0 : { return this->append(__str); }</span> -<span class="lineNum"> 775 </span> : -<span class="lineNum"> 776 </span> : /** -<span class="lineNum"> 777 </span> : * @brief Append a C string. -<span class="lineNum"> 778 </span> : * @param s The C string to append. -<span class="lineNum"> 779 </span> : * @return Reference to this string. -<span class="lineNum"> 780 </span> : */ -<span class="lineNum"> 781 </span> : basic_string& -<span class="lineNum"> 782 </span><span class="lineNoCov"> 0 : operator+=(const _CharT* __s)</span> -<span class="lineNum"> 783 </span><span class="lineNoCov"> 0 : { return this->append(__s); }</span> -<span class="lineNum"> 784 </span> : -<span class="lineNum"> 785 </span> : /** -<span class="lineNum"> 786 </span> : * @brief Append a character. -<span class="lineNum"> 787 </span> : * @param c The character to append. -<span class="lineNum"> 788 </span> : * @return Reference to this string. -<span class="lineNum"> 789 </span> : */ -<span class="lineNum"> 790 </span> : basic_string& -<span class="lineNum"> 791 </span><span class="lineNoCov"> 0 : operator+=(_CharT __c)</span> -<span class="lineNum"> 792 </span> : { -<span class="lineNum"> 793 </span><span class="lineNoCov"> 0 : this->push_back(__c);</span> -<span class="lineNum"> 794 </span><span class="lineNoCov"> 0 : return *this;</span> -<span class="lineNum"> 795 </span> : } -<span class="lineNum"> 796 </span> : -<span class="lineNum"> 797 </span> : /** -<span class="lineNum"> 798 </span> : * @brief Append a string to this string. -<span class="lineNum"> 799 </span> : * @param str The string to append. -<span class="lineNum"> 800 </span> : * @return Reference to this string. -<span class="lineNum"> 801 </span> : */ -<span class="lineNum"> 802 </span> : basic_string& -<span class="lineNum"> 803 </span> : append(const basic_string& __str); -<span class="lineNum"> 804 </span> : -<span class="lineNum"> 805 </span> : /** -<span class="lineNum"> 806 </span> : * @brief Append a substring. -<span class="lineNum"> 807 </span> : * @param str The string to append. -<span class="lineNum"> 808 </span> : * @param pos Index of the first character of str to append. -<span class="lineNum"> 809 </span> : * @param n The number of characters to append. -<span class="lineNum"> 810 </span> : * @return Reference to this string. -<span class="lineNum"> 811 </span> : * @throw std::out_of_range if @a pos is not a valid index. -<span class="lineNum"> 812 </span> : * -<span class="lineNum"> 813 </span> : * This function appends @a n characters from @a str starting at @a pos -<span class="lineNum"> 814 </span> : * to this string. If @a n is is larger than the number of available -<span class="lineNum"> 815 </span> : * characters in @a str, the remainder of @a str is appended. -<span class="lineNum"> 816 </span> : */ -<span class="lineNum"> 817 </span> : basic_string& -<span class="lineNum"> 818 </span> : append(const basic_string& __str, size_type __pos, size_type __n); -<span class="lineNum"> 819 </span> : -<span class="lineNum"> 820 </span> : /** -<span class="lineNum"> 821 </span> : * @brief Append a C substring. -<span class="lineNum"> 822 </span> : * @param s The C string to append. -<span class="lineNum"> 823 </span> : * @param n The number of characters to append. -<span class="lineNum"> 824 </span> : * @return Reference to this string. -<span class="lineNum"> 825 </span> : */ -<span class="lineNum"> 826 </span> : basic_string& -<span class="lineNum"> 827 </span> : append(const _CharT* __s, size_type __n); -<span class="lineNum"> 828 </span> : -<span class="lineNum"> 829 </span> : /** -<span class="lineNum"> 830 </span> : * @brief Append a C string. -<span class="lineNum"> 831 </span> : * @param s The C string to append. -<span class="lineNum"> 832 </span> : * @return Reference to this string. -<span class="lineNum"> 833 </span> : */ -<span class="lineNum"> 834 </span> : basic_string& -<span class="lineNum"> 835 </span><span class="lineNoCov"> 0 : append(const _CharT* __s)</span> -<span class="lineNum"> 836 </span> : { -<span class="lineNum"> 837 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 838 </span><span class="lineNoCov"> 0 : return this->append(__s, traits_type::length(__s));</span> -<span class="lineNum"> 839 </span> : } -<span class="lineNum"> 840 </span> : -<span class="lineNum"> 841 </span> : /** -<span class="lineNum"> 842 </span> : * @brief Append multiple characters. -<span class="lineNum"> 843 </span> : * @param n The number of characters to append. -<span class="lineNum"> 844 </span> : * @param c The character to use. -<span class="lineNum"> 845 </span> : * @return Reference to this string. -<span class="lineNum"> 846 </span> : * -<span class="lineNum"> 847 </span> : * Appends n copies of c to this string. -<span class="lineNum"> 848 </span> : */ -<span class="lineNum"> 849 </span> : basic_string& -<span class="lineNum"> 850 </span> : append(size_type __n, _CharT __c); -<span class="lineNum"> 851 </span> : -<span class="lineNum"> 852 </span> : /** -<span class="lineNum"> 853 </span> : * @brief Append a range of characters. -<span class="lineNum"> 854 </span> : * @param first Iterator referencing the first character to append. -<span class="lineNum"> 855 </span> : * @param last Iterator marking the end of the range. -<span class="lineNum"> 856 </span> : * @return Reference to this string. -<span class="lineNum"> 857 </span> : * -<span class="lineNum"> 858 </span> : * Appends characters in the range [first,last) to this string. -<span class="lineNum"> 859 </span> : */ -<span class="lineNum"> 860 </span> : template<class _InputIterator> -<span class="lineNum"> 861 </span> : basic_string& -<span class="lineNum"> 862 </span> : append(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 863 </span> : { return this->replace(_M_iend(), _M_iend(), __first, __last); } -<span class="lineNum"> 864 </span> : -<span class="lineNum"> 865 </span> : /** -<span class="lineNum"> 866 </span> : * @brief Append a single character. -<span class="lineNum"> 867 </span> : * @param c Character to append. -<span class="lineNum"> 868 </span> : */ -<span class="lineNum"> 869 </span> : void -<span class="lineNum"> 870 </span><span class="lineNoCov"> 0 : push_back(_CharT __c)</span> -<span class="lineNum"> 871 </span> : { -<span class="lineNum"> 872 </span><span class="lineNoCov"> 0 : const size_type __len = 1 + this->size();</span> -<span class="lineNum"> 873 </span><span class="lineNoCov"> 0 : if (__len > this->capacity() || _M_rep()->_M_is_shared())</span> -<span class="lineNum"> 874 </span><span class="lineNoCov"> 0 : this->reserve(__len);</span> -<span class="lineNum"> 875 </span><span class="lineNoCov"> 0 : traits_type::assign(_M_data()[this->size()], __c);</span> -<span class="lineNum"> 876 </span><span class="lineNoCov"> 0 : _M_rep()->_M_set_length_and_sharable(__len);</span> -<span class="lineNum"> 877 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 878 </span> : -<span class="lineNum"> 879 </span> : /** -<span class="lineNum"> 880 </span> : * @brief Set value to contents of another string. -<span class="lineNum"> 881 </span> : * @param str Source string to use. -<span class="lineNum"> 882 </span> : * @return Reference to this string. -<span class="lineNum"> 883 </span> : */ -<span class="lineNum"> 884 </span> : basic_string& -<span class="lineNum"> 885 </span> : assign(const basic_string& __str); -<span class="lineNum"> 886 </span> : -<span class="lineNum"> 887 </span> : /** -<span class="lineNum"> 888 </span> : * @brief Set value to a substring of a string. -<span class="lineNum"> 889 </span> : * @param str The string to use. -<span class="lineNum"> 890 </span> : * @param pos Index of the first character of str. -<span class="lineNum"> 891 </span> : * @param n Number of characters to use. -<span class="lineNum"> 892 </span> : * @return Reference to this string. -<span class="lineNum"> 893 </span> : * @throw std::out_of_range if @a pos is not a valid index. -<span class="lineNum"> 894 </span> : * -<span class="lineNum"> 895 </span> : * This function sets this string to the substring of @a str consisting -<span class="lineNum"> 896 </span> : * of @a n characters at @a pos. If @a n is is larger than the number -<span class="lineNum"> 897 </span> : * of available characters in @a str, the remainder of @a str is used. -<span class="lineNum"> 898 </span> : */ -<span class="lineNum"> 899 </span> : basic_string& -<span class="lineNum"> 900 </span> : assign(const basic_string& __str, size_type __pos, size_type __n) -<span class="lineNum"> 901 </span> : { return this->assign(__str._M_data() -<span class="lineNum"> 902 </span> : + __str._M_check(__pos, "basic_string::assign"), -<span class="lineNum"> 903 </span> : __str._M_limit(__pos, __n)); } -<span class="lineNum"> 904 </span> : -<span class="lineNum"> 905 </span> : /** -<span class="lineNum"> 906 </span> : * @brief Set value to a C substring. -<span class="lineNum"> 907 </span> : * @param s The C string to use. -<span class="lineNum"> 908 </span> : * @param n Number of characters to use. -<span class="lineNum"> 909 </span> : * @return Reference to this string. -<span class="lineNum"> 910 </span> : * -<span class="lineNum"> 911 </span> : * This function sets the value of this string to the first @a n -<span class="lineNum"> 912 </span> : * characters of @a s. If @a n is is larger than the number of -<span class="lineNum"> 913 </span> : * available characters in @a s, the remainder of @a s is used. -<span class="lineNum"> 914 </span> : */ -<span class="lineNum"> 915 </span> : basic_string& -<span class="lineNum"> 916 </span> : assign(const _CharT* __s, size_type __n); -<span class="lineNum"> 917 </span> : -<span class="lineNum"> 918 </span> : /** -<span class="lineNum"> 919 </span> : * @brief Set value to contents of a C string. -<span class="lineNum"> 920 </span> : * @param s The C string to use. -<span class="lineNum"> 921 </span> : * @return Reference to this string. -<span class="lineNum"> 922 </span> : * -<span class="lineNum"> 923 </span> : * This function sets the value of this string to the value of @a s. -<span class="lineNum"> 924 </span> : * The data is copied, so there is no dependence on @a s once the -<span class="lineNum"> 925 </span> : * function returns. -<span class="lineNum"> 926 </span> : */ -<span class="lineNum"> 927 </span> : basic_string& -<span class="lineNum"> 928 </span><span class="lineNoCov"> 0 : assign(const _CharT* __s)</span> -<span class="lineNum"> 929 </span> : { -<span class="lineNum"> 930 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 931 </span><span class="lineNoCov"> 0 : return this->assign(__s, traits_type::length(__s));</span> -<span class="lineNum"> 932 </span> : } -<span class="lineNum"> 933 </span> : -<span class="lineNum"> 934 </span> : /** -<span class="lineNum"> 935 </span> : * @brief Set value to multiple characters. -<span class="lineNum"> 936 </span> : * @param n Length of the resulting string. -<span class="lineNum"> 937 </span> : * @param c The character to use. -<span class="lineNum"> 938 </span> : * @return Reference to this string. -<span class="lineNum"> 939 </span> : * -<span class="lineNum"> 940 </span> : * This function sets the value of this string to @a n copies of -<span class="lineNum"> 941 </span> : * character @a c. -<span class="lineNum"> 942 </span> : */ -<span class="lineNum"> 943 </span> : basic_string& -<span class="lineNum"> 944 </span> : assign(size_type __n, _CharT __c) -<span class="lineNum"> 945 </span> : { return _M_replace_aux(size_type(0), this->size(), __n, __c); } -<span class="lineNum"> 946 </span> : -<span class="lineNum"> 947 </span> : /** -<span class="lineNum"> 948 </span> : * @brief Set value to a range of characters. -<span class="lineNum"> 949 </span> : * @param first Iterator referencing the first character to append. -<span class="lineNum"> 950 </span> : * @param last Iterator marking the end of the range. -<span class="lineNum"> 951 </span> : * @return Reference to this string. -<span class="lineNum"> 952 </span> : * -<span class="lineNum"> 953 </span> : * Sets value of string to characters in the range [first,last). -<span class="lineNum"> 954 </span> : */ -<span class="lineNum"> 955 </span> : template<class _InputIterator> -<span class="lineNum"> 956 </span> : basic_string& -<span class="lineNum"> 957 </span> : assign(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 958 </span> : { return this->replace(_M_ibegin(), _M_iend(), __first, __last); } -<span class="lineNum"> 959 </span> : -<span class="lineNum"> 960 </span> : /** -<span class="lineNum"> 961 </span> : * @brief Insert multiple characters. -<span class="lineNum"> 962 </span> : * @param p Iterator referencing location in string to insert at. -<span class="lineNum"> 963 </span> : * @param n Number of characters to insert -<span class="lineNum"> 964 </span> : * @param c The character to insert. -<span class="lineNum"> 965 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 966 </span> : * -<span class="lineNum"> 967 </span> : * Inserts @a n copies of character @a c starting at the position -<span class="lineNum"> 968 </span> : * referenced by iterator @a p. If adding characters causes the length -<span class="lineNum"> 969 </span> : * to exceed max_size(), length_error is thrown. The value of the -<span class="lineNum"> 970 </span> : * string doesn't change if an error is thrown. -<span class="lineNum"> 971 </span> : */ -<span class="lineNum"> 972 </span> : void -<span class="lineNum"> 973 </span> : insert(iterator __p, size_type __n, _CharT __c) -<span class="lineNum"> 974 </span> : { this->replace(__p, __p, __n, __c); } -<span class="lineNum"> 975 </span> : -<span class="lineNum"> 976 </span> : /** -<span class="lineNum"> 977 </span> : * @brief Insert a range of characters. -<span class="lineNum"> 978 </span> : * @param p Iterator referencing location in string to insert at. -<span class="lineNum"> 979 </span> : * @param beg Start of range. -<span class="lineNum"> 980 </span> : * @param end End of range. -<span class="lineNum"> 981 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 982 </span> : * -<span class="lineNum"> 983 </span> : * Inserts characters in range [beg,end). If adding characters causes -<span class="lineNum"> 984 </span> : * the length to exceed max_size(), length_error is thrown. The value -<span class="lineNum"> 985 </span> : * of the string doesn't change if an error is thrown. -<span class="lineNum"> 986 </span> : */ -<span class="lineNum"> 987 </span> : template<class _InputIterator> -<span class="lineNum"> 988 </span> : void -<span class="lineNum"> 989 </span> : insert(iterator __p, _InputIterator __beg, _InputIterator __end) -<span class="lineNum"> 990 </span> : { this->replace(__p, __p, __beg, __end); } -<span class="lineNum"> 991 </span> : -<span class="lineNum"> 992 </span> : /** -<span class="lineNum"> 993 </span> : * @brief Insert value of a string. -<span class="lineNum"> 994 </span> : * @param pos1 Iterator referencing location in string to insert at. -<span class="lineNum"> 995 </span> : * @param str The string to insert. -<span class="lineNum"> 996 </span> : * @return Reference to this string. -<span class="lineNum"> 997 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 998 </span> : * -<span class="lineNum"> 999 </span> : * Inserts value of @a str starting at @a pos1. If adding characters -<span class="lineNum"> 1000 </span> : * causes the length to exceed max_size(), length_error is thrown. The -<span class="lineNum"> 1001 </span> : * value of the string doesn't change if an error is thrown. -<span class="lineNum"> 1002 </span> : */ -<span class="lineNum"> 1003 </span> : basic_string& -<span class="lineNum"> 1004 </span> : insert(size_type __pos1, const basic_string& __str) -<span class="lineNum"> 1005 </span> : { return this->insert(__pos1, __str, size_type(0), __str.size()); } -<span class="lineNum"> 1006 </span> : -<span class="lineNum"> 1007 </span> : /** -<span class="lineNum"> 1008 </span> : * @brief Insert a substring. -<span class="lineNum"> 1009 </span> : * @param pos1 Iterator referencing location in string to insert at. -<span class="lineNum"> 1010 </span> : * @param str The string to insert. -<span class="lineNum"> 1011 </span> : * @param pos2 Start of characters in str to insert. -<span class="lineNum"> 1012 </span> : * @param n Number of characters to insert. -<span class="lineNum"> 1013 </span> : * @return Reference to this string. -<span class="lineNum"> 1014 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1015 </span> : * @throw std::out_of_range If @a pos1 > size() or -<span class="lineNum"> 1016 </span> : * @a pos2 > @a str.size(). -<span class="lineNum"> 1017 </span> : * -<span class="lineNum"> 1018 </span> : * Starting at @a pos1, insert @a n character of @a str beginning with -<span class="lineNum"> 1019 </span> : * @a pos2. If adding characters causes the length to exceed -<span class="lineNum"> 1020 </span> : * max_size(), length_error is thrown. If @a pos1 is beyond the end of -<span class="lineNum"> 1021 </span> : * this string or @a pos2 is beyond the end of @a str, out_of_range is -<span class="lineNum"> 1022 </span> : * thrown. The value of the string doesn't change if an error is -<span class="lineNum"> 1023 </span> : * thrown. -<span class="lineNum"> 1024 </span> : */ -<span class="lineNum"> 1025 </span> : basic_string& -<span class="lineNum"> 1026 </span> : insert(size_type __pos1, const basic_string& __str, -<span class="lineNum"> 1027 </span> : size_type __pos2, size_type __n) -<span class="lineNum"> 1028 </span> : { return this->insert(__pos1, __str._M_data() -<span class="lineNum"> 1029 </span> : + __str._M_check(__pos2, "basic_string::insert"), -<span class="lineNum"> 1030 </span> : __str._M_limit(__pos2, __n)); } -<span class="lineNum"> 1031 </span> : -<span class="lineNum"> 1032 </span> : /** -<span class="lineNum"> 1033 </span> : * @brief Insert a C substring. -<span class="lineNum"> 1034 </span> : * @param pos Iterator referencing location in string to insert at. -<span class="lineNum"> 1035 </span> : * @param s The C string to insert. -<span class="lineNum"> 1036 </span> : * @param n The number of characters to insert. -<span class="lineNum"> 1037 </span> : * @return Reference to this string. -<span class="lineNum"> 1038 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1039 </span> : * @throw std::out_of_range If @a pos is beyond the end of this -<span class="lineNum"> 1040 </span> : * string. -<span class="lineNum"> 1041 </span> : * -<span class="lineNum"> 1042 </span> : * Inserts the first @a n characters of @a s starting at @a pos. If -<span class="lineNum"> 1043 </span> : * adding characters causes the length to exceed max_size(), -<span class="lineNum"> 1044 </span> : * length_error is thrown. If @a pos is beyond end(), out_of_range is -<span class="lineNum"> 1045 </span> : * thrown. The value of the string doesn't change if an error is -<span class="lineNum"> 1046 </span> : * thrown. -<span class="lineNum"> 1047 </span> : */ -<span class="lineNum"> 1048 </span> : basic_string& -<span class="lineNum"> 1049 </span> : insert(size_type __pos, const _CharT* __s, size_type __n); -<span class="lineNum"> 1050 </span> : -<span class="lineNum"> 1051 </span> : /** -<span class="lineNum"> 1052 </span> : * @brief Insert a C string. -<span class="lineNum"> 1053 </span> : * @param pos Iterator referencing location in string to insert at. -<span class="lineNum"> 1054 </span> : * @param s The C string to insert. -<span class="lineNum"> 1055 </span> : * @return Reference to this string. -<span class="lineNum"> 1056 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1057 </span> : * @throw std::out_of_range If @a pos is beyond the end of this -<span class="lineNum"> 1058 </span> : * string. -<span class="lineNum"> 1059 </span> : * -<span class="lineNum"> 1060 </span> : * Inserts the first @a n characters of @a s starting at @a pos. If -<span class="lineNum"> 1061 </span> : * adding characters causes the length to exceed max_size(), -<span class="lineNum"> 1062 </span> : * length_error is thrown. If @a pos is beyond end(), out_of_range is -<span class="lineNum"> 1063 </span> : * thrown. The value of the string doesn't change if an error is -<span class="lineNum"> 1064 </span> : * thrown. -<span class="lineNum"> 1065 </span> : */ -<span class="lineNum"> 1066 </span> : basic_string& -<span class="lineNum"> 1067 </span> : insert(size_type __pos, const _CharT* __s) -<span class="lineNum"> 1068 </span> : { -<span class="lineNum"> 1069 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1070 </span> : return this->insert(__pos, __s, traits_type::length(__s)); -<span class="lineNum"> 1071 </span> : } -<span class="lineNum"> 1072 </span> : -<span class="lineNum"> 1073 </span> : /** -<span class="lineNum"> 1074 </span> : * @brief Insert multiple characters. -<span class="lineNum"> 1075 </span> : * @param pos Index in string to insert at. -<span class="lineNum"> 1076 </span> : * @param n Number of characters to insert -<span class="lineNum"> 1077 </span> : * @param c The character to insert. -<span class="lineNum"> 1078 </span> : * @return Reference to this string. -<span class="lineNum"> 1079 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1080 </span> : * @throw std::out_of_range If @a pos is beyond the end of this -<span class="lineNum"> 1081 </span> : * string. -<span class="lineNum"> 1082 </span> : * -<span class="lineNum"> 1083 </span> : * Inserts @a n copies of character @a c starting at index @a pos. If -<span class="lineNum"> 1084 </span> : * adding characters causes the length to exceed max_size(), -<span class="lineNum"> 1085 </span> : * length_error is thrown. If @a pos > length(), out_of_range is -<span class="lineNum"> 1086 </span> : * thrown. The value of the string doesn't change if an error is -<span class="lineNum"> 1087 </span> : * thrown. -<span class="lineNum"> 1088 </span> : */ -<span class="lineNum"> 1089 </span> : basic_string& -<span class="lineNum"> 1090 </span> : insert(size_type __pos, size_type __n, _CharT __c) -<span class="lineNum"> 1091 </span> : { return _M_replace_aux(_M_check(__pos, "basic_string::insert"), -<span class="lineNum"> 1092 </span> : size_type(0), __n, __c); } -<span class="lineNum"> 1093 </span> : -<span class="lineNum"> 1094 </span> : /** -<span class="lineNum"> 1095 </span> : * @brief Insert one character. -<span class="lineNum"> 1096 </span> : * @param p Iterator referencing position in string to insert at. -<span class="lineNum"> 1097 </span> : * @param c The character to insert. -<span class="lineNum"> 1098 </span> : * @return Iterator referencing newly inserted char. -<span class="lineNum"> 1099 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1100 </span> : * -<span class="lineNum"> 1101 </span> : * Inserts character @a c at position referenced by @a p. If adding -<span class="lineNum"> 1102 </span> : * character causes the length to exceed max_size(), length_error is -<span class="lineNum"> 1103 </span> : * thrown. If @a p is beyond end of string, out_of_range is thrown. -<span class="lineNum"> 1104 </span> : * The value of the string doesn't change if an error is thrown. -<span class="lineNum"> 1105 </span> : */ -<span class="lineNum"> 1106 </span> : iterator -<span class="lineNum"> 1107 </span> : insert(iterator __p, _CharT __c) -<span class="lineNum"> 1108 </span> : { -<span class="lineNum"> 1109 </span> : _GLIBCXX_DEBUG_PEDASSERT(__p >= _M_ibegin() && __p <= _M_iend()); -<span class="lineNum"> 1110 </span> : const size_type __pos = __p - _M_ibegin(); -<span class="lineNum"> 1111 </span> : _M_replace_aux(__pos, size_type(0), size_type(1), __c); -<span class="lineNum"> 1112 </span> : _M_rep()->_M_set_leaked(); -<span class="lineNum"> 1113 </span> : return iterator(_M_data() + __pos); -<span class="lineNum"> 1114 </span> : } -<span class="lineNum"> 1115 </span> : -<span class="lineNum"> 1116 </span> : /** -<span class="lineNum"> 1117 </span> : * @brief Remove characters. -<span class="lineNum"> 1118 </span> : * @param pos Index of first character to remove (default 0). -<span class="lineNum"> 1119 </span> : * @param n Number of characters to remove (default remainder). -<span class="lineNum"> 1120 </span> : * @return Reference to this string. -<span class="lineNum"> 1121 </span> : * @throw std::out_of_range If @a pos is beyond the end of this -<span class="lineNum"> 1122 </span> : * string. -<span class="lineNum"> 1123 </span> : * -<span class="lineNum"> 1124 </span> : * Removes @a n characters from this string starting at @a pos. The -<span class="lineNum"> 1125 </span> : * length of the string is reduced by @a n. If there are < @a n -<span class="lineNum"> 1126 </span> : * characters to remove, the remainder of the string is truncated. If -<span class="lineNum"> 1127 </span> : * @a p is beyond end of string, out_of_range is thrown. The value of -<span class="lineNum"> 1128 </span> : * the string doesn't change if an error is thrown. -<span class="lineNum"> 1129 </span> : */ -<span class="lineNum"> 1130 </span> : basic_string& -<span class="lineNum"> 1131 </span> : erase(size_type __pos = 0, size_type __n = npos) -<span class="lineNum"> 1132 </span> : { -<span class="lineNum"> 1133 </span> : _M_mutate(_M_check(__pos, "basic_string::erase"), -<span class="lineNum"> 1134 </span> : _M_limit(__pos, __n), size_type(0)); -<span class="lineNum"> 1135 </span> : return *this; -<span class="lineNum"> 1136 </span> : } -<span class="lineNum"> 1137 </span> : -<span class="lineNum"> 1138 </span> : /** -<span class="lineNum"> 1139 </span> : * @brief Remove one character. -<span class="lineNum"> 1140 </span> : * @param position Iterator referencing the character to remove. -<span class="lineNum"> 1141 </span> : * @return iterator referencing same location after removal. -<span class="lineNum"> 1142 </span> : * -<span class="lineNum"> 1143 </span> : * Removes the character at @a position from this string. The value -<span class="lineNum"> 1144 </span> : * of the string doesn't change if an error is thrown. -<span class="lineNum"> 1145 </span> : */ -<span class="lineNum"> 1146 </span> : iterator -<span class="lineNum"> 1147 </span><span class="lineNoCov"> 0 : erase(iterator __position)</span> -<span class="lineNum"> 1148 </span> : { -<span class="lineNum"> 1149 </span> : _GLIBCXX_DEBUG_PEDASSERT(__position >= _M_ibegin() -<span class="lineNum"> 1150 </span> : && __position < _M_iend()); -<span class="lineNum"> 1151 </span><span class="lineNoCov"> 0 : const size_type __pos = __position - _M_ibegin();</span> -<span class="lineNum"> 1152 </span><span class="lineNoCov"> 0 : _M_mutate(__pos, size_type(1), size_type(0));</span> -<span class="lineNum"> 1153 </span><span class="lineNoCov"> 0 : _M_rep()->_M_set_leaked();</span> -<span class="lineNum"> 1154 </span><span class="lineNoCov"> 0 : return iterator(_M_data() + __pos);</span> -<span class="lineNum"> 1155 </span> : } -<span class="lineNum"> 1156 </span> : -<span class="lineNum"> 1157 </span> : /** -<span class="lineNum"> 1158 </span> : * @brief Remove a range of characters. -<span class="lineNum"> 1159 </span> : * @param first Iterator referencing the first character to remove. -<span class="lineNum"> 1160 </span> : * @param last Iterator referencing the end of the range. -<span class="lineNum"> 1161 </span> : * @return Iterator referencing location of first after removal. -<span class="lineNum"> 1162 </span> : * -<span class="lineNum"> 1163 </span> : * Removes the characters in the range [first,last) from this string. -<span class="lineNum"> 1164 </span> : * The value of the string doesn't change if an error is thrown. -<span class="lineNum"> 1165 </span> : */ -<span class="lineNum"> 1166 </span> : iterator -<span class="lineNum"> 1167 </span> : erase(iterator __first, iterator __last) -<span class="lineNum"> 1168 </span> : { -<span class="lineNum"> 1169 </span> : _GLIBCXX_DEBUG_PEDASSERT(__first >= _M_ibegin() && __first <= __last -<span class="lineNum"> 1170 </span> : && __last <= _M_iend()); -<span class="lineNum"> 1171 </span> : const size_type __pos = __first - _M_ibegin(); -<span class="lineNum"> 1172 </span> : _M_mutate(__pos, __last - __first, size_type(0)); -<span class="lineNum"> 1173 </span> : _M_rep()->_M_set_leaked(); -<span class="lineNum"> 1174 </span> : return iterator(_M_data() + __pos); -<span class="lineNum"> 1175 </span> : } -<span class="lineNum"> 1176 </span> : -<span class="lineNum"> 1177 </span> : /** -<span class="lineNum"> 1178 </span> : * @brief Replace characters with value from another string. -<span class="lineNum"> 1179 </span> : * @param pos Index of first character to replace. -<span class="lineNum"> 1180 </span> : * @param n Number of characters to be replaced. -<span class="lineNum"> 1181 </span> : * @param str String to insert. -<span class="lineNum"> 1182 </span> : * @return Reference to this string. -<span class="lineNum"> 1183 </span> : * @throw std::out_of_range If @a pos is beyond the end of this -<span class="lineNum"> 1184 </span> : * string. -<span class="lineNum"> 1185 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1186 </span> : * -<span class="lineNum"> 1187 </span> : * Removes the characters in the range [pos,pos+n) from this string. -<span class="lineNum"> 1188 </span> : * In place, the value of @a str is inserted. If @a pos is beyond end -<span class="lineNum"> 1189 </span> : * of string, out_of_range is thrown. If the length of the result -<span class="lineNum"> 1190 </span> : * exceeds max_size(), length_error is thrown. The value of the string -<span class="lineNum"> 1191 </span> : * doesn't change if an error is thrown. -<span class="lineNum"> 1192 </span> : */ -<span class="lineNum"> 1193 </span> : basic_string& -<span class="lineNum"> 1194 </span> : replace(size_type __pos, size_type __n, const basic_string& __str) -<span class="lineNum"> 1195 </span> : { return this->replace(__pos, __n, __str._M_data(), __str.size()); } -<span class="lineNum"> 1196 </span> : -<span class="lineNum"> 1197 </span> : /** -<span class="lineNum"> 1198 </span> : * @brief Replace characters with value from another string. -<span class="lineNum"> 1199 </span> : * @param pos1 Index of first character to replace. -<span class="lineNum"> 1200 </span> : * @param n1 Number of characters to be replaced. -<span class="lineNum"> 1201 </span> : * @param str String to insert. -<span class="lineNum"> 1202 </span> : * @param pos2 Index of first character of str to use. -<span class="lineNum"> 1203 </span> : * @param n2 Number of characters from str to use. -<span class="lineNum"> 1204 </span> : * @return Reference to this string. -<span class="lineNum"> 1205 </span> : * @throw std::out_of_range If @a pos1 > size() or @a pos2 > -<span class="lineNum"> 1206 </span> : * str.size(). -<span class="lineNum"> 1207 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1208 </span> : * -<span class="lineNum"> 1209 </span> : * Removes the characters in the range [pos1,pos1 + n) from this -<span class="lineNum"> 1210 </span> : * string. In place, the value of @a str is inserted. If @a pos is -<span class="lineNum"> 1211 </span> : * beyond end of string, out_of_range is thrown. If the length of the -<span class="lineNum"> 1212 </span> : * result exceeds max_size(), length_error is thrown. The value of the -<span class="lineNum"> 1213 </span> : * string doesn't change if an error is thrown. -<span class="lineNum"> 1214 </span> : */ -<span class="lineNum"> 1215 </span> : basic_string& -<span class="lineNum"> 1216 </span> : replace(size_type __pos1, size_type __n1, const basic_string& __str, -<span class="lineNum"> 1217 </span> : size_type __pos2, size_type __n2) -<span class="lineNum"> 1218 </span> : { return this->replace(__pos1, __n1, __str._M_data() -<span class="lineNum"> 1219 </span> : + __str._M_check(__pos2, "basic_string::replace"), -<span class="lineNum"> 1220 </span> : __str._M_limit(__pos2, __n2)); } -<span class="lineNum"> 1221 </span> : -<span class="lineNum"> 1222 </span> : /** -<span class="lineNum"> 1223 </span> : * @brief Replace characters with value of a C substring. -<span class="lineNum"> 1224 </span> : * @param pos Index of first character to replace. -<span class="lineNum"> 1225 </span> : * @param n1 Number of characters to be replaced. -<span class="lineNum"> 1226 </span> : * @param s C string to insert. -<span class="lineNum"> 1227 </span> : * @param n2 Number of characters from @a s to use. -<span class="lineNum"> 1228 </span> : * @return Reference to this string. -<span class="lineNum"> 1229 </span> : * @throw std::out_of_range If @a pos1 > size(). -<span class="lineNum"> 1230 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1231 </span> : * -<span class="lineNum"> 1232 </span> : * Removes the characters in the range [pos,pos + n1) from this string. -<span class="lineNum"> 1233 </span> : * In place, the first @a n2 characters of @a s are inserted, or all -<span class="lineNum"> 1234 </span> : * of @a s if @a n2 is too large. If @a pos is beyond end of string, -<span class="lineNum"> 1235 </span> : * out_of_range is thrown. If the length of result exceeds max_size(), -<span class="lineNum"> 1236 </span> : * length_error is thrown. The value of the string doesn't change if -<span class="lineNum"> 1237 </span> : * an error is thrown. -<span class="lineNum"> 1238 </span> : */ -<span class="lineNum"> 1239 </span> : basic_string& -<span class="lineNum"> 1240 </span> : replace(size_type __pos, size_type __n1, const _CharT* __s, -<span class="lineNum"> 1241 </span> : size_type __n2); -<span class="lineNum"> 1242 </span> : -<span class="lineNum"> 1243 </span> : /** -<span class="lineNum"> 1244 </span> : * @brief Replace characters with value of a C string. -<span class="lineNum"> 1245 </span> : * @param pos Index of first character to replace. -<span class="lineNum"> 1246 </span> : * @param n1 Number of characters to be replaced. -<span class="lineNum"> 1247 </span> : * @param s C string to insert. -<span class="lineNum"> 1248 </span> : * @return Reference to this string. -<span class="lineNum"> 1249 </span> : * @throw std::out_of_range If @a pos > size(). -<span class="lineNum"> 1250 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1251 </span> : * -<span class="lineNum"> 1252 </span> : * Removes the characters in the range [pos,pos + n1) from this string. -<span class="lineNum"> 1253 </span> : * In place, the first @a n characters of @a s are inserted. If @a -<span class="lineNum"> 1254 </span> : * pos is beyond end of string, out_of_range is thrown. If the length -<span class="lineNum"> 1255 </span> : * of result exceeds max_size(), length_error is thrown. The value of -<span class="lineNum"> 1256 </span> : * the string doesn't change if an error is thrown. -<span class="lineNum"> 1257 </span> : */ -<span class="lineNum"> 1258 </span> : basic_string& -<span class="lineNum"> 1259 </span> : replace(size_type __pos, size_type __n1, const _CharT* __s) -<span class="lineNum"> 1260 </span> : { -<span class="lineNum"> 1261 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1262 </span> : return this->replace(__pos, __n1, __s, traits_type::length(__s)); -<span class="lineNum"> 1263 </span> : } -<span class="lineNum"> 1264 </span> : -<span class="lineNum"> 1265 </span> : /** -<span class="lineNum"> 1266 </span> : * @brief Replace characters with multiple characters. -<span class="lineNum"> 1267 </span> : * @param pos Index of first character to replace. -<span class="lineNum"> 1268 </span> : * @param n1 Number of characters to be replaced. -<span class="lineNum"> 1269 </span> : * @param n2 Number of characters to insert. -<span class="lineNum"> 1270 </span> : * @param c Character to insert. -<span class="lineNum"> 1271 </span> : * @return Reference to this string. -<span class="lineNum"> 1272 </span> : * @throw std::out_of_range If @a pos > size(). -<span class="lineNum"> 1273 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1274 </span> : * -<span class="lineNum"> 1275 </span> : * Removes the characters in the range [pos,pos + n1) from this string. -<span class="lineNum"> 1276 </span> : * In place, @a n2 copies of @a c are inserted. If @a pos is beyond -<span class="lineNum"> 1277 </span> : * end of string, out_of_range is thrown. If the length of result -<span class="lineNum"> 1278 </span> : * exceeds max_size(), length_error is thrown. The value of the string -<span class="lineNum"> 1279 </span> : * doesn't change if an error is thrown. -<span class="lineNum"> 1280 </span> : */ -<span class="lineNum"> 1281 </span> : basic_string& -<span class="lineNum"> 1282 </span> : replace(size_type __pos, size_type __n1, size_type __n2, _CharT __c) -<span class="lineNum"> 1283 </span> : { return _M_replace_aux(_M_check(__pos, "basic_string::replace"), -<span class="lineNum"> 1284 </span> : _M_limit(__pos, __n1), __n2, __c); } -<span class="lineNum"> 1285 </span> : -<span class="lineNum"> 1286 </span> : /** -<span class="lineNum"> 1287 </span> : * @brief Replace range of characters with string. -<span class="lineNum"> 1288 </span> : * @param i1 Iterator referencing start of range to replace. -<span class="lineNum"> 1289 </span> : * @param i2 Iterator referencing end of range to replace. -<span class="lineNum"> 1290 </span> : * @param str String value to insert. -<span class="lineNum"> 1291 </span> : * @return Reference to this string. -<span class="lineNum"> 1292 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1293 </span> : * -<span class="lineNum"> 1294 </span> : * Removes the characters in the range [i1,i2). In place, the value of -<span class="lineNum"> 1295 </span> : * @a str is inserted. If the length of result exceeds max_size(), -<span class="lineNum"> 1296 </span> : * length_error is thrown. The value of the string doesn't change if -<span class="lineNum"> 1297 </span> : * an error is thrown. -<span class="lineNum"> 1298 </span> : */ -<span class="lineNum"> 1299 </span> : basic_string& -<span class="lineNum"> 1300 </span> : replace(iterator __i1, iterator __i2, const basic_string& __str) -<span class="lineNum"> 1301 </span> : { return this->replace(__i1, __i2, __str._M_data(), __str.size()); } -<span class="lineNum"> 1302 </span> : -<span class="lineNum"> 1303 </span> : /** -<span class="lineNum"> 1304 </span> : * @brief Replace range of characters with C substring. -<span class="lineNum"> 1305 </span> : * @param i1 Iterator referencing start of range to replace. -<span class="lineNum"> 1306 </span> : * @param i2 Iterator referencing end of range to replace. -<span class="lineNum"> 1307 </span> : * @param s C string value to insert. -<span class="lineNum"> 1308 </span> : * @param n Number of characters from s to insert. -<span class="lineNum"> 1309 </span> : * @return Reference to this string. -<span class="lineNum"> 1310 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1311 </span> : * -<span class="lineNum"> 1312 </span> : * Removes the characters in the range [i1,i2). In place, the first @a -<span class="lineNum"> 1313 </span> : * n characters of @a s are inserted. If the length of result exceeds -<span class="lineNum"> 1314 </span> : * max_size(), length_error is thrown. The value of the string doesn't -<span class="lineNum"> 1315 </span> : * change if an error is thrown. -<span class="lineNum"> 1316 </span> : */ -<span class="lineNum"> 1317 </span> : basic_string& -<span class="lineNum"> 1318 </span> : replace(iterator __i1, iterator __i2, const _CharT* __s, size_type __n) -<span class="lineNum"> 1319 </span> : { -<span class="lineNum"> 1320 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1321 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1322 </span> : return this->replace(__i1 - _M_ibegin(), __i2 - __i1, __s, __n); -<span class="lineNum"> 1323 </span> : } -<span class="lineNum"> 1324 </span> : -<span class="lineNum"> 1325 </span> : /** -<span class="lineNum"> 1326 </span> : * @brief Replace range of characters with C string. -<span class="lineNum"> 1327 </span> : * @param i1 Iterator referencing start of range to replace. -<span class="lineNum"> 1328 </span> : * @param i2 Iterator referencing end of range to replace. -<span class="lineNum"> 1329 </span> : * @param s C string value to insert. -<span class="lineNum"> 1330 </span> : * @return Reference to this string. -<span class="lineNum"> 1331 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1332 </span> : * -<span class="lineNum"> 1333 </span> : * Removes the characters in the range [i1,i2). In place, the -<span class="lineNum"> 1334 </span> : * characters of @a s are inserted. If the length of result exceeds -<span class="lineNum"> 1335 </span> : * max_size(), length_error is thrown. The value of the string doesn't -<span class="lineNum"> 1336 </span> : * change if an error is thrown. -<span class="lineNum"> 1337 </span> : */ -<span class="lineNum"> 1338 </span> : basic_string& -<span class="lineNum"> 1339 </span> : replace(iterator __i1, iterator __i2, const _CharT* __s) -<span class="lineNum"> 1340 </span> : { -<span class="lineNum"> 1341 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1342 </span> : return this->replace(__i1, __i2, __s, traits_type::length(__s)); -<span class="lineNum"> 1343 </span> : } -<span class="lineNum"> 1344 </span> : -<span class="lineNum"> 1345 </span> : /** -<span class="lineNum"> 1346 </span> : * @brief Replace range of characters with multiple characters -<span class="lineNum"> 1347 </span> : * @param i1 Iterator referencing start of range to replace. -<span class="lineNum"> 1348 </span> : * @param i2 Iterator referencing end of range to replace. -<span class="lineNum"> 1349 </span> : * @param n Number of characters to insert. -<span class="lineNum"> 1350 </span> : * @param c Character to insert. -<span class="lineNum"> 1351 </span> : * @return Reference to this string. -<span class="lineNum"> 1352 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1353 </span> : * -<span class="lineNum"> 1354 </span> : * Removes the characters in the range [i1,i2). In place, @a n copies -<span class="lineNum"> 1355 </span> : * of @a c are inserted. If the length of result exceeds max_size(), -<span class="lineNum"> 1356 </span> : * length_error is thrown. The value of the string doesn't change if -<span class="lineNum"> 1357 </span> : * an error is thrown. -<span class="lineNum"> 1358 </span> : */ -<span class="lineNum"> 1359 </span> : basic_string& -<span class="lineNum"> 1360 </span> : replace(iterator __i1, iterator __i2, size_type __n, _CharT __c) -<span class="lineNum"> 1361 </span> : { -<span class="lineNum"> 1362 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1363 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1364 </span> : return _M_replace_aux(__i1 - _M_ibegin(), __i2 - __i1, __n, __c); -<span class="lineNum"> 1365 </span> : } -<span class="lineNum"> 1366 </span> : -<span class="lineNum"> 1367 </span> : /** -<span class="lineNum"> 1368 </span> : * @brief Replace range of characters with range. -<span class="lineNum"> 1369 </span> : * @param i1 Iterator referencing start of range to replace. -<span class="lineNum"> 1370 </span> : * @param i2 Iterator referencing end of range to replace. -<span class="lineNum"> 1371 </span> : * @param k1 Iterator referencing start of range to insert. -<span class="lineNum"> 1372 </span> : * @param k2 Iterator referencing end of range to insert. -<span class="lineNum"> 1373 </span> : * @return Reference to this string. -<span class="lineNum"> 1374 </span> : * @throw std::length_error If new length exceeds @c max_size(). -<span class="lineNum"> 1375 </span> : * -<span class="lineNum"> 1376 </span> : * Removes the characters in the range [i1,i2). In place, characters -<span class="lineNum"> 1377 </span> : * in the range [k1,k2) are inserted. If the length of result exceeds -<span class="lineNum"> 1378 </span> : * max_size(), length_error is thrown. The value of the string doesn't -<span class="lineNum"> 1379 </span> : * change if an error is thrown. -<span class="lineNum"> 1380 </span> : */ -<span class="lineNum"> 1381 </span> : template<class _InputIterator> -<span class="lineNum"> 1382 </span> : basic_string& -<span class="lineNum"> 1383 </span> : replace(iterator __i1, iterator __i2, -<span class="lineNum"> 1384 </span> : _InputIterator __k1, _InputIterator __k2) -<span class="lineNum"> 1385 </span> : { -<span class="lineNum"> 1386 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1387 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1388 </span> : __glibcxx_requires_valid_range(__k1, __k2); -<span class="lineNum"> 1389 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 1390 </span> : return _M_replace_dispatch(__i1, __i2, __k1, __k2, _Integral()); -<span class="lineNum"> 1391 </span> : } -<span class="lineNum"> 1392 </span> : -<span class="lineNum"> 1393 </span> : // Specializations for the common case of pointer and iterator: -<span class="lineNum"> 1394 </span> : // useful to avoid the overhead of temporary buffering in _M_replace. -<span class="lineNum"> 1395 </span> : basic_string& -<span class="lineNum"> 1396 </span> : replace(iterator __i1, iterator __i2, _CharT* __k1, _CharT* __k2) -<span class="lineNum"> 1397 </span> : { -<span class="lineNum"> 1398 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1399 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1400 </span> : __glibcxx_requires_valid_range(__k1, __k2); -<span class="lineNum"> 1401 </span> : return this->replace(__i1 - _M_ibegin(), __i2 - __i1, -<span class="lineNum"> 1402 </span> : __k1, __k2 - __k1); -<span class="lineNum"> 1403 </span> : } -<span class="lineNum"> 1404 </span> : -<span class="lineNum"> 1405 </span> : basic_string& -<span class="lineNum"> 1406 </span> : replace(iterator __i1, iterator __i2, -<span class="lineNum"> 1407 </span> : const _CharT* __k1, const _CharT* __k2) -<span class="lineNum"> 1408 </span> : { -<span class="lineNum"> 1409 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1410 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1411 </span> : __glibcxx_requires_valid_range(__k1, __k2); -<span class="lineNum"> 1412 </span> : return this->replace(__i1 - _M_ibegin(), __i2 - __i1, -<span class="lineNum"> 1413 </span> : __k1, __k2 - __k1); -<span class="lineNum"> 1414 </span> : } -<span class="lineNum"> 1415 </span> : -<span class="lineNum"> 1416 </span> : basic_string& -<span class="lineNum"> 1417 </span> : replace(iterator __i1, iterator __i2, iterator __k1, iterator __k2) -<span class="lineNum"> 1418 </span> : { -<span class="lineNum"> 1419 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1420 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1421 </span> : __glibcxx_requires_valid_range(__k1, __k2); -<span class="lineNum"> 1422 </span> : return this->replace(__i1 - _M_ibegin(), __i2 - __i1, -<span class="lineNum"> 1423 </span> : __k1.base(), __k2 - __k1); -<span class="lineNum"> 1424 </span> : } -<span class="lineNum"> 1425 </span> : -<span class="lineNum"> 1426 </span> : basic_string& -<span class="lineNum"> 1427 </span> : replace(iterator __i1, iterator __i2, -<span class="lineNum"> 1428 </span> : const_iterator __k1, const_iterator __k2) -<span class="lineNum"> 1429 </span> : { -<span class="lineNum"> 1430 </span> : _GLIBCXX_DEBUG_PEDASSERT(_M_ibegin() <= __i1 && __i1 <= __i2 -<span class="lineNum"> 1431 </span> : && __i2 <= _M_iend()); -<span class="lineNum"> 1432 </span> : __glibcxx_requires_valid_range(__k1, __k2); -<span class="lineNum"> 1433 </span> : return this->replace(__i1 - _M_ibegin(), __i2 - __i1, -<span class="lineNum"> 1434 </span> : __k1.base(), __k2 - __k1); -<span class="lineNum"> 1435 </span> : } -<span class="lineNum"> 1436 </span> : -<span class="lineNum"> 1437 </span> : private: -<span class="lineNum"> 1438 </span> : template<class _Integer> -<span class="lineNum"> 1439 </span> : basic_string& -<span class="lineNum"> 1440 </span> : _M_replace_dispatch(iterator __i1, iterator __i2, _Integer __n, -<span class="lineNum"> 1441 </span> : _Integer __val, __true_type) -<span class="lineNum"> 1442 </span> : { return _M_replace_aux(__i1 - _M_ibegin(), __i2 - __i1, __n, __val); } -<span class="lineNum"> 1443 </span> : -<span class="lineNum"> 1444 </span> : template<class _InputIterator> -<span class="lineNum"> 1445 </span> : basic_string& -<span class="lineNum"> 1446 </span> : _M_replace_dispatch(iterator __i1, iterator __i2, _InputIterator __k1, -<span class="lineNum"> 1447 </span> : _InputIterator __k2, __false_type); -<span class="lineNum"> 1448 </span> : -<span class="lineNum"> 1449 </span> : basic_string& -<span class="lineNum"> 1450 </span> : _M_replace_aux(size_type __pos1, size_type __n1, size_type __n2, -<span class="lineNum"> 1451 </span> : _CharT __c); -<span class="lineNum"> 1452 </span> : -<span class="lineNum"> 1453 </span> : basic_string& -<span class="lineNum"> 1454 </span> : _M_replace_safe(size_type __pos1, size_type __n1, const _CharT* __s, -<span class="lineNum"> 1455 </span> : size_type __n2); -<span class="lineNum"> 1456 </span> : -<span class="lineNum"> 1457 </span> : // _S_construct_aux is used to implement the 21.3.1 para 15 which -<span class="lineNum"> 1458 </span> : // requires special behaviour if _InIter is an integral type -<span class="lineNum"> 1459 </span> : template<class _InIterator> -<span class="lineNum"> 1460 </span> : static _CharT* -<span class="lineNum"> 1461 </span> : _S_construct_aux(_InIterator __beg, _InIterator __end, -<span class="lineNum"> 1462 </span><span class="lineCov"> 1287 : const _Alloc& __a, __false_type)</span> -<span class="lineNum"> 1463 </span> : { -<span class="lineNum"> 1464 </span> : typedef typename iterator_traits<_InIterator>::iterator_category _Tag; -<span class="lineNum"> 1465 </span><span class="lineCov"> 1287 : return _S_construct(__beg, __end, __a, _Tag());</span> -<span class="lineNum"> 1466 </span> : } -<span class="lineNum"> 1467 </span> : -<span class="lineNum"> 1468 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1469 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1470 </span> : template<class _Integer> -<span class="lineNum"> 1471 </span> : static _CharT* -<span class="lineNum"> 1472 </span> : _S_construct_aux(_Integer __beg, _Integer __end, -<span class="lineNum"> 1473 </span> : const _Alloc& __a, __true_type) -<span class="lineNum"> 1474 </span> : { return _S_construct(static_cast<size_type>(__beg), __end, __a); } -<span class="lineNum"> 1475 </span> : -<span class="lineNum"> 1476 </span> : template<class _InIterator> -<span class="lineNum"> 1477 </span> : static _CharT* -<span class="lineNum"> 1478 </span><span class="lineCov"> 1287 : _S_construct(_InIterator __beg, _InIterator __end, const _Alloc& __a)</span> -<span class="lineNum"> 1479 </span> : { -<span class="lineNum"> 1480 </span> : typedef typename std::__is_integer<_InIterator>::__type _Integral; -<span class="lineNum"> 1481 </span><span class="lineCov"> 1287 : return _S_construct_aux(__beg, __end, __a, _Integral());</span> -<span class="lineNum"> 1482 </span> : } -<span class="lineNum"> 1483 </span> : -<span class="lineNum"> 1484 </span> : // For Input Iterators, used in istreambuf_iterators, etc. -<span class="lineNum"> 1485 </span> : template<class _InIterator> -<span class="lineNum"> 1486 </span> : static _CharT* -<span class="lineNum"> 1487 </span> : _S_construct(_InIterator __beg, _InIterator __end, const _Alloc& __a, -<span class="lineNum"> 1488 </span> : input_iterator_tag); -<span class="lineNum"> 1489 </span> : -<span class="lineNum"> 1490 </span> : // For forward_iterators up to random_access_iterators, used for -<span class="lineNum"> 1491 </span> : // string::iterator, _CharT*, etc. -<span class="lineNum"> 1492 </span> : template<class _FwdIterator> -<span class="lineNum"> 1493 </span> : static _CharT* -<span class="lineNum"> 1494 </span> : _S_construct(_FwdIterator __beg, _FwdIterator __end, const _Alloc& __a, -<span class="lineNum"> 1495 </span> : forward_iterator_tag); -<span class="lineNum"> 1496 </span> : -<span class="lineNum"> 1497 </span> : static _CharT* -<span class="lineNum"> 1498 </span> : _S_construct(size_type __req, _CharT __c, const _Alloc& __a); -<span class="lineNum"> 1499 </span> : -<span class="lineNum"> 1500 </span> : public: -<span class="lineNum"> 1501 </span> : -<span class="lineNum"> 1502 </span> : /** -<span class="lineNum"> 1503 </span> : * @brief Copy substring into C string. -<span class="lineNum"> 1504 </span> : * @param s C string to copy value into. -<span class="lineNum"> 1505 </span> : * @param n Number of characters to copy. -<span class="lineNum"> 1506 </span> : * @param pos Index of first character to copy. -<span class="lineNum"> 1507 </span> : * @return Number of characters actually copied -<span class="lineNum"> 1508 </span> : * @throw std::out_of_range If pos > size(). -<span class="lineNum"> 1509 </span> : * -<span class="lineNum"> 1510 </span> : * Copies up to @a n characters starting at @a pos into the C string @a -<span class="lineNum"> 1511 </span> : * s. If @a pos is greater than size(), out_of_range is thrown. -<span class="lineNum"> 1512 </span> : */ -<span class="lineNum"> 1513 </span> : size_type -<span class="lineNum"> 1514 </span> : copy(_CharT* __s, size_type __n, size_type __pos = 0) const; -<span class="lineNum"> 1515 </span> : -<span class="lineNum"> 1516 </span> : /** -<span class="lineNum"> 1517 </span> : * @brief Swap contents with another string. -<span class="lineNum"> 1518 </span> : * @param s String to swap with. -<span class="lineNum"> 1519 </span> : * -<span class="lineNum"> 1520 </span> : * Exchanges the contents of this string with that of @a s in constant -<span class="lineNum"> 1521 </span> : * time. -<span class="lineNum"> 1522 </span> : */ -<span class="lineNum"> 1523 </span> : void -<span class="lineNum"> 1524 </span> : swap(basic_string& __s); -<span class="lineNum"> 1525 </span> : -<span class="lineNum"> 1526 </span> : // String operations: -<span class="lineNum"> 1527 </span> : /** -<span class="lineNum"> 1528 </span> : * @brief Return const pointer to null-terminated contents. -<span class="lineNum"> 1529 </span> : * -<span class="lineNum"> 1530 </span> : * This is a handle to internal data. Do not modify or dire things may -<span class="lineNum"> 1531 </span> : * happen. -<span class="lineNum"> 1532 </span> : */ -<span class="lineNum"> 1533 </span> : const _CharT* -<span class="lineNum"> 1534 </span><span class="lineNoCov"> 0 : c_str() const</span> -<span class="lineNum"> 1535 </span><span class="lineNoCov"> 0 : { return _M_data(); }</span> -<span class="lineNum"> 1536 </span> : -<span class="lineNum"> 1537 </span> : /** -<span class="lineNum"> 1538 </span> : * @brief Return const pointer to contents. -<span class="lineNum"> 1539 </span> : * -<span class="lineNum"> 1540 </span> : * This is a handle to internal data. Do not modify or dire things may -<span class="lineNum"> 1541 </span> : * happen. -<span class="lineNum"> 1542 </span> : */ -<span class="lineNum"> 1543 </span> : const _CharT* -<span class="lineNum"> 1544 </span><span class="lineNoCov"> 0 : data() const</span> -<span class="lineNum"> 1545 </span><span class="lineNoCov"> 0 : { return _M_data(); }</span> -<span class="lineNum"> 1546 </span> : -<span class="lineNum"> 1547 </span> : /** -<span class="lineNum"> 1548 </span> : * @brief Return copy of allocator used to construct this string. -<span class="lineNum"> 1549 </span> : */ -<span class="lineNum"> 1550 </span> : allocator_type -<span class="lineNum"> 1551 </span><span class="lineNoCov"> 0 : get_allocator() const</span> -<span class="lineNum"> 1552 </span><span class="lineNoCov"> 0 : { return _M_dataplus; }</span> -<span class="lineNum"> 1553 </span> : -<span class="lineNum"> 1554 </span> : /** -<span class="lineNum"> 1555 </span> : * @brief Find position of a C substring. -<span class="lineNum"> 1556 </span> : * @param s C string to locate. -<span class="lineNum"> 1557 </span> : * @param pos Index of character to search from. -<span class="lineNum"> 1558 </span> : * @param n Number of characters from @a s to search for. -<span class="lineNum"> 1559 </span> : * @return Index of start of first occurrence. -<span class="lineNum"> 1560 </span> : * -<span class="lineNum"> 1561 </span> : * Starting from @a pos, searches forward for the first @a n characters -<span class="lineNum"> 1562 </span> : * in @a s within this string. If found, returns the index where it -<span class="lineNum"> 1563 </span> : * begins. If not found, returns npos. -<span class="lineNum"> 1564 </span> : */ -<span class="lineNum"> 1565 </span> : size_type -<span class="lineNum"> 1566 </span> : find(const _CharT* __s, size_type __pos, size_type __n) const; -<span class="lineNum"> 1567 </span> : -<span class="lineNum"> 1568 </span> : /** -<span class="lineNum"> 1569 </span> : * @brief Find position of a string. -<span class="lineNum"> 1570 </span> : * @param str String to locate. -<span class="lineNum"> 1571 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1572 </span> : * @return Index of start of first occurrence. -<span class="lineNum"> 1573 </span> : * -<span class="lineNum"> 1574 </span> : * Starting from @a pos, searches forward for value of @a str within -<span class="lineNum"> 1575 </span> : * this string. If found, returns the index where it begins. If not -<span class="lineNum"> 1576 </span> : * found, returns npos. -<span class="lineNum"> 1577 </span> : */ -<span class="lineNum"> 1578 </span> : size_type -<span class="lineNum"> 1579 </span><span class="lineNoCov"> 0 : find(const basic_string& __str, size_type __pos = 0) const</span> -<span class="lineNum"> 1580 </span><span class="lineNoCov"> 0 : { return this->find(__str.data(), __pos, __str.size()); }</span> -<span class="lineNum"> 1581 </span> : -<span class="lineNum"> 1582 </span> : /** -<span class="lineNum"> 1583 </span> : * @brief Find position of a C string. -<span class="lineNum"> 1584 </span> : * @param s C string to locate. -<span class="lineNum"> 1585 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1586 </span> : * @return Index of start of first occurrence. -<span class="lineNum"> 1587 </span> : * -<span class="lineNum"> 1588 </span> : * Starting from @a pos, searches forward for the value of @a s within -<span class="lineNum"> 1589 </span> : * this string. If found, returns the index where it begins. If not -<span class="lineNum"> 1590 </span> : * found, returns npos. -<span class="lineNum"> 1591 </span> : */ -<span class="lineNum"> 1592 </span> : size_type -<span class="lineNum"> 1593 </span><span class="lineNoCov"> 0 : find(const _CharT* __s, size_type __pos = 0) const</span> -<span class="lineNum"> 1594 </span> : { -<span class="lineNum"> 1595 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1596 </span><span class="lineNoCov"> 0 : return this->find(__s, __pos, traits_type::length(__s));</span> -<span class="lineNum"> 1597 </span> : } -<span class="lineNum"> 1598 </span> : -<span class="lineNum"> 1599 </span> : /** -<span class="lineNum"> 1600 </span> : * @brief Find position of a character. -<span class="lineNum"> 1601 </span> : * @param c Character to locate. -<span class="lineNum"> 1602 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1603 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1604 </span> : * -<span class="lineNum"> 1605 </span> : * Starting from @a pos, searches forward for @a c within this string. -<span class="lineNum"> 1606 </span> : * If found, returns the index where it was found. If not found, -<span class="lineNum"> 1607 </span> : * returns npos. -<span class="lineNum"> 1608 </span> : */ -<span class="lineNum"> 1609 </span> : size_type -<span class="lineNum"> 1610 </span> : find(_CharT __c, size_type __pos = 0) const; -<span class="lineNum"> 1611 </span> : -<span class="lineNum"> 1612 </span> : /** -<span class="lineNum"> 1613 </span> : * @brief Find last position of a string. -<span class="lineNum"> 1614 </span> : * @param str String to locate. -<span class="lineNum"> 1615 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1616 </span> : * @return Index of start of last occurrence. -<span class="lineNum"> 1617 </span> : * -<span class="lineNum"> 1618 </span> : * Starting from @a pos, searches backward for value of @a str within -<span class="lineNum"> 1619 </span> : * this string. If found, returns the index where it begins. If not -<span class="lineNum"> 1620 </span> : * found, returns npos. -<span class="lineNum"> 1621 </span> : */ -<span class="lineNum"> 1622 </span> : size_type -<span class="lineNum"> 1623 </span> : rfind(const basic_string& __str, size_type __pos = npos) const -<span class="lineNum"> 1624 </span> : { return this->rfind(__str.data(), __pos, __str.size()); } -<span class="lineNum"> 1625 </span> : -<span class="lineNum"> 1626 </span> : /** -<span class="lineNum"> 1627 </span> : * @brief Find last position of a C substring. -<span class="lineNum"> 1628 </span> : * @param s C string to locate. -<span class="lineNum"> 1629 </span> : * @param pos Index of character to search back from. -<span class="lineNum"> 1630 </span> : * @param n Number of characters from s to search for. -<span class="lineNum"> 1631 </span> : * @return Index of start of last occurrence. -<span class="lineNum"> 1632 </span> : * -<span class="lineNum"> 1633 </span> : * Starting from @a pos, searches backward for the first @a n -<span class="lineNum"> 1634 </span> : * characters in @a s within this string. If found, returns the index -<span class="lineNum"> 1635 </span> : * where it begins. If not found, returns npos. -<span class="lineNum"> 1636 </span> : */ -<span class="lineNum"> 1637 </span> : size_type -<span class="lineNum"> 1638 </span> : rfind(const _CharT* __s, size_type __pos, size_type __n) const; -<span class="lineNum"> 1639 </span> : -<span class="lineNum"> 1640 </span> : /** -<span class="lineNum"> 1641 </span> : * @brief Find last position of a C string. -<span class="lineNum"> 1642 </span> : * @param s C string to locate. -<span class="lineNum"> 1643 </span> : * @param pos Index of character to start search at (default end). -<span class="lineNum"> 1644 </span> : * @return Index of start of last occurrence. -<span class="lineNum"> 1645 </span> : * -<span class="lineNum"> 1646 </span> : * Starting from @a pos, searches backward for the value of @a s within -<span class="lineNum"> 1647 </span> : * this string. If found, returns the index where it begins. If not -<span class="lineNum"> 1648 </span> : * found, returns npos. -<span class="lineNum"> 1649 </span> : */ -<span class="lineNum"> 1650 </span> : size_type -<span class="lineNum"> 1651 </span><span class="lineNoCov"> 0 : rfind(const _CharT* __s, size_type __pos = npos) const</span> -<span class="lineNum"> 1652 </span> : { -<span class="lineNum"> 1653 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1654 </span><span class="lineNoCov"> 0 : return this->rfind(__s, __pos, traits_type::length(__s));</span> -<span class="lineNum"> 1655 </span> : } -<span class="lineNum"> 1656 </span> : -<span class="lineNum"> 1657 </span> : /** -<span class="lineNum"> 1658 </span> : * @brief Find last position of a character. -<span class="lineNum"> 1659 </span> : * @param c Character to locate. -<span class="lineNum"> 1660 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1661 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1662 </span> : * -<span class="lineNum"> 1663 </span> : * Starting from @a pos, searches backward for @a c within this string. -<span class="lineNum"> 1664 </span> : * If found, returns the index where it was found. If not found, -<span class="lineNum"> 1665 </span> : * returns npos. -<span class="lineNum"> 1666 </span> : */ -<span class="lineNum"> 1667 </span> : size_type -<span class="lineNum"> 1668 </span> : rfind(_CharT __c, size_type __pos = npos) const; -<span class="lineNum"> 1669 </span> : -<span class="lineNum"> 1670 </span> : /** -<span class="lineNum"> 1671 </span> : * @brief Find position of a character of string. -<span class="lineNum"> 1672 </span> : * @param str String containing characters to locate. -<span class="lineNum"> 1673 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1674 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1675 </span> : * -<span class="lineNum"> 1676 </span> : * Starting from @a pos, searches forward for one of the characters of -<span class="lineNum"> 1677 </span> : * @a str within this string. If found, returns the index where it was -<span class="lineNum"> 1678 </span> : * found. If not found, returns npos. -<span class="lineNum"> 1679 </span> : */ -<span class="lineNum"> 1680 </span> : size_type -<span class="lineNum"> 1681 </span> : find_first_of(const basic_string& __str, size_type __pos = 0) const -<span class="lineNum"> 1682 </span> : { return this->find_first_of(__str.data(), __pos, __str.size()); } -<span class="lineNum"> 1683 </span> : -<span class="lineNum"> 1684 </span> : /** -<span class="lineNum"> 1685 </span> : * @brief Find position of a character of C substring. -<span class="lineNum"> 1686 </span> : * @param s String containing characters to locate. -<span class="lineNum"> 1687 </span> : * @param pos Index of character to search from. -<span class="lineNum"> 1688 </span> : * @param n Number of characters from s to search for. -<span class="lineNum"> 1689 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1690 </span> : * -<span class="lineNum"> 1691 </span> : * Starting from @a pos, searches forward for one of the first @a n -<span class="lineNum"> 1692 </span> : * characters of @a s within this string. If found, returns the index -<span class="lineNum"> 1693 </span> : * where it was found. If not found, returns npos. -<span class="lineNum"> 1694 </span> : */ -<span class="lineNum"> 1695 </span> : size_type -<span class="lineNum"> 1696 </span> : find_first_of(const _CharT* __s, size_type __pos, size_type __n) const; -<span class="lineNum"> 1697 </span> : -<span class="lineNum"> 1698 </span> : /** -<span class="lineNum"> 1699 </span> : * @brief Find position of a character of C string. -<span class="lineNum"> 1700 </span> : * @param s String containing characters to locate. -<span class="lineNum"> 1701 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1702 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1703 </span> : * -<span class="lineNum"> 1704 </span> : * Starting from @a pos, searches forward for one of the characters of -<span class="lineNum"> 1705 </span> : * @a s within this string. If found, returns the index where it was -<span class="lineNum"> 1706 </span> : * found. If not found, returns npos. -<span class="lineNum"> 1707 </span> : */ -<span class="lineNum"> 1708 </span> : size_type -<span class="lineNum"> 1709 </span> : find_first_of(const _CharT* __s, size_type __pos = 0) const -<span class="lineNum"> 1710 </span> : { -<span class="lineNum"> 1711 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1712 </span> : return this->find_first_of(__s, __pos, traits_type::length(__s)); -<span class="lineNum"> 1713 </span> : } -<span class="lineNum"> 1714 </span> : -<span class="lineNum"> 1715 </span> : /** -<span class="lineNum"> 1716 </span> : * @brief Find position of a character. -<span class="lineNum"> 1717 </span> : * @param c Character to locate. -<span class="lineNum"> 1718 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1719 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1720 </span> : * -<span class="lineNum"> 1721 </span> : * Starting from @a pos, searches forward for the character @a c within -<span class="lineNum"> 1722 </span> : * this string. If found, returns the index where it was found. If -<span class="lineNum"> 1723 </span> : * not found, returns npos. -<span class="lineNum"> 1724 </span> : * -<span class="lineNum"> 1725 </span> : * Note: equivalent to find(c, pos). -<span class="lineNum"> 1726 </span> : */ -<span class="lineNum"> 1727 </span> : size_type -<span class="lineNum"> 1728 </span> : find_first_of(_CharT __c, size_type __pos = 0) const -<span class="lineNum"> 1729 </span> : { return this->find(__c, __pos); } -<span class="lineNum"> 1730 </span> : -<span class="lineNum"> 1731 </span> : /** -<span class="lineNum"> 1732 </span> : * @brief Find last position of a character of string. -<span class="lineNum"> 1733 </span> : * @param str String containing characters to locate. -<span class="lineNum"> 1734 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1735 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1736 </span> : * -<span class="lineNum"> 1737 </span> : * Starting from @a pos, searches backward for one of the characters of -<span class="lineNum"> 1738 </span> : * @a str within this string. If found, returns the index where it was -<span class="lineNum"> 1739 </span> : * found. If not found, returns npos. -<span class="lineNum"> 1740 </span> : */ -<span class="lineNum"> 1741 </span> : size_type -<span class="lineNum"> 1742 </span> : find_last_of(const basic_string& __str, size_type __pos = npos) const -<span class="lineNum"> 1743 </span> : { return this->find_last_of(__str.data(), __pos, __str.size()); } -<span class="lineNum"> 1744 </span> : -<span class="lineNum"> 1745 </span> : /** -<span class="lineNum"> 1746 </span> : * @brief Find last position of a character of C substring. -<span class="lineNum"> 1747 </span> : * @param s C string containing characters to locate. -<span class="lineNum"> 1748 </span> : * @param pos Index of character to search back from. -<span class="lineNum"> 1749 </span> : * @param n Number of characters from s to search for. -<span class="lineNum"> 1750 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1751 </span> : * -<span class="lineNum"> 1752 </span> : * Starting from @a pos, searches backward for one of the first @a n -<span class="lineNum"> 1753 </span> : * characters of @a s within this string. If found, returns the index -<span class="lineNum"> 1754 </span> : * where it was found. If not found, returns npos. -<span class="lineNum"> 1755 </span> : */ -<span class="lineNum"> 1756 </span> : size_type -<span class="lineNum"> 1757 </span> : find_last_of(const _CharT* __s, size_type __pos, size_type __n) const; -<span class="lineNum"> 1758 </span> : -<span class="lineNum"> 1759 </span> : /** -<span class="lineNum"> 1760 </span> : * @brief Find last position of a character of C string. -<span class="lineNum"> 1761 </span> : * @param s C string containing characters to locate. -<span class="lineNum"> 1762 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1763 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1764 </span> : * -<span class="lineNum"> 1765 </span> : * Starting from @a pos, searches backward for one of the characters of -<span class="lineNum"> 1766 </span> : * @a s within this string. If found, returns the index where it was -<span class="lineNum"> 1767 </span> : * found. If not found, returns npos. -<span class="lineNum"> 1768 </span> : */ -<span class="lineNum"> 1769 </span> : size_type -<span class="lineNum"> 1770 </span> : find_last_of(const _CharT* __s, size_type __pos = npos) const -<span class="lineNum"> 1771 </span> : { -<span class="lineNum"> 1772 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1773 </span> : return this->find_last_of(__s, __pos, traits_type::length(__s)); -<span class="lineNum"> 1774 </span> : } -<span class="lineNum"> 1775 </span> : -<span class="lineNum"> 1776 </span> : /** -<span class="lineNum"> 1777 </span> : * @brief Find last position of a character. -<span class="lineNum"> 1778 </span> : * @param c Character to locate. -<span class="lineNum"> 1779 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1780 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1781 </span> : * -<span class="lineNum"> 1782 </span> : * Starting from @a pos, searches backward for @a c within this string. -<span class="lineNum"> 1783 </span> : * If found, returns the index where it was found. If not found, -<span class="lineNum"> 1784 </span> : * returns npos. -<span class="lineNum"> 1785 </span> : * -<span class="lineNum"> 1786 </span> : * Note: equivalent to rfind(c, pos). -<span class="lineNum"> 1787 </span> : */ -<span class="lineNum"> 1788 </span> : size_type -<span class="lineNum"> 1789 </span> : find_last_of(_CharT __c, size_type __pos = npos) const -<span class="lineNum"> 1790 </span> : { return this->rfind(__c, __pos); } -<span class="lineNum"> 1791 </span> : -<span class="lineNum"> 1792 </span> : /** -<span class="lineNum"> 1793 </span> : * @brief Find position of a character not in string. -<span class="lineNum"> 1794 </span> : * @param str String containing characters to avoid. -<span class="lineNum"> 1795 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1796 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1797 </span> : * -<span class="lineNum"> 1798 </span> : * Starting from @a pos, searches forward for a character not contained -<span class="lineNum"> 1799 </span> : * in @a str within this string. If found, returns the index where it -<span class="lineNum"> 1800 </span> : * was found. If not found, returns npos. -<span class="lineNum"> 1801 </span> : */ -<span class="lineNum"> 1802 </span> : size_type -<span class="lineNum"> 1803 </span> : find_first_not_of(const basic_string& __str, size_type __pos = 0) const -<span class="lineNum"> 1804 </span> : { return this->find_first_not_of(__str.data(), __pos, __str.size()); } -<span class="lineNum"> 1805 </span> : -<span class="lineNum"> 1806 </span> : /** -<span class="lineNum"> 1807 </span> : * @brief Find position of a character not in C substring. -<span class="lineNum"> 1808 </span> : * @param s C string containing characters to avoid. -<span class="lineNum"> 1809 </span> : * @param pos Index of character to search from. -<span class="lineNum"> 1810 </span> : * @param n Number of characters from s to consider. -<span class="lineNum"> 1811 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1812 </span> : * -<span class="lineNum"> 1813 </span> : * Starting from @a pos, searches forward for a character not contained -<span class="lineNum"> 1814 </span> : * in the first @a n characters of @a s within this string. If found, -<span class="lineNum"> 1815 </span> : * returns the index where it was found. If not found, returns npos. -<span class="lineNum"> 1816 </span> : */ -<span class="lineNum"> 1817 </span> : size_type -<span class="lineNum"> 1818 </span> : find_first_not_of(const _CharT* __s, size_type __pos, -<span class="lineNum"> 1819 </span> : size_type __n) const; -<span class="lineNum"> 1820 </span> : -<span class="lineNum"> 1821 </span> : /** -<span class="lineNum"> 1822 </span> : * @brief Find position of a character not in C string. -<span class="lineNum"> 1823 </span> : * @param s C string containing characters to avoid. -<span class="lineNum"> 1824 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1825 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1826 </span> : * -<span class="lineNum"> 1827 </span> : * Starting from @a pos, searches forward for a character not contained -<span class="lineNum"> 1828 </span> : * in @a s within this string. If found, returns the index where it -<span class="lineNum"> 1829 </span> : * was found. If not found, returns npos. -<span class="lineNum"> 1830 </span> : */ -<span class="lineNum"> 1831 </span> : size_type -<span class="lineNum"> 1832 </span> : find_first_not_of(const _CharT* __s, size_type __pos = 0) const -<span class="lineNum"> 1833 </span> : { -<span class="lineNum"> 1834 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1835 </span> : return this->find_first_not_of(__s, __pos, traits_type::length(__s)); -<span class="lineNum"> 1836 </span> : } -<span class="lineNum"> 1837 </span> : -<span class="lineNum"> 1838 </span> : /** -<span class="lineNum"> 1839 </span> : * @brief Find position of a different character. -<span class="lineNum"> 1840 </span> : * @param c Character to avoid. -<span class="lineNum"> 1841 </span> : * @param pos Index of character to search from (default 0). -<span class="lineNum"> 1842 </span> : * @return Index of first occurrence. -<span class="lineNum"> 1843 </span> : * -<span class="lineNum"> 1844 </span> : * Starting from @a pos, searches forward for a character other than @a c -<span class="lineNum"> 1845 </span> : * within this string. If found, returns the index where it was found. -<span class="lineNum"> 1846 </span> : * If not found, returns npos. -<span class="lineNum"> 1847 </span> : */ -<span class="lineNum"> 1848 </span> : size_type -<span class="lineNum"> 1849 </span> : find_first_not_of(_CharT __c, size_type __pos = 0) const; -<span class="lineNum"> 1850 </span> : -<span class="lineNum"> 1851 </span> : /** -<span class="lineNum"> 1852 </span> : * @brief Find last position of a character not in string. -<span class="lineNum"> 1853 </span> : * @param str String containing characters to avoid. -<span class="lineNum"> 1854 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1855 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1856 </span> : * -<span class="lineNum"> 1857 </span> : * Starting from @a pos, searches backward for a character not -<span class="lineNum"> 1858 </span> : * contained in @a str within this string. If found, returns the index -<span class="lineNum"> 1859 </span> : * where it was found. If not found, returns npos. -<span class="lineNum"> 1860 </span> : */ -<span class="lineNum"> 1861 </span> : size_type -<span class="lineNum"> 1862 </span> : find_last_not_of(const basic_string& __str, size_type __pos = npos) const -<span class="lineNum"> 1863 </span> : { return this->find_last_not_of(__str.data(), __pos, __str.size()); } -<span class="lineNum"> 1864 </span> : -<span class="lineNum"> 1865 </span> : /** -<span class="lineNum"> 1866 </span> : * @brief Find last position of a character not in C substring. -<span class="lineNum"> 1867 </span> : * @param s C string containing characters to avoid. -<span class="lineNum"> 1868 </span> : * @param pos Index of character to search back from. -<span class="lineNum"> 1869 </span> : * @param n Number of characters from s to consider. -<span class="lineNum"> 1870 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1871 </span> : * -<span class="lineNum"> 1872 </span> : * Starting from @a pos, searches backward for a character not -<span class="lineNum"> 1873 </span> : * contained in the first @a n characters of @a s within this string. -<span class="lineNum"> 1874 </span> : * If found, returns the index where it was found. If not found, -<span class="lineNum"> 1875 </span> : * returns npos. -<span class="lineNum"> 1876 </span> : */ -<span class="lineNum"> 1877 </span> : size_type -<span class="lineNum"> 1878 </span> : find_last_not_of(const _CharT* __s, size_type __pos, -<span class="lineNum"> 1879 </span> : size_type __n) const; -<span class="lineNum"> 1880 </span> : /** -<span class="lineNum"> 1881 </span> : * @brief Find last position of a character not in C string. -<span class="lineNum"> 1882 </span> : * @param s C string containing characters to avoid. -<span class="lineNum"> 1883 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1884 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1885 </span> : * -<span class="lineNum"> 1886 </span> : * Starting from @a pos, searches backward for a character not -<span class="lineNum"> 1887 </span> : * contained in @a s within this string. If found, returns the index -<span class="lineNum"> 1888 </span> : * where it was found. If not found, returns npos. -<span class="lineNum"> 1889 </span> : */ -<span class="lineNum"> 1890 </span> : size_type -<span class="lineNum"> 1891 </span><span class="lineNoCov"> 0 : find_last_not_of(const _CharT* __s, size_type __pos = npos) const</span> -<span class="lineNum"> 1892 </span> : { -<span class="lineNum"> 1893 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 1894 </span><span class="lineNoCov"> 0 : return this->find_last_not_of(__s, __pos, traits_type::length(__s));</span> -<span class="lineNum"> 1895 </span> : } -<span class="lineNum"> 1896 </span> : -<span class="lineNum"> 1897 </span> : /** -<span class="lineNum"> 1898 </span> : * @brief Find last position of a different character. -<span class="lineNum"> 1899 </span> : * @param c Character to avoid. -<span class="lineNum"> 1900 </span> : * @param pos Index of character to search back from (default end). -<span class="lineNum"> 1901 </span> : * @return Index of last occurrence. -<span class="lineNum"> 1902 </span> : * -<span class="lineNum"> 1903 </span> : * Starting from @a pos, searches backward for a character other than -<span class="lineNum"> 1904 </span> : * @a c within this string. If found, returns the index where it was -<span class="lineNum"> 1905 </span> : * found. If not found, returns npos. -<span class="lineNum"> 1906 </span> : */ -<span class="lineNum"> 1907 </span> : size_type -<span class="lineNum"> 1908 </span> : find_last_not_of(_CharT __c, size_type __pos = npos) const; -<span class="lineNum"> 1909 </span> : -<span class="lineNum"> 1910 </span> : /** -<span class="lineNum"> 1911 </span> : * @brief Get a substring. -<span class="lineNum"> 1912 </span> : * @param pos Index of first character (default 0). -<span class="lineNum"> 1913 </span> : * @param n Number of characters in substring (default remainder). -<span class="lineNum"> 1914 </span> : * @return The new string. -<span class="lineNum"> 1915 </span> : * @throw std::out_of_range If pos > size(). -<span class="lineNum"> 1916 </span> : * -<span class="lineNum"> 1917 </span> : * Construct and return a new string using the @a n characters starting -<span class="lineNum"> 1918 </span> : * at @a pos. If the string is too short, use the remainder of the -<span class="lineNum"> 1919 </span> : * characters. If @a pos is beyond the end of the string, out_of_range -<span class="lineNum"> 1920 </span> : * is thrown. -<span class="lineNum"> 1921 </span> : */ -<span class="lineNum"> 1922 </span> : basic_string -<span class="lineNum"> 1923 </span><span class="lineNoCov"> 0 : substr(size_type __pos = 0, size_type __n = npos) const</span> -<span class="lineNum"> 1924 </span> : { return basic_string(*this, -<span class="lineNum"> 1925 </span><span class="lineNoCov"> 0 : _M_check(__pos, "basic_string::substr"), __n); }</span> -<span class="lineNum"> 1926 </span> : -<span class="lineNum"> 1927 </span> : /** -<span class="lineNum"> 1928 </span> : * @brief Compare to a string. -<span class="lineNum"> 1929 </span> : * @param str String to compare against. -<span class="lineNum"> 1930 </span> : * @return Integer < 0, 0, or > 0. -<span class="lineNum"> 1931 </span> : * -<span class="lineNum"> 1932 </span> : * Returns an integer < 0 if this string is ordered before @a str, 0 if -<span class="lineNum"> 1933 </span> : * their values are equivalent, or > 0 if this string is ordered after -<span class="lineNum"> 1934 </span> : * @a str. Determines the effective length rlen of the strings to -<span class="lineNum"> 1935 </span> : * compare as the smallest of size() and str.size(). The function -<span class="lineNum"> 1936 </span> : * then compares the two strings by calling traits::compare(data(), -<span class="lineNum"> 1937 </span> : * str.data(),rlen). If the result of the comparison is nonzero returns -<span class="lineNum"> 1938 </span> : * it, otherwise the shorter one is ordered first. -<span class="lineNum"> 1939 </span> : */ -<span class="lineNum"> 1940 </span> : int -<span class="lineNum"> 1941 </span><span class="lineNoCov"> 0 : compare(const basic_string& __str) const</span> -<span class="lineNum"> 1942 </span> : { -<span class="lineNum"> 1943 </span><span class="lineNoCov"> 0 : const size_type __size = this->size();</span> -<span class="lineNum"> 1944 </span><span class="lineNoCov"> 0 : const size_type __osize = __str.size();</span> -<span class="lineNum"> 1945 </span><span class="lineNoCov"> 0 : const size_type __len = std::min(__size, __osize);</span> -<span class="lineNum"> 1946 </span> : -<span class="lineNum"> 1947 </span><span class="lineNoCov"> 0 : int __r = traits_type::compare(_M_data(), __str.data(), __len);</span> -<span class="lineNum"> 1948 </span><span class="lineNoCov"> 0 : if (!__r)</span> -<span class="lineNum"> 1949 </span><span class="lineNoCov"> 0 : __r = _S_compare(__size, __osize);</span> -<span class="lineNum"> 1950 </span><span class="lineNoCov"> 0 : return __r;</span> -<span class="lineNum"> 1951 </span> : } -<span class="lineNum"> 1952 </span> : -<span class="lineNum"> 1953 </span> : /** -<span class="lineNum"> 1954 </span> : * @brief Compare substring to a string. -<span class="lineNum"> 1955 </span> : * @param pos Index of first character of substring. -<span class="lineNum"> 1956 </span> : * @param n Number of characters in substring. -<span class="lineNum"> 1957 </span> : * @param str String to compare against. -<span class="lineNum"> 1958 </span> : * @return Integer < 0, 0, or > 0. -<span class="lineNum"> 1959 </span> : * -<span class="lineNum"> 1960 </span> : * Form the substring of this string from the @a n characters starting -<span class="lineNum"> 1961 </span> : * at @a pos. Returns an integer < 0 if the substring is ordered -<span class="lineNum"> 1962 </span> : * before @a str, 0 if their values are equivalent, or > 0 if the -<span class="lineNum"> 1963 </span> : * substring is ordered after @a str. Determines the effective length -<span class="lineNum"> 1964 </span> : * rlen of the strings to compare as the smallest of the length of the -<span class="lineNum"> 1965 </span> : * substring and @a str.size(). The function then compares the two -<span class="lineNum"> 1966 </span> : * strings by calling traits::compare(substring.data(),str.data(),rlen). -<span class="lineNum"> 1967 </span> : * If the result of the comparison is nonzero returns it, otherwise the -<span class="lineNum"> 1968 </span> : * shorter one is ordered first. -<span class="lineNum"> 1969 </span> : */ -<span class="lineNum"> 1970 </span> : int -<span class="lineNum"> 1971 </span> : compare(size_type __pos, size_type __n, const basic_string& __str) const; -<span class="lineNum"> 1972 </span> : -<span class="lineNum"> 1973 </span> : /** -<span class="lineNum"> 1974 </span> : * @brief Compare substring to a substring. -<span class="lineNum"> 1975 </span> : * @param pos1 Index of first character of substring. -<span class="lineNum"> 1976 </span> : * @param n1 Number of characters in substring. -<span class="lineNum"> 1977 </span> : * @param str String to compare against. -<span class="lineNum"> 1978 </span> : * @param pos2 Index of first character of substring of str. -<span class="lineNum"> 1979 </span> : * @param n2 Number of characters in substring of str. -<span class="lineNum"> 1980 </span> : * @return Integer < 0, 0, or > 0. -<span class="lineNum"> 1981 </span> : * -<span class="lineNum"> 1982 </span> : * Form the substring of this string from the @a n1 characters starting -<span class="lineNum"> 1983 </span> : * at @a pos1. Form the substring of @a str from the @a n2 characters -<span class="lineNum"> 1984 </span> : * starting at @a pos2. Returns an integer < 0 if this substring is -<span class="lineNum"> 1985 </span> : * ordered before the substring of @a str, 0 if their values are -<span class="lineNum"> 1986 </span> : * equivalent, or > 0 if this substring is ordered after the substring -<span class="lineNum"> 1987 </span> : * of @a str. Determines the effective length rlen of the strings -<span class="lineNum"> 1988 </span> : * to compare as the smallest of the lengths of the substrings. The -<span class="lineNum"> 1989 </span> : * function then compares the two strings by calling -<span class="lineNum"> 1990 </span> : * traits::compare(substring.data(),str.substr(pos2,n2).data(),rlen). -<span class="lineNum"> 1991 </span> : * If the result of the comparison is nonzero returns it, otherwise the -<span class="lineNum"> 1992 </span> : * shorter one is ordered first. -<span class="lineNum"> 1993 </span> : */ -<span class="lineNum"> 1994 </span> : int -<span class="lineNum"> 1995 </span> : compare(size_type __pos1, size_type __n1, const basic_string& __str, -<span class="lineNum"> 1996 </span> : size_type __pos2, size_type __n2) const; -<span class="lineNum"> 1997 </span> : -<span class="lineNum"> 1998 </span> : /** -<span class="lineNum"> 1999 </span> : * @brief Compare to a C string. -<span class="lineNum"> 2000 </span> : * @param s C string to compare against. -<span class="lineNum"> 2001 </span> : * @return Integer < 0, 0, or > 0. -<span class="lineNum"> 2002 </span> : * -<span class="lineNum"> 2003 </span> : * Returns an integer < 0 if this string is ordered before @a s, 0 if -<span class="lineNum"> 2004 </span> : * their values are equivalent, or > 0 if this string is ordered after -<span class="lineNum"> 2005 </span> : * @a s. Determines the effective length rlen of the strings to -<span class="lineNum"> 2006 </span> : * compare as the smallest of size() and the length of a string -<span class="lineNum"> 2007 </span> : * constructed from @a s. The function then compares the two strings -<span class="lineNum"> 2008 </span> : * by calling traits::compare(data(),s,rlen). If the result of the -<span class="lineNum"> 2009 </span> : * comparison is nonzero returns it, otherwise the shorter one is -<span class="lineNum"> 2010 </span> : * ordered first. -<span class="lineNum"> 2011 </span> : */ -<span class="lineNum"> 2012 </span> : int -<span class="lineNum"> 2013 </span> : compare(const _CharT* __s) const; -<span class="lineNum"> 2014 </span> : -<span class="lineNum"> 2015 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 2016 </span> : // 5 String::compare specification questionable -<span class="lineNum"> 2017 </span> : /** -<span class="lineNum"> 2018 </span> : * @brief Compare substring to a C string. -<span class="lineNum"> 2019 </span> : * @param pos Index of first character of substring. -<span class="lineNum"> 2020 </span> : * @param n1 Number of characters in substring. -<span class="lineNum"> 2021 </span> : * @param s C string to compare against. -<span class="lineNum"> 2022 </span> : * @return Integer < 0, 0, or > 0. -<span class="lineNum"> 2023 </span> : * -<span class="lineNum"> 2024 </span> : * Form the substring of this string from the @a n1 characters starting -<span class="lineNum"> 2025 </span> : * at @a pos. Returns an integer < 0 if the substring is ordered -<span class="lineNum"> 2026 </span> : * before @a s, 0 if their values are equivalent, or > 0 if the -<span class="lineNum"> 2027 </span> : * substring is ordered after @a s. Determines the effective length -<span class="lineNum"> 2028 </span> : * rlen of the strings to compare as the smallest of the length of the -<span class="lineNum"> 2029 </span> : * substring and the length of a string constructed from @a s. The -<span class="lineNum"> 2030 </span> : * function then compares the two string by calling -<span class="lineNum"> 2031 </span> : * traits::compare(substring.data(),s,rlen). If the result of the -<span class="lineNum"> 2032 </span> : * comparison is nonzero returns it, otherwise the shorter one is -<span class="lineNum"> 2033 </span> : * ordered first. -<span class="lineNum"> 2034 </span> : */ -<span class="lineNum"> 2035 </span> : int -<span class="lineNum"> 2036 </span> : compare(size_type __pos, size_type __n1, const _CharT* __s) const; -<span class="lineNum"> 2037 </span> : -<span class="lineNum"> 2038 </span> : /** -<span class="lineNum"> 2039 </span> : * @brief Compare substring against a character array. -<span class="lineNum"> 2040 </span> : * @param pos1 Index of first character of substring. -<span class="lineNum"> 2041 </span> : * @param n1 Number of characters in substring. -<span class="lineNum"> 2042 </span> : * @param s character array to compare against. -<span class="lineNum"> 2043 </span> : * @param n2 Number of characters of s. -<span class="lineNum"> 2044 </span> : * @return Integer < 0, 0, or > 0. -<span class="lineNum"> 2045 </span> : * -<span class="lineNum"> 2046 </span> : * Form the substring of this string from the @a n1 characters starting -<span class="lineNum"> 2047 </span> : * at @a pos1. Form a string from the first @a n2 characters of @a s. -<span class="lineNum"> 2048 </span> : * Returns an integer < 0 if this substring is ordered before the string -<span class="lineNum"> 2049 </span> : * from @a s, 0 if their values are equivalent, or > 0 if this substring -<span class="lineNum"> 2050 </span> : * is ordered after the string from @a s. Determines the effective -<span class="lineNum"> 2051 </span> : * length rlen of the strings to compare as the smallest of the length -<span class="lineNum"> 2052 </span> : * of the substring and @a n2. The function then compares the two -<span class="lineNum"> 2053 </span> : * strings by calling traits::compare(substring.data(),s,rlen). If the -<span class="lineNum"> 2054 </span> : * result of the comparison is nonzero returns it, otherwise the shorter -<span class="lineNum"> 2055 </span> : * one is ordered first. -<span class="lineNum"> 2056 </span> : * -<span class="lineNum"> 2057 </span> : * NB: s must have at least n2 characters, '\0' has no special -<span class="lineNum"> 2058 </span> : * meaning. -<span class="lineNum"> 2059 </span> : */ -<span class="lineNum"> 2060 </span> : int -<span class="lineNum"> 2061 </span> : compare(size_type __pos, size_type __n1, const _CharT* __s, -<span class="lineNum"> 2062 </span> : size_type __n2) const; -<span class="lineNum"> 2063 </span> : }; -<span class="lineNum"> 2064 </span> : -<span class="lineNum"> 2065 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2066 </span> : inline basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 2067 </span><span class="lineNoCov"> 0 : basic_string()</span> -<span class="lineNum"> 2068 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 2069 </span><span class="lineNoCov"> 0 : : _M_dataplus(_S_empty_rep()._M_refdata(), _Alloc()) { }</span> -<span class="lineNum"> 2070 </span> : #else -<span class="lineNum"> 2071 </span> : : _M_dataplus(_S_construct(size_type(), _CharT(), _Alloc()), _Alloc()) { } -<span class="lineNum"> 2072 </span> : #endif -<span class="lineNum"> 2073 </span> : -<span class="lineNum"> 2074 </span> : // operator+ -<span class="lineNum"> 2075 </span> : /** -<span class="lineNum"> 2076 </span> : * @brief Concatenate two strings. -<span class="lineNum"> 2077 </span> : * @param lhs First string. -<span class="lineNum"> 2078 </span> : * @param rhs Last string. -<span class="lineNum"> 2079 </span> : * @return New string with value of @a lhs followed by @a rhs. -<span class="lineNum"> 2080 </span> : */ -<span class="lineNum"> 2081 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2082 </span> : basic_string<_CharT, _Traits, _Alloc> -<span class="lineNum"> 2083 </span> : operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2084 </span><span class="lineCov"> 715370 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2085 </span> : { -<span class="lineNum"> 2086 </span><span class="lineCov"> 715370 : basic_string<_CharT, _Traits, _Alloc> __str(__lhs);</span> -<span class="lineNum"> 2087 </span><span class="lineCov"> 715370 : __str.append(__rhs);</span> -<span class="lineNum"> 2088 </span><span class="lineNoCov"> 0 : return __str;</span> -<span class="lineNum"> 2089 </span> : } -<span class="lineNum"> 2090 </span> : -<span class="lineNum"> 2091 </span> : /** -<span class="lineNum"> 2092 </span> : * @brief Concatenate C string and string. -<span class="lineNum"> 2093 </span> : * @param lhs First string. -<span class="lineNum"> 2094 </span> : * @param rhs Last string. -<span class="lineNum"> 2095 </span> : * @return New string with value of @a lhs followed by @a rhs. -<span class="lineNum"> 2096 </span> : */ -<span class="lineNum"> 2097 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2098 </span> : basic_string<_CharT,_Traits,_Alloc> -<span class="lineNum"> 2099 </span> : operator+(const _CharT* __lhs, -<span class="lineNum"> 2100 </span> : const basic_string<_CharT,_Traits,_Alloc>& __rhs); -<span class="lineNum"> 2101 </span> : -<span class="lineNum"> 2102 </span> : /** -<span class="lineNum"> 2103 </span> : * @brief Concatenate character and string. -<span class="lineNum"> 2104 </span> : * @param lhs First string. -<span class="lineNum"> 2105 </span> : * @param rhs Last string. -<span class="lineNum"> 2106 </span> : * @return New string with @a lhs followed by @a rhs. -<span class="lineNum"> 2107 </span> : */ -<span class="lineNum"> 2108 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2109 </span> : basic_string<_CharT,_Traits,_Alloc> -<span class="lineNum"> 2110 </span> : operator+(_CharT __lhs, const basic_string<_CharT,_Traits,_Alloc>& __rhs); -<span class="lineNum"> 2111 </span> : -<span class="lineNum"> 2112 </span> : /** -<span class="lineNum"> 2113 </span> : * @brief Concatenate string and C string. -<span class="lineNum"> 2114 </span> : * @param lhs First string. -<span class="lineNum"> 2115 </span> : * @param rhs Last string. -<span class="lineNum"> 2116 </span> : * @return New string with @a lhs followed by @a rhs. -<span class="lineNum"> 2117 </span> : */ -<span class="lineNum"> 2118 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2119 </span> : inline basic_string<_CharT, _Traits, _Alloc> -<span class="lineNum"> 2120 </span> : operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2121 </span><span class="lineCov"> 5962 : const _CharT* __rhs)</span> -<span class="lineNum"> 2122 </span> : { -<span class="lineNum"> 2123 </span><span class="lineCov"> 5962 : basic_string<_CharT, _Traits, _Alloc> __str(__lhs);</span> -<span class="lineNum"> 2124 </span><span class="lineCov"> 5962 : __str.append(__rhs);</span> -<span class="lineNum"> 2125 </span><span class="lineNoCov"> 0 : return __str;</span> -<span class="lineNum"> 2126 </span> : } -<span class="lineNum"> 2127 </span> : -<span class="lineNum"> 2128 </span> : /** -<span class="lineNum"> 2129 </span> : * @brief Concatenate string and character. -<span class="lineNum"> 2130 </span> : * @param lhs First string. -<span class="lineNum"> 2131 </span> : * @param rhs Last string. -<span class="lineNum"> 2132 </span> : * @return New string with @a lhs followed by @a rhs. -<span class="lineNum"> 2133 </span> : */ -<span class="lineNum"> 2134 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2135 </span> : inline basic_string<_CharT, _Traits, _Alloc> -<span class="lineNum"> 2136 </span><span class="lineCov"> 140 : operator+(const basic_string<_CharT, _Traits, _Alloc>& __lhs, _CharT __rhs)</span> -<span class="lineNum"> 2137 </span> : { -<span class="lineNum"> 2138 </span> : typedef basic_string<_CharT, _Traits, _Alloc> __string_type; -<span class="lineNum"> 2139 </span> : typedef typename __string_type::size_type __size_type; -<span class="lineNum"> 2140 </span><span class="lineCov"> 140 : __string_type __str(__lhs);</span> -<span class="lineNum"> 2141 </span><span class="lineCov"> 140 : __str.append(__size_type(1), __rhs);</span> -<span class="lineNum"> 2142 </span><span class="lineNoCov"> 0 : return __str;</span> -<span class="lineNum"> 2143 </span> : } -<span class="lineNum"> 2144 </span> : -<span class="lineNum"> 2145 </span> : // operator == -<span class="lineNum"> 2146 </span> : /** -<span class="lineNum"> 2147 </span> : * @brief Test equivalence of two strings. -<span class="lineNum"> 2148 </span> : * @param lhs First string. -<span class="lineNum"> 2149 </span> : * @param rhs Second string. -<span class="lineNum"> 2150 </span> : * @return True if @a lhs.compare(@a rhs) == 0. False otherwise. -<span class="lineNum"> 2151 </span> : */ -<span class="lineNum"> 2152 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2153 </span> : inline bool -<span class="lineNum"> 2154 </span> : operator==(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2155 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2156 </span> : { return __lhs.compare(__rhs) == 0; } -<span class="lineNum"> 2157 </span> : -<span class="lineNum"> 2158 </span> : template<typename _CharT> -<span class="lineNum"> 2159 </span> : inline -<span class="lineNum"> 2160 </span> : typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, bool>::__type -<span class="lineNum"> 2161 </span> : operator==(const basic_string<_CharT>& __lhs, -<span class="lineNum"> 2162 </span><span class="lineCov"> 134945 : const basic_string<_CharT>& __rhs)</span> -<span class="lineNum"> 2163 </span> : { return (__lhs.size() == __rhs.size() -<span class="lineNum"> 2164 </span> : && !std::char_traits<_CharT>::compare(__lhs.data(), __rhs.data(), -<span class="lineNum"> 2165 </span><span class="lineCov"> 134945 : __lhs.size())); }</span> -<span class="lineNum"> 2166 </span> : -<span class="lineNum"> 2167 </span> : /** -<span class="lineNum"> 2168 </span> : * @brief Test equivalence of C string and string. -<span class="lineNum"> 2169 </span> : * @param lhs C string. -<span class="lineNum"> 2170 </span> : * @param rhs String. -<span class="lineNum"> 2171 </span> : * @return True if @a rhs.compare(@a lhs) == 0. False otherwise. -<span class="lineNum"> 2172 </span> : */ -<span class="lineNum"> 2173 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2174 </span> : inline bool -<span class="lineNum"> 2175 </span> : operator==(const _CharT* __lhs, -<span class="lineNum"> 2176 </span><span class="lineNoCov"> 0 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2177 </span><span class="lineNoCov"> 0 : { return __rhs.compare(__lhs) == 0; }</span> -<span class="lineNum"> 2178 </span> : -<span class="lineNum"> 2179 </span> : /** -<span class="lineNum"> 2180 </span> : * @brief Test equivalence of string and C string. -<span class="lineNum"> 2181 </span> : * @param lhs String. -<span class="lineNum"> 2182 </span> : * @param rhs C string. -<span class="lineNum"> 2183 </span> : * @return True if @a lhs.compare(@a rhs) == 0. False otherwise. -<span class="lineNum"> 2184 </span> : */ -<span class="lineNum"> 2185 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2186 </span> : inline bool -<span class="lineNum"> 2187 </span> : operator==(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2188 </span><span class="lineCov"> 156952 : const _CharT* __rhs)</span> -<span class="lineNum"> 2189 </span><span class="lineCov"> 156952 : { return __lhs.compare(__rhs) == 0; }</span> -<span class="lineNum"> 2190 </span> : -<span class="lineNum"> 2191 </span> : // operator != -<span class="lineNum"> 2192 </span> : /** -<span class="lineNum"> 2193 </span> : * @brief Test difference of two strings. -<span class="lineNum"> 2194 </span> : * @param lhs First string. -<span class="lineNum"> 2195 </span> : * @param rhs Second string. -<span class="lineNum"> 2196 </span> : * @return True if @a lhs.compare(@a rhs) != 0. False otherwise. -<span class="lineNum"> 2197 </span> : */ -<span class="lineNum"> 2198 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2199 </span> : inline bool -<span class="lineNum"> 2200 </span> : operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2201 </span><span class="lineCov"> 84867 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2202 </span><span class="lineCov"> 84867 : { return !(__lhs == __rhs); }</span> -<span class="lineNum"> 2203 </span> : -<span class="lineNum"> 2204 </span> : /** -<span class="lineNum"> 2205 </span> : * @brief Test difference of C string and string. -<span class="lineNum"> 2206 </span> : * @param lhs C string. -<span class="lineNum"> 2207 </span> : * @param rhs String. -<span class="lineNum"> 2208 </span> : * @return True if @a rhs.compare(@a lhs) != 0. False otherwise. -<span class="lineNum"> 2209 </span> : */ -<span class="lineNum"> 2210 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2211 </span> : inline bool -<span class="lineNum"> 2212 </span> : operator!=(const _CharT* __lhs, -<span class="lineNum"> 2213 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2214 </span> : { return !(__lhs == __rhs); } -<span class="lineNum"> 2215 </span> : -<span class="lineNum"> 2216 </span> : /** -<span class="lineNum"> 2217 </span> : * @brief Test difference of string and C string. -<span class="lineNum"> 2218 </span> : * @param lhs String. -<span class="lineNum"> 2219 </span> : * @param rhs C string. -<span class="lineNum"> 2220 </span> : * @return True if @a lhs.compare(@a rhs) != 0. False otherwise. -<span class="lineNum"> 2221 </span> : */ -<span class="lineNum"> 2222 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2223 </span> : inline bool -<span class="lineNum"> 2224 </span> : operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2225 </span><span class="lineCov"> 74475 : const _CharT* __rhs)</span> -<span class="lineNum"> 2226 </span><span class="lineCov"> 74475 : { return !(__lhs == __rhs); }</span> -<span class="lineNum"> 2227 </span> : -<span class="lineNum"> 2228 </span> : // operator < -<span class="lineNum"> 2229 </span> : /** -<span class="lineNum"> 2230 </span> : * @brief Test if string precedes string. -<span class="lineNum"> 2231 </span> : * @param lhs First string. -<span class="lineNum"> 2232 </span> : * @param rhs Second string. -<span class="lineNum"> 2233 </span> : * @return True if @a lhs precedes @a rhs. False otherwise. -<span class="lineNum"> 2234 </span> : */ -<span class="lineNum"> 2235 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2236 </span> : inline bool -<span class="lineNum"> 2237 </span> : operator<(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2238 </span><span class="lineCov"> 4885154 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2239 </span><span class="lineCov"> 4885154 : { return __lhs.compare(__rhs) < 0; }</span> -<span class="lineNum"> 2240 </span> : -<span class="lineNum"> 2241 </span> : /** -<span class="lineNum"> 2242 </span> : * @brief Test if string precedes C string. -<span class="lineNum"> 2243 </span> : * @param lhs String. -<span class="lineNum"> 2244 </span> : * @param rhs C string. -<span class="lineNum"> 2245 </span> : * @return True if @a lhs precedes @a rhs. False otherwise. -<span class="lineNum"> 2246 </span> : */ -<span class="lineNum"> 2247 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2248 </span> : inline bool -<span class="lineNum"> 2249 </span> : operator<(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2250 </span> : const _CharT* __rhs) -<span class="lineNum"> 2251 </span> : { return __lhs.compare(__rhs) < 0; } -<span class="lineNum"> 2252 </span> : -<span class="lineNum"> 2253 </span> : /** -<span class="lineNum"> 2254 </span> : * @brief Test if C string precedes string. -<span class="lineNum"> 2255 </span> : * @param lhs C string. -<span class="lineNum"> 2256 </span> : * @param rhs String. -<span class="lineNum"> 2257 </span> : * @return True if @a lhs precedes @a rhs. False otherwise. -<span class="lineNum"> 2258 </span> : */ -<span class="lineNum"> 2259 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2260 </span> : inline bool -<span class="lineNum"> 2261 </span> : operator<(const _CharT* __lhs, -<span class="lineNum"> 2262 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2263 </span> : { return __rhs.compare(__lhs) > 0; } -<span class="lineNum"> 2264 </span> : -<span class="lineNum"> 2265 </span> : // operator > -<span class="lineNum"> 2266 </span> : /** -<span class="lineNum"> 2267 </span> : * @brief Test if string follows string. -<span class="lineNum"> 2268 </span> : * @param lhs First string. -<span class="lineNum"> 2269 </span> : * @param rhs Second string. -<span class="lineNum"> 2270 </span> : * @return True if @a lhs follows @a rhs. False otherwise. -<span class="lineNum"> 2271 </span> : */ -<span class="lineNum"> 2272 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2273 </span> : inline bool -<span class="lineNum"> 2274 </span> : operator>(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2275 </span><span class="lineCov"> 1024110 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2276 </span><span class="lineCov"> 1024110 : { return __lhs.compare(__rhs) > 0; }</span> -<span class="lineNum"> 2277 </span> : -<span class="lineNum"> 2278 </span> : /** -<span class="lineNum"> 2279 </span> : * @brief Test if string follows C string. -<span class="lineNum"> 2280 </span> : * @param lhs String. -<span class="lineNum"> 2281 </span> : * @param rhs C string. -<span class="lineNum"> 2282 </span> : * @return True if @a lhs follows @a rhs. False otherwise. -<span class="lineNum"> 2283 </span> : */ -<span class="lineNum"> 2284 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2285 </span> : inline bool -<span class="lineNum"> 2286 </span> : operator>(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2287 </span> : const _CharT* __rhs) -<span class="lineNum"> 2288 </span> : { return __lhs.compare(__rhs) > 0; } -<span class="lineNum"> 2289 </span> : -<span class="lineNum"> 2290 </span> : /** -<span class="lineNum"> 2291 </span> : * @brief Test if C string follows string. -<span class="lineNum"> 2292 </span> : * @param lhs C string. -<span class="lineNum"> 2293 </span> : * @param rhs String. -<span class="lineNum"> 2294 </span> : * @return True if @a lhs follows @a rhs. False otherwise. -<span class="lineNum"> 2295 </span> : */ -<span class="lineNum"> 2296 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2297 </span> : inline bool -<span class="lineNum"> 2298 </span> : operator>(const _CharT* __lhs, -<span class="lineNum"> 2299 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2300 </span> : { return __rhs.compare(__lhs) < 0; } -<span class="lineNum"> 2301 </span> : -<span class="lineNum"> 2302 </span> : // operator <= -<span class="lineNum"> 2303 </span> : /** -<span class="lineNum"> 2304 </span> : * @brief Test if string doesn't follow string. -<span class="lineNum"> 2305 </span> : * @param lhs First string. -<span class="lineNum"> 2306 </span> : * @param rhs Second string. -<span class="lineNum"> 2307 </span> : * @return True if @a lhs doesn't follow @a rhs. False otherwise. -<span class="lineNum"> 2308 </span> : */ -<span class="lineNum"> 2309 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2310 </span> : inline bool -<span class="lineNum"> 2311 </span> : operator<=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2312 </span><span class="lineCov"> 58 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2313 </span><span class="lineCov"> 58 : { return __lhs.compare(__rhs) <= 0; }</span> -<span class="lineNum"> 2314 </span> : -<span class="lineNum"> 2315 </span> : /** -<span class="lineNum"> 2316 </span> : * @brief Test if string doesn't follow C string. -<span class="lineNum"> 2317 </span> : * @param lhs String. -<span class="lineNum"> 2318 </span> : * @param rhs C string. -<span class="lineNum"> 2319 </span> : * @return True if @a lhs doesn't follow @a rhs. False otherwise. -<span class="lineNum"> 2320 </span> : */ -<span class="lineNum"> 2321 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2322 </span> : inline bool -<span class="lineNum"> 2323 </span> : operator<=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2324 </span> : const _CharT* __rhs) -<span class="lineNum"> 2325 </span> : { return __lhs.compare(__rhs) <= 0; } -<span class="lineNum"> 2326 </span> : -<span class="lineNum"> 2327 </span> : /** -<span class="lineNum"> 2328 </span> : * @brief Test if C string doesn't follow string. -<span class="lineNum"> 2329 </span> : * @param lhs C string. -<span class="lineNum"> 2330 </span> : * @param rhs String. -<span class="lineNum"> 2331 </span> : * @return True if @a lhs doesn't follow @a rhs. False otherwise. -<span class="lineNum"> 2332 </span> : */ -<span class="lineNum"> 2333 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2334 </span> : inline bool -<span class="lineNum"> 2335 </span> : operator<=(const _CharT* __lhs, -<span class="lineNum"> 2336 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2337 </span> : { return __rhs.compare(__lhs) >= 0; } -<span class="lineNum"> 2338 </span> : -<span class="lineNum"> 2339 </span> : // operator >= -<span class="lineNum"> 2340 </span> : /** -<span class="lineNum"> 2341 </span> : * @brief Test if string doesn't precede string. -<span class="lineNum"> 2342 </span> : * @param lhs First string. -<span class="lineNum"> 2343 </span> : * @param rhs Second string. -<span class="lineNum"> 2344 </span> : * @return True if @a lhs doesn't precede @a rhs. False otherwise. -<span class="lineNum"> 2345 </span> : */ -<span class="lineNum"> 2346 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2347 </span> : inline bool -<span class="lineNum"> 2348 </span> : operator>=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2349 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2350 </span> : { return __lhs.compare(__rhs) >= 0; } -<span class="lineNum"> 2351 </span> : -<span class="lineNum"> 2352 </span> : /** -<span class="lineNum"> 2353 </span> : * @brief Test if string doesn't precede C string. -<span class="lineNum"> 2354 </span> : * @param lhs String. -<span class="lineNum"> 2355 </span> : * @param rhs C string. -<span class="lineNum"> 2356 </span> : * @return True if @a lhs doesn't precede @a rhs. False otherwise. -<span class="lineNum"> 2357 </span> : */ -<span class="lineNum"> 2358 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2359 </span> : inline bool -<span class="lineNum"> 2360 </span> : operator>=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2361 </span> : const _CharT* __rhs) -<span class="lineNum"> 2362 </span> : { return __lhs.compare(__rhs) >= 0; } -<span class="lineNum"> 2363 </span> : -<span class="lineNum"> 2364 </span> : /** -<span class="lineNum"> 2365 </span> : * @brief Test if C string doesn't precede string. -<span class="lineNum"> 2366 </span> : * @param lhs C string. -<span class="lineNum"> 2367 </span> : * @param rhs String. -<span class="lineNum"> 2368 </span> : * @return True if @a lhs doesn't precede @a rhs. False otherwise. -<span class="lineNum"> 2369 </span> : */ -<span class="lineNum"> 2370 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2371 </span> : inline bool -<span class="lineNum"> 2372 </span> : operator>=(const _CharT* __lhs, -<span class="lineNum"> 2373 </span> : const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 2374 </span> : { return __rhs.compare(__lhs) <= 0; } -<span class="lineNum"> 2375 </span> : -<span class="lineNum"> 2376 </span> : /** -<span class="lineNum"> 2377 </span> : * @brief Swap contents of two strings. -<span class="lineNum"> 2378 </span> : * @param lhs First string. -<span class="lineNum"> 2379 </span> : * @param rhs Second string. -<span class="lineNum"> 2380 </span> : * -<span class="lineNum"> 2381 </span> : * Exchanges the contents of @a lhs and @a rhs in constant time. -<span class="lineNum"> 2382 </span> : */ -<span class="lineNum"> 2383 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2384 </span> : inline void -<span class="lineNum"> 2385 </span> : swap(basic_string<_CharT, _Traits, _Alloc>& __lhs, -<span class="lineNum"> 2386 </span><span class="lineNoCov"> 0 : basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 2387 </span><span class="lineNoCov"> 0 : { __lhs.swap(__rhs); }</span> -<span class="lineNum"> 2388 </span> : -<span class="lineNum"> 2389 </span> : /** -<span class="lineNum"> 2390 </span> : * @brief Read stream into a string. -<span class="lineNum"> 2391 </span> : * @param is Input stream. -<span class="lineNum"> 2392 </span> : * @param str Buffer to store into. -<span class="lineNum"> 2393 </span> : * @return Reference to the input stream. -<span class="lineNum"> 2394 </span> : * -<span class="lineNum"> 2395 </span> : * Stores characters from @a is into @a str until whitespace is found, the -<span class="lineNum"> 2396 </span> : * end of the stream is encountered, or str.max_size() is reached. If -<span class="lineNum"> 2397 </span> : * is.width() is non-zero, that is the limit on the number of characters -<span class="lineNum"> 2398 </span> : * stored into @a str. Any previous contents of @a str are erased. -<span class="lineNum"> 2399 </span> : */ -<span class="lineNum"> 2400 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2401 </span> : basic_istream<_CharT, _Traits>& -<span class="lineNum"> 2402 </span> : operator>>(basic_istream<_CharT, _Traits>& __is, -<span class="lineNum"> 2403 </span> : basic_string<_CharT, _Traits, _Alloc>& __str); -<span class="lineNum"> 2404 </span> : -<span class="lineNum"> 2405 </span> : template<> -<span class="lineNum"> 2406 </span> : basic_istream<char>& -<span class="lineNum"> 2407 </span> : operator>>(basic_istream<char>& __is, basic_string<char>& __str); -<span class="lineNum"> 2408 </span> : -<span class="lineNum"> 2409 </span> : /** -<span class="lineNum"> 2410 </span> : * @brief Write string to a stream. -<span class="lineNum"> 2411 </span> : * @param os Output stream. -<span class="lineNum"> 2412 </span> : * @param str String to write out. -<span class="lineNum"> 2413 </span> : * @return Reference to the output stream. -<span class="lineNum"> 2414 </span> : * -<span class="lineNum"> 2415 </span> : * Output characters of @a str into os following the same rules as for -<span class="lineNum"> 2416 </span> : * writing a C string. -<span class="lineNum"> 2417 </span> : */ -<span class="lineNum"> 2418 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2419 </span> : inline basic_ostream<_CharT, _Traits>& -<span class="lineNum"> 2420 </span> : operator<<(basic_ostream<_CharT, _Traits>& __os, -<span class="lineNum"> 2421 </span><span class="lineNoCov"> 0 : const basic_string<_CharT, _Traits, _Alloc>& __str)</span> -<span class="lineNum"> 2422 </span> : { -<span class="lineNum"> 2423 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 2424 </span> : // 586. string inserter not a formatted function -<span class="lineNum"> 2425 </span><span class="lineNoCov"> 0 : return __ostream_insert(__os, __str.data(), __str.size());</span> -<span class="lineNum"> 2426 </span> : } -<span class="lineNum"> 2427 </span> : -<span class="lineNum"> 2428 </span> : /** -<span class="lineNum"> 2429 </span> : * @brief Read a line from stream into a string. -<span class="lineNum"> 2430 </span> : * @param is Input stream. -<span class="lineNum"> 2431 </span> : * @param str Buffer to store into. -<span class="lineNum"> 2432 </span> : * @param delim Character marking end of line. -<span class="lineNum"> 2433 </span> : * @return Reference to the input stream. -<span class="lineNum"> 2434 </span> : * -<span class="lineNum"> 2435 </span> : * Stores characters from @a is into @a str until @a delim is found, the -<span class="lineNum"> 2436 </span> : * end of the stream is encountered, or str.max_size() is reached. If -<span class="lineNum"> 2437 </span> : * is.width() is non-zero, that is the limit on the number of characters -<span class="lineNum"> 2438 </span> : * stored into @a str. Any previous contents of @a str are erased. If @a -<span class="lineNum"> 2439 </span> : * delim was encountered, it is extracted but not stored into @a str. -<span class="lineNum"> 2440 </span> : */ -<span class="lineNum"> 2441 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2442 </span> : basic_istream<_CharT, _Traits>& -<span class="lineNum"> 2443 </span> : getline(basic_istream<_CharT, _Traits>& __is, -<span class="lineNum"> 2444 </span> : basic_string<_CharT, _Traits, _Alloc>& __str, _CharT __delim); -<span class="lineNum"> 2445 </span> : -<span class="lineNum"> 2446 </span> : /** -<span class="lineNum"> 2447 </span> : * @brief Read a line from stream into a string. -<span class="lineNum"> 2448 </span> : * @param is Input stream. -<span class="lineNum"> 2449 </span> : * @param str Buffer to store into. -<span class="lineNum"> 2450 </span> : * @return Reference to the input stream. -<span class="lineNum"> 2451 </span> : * -<span class="lineNum"> 2452 </span> : * Stores characters from is into @a str until '\n' is found, the end of -<span class="lineNum"> 2453 </span> : * the stream is encountered, or str.max_size() is reached. If is.width() -<span class="lineNum"> 2454 </span> : * is non-zero, that is the limit on the number of characters stored into -<span class="lineNum"> 2455 </span> : * @a str. Any previous contents of @a str are erased. If end of line was -<span class="lineNum"> 2456 </span> : * encountered, it is extracted but not stored into @a str. -<span class="lineNum"> 2457 </span> : */ -<span class="lineNum"> 2458 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 2459 </span> : inline basic_istream<_CharT, _Traits>& -<span class="lineNum"> 2460 </span> : getline(basic_istream<_CharT, _Traits>& __is, -<span class="lineNum"> 2461 </span><span class="lineNoCov"> 0 : basic_string<_CharT, _Traits, _Alloc>& __str)</span> -<span class="lineNum"> 2462 </span><span class="lineNoCov"> 0 : { return getline(__is, __str, __is.widen('\n')); }</span> -<span class="lineNum"> 2463 </span> : -<span class="lineNum"> 2464 </span> : template<> -<span class="lineNum"> 2465 </span> : basic_istream<char>& -<span class="lineNum"> 2466 </span> : getline(basic_istream<char>& __in, basic_string<char>& __str, -<span class="lineNum"> 2467 </span> : char __delim); -<span class="lineNum"> 2468 </span> : -<span class="lineNum"> 2469 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 2470 </span> : template<> -<span class="lineNum"> 2471 </span> : basic_istream<wchar_t>& -<span class="lineNum"> 2472 </span> : getline(basic_istream<wchar_t>& __in, basic_string<wchar_t>& __str, -<span class="lineNum"> 2473 </span> : wchar_t __delim); -<span class="lineNum"> 2474 </span> : #endif -<span class="lineNum"> 2475 </span> : -<span class="lineNum"> 2476 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 2477 </span> : -<span class="lineNum"> 2478 </span> : #endif /* _BASIC_STRING_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/basic_string.tcc.gcov.html b/rep/usr/include/c++/4.3/bits/basic_string.tcc.gcov.html deleted file mode 100644 index 169e3e7..0000000 --- a/rep/usr/include/c++/4.3/bits/basic_string.tcc.gcov.html +++ /dev/null @@ -1,1208 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/basic_string.tcc</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - basic_string.tcc</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">23</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">73.9 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">17</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Components for manipulating sequences of characters -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file basic_string.tcc -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : // -<span class="lineNum"> 38 </span> : // ISO C++ 14882: 21 Strings library -<span class="lineNum"> 39 </span> : // -<span class="lineNum"> 40 </span> : -<span class="lineNum"> 41 </span> : // Written by Jason Merrill based upon the specification by Takanori Adachi -<span class="lineNum"> 42 </span> : // in ANSI X3J16/94-0013R2. Rewritten by Nathan Myers to ISO-14882. -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : #ifndef _BASIC_STRING_TCC -<span class="lineNum"> 45 </span> : #define _BASIC_STRING_TCC 1 -<span class="lineNum"> 46 </span> : -<span class="lineNum"> 47 </span> : #pragma GCC system_header -<span class="lineNum"> 48 </span> : -<span class="lineNum"> 49 </span> : #include <cxxabi-forced.h> -<span class="lineNum"> 50 </span> : -<span class="lineNum"> 51 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 52 </span> : -<span class="lineNum"> 53 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 54 </span> : const typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 55 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 56 </span> : _Rep::_S_max_size = (((npos - sizeof(_Rep_base))/sizeof(_CharT)) - 1) / 4; -<span class="lineNum"> 57 </span> : -<span class="lineNum"> 58 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 59 </span> : const _CharT -<span class="lineNum"> 60 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 61 </span> : _Rep::_S_terminal = _CharT(); -<span class="lineNum"> 62 </span> : -<span class="lineNum"> 63 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 64 </span> : const typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 65 </span> : basic_string<_CharT, _Traits, _Alloc>::npos; -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : // Linker sets _S_empty_rep_storage to all 0s (one reference, empty string) -<span class="lineNum"> 68 </span> : // at static init time (before static ctors are run). -<span class="lineNum"> 69 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 70 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 71 </span> : basic_string<_CharT, _Traits, _Alloc>::_Rep::_S_empty_rep_storage[ -<span class="lineNum"> 72 </span> : (sizeof(_Rep_base) + sizeof(_CharT) + sizeof(size_type) - 1) / -<span class="lineNum"> 73 </span> : sizeof(size_type)]; -<span class="lineNum"> 74 </span> : -<span class="lineNum"> 75 </span> : // NB: This is the special case for Input Iterators, used in -<span class="lineNum"> 76 </span> : // istreambuf_iterators, etc. -<span class="lineNum"> 77 </span> : // Input Iterators have a cost structure very different from -<span class="lineNum"> 78 </span> : // pointers, calling for a different coding style. -<span class="lineNum"> 79 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 80 </span> : template<typename _InIterator> -<span class="lineNum"> 81 </span> : _CharT* -<span class="lineNum"> 82 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 83 </span> : _S_construct(_InIterator __beg, _InIterator __end, const _Alloc& __a, -<span class="lineNum"> 84 </span> : input_iterator_tag) -<span class="lineNum"> 85 </span> : { -<span class="lineNum"> 86 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 87 </span> : if (__beg == __end && __a == _Alloc()) -<span class="lineNum"> 88 </span> : return _S_empty_rep()._M_refdata(); -<span class="lineNum"> 89 </span> : #endif -<span class="lineNum"> 90 </span> : // Avoid reallocation for common case. -<span class="lineNum"> 91 </span> : _CharT __buf[128]; -<span class="lineNum"> 92 </span> : size_type __len = 0; -<span class="lineNum"> 93 </span> : while (__beg != __end && __len < sizeof(__buf) / sizeof(_CharT)) -<span class="lineNum"> 94 </span> : { -<span class="lineNum"> 95 </span> : __buf[__len++] = *__beg; -<span class="lineNum"> 96 </span> : ++__beg; -<span class="lineNum"> 97 </span> : } -<span class="lineNum"> 98 </span> : _Rep* __r = _Rep::_S_create(__len, size_type(0), __a); -<span class="lineNum"> 99 </span> : _M_copy(__r->_M_refdata(), __buf, __len); -<span class="lineNum"> 100 </span> : try -<span class="lineNum"> 101 </span> : { -<span class="lineNum"> 102 </span> : while (__beg != __end) -<span class="lineNum"> 103 </span> : { -<span class="lineNum"> 104 </span> : if (__len == __r->_M_capacity) -<span class="lineNum"> 105 </span> : { -<span class="lineNum"> 106 </span> : // Allocate more space. -<span class="lineNum"> 107 </span> : _Rep* __another = _Rep::_S_create(__len + 1, __len, __a); -<span class="lineNum"> 108 </span> : _M_copy(__another->_M_refdata(), __r->_M_refdata(), __len); -<span class="lineNum"> 109 </span> : __r->_M_destroy(__a); -<span class="lineNum"> 110 </span> : __r = __another; -<span class="lineNum"> 111 </span> : } -<span class="lineNum"> 112 </span> : __r->_M_refdata()[__len++] = *__beg; -<span class="lineNum"> 113 </span> : ++__beg; -<span class="lineNum"> 114 </span> : } -<span class="lineNum"> 115 </span> : } -<span class="lineNum"> 116 </span> : catch(...) -<span class="lineNum"> 117 </span> : { -<span class="lineNum"> 118 </span> : __r->_M_destroy(__a); -<span class="lineNum"> 119 </span> : __throw_exception_again; -<span class="lineNum"> 120 </span> : } -<span class="lineNum"> 121 </span> : __r->_M_set_length_and_sharable(__len); -<span class="lineNum"> 122 </span> : return __r->_M_refdata(); -<span class="lineNum"> 123 </span> : } -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 126 </span> : template <typename _InIterator> -<span class="lineNum"> 127 </span> : _CharT* -<span class="lineNum"> 128 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 129 </span> : _S_construct(_InIterator __beg, _InIterator __end, const _Alloc& __a, -<span class="lineNum"> 130 </span><span class="lineCov"> 1287 : forward_iterator_tag)</span> -<span class="lineNum"> 131 </span> : { -<span class="lineNum"> 132 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 133 </span><span class="lineCov"> 1287 : if (__beg == __end && __a == _Alloc())</span> -<span class="lineNum"> 134 </span><span class="lineNoCov"> 0 : return _S_empty_rep()._M_refdata();</span> -<span class="lineNum"> 135 </span> : #endif -<span class="lineNum"> 136 </span> : // NB: Not required, but considered best practice. -<span class="lineNum"> 137 </span><span class="lineCov"> 1287 : if (__builtin_expect(__gnu_cxx::__is_null_pointer(__beg)</span> -<span class="lineNum"> 138 </span> : && __beg != __end, 0)) -<span class="lineNum"> 139 </span><span class="lineNoCov"> 0 : __throw_logic_error(__N("basic_string::_S_construct NULL not valid"));</span> -<span class="lineNum"> 140 </span> : -<span class="lineNum"> 141 </span> : const size_type __dnew = static_cast<size_type>(std::distance(__beg, -<span class="lineNum"> 142 </span><span class="lineCov"> 1287 : __end));</span> -<span class="lineNum"> 143 </span> : // Check for out_of_range and length_error exceptions. -<span class="lineNum"> 144 </span><span class="lineCov"> 1287 : _Rep* __r = _Rep::_S_create(__dnew, size_type(0), __a);</span> -<span class="lineNum"> 145 </span> : try -<span class="lineNum"> 146 </span><span class="lineCov"> 1287 : { _S_copy_chars(__r->_M_refdata(), __beg, __end); }</span> -<span class="lineNum"> 147 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 148 </span> : { -<span class="lineNum"> 149 </span><span class="lineNoCov"> 0 : __r->_M_destroy(__a);</span> -<span class="lineNum"> 150 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 151 </span> : } -<span class="lineNum"> 152 </span><span class="lineCov"> 1287 : __r->_M_set_length_and_sharable(__dnew);</span> -<span class="lineNum"> 153 </span><span class="lineCov"> 1287 : return __r->_M_refdata();</span> -<span class="lineNum"> 154 </span> : } -<span class="lineNum"> 155 </span> : -<span class="lineNum"> 156 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 157 </span> : _CharT* -<span class="lineNum"> 158 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 159 </span> : _S_construct(size_type __n, _CharT __c, const _Alloc& __a) -<span class="lineNum"> 160 </span> : { -<span class="lineNum"> 161 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 162 </span> : if (__n == 0 && __a == _Alloc()) -<span class="lineNum"> 163 </span> : return _S_empty_rep()._M_refdata(); -<span class="lineNum"> 164 </span> : #endif -<span class="lineNum"> 165 </span> : // Check for out_of_range and length_error exceptions. -<span class="lineNum"> 166 </span> : _Rep* __r = _Rep::_S_create(__n, size_type(0), __a); -<span class="lineNum"> 167 </span> : if (__n) -<span class="lineNum"> 168 </span> : _M_assign(__r->_M_refdata(), __n, __c); -<span class="lineNum"> 169 </span> : -<span class="lineNum"> 170 </span> : __r->_M_set_length_and_sharable(__n); -<span class="lineNum"> 171 </span> : return __r->_M_refdata(); -<span class="lineNum"> 172 </span> : } -<span class="lineNum"> 173 </span> : -<span class="lineNum"> 174 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 175 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 176 </span> : basic_string(const basic_string& __str) -<span class="lineNum"> 177 </span> : : _M_dataplus(__str._M_rep()->_M_grab(_Alloc(__str.get_allocator()), -<span class="lineNum"> 178 </span> : __str.get_allocator()), -<span class="lineNum"> 179 </span> : __str.get_allocator()) -<span class="lineNum"> 180 </span> : { } -<span class="lineNum"> 181 </span> : -<span class="lineNum"> 182 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 183 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 184 </span> : basic_string(const _Alloc& __a) -<span class="lineNum"> 185 </span> : : _M_dataplus(_S_construct(size_type(), _CharT(), __a), __a) -<span class="lineNum"> 186 </span> : { } -<span class="lineNum"> 187 </span> : -<span class="lineNum"> 188 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 189 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 190 </span> : basic_string(const basic_string& __str, size_type __pos, size_type __n) -<span class="lineNum"> 191 </span> : : _M_dataplus(_S_construct(__str._M_data() -<span class="lineNum"> 192 </span> : + __str._M_check(__pos, -<span class="lineNum"> 193 </span> : "basic_string::basic_string"), -<span class="lineNum"> 194 </span> : __str._M_data() + __str._M_limit(__pos, __n) -<span class="lineNum"> 195 </span> : + __pos, _Alloc()), _Alloc()) -<span class="lineNum"> 196 </span> : { } -<span class="lineNum"> 197 </span> : -<span class="lineNum"> 198 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 199 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 200 </span> : basic_string(const basic_string& __str, size_type __pos, -<span class="lineNum"> 201 </span> : size_type __n, const _Alloc& __a) -<span class="lineNum"> 202 </span> : : _M_dataplus(_S_construct(__str._M_data() -<span class="lineNum"> 203 </span> : + __str._M_check(__pos, -<span class="lineNum"> 204 </span> : "basic_string::basic_string"), -<span class="lineNum"> 205 </span> : __str._M_data() + __str._M_limit(__pos, __n) -<span class="lineNum"> 206 </span> : + __pos, __a), __a) -<span class="lineNum"> 207 </span> : { } -<span class="lineNum"> 208 </span> : -<span class="lineNum"> 209 </span> : // TBD: DPG annotate -<span class="lineNum"> 210 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 211 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 212 </span> : basic_string(const _CharT* __s, size_type __n, const _Alloc& __a) -<span class="lineNum"> 213 </span> : : _M_dataplus(_S_construct(__s, __s + __n, __a), __a) -<span class="lineNum"> 214 </span> : { } -<span class="lineNum"> 215 </span> : -<span class="lineNum"> 216 </span> : // TBD: DPG annotate -<span class="lineNum"> 217 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 218 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 219 </span> : basic_string(const _CharT* __s, const _Alloc& __a) -<span class="lineNum"> 220 </span> : : _M_dataplus(_S_construct(__s, __s ? __s + traits_type::length(__s) : -<span class="lineNum"> 221 </span> : __s + npos, __a), __a) -<span class="lineNum"> 222 </span> : { } -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 225 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 226 </span> : basic_string(size_type __n, _CharT __c, const _Alloc& __a) -<span class="lineNum"> 227 </span> : : _M_dataplus(_S_construct(__n, __c, __a), __a) -<span class="lineNum"> 228 </span> : { } -<span class="lineNum"> 229 </span> : -<span class="lineNum"> 230 </span> : // TBD: DPG annotate -<span class="lineNum"> 231 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 232 </span> : template<typename _InputIterator> -<span class="lineNum"> 233 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 234 </span><span class="lineCov"> 1287 : basic_string(_InputIterator __beg, _InputIterator __end, const _Alloc& __a)</span> -<span class="lineNum"> 235 </span><span class="lineCov"> 1287 : : _M_dataplus(_S_construct(__beg, __end, __a), __a)</span> -<span class="lineNum"> 236 </span><span class="lineCov"> 1287 : { }</span> -<span class="lineNum"> 237 </span> : -<span class="lineNum"> 238 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 239 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 240 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 241 </span> : assign(const basic_string& __str) -<span class="lineNum"> 242 </span> : { -<span class="lineNum"> 243 </span> : if (_M_rep() != __str._M_rep()) -<span class="lineNum"> 244 </span> : { -<span class="lineNum"> 245 </span> : // XXX MT -<span class="lineNum"> 246 </span> : const allocator_type __a = this->get_allocator(); -<span class="lineNum"> 247 </span> : _CharT* __tmp = __str._M_rep()->_M_grab(__a, __str.get_allocator()); -<span class="lineNum"> 248 </span> : _M_rep()->_M_dispose(__a); -<span class="lineNum"> 249 </span> : _M_data(__tmp); -<span class="lineNum"> 250 </span> : } -<span class="lineNum"> 251 </span> : return *this; -<span class="lineNum"> 252 </span> : } -<span class="lineNum"> 253 </span> : -<span class="lineNum"> 254 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 255 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 256 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 257 </span> : assign(const _CharT* __s, size_type __n) -<span class="lineNum"> 258 </span> : { -<span class="lineNum"> 259 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 260 </span> : _M_check_length(this->size(), __n, "basic_string::assign"); -<span class="lineNum"> 261 </span> : if (_M_disjunct(__s) || _M_rep()->_M_is_shared()) -<span class="lineNum"> 262 </span> : return _M_replace_safe(size_type(0), this->size(), __s, __n); -<span class="lineNum"> 263 </span> : else -<span class="lineNum"> 264 </span> : { -<span class="lineNum"> 265 </span> : // Work in-place. -<span class="lineNum"> 266 </span> : const size_type __pos = __s - _M_data(); -<span class="lineNum"> 267 </span> : if (__pos >= __n) -<span class="lineNum"> 268 </span> : _M_copy(_M_data(), __s, __n); -<span class="lineNum"> 269 </span> : else if (__pos) -<span class="lineNum"> 270 </span> : _M_move(_M_data(), __s, __n); -<span class="lineNum"> 271 </span> : _M_rep()->_M_set_length_and_sharable(__n); -<span class="lineNum"> 272 </span> : return *this; -<span class="lineNum"> 273 </span> : } -<span class="lineNum"> 274 </span> : } -<span class="lineNum"> 275 </span> : -<span class="lineNum"> 276 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 277 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 278 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 279 </span> : append(size_type __n, _CharT __c) -<span class="lineNum"> 280 </span> : { -<span class="lineNum"> 281 </span> : if (__n) -<span class="lineNum"> 282 </span> : { -<span class="lineNum"> 283 </span> : _M_check_length(size_type(0), __n, "basic_string::append"); -<span class="lineNum"> 284 </span> : const size_type __len = __n + this->size(); -<span class="lineNum"> 285 </span> : if (__len > this->capacity() || _M_rep()->_M_is_shared()) -<span class="lineNum"> 286 </span> : this->reserve(__len); -<span class="lineNum"> 287 </span> : _M_assign(_M_data() + this->size(), __n, __c); -<span class="lineNum"> 288 </span> : _M_rep()->_M_set_length_and_sharable(__len); -<span class="lineNum"> 289 </span> : } -<span class="lineNum"> 290 </span> : return *this; -<span class="lineNum"> 291 </span> : } -<span class="lineNum"> 292 </span> : -<span class="lineNum"> 293 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 294 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 295 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 296 </span> : append(const _CharT* __s, size_type __n) -<span class="lineNum"> 297 </span> : { -<span class="lineNum"> 298 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 299 </span> : if (__n) -<span class="lineNum"> 300 </span> : { -<span class="lineNum"> 301 </span> : _M_check_length(size_type(0), __n, "basic_string::append"); -<span class="lineNum"> 302 </span> : const size_type __len = __n + this->size(); -<span class="lineNum"> 303 </span> : if (__len > this->capacity() || _M_rep()->_M_is_shared()) -<span class="lineNum"> 304 </span> : { -<span class="lineNum"> 305 </span> : if (_M_disjunct(__s)) -<span class="lineNum"> 306 </span> : this->reserve(__len); -<span class="lineNum"> 307 </span> : else -<span class="lineNum"> 308 </span> : { -<span class="lineNum"> 309 </span> : const size_type __off = __s - _M_data(); -<span class="lineNum"> 310 </span> : this->reserve(__len); -<span class="lineNum"> 311 </span> : __s = _M_data() + __off; -<span class="lineNum"> 312 </span> : } -<span class="lineNum"> 313 </span> : } -<span class="lineNum"> 314 </span> : _M_copy(_M_data() + this->size(), __s, __n); -<span class="lineNum"> 315 </span> : _M_rep()->_M_set_length_and_sharable(__len); -<span class="lineNum"> 316 </span> : } -<span class="lineNum"> 317 </span> : return *this; -<span class="lineNum"> 318 </span> : } -<span class="lineNum"> 319 </span> : -<span class="lineNum"> 320 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 321 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 322 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 323 </span> : append(const basic_string& __str) -<span class="lineNum"> 324 </span> : { -<span class="lineNum"> 325 </span> : const size_type __size = __str.size(); -<span class="lineNum"> 326 </span> : if (__size) -<span class="lineNum"> 327 </span> : { -<span class="lineNum"> 328 </span> : const size_type __len = __size + this->size(); -<span class="lineNum"> 329 </span> : if (__len > this->capacity() || _M_rep()->_M_is_shared()) -<span class="lineNum"> 330 </span> : this->reserve(__len); -<span class="lineNum"> 331 </span> : _M_copy(_M_data() + this->size(), __str._M_data(), __size); -<span class="lineNum"> 332 </span> : _M_rep()->_M_set_length_and_sharable(__len); -<span class="lineNum"> 333 </span> : } -<span class="lineNum"> 334 </span> : return *this; -<span class="lineNum"> 335 </span> : } -<span class="lineNum"> 336 </span> : -<span class="lineNum"> 337 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 338 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 339 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 340 </span> : append(const basic_string& __str, size_type __pos, size_type __n) -<span class="lineNum"> 341 </span> : { -<span class="lineNum"> 342 </span> : __str._M_check(__pos, "basic_string::append"); -<span class="lineNum"> 343 </span> : __n = __str._M_limit(__pos, __n); -<span class="lineNum"> 344 </span> : if (__n) -<span class="lineNum"> 345 </span> : { -<span class="lineNum"> 346 </span> : const size_type __len = __n + this->size(); -<span class="lineNum"> 347 </span> : if (__len > this->capacity() || _M_rep()->_M_is_shared()) -<span class="lineNum"> 348 </span> : this->reserve(__len); -<span class="lineNum"> 349 </span> : _M_copy(_M_data() + this->size(), __str._M_data() + __pos, __n); -<span class="lineNum"> 350 </span> : _M_rep()->_M_set_length_and_sharable(__len); -<span class="lineNum"> 351 </span> : } -<span class="lineNum"> 352 </span> : return *this; -<span class="lineNum"> 353 </span> : } -<span class="lineNum"> 354 </span> : -<span class="lineNum"> 355 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 356 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 357 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 358 </span> : insert(size_type __pos, const _CharT* __s, size_type __n) -<span class="lineNum"> 359 </span> : { -<span class="lineNum"> 360 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 361 </span> : _M_check(__pos, "basic_string::insert"); -<span class="lineNum"> 362 </span> : _M_check_length(size_type(0), __n, "basic_string::insert"); -<span class="lineNum"> 363 </span> : if (_M_disjunct(__s) || _M_rep()->_M_is_shared()) -<span class="lineNum"> 364 </span> : return _M_replace_safe(__pos, size_type(0), __s, __n); -<span class="lineNum"> 365 </span> : else -<span class="lineNum"> 366 </span> : { -<span class="lineNum"> 367 </span> : // Work in-place. -<span class="lineNum"> 368 </span> : const size_type __off = __s - _M_data(); -<span class="lineNum"> 369 </span> : _M_mutate(__pos, 0, __n); -<span class="lineNum"> 370 </span> : __s = _M_data() + __off; -<span class="lineNum"> 371 </span> : _CharT* __p = _M_data() + __pos; -<span class="lineNum"> 372 </span> : if (__s + __n <= __p) -<span class="lineNum"> 373 </span> : _M_copy(__p, __s, __n); -<span class="lineNum"> 374 </span> : else if (__s >= __p) -<span class="lineNum"> 375 </span> : _M_copy(__p, __s + __n, __n); -<span class="lineNum"> 376 </span> : else -<span class="lineNum"> 377 </span> : { -<span class="lineNum"> 378 </span> : const size_type __nleft = __p - __s; -<span class="lineNum"> 379 </span> : _M_copy(__p, __s, __nleft); -<span class="lineNum"> 380 </span> : _M_copy(__p + __nleft, __p + __n, __n - __nleft); -<span class="lineNum"> 381 </span> : } -<span class="lineNum"> 382 </span> : return *this; -<span class="lineNum"> 383 </span> : } -<span class="lineNum"> 384 </span> : } -<span class="lineNum"> 385 </span> : -<span class="lineNum"> 386 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 387 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 388 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 389 </span> : replace(size_type __pos, size_type __n1, const _CharT* __s, -<span class="lineNum"> 390 </span> : size_type __n2) -<span class="lineNum"> 391 </span> : { -<span class="lineNum"> 392 </span> : __glibcxx_requires_string_len(__s, __n2); -<span class="lineNum"> 393 </span> : _M_check(__pos, "basic_string::replace"); -<span class="lineNum"> 394 </span> : __n1 = _M_limit(__pos, __n1); -<span class="lineNum"> 395 </span> : _M_check_length(__n1, __n2, "basic_string::replace"); -<span class="lineNum"> 396 </span> : bool __left; -<span class="lineNum"> 397 </span> : if (_M_disjunct(__s) || _M_rep()->_M_is_shared()) -<span class="lineNum"> 398 </span> : return _M_replace_safe(__pos, __n1, __s, __n2); -<span class="lineNum"> 399 </span> : else if ((__left = __s + __n2 <= _M_data() + __pos) -<span class="lineNum"> 400 </span> : || _M_data() + __pos + __n1 <= __s) -<span class="lineNum"> 401 </span> : { -<span class="lineNum"> 402 </span> : // Work in-place: non-overlapping case. -<span class="lineNum"> 403 </span> : size_type __off = __s - _M_data(); -<span class="lineNum"> 404 </span> : __left ? __off : (__off += __n2 - __n1); -<span class="lineNum"> 405 </span> : _M_mutate(__pos, __n1, __n2); -<span class="lineNum"> 406 </span> : _M_copy(_M_data() + __pos, _M_data() + __off, __n2); -<span class="lineNum"> 407 </span> : return *this; -<span class="lineNum"> 408 </span> : } -<span class="lineNum"> 409 </span> : else -<span class="lineNum"> 410 </span> : { -<span class="lineNum"> 411 </span> : // Todo: overlapping case. -<span class="lineNum"> 412 </span> : const basic_string __tmp(__s, __n2); -<span class="lineNum"> 413 </span> : return _M_replace_safe(__pos, __n1, __tmp._M_data(), __n2); -<span class="lineNum"> 414 </span> : } -<span class="lineNum"> 415 </span> : } -<span class="lineNum"> 416 </span> : -<span class="lineNum"> 417 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 418 </span> : void -<span class="lineNum"> 419 </span> : basic_string<_CharT, _Traits, _Alloc>::_Rep:: -<span class="lineNum"> 420 </span> : _M_destroy(const _Alloc& __a) throw () -<span class="lineNum"> 421 </span> : { -<span class="lineNum"> 422 </span> : const size_type __size = sizeof(_Rep_base) + -<span class="lineNum"> 423 </span> : (this->_M_capacity + 1) * sizeof(_CharT); -<span class="lineNum"> 424 </span> : _Raw_bytes_alloc(__a).deallocate(reinterpret_cast<char*>(this), __size); -<span class="lineNum"> 425 </span> : } -<span class="lineNum"> 426 </span> : -<span class="lineNum"> 427 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 428 </span> : void -<span class="lineNum"> 429 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 430 </span> : _M_leak_hard() -<span class="lineNum"> 431 </span> : { -<span class="lineNum"> 432 </span> : #ifndef _GLIBCXX_FULLY_DYNAMIC_STRING -<span class="lineNum"> 433 </span> : if (_M_rep() == &_S_empty_rep()) -<span class="lineNum"> 434 </span> : return; -<span class="lineNum"> 435 </span> : #endif -<span class="lineNum"> 436 </span> : if (_M_rep()->_M_is_shared()) -<span class="lineNum"> 437 </span> : _M_mutate(0, 0, 0); -<span class="lineNum"> 438 </span> : _M_rep()->_M_set_leaked(); -<span class="lineNum"> 439 </span> : } -<span class="lineNum"> 440 </span> : -<span class="lineNum"> 441 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 442 </span> : void -<span class="lineNum"> 443 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 444 </span> : _M_mutate(size_type __pos, size_type __len1, size_type __len2) -<span class="lineNum"> 445 </span> : { -<span class="lineNum"> 446 </span> : const size_type __old_size = this->size(); -<span class="lineNum"> 447 </span> : const size_type __new_size = __old_size + __len2 - __len1; -<span class="lineNum"> 448 </span> : const size_type __how_much = __old_size - __pos - __len1; -<span class="lineNum"> 449 </span> : -<span class="lineNum"> 450 </span> : if (__new_size > this->capacity() || _M_rep()->_M_is_shared()) -<span class="lineNum"> 451 </span> : { -<span class="lineNum"> 452 </span> : // Must reallocate. -<span class="lineNum"> 453 </span> : const allocator_type __a = get_allocator(); -<span class="lineNum"> 454 </span> : _Rep* __r = _Rep::_S_create(__new_size, this->capacity(), __a); -<span class="lineNum"> 455 </span> : -<span class="lineNum"> 456 </span> : if (__pos) -<span class="lineNum"> 457 </span> : _M_copy(__r->_M_refdata(), _M_data(), __pos); -<span class="lineNum"> 458 </span> : if (__how_much) -<span class="lineNum"> 459 </span> : _M_copy(__r->_M_refdata() + __pos + __len2, -<span class="lineNum"> 460 </span> : _M_data() + __pos + __len1, __how_much); -<span class="lineNum"> 461 </span> : -<span class="lineNum"> 462 </span> : _M_rep()->_M_dispose(__a); -<span class="lineNum"> 463 </span> : _M_data(__r->_M_refdata()); -<span class="lineNum"> 464 </span> : } -<span class="lineNum"> 465 </span> : else if (__how_much && __len1 != __len2) -<span class="lineNum"> 466 </span> : { -<span class="lineNum"> 467 </span> : // Work in-place. -<span class="lineNum"> 468 </span> : _M_move(_M_data() + __pos + __len2, -<span class="lineNum"> 469 </span> : _M_data() + __pos + __len1, __how_much); -<span class="lineNum"> 470 </span> : } -<span class="lineNum"> 471 </span> : _M_rep()->_M_set_length_and_sharable(__new_size); -<span class="lineNum"> 472 </span> : } -<span class="lineNum"> 473 </span> : -<span class="lineNum"> 474 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 475 </span> : void -<span class="lineNum"> 476 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 477 </span> : reserve(size_type __res) -<span class="lineNum"> 478 </span> : { -<span class="lineNum"> 479 </span> : if (__res != this->capacity() || _M_rep()->_M_is_shared()) -<span class="lineNum"> 480 </span> : { -<span class="lineNum"> 481 </span> : // Make sure we don't shrink below the current size -<span class="lineNum"> 482 </span> : if (__res < this->size()) -<span class="lineNum"> 483 </span> : __res = this->size(); -<span class="lineNum"> 484 </span> : const allocator_type __a = get_allocator(); -<span class="lineNum"> 485 </span> : _CharT* __tmp = _M_rep()->_M_clone(__a, __res - this->size()); -<span class="lineNum"> 486 </span> : _M_rep()->_M_dispose(__a); -<span class="lineNum"> 487 </span> : _M_data(__tmp); -<span class="lineNum"> 488 </span> : } -<span class="lineNum"> 489 </span> : } -<span class="lineNum"> 490 </span> : -<span class="lineNum"> 491 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 492 </span> : void -<span class="lineNum"> 493 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 494 </span> : swap(basic_string& __s) -<span class="lineNum"> 495 </span> : { -<span class="lineNum"> 496 </span> : if (_M_rep()->_M_is_leaked()) -<span class="lineNum"> 497 </span> : _M_rep()->_M_set_sharable(); -<span class="lineNum"> 498 </span> : if (__s._M_rep()->_M_is_leaked()) -<span class="lineNum"> 499 </span> : __s._M_rep()->_M_set_sharable(); -<span class="lineNum"> 500 </span> : if (this->get_allocator() == __s.get_allocator()) -<span class="lineNum"> 501 </span> : { -<span class="lineNum"> 502 </span> : _CharT* __tmp = _M_data(); -<span class="lineNum"> 503 </span> : _M_data(__s._M_data()); -<span class="lineNum"> 504 </span> : __s._M_data(__tmp); -<span class="lineNum"> 505 </span> : } -<span class="lineNum"> 506 </span> : // The code below can usually be optimized away. -<span class="lineNum"> 507 </span> : else -<span class="lineNum"> 508 </span> : { -<span class="lineNum"> 509 </span> : const basic_string __tmp1(_M_ibegin(), _M_iend(), -<span class="lineNum"> 510 </span> : __s.get_allocator()); -<span class="lineNum"> 511 </span> : const basic_string __tmp2(__s._M_ibegin(), __s._M_iend(), -<span class="lineNum"> 512 </span> : this->get_allocator()); -<span class="lineNum"> 513 </span> : *this = __tmp2; -<span class="lineNum"> 514 </span> : __s = __tmp1; -<span class="lineNum"> 515 </span> : } -<span class="lineNum"> 516 </span> : } -<span class="lineNum"> 517 </span> : -<span class="lineNum"> 518 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 519 </span> : typename basic_string<_CharT, _Traits, _Alloc>::_Rep* -<span class="lineNum"> 520 </span> : basic_string<_CharT, _Traits, _Alloc>::_Rep:: -<span class="lineNum"> 521 </span> : _S_create(size_type __capacity, size_type __old_capacity, -<span class="lineNum"> 522 </span> : const _Alloc& __alloc) -<span class="lineNum"> 523 </span> : { -<span class="lineNum"> 524 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 525 </span> : // 83. String::npos vs. string::max_size() -<span class="lineNum"> 526 </span> : if (__capacity > _S_max_size) -<span class="lineNum"> 527 </span> : __throw_length_error(__N("basic_string::_S_create")); -<span class="lineNum"> 528 </span> : -<span class="lineNum"> 529 </span> : // The standard places no restriction on allocating more memory -<span class="lineNum"> 530 </span> : // than is strictly needed within this layer at the moment or as -<span class="lineNum"> 531 </span> : // requested by an explicit application call to reserve(). -<span class="lineNum"> 532 </span> : -<span class="lineNum"> 533 </span> : // Many malloc implementations perform quite poorly when an -<span class="lineNum"> 534 </span> : // application attempts to allocate memory in a stepwise fashion -<span class="lineNum"> 535 </span> : // growing each allocation size by only 1 char. Additionally, -<span class="lineNum"> 536 </span> : // it makes little sense to allocate less linear memory than the -<span class="lineNum"> 537 </span> : // natural blocking size of the malloc implementation. -<span class="lineNum"> 538 </span> : // Unfortunately, we would need a somewhat low-level calculation -<span class="lineNum"> 539 </span> : // with tuned parameters to get this perfect for any particular -<span class="lineNum"> 540 </span> : // malloc implementation. Fortunately, generalizations about -<span class="lineNum"> 541 </span> : // common features seen among implementations seems to suffice. -<span class="lineNum"> 542 </span> : -<span class="lineNum"> 543 </span> : // __pagesize need not match the actual VM page size for good -<span class="lineNum"> 544 </span> : // results in practice, thus we pick a common value on the low -<span class="lineNum"> 545 </span> : // side. __malloc_header_size is an estimate of the amount of -<span class="lineNum"> 546 </span> : // overhead per memory allocation (in practice seen N * sizeof -<span class="lineNum"> 547 </span> : // (void*) where N is 0, 2 or 4). According to folklore, -<span class="lineNum"> 548 </span> : // picking this value on the high side is better than -<span class="lineNum"> 549 </span> : // low-balling it (especially when this algorithm is used with -<span class="lineNum"> 550 </span> : // malloc implementations that allocate memory blocks rounded up -<span class="lineNum"> 551 </span> : // to a size which is a power of 2). -<span class="lineNum"> 552 </span> : const size_type __pagesize = 4096; -<span class="lineNum"> 553 </span> : const size_type __malloc_header_size = 4 * sizeof(void*); -<span class="lineNum"> 554 </span> : -<span class="lineNum"> 555 </span> : // The below implements an exponential growth policy, necessary to -<span class="lineNum"> 556 </span> : // meet amortized linear time requirements of the library: see -<span class="lineNum"> 557 </span> : // http://gcc.gnu.org/ml/libstdc++/2001-07/msg00085.html. -<span class="lineNum"> 558 </span> : // It's active for allocations requiring an amount of memory above -<span class="lineNum"> 559 </span> : // system pagesize. This is consistent with the requirements of the -<span class="lineNum"> 560 </span> : // standard: http://gcc.gnu.org/ml/libstdc++/2001-07/msg00130.html -<span class="lineNum"> 561 </span> : if (__capacity > __old_capacity && __capacity < 2 * __old_capacity) -<span class="lineNum"> 562 </span> : __capacity = 2 * __old_capacity; -<span class="lineNum"> 563 </span> : -<span class="lineNum"> 564 </span> : // NB: Need an array of char_type[__capacity], plus a terminating -<span class="lineNum"> 565 </span> : // null char_type() element, plus enough for the _Rep data structure. -<span class="lineNum"> 566 </span> : // Whew. Seemingly so needy, yet so elemental. -<span class="lineNum"> 567 </span> : size_type __size = (__capacity + 1) * sizeof(_CharT) + sizeof(_Rep); -<span class="lineNum"> 568 </span> : -<span class="lineNum"> 569 </span> : const size_type __adj_size = __size + __malloc_header_size; -<span class="lineNum"> 570 </span> : if (__adj_size > __pagesize && __capacity > __old_capacity) -<span class="lineNum"> 571 </span> : { -<span class="lineNum"> 572 </span> : const size_type __extra = __pagesize - __adj_size % __pagesize; -<span class="lineNum"> 573 </span> : __capacity += __extra / sizeof(_CharT); -<span class="lineNum"> 574 </span> : // Never allocate a string bigger than _S_max_size. -<span class="lineNum"> 575 </span> : if (__capacity > _S_max_size) -<span class="lineNum"> 576 </span> : __capacity = _S_max_size; -<span class="lineNum"> 577 </span> : __size = (__capacity + 1) * sizeof(_CharT) + sizeof(_Rep); -<span class="lineNum"> 578 </span> : } -<span class="lineNum"> 579 </span> : -<span class="lineNum"> 580 </span> : // NB: Might throw, but no worries about a leak, mate: _Rep() -<span class="lineNum"> 581 </span> : // does not throw. -<span class="lineNum"> 582 </span> : void* __place = _Raw_bytes_alloc(__alloc).allocate(__size); -<span class="lineNum"> 583 </span> : _Rep *__p = new (__place) _Rep; -<span class="lineNum"> 584 </span> : __p->_M_capacity = __capacity; -<span class="lineNum"> 585 </span> : // ABI compatibility - 3.4.x set in _S_create both -<span class="lineNum"> 586 </span> : // _M_refcount and _M_length. All callers of _S_create -<span class="lineNum"> 587 </span> : // in basic_string.tcc then set just _M_length. -<span class="lineNum"> 588 </span> : // In 4.0.x and later both _M_refcount and _M_length -<span class="lineNum"> 589 </span> : // are initialized in the callers, unfortunately we can -<span class="lineNum"> 590 </span> : // have 3.4.x compiled code with _S_create callers inlined -<span class="lineNum"> 591 </span> : // calling 4.0.x+ _S_create. -<span class="lineNum"> 592 </span> : __p->_M_set_sharable(); -<span class="lineNum"> 593 </span> : return __p; -<span class="lineNum"> 594 </span> : } -<span class="lineNum"> 595 </span> : -<span class="lineNum"> 596 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 597 </span> : _CharT* -<span class="lineNum"> 598 </span> : basic_string<_CharT, _Traits, _Alloc>::_Rep:: -<span class="lineNum"> 599 </span> : _M_clone(const _Alloc& __alloc, size_type __res) -<span class="lineNum"> 600 </span> : { -<span class="lineNum"> 601 </span> : // Requested capacity of the clone. -<span class="lineNum"> 602 </span> : const size_type __requested_cap = this->_M_length + __res; -<span class="lineNum"> 603 </span> : _Rep* __r = _Rep::_S_create(__requested_cap, this->_M_capacity, -<span class="lineNum"> 604 </span> : __alloc); -<span class="lineNum"> 605 </span> : if (this->_M_length) -<span class="lineNum"> 606 </span> : _M_copy(__r->_M_refdata(), _M_refdata(), this->_M_length); -<span class="lineNum"> 607 </span> : -<span class="lineNum"> 608 </span> : __r->_M_set_length_and_sharable(this->_M_length); -<span class="lineNum"> 609 </span> : return __r->_M_refdata(); -<span class="lineNum"> 610 </span> : } -<span class="lineNum"> 611 </span> : -<span class="lineNum"> 612 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 613 </span> : void -<span class="lineNum"> 614 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 615 </span> : resize(size_type __n, _CharT __c) -<span class="lineNum"> 616 </span> : { -<span class="lineNum"> 617 </span> : const size_type __size = this->size(); -<span class="lineNum"> 618 </span> : _M_check_length(__size, __n, "basic_string::resize"); -<span class="lineNum"> 619 </span> : if (__size < __n) -<span class="lineNum"> 620 </span> : this->append(__n - __size, __c); -<span class="lineNum"> 621 </span> : else if (__n < __size) -<span class="lineNum"> 622 </span> : this->erase(__n); -<span class="lineNum"> 623 </span> : // else nothing (in particular, avoid calling _M_mutate() unnecessarily.) -<span class="lineNum"> 624 </span> : } -<span class="lineNum"> 625 </span> : -<span class="lineNum"> 626 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 627 </span> : template<typename _InputIterator> -<span class="lineNum"> 628 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 629 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 630 </span> : _M_replace_dispatch(iterator __i1, iterator __i2, _InputIterator __k1, -<span class="lineNum"> 631 </span> : _InputIterator __k2, __false_type) -<span class="lineNum"> 632 </span> : { -<span class="lineNum"> 633 </span> : const basic_string __s(__k1, __k2); -<span class="lineNum"> 634 </span> : const size_type __n1 = __i2 - __i1; -<span class="lineNum"> 635 </span> : _M_check_length(__n1, __s.size(), "basic_string::_M_replace_dispatch"); -<span class="lineNum"> 636 </span> : return _M_replace_safe(__i1 - _M_ibegin(), __n1, __s._M_data(), -<span class="lineNum"> 637 </span> : __s.size()); -<span class="lineNum"> 638 </span> : } -<span class="lineNum"> 639 </span> : -<span class="lineNum"> 640 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 641 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 642 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 643 </span> : _M_replace_aux(size_type __pos1, size_type __n1, size_type __n2, -<span class="lineNum"> 644 </span> : _CharT __c) -<span class="lineNum"> 645 </span> : { -<span class="lineNum"> 646 </span> : _M_check_length(__n1, __n2, "basic_string::_M_replace_aux"); -<span class="lineNum"> 647 </span> : _M_mutate(__pos1, __n1, __n2); -<span class="lineNum"> 648 </span> : if (__n2) -<span class="lineNum"> 649 </span> : _M_assign(_M_data() + __pos1, __n2, __c); -<span class="lineNum"> 650 </span> : return *this; -<span class="lineNum"> 651 </span> : } -<span class="lineNum"> 652 </span> : -<span class="lineNum"> 653 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 654 </span> : basic_string<_CharT, _Traits, _Alloc>& -<span class="lineNum"> 655 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 656 </span> : _M_replace_safe(size_type __pos1, size_type __n1, const _CharT* __s, -<span class="lineNum"> 657 </span> : size_type __n2) -<span class="lineNum"> 658 </span> : { -<span class="lineNum"> 659 </span> : _M_mutate(__pos1, __n1, __n2); -<span class="lineNum"> 660 </span> : if (__n2) -<span class="lineNum"> 661 </span> : _M_copy(_M_data() + __pos1, __s, __n2); -<span class="lineNum"> 662 </span> : return *this; -<span class="lineNum"> 663 </span> : } -<span class="lineNum"> 664 </span> : -<span class="lineNum"> 665 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 666 </span> : basic_string<_CharT, _Traits, _Alloc> -<span class="lineNum"> 667 </span> : operator+(const _CharT* __lhs, -<span class="lineNum"> 668 </span><span class="lineCov"> 2633 : const basic_string<_CharT, _Traits, _Alloc>& __rhs)</span> -<span class="lineNum"> 669 </span> : { -<span class="lineNum"> 670 </span> : __glibcxx_requires_string(__lhs); -<span class="lineNum"> 671 </span> : typedef basic_string<_CharT, _Traits, _Alloc> __string_type; -<span class="lineNum"> 672 </span> : typedef typename __string_type::size_type __size_type; -<span class="lineNum"> 673 </span><span class="lineCov"> 2633 : const __size_type __len = _Traits::length(__lhs);</span> -<span class="lineNum"> 674 </span><span class="lineCov"> 2633 : __string_type __str;</span> -<span class="lineNum"> 675 </span><span class="lineCov"> 2633 : __str.reserve(__len + __rhs.size());</span> -<span class="lineNum"> 676 </span><span class="lineCov"> 2633 : __str.append(__lhs, __len);</span> -<span class="lineNum"> 677 </span><span class="lineCov"> 2633 : __str.append(__rhs);</span> -<span class="lineNum"> 678 </span><span class="lineNoCov"> 0 : return __str;</span> -<span class="lineNum"> 679 </span> : } -<span class="lineNum"> 680 </span> : -<span class="lineNum"> 681 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 682 </span> : basic_string<_CharT, _Traits, _Alloc> -<span class="lineNum"> 683 </span> : operator+(_CharT __lhs, const basic_string<_CharT, _Traits, _Alloc>& __rhs) -<span class="lineNum"> 684 </span> : { -<span class="lineNum"> 685 </span> : typedef basic_string<_CharT, _Traits, _Alloc> __string_type; -<span class="lineNum"> 686 </span> : typedef typename __string_type::size_type __size_type; -<span class="lineNum"> 687 </span> : __string_type __str; -<span class="lineNum"> 688 </span> : const __size_type __len = __rhs.size(); -<span class="lineNum"> 689 </span> : __str.reserve(__len + 1); -<span class="lineNum"> 690 </span> : __str.append(__size_type(1), __lhs); -<span class="lineNum"> 691 </span> : __str.append(__rhs); -<span class="lineNum"> 692 </span> : return __str; -<span class="lineNum"> 693 </span> : } -<span class="lineNum"> 694 </span> : -<span class="lineNum"> 695 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 696 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 697 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 698 </span> : copy(_CharT* __s, size_type __n, size_type __pos) const -<span class="lineNum"> 699 </span> : { -<span class="lineNum"> 700 </span> : _M_check(__pos, "basic_string::copy"); -<span class="lineNum"> 701 </span> : __n = _M_limit(__pos, __n); -<span class="lineNum"> 702 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 703 </span> : if (__n) -<span class="lineNum"> 704 </span> : _M_copy(__s, _M_data() + __pos, __n); -<span class="lineNum"> 705 </span> : // 21.3.5.7 par 3: do not append null. (good.) -<span class="lineNum"> 706 </span> : return __n; -<span class="lineNum"> 707 </span> : } -<span class="lineNum"> 708 </span> : -<span class="lineNum"> 709 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 710 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 711 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 712 </span> : find(const _CharT* __s, size_type __pos, size_type __n) const -<span class="lineNum"> 713 </span> : { -<span class="lineNum"> 714 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 715 </span> : const size_type __size = this->size(); -<span class="lineNum"> 716 </span> : const _CharT* __data = _M_data(); -<span class="lineNum"> 717 </span> : -<span class="lineNum"> 718 </span> : if (__n == 0) -<span class="lineNum"> 719 </span> : return __pos <= __size ? __pos : npos; -<span class="lineNum"> 720 </span> : -<span class="lineNum"> 721 </span> : if (__n <= __size) -<span class="lineNum"> 722 </span> : { -<span class="lineNum"> 723 </span> : for (; __pos <= __size - __n; ++__pos) -<span class="lineNum"> 724 </span> : if (traits_type::eq(__data[__pos], __s[0]) -<span class="lineNum"> 725 </span> : && traits_type::compare(__data + __pos + 1, -<span class="lineNum"> 726 </span> : __s + 1, __n - 1) == 0) -<span class="lineNum"> 727 </span> : return __pos; -<span class="lineNum"> 728 </span> : } -<span class="lineNum"> 729 </span> : return npos; -<span class="lineNum"> 730 </span> : } -<span class="lineNum"> 731 </span> : -<span class="lineNum"> 732 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 733 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 734 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 735 </span> : find(_CharT __c, size_type __pos) const -<span class="lineNum"> 736 </span> : { -<span class="lineNum"> 737 </span> : size_type __ret = npos; -<span class="lineNum"> 738 </span> : const size_type __size = this->size(); -<span class="lineNum"> 739 </span> : if (__pos < __size) -<span class="lineNum"> 740 </span> : { -<span class="lineNum"> 741 </span> : const _CharT* __data = _M_data(); -<span class="lineNum"> 742 </span> : const size_type __n = __size - __pos; -<span class="lineNum"> 743 </span> : const _CharT* __p = traits_type::find(__data + __pos, __n, __c); -<span class="lineNum"> 744 </span> : if (__p) -<span class="lineNum"> 745 </span> : __ret = __p - __data; -<span class="lineNum"> 746 </span> : } -<span class="lineNum"> 747 </span> : return __ret; -<span class="lineNum"> 748 </span> : } -<span class="lineNum"> 749 </span> : -<span class="lineNum"> 750 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 751 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 752 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 753 </span> : rfind(const _CharT* __s, size_type __pos, size_type __n) const -<span class="lineNum"> 754 </span> : { -<span class="lineNum"> 755 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 756 </span> : const size_type __size = this->size(); -<span class="lineNum"> 757 </span> : if (__n <= __size) -<span class="lineNum"> 758 </span> : { -<span class="lineNum"> 759 </span> : __pos = std::min(size_type(__size - __n), __pos); -<span class="lineNum"> 760 </span> : const _CharT* __data = _M_data(); -<span class="lineNum"> 761 </span> : do -<span class="lineNum"> 762 </span> : { -<span class="lineNum"> 763 </span> : if (traits_type::compare(__data + __pos, __s, __n) == 0) -<span class="lineNum"> 764 </span> : return __pos; -<span class="lineNum"> 765 </span> : } -<span class="lineNum"> 766 </span> : while (__pos-- > 0); -<span class="lineNum"> 767 </span> : } -<span class="lineNum"> 768 </span> : return npos; -<span class="lineNum"> 769 </span> : } -<span class="lineNum"> 770 </span> : -<span class="lineNum"> 771 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 772 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 773 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 774 </span> : rfind(_CharT __c, size_type __pos) const -<span class="lineNum"> 775 </span> : { -<span class="lineNum"> 776 </span> : size_type __size = this->size(); -<span class="lineNum"> 777 </span> : if (__size) -<span class="lineNum"> 778 </span> : { -<span class="lineNum"> 779 </span> : if (--__size > __pos) -<span class="lineNum"> 780 </span> : __size = __pos; -<span class="lineNum"> 781 </span> : for (++__size; __size-- > 0; ) -<span class="lineNum"> 782 </span> : if (traits_type::eq(_M_data()[__size], __c)) -<span class="lineNum"> 783 </span> : return __size; -<span class="lineNum"> 784 </span> : } -<span class="lineNum"> 785 </span> : return npos; -<span class="lineNum"> 786 </span> : } -<span class="lineNum"> 787 </span> : -<span class="lineNum"> 788 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 789 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 790 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 791 </span> : find_first_of(const _CharT* __s, size_type __pos, size_type __n) const -<span class="lineNum"> 792 </span> : { -<span class="lineNum"> 793 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 794 </span> : for (; __n && __pos < this->size(); ++__pos) -<span class="lineNum"> 795 </span> : { -<span class="lineNum"> 796 </span> : const _CharT* __p = traits_type::find(__s, __n, _M_data()[__pos]); -<span class="lineNum"> 797 </span> : if (__p) -<span class="lineNum"> 798 </span> : return __pos; -<span class="lineNum"> 799 </span> : } -<span class="lineNum"> 800 </span> : return npos; -<span class="lineNum"> 801 </span> : } -<span class="lineNum"> 802 </span> : -<span class="lineNum"> 803 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 804 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 805 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 806 </span> : find_last_of(const _CharT* __s, size_type __pos, size_type __n) const -<span class="lineNum"> 807 </span> : { -<span class="lineNum"> 808 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 809 </span> : size_type __size = this->size(); -<span class="lineNum"> 810 </span> : if (__size && __n) -<span class="lineNum"> 811 </span> : { -<span class="lineNum"> 812 </span> : if (--__size > __pos) -<span class="lineNum"> 813 </span> : __size = __pos; -<span class="lineNum"> 814 </span> : do -<span class="lineNum"> 815 </span> : { -<span class="lineNum"> 816 </span> : if (traits_type::find(__s, __n, _M_data()[__size])) -<span class="lineNum"> 817 </span> : return __size; -<span class="lineNum"> 818 </span> : } -<span class="lineNum"> 819 </span> : while (__size-- != 0); -<span class="lineNum"> 820 </span> : } -<span class="lineNum"> 821 </span> : return npos; -<span class="lineNum"> 822 </span> : } -<span class="lineNum"> 823 </span> : -<span class="lineNum"> 824 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 825 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 826 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 827 </span> : find_first_not_of(const _CharT* __s, size_type __pos, size_type __n) const -<span class="lineNum"> 828 </span> : { -<span class="lineNum"> 829 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 830 </span> : for (; __pos < this->size(); ++__pos) -<span class="lineNum"> 831 </span> : if (!traits_type::find(__s, __n, _M_data()[__pos])) -<span class="lineNum"> 832 </span> : return __pos; -<span class="lineNum"> 833 </span> : return npos; -<span class="lineNum"> 834 </span> : } -<span class="lineNum"> 835 </span> : -<span class="lineNum"> 836 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 837 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 838 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 839 </span> : find_first_not_of(_CharT __c, size_type __pos) const -<span class="lineNum"> 840 </span> : { -<span class="lineNum"> 841 </span> : for (; __pos < this->size(); ++__pos) -<span class="lineNum"> 842 </span> : if (!traits_type::eq(_M_data()[__pos], __c)) -<span class="lineNum"> 843 </span> : return __pos; -<span class="lineNum"> 844 </span> : return npos; -<span class="lineNum"> 845 </span> : } -<span class="lineNum"> 846 </span> : -<span class="lineNum"> 847 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 848 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 849 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 850 </span> : find_last_not_of(const _CharT* __s, size_type __pos, size_type __n) const -<span class="lineNum"> 851 </span> : { -<span class="lineNum"> 852 </span> : __glibcxx_requires_string_len(__s, __n); -<span class="lineNum"> 853 </span> : size_type __size = this->size(); -<span class="lineNum"> 854 </span> : if (__size) -<span class="lineNum"> 855 </span> : { -<span class="lineNum"> 856 </span> : if (--__size > __pos) -<span class="lineNum"> 857 </span> : __size = __pos; -<span class="lineNum"> 858 </span> : do -<span class="lineNum"> 859 </span> : { -<span class="lineNum"> 860 </span> : if (!traits_type::find(__s, __n, _M_data()[__size])) -<span class="lineNum"> 861 </span> : return __size; -<span class="lineNum"> 862 </span> : } -<span class="lineNum"> 863 </span> : while (__size--); -<span class="lineNum"> 864 </span> : } -<span class="lineNum"> 865 </span> : return npos; -<span class="lineNum"> 866 </span> : } -<span class="lineNum"> 867 </span> : -<span class="lineNum"> 868 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 869 </span> : typename basic_string<_CharT, _Traits, _Alloc>::size_type -<span class="lineNum"> 870 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 871 </span> : find_last_not_of(_CharT __c, size_type __pos) const -<span class="lineNum"> 872 </span> : { -<span class="lineNum"> 873 </span> : size_type __size = this->size(); -<span class="lineNum"> 874 </span> : if (__size) -<span class="lineNum"> 875 </span> : { -<span class="lineNum"> 876 </span> : if (--__size > __pos) -<span class="lineNum"> 877 </span> : __size = __pos; -<span class="lineNum"> 878 </span> : do -<span class="lineNum"> 879 </span> : { -<span class="lineNum"> 880 </span> : if (!traits_type::eq(_M_data()[__size], __c)) -<span class="lineNum"> 881 </span> : return __size; -<span class="lineNum"> 882 </span> : } -<span class="lineNum"> 883 </span> : while (__size--); -<span class="lineNum"> 884 </span> : } -<span class="lineNum"> 885 </span> : return npos; -<span class="lineNum"> 886 </span> : } -<span class="lineNum"> 887 </span> : -<span class="lineNum"> 888 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 889 </span> : int -<span class="lineNum"> 890 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 891 </span> : compare(size_type __pos, size_type __n, const basic_string& __str) const -<span class="lineNum"> 892 </span> : { -<span class="lineNum"> 893 </span> : _M_check(__pos, "basic_string::compare"); -<span class="lineNum"> 894 </span> : __n = _M_limit(__pos, __n); -<span class="lineNum"> 895 </span> : const size_type __osize = __str.size(); -<span class="lineNum"> 896 </span> : const size_type __len = std::min(__n, __osize); -<span class="lineNum"> 897 </span> : int __r = traits_type::compare(_M_data() + __pos, __str.data(), __len); -<span class="lineNum"> 898 </span> : if (!__r) -<span class="lineNum"> 899 </span> : __r = _S_compare(__n, __osize); -<span class="lineNum"> 900 </span> : return __r; -<span class="lineNum"> 901 </span> : } -<span class="lineNum"> 902 </span> : -<span class="lineNum"> 903 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 904 </span> : int -<span class="lineNum"> 905 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 906 </span> : compare(size_type __pos1, size_type __n1, const basic_string& __str, -<span class="lineNum"> 907 </span> : size_type __pos2, size_type __n2) const -<span class="lineNum"> 908 </span> : { -<span class="lineNum"> 909 </span> : _M_check(__pos1, "basic_string::compare"); -<span class="lineNum"> 910 </span> : __str._M_check(__pos2, "basic_string::compare"); -<span class="lineNum"> 911 </span> : __n1 = _M_limit(__pos1, __n1); -<span class="lineNum"> 912 </span> : __n2 = __str._M_limit(__pos2, __n2); -<span class="lineNum"> 913 </span> : const size_type __len = std::min(__n1, __n2); -<span class="lineNum"> 914 </span> : int __r = traits_type::compare(_M_data() + __pos1, -<span class="lineNum"> 915 </span> : __str.data() + __pos2, __len); -<span class="lineNum"> 916 </span> : if (!__r) -<span class="lineNum"> 917 </span> : __r = _S_compare(__n1, __n2); -<span class="lineNum"> 918 </span> : return __r; -<span class="lineNum"> 919 </span> : } -<span class="lineNum"> 920 </span> : -<span class="lineNum"> 921 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 922 </span> : int -<span class="lineNum"> 923 </span> : basic_string<_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 924 </span> : compare(const _CharT* __s) const -<span class="lineNum"> 925 </span> : { -<span class="lineNum"> 926 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 927 </span> : const size_type __size = this->size(); -<span class="lineNum"> 928 </span> : const size_type __osize = traits_type::length(__s); -<span class="lineNum"> 929 </span> : const size_type __len = std::min(__size, __osize); -<span class="lineNum"> 930 </span> : int __r = traits_type::compare(_M_data(), __s, __len); -<span class="lineNum"> 931 </span> : if (!__r) -<span class="lineNum"> 932 </span> : __r = _S_compare(__size, __osize); -<span class="lineNum"> 933 </span> : return __r; -<span class="lineNum"> 934 </span> : } -<span class="lineNum"> 935 </span> : -<span class="lineNum"> 936 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 937 </span> : int -<span class="lineNum"> 938 </span> : basic_string <_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 939 </span> : compare(size_type __pos, size_type __n1, const _CharT* __s) const -<span class="lineNum"> 940 </span> : { -<span class="lineNum"> 941 </span> : __glibcxx_requires_string(__s); -<span class="lineNum"> 942 </span> : _M_check(__pos, "basic_string::compare"); -<span class="lineNum"> 943 </span> : __n1 = _M_limit(__pos, __n1); -<span class="lineNum"> 944 </span> : const size_type __osize = traits_type::length(__s); -<span class="lineNum"> 945 </span> : const size_type __len = std::min(__n1, __osize); -<span class="lineNum"> 946 </span> : int __r = traits_type::compare(_M_data() + __pos, __s, __len); -<span class="lineNum"> 947 </span> : if (!__r) -<span class="lineNum"> 948 </span> : __r = _S_compare(__n1, __osize); -<span class="lineNum"> 949 </span> : return __r; -<span class="lineNum"> 950 </span> : } -<span class="lineNum"> 951 </span> : -<span class="lineNum"> 952 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 953 </span> : int -<span class="lineNum"> 954 </span> : basic_string <_CharT, _Traits, _Alloc>:: -<span class="lineNum"> 955 </span> : compare(size_type __pos, size_type __n1, const _CharT* __s, -<span class="lineNum"> 956 </span> : size_type __n2) const -<span class="lineNum"> 957 </span> : { -<span class="lineNum"> 958 </span> : __glibcxx_requires_string_len(__s, __n2); -<span class="lineNum"> 959 </span> : _M_check(__pos, "basic_string::compare"); -<span class="lineNum"> 960 </span> : __n1 = _M_limit(__pos, __n1); -<span class="lineNum"> 961 </span> : const size_type __len = std::min(__n1, __n2); -<span class="lineNum"> 962 </span> : int __r = traits_type::compare(_M_data() + __pos, __s, __len); -<span class="lineNum"> 963 </span> : if (!__r) -<span class="lineNum"> 964 </span> : __r = _S_compare(__n1, __n2); -<span class="lineNum"> 965 </span> : return __r; -<span class="lineNum"> 966 </span> : } -<span class="lineNum"> 967 </span> : -<span class="lineNum"> 968 </span> : // 21.3.7.9 basic_string::getline and operators -<span class="lineNum"> 969 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 970 </span> : basic_istream<_CharT, _Traits>& -<span class="lineNum"> 971 </span> : operator>>(basic_istream<_CharT, _Traits>& __in, -<span class="lineNum"> 972 </span> : basic_string<_CharT, _Traits, _Alloc>& __str) -<span class="lineNum"> 973 </span> : { -<span class="lineNum"> 974 </span> : typedef basic_istream<_CharT, _Traits> __istream_type; -<span class="lineNum"> 975 </span> : typedef basic_string<_CharT, _Traits, _Alloc> __string_type; -<span class="lineNum"> 976 </span> : typedef typename __istream_type::ios_base __ios_base; -<span class="lineNum"> 977 </span> : typedef typename __istream_type::int_type __int_type; -<span class="lineNum"> 978 </span> : typedef typename __string_type::size_type __size_type; -<span class="lineNum"> 979 </span> : typedef ctype<_CharT> __ctype_type; -<span class="lineNum"> 980 </span> : typedef typename __ctype_type::ctype_base __ctype_base; -<span class="lineNum"> 981 </span> : -<span class="lineNum"> 982 </span> : __size_type __extracted = 0; -<span class="lineNum"> 983 </span> : typename __ios_base::iostate __err = __ios_base::goodbit; -<span class="lineNum"> 984 </span> : typename __istream_type::sentry __cerb(__in, false); -<span class="lineNum"> 985 </span> : if (__cerb) -<span class="lineNum"> 986 </span> : { -<span class="lineNum"> 987 </span> : try -<span class="lineNum"> 988 </span> : { -<span class="lineNum"> 989 </span> : // Avoid reallocation for common case. -<span class="lineNum"> 990 </span> : __str.erase(); -<span class="lineNum"> 991 </span> : _CharT __buf[128]; -<span class="lineNum"> 992 </span> : __size_type __len = 0; -<span class="lineNum"> 993 </span> : const streamsize __w = __in.width(); -<span class="lineNum"> 994 </span> : const __size_type __n = __w > 0 ? static_cast<__size_type>(__w) -<span class="lineNum"> 995 </span> : : __str.max_size(); -<span class="lineNum"> 996 </span> : const __ctype_type& __ct = use_facet<__ctype_type>(__in.getloc()); -<span class="lineNum"> 997 </span> : const __int_type __eof = _Traits::eof(); -<span class="lineNum"> 998 </span> : __int_type __c = __in.rdbuf()->sgetc(); -<span class="lineNum"> 999 </span> : -<span class="lineNum"> 1000 </span> : while (__extracted < __n -<span class="lineNum"> 1001 </span> : && !_Traits::eq_int_type(__c, __eof) -<span class="lineNum"> 1002 </span> : && !__ct.is(__ctype_base::space, -<span class="lineNum"> 1003 </span> : _Traits::to_char_type(__c))) -<span class="lineNum"> 1004 </span> : { -<span class="lineNum"> 1005 </span> : if (__len == sizeof(__buf) / sizeof(_CharT)) -<span class="lineNum"> 1006 </span> : { -<span class="lineNum"> 1007 </span> : __str.append(__buf, sizeof(__buf) / sizeof(_CharT)); -<span class="lineNum"> 1008 </span> : __len = 0; -<span class="lineNum"> 1009 </span> : } -<span class="lineNum"> 1010 </span> : __buf[__len++] = _Traits::to_char_type(__c); -<span class="lineNum"> 1011 </span> : ++__extracted; -<span class="lineNum"> 1012 </span> : __c = __in.rdbuf()->snextc(); -<span class="lineNum"> 1013 </span> : } -<span class="lineNum"> 1014 </span> : __str.append(__buf, __len); -<span class="lineNum"> 1015 </span> : -<span class="lineNum"> 1016 </span> : if (_Traits::eq_int_type(__c, __eof)) -<span class="lineNum"> 1017 </span> : __err |= __ios_base::eofbit; -<span class="lineNum"> 1018 </span> : __in.width(0); -<span class="lineNum"> 1019 </span> : } -<span class="lineNum"> 1020 </span> : catch(__cxxabiv1::__forced_unwind&) -<span class="lineNum"> 1021 </span> : { -<span class="lineNum"> 1022 </span> : __in._M_setstate(__ios_base::badbit); -<span class="lineNum"> 1023 </span> : __throw_exception_again; -<span class="lineNum"> 1024 </span> : } -<span class="lineNum"> 1025 </span> : catch(...) -<span class="lineNum"> 1026 </span> : { -<span class="lineNum"> 1027 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1028 </span> : // 91. Description of operator>> and getline() for string<> -<span class="lineNum"> 1029 </span> : // might cause endless loop -<span class="lineNum"> 1030 </span> : __in._M_setstate(__ios_base::badbit); -<span class="lineNum"> 1031 </span> : } -<span class="lineNum"> 1032 </span> : } -<span class="lineNum"> 1033 </span> : // 211. operator>>(istream&, string&) doesn't set failbit -<span class="lineNum"> 1034 </span> : if (!__extracted) -<span class="lineNum"> 1035 </span> : __err |= __ios_base::failbit; -<span class="lineNum"> 1036 </span> : if (__err) -<span class="lineNum"> 1037 </span> : __in.setstate(__err); -<span class="lineNum"> 1038 </span> : return __in; -<span class="lineNum"> 1039 </span> : } -<span class="lineNum"> 1040 </span> : -<span class="lineNum"> 1041 </span> : template<typename _CharT, typename _Traits, typename _Alloc> -<span class="lineNum"> 1042 </span> : basic_istream<_CharT, _Traits>& -<span class="lineNum"> 1043 </span> : getline(basic_istream<_CharT, _Traits>& __in, -<span class="lineNum"> 1044 </span> : basic_string<_CharT, _Traits, _Alloc>& __str, _CharT __delim) -<span class="lineNum"> 1045 </span> : { -<span class="lineNum"> 1046 </span> : typedef basic_istream<_CharT, _Traits> __istream_type; -<span class="lineNum"> 1047 </span> : typedef basic_string<_CharT, _Traits, _Alloc> __string_type; -<span class="lineNum"> 1048 </span> : typedef typename __istream_type::ios_base __ios_base; -<span class="lineNum"> 1049 </span> : typedef typename __istream_type::int_type __int_type; -<span class="lineNum"> 1050 </span> : typedef typename __string_type::size_type __size_type; -<span class="lineNum"> 1051 </span> : -<span class="lineNum"> 1052 </span> : __size_type __extracted = 0; -<span class="lineNum"> 1053 </span> : const __size_type __n = __str.max_size(); -<span class="lineNum"> 1054 </span> : typename __ios_base::iostate __err = __ios_base::goodbit; -<span class="lineNum"> 1055 </span> : typename __istream_type::sentry __cerb(__in, true); -<span class="lineNum"> 1056 </span> : if (__cerb) -<span class="lineNum"> 1057 </span> : { -<span class="lineNum"> 1058 </span> : try -<span class="lineNum"> 1059 </span> : { -<span class="lineNum"> 1060 </span> : __str.erase(); -<span class="lineNum"> 1061 </span> : const __int_type __idelim = _Traits::to_int_type(__delim); -<span class="lineNum"> 1062 </span> : const __int_type __eof = _Traits::eof(); -<span class="lineNum"> 1063 </span> : __int_type __c = __in.rdbuf()->sgetc(); -<span class="lineNum"> 1064 </span> : -<span class="lineNum"> 1065 </span> : while (__extracted < __n -<span class="lineNum"> 1066 </span> : && !_Traits::eq_int_type(__c, __eof) -<span class="lineNum"> 1067 </span> : && !_Traits::eq_int_type(__c, __idelim)) -<span class="lineNum"> 1068 </span> : { -<span class="lineNum"> 1069 </span> : __str += _Traits::to_char_type(__c); -<span class="lineNum"> 1070 </span> : ++__extracted; -<span class="lineNum"> 1071 </span> : __c = __in.rdbuf()->snextc(); -<span class="lineNum"> 1072 </span> : } -<span class="lineNum"> 1073 </span> : -<span class="lineNum"> 1074 </span> : if (_Traits::eq_int_type(__c, __eof)) -<span class="lineNum"> 1075 </span> : __err |= __ios_base::eofbit; -<span class="lineNum"> 1076 </span> : else if (_Traits::eq_int_type(__c, __idelim)) -<span class="lineNum"> 1077 </span> : { -<span class="lineNum"> 1078 </span> : ++__extracted; -<span class="lineNum"> 1079 </span> : __in.rdbuf()->sbumpc(); -<span class="lineNum"> 1080 </span> : } -<span class="lineNum"> 1081 </span> : else -<span class="lineNum"> 1082 </span> : __err |= __ios_base::failbit; -<span class="lineNum"> 1083 </span> : } -<span class="lineNum"> 1084 </span> : catch(__cxxabiv1::__forced_unwind&) -<span class="lineNum"> 1085 </span> : { -<span class="lineNum"> 1086 </span> : __in._M_setstate(__ios_base::badbit); -<span class="lineNum"> 1087 </span> : __throw_exception_again; -<span class="lineNum"> 1088 </span> : } -<span class="lineNum"> 1089 </span> : catch(...) -<span class="lineNum"> 1090 </span> : { -<span class="lineNum"> 1091 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1092 </span> : // 91. Description of operator>> and getline() for string<> -<span class="lineNum"> 1093 </span> : // might cause endless loop -<span class="lineNum"> 1094 </span> : __in._M_setstate(__ios_base::badbit); -<span class="lineNum"> 1095 </span> : } -<span class="lineNum"> 1096 </span> : } -<span class="lineNum"> 1097 </span> : if (!__extracted) -<span class="lineNum"> 1098 </span> : __err |= __ios_base::failbit; -<span class="lineNum"> 1099 </span> : if (__err) -<span class="lineNum"> 1100 </span> : __in.setstate(__err); -<span class="lineNum"> 1101 </span> : return __in; -<span class="lineNum"> 1102 </span> : } -<span class="lineNum"> 1103 </span> : -<span class="lineNum"> 1104 </span> : // Inhibit implicit instantiations for required instantiations, -<span class="lineNum"> 1105 </span> : // which are defined via explicit instantiations elsewhere. -<span class="lineNum"> 1106 </span> : // NB: This syntax is a GNU extension. -<span class="lineNum"> 1107 </span> : #if _GLIBCXX_EXTERN_TEMPLATE -<span class="lineNum"> 1108 </span> : extern template class basic_string<char>; -<span class="lineNum"> 1109 </span> : extern template -<span class="lineNum"> 1110 </span> : basic_istream<char>& -<span class="lineNum"> 1111 </span> : operator>>(basic_istream<char>&, string&); -<span class="lineNum"> 1112 </span> : extern template -<span class="lineNum"> 1113 </span> : basic_ostream<char>& -<span class="lineNum"> 1114 </span> : operator<<(basic_ostream<char>&, const string&); -<span class="lineNum"> 1115 </span> : extern template -<span class="lineNum"> 1116 </span> : basic_istream<char>& -<span class="lineNum"> 1117 </span> : getline(basic_istream<char>&, string&, char); -<span class="lineNum"> 1118 </span> : extern template -<span class="lineNum"> 1119 </span> : basic_istream<char>& -<span class="lineNum"> 1120 </span> : getline(basic_istream<char>&, string&); -<span class="lineNum"> 1121 </span> : -<span class="lineNum"> 1122 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 1123 </span> : extern template class basic_string<wchar_t>; -<span class="lineNum"> 1124 </span> : extern template -<span class="lineNum"> 1125 </span> : basic_istream<wchar_t>& -<span class="lineNum"> 1126 </span> : operator>>(basic_istream<wchar_t>&, wstring&); -<span class="lineNum"> 1127 </span> : extern template -<span class="lineNum"> 1128 </span> : basic_ostream<wchar_t>& -<span class="lineNum"> 1129 </span> : operator<<(basic_ostream<wchar_t>&, const wstring&); -<span class="lineNum"> 1130 </span> : extern template -<span class="lineNum"> 1131 </span> : basic_istream<wchar_t>& -<span class="lineNum"> 1132 </span> : getline(basic_istream<wchar_t>&, wstring&, wchar_t); -<span class="lineNum"> 1133 </span> : extern template -<span class="lineNum"> 1134 </span> : basic_istream<wchar_t>& -<span class="lineNum"> 1135 </span> : getline(basic_istream<wchar_t>&, wstring&); -<span class="lineNum"> 1136 </span> : #endif -<span class="lineNum"> 1137 </span> : #endif -<span class="lineNum"> 1138 </span> : -<span class="lineNum"> 1139 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 1140 </span> : -<span class="lineNum"> 1141 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/char_traits.h.gcov.html b/rep/usr/include/c++/4.3/bits/char_traits.h.gcov.html deleted file mode 100644 index 5a682d1..0000000 --- a/rep/usr/include/c++/4.3/bits/char_traits.h.gcov.html +++ /dev/null @@ -1,438 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/char_traits.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - char_traits.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">13</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">46.2 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">6</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Character Traits for use by standard string and iostream -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file char_traits.h -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : // -<span class="lineNum"> 38 </span> : // ISO C++ 14882: 21 Strings library -<span class="lineNum"> 39 </span> : // -<span class="lineNum"> 40 </span> : -<span class="lineNum"> 41 </span> : #ifndef _CHAR_TRAITS_H -<span class="lineNum"> 42 </span> : #define _CHAR_TRAITS_H 1 -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : #pragma GCC system_header -<span class="lineNum"> 45 </span> : -<span class="lineNum"> 46 </span> : #include <bits/stl_algobase.h> // std::copy, std::fill_n -<span class="lineNum"> 47 </span> : #include <bits/postypes.h> // For streampos -<span class="lineNum"> 48 </span> : #include <cstdio> // For EOF -<span class="lineNum"> 49 </span> : #include <cwchar> // For WEOF, wmemmove, wmemset, etc. -<span class="lineNum"> 50 </span> : -<span class="lineNum"> 51 </span> : _GLIBCXX_BEGIN_NAMESPACE(__gnu_cxx) -<span class="lineNum"> 52 </span> : -<span class="lineNum"> 53 </span> : /** -<span class="lineNum"> 54 </span> : * @brief Mapping from character type to associated types. -<span class="lineNum"> 55 </span> : * -<span class="lineNum"> 56 </span> : * @note This is an implementation class for the generic version -<span class="lineNum"> 57 </span> : * of char_traits. It defines int_type, off_type, pos_type, and -<span class="lineNum"> 58 </span> : * state_type. By default these are unsigned long, streamoff, -<span class="lineNum"> 59 </span> : * streampos, and mbstate_t. Users who need a different set of -<span class="lineNum"> 60 </span> : * types, but who don't need to change the definitions of any function -<span class="lineNum"> 61 </span> : * defined in char_traits, can specialize __gnu_cxx::_Char_types -<span class="lineNum"> 62 </span> : * while leaving __gnu_cxx::char_traits alone. */ -<span class="lineNum"> 63 </span> : template<typename _CharT> -<span class="lineNum"> 64 </span> : struct _Char_types -<span class="lineNum"> 65 </span> : { -<span class="lineNum"> 66 </span> : typedef unsigned long int_type; -<span class="lineNum"> 67 </span> : typedef std::streampos pos_type; -<span class="lineNum"> 68 </span> : typedef std::streamoff off_type; -<span class="lineNum"> 69 </span> : typedef std::mbstate_t state_type; -<span class="lineNum"> 70 </span> : }; -<span class="lineNum"> 71 </span> : -<span class="lineNum"> 72 </span> : -<span class="lineNum"> 73 </span> : /** -<span class="lineNum"> 74 </span> : * @brief Base class used to implement std::char_traits. -<span class="lineNum"> 75 </span> : * -<span class="lineNum"> 76 </span> : * @note For any given actual character type, this definition is -<span class="lineNum"> 77 </span> : * probably wrong. (Most of the member functions are likely to be -<span class="lineNum"> 78 </span> : * right, but the int_type and state_type typedefs, and the eof() -<span class="lineNum"> 79 </span> : * member function, are likely to be wrong.) The reason this class -<span class="lineNum"> 80 </span> : * exists is so users can specialize it. Classes in namespace std -<span class="lineNum"> 81 </span> : * may not be specialized for fundamental types, but classes in -<span class="lineNum"> 82 </span> : * namespace __gnu_cxx may be. -<span class="lineNum"> 83 </span> : * -<span class="lineNum"> 84 </span> : * See http://gcc.gnu.org/onlinedocs/libstdc++/21_strings/howto.html#5 -<span class="lineNum"> 85 </span> : * for advice on how to make use of this class for "unusual" character -<span class="lineNum"> 86 </span> : * types. Also, check out include/ext/pod_char_traits.h. -<span class="lineNum"> 87 </span> : */ -<span class="lineNum"> 88 </span> : template<typename _CharT> -<span class="lineNum"> 89 </span> : struct char_traits -<span class="lineNum"> 90 </span> : { -<span class="lineNum"> 91 </span> : typedef _CharT char_type; -<span class="lineNum"> 92 </span> : typedef typename _Char_types<_CharT>::int_type int_type; -<span class="lineNum"> 93 </span> : typedef typename _Char_types<_CharT>::pos_type pos_type; -<span class="lineNum"> 94 </span> : typedef typename _Char_types<_CharT>::off_type off_type; -<span class="lineNum"> 95 </span> : typedef typename _Char_types<_CharT>::state_type state_type; -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : static void -<span class="lineNum"> 98 </span> : assign(char_type& __c1, const char_type& __c2) -<span class="lineNum"> 99 </span> : { __c1 = __c2; } -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : static bool -<span class="lineNum"> 102 </span> : eq(const char_type& __c1, const char_type& __c2) -<span class="lineNum"> 103 </span> : { return __c1 == __c2; } -<span class="lineNum"> 104 </span> : -<span class="lineNum"> 105 </span> : static bool -<span class="lineNum"> 106 </span> : lt(const char_type& __c1, const char_type& __c2) -<span class="lineNum"> 107 </span> : { return __c1 < __c2; } -<span class="lineNum"> 108 </span> : -<span class="lineNum"> 109 </span> : static int -<span class="lineNum"> 110 </span> : compare(const char_type* __s1, const char_type* __s2, std::size_t __n); -<span class="lineNum"> 111 </span> : -<span class="lineNum"> 112 </span> : static std::size_t -<span class="lineNum"> 113 </span> : length(const char_type* __s); -<span class="lineNum"> 114 </span> : -<span class="lineNum"> 115 </span> : static const char_type* -<span class="lineNum"> 116 </span> : find(const char_type* __s, std::size_t __n, const char_type& __a); -<span class="lineNum"> 117 </span> : -<span class="lineNum"> 118 </span> : static char_type* -<span class="lineNum"> 119 </span> : move(char_type* __s1, const char_type* __s2, std::size_t __n); -<span class="lineNum"> 120 </span> : -<span class="lineNum"> 121 </span> : static char_type* -<span class="lineNum"> 122 </span> : copy(char_type* __s1, const char_type* __s2, std::size_t __n); -<span class="lineNum"> 123 </span> : -<span class="lineNum"> 124 </span> : static char_type* -<span class="lineNum"> 125 </span> : assign(char_type* __s, std::size_t __n, char_type __a); -<span class="lineNum"> 126 </span> : -<span class="lineNum"> 127 </span> : static char_type -<span class="lineNum"> 128 </span> : to_char_type(const int_type& __c) -<span class="lineNum"> 129 </span> : { return static_cast<char_type>(__c); } -<span class="lineNum"> 130 </span> : -<span class="lineNum"> 131 </span> : static int_type -<span class="lineNum"> 132 </span> : to_int_type(const char_type& __c) -<span class="lineNum"> 133 </span> : { return static_cast<int_type>(__c); } -<span class="lineNum"> 134 </span> : -<span class="lineNum"> 135 </span> : static bool -<span class="lineNum"> 136 </span> : eq_int_type(const int_type& __c1, const int_type& __c2) -<span class="lineNum"> 137 </span> : { return __c1 == __c2; } -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : static int_type -<span class="lineNum"> 140 </span> : eof() -<span class="lineNum"> 141 </span> : { return static_cast<int_type>(EOF); } -<span class="lineNum"> 142 </span> : -<span class="lineNum"> 143 </span> : static int_type -<span class="lineNum"> 144 </span> : not_eof(const int_type& __c) -<span class="lineNum"> 145 </span> : { return !eq_int_type(__c, eof()) ? __c : to_int_type(char_type()); } -<span class="lineNum"> 146 </span> : }; -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : template<typename _CharT> -<span class="lineNum"> 149 </span> : int -<span class="lineNum"> 150 </span> : char_traits<_CharT>:: -<span class="lineNum"> 151 </span> : compare(const char_type* __s1, const char_type* __s2, std::size_t __n) -<span class="lineNum"> 152 </span> : { -<span class="lineNum"> 153 </span> : for (std::size_t __i = 0; __i < __n; ++__i) -<span class="lineNum"> 154 </span> : if (lt(__s1[__i], __s2[__i])) -<span class="lineNum"> 155 </span> : return -1; -<span class="lineNum"> 156 </span> : else if (lt(__s2[__i], __s1[__i])) -<span class="lineNum"> 157 </span> : return 1; -<span class="lineNum"> 158 </span> : return 0; -<span class="lineNum"> 159 </span> : } -<span class="lineNum"> 160 </span> : -<span class="lineNum"> 161 </span> : template<typename _CharT> -<span class="lineNum"> 162 </span> : std::size_t -<span class="lineNum"> 163 </span> : char_traits<_CharT>:: -<span class="lineNum"> 164 </span> : length(const char_type* __p) -<span class="lineNum"> 165 </span> : { -<span class="lineNum"> 166 </span> : std::size_t __i = 0; -<span class="lineNum"> 167 </span> : while (!eq(__p[__i], char_type())) -<span class="lineNum"> 168 </span> : ++__i; -<span class="lineNum"> 169 </span> : return __i; -<span class="lineNum"> 170 </span> : } -<span class="lineNum"> 171 </span> : -<span class="lineNum"> 172 </span> : template<typename _CharT> -<span class="lineNum"> 173 </span> : const typename char_traits<_CharT>::char_type* -<span class="lineNum"> 174 </span> : char_traits<_CharT>:: -<span class="lineNum"> 175 </span> : find(const char_type* __s, std::size_t __n, const char_type& __a) -<span class="lineNum"> 176 </span> : { -<span class="lineNum"> 177 </span> : for (std::size_t __i = 0; __i < __n; ++__i) -<span class="lineNum"> 178 </span> : if (eq(__s[__i], __a)) -<span class="lineNum"> 179 </span> : return __s + __i; -<span class="lineNum"> 180 </span> : return 0; -<span class="lineNum"> 181 </span> : } -<span class="lineNum"> 182 </span> : -<span class="lineNum"> 183 </span> : template<typename _CharT> -<span class="lineNum"> 184 </span> : typename char_traits<_CharT>::char_type* -<span class="lineNum"> 185 </span> : char_traits<_CharT>:: -<span class="lineNum"> 186 </span> : move(char_type* __s1, const char_type* __s2, std::size_t __n) -<span class="lineNum"> 187 </span> : { -<span class="lineNum"> 188 </span> : return static_cast<_CharT*>(__builtin_memmove(__s1, __s2, -<span class="lineNum"> 189 </span> : __n * sizeof(char_type))); -<span class="lineNum"> 190 </span> : } -<span class="lineNum"> 191 </span> : -<span class="lineNum"> 192 </span> : template<typename _CharT> -<span class="lineNum"> 193 </span> : typename char_traits<_CharT>::char_type* -<span class="lineNum"> 194 </span> : char_traits<_CharT>:: -<span class="lineNum"> 195 </span> : copy(char_type* __s1, const char_type* __s2, std::size_t __n) -<span class="lineNum"> 196 </span> : { -<span class="lineNum"> 197 </span> : // NB: Inline std::copy so no recursive dependencies. -<span class="lineNum"> 198 </span> : std::copy(__s2, __s2 + __n, __s1); -<span class="lineNum"> 199 </span> : return __s1; -<span class="lineNum"> 200 </span> : } -<span class="lineNum"> 201 </span> : -<span class="lineNum"> 202 </span> : template<typename _CharT> -<span class="lineNum"> 203 </span> : typename char_traits<_CharT>::char_type* -<span class="lineNum"> 204 </span> : char_traits<_CharT>:: -<span class="lineNum"> 205 </span> : assign(char_type* __s, std::size_t __n, char_type __a) -<span class="lineNum"> 206 </span> : { -<span class="lineNum"> 207 </span> : // NB: Inline std::fill_n so no recursive dependencies. -<span class="lineNum"> 208 </span> : std::fill_n(__s, __n, __a); -<span class="lineNum"> 209 </span> : return __s; -<span class="lineNum"> 210 </span> : } -<span class="lineNum"> 211 </span> : -<span class="lineNum"> 212 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 213 </span> : -<span class="lineNum"> 214 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 215 </span> : -<span class="lineNum"> 216 </span> : // 21.1 -<span class="lineNum"> 217 </span> : /** -<span class="lineNum"> 218 </span> : * @brief Basis for explicit traits specializations. -<span class="lineNum"> 219 </span> : * -<span class="lineNum"> 220 </span> : * @note For any given actual character type, this definition is -<span class="lineNum"> 221 </span> : * probably wrong. Since this is just a thin wrapper around -<span class="lineNum"> 222 </span> : * __gnu_cxx::char_traits, it is possible to achieve a more -<span class="lineNum"> 223 </span> : * appropriate definition by specializing __gnu_cxx::char_traits. -<span class="lineNum"> 224 </span> : * -<span class="lineNum"> 225 </span> : * See http://gcc.gnu.org/onlinedocs/libstdc++/21_strings/howto.html#5 -<span class="lineNum"> 226 </span> : * for advice on how to make use of this class for "unusual" character -<span class="lineNum"> 227 </span> : * types. Also, check out include/ext/pod_char_traits.h. -<span class="lineNum"> 228 </span> : */ -<span class="lineNum"> 229 </span> : template<class _CharT> -<span class="lineNum"> 230 </span> : struct char_traits : public __gnu_cxx::char_traits<_CharT> -<span class="lineNum"> 231 </span> : { }; -<span class="lineNum"> 232 </span> : -<span class="lineNum"> 233 </span> : -<span class="lineNum"> 234 </span> : /// 21.1.3.1 char_traits specializations -<span class="lineNum"> 235 </span> : template<> -<span class="lineNum"> 236 </span> : struct char_traits<char> -<span class="lineNum"> 237 </span> : { -<span class="lineNum"> 238 </span> : typedef char char_type; -<span class="lineNum"> 239 </span> : typedef int int_type; -<span class="lineNum"> 240 </span> : typedef streampos pos_type; -<span class="lineNum"> 241 </span> : typedef streamoff off_type; -<span class="lineNum"> 242 </span> : typedef mbstate_t state_type; -<span class="lineNum"> 243 </span> : -<span class="lineNum"> 244 </span> : static void -<span class="lineNum"> 245 </span><span class="lineCov"> 10976 : assign(char_type& __c1, const char_type& __c2)</span> -<span class="lineNum"> 246 </span><span class="lineCov"> 10976 : { __c1 = __c2; }</span> -<span class="lineNum"> 247 </span> : -<span class="lineNum"> 248 </span> : static bool -<span class="lineNum"> 249 </span> : eq(const char_type& __c1, const char_type& __c2) -<span class="lineNum"> 250 </span> : { return __c1 == __c2; } -<span class="lineNum"> 251 </span> : -<span class="lineNum"> 252 </span> : static bool -<span class="lineNum"> 253 </span> : lt(const char_type& __c1, const char_type& __c2) -<span class="lineNum"> 254 </span> : { return __c1 < __c2; } -<span class="lineNum"> 255 </span> : -<span class="lineNum"> 256 </span> : static int -<span class="lineNum"> 257 </span><span class="lineCov"> 115296 : compare(const char_type* __s1, const char_type* __s2, size_t __n)</span> -<span class="lineNum"> 258 </span><span class="lineCov"> 115296 : { return __builtin_memcmp(__s1, __s2, __n); }</span> -<span class="lineNum"> 259 </span> : -<span class="lineNum"> 260 </span> : static size_t -<span class="lineNum"> 261 </span><span class="lineCov"> 2633 : length(const char_type* __s)</span> -<span class="lineNum"> 262 </span><span class="lineCov"> 2633 : { return __builtin_strlen(__s); }</span> -<span class="lineNum"> 263 </span> : -<span class="lineNum"> 264 </span> : static const char_type* -<span class="lineNum"> 265 </span> : find(const char_type* __s, size_t __n, const char_type& __a) -<span class="lineNum"> 266 </span> : { return static_cast<const char_type*>(__builtin_memchr(__s, __a, __n)); } -<span class="lineNum"> 267 </span> : -<span class="lineNum"> 268 </span> : static char_type* -<span class="lineNum"> 269 </span> : move(char_type* __s1, const char_type* __s2, size_t __n) -<span class="lineNum"> 270 </span> : { return static_cast<char_type*>(__builtin_memmove(__s1, __s2, __n)); } -<span class="lineNum"> 271 </span> : -<span class="lineNum"> 272 </span> : static char_type* -<span class="lineNum"> 273 </span><span class="lineNoCov"> 0 : copy(char_type* __s1, const char_type* __s2, size_t __n)</span> -<span class="lineNum"> 274 </span><span class="lineNoCov"> 0 : { return static_cast<char_type*>(__builtin_memcpy(__s1, __s2, __n)); }</span> -<span class="lineNum"> 275 </span> : -<span class="lineNum"> 276 </span> : static char_type* -<span class="lineNum"> 277 </span> : assign(char_type* __s, size_t __n, char_type __a) -<span class="lineNum"> 278 </span> : { return static_cast<char_type*>(__builtin_memset(__s, __a, __n)); } -<span class="lineNum"> 279 </span> : -<span class="lineNum"> 280 </span> : static char_type -<span class="lineNum"> 281 </span> : to_char_type(const int_type& __c) -<span class="lineNum"> 282 </span> : { return static_cast<char_type>(__c); } -<span class="lineNum"> 283 </span> : -<span class="lineNum"> 284 </span> : // To keep both the byte 0xff and the eof symbol 0xffffffff -<span class="lineNum"> 285 </span> : // from ending up as 0xffffffff. -<span class="lineNum"> 286 </span> : static int_type -<span class="lineNum"> 287 </span><span class="lineNoCov"> 0 : to_int_type(const char_type& __c)</span> -<span class="lineNum"> 288 </span><span class="lineNoCov"> 0 : { return static_cast<int_type>(static_cast<unsigned char>(__c)); }</span> -<span class="lineNum"> 289 </span> : -<span class="lineNum"> 290 </span> : static bool -<span class="lineNum"> 291 </span><span class="lineNoCov"> 0 : eq_int_type(const int_type& __c1, const int_type& __c2)</span> -<span class="lineNum"> 292 </span><span class="lineNoCov"> 0 : { return __c1 == __c2; }</span> -<span class="lineNum"> 293 </span> : -<span class="lineNum"> 294 </span> : static int_type -<span class="lineNum"> 295 </span><span class="lineNoCov"> 0 : eof() { return static_cast<int_type>(EOF); }</span> -<span class="lineNum"> 296 </span> : -<span class="lineNum"> 297 </span> : static int_type -<span class="lineNum"> 298 </span> : not_eof(const int_type& __c) -<span class="lineNum"> 299 </span> : { return (__c == eof()) ? 0 : __c; } -<span class="lineNum"> 300 </span> : }; -<span class="lineNum"> 301 </span> : -<span class="lineNum"> 302 </span> : -<span class="lineNum"> 303 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 304 </span> : /// 21.1.3.2 char_traits specializations -<span class="lineNum"> 305 </span> : template<> -<span class="lineNum"> 306 </span> : struct char_traits<wchar_t> -<span class="lineNum"> 307 </span> : { -<span class="lineNum"> 308 </span> : typedef wchar_t char_type; -<span class="lineNum"> 309 </span> : typedef wint_t int_type; -<span class="lineNum"> 310 </span> : typedef streamoff off_type; -<span class="lineNum"> 311 </span> : typedef wstreampos pos_type; -<span class="lineNum"> 312 </span> : typedef mbstate_t state_type; -<span class="lineNum"> 313 </span> : -<span class="lineNum"> 314 </span> : static void -<span class="lineNum"> 315 </span> : assign(char_type& __c1, const char_type& __c2) -<span class="lineNum"> 316 </span> : { __c1 = __c2; } -<span class="lineNum"> 317 </span> : -<span class="lineNum"> 318 </span> : static bool -<span class="lineNum"> 319 </span> : eq(const char_type& __c1, const char_type& __c2) -<span class="lineNum"> 320 </span> : { return __c1 == __c2; } -<span class="lineNum"> 321 </span> : -<span class="lineNum"> 322 </span> : static bool -<span class="lineNum"> 323 </span> : lt(const char_type& __c1, const char_type& __c2) -<span class="lineNum"> 324 </span> : { return __c1 < __c2; } -<span class="lineNum"> 325 </span> : -<span class="lineNum"> 326 </span> : static int -<span class="lineNum"> 327 </span> : compare(const char_type* __s1, const char_type* __s2, size_t __n) -<span class="lineNum"> 328 </span> : { return wmemcmp(__s1, __s2, __n); } -<span class="lineNum"> 329 </span> : -<span class="lineNum"> 330 </span> : static size_t -<span class="lineNum"> 331 </span> : length(const char_type* __s) -<span class="lineNum"> 332 </span> : { return wcslen(__s); } -<span class="lineNum"> 333 </span> : -<span class="lineNum"> 334 </span> : static const char_type* -<span class="lineNum"> 335 </span> : find(const char_type* __s, size_t __n, const char_type& __a) -<span class="lineNum"> 336 </span> : { return wmemchr(__s, __a, __n); } -<span class="lineNum"> 337 </span> : -<span class="lineNum"> 338 </span> : static char_type* -<span class="lineNum"> 339 </span> : move(char_type* __s1, const char_type* __s2, size_t __n) -<span class="lineNum"> 340 </span> : { return wmemmove(__s1, __s2, __n); } -<span class="lineNum"> 341 </span> : -<span class="lineNum"> 342 </span> : static char_type* -<span class="lineNum"> 343 </span> : copy(char_type* __s1, const char_type* __s2, size_t __n) -<span class="lineNum"> 344 </span> : { return wmemcpy(__s1, __s2, __n); } -<span class="lineNum"> 345 </span> : -<span class="lineNum"> 346 </span> : static char_type* -<span class="lineNum"> 347 </span> : assign(char_type* __s, size_t __n, char_type __a) -<span class="lineNum"> 348 </span> : { return wmemset(__s, __a, __n); } -<span class="lineNum"> 349 </span> : -<span class="lineNum"> 350 </span> : static char_type -<span class="lineNum"> 351 </span> : to_char_type(const int_type& __c) { return char_type(__c); } -<span class="lineNum"> 352 </span> : -<span class="lineNum"> 353 </span> : static int_type -<span class="lineNum"> 354 </span> : to_int_type(const char_type& __c) { return int_type(__c); } -<span class="lineNum"> 355 </span> : -<span class="lineNum"> 356 </span> : static bool -<span class="lineNum"> 357 </span> : eq_int_type(const int_type& __c1, const int_type& __c2) -<span class="lineNum"> 358 </span> : { return __c1 == __c2; } -<span class="lineNum"> 359 </span> : -<span class="lineNum"> 360 </span> : static int_type -<span class="lineNum"> 361 </span> : eof() { return static_cast<int_type>(WEOF); } -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : static int_type -<span class="lineNum"> 364 </span> : not_eof(const int_type& __c) -<span class="lineNum"> 365 </span> : { return eq_int_type(__c, eof()) ? 0 : __c; } -<span class="lineNum"> 366 </span> : }; -<span class="lineNum"> 367 </span> : #endif //_GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 368 </span> : -<span class="lineNum"> 369 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 370 </span> : -<span class="lineNum"> 371 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/deque.tcc.gcov.html b/rep/usr/include/c++/4.3/bits/deque.tcc.gcov.html deleted file mode 100644 index 08f01e5..0000000 --- a/rep/usr/include/c++/4.3/bits/deque.tcc.gcov.html +++ /dev/null @@ -1,900 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/deque.tcc</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - deque.tcc</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">147</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">19.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">28</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Deque implementation (out of line) -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file deque.tcc -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _DEQUE_TCC -<span class="lineNum"> 63 </span> : #define _DEQUE_TCC 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 68 </span> : deque<_Tp, _Alloc>& -<span class="lineNum"> 69 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 70 </span><span class="lineCov"> 4 : operator=(const deque& __x)</span> -<span class="lineNum"> 71 </span> : { -<span class="lineNum"> 72 </span><span class="lineCov"> 4 : const size_type __len = size();</span> -<span class="lineNum"> 73 </span><span class="lineCov"> 4 : if (&__x != this)</span> -<span class="lineNum"> 74 </span> : { -<span class="lineNum"> 75 </span><span class="lineCov"> 4 : if (__len >= __x.size())</span> -<span class="lineNum"> 76 </span><span class="lineCov"> 4 : _M_erase_at_end(std::copy(__x.begin(), __x.end(),</span> -<span class="lineNum"> 77 </span> : this->_M_impl._M_start)); -<span class="lineNum"> 78 </span> : else -<span class="lineNum"> 79 </span> : { -<span class="lineNum"> 80 </span><span class="lineNoCov"> 0 : const_iterator __mid = __x.begin() + difference_type(__len);</span> -<span class="lineNum"> 81 </span><span class="lineNoCov"> 0 : std::copy(__x.begin(), __mid, this->_M_impl._M_start);</span> -<span class="lineNum"> 82 </span><span class="lineNoCov"> 0 : insert(this->_M_impl._M_finish, __mid, __x.end());</span> -<span class="lineNum"> 83 </span> : } -<span class="lineNum"> 84 </span> : } -<span class="lineNum"> 85 </span><span class="lineCov"> 4 : return *this;</span> -<span class="lineNum"> 86 </span> : } -<span class="lineNum"> 87 </span> : -<span class="lineNum"> 88 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 89 </span> : typename deque<_Tp, _Alloc>::iterator -<span class="lineNum"> 90 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 91 </span> : insert(iterator __position, const value_type& __x) -<span class="lineNum"> 92 </span> : { -<span class="lineNum"> 93 </span> : if (__position._M_cur == this->_M_impl._M_start._M_cur) -<span class="lineNum"> 94 </span> : { -<span class="lineNum"> 95 </span> : push_front(__x); -<span class="lineNum"> 96 </span> : return this->_M_impl._M_start; -<span class="lineNum"> 97 </span> : } -<span class="lineNum"> 98 </span> : else if (__position._M_cur == this->_M_impl._M_finish._M_cur) -<span class="lineNum"> 99 </span> : { -<span class="lineNum"> 100 </span> : push_back(__x); -<span class="lineNum"> 101 </span> : iterator __tmp = this->_M_impl._M_finish; -<span class="lineNum"> 102 </span> : --__tmp; -<span class="lineNum"> 103 </span> : return __tmp; -<span class="lineNum"> 104 </span> : } -<span class="lineNum"> 105 </span> : else -<span class="lineNum"> 106 </span> : return _M_insert_aux(__position, __x); -<span class="lineNum"> 107 </span> : } -<span class="lineNum"> 108 </span> : -<span class="lineNum"> 109 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 110 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 111 </span> : template<typename... _Args> -<span class="lineNum"> 112 </span> : typename deque<_Tp, _Alloc>::iterator -<span class="lineNum"> 113 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 114 </span> : emplace(iterator __position, _Args&&... __args) -<span class="lineNum"> 115 </span> : { -<span class="lineNum"> 116 </span> : if (__position._M_cur == this->_M_impl._M_start._M_cur) -<span class="lineNum"> 117 </span> : { -<span class="lineNum"> 118 </span> : push_front(std::forward<_Args>(__args)...); -<span class="lineNum"> 119 </span> : return this->_M_impl._M_start; -<span class="lineNum"> 120 </span> : } -<span class="lineNum"> 121 </span> : else if (__position._M_cur == this->_M_impl._M_finish._M_cur) -<span class="lineNum"> 122 </span> : { -<span class="lineNum"> 123 </span> : push_back(std::forward<_Args>(__args)...); -<span class="lineNum"> 124 </span> : iterator __tmp = this->_M_impl._M_finish; -<span class="lineNum"> 125 </span> : --__tmp; -<span class="lineNum"> 126 </span> : return __tmp; -<span class="lineNum"> 127 </span> : } -<span class="lineNum"> 128 </span> : else -<span class="lineNum"> 129 </span> : return _M_insert_aux(__position, std::forward<_Args>(__args)...); -<span class="lineNum"> 130 </span> : } -<span class="lineNum"> 131 </span> : #endif -<span class="lineNum"> 132 </span> : -<span class="lineNum"> 133 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 134 </span> : typename deque<_Tp, _Alloc>::iterator -<span class="lineNum"> 135 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 136 </span> : erase(iterator __position) -<span class="lineNum"> 137 </span> : { -<span class="lineNum"> 138 </span> : iterator __next = __position; -<span class="lineNum"> 139 </span> : ++__next; -<span class="lineNum"> 140 </span> : const difference_type __index = __position - begin(); -<span class="lineNum"> 141 </span> : if (static_cast<size_type>(__index) < (size() >> 1)) -<span class="lineNum"> 142 </span> : { -<span class="lineNum"> 143 </span> : if (__position != begin()) -<span class="lineNum"> 144 </span> : _GLIBCXX_MOVE_BACKWARD3(begin(), __position, __next); -<span class="lineNum"> 145 </span> : pop_front(); -<span class="lineNum"> 146 </span> : } -<span class="lineNum"> 147 </span> : else -<span class="lineNum"> 148 </span> : { -<span class="lineNum"> 149 </span> : if (__next != end()) -<span class="lineNum"> 150 </span> : _GLIBCXX_MOVE3(__next, end(), __position); -<span class="lineNum"> 151 </span> : pop_back(); -<span class="lineNum"> 152 </span> : } -<span class="lineNum"> 153 </span> : return begin() + __index; -<span class="lineNum"> 154 </span> : } -<span class="lineNum"> 155 </span> : -<span class="lineNum"> 156 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 157 </span> : typename deque<_Tp, _Alloc>::iterator -<span class="lineNum"> 158 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 159 </span><span class="lineCov"> 1012 : erase(iterator __first, iterator __last)</span> -<span class="lineNum"> 160 </span> : { -<span class="lineNum"> 161 </span><span class="lineCov"> 1012 : if (__first == begin() && __last == end())</span> -<span class="lineNum"> 162 </span> : { -<span class="lineNum"> 163 </span><span class="lineCov"> 922 : clear();</span> -<span class="lineNum"> 164 </span><span class="lineCov"> 922 : return end();</span> -<span class="lineNum"> 165 </span> : } -<span class="lineNum"> 166 </span> : else -<span class="lineNum"> 167 </span> : { -<span class="lineNum"> 168 </span><span class="lineCov"> 90 : const difference_type __n = __last - __first;</span> -<span class="lineNum"> 169 </span><span class="lineCov"> 90 : const difference_type __elems_before = __first - begin();</span> -<span class="lineNum"> 170 </span><span class="lineCov"> 90 : if (static_cast<size_type>(__elems_before) <= (size() - __n) / 2)</span> -<span class="lineNum"> 171 </span> : { -<span class="lineNum"> 172 </span><span class="lineCov"> 90 : if (__first != begin())</span> -<span class="lineNum"> 173 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE_BACKWARD3(begin(), __first, __last);</span> -<span class="lineNum"> 174 </span><span class="lineCov"> 90 : _M_erase_at_begin(begin() + __n);</span> -<span class="lineNum"> 175 </span> : } -<span class="lineNum"> 176 </span> : else -<span class="lineNum"> 177 </span> : { -<span class="lineNum"> 178 </span><span class="lineNoCov"> 0 : if (__last != end())</span> -<span class="lineNum"> 179 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE3(__last, end(), __first);</span> -<span class="lineNum"> 180 </span><span class="lineNoCov"> 0 : _M_erase_at_end(end() - __n);</span> -<span class="lineNum"> 181 </span> : } -<span class="lineNum"> 182 </span><span class="lineCov"> 90 : return begin() + __elems_before;</span> -<span class="lineNum"> 183 </span> : } -<span class="lineNum"> 184 </span> : } -<span class="lineNum"> 185 </span> : -<span class="lineNum"> 186 </span> : template <typename _Tp, class _Alloc> -<span class="lineNum"> 187 </span> : template <typename _InputIterator> -<span class="lineNum"> 188 </span> : void -<span class="lineNum"> 189 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 190 </span> : _M_assign_aux(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 191 </span> : std::input_iterator_tag) -<span class="lineNum"> 192 </span> : { -<span class="lineNum"> 193 </span> : iterator __cur = begin(); -<span class="lineNum"> 194 </span> : for (; __first != __last && __cur != end(); ++__cur, ++__first) -<span class="lineNum"> 195 </span> : *__cur = *__first; -<span class="lineNum"> 196 </span> : if (__first == __last) -<span class="lineNum"> 197 </span> : _M_erase_at_end(__cur); -<span class="lineNum"> 198 </span> : else -<span class="lineNum"> 199 </span> : insert(end(), __first, __last); -<span class="lineNum"> 200 </span> : } -<span class="lineNum"> 201 </span> : -<span class="lineNum"> 202 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 203 </span> : void -<span class="lineNum"> 204 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 205 </span> : _M_fill_insert(iterator __pos, size_type __n, const value_type& __x) -<span class="lineNum"> 206 </span> : { -<span class="lineNum"> 207 </span> : if (__pos._M_cur == this->_M_impl._M_start._M_cur) -<span class="lineNum"> 208 </span> : { -<span class="lineNum"> 209 </span> : iterator __new_start = _M_reserve_elements_at_front(__n); -<span class="lineNum"> 210 </span> : try -<span class="lineNum"> 211 </span> : { -<span class="lineNum"> 212 </span> : std::__uninitialized_fill_a(__new_start, this->_M_impl._M_start, -<span class="lineNum"> 213 </span> : __x, _M_get_Tp_allocator()); -<span class="lineNum"> 214 </span> : this->_M_impl._M_start = __new_start; -<span class="lineNum"> 215 </span> : } -<span class="lineNum"> 216 </span> : catch(...) -<span class="lineNum"> 217 </span> : { -<span class="lineNum"> 218 </span> : _M_destroy_nodes(__new_start._M_node, -<span class="lineNum"> 219 </span> : this->_M_impl._M_start._M_node); -<span class="lineNum"> 220 </span> : __throw_exception_again; -<span class="lineNum"> 221 </span> : } -<span class="lineNum"> 222 </span> : } -<span class="lineNum"> 223 </span> : else if (__pos._M_cur == this->_M_impl._M_finish._M_cur) -<span class="lineNum"> 224 </span> : { -<span class="lineNum"> 225 </span> : iterator __new_finish = _M_reserve_elements_at_back(__n); -<span class="lineNum"> 226 </span> : try -<span class="lineNum"> 227 </span> : { -<span class="lineNum"> 228 </span> : std::__uninitialized_fill_a(this->_M_impl._M_finish, -<span class="lineNum"> 229 </span> : __new_finish, __x, -<span class="lineNum"> 230 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 231 </span> : this->_M_impl._M_finish = __new_finish; -<span class="lineNum"> 232 </span> : } -<span class="lineNum"> 233 </span> : catch(...) -<span class="lineNum"> 234 </span> : { -<span class="lineNum"> 235 </span> : _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1, -<span class="lineNum"> 236 </span> : __new_finish._M_node + 1); -<span class="lineNum"> 237 </span> : __throw_exception_again; -<span class="lineNum"> 238 </span> : } -<span class="lineNum"> 239 </span> : } -<span class="lineNum"> 240 </span> : else -<span class="lineNum"> 241 </span> : _M_insert_aux(__pos, __n, __x); -<span class="lineNum"> 242 </span> : } -<span class="lineNum"> 243 </span> : -<span class="lineNum"> 244 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 245 </span> : void -<span class="lineNum"> 246 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 247 </span> : _M_fill_initialize(const value_type& __value) -<span class="lineNum"> 248 </span> : { -<span class="lineNum"> 249 </span> : _Map_pointer __cur; -<span class="lineNum"> 250 </span> : try -<span class="lineNum"> 251 </span> : { -<span class="lineNum"> 252 </span> : for (__cur = this->_M_impl._M_start._M_node; -<span class="lineNum"> 253 </span> : __cur < this->_M_impl._M_finish._M_node; -<span class="lineNum"> 254 </span> : ++__cur) -<span class="lineNum"> 255 </span> : std::__uninitialized_fill_a(*__cur, *__cur + _S_buffer_size(), -<span class="lineNum"> 256 </span> : __value, _M_get_Tp_allocator()); -<span class="lineNum"> 257 </span> : std::__uninitialized_fill_a(this->_M_impl._M_finish._M_first, -<span class="lineNum"> 258 </span> : this->_M_impl._M_finish._M_cur, -<span class="lineNum"> 259 </span> : __value, _M_get_Tp_allocator()); -<span class="lineNum"> 260 </span> : } -<span class="lineNum"> 261 </span> : catch(...) -<span class="lineNum"> 262 </span> : { -<span class="lineNum"> 263 </span> : std::_Destroy(this->_M_impl._M_start, iterator(*__cur, __cur), -<span class="lineNum"> 264 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 265 </span> : __throw_exception_again; -<span class="lineNum"> 266 </span> : } -<span class="lineNum"> 267 </span> : } -<span class="lineNum"> 268 </span> : -<span class="lineNum"> 269 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 270 </span> : template <typename _InputIterator> -<span class="lineNum"> 271 </span> : void -<span class="lineNum"> 272 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 273 </span> : _M_range_initialize(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 274 </span> : std::input_iterator_tag) -<span class="lineNum"> 275 </span> : { -<span class="lineNum"> 276 </span> : this->_M_initialize_map(0); -<span class="lineNum"> 277 </span> : try -<span class="lineNum"> 278 </span> : { -<span class="lineNum"> 279 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 280 </span> : push_back(*__first); -<span class="lineNum"> 281 </span> : } -<span class="lineNum"> 282 </span> : catch(...) -<span class="lineNum"> 283 </span> : { -<span class="lineNum"> 284 </span> : clear(); -<span class="lineNum"> 285 </span> : __throw_exception_again; -<span class="lineNum"> 286 </span> : } -<span class="lineNum"> 287 </span> : } -<span class="lineNum"> 288 </span> : -<span class="lineNum"> 289 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 290 </span> : template <typename _ForwardIterator> -<span class="lineNum"> 291 </span> : void -<span class="lineNum"> 292 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 293 </span> : _M_range_initialize(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 294 </span> : std::forward_iterator_tag) -<span class="lineNum"> 295 </span> : { -<span class="lineNum"> 296 </span> : const size_type __n = std::distance(__first, __last); -<span class="lineNum"> 297 </span> : this->_M_initialize_map(__n); -<span class="lineNum"> 298 </span> : -<span class="lineNum"> 299 </span> : _Map_pointer __cur_node; -<span class="lineNum"> 300 </span> : try -<span class="lineNum"> 301 </span> : { -<span class="lineNum"> 302 </span> : for (__cur_node = this->_M_impl._M_start._M_node; -<span class="lineNum"> 303 </span> : __cur_node < this->_M_impl._M_finish._M_node; -<span class="lineNum"> 304 </span> : ++__cur_node) -<span class="lineNum"> 305 </span> : { -<span class="lineNum"> 306 </span> : _ForwardIterator __mid = __first; -<span class="lineNum"> 307 </span> : std::advance(__mid, _S_buffer_size()); -<span class="lineNum"> 308 </span> : std::__uninitialized_copy_a(__first, __mid, *__cur_node, -<span class="lineNum"> 309 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 310 </span> : __first = __mid; -<span class="lineNum"> 311 </span> : } -<span class="lineNum"> 312 </span> : std::__uninitialized_copy_a(__first, __last, -<span class="lineNum"> 313 </span> : this->_M_impl._M_finish._M_first, -<span class="lineNum"> 314 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 315 </span> : } -<span class="lineNum"> 316 </span> : catch(...) -<span class="lineNum"> 317 </span> : { -<span class="lineNum"> 318 </span> : std::_Destroy(this->_M_impl._M_start, -<span class="lineNum"> 319 </span> : iterator(*__cur_node, __cur_node), -<span class="lineNum"> 320 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 321 </span> : __throw_exception_again; -<span class="lineNum"> 322 </span> : } -<span class="lineNum"> 323 </span> : } -<span class="lineNum"> 324 </span> : -<span class="lineNum"> 325 </span> : // Called only if _M_impl._M_finish._M_cur == _M_impl._M_finish._M_last - 1. -<span class="lineNum"> 326 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 327 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 328 </span> : template<typename... _Args> -<span class="lineNum"> 329 </span> : void -<span class="lineNum"> 330 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 331 </span> : _M_push_back_aux(_Args&&... __args) -<span class="lineNum"> 332 </span> : #else -<span class="lineNum"> 333 </span> : void -<span class="lineNum"> 334 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 335 </span><span class="lineCov"> 13 : _M_push_back_aux(const value_type& __t)</span> -<span class="lineNum"> 336 </span> : #endif -<span class="lineNum"> 337 </span> : { -<span class="lineNum"> 338 </span><span class="lineCov"> 13 : _M_reserve_map_at_back();</span> -<span class="lineNum"> 339 </span><span class="lineCov"> 13 : *(this->_M_impl._M_finish._M_node + 1) = this->_M_allocate_node();</span> -<span class="lineNum"> 340 </span> : try -<span class="lineNum"> 341 </span> : { -<span class="lineNum"> 342 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 343 </span> : this->_M_impl.construct(this->_M_impl._M_finish._M_cur, -<span class="lineNum"> 344 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 345 </span> : #else -<span class="lineNum"> 346 </span><span class="lineCov"> 13 : this->_M_impl.construct(this->_M_impl._M_finish._M_cur, __t);</span> -<span class="lineNum"> 347 </span> : #endif -<span class="lineNum"> 348 </span><span class="lineCov"> 13 : this->_M_impl._M_finish._M_set_node(this->_M_impl._M_finish._M_node</span> -<span class="lineNum"> 349 </span> : + 1); -<span class="lineNum"> 350 </span><span class="lineCov"> 13 : this->_M_impl._M_finish._M_cur = this->_M_impl._M_finish._M_first;</span> -<span class="lineNum"> 351 </span> : } -<span class="lineNum"> 352 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 353 </span> : { -<span class="lineNum"> 354 </span><span class="lineNoCov"> 0 : _M_deallocate_node(*(this->_M_impl._M_finish._M_node + 1));</span> -<span class="lineNum"> 355 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 356 </span> : } -<span class="lineNum"> 357 </span><span class="lineCov"> 13 : }</span> -<span class="lineNum"> 358 </span> : -<span class="lineNum"> 359 </span> : // Called only if _M_impl._M_start._M_cur == _M_impl._M_start._M_first. -<span class="lineNum"> 360 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 361 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 362 </span> : template<typename... _Args> -<span class="lineNum"> 363 </span> : void -<span class="lineNum"> 364 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 365 </span> : _M_push_front_aux(_Args&&... __args) -<span class="lineNum"> 366 </span> : #else -<span class="lineNum"> 367 </span> : void -<span class="lineNum"> 368 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 369 </span> : _M_push_front_aux(const value_type& __t) -<span class="lineNum"> 370 </span> : #endif -<span class="lineNum"> 371 </span> : { -<span class="lineNum"> 372 </span> : _M_reserve_map_at_front(); -<span class="lineNum"> 373 </span> : *(this->_M_impl._M_start._M_node - 1) = this->_M_allocate_node(); -<span class="lineNum"> 374 </span> : try -<span class="lineNum"> 375 </span> : { -<span class="lineNum"> 376 </span> : this->_M_impl._M_start._M_set_node(this->_M_impl._M_start._M_node -<span class="lineNum"> 377 </span> : - 1); -<span class="lineNum"> 378 </span> : this->_M_impl._M_start._M_cur = this->_M_impl._M_start._M_last - 1; -<span class="lineNum"> 379 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 380 </span> : this->_M_impl.construct(this->_M_impl._M_start._M_cur, -<span class="lineNum"> 381 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 382 </span> : #else -<span class="lineNum"> 383 </span> : this->_M_impl.construct(this->_M_impl._M_start._M_cur, __t); -<span class="lineNum"> 384 </span> : #endif -<span class="lineNum"> 385 </span> : } -<span class="lineNum"> 386 </span> : catch(...) -<span class="lineNum"> 387 </span> : { -<span class="lineNum"> 388 </span> : ++this->_M_impl._M_start; -<span class="lineNum"> 389 </span> : _M_deallocate_node(*(this->_M_impl._M_start._M_node - 1)); -<span class="lineNum"> 390 </span> : __throw_exception_again; -<span class="lineNum"> 391 </span> : } -<span class="lineNum"> 392 </span> : } -<span class="lineNum"> 393 </span> : -<span class="lineNum"> 394 </span> : // Called only if _M_impl._M_finish._M_cur == _M_impl._M_finish._M_first. -<span class="lineNum"> 395 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 396 </span> : void deque<_Tp, _Alloc>:: -<span class="lineNum"> 397 </span><span class="lineNoCov"> 0 : _M_pop_back_aux()</span> -<span class="lineNum"> 398 </span> : { -<span class="lineNum"> 399 </span><span class="lineNoCov"> 0 : _M_deallocate_node(this->_M_impl._M_finish._M_first);</span> -<span class="lineNum"> 400 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish._M_set_node(this->_M_impl._M_finish._M_node - 1);</span> -<span class="lineNum"> 401 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish._M_cur = this->_M_impl._M_finish._M_last - 1;</span> -<span class="lineNum"> 402 </span><span class="lineNoCov"> 0 : this->_M_impl.destroy(this->_M_impl._M_finish._M_cur);</span> -<span class="lineNum"> 403 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 404 </span> : -<span class="lineNum"> 405 </span> : // Called only if _M_impl._M_start._M_cur == _M_impl._M_start._M_last - 1. -<span class="lineNum"> 406 </span> : // Note that if the deque has at least one element (a precondition for this -<span class="lineNum"> 407 </span> : // member function), and if -<span class="lineNum"> 408 </span> : // _M_impl._M_start._M_cur == _M_impl._M_start._M_last, -<span class="lineNum"> 409 </span> : // then the deque must have at least two nodes. -<span class="lineNum"> 410 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 411 </span> : void deque<_Tp, _Alloc>:: -<span class="lineNum"> 412 </span> : _M_pop_front_aux() -<span class="lineNum"> 413 </span> : { -<span class="lineNum"> 414 </span> : this->_M_impl.destroy(this->_M_impl._M_start._M_cur); -<span class="lineNum"> 415 </span> : _M_deallocate_node(this->_M_impl._M_start._M_first); -<span class="lineNum"> 416 </span> : this->_M_impl._M_start._M_set_node(this->_M_impl._M_start._M_node + 1); -<span class="lineNum"> 417 </span> : this->_M_impl._M_start._M_cur = this->_M_impl._M_start._M_first; -<span class="lineNum"> 418 </span> : } -<span class="lineNum"> 419 </span> : -<span class="lineNum"> 420 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 421 </span> : template <typename _InputIterator> -<span class="lineNum"> 422 </span> : void -<span class="lineNum"> 423 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 424 </span> : _M_range_insert_aux(iterator __pos, -<span class="lineNum"> 425 </span> : _InputIterator __first, _InputIterator __last, -<span class="lineNum"> 426 </span> : std::input_iterator_tag) -<span class="lineNum"> 427 </span> : { std::copy(__first, __last, std::inserter(*this, __pos)); } -<span class="lineNum"> 428 </span> : -<span class="lineNum"> 429 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 430 </span> : template <typename _ForwardIterator> -<span class="lineNum"> 431 </span> : void -<span class="lineNum"> 432 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 433 </span> : _M_range_insert_aux(iterator __pos, -<span class="lineNum"> 434 </span> : _ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 435 </span><span class="lineNoCov"> 0 : std::forward_iterator_tag)</span> -<span class="lineNum"> 436 </span> : { -<span class="lineNum"> 437 </span><span class="lineNoCov"> 0 : const size_type __n = std::distance(__first, __last);</span> -<span class="lineNum"> 438 </span><span class="lineNoCov"> 0 : if (__pos._M_cur == this->_M_impl._M_start._M_cur)</span> -<span class="lineNum"> 439 </span> : { -<span class="lineNum"> 440 </span><span class="lineNoCov"> 0 : iterator __new_start = _M_reserve_elements_at_front(__n);</span> -<span class="lineNum"> 441 </span> : try -<span class="lineNum"> 442 </span> : { -<span class="lineNum"> 443 </span><span class="lineNoCov"> 0 : std::__uninitialized_copy_a(__first, __last, __new_start,</span> -<span class="lineNum"> 444 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 445 </span><span class="lineNoCov"> 0 : this->_M_impl._M_start = __new_start;</span> -<span class="lineNum"> 446 </span> : } -<span class="lineNum"> 447 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 448 </span> : { -<span class="lineNum"> 449 </span><span class="lineNoCov"> 0 : _M_destroy_nodes(__new_start._M_node,</span> -<span class="lineNum"> 450 </span> : this->_M_impl._M_start._M_node); -<span class="lineNum"> 451 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 452 </span> : } -<span class="lineNum"> 453 </span> : } -<span class="lineNum"> 454 </span><span class="lineNoCov"> 0 : else if (__pos._M_cur == this->_M_impl._M_finish._M_cur)</span> -<span class="lineNum"> 455 </span> : { -<span class="lineNum"> 456 </span><span class="lineNoCov"> 0 : iterator __new_finish = _M_reserve_elements_at_back(__n);</span> -<span class="lineNum"> 457 </span> : try -<span class="lineNum"> 458 </span> : { -<span class="lineNum"> 459 </span><span class="lineNoCov"> 0 : std::__uninitialized_copy_a(__first, __last,</span> -<span class="lineNum"> 460 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 461 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 462 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish = __new_finish;</span> -<span class="lineNum"> 463 </span> : } -<span class="lineNum"> 464 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 465 </span> : { -<span class="lineNum"> 466 </span><span class="lineNoCov"> 0 : _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,</span> -<span class="lineNum"> 467 </span> : __new_finish._M_node + 1); -<span class="lineNum"> 468 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 469 </span> : } -<span class="lineNum"> 470 </span> : } -<span class="lineNum"> 471 </span> : else -<span class="lineNum"> 472 </span><span class="lineNoCov"> 0 : _M_insert_aux(__pos, __first, __last, __n);</span> -<span class="lineNum"> 473 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 474 </span> : -<span class="lineNum"> 475 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 476 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 477 </span> : template<typename... _Args> -<span class="lineNum"> 478 </span> : typename deque<_Tp, _Alloc>::iterator -<span class="lineNum"> 479 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 480 </span> : _M_insert_aux(iterator __pos, _Args&&... __args) -<span class="lineNum"> 481 </span> : { -<span class="lineNum"> 482 </span> : value_type __x_copy(std::forward<_Args>(__args)...); // XXX copy -<span class="lineNum"> 483 </span> : #else -<span class="lineNum"> 484 </span> : typename deque<_Tp, _Alloc>::iterator -<span class="lineNum"> 485 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 486 </span> : _M_insert_aux(iterator __pos, const value_type& __x) -<span class="lineNum"> 487 </span> : { -<span class="lineNum"> 488 </span> : value_type __x_copy = __x; // XXX copy -<span class="lineNum"> 489 </span> : #endif -<span class="lineNum"> 490 </span> : difference_type __index = __pos - this->_M_impl._M_start; -<span class="lineNum"> 491 </span> : if (static_cast<size_type>(__index) < size() / 2) -<span class="lineNum"> 492 </span> : { -<span class="lineNum"> 493 </span> : push_front(_GLIBCXX_MOVE(front())); -<span class="lineNum"> 494 </span> : iterator __front1 = this->_M_impl._M_start; -<span class="lineNum"> 495 </span> : ++__front1; -<span class="lineNum"> 496 </span> : iterator __front2 = __front1; -<span class="lineNum"> 497 </span> : ++__front2; -<span class="lineNum"> 498 </span> : __pos = this->_M_impl._M_start + __index; -<span class="lineNum"> 499 </span> : iterator __pos1 = __pos; -<span class="lineNum"> 500 </span> : ++__pos1; -<span class="lineNum"> 501 </span> : _GLIBCXX_MOVE3(__front2, __pos1, __front1); -<span class="lineNum"> 502 </span> : } -<span class="lineNum"> 503 </span> : else -<span class="lineNum"> 504 </span> : { -<span class="lineNum"> 505 </span> : push_back(_GLIBCXX_MOVE(back())); -<span class="lineNum"> 506 </span> : iterator __back1 = this->_M_impl._M_finish; -<span class="lineNum"> 507 </span> : --__back1; -<span class="lineNum"> 508 </span> : iterator __back2 = __back1; -<span class="lineNum"> 509 </span> : --__back2; -<span class="lineNum"> 510 </span> : __pos = this->_M_impl._M_start + __index; -<span class="lineNum"> 511 </span> : _GLIBCXX_MOVE_BACKWARD3(__pos, __back2, __back1); -<span class="lineNum"> 512 </span> : } -<span class="lineNum"> 513 </span> : *__pos = _GLIBCXX_MOVE(__x_copy); -<span class="lineNum"> 514 </span> : return __pos; -<span class="lineNum"> 515 </span> : } -<span class="lineNum"> 516 </span> : -<span class="lineNum"> 517 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 518 </span> : void -<span class="lineNum"> 519 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 520 </span> : _M_insert_aux(iterator __pos, size_type __n, const value_type& __x) -<span class="lineNum"> 521 </span> : { -<span class="lineNum"> 522 </span> : const difference_type __elems_before = __pos - this->_M_impl._M_start; -<span class="lineNum"> 523 </span> : const size_type __length = this->size(); -<span class="lineNum"> 524 </span> : value_type __x_copy = __x; -<span class="lineNum"> 525 </span> : if (__elems_before < difference_type(__length / 2)) -<span class="lineNum"> 526 </span> : { -<span class="lineNum"> 527 </span> : iterator __new_start = _M_reserve_elements_at_front(__n); -<span class="lineNum"> 528 </span> : iterator __old_start = this->_M_impl._M_start; -<span class="lineNum"> 529 </span> : __pos = this->_M_impl._M_start + __elems_before; -<span class="lineNum"> 530 </span> : try -<span class="lineNum"> 531 </span> : { -<span class="lineNum"> 532 </span> : if (__elems_before >= difference_type(__n)) -<span class="lineNum"> 533 </span> : { -<span class="lineNum"> 534 </span> : iterator __start_n = (this->_M_impl._M_start -<span class="lineNum"> 535 </span> : + difference_type(__n)); -<span class="lineNum"> 536 </span> : std::__uninitialized_move_a(this->_M_impl._M_start, -<span class="lineNum"> 537 </span> : __start_n, __new_start, -<span class="lineNum"> 538 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 539 </span> : this->_M_impl._M_start = __new_start; -<span class="lineNum"> 540 </span> : _GLIBCXX_MOVE3(__start_n, __pos, __old_start); -<span class="lineNum"> 541 </span> : std::fill(__pos - difference_type(__n), __pos, __x_copy); -<span class="lineNum"> 542 </span> : } -<span class="lineNum"> 543 </span> : else -<span class="lineNum"> 544 </span> : { -<span class="lineNum"> 545 </span> : std::__uninitialized_move_fill(this->_M_impl._M_start, -<span class="lineNum"> 546 </span> : __pos, __new_start, -<span class="lineNum"> 547 </span> : this->_M_impl._M_start, -<span class="lineNum"> 548 </span> : __x_copy, -<span class="lineNum"> 549 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 550 </span> : this->_M_impl._M_start = __new_start; -<span class="lineNum"> 551 </span> : std::fill(__old_start, __pos, __x_copy); -<span class="lineNum"> 552 </span> : } -<span class="lineNum"> 553 </span> : } -<span class="lineNum"> 554 </span> : catch(...) -<span class="lineNum"> 555 </span> : { -<span class="lineNum"> 556 </span> : _M_destroy_nodes(__new_start._M_node, -<span class="lineNum"> 557 </span> : this->_M_impl._M_start._M_node); -<span class="lineNum"> 558 </span> : __throw_exception_again; -<span class="lineNum"> 559 </span> : } -<span class="lineNum"> 560 </span> : } -<span class="lineNum"> 561 </span> : else -<span class="lineNum"> 562 </span> : { -<span class="lineNum"> 563 </span> : iterator __new_finish = _M_reserve_elements_at_back(__n); -<span class="lineNum"> 564 </span> : iterator __old_finish = this->_M_impl._M_finish; -<span class="lineNum"> 565 </span> : const difference_type __elems_after = -<span class="lineNum"> 566 </span> : difference_type(__length) - __elems_before; -<span class="lineNum"> 567 </span> : __pos = this->_M_impl._M_finish - __elems_after; -<span class="lineNum"> 568 </span> : try -<span class="lineNum"> 569 </span> : { -<span class="lineNum"> 570 </span> : if (__elems_after > difference_type(__n)) -<span class="lineNum"> 571 </span> : { -<span class="lineNum"> 572 </span> : iterator __finish_n = (this->_M_impl._M_finish -<span class="lineNum"> 573 </span> : - difference_type(__n)); -<span class="lineNum"> 574 </span> : std::__uninitialized_move_a(__finish_n, -<span class="lineNum"> 575 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 576 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 577 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 578 </span> : this->_M_impl._M_finish = __new_finish; -<span class="lineNum"> 579 </span> : _GLIBCXX_MOVE_BACKWARD3(__pos, __finish_n, __old_finish); -<span class="lineNum"> 580 </span> : std::fill(__pos, __pos + difference_type(__n), __x_copy); -<span class="lineNum"> 581 </span> : } -<span class="lineNum"> 582 </span> : else -<span class="lineNum"> 583 </span> : { -<span class="lineNum"> 584 </span> : std::__uninitialized_fill_move(this->_M_impl._M_finish, -<span class="lineNum"> 585 </span> : __pos + difference_type(__n), -<span class="lineNum"> 586 </span> : __x_copy, __pos, -<span class="lineNum"> 587 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 588 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 589 </span> : this->_M_impl._M_finish = __new_finish; -<span class="lineNum"> 590 </span> : std::fill(__pos, __old_finish, __x_copy); -<span class="lineNum"> 591 </span> : } -<span class="lineNum"> 592 </span> : } -<span class="lineNum"> 593 </span> : catch(...) -<span class="lineNum"> 594 </span> : { -<span class="lineNum"> 595 </span> : _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1, -<span class="lineNum"> 596 </span> : __new_finish._M_node + 1); -<span class="lineNum"> 597 </span> : __throw_exception_again; -<span class="lineNum"> 598 </span> : } -<span class="lineNum"> 599 </span> : } -<span class="lineNum"> 600 </span> : } -<span class="lineNum"> 601 </span> : -<span class="lineNum"> 602 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 603 </span> : template <typename _ForwardIterator> -<span class="lineNum"> 604 </span> : void -<span class="lineNum"> 605 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 606 </span> : _M_insert_aux(iterator __pos, -<span class="lineNum"> 607 </span> : _ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 608 </span><span class="lineNoCov"> 0 : size_type __n)</span> -<span class="lineNum"> 609 </span> : { -<span class="lineNum"> 610 </span><span class="lineNoCov"> 0 : const difference_type __elemsbefore = __pos - this->_M_impl._M_start;</span> -<span class="lineNum"> 611 </span><span class="lineNoCov"> 0 : const size_type __length = size();</span> -<span class="lineNum"> 612 </span><span class="lineNoCov"> 0 : if (static_cast<size_type>(__elemsbefore) < __length / 2)</span> -<span class="lineNum"> 613 </span> : { -<span class="lineNum"> 614 </span><span class="lineNoCov"> 0 : iterator __new_start = _M_reserve_elements_at_front(__n);</span> -<span class="lineNum"> 615 </span><span class="lineNoCov"> 0 : iterator __old_start = this->_M_impl._M_start;</span> -<span class="lineNum"> 616 </span><span class="lineNoCov"> 0 : __pos = this->_M_impl._M_start + __elemsbefore;</span> -<span class="lineNum"> 617 </span> : try -<span class="lineNum"> 618 </span> : { -<span class="lineNum"> 619 </span><span class="lineNoCov"> 0 : if (__elemsbefore >= difference_type(__n))</span> -<span class="lineNum"> 620 </span> : { -<span class="lineNum"> 621 </span> : iterator __start_n = (this->_M_impl._M_start -<span class="lineNum"> 622 </span><span class="lineNoCov"> 0 : + difference_type(__n));</span> -<span class="lineNum"> 623 </span><span class="lineNoCov"> 0 : std::__uninitialized_move_a(this->_M_impl._M_start,</span> -<span class="lineNum"> 624 </span> : __start_n, __new_start, -<span class="lineNum"> 625 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 626 </span><span class="lineNoCov"> 0 : this->_M_impl._M_start = __new_start;</span> -<span class="lineNum"> 627 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE3(__start_n, __pos, __old_start);</span> -<span class="lineNum"> 628 </span><span class="lineNoCov"> 0 : std::copy(__first, __last, __pos - difference_type(__n));</span> -<span class="lineNum"> 629 </span> : } -<span class="lineNum"> 630 </span> : else -<span class="lineNum"> 631 </span> : { -<span class="lineNum"> 632 </span><span class="lineNoCov"> 0 : _ForwardIterator __mid = __first;</span> -<span class="lineNum"> 633 </span><span class="lineNoCov"> 0 : std::advance(__mid, difference_type(__n) - __elemsbefore);</span> -<span class="lineNum"> 634 </span><span class="lineNoCov"> 0 : std::__uninitialized_move_copy(this->_M_impl._M_start,</span> -<span class="lineNum"> 635 </span> : __pos, __first, __mid, -<span class="lineNum"> 636 </span> : __new_start, -<span class="lineNum"> 637 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 638 </span><span class="lineNoCov"> 0 : this->_M_impl._M_start = __new_start;</span> -<span class="lineNum"> 639 </span><span class="lineNoCov"> 0 : std::copy(__mid, __last, __old_start);</span> -<span class="lineNum"> 640 </span> : } -<span class="lineNum"> 641 </span> : } -<span class="lineNum"> 642 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 643 </span> : { -<span class="lineNum"> 644 </span><span class="lineNoCov"> 0 : _M_destroy_nodes(__new_start._M_node,</span> -<span class="lineNum"> 645 </span> : this->_M_impl._M_start._M_node); -<span class="lineNum"> 646 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 647 </span> : } -<span class="lineNum"> 648 </span> : } -<span class="lineNum"> 649 </span> : else -<span class="lineNum"> 650 </span> : { -<span class="lineNum"> 651 </span><span class="lineNoCov"> 0 : iterator __new_finish = _M_reserve_elements_at_back(__n);</span> -<span class="lineNum"> 652 </span><span class="lineNoCov"> 0 : iterator __old_finish = this->_M_impl._M_finish;</span> -<span class="lineNum"> 653 </span> : const difference_type __elemsafter = -<span class="lineNum"> 654 </span><span class="lineNoCov"> 0 : difference_type(__length) - __elemsbefore;</span> -<span class="lineNum"> 655 </span><span class="lineNoCov"> 0 : __pos = this->_M_impl._M_finish - __elemsafter;</span> -<span class="lineNum"> 656 </span> : try -<span class="lineNum"> 657 </span> : { -<span class="lineNum"> 658 </span><span class="lineNoCov"> 0 : if (__elemsafter > difference_type(__n))</span> -<span class="lineNum"> 659 </span> : { -<span class="lineNum"> 660 </span> : iterator __finish_n = (this->_M_impl._M_finish -<span class="lineNum"> 661 </span><span class="lineNoCov"> 0 : - difference_type(__n));</span> -<span class="lineNum"> 662 </span><span class="lineNoCov"> 0 : std::__uninitialized_move_a(__finish_n,</span> -<span class="lineNum"> 663 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 664 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 665 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 666 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish = __new_finish;</span> -<span class="lineNum"> 667 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE_BACKWARD3(__pos, __finish_n, __old_finish);</span> -<span class="lineNum"> 668 </span><span class="lineNoCov"> 0 : std::copy(__first, __last, __pos);</span> -<span class="lineNum"> 669 </span> : } -<span class="lineNum"> 670 </span> : else -<span class="lineNum"> 671 </span> : { -<span class="lineNum"> 672 </span><span class="lineNoCov"> 0 : _ForwardIterator __mid = __first;</span> -<span class="lineNum"> 673 </span><span class="lineNoCov"> 0 : std::advance(__mid, __elemsafter);</span> -<span class="lineNum"> 674 </span><span class="lineNoCov"> 0 : std::__uninitialized_copy_move(__mid, __last, __pos,</span> -<span class="lineNum"> 675 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 676 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 677 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 678 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish = __new_finish;</span> -<span class="lineNum"> 679 </span><span class="lineNoCov"> 0 : std::copy(__first, __mid, __pos);</span> -<span class="lineNum"> 680 </span> : } -<span class="lineNum"> 681 </span> : } -<span class="lineNum"> 682 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 683 </span> : { -<span class="lineNum"> 684 </span><span class="lineNoCov"> 0 : _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,</span> -<span class="lineNum"> 685 </span> : __new_finish._M_node + 1); -<span class="lineNum"> 686 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 687 </span> : } -<span class="lineNum"> 688 </span> : } -<span class="lineNum"> 689 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 690 </span> : -<span class="lineNum"> 691 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 692 </span> : void -<span class="lineNum"> 693 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 694 </span><span class="lineCov"> 26 : _M_destroy_data_aux(iterator __first, iterator __last)</span> -<span class="lineNum"> 695 </span> : { -<span class="lineNum"> 696 </span><span class="lineCov"> 26 : for (_Map_pointer __node = __first._M_node + 1;</span> -<span class="lineNum"> 697 </span> : __node < __last._M_node; ++__node) -<span class="lineNum"> 698 </span><span class="lineNoCov"> 0 : std::_Destroy(*__node, *__node + _S_buffer_size(),</span> -<span class="lineNum"> 699 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 700 </span> : -<span class="lineNum"> 701 </span><span class="lineCov"> 26 : if (__first._M_node != __last._M_node)</span> -<span class="lineNum"> 702 </span> : { -<span class="lineNum"> 703 </span><span class="lineNoCov"> 0 : std::_Destroy(__first._M_cur, __first._M_last,</span> -<span class="lineNum"> 704 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 705 </span><span class="lineNoCov"> 0 : std::_Destroy(__last._M_first, __last._M_cur,</span> -<span class="lineNum"> 706 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 707 </span> : } -<span class="lineNum"> 708 </span> : else -<span class="lineNum"> 709 </span><span class="lineCov"> 26 : std::_Destroy(__first._M_cur, __last._M_cur,</span> -<span class="lineNum"> 710 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 711 </span><span class="lineCov"> 26 : }</span> -<span class="lineNum"> 712 </span> : -<span class="lineNum"> 713 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 714 </span> : void -<span class="lineNum"> 715 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 716 </span><span class="lineNoCov"> 0 : _M_new_elements_at_front(size_type __new_elems)</span> -<span class="lineNum"> 717 </span> : { -<span class="lineNum"> 718 </span><span class="lineNoCov"> 0 : if (this->max_size() - this->size() < __new_elems)</span> -<span class="lineNum"> 719 </span><span class="lineNoCov"> 0 : __throw_length_error(__N("deque::_M_new_elements_at_front"));</span> -<span class="lineNum"> 720 </span> : -<span class="lineNum"> 721 </span> : const size_type __new_nodes = ((__new_elems + _S_buffer_size() - 1) -<span class="lineNum"> 722 </span><span class="lineNoCov"> 0 : / _S_buffer_size());</span> -<span class="lineNum"> 723 </span><span class="lineNoCov"> 0 : _M_reserve_map_at_front(__new_nodes);</span> -<span class="lineNum"> 724 </span> : size_type __i; -<span class="lineNum"> 725 </span> : try -<span class="lineNum"> 726 </span> : { -<span class="lineNum"> 727 </span><span class="lineNoCov"> 0 : for (__i = 1; __i <= __new_nodes; ++__i)</span> -<span class="lineNum"> 728 </span><span class="lineNoCov"> 0 : *(this->_M_impl._M_start._M_node - __i) = this->_M_allocate_node();</span> -<span class="lineNum"> 729 </span> : } -<span class="lineNum"> 730 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 731 </span> : { -<span class="lineNum"> 732 </span><span class="lineNoCov"> 0 : for (size_type __j = 1; __j < __i; ++__j)</span> -<span class="lineNum"> 733 </span><span class="lineNoCov"> 0 : _M_deallocate_node(*(this->_M_impl._M_start._M_node - __j));</span> -<span class="lineNum"> 734 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 735 </span> : } -<span class="lineNum"> 736 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 737 </span> : -<span class="lineNum"> 738 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 739 </span> : void -<span class="lineNum"> 740 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 741 </span><span class="lineNoCov"> 0 : _M_new_elements_at_back(size_type __new_elems)</span> -<span class="lineNum"> 742 </span> : { -<span class="lineNum"> 743 </span><span class="lineNoCov"> 0 : if (this->max_size() - this->size() < __new_elems)</span> -<span class="lineNum"> 744 </span><span class="lineNoCov"> 0 : __throw_length_error(__N("deque::_M_new_elements_at_back"));</span> -<span class="lineNum"> 745 </span> : -<span class="lineNum"> 746 </span> : const size_type __new_nodes = ((__new_elems + _S_buffer_size() - 1) -<span class="lineNum"> 747 </span><span class="lineNoCov"> 0 : / _S_buffer_size());</span> -<span class="lineNum"> 748 </span><span class="lineNoCov"> 0 : _M_reserve_map_at_back(__new_nodes);</span> -<span class="lineNum"> 749 </span> : size_type __i; -<span class="lineNum"> 750 </span> : try -<span class="lineNum"> 751 </span> : { -<span class="lineNum"> 752 </span><span class="lineNoCov"> 0 : for (__i = 1; __i <= __new_nodes; ++__i)</span> -<span class="lineNum"> 753 </span><span class="lineNoCov"> 0 : *(this->_M_impl._M_finish._M_node + __i) = this->_M_allocate_node();</span> -<span class="lineNum"> 754 </span> : } -<span class="lineNum"> 755 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 756 </span> : { -<span class="lineNum"> 757 </span><span class="lineNoCov"> 0 : for (size_type __j = 1; __j < __i; ++__j)</span> -<span class="lineNum"> 758 </span><span class="lineNoCov"> 0 : _M_deallocate_node(*(this->_M_impl._M_finish._M_node + __j));</span> -<span class="lineNum"> 759 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 760 </span> : } -<span class="lineNum"> 761 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 762 </span> : -<span class="lineNum"> 763 </span> : template <typename _Tp, typename _Alloc> -<span class="lineNum"> 764 </span> : void -<span class="lineNum"> 765 </span> : deque<_Tp, _Alloc>:: -<span class="lineNum"> 766 </span><span class="lineNoCov"> 0 : _M_reallocate_map(size_type __nodes_to_add, bool __add_at_front)</span> -<span class="lineNum"> 767 </span> : { -<span class="lineNum"> 768 </span> : const size_type __old_num_nodes -<span class="lineNum"> 769 </span><span class="lineNoCov"> 0 : = this->_M_impl._M_finish._M_node - this->_M_impl._M_start._M_node + 1;</span> -<span class="lineNum"> 770 </span><span class="lineNoCov"> 0 : const size_type __new_num_nodes = __old_num_nodes + __nodes_to_add;</span> -<span class="lineNum"> 771 </span> : -<span class="lineNum"> 772 </span> : _Map_pointer __new_nstart; -<span class="lineNum"> 773 </span><span class="lineNoCov"> 0 : if (this->_M_impl._M_map_size > 2 * __new_num_nodes)</span> -<span class="lineNum"> 774 </span> : { -<span class="lineNum"> 775 </span><span class="lineNoCov"> 0 : __new_nstart = this->_M_impl._M_map + (this->_M_impl._M_map_size</span> -<span class="lineNum"> 776 </span> : - __new_num_nodes) / 2 -<span class="lineNum"> 777 </span> : + (__add_at_front ? __nodes_to_add : 0); -<span class="lineNum"> 778 </span><span class="lineNoCov"> 0 : if (__new_nstart < this->_M_impl._M_start._M_node)</span> -<span class="lineNum"> 779 </span><span class="lineNoCov"> 0 : std::copy(this->_M_impl._M_start._M_node,</span> -<span class="lineNum"> 780 </span> : this->_M_impl._M_finish._M_node + 1, -<span class="lineNum"> 781 </span> : __new_nstart); -<span class="lineNum"> 782 </span> : else -<span class="lineNum"> 783 </span><span class="lineNoCov"> 0 : std::copy_backward(this->_M_impl._M_start._M_node,</span> -<span class="lineNum"> 784 </span> : this->_M_impl._M_finish._M_node + 1, -<span class="lineNum"> 785 </span> : __new_nstart + __old_num_nodes); -<span class="lineNum"> 786 </span> : } -<span class="lineNum"> 787 </span> : else -<span class="lineNum"> 788 </span> : { -<span class="lineNum"> 789 </span> : size_type __new_map_size = this->_M_impl._M_map_size -<span class="lineNum"> 790 </span> : + std::max(this->_M_impl._M_map_size, -<span class="lineNum"> 791 </span><span class="lineNoCov"> 0 : __nodes_to_add) + 2;</span> -<span class="lineNum"> 792 </span> : -<span class="lineNum"> 793 </span><span class="lineNoCov"> 0 : _Map_pointer __new_map = this->_M_allocate_map(__new_map_size);</span> -<span class="lineNum"> 794 </span><span class="lineNoCov"> 0 : __new_nstart = __new_map + (__new_map_size - __new_num_nodes) / 2</span> -<span class="lineNum"> 795 </span> : + (__add_at_front ? __nodes_to_add : 0); -<span class="lineNum"> 796 </span><span class="lineNoCov"> 0 : std::copy(this->_M_impl._M_start._M_node,</span> -<span class="lineNum"> 797 </span> : this->_M_impl._M_finish._M_node + 1, -<span class="lineNum"> 798 </span> : __new_nstart); -<span class="lineNum"> 799 </span><span class="lineNoCov"> 0 : _M_deallocate_map(this->_M_impl._M_map, this->_M_impl._M_map_size);</span> -<span class="lineNum"> 800 </span> : -<span class="lineNum"> 801 </span><span class="lineNoCov"> 0 : this->_M_impl._M_map = __new_map;</span> -<span class="lineNum"> 802 </span><span class="lineNoCov"> 0 : this->_M_impl._M_map_size = __new_map_size;</span> -<span class="lineNum"> 803 </span> : } -<span class="lineNum"> 804 </span> : -<span class="lineNum"> 805 </span><span class="lineNoCov"> 0 : this->_M_impl._M_start._M_set_node(__new_nstart);</span> -<span class="lineNum"> 806 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish._M_set_node(__new_nstart + __old_num_nodes - 1);</span> -<span class="lineNum"> 807 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 808 </span> : -<span class="lineNum"> 809 </span> : // Overload for deque::iterators, exploiting the "segmented-iterator -<span class="lineNum"> 810 </span> : // optimization". NB: leave const_iterators alone! -<span class="lineNum"> 811 </span> : template<typename _Tp> -<span class="lineNum"> 812 </span> : void -<span class="lineNum"> 813 </span> : fill(const _Deque_iterator<_Tp, _Tp&, _Tp*>& __first, -<span class="lineNum"> 814 </span> : const _Deque_iterator<_Tp, _Tp&, _Tp*>& __last, const _Tp& __value) -<span class="lineNum"> 815 </span> : { -<span class="lineNum"> 816 </span> : typedef typename _Deque_iterator<_Tp, _Tp&, _Tp*>::_Self _Self; -<span class="lineNum"> 817 </span> : -<span class="lineNum"> 818 </span> : for (typename _Self::_Map_pointer __node = __first._M_node + 1; -<span class="lineNum"> 819 </span> : __node < __last._M_node; ++__node) -<span class="lineNum"> 820 </span> : std::fill(*__node, *__node + _Self::_S_buffer_size(), __value); -<span class="lineNum"> 821 </span> : -<span class="lineNum"> 822 </span> : if (__first._M_node != __last._M_node) -<span class="lineNum"> 823 </span> : { -<span class="lineNum"> 824 </span> : std::fill(__first._M_cur, __first._M_last, __value); -<span class="lineNum"> 825 </span> : std::fill(__last._M_first, __last._M_cur, __value); -<span class="lineNum"> 826 </span> : } -<span class="lineNum"> 827 </span> : else -<span class="lineNum"> 828 </span> : std::fill(__first._M_cur, __last._M_cur, __value); -<span class="lineNum"> 829 </span> : } -<span class="lineNum"> 830 </span> : -<span class="lineNum"> 831 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 832 </span> : -<span class="lineNum"> 833 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/index.html b/rep/usr/include/c++/4.3/bits/index.html deleted file mode 100644 index 4e6a4f9..0000000 --- a/rep/usr/include/c++/4.3/bits/index.html +++ /dev/null @@ -1,353 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - /usr/include/c++/4.3/bits</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">2051</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">69.1 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">1418</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <center> - <table width="80%" cellpadding=2 cellspacing=1 border=0> - - <tr> - <td width="50%"><br></td> - <td width="15%"></td> - <td width="15%"></td> - <td width="20%"></td> - </tr> - - <tr> - <td class="tableHead">Filename</td> - <td class="tableHead" colspan=3>Coverage</td> - </tr> - - <tr> - <td class="coverFile"><a href="allocator.h.gcov.html">allocator.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=71 height=10 alt="71.4%"><img src="../../../../../snow.png" width=29 height=10 alt="71.4%"></td></tr></table> - </td> - <td class="coverPerHi">71.4 %</td> - <td class="coverNumHi">5 / 7 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="basic_ios.h.gcov.html">basic_ios.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../snow.png" width=100 height=10 alt="0.0%"></td></tr></table> - </td> - <td class="coverPerLo">0.0 %</td> - <td class="coverNumLo">0 / 35 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="basic_string.h.gcov.html">basic_string.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../amber.png" width=17 height=10 alt="17.4%"><img src="../../../../../snow.png" width=83 height=10 alt="17.4%"></td></tr></table> - </td> - <td class="coverPerMed">17.4 %</td> - <td class="coverNumMed">31 / 178 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="basic_string.tcc.gcov.html">basic_string.tcc</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=74 height=10 alt="73.9%"><img src="../../../../../snow.png" width=26 height=10 alt="73.9%"></td></tr></table> - </td> - <td class="coverPerHi">73.9 %</td> - <td class="coverNumHi">17 / 23 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="char_traits.h.gcov.html">char_traits.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../amber.png" width=46 height=10 alt="46.2%"><img src="../../../../../snow.png" width=54 height=10 alt="46.2%"></td></tr></table> - </td> - <td class="coverPerMed">46.2 %</td> - <td class="coverNumMed">6 / 13 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="deque.tcc.gcov.html">deque.tcc</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../amber.png" width=19 height=10 alt="19.0%"><img src="../../../../../snow.png" width=81 height=10 alt="19.0%"></td></tr></table> - </td> - <td class="coverPerMed">19.0 %</td> - <td class="coverNumMed">28 / 147 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="ios_base.h.gcov.html">ios_base.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=67 height=10 alt="66.7%"><img src="../../../../../snow.png" width=33 height=10 alt="66.7%"></td></tr></table> - </td> - <td class="coverPerHi">66.7 %</td> - <td class="coverNumHi">20 / 30 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="list.tcc.gcov.html">list.tcc</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">11 / 11 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="locale_facets.h.gcov.html">locale_facets.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../snow.png" width=100 height=10 alt="0.0%"></td></tr></table> - </td> - <td class="coverPerLo">0.0 %</td> - <td class="coverNumLo">0 / 13 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="postypes.h.gcov.html">postypes.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../snow.png" width=100 height=10 alt="0.0%"></td></tr></table> - </td> - <td class="coverPerLo">0.0 %</td> - <td class="coverNumLo">0 / 3 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_algo.h.gcov.html">stl_algo.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=85 height=10 alt="85.0%"><img src="../../../../../snow.png" width=15 height=10 alt="85.0%"></td></tr></table> - </td> - <td class="coverPerHi">85.0 %</td> - <td class="coverNumHi">192 / 226 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_algobase.h.gcov.html">stl_algobase.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=91 height=10 alt="91.1%"><img src="../../../../../snow.png" width=9 height=10 alt="91.1%"></td></tr></table> - </td> - <td class="coverPerHi">91.1 %</td> - <td class="coverNumHi">72 / 79 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_bvector.h.gcov.html">stl_bvector.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=70 height=10 alt="70.4%"><img src="../../../../../snow.png" width=30 height=10 alt="70.4%"></td></tr></table> - </td> - <td class="coverPerHi">70.4 %</td> - <td class="coverNumHi">81 / 115 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_construct.h.gcov.html">stl_construct.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">12 / 12 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_deque.h.gcov.html">stl_deque.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=78 height=10 alt="78.3%"><img src="../../../../../snow.png" width=22 height=10 alt="78.3%"></td></tr></table> - </td> - <td class="coverPerHi">78.3 %</td> - <td class="coverNumHi">148 / 189 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_function.h.gcov.html">stl_function.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">17 / 17 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_heap.h.gcov.html">stl_heap.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../snow.png" width=100 height=10 alt="0.0%"></td></tr></table> - </td> - <td class="coverPerLo">0.0 %</td> - <td class="coverNumLo">0 / 92 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_iterator.h.gcov.html">stl_iterator.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=94 height=10 alt="93.9%"><img src="../../../../../snow.png" width=6 height=10 alt="93.9%"></td></tr></table> - </td> - <td class="coverPerHi">93.9 %</td> - <td class="coverNumHi">62 / 66 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_iterator_base_funcs.h.gcov.html">stl_iterator_base_funcs.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=82 height=10 alt="82.1%"><img src="../../../../../snow.png" width=18 height=10 alt="82.1%"></td></tr></table> - </td> - <td class="coverPerHi">82.1 %</td> - <td class="coverNumHi">23 / 28 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_iterator_base_types.h.gcov.html">stl_iterator_base_types.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">3 / 3 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_list.h.gcov.html">stl_list.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=94 height=10 alt="93.6%"><img src="../../../../../snow.png" width=6 height=10 alt="93.6%"></td></tr></table> - </td> - <td class="coverPerHi">93.6 %</td> - <td class="coverNumHi">88 / 94 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_map.h.gcov.html">stl_map.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">41 / 41 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_move.h.gcov.html">stl_move.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">5 / 5 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_pair.h.gcov.html">stl_pair.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">9 / 9 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_set.h.gcov.html">stl_set.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">33 / 33 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_stack.h.gcov.html">stl_stack.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">12 / 12 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_tree.h.gcov.html">stl_tree.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=94 height=10 alt="94.2%"><img src="../../../../../snow.png" width=6 height=10 alt="94.2%"></td></tr></table> - </td> - <td class="coverPerHi">94.2 %</td> - <td class="coverNumHi">278 / 295 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_uninitialized.h.gcov.html">stl_uninitialized.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=58 height=10 alt="58.1%"><img src="../../../../../snow.png" width=42 height=10 alt="58.1%"></td></tr></table> - </td> - <td class="coverPerHi">58.1 %</td> - <td class="coverNumHi">25 / 43 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stl_vector.h.gcov.html">stl_vector.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=91 height=10 alt="91.3%"><img src="../../../../../snow.png" width=9 height=10 alt="91.3%"></td></tr></table> - </td> - <td class="coverPerHi">91.3 %</td> - <td class="coverNumHi">94 / 103 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="stream_iterator.h.gcov.html">stream_iterator.h</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=100 height=10 alt="100.0%"></td></tr></table> - </td> - <td class="coverPerHi">100.0 %</td> - <td class="coverNumHi">33 / 33 lines</td> - </tr> - - <tr> - <td class="coverFile"><a href="vector.tcc.gcov.html">vector.tcc</a></td> - <td class="coverBar" align="center"> - <table border=0 cellspacing=0 cellpadding=1><tr><td class="coverBarOutline"><img src="../../../../../emerald.png" width=75 height=10 alt="75.0%"><img src="../../../../../snow.png" width=25 height=10 alt="75.0%"></td></tr></table> - </td> - <td class="coverPerHi">75.0 %</td> - <td class="coverNumHi">72 / 96 lines</td> - </tr> - - </table> - </center> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/ios_base.h.gcov.html b/rep/usr/include/c++/4.3/bits/ios_base.h.gcov.html deleted file mode 100644 index 091c26d..0000000 --- a/rep/usr/include/c++/4.3/bits/ios_base.h.gcov.html +++ /dev/null @@ -1,1039 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/ios_base.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - ios_base.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">30</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">66.7 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">20</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Iostreams base classes -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007, 2008 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file ios_base.h -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : // -<span class="lineNum"> 38 </span> : // ISO C++ 14882: 27.4 Iostreams base classes -<span class="lineNum"> 39 </span> : // -<span class="lineNum"> 40 </span> : -<span class="lineNum"> 41 </span> : #ifndef _IOS_BASE_H -<span class="lineNum"> 42 </span> : #define _IOS_BASE_H 1 -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : #pragma GCC system_header -<span class="lineNum"> 45 </span> : -<span class="lineNum"> 46 </span> : #include <ext/atomicity.h> -<span class="lineNum"> 47 </span> : #include <bits/localefwd.h> -<span class="lineNum"> 48 </span> : #include <bits/locale_classes.h> -<span class="lineNum"> 49 </span> : #include <cstdio> // For SEEK_CUR, SEEK_END -<span class="lineNum"> 50 </span> : -<span class="lineNum"> 51 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 52 </span> : -<span class="lineNum"> 53 </span> : // The following definitions of bitmask types are enums, not ints, -<span class="lineNum"> 54 </span> : // as permitted (but not required) in the standard, in order to provide -<span class="lineNum"> 55 </span> : // better type safety in iostream calls. A side effect is that -<span class="lineNum"> 56 </span> : // expressions involving them are no longer compile-time constants. -<span class="lineNum"> 57 </span> : enum _Ios_Fmtflags -<span class="lineNum"> 58 </span> : { -<span class="lineNum"> 59 </span> : _S_boolalpha = 1L << 0, -<span class="lineNum"> 60 </span> : _S_dec = 1L << 1, -<span class="lineNum"> 61 </span> : _S_fixed = 1L << 2, -<span class="lineNum"> 62 </span> : _S_hex = 1L << 3, -<span class="lineNum"> 63 </span> : _S_internal = 1L << 4, -<span class="lineNum"> 64 </span> : _S_left = 1L << 5, -<span class="lineNum"> 65 </span> : _S_oct = 1L << 6, -<span class="lineNum"> 66 </span> : _S_right = 1L << 7, -<span class="lineNum"> 67 </span> : _S_scientific = 1L << 8, -<span class="lineNum"> 68 </span> : _S_showbase = 1L << 9, -<span class="lineNum"> 69 </span> : _S_showpoint = 1L << 10, -<span class="lineNum"> 70 </span> : _S_showpos = 1L << 11, -<span class="lineNum"> 71 </span> : _S_skipws = 1L << 12, -<span class="lineNum"> 72 </span> : _S_unitbuf = 1L << 13, -<span class="lineNum"> 73 </span> : _S_uppercase = 1L << 14, -<span class="lineNum"> 74 </span> : _S_adjustfield = _S_left | _S_right | _S_internal, -<span class="lineNum"> 75 </span> : _S_basefield = _S_dec | _S_oct | _S_hex, -<span class="lineNum"> 76 </span> : _S_floatfield = _S_scientific | _S_fixed, -<span class="lineNum"> 77 </span> : _S_ios_fmtflags_end = 1L << 16 -<span class="lineNum"> 78 </span> : }; -<span class="lineNum"> 79 </span> : -<span class="lineNum"> 80 </span> : inline _Ios_Fmtflags -<span class="lineNum"> 81 </span><span class="lineCov"> 66 : operator&(_Ios_Fmtflags __a, _Ios_Fmtflags __b)</span> -<span class="lineNum"> 82 </span><span class="lineCov"> 66 : { return _Ios_Fmtflags(static_cast<int>(__a) & static_cast<int>(__b)); }</span> -<span class="lineNum"> 83 </span> : -<span class="lineNum"> 84 </span> : inline _Ios_Fmtflags -<span class="lineNum"> 85 </span><span class="lineCov"> 33 : operator|(_Ios_Fmtflags __a, _Ios_Fmtflags __b)</span> -<span class="lineNum"> 86 </span><span class="lineCov"> 33 : { return _Ios_Fmtflags(static_cast<int>(__a) | static_cast<int>(__b)); }</span> -<span class="lineNum"> 87 </span> : -<span class="lineNum"> 88 </span> : inline _Ios_Fmtflags -<span class="lineNum"> 89 </span> : operator^(_Ios_Fmtflags __a, _Ios_Fmtflags __b) -<span class="lineNum"> 90 </span> : { return _Ios_Fmtflags(static_cast<int>(__a) ^ static_cast<int>(__b)); } -<span class="lineNum"> 91 </span> : -<span class="lineNum"> 92 </span> : inline _Ios_Fmtflags& -<span class="lineNum"> 93 </span><span class="lineCov"> 33 : operator|=(_Ios_Fmtflags& __a, _Ios_Fmtflags __b)</span> -<span class="lineNum"> 94 </span><span class="lineCov"> 33 : { return __a = __a | __b; }</span> -<span class="lineNum"> 95 </span> : -<span class="lineNum"> 96 </span> : inline _Ios_Fmtflags& -<span class="lineNum"> 97 </span><span class="lineCov"> 33 : operator&=(_Ios_Fmtflags& __a, _Ios_Fmtflags __b)</span> -<span class="lineNum"> 98 </span><span class="lineCov"> 33 : { return __a = __a & __b; }</span> -<span class="lineNum"> 99 </span> : -<span class="lineNum"> 100 </span> : inline _Ios_Fmtflags& -<span class="lineNum"> 101 </span> : operator^=(_Ios_Fmtflags& __a, _Ios_Fmtflags __b) -<span class="lineNum"> 102 </span> : { return __a = __a ^ __b; } -<span class="lineNum"> 103 </span> : -<span class="lineNum"> 104 </span> : inline _Ios_Fmtflags -<span class="lineNum"> 105 </span><span class="lineCov"> 33 : operator~(_Ios_Fmtflags __a)</span> -<span class="lineNum"> 106 </span><span class="lineCov"> 33 : { return _Ios_Fmtflags(~static_cast<int>(__a)); }</span> -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : -<span class="lineNum"> 109 </span> : enum _Ios_Openmode -<span class="lineNum"> 110 </span> : { -<span class="lineNum"> 111 </span> : _S_app = 1L << 0, -<span class="lineNum"> 112 </span> : _S_ate = 1L << 1, -<span class="lineNum"> 113 </span> : _S_bin = 1L << 2, -<span class="lineNum"> 114 </span> : _S_in = 1L << 3, -<span class="lineNum"> 115 </span> : _S_out = 1L << 4, -<span class="lineNum"> 116 </span> : _S_trunc = 1L << 5, -<span class="lineNum"> 117 </span> : _S_ios_openmode_end = 1L << 16 -<span class="lineNum"> 118 </span> : }; -<span class="lineNum"> 119 </span> : -<span class="lineNum"> 120 </span> : inline _Ios_Openmode -<span class="lineNum"> 121 </span><span class="lineNoCov"> 0 : operator&(_Ios_Openmode __a, _Ios_Openmode __b)</span> -<span class="lineNum"> 122 </span><span class="lineNoCov"> 0 : { return _Ios_Openmode(static_cast<int>(__a) & static_cast<int>(__b)); }</span> -<span class="lineNum"> 123 </span> : -<span class="lineNum"> 124 </span> : inline _Ios_Openmode -<span class="lineNum"> 125 </span><span class="lineCov"> 1364 : operator|(_Ios_Openmode __a, _Ios_Openmode __b)</span> -<span class="lineNum"> 126 </span><span class="lineCov"> 1364 : { return _Ios_Openmode(static_cast<int>(__a) | static_cast<int>(__b)); }</span> -<span class="lineNum"> 127 </span> : -<span class="lineNum"> 128 </span> : inline _Ios_Openmode -<span class="lineNum"> 129 </span> : operator^(_Ios_Openmode __a, _Ios_Openmode __b) -<span class="lineNum"> 130 </span> : { return _Ios_Openmode(static_cast<int>(__a) ^ static_cast<int>(__b)); } -<span class="lineNum"> 131 </span> : -<span class="lineNum"> 132 </span> : inline _Ios_Openmode& -<span class="lineNum"> 133 </span> : operator|=(_Ios_Openmode& __a, _Ios_Openmode __b) -<span class="lineNum"> 134 </span> : { return __a = __a | __b; } -<span class="lineNum"> 135 </span> : -<span class="lineNum"> 136 </span> : inline _Ios_Openmode& -<span class="lineNum"> 137 </span> : operator&=(_Ios_Openmode& __a, _Ios_Openmode __b) -<span class="lineNum"> 138 </span> : { return __a = __a & __b; } -<span class="lineNum"> 139 </span> : -<span class="lineNum"> 140 </span> : inline _Ios_Openmode& -<span class="lineNum"> 141 </span> : operator^=(_Ios_Openmode& __a, _Ios_Openmode __b) -<span class="lineNum"> 142 </span> : { return __a = __a ^ __b; } -<span class="lineNum"> 143 </span> : -<span class="lineNum"> 144 </span> : inline _Ios_Openmode -<span class="lineNum"> 145 </span> : operator~(_Ios_Openmode __a) -<span class="lineNum"> 146 </span> : { return _Ios_Openmode(~static_cast<int>(__a)); } -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : -<span class="lineNum"> 149 </span> : enum _Ios_Iostate -<span class="lineNum"> 150 </span> : { -<span class="lineNum"> 151 </span> : _S_goodbit = 0, -<span class="lineNum"> 152 </span> : _S_badbit = 1L << 0, -<span class="lineNum"> 153 </span> : _S_eofbit = 1L << 1, -<span class="lineNum"> 154 </span> : _S_failbit = 1L << 2, -<span class="lineNum"> 155 </span> : _S_ios_iostate_end = 1L << 16 -<span class="lineNum"> 156 </span> : }; -<span class="lineNum"> 157 </span> : -<span class="lineNum"> 158 </span> : inline _Ios_Iostate -<span class="lineNum"> 159 </span><span class="lineNoCov"> 0 : operator&(_Ios_Iostate __a, _Ios_Iostate __b)</span> -<span class="lineNum"> 160 </span><span class="lineNoCov"> 0 : { return _Ios_Iostate(static_cast<int>(__a) & static_cast<int>(__b)); }</span> -<span class="lineNum"> 161 </span> : -<span class="lineNum"> 162 </span> : inline _Ios_Iostate -<span class="lineNum"> 163 </span><span class="lineNoCov"> 0 : operator|(_Ios_Iostate __a, _Ios_Iostate __b)</span> -<span class="lineNum"> 164 </span><span class="lineNoCov"> 0 : { return _Ios_Iostate(static_cast<int>(__a) | static_cast<int>(__b)); }</span> -<span class="lineNum"> 165 </span> : -<span class="lineNum"> 166 </span> : inline _Ios_Iostate -<span class="lineNum"> 167 </span> : operator^(_Ios_Iostate __a, _Ios_Iostate __b) -<span class="lineNum"> 168 </span> : { return _Ios_Iostate(static_cast<int>(__a) ^ static_cast<int>(__b)); } -<span class="lineNum"> 169 </span> : -<span class="lineNum"> 170 </span> : inline _Ios_Iostate& -<span class="lineNum"> 171 </span> : operator|=(_Ios_Iostate& __a, _Ios_Iostate __b) -<span class="lineNum"> 172 </span> : { return __a = __a | __b; } -<span class="lineNum"> 173 </span> : -<span class="lineNum"> 174 </span> : inline _Ios_Iostate& -<span class="lineNum"> 175 </span> : operator&=(_Ios_Iostate& __a, _Ios_Iostate __b) -<span class="lineNum"> 176 </span> : { return __a = __a & __b; } -<span class="lineNum"> 177 </span> : -<span class="lineNum"> 178 </span> : inline _Ios_Iostate& -<span class="lineNum"> 179 </span> : operator^=(_Ios_Iostate& __a, _Ios_Iostate __b) -<span class="lineNum"> 180 </span> : { return __a = __a ^ __b; } -<span class="lineNum"> 181 </span> : -<span class="lineNum"> 182 </span> : inline _Ios_Iostate -<span class="lineNum"> 183 </span> : operator~(_Ios_Iostate __a) -<span class="lineNum"> 184 </span> : { return _Ios_Iostate(~static_cast<int>(__a)); } -<span class="lineNum"> 185 </span> : -<span class="lineNum"> 186 </span> : enum _Ios_Seekdir -<span class="lineNum"> 187 </span> : { -<span class="lineNum"> 188 </span> : _S_beg = 0, -<span class="lineNum"> 189 </span> : _S_cur = SEEK_CUR, -<span class="lineNum"> 190 </span> : _S_end = SEEK_END, -<span class="lineNum"> 191 </span> : _S_ios_seekdir_end = 1L << 16 -<span class="lineNum"> 192 </span> : }; -<span class="lineNum"> 193 </span> : -<span class="lineNum"> 194 </span> : // 27.4.2 Class ios_base -<span class="lineNum"> 195 </span> : /** -<span class="lineNum"> 196 </span> : * @brief The base of the I/O class hierarchy. -<span class="lineNum"> 197 </span> : * -<span class="lineNum"> 198 </span> : * This class defines everything that can be defined about I/O that does -<span class="lineNum"> 199 </span> : * not depend on the type of characters being input or output. Most -<span class="lineNum"> 200 </span> : * people will only see @c ios_base when they need to specify the full -<span class="lineNum"> 201 </span> : * name of the various I/O flags (e.g., the openmodes). -<span class="lineNum"> 202 </span> : */ -<span class="lineNum"> 203 </span> : class ios_base -<span class="lineNum"> 204 </span> : { -<span class="lineNum"> 205 </span> : public: -<span class="lineNum"> 206 </span> : -<span class="lineNum"> 207 </span> : // 27.4.2.1.1 Class ios_base::failure -<span class="lineNum"> 208 </span> : /// These are thrown to indicate problems. Doc me. -<span class="lineNum"> 209 </span> : class failure : public exception -<span class="lineNum"> 210 </span> : { -<span class="lineNum"> 211 </span> : public: -<span class="lineNum"> 212 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 213 </span> : // 48. Use of non-existent exception constructor -<span class="lineNum"> 214 </span> : explicit -<span class="lineNum"> 215 </span> : failure(const string& __str) throw(); -<span class="lineNum"> 216 </span> : -<span class="lineNum"> 217 </span> : // This declaration is not useless: -<span class="lineNum"> 218 </span> : // http://gcc.gnu.org/onlinedocs/gcc-3.0.2/gcc_6.html#SEC118 -<span class="lineNum"> 219 </span> : virtual -<span class="lineNum"> 220 </span> : ~failure() throw(); -<span class="lineNum"> 221 </span> : -<span class="lineNum"> 222 </span> : virtual const char* -<span class="lineNum"> 223 </span> : what() const throw(); -<span class="lineNum"> 224 </span> : -<span class="lineNum"> 225 </span> : private: -<span class="lineNum"> 226 </span> : string _M_msg; -<span class="lineNum"> 227 </span> : }; -<span class="lineNum"> 228 </span> : -<span class="lineNum"> 229 </span> : // 27.4.2.1.2 Type ios_base::fmtflags -<span class="lineNum"> 230 </span> : /** -<span class="lineNum"> 231 </span> : * @brief This is a bitmask type. -<span class="lineNum"> 232 </span> : * -<span class="lineNum"> 233 </span> : * @c "_Ios_Fmtflags" is implementation-defined, but it is valid to -<span class="lineNum"> 234 </span> : * perform bitwise operations on these values and expect the Right -<span class="lineNum"> 235 </span> : * Thing to happen. Defined objects of type fmtflags are: -<span class="lineNum"> 236 </span> : * - boolalpha -<span class="lineNum"> 237 </span> : * - dec -<span class="lineNum"> 238 </span> : * - fixed -<span class="lineNum"> 239 </span> : * - hex -<span class="lineNum"> 240 </span> : * - internal -<span class="lineNum"> 241 </span> : * - left -<span class="lineNum"> 242 </span> : * - oct -<span class="lineNum"> 243 </span> : * - right -<span class="lineNum"> 244 </span> : * - scientific -<span class="lineNum"> 245 </span> : * - showbase -<span class="lineNum"> 246 </span> : * - showpoint -<span class="lineNum"> 247 </span> : * - showpos -<span class="lineNum"> 248 </span> : * - skipws -<span class="lineNum"> 249 </span> : * - unitbuf -<span class="lineNum"> 250 </span> : * - uppercase -<span class="lineNum"> 251 </span> : * - adjustfield -<span class="lineNum"> 252 </span> : * - basefield -<span class="lineNum"> 253 </span> : * - floatfield -<span class="lineNum"> 254 </span> : */ -<span class="lineNum"> 255 </span> : typedef _Ios_Fmtflags fmtflags; -<span class="lineNum"> 256 </span> : -<span class="lineNum"> 257 </span> : /// Insert/extract @c bool in alphabetic rather than numeric format. -<span class="lineNum"> 258 </span> : static const fmtflags boolalpha = _S_boolalpha; -<span class="lineNum"> 259 </span> : -<span class="lineNum"> 260 </span> : /// Converts integer input or generates integer output in decimal base. -<span class="lineNum"> 261 </span> : static const fmtflags dec = _S_dec; -<span class="lineNum"> 262 </span> : -<span class="lineNum"> 263 </span> : /// Generate floating-point output in fixed-point notation. -<span class="lineNum"> 264 </span> : static const fmtflags fixed = _S_fixed; -<span class="lineNum"> 265 </span> : -<span class="lineNum"> 266 </span> : /// Converts integer input or generates integer output in hexadecimal base. -<span class="lineNum"> 267 </span> : static const fmtflags hex = _S_hex; -<span class="lineNum"> 268 </span> : -<span class="lineNum"> 269 </span> : /// Adds fill characters at a designated internal point in certain -<span class="lineNum"> 270 </span> : /// generated output, or identical to @c right if no such point is -<span class="lineNum"> 271 </span> : /// designated. -<span class="lineNum"> 272 </span> : static const fmtflags internal = _S_internal; -<span class="lineNum"> 273 </span> : -<span class="lineNum"> 274 </span> : /// Adds fill characters on the right (final positions) of certain -<span class="lineNum"> 275 </span> : /// generated output. (I.e., the thing you print is flush left.) -<span class="lineNum"> 276 </span> : static const fmtflags left = _S_left; -<span class="lineNum"> 277 </span> : -<span class="lineNum"> 278 </span> : /// Converts integer input or generates integer output in octal base. -<span class="lineNum"> 279 </span> : static const fmtflags oct = _S_oct; -<span class="lineNum"> 280 </span> : -<span class="lineNum"> 281 </span> : /// Adds fill characters on the left (initial positions) of certain -<span class="lineNum"> 282 </span> : /// generated output. (I.e., the thing you print is flush right.) -<span class="lineNum"> 283 </span> : static const fmtflags right = _S_right; -<span class="lineNum"> 284 </span> : -<span class="lineNum"> 285 </span> : /// Generates floating-point output in scientific notation. -<span class="lineNum"> 286 </span> : static const fmtflags scientific = _S_scientific; -<span class="lineNum"> 287 </span> : -<span class="lineNum"> 288 </span> : /// Generates a prefix indicating the numeric base of generated integer -<span class="lineNum"> 289 </span> : /// output. -<span class="lineNum"> 290 </span> : static const fmtflags showbase = _S_showbase; -<span class="lineNum"> 291 </span> : -<span class="lineNum"> 292 </span> : /// Generates a decimal-point character unconditionally in generated -<span class="lineNum"> 293 </span> : /// floating-point output. -<span class="lineNum"> 294 </span> : static const fmtflags showpoint = _S_showpoint; -<span class="lineNum"> 295 </span> : -<span class="lineNum"> 296 </span> : /// Generates a + sign in non-negative generated numeric output. -<span class="lineNum"> 297 </span> : static const fmtflags showpos = _S_showpos; -<span class="lineNum"> 298 </span> : -<span class="lineNum"> 299 </span> : /// Skips leading white space before certain input operations. -<span class="lineNum"> 300 </span> : static const fmtflags skipws = _S_skipws; -<span class="lineNum"> 301 </span> : -<span class="lineNum"> 302 </span> : /// Flushes output after each output operation. -<span class="lineNum"> 303 </span> : static const fmtflags unitbuf = _S_unitbuf; -<span class="lineNum"> 304 </span> : -<span class="lineNum"> 305 </span> : /// Replaces certain lowercase letters with their uppercase equivalents -<span class="lineNum"> 306 </span> : /// in generated output. -<span class="lineNum"> 307 </span> : static const fmtflags uppercase = _S_uppercase; -<span class="lineNum"> 308 </span> : -<span class="lineNum"> 309 </span> : /// A mask of left|right|internal. Useful for the 2-arg form of @c setf. -<span class="lineNum"> 310 </span> : static const fmtflags adjustfield = _S_adjustfield; -<span class="lineNum"> 311 </span> : -<span class="lineNum"> 312 </span> : /// A mask of dec|oct|hex. Useful for the 2-arg form of @c setf. -<span class="lineNum"> 313 </span> : static const fmtflags basefield = _S_basefield; -<span class="lineNum"> 314 </span> : -<span class="lineNum"> 315 </span> : /// A mask of scientific|fixed. Useful for the 2-arg form of @c setf. -<span class="lineNum"> 316 </span> : static const fmtflags floatfield = _S_floatfield; -<span class="lineNum"> 317 </span> : -<span class="lineNum"> 318 </span> : // 27.4.2.1.3 Type ios_base::iostate -<span class="lineNum"> 319 </span> : /** -<span class="lineNum"> 320 </span> : * @brief This is a bitmask type. -<span class="lineNum"> 321 </span> : * -<span class="lineNum"> 322 </span> : * @c "_Ios_Iostate" is implementation-defined, but it is valid to -<span class="lineNum"> 323 </span> : * perform bitwise operations on these values and expect the Right -<span class="lineNum"> 324 </span> : * Thing to happen. Defined objects of type iostate are: -<span class="lineNum"> 325 </span> : * - badbit -<span class="lineNum"> 326 </span> : * - eofbit -<span class="lineNum"> 327 </span> : * - failbit -<span class="lineNum"> 328 </span> : * - goodbit -<span class="lineNum"> 329 </span> : */ -<span class="lineNum"> 330 </span> : typedef _Ios_Iostate iostate; -<span class="lineNum"> 331 </span> : -<span class="lineNum"> 332 </span> : /// Indicates a loss of integrity in an input or output sequence (such -<span class="lineNum"> 333 </span> : /// as an irrecoverable read error from a file). -<span class="lineNum"> 334 </span> : static const iostate badbit = _S_badbit; -<span class="lineNum"> 335 </span> : -<span class="lineNum"> 336 </span> : /// Indicates that an input operation reached the end of an input sequence. -<span class="lineNum"> 337 </span> : static const iostate eofbit = _S_eofbit; -<span class="lineNum"> 338 </span> : -<span class="lineNum"> 339 </span> : /// Indicates that an input operation failed to read the expected -<span class="lineNum"> 340 </span> : /// characters, or that an output operation failed to generate the -<span class="lineNum"> 341 </span> : /// desired characters. -<span class="lineNum"> 342 </span> : static const iostate failbit = _S_failbit; -<span class="lineNum"> 343 </span> : -<span class="lineNum"> 344 </span> : /// Indicates all is well. -<span class="lineNum"> 345 </span> : static const iostate goodbit = _S_goodbit; -<span class="lineNum"> 346 </span> : -<span class="lineNum"> 347 </span> : // 27.4.2.1.4 Type ios_base::openmode -<span class="lineNum"> 348 </span> : /** -<span class="lineNum"> 349 </span> : * @brief This is a bitmask type. -<span class="lineNum"> 350 </span> : * -<span class="lineNum"> 351 </span> : * @c "_Ios_Openmode" is implementation-defined, but it is valid to -<span class="lineNum"> 352 </span> : * perform bitwise operations on these values and expect the Right -<span class="lineNum"> 353 </span> : * Thing to happen. Defined objects of type openmode are: -<span class="lineNum"> 354 </span> : * - app -<span class="lineNum"> 355 </span> : * - ate -<span class="lineNum"> 356 </span> : * - binary -<span class="lineNum"> 357 </span> : * - in -<span class="lineNum"> 358 </span> : * - out -<span class="lineNum"> 359 </span> : * - trunc -<span class="lineNum"> 360 </span> : */ -<span class="lineNum"> 361 </span> : typedef _Ios_Openmode openmode; -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : /// Seek to end before each write. -<span class="lineNum"> 364 </span> : static const openmode app = _S_app; -<span class="lineNum"> 365 </span> : -<span class="lineNum"> 366 </span> : /// Open and seek to end immediately after opening. -<span class="lineNum"> 367 </span> : static const openmode ate = _S_ate; -<span class="lineNum"> 368 </span> : -<span class="lineNum"> 369 </span> : /// Perform input and output in binary mode (as opposed to text mode). -<span class="lineNum"> 370 </span> : /// This is probably not what you think it is; see -<span class="lineNum"> 371 </span> : /// http://gcc.gnu.org/onlinedocs/libstdc++/27_io/howto.html#3 and -<span class="lineNum"> 372 </span> : /// http://gcc.gnu.org/onlinedocs/libstdc++/27_io/howto.html#7 for more. -<span class="lineNum"> 373 </span> : static const openmode binary = _S_bin; -<span class="lineNum"> 374 </span> : -<span class="lineNum"> 375 </span> : /// Open for input. Default for @c ifstream and fstream. -<span class="lineNum"> 376 </span> : static const openmode in = _S_in; -<span class="lineNum"> 377 </span> : -<span class="lineNum"> 378 </span> : /// Open for output. Default for @c ofstream and fstream. -<span class="lineNum"> 379 </span> : static const openmode out = _S_out; -<span class="lineNum"> 380 </span> : -<span class="lineNum"> 381 </span> : /// Open for input. Default for @c ofstream. -<span class="lineNum"> 382 </span> : static const openmode trunc = _S_trunc; -<span class="lineNum"> 383 </span> : -<span class="lineNum"> 384 </span> : // 27.4.2.1.5 Type ios_base::seekdir -<span class="lineNum"> 385 </span> : /** -<span class="lineNum"> 386 </span> : * @brief This is an enumerated type. -<span class="lineNum"> 387 </span> : * -<span class="lineNum"> 388 </span> : * @c "_Ios_Seekdir" is implementation-defined. Defined values -<span class="lineNum"> 389 </span> : * of type seekdir are: -<span class="lineNum"> 390 </span> : * - beg -<span class="lineNum"> 391 </span> : * - cur, equivalent to @c SEEK_CUR in the C standard library. -<span class="lineNum"> 392 </span> : * - end, equivalent to @c SEEK_END in the C standard library. -<span class="lineNum"> 393 </span> : */ -<span class="lineNum"> 394 </span> : typedef _Ios_Seekdir seekdir; -<span class="lineNum"> 395 </span> : -<span class="lineNum"> 396 </span> : /// Request a seek relative to the beginning of the stream. -<span class="lineNum"> 397 </span> : static const seekdir beg = _S_beg; -<span class="lineNum"> 398 </span> : -<span class="lineNum"> 399 </span> : /// Request a seek relative to the current position within the sequence. -<span class="lineNum"> 400 </span> : static const seekdir cur = _S_cur; -<span class="lineNum"> 401 </span> : -<span class="lineNum"> 402 </span> : /// Request a seek relative to the current end of the sequence. -<span class="lineNum"> 403 </span> : static const seekdir end = _S_end; -<span class="lineNum"> 404 </span> : -<span class="lineNum"> 405 </span> : // Annex D.6 -<span class="lineNum"> 406 </span> : typedef int io_state; -<span class="lineNum"> 407 </span> : typedef int open_mode; -<span class="lineNum"> 408 </span> : typedef int seek_dir; -<span class="lineNum"> 409 </span> : -<span class="lineNum"> 410 </span> : typedef std::streampos streampos; -<span class="lineNum"> 411 </span> : typedef std::streamoff streamoff; -<span class="lineNum"> 412 </span> : -<span class="lineNum"> 413 </span> : // Callbacks; -<span class="lineNum"> 414 </span> : /** -<span class="lineNum"> 415 </span> : * @brief The set of events that may be passed to an event callback. -<span class="lineNum"> 416 </span> : * -<span class="lineNum"> 417 </span> : * erase_event is used during ~ios() and copyfmt(). imbue_event is used -<span class="lineNum"> 418 </span> : * during imbue(). copyfmt_event is used during copyfmt(). -<span class="lineNum"> 419 </span> : */ -<span class="lineNum"> 420 </span> : enum event -<span class="lineNum"> 421 </span> : { -<span class="lineNum"> 422 </span> : erase_event, -<span class="lineNum"> 423 </span> : imbue_event, -<span class="lineNum"> 424 </span> : copyfmt_event -<span class="lineNum"> 425 </span> : }; -<span class="lineNum"> 426 </span> : -<span class="lineNum"> 427 </span> : /** -<span class="lineNum"> 428 </span> : * @brief The type of an event callback function. -<span class="lineNum"> 429 </span> : * @param event One of the members of the event enum. -<span class="lineNum"> 430 </span> : * @param ios_base Reference to the ios_base object. -<span class="lineNum"> 431 </span> : * @param int The integer provided when the callback was registered. -<span class="lineNum"> 432 </span> : * -<span class="lineNum"> 433 </span> : * Event callbacks are user defined functions that get called during -<span class="lineNum"> 434 </span> : * several ios_base and basic_ios functions, specifically imbue(), -<span class="lineNum"> 435 </span> : * copyfmt(), and ~ios(). -<span class="lineNum"> 436 </span> : */ -<span class="lineNum"> 437 </span> : typedef void (*event_callback) (event, ios_base&, int); -<span class="lineNum"> 438 </span> : -<span class="lineNum"> 439 </span> : /** -<span class="lineNum"> 440 </span> : * @brief Add the callback __fn with parameter __index. -<span class="lineNum"> 441 </span> : * @param __fn The function to add. -<span class="lineNum"> 442 </span> : * @param __index The integer to pass to the function when invoked. -<span class="lineNum"> 443 </span> : * -<span class="lineNum"> 444 </span> : * Registers a function as an event callback with an integer parameter to -<span class="lineNum"> 445 </span> : * be passed to the function when invoked. Multiple copies of the -<span class="lineNum"> 446 </span> : * function are allowed. If there are multiple callbacks, they are -<span class="lineNum"> 447 </span> : * invoked in the order they were registered. -<span class="lineNum"> 448 </span> : */ -<span class="lineNum"> 449 </span> : void -<span class="lineNum"> 450 </span> : register_callback(event_callback __fn, int __index); -<span class="lineNum"> 451 </span> : -<span class="lineNum"> 452 </span> : protected: -<span class="lineNum"> 453 </span> : //@{ -<span class="lineNum"> 454 </span> : /** -<span class="lineNum"> 455 </span> : * ios_base data members (doc me) -<span class="lineNum"> 456 </span> : */ -<span class="lineNum"> 457 </span> : streamsize _M_precision; -<span class="lineNum"> 458 </span> : streamsize _M_width; -<span class="lineNum"> 459 </span> : fmtflags _M_flags; -<span class="lineNum"> 460 </span> : iostate _M_exception; -<span class="lineNum"> 461 </span> : iostate _M_streambuf_state; -<span class="lineNum"> 462 </span> : //@} -<span class="lineNum"> 463 </span> : -<span class="lineNum"> 464 </span> : // 27.4.2.6 Members for callbacks -<span class="lineNum"> 465 </span> : // 27.4.2.6 ios_base callbacks -<span class="lineNum"> 466 </span> : struct _Callback_list -<span class="lineNum"> 467 </span> : { -<span class="lineNum"> 468 </span> : // Data Members -<span class="lineNum"> 469 </span> : _Callback_list* _M_next; -<span class="lineNum"> 470 </span> : ios_base::event_callback _M_fn; -<span class="lineNum"> 471 </span> : int _M_index; -<span class="lineNum"> 472 </span> : _Atomic_word _M_refcount; // 0 means one reference. -<span class="lineNum"> 473 </span> : -<span class="lineNum"> 474 </span> : _Callback_list(ios_base::event_callback __fn, int __index, -<span class="lineNum"> 475 </span> : _Callback_list* __cb) -<span class="lineNum"> 476 </span> : : _M_next(__cb), _M_fn(__fn), _M_index(__index), _M_refcount(0) { } -<span class="lineNum"> 477 </span> : -<span class="lineNum"> 478 </span> : void -<span class="lineNum"> 479 </span> : _M_add_reference() { __gnu_cxx::__atomic_add_dispatch(&_M_refcount, 1); } -<span class="lineNum"> 480 </span> : -<span class="lineNum"> 481 </span> : // 0 => OK to delete. -<span class="lineNum"> 482 </span> : int -<span class="lineNum"> 483 </span> : _M_remove_reference() -<span class="lineNum"> 484 </span> : { return __gnu_cxx::__exchange_and_add_dispatch(&_M_refcount, -1); } -<span class="lineNum"> 485 </span> : }; -<span class="lineNum"> 486 </span> : -<span class="lineNum"> 487 </span> : _Callback_list* _M_callbacks; -<span class="lineNum"> 488 </span> : -<span class="lineNum"> 489 </span> : void -<span class="lineNum"> 490 </span> : _M_call_callbacks(event __ev) throw(); -<span class="lineNum"> 491 </span> : -<span class="lineNum"> 492 </span> : void -<span class="lineNum"> 493 </span> : _M_dispose_callbacks(void); -<span class="lineNum"> 494 </span> : -<span class="lineNum"> 495 </span> : // 27.4.2.5 Members for iword/pword storage -<span class="lineNum"> 496 </span> : struct _Words -<span class="lineNum"> 497 </span> : { -<span class="lineNum"> 498 </span> : void* _M_pword; -<span class="lineNum"> 499 </span> : long _M_iword; -<span class="lineNum"> 500 </span> : _Words() : _M_pword(0), _M_iword(0) { } -<span class="lineNum"> 501 </span> : }; -<span class="lineNum"> 502 </span> : -<span class="lineNum"> 503 </span> : // Only for failed iword/pword calls. -<span class="lineNum"> 504 </span> : _Words _M_word_zero; -<span class="lineNum"> 505 </span> : -<span class="lineNum"> 506 </span> : // Guaranteed storage. -<span class="lineNum"> 507 </span> : // The first 5 iword and pword slots are reserved for internal use. -<span class="lineNum"> 508 </span> : enum { _S_local_word_size = 8 }; -<span class="lineNum"> 509 </span> : _Words _M_local_word[_S_local_word_size]; -<span class="lineNum"> 510 </span> : -<span class="lineNum"> 511 </span> : // Allocated storage. -<span class="lineNum"> 512 </span> : int _M_word_size; -<span class="lineNum"> 513 </span> : _Words* _M_word; -<span class="lineNum"> 514 </span> : -<span class="lineNum"> 515 </span> : _Words& -<span class="lineNum"> 516 </span> : _M_grow_words(int __index, bool __iword); -<span class="lineNum"> 517 </span> : -<span class="lineNum"> 518 </span> : // Members for locale and locale caching. -<span class="lineNum"> 519 </span> : locale _M_ios_locale; -<span class="lineNum"> 520 </span> : -<span class="lineNum"> 521 </span> : void -<span class="lineNum"> 522 </span> : _M_init(); -<span class="lineNum"> 523 </span> : -<span class="lineNum"> 524 </span> : public: -<span class="lineNum"> 525 </span> : -<span class="lineNum"> 526 </span> : // 27.4.2.1.6 Class ios_base::Init -<span class="lineNum"> 527 </span> : // Used to initialize standard streams. In theory, g++ could use -<span class="lineNum"> 528 </span> : // -finit-priority to order this stuff correctly without going -<span class="lineNum"> 529 </span> : // through these machinations. -<span class="lineNum"> 530 </span> : class Init -<span class="lineNum"> 531 </span> : { -<span class="lineNum"> 532 </span> : friend class ios_base; -<span class="lineNum"> 533 </span> : public: -<span class="lineNum"> 534 </span> : Init(); -<span class="lineNum"> 535 </span> : ~Init(); -<span class="lineNum"> 536 </span> : -<span class="lineNum"> 537 </span> : private: -<span class="lineNum"> 538 </span> : static _Atomic_word _S_refcount; -<span class="lineNum"> 539 </span> : static bool _S_synced_with_stdio; -<span class="lineNum"> 540 </span> : }; -<span class="lineNum"> 541 </span> : -<span class="lineNum"> 542 </span> : // [27.4.2.2] fmtflags state functions -<span class="lineNum"> 543 </span> : /** -<span class="lineNum"> 544 </span> : * @brief Access to format flags. -<span class="lineNum"> 545 </span> : * @return The format control flags for both input and output. -<span class="lineNum"> 546 </span> : */ -<span class="lineNum"> 547 </span> : fmtflags -<span class="lineNum"> 548 </span> : flags() const -<span class="lineNum"> 549 </span> : { return _M_flags; } -<span class="lineNum"> 550 </span> : -<span class="lineNum"> 551 </span> : /** -<span class="lineNum"> 552 </span> : * @brief Setting new format flags all at once. -<span class="lineNum"> 553 </span> : * @param fmtfl The new flags to set. -<span class="lineNum"> 554 </span> : * @return The previous format control flags. -<span class="lineNum"> 555 </span> : * -<span class="lineNum"> 556 </span> : * This function overwrites all the format flags with @a fmtfl. -<span class="lineNum"> 557 </span> : */ -<span class="lineNum"> 558 </span> : fmtflags -<span class="lineNum"> 559 </span> : flags(fmtflags __fmtfl) -<span class="lineNum"> 560 </span> : { -<span class="lineNum"> 561 </span> : fmtflags __old = _M_flags; -<span class="lineNum"> 562 </span> : _M_flags = __fmtfl; -<span class="lineNum"> 563 </span> : return __old; -<span class="lineNum"> 564 </span> : } -<span class="lineNum"> 565 </span> : -<span class="lineNum"> 566 </span> : /** -<span class="lineNum"> 567 </span> : * @brief Setting new format flags. -<span class="lineNum"> 568 </span> : * @param fmtfl Additional flags to set. -<span class="lineNum"> 569 </span> : * @return The previous format control flags. -<span class="lineNum"> 570 </span> : * -<span class="lineNum"> 571 </span> : * This function sets additional flags in format control. Flags that -<span class="lineNum"> 572 </span> : * were previously set remain set. -<span class="lineNum"> 573 </span> : */ -<span class="lineNum"> 574 </span> : fmtflags -<span class="lineNum"> 575 </span> : setf(fmtflags __fmtfl) -<span class="lineNum"> 576 </span> : { -<span class="lineNum"> 577 </span> : fmtflags __old = _M_flags; -<span class="lineNum"> 578 </span> : _M_flags |= __fmtfl; -<span class="lineNum"> 579 </span> : return __old; -<span class="lineNum"> 580 </span> : } -<span class="lineNum"> 581 </span> : -<span class="lineNum"> 582 </span> : /** -<span class="lineNum"> 583 </span> : * @brief Setting new format flags. -<span class="lineNum"> 584 </span> : * @param fmtfl Additional flags to set. -<span class="lineNum"> 585 </span> : * @param mask The flags mask for @a fmtfl. -<span class="lineNum"> 586 </span> : * @return The previous format control flags. -<span class="lineNum"> 587 </span> : * -<span class="lineNum"> 588 </span> : * This function clears @a mask in the format flags, then sets -<span class="lineNum"> 589 </span> : * @a fmtfl @c & @a mask. An example mask is @c ios_base::adjustfield. -<span class="lineNum"> 590 </span> : */ -<span class="lineNum"> 591 </span> : fmtflags -<span class="lineNum"> 592 </span><span class="lineCov"> 33 : setf(fmtflags __fmtfl, fmtflags __mask)</span> -<span class="lineNum"> 593 </span> : { -<span class="lineNum"> 594 </span><span class="lineCov"> 33 : fmtflags __old = _M_flags;</span> -<span class="lineNum"> 595 </span><span class="lineCov"> 33 : _M_flags &= ~__mask;</span> -<span class="lineNum"> 596 </span><span class="lineCov"> 33 : _M_flags |= (__fmtfl & __mask);</span> -<span class="lineNum"> 597 </span><span class="lineCov"> 33 : return __old;</span> -<span class="lineNum"> 598 </span> : } -<span class="lineNum"> 599 </span> : -<span class="lineNum"> 600 </span> : /** -<span class="lineNum"> 601 </span> : * @brief Clearing format flags. -<span class="lineNum"> 602 </span> : * @param mask The flags to unset. -<span class="lineNum"> 603 </span> : * -<span class="lineNum"> 604 </span> : * This function clears @a mask in the format flags. -<span class="lineNum"> 605 </span> : */ -<span class="lineNum"> 606 </span> : void -<span class="lineNum"> 607 </span> : unsetf(fmtflags __mask) -<span class="lineNum"> 608 </span> : { _M_flags &= ~__mask; } -<span class="lineNum"> 609 </span> : -<span class="lineNum"> 610 </span> : /** -<span class="lineNum"> 611 </span> : * @brief Flags access. -<span class="lineNum"> 612 </span> : * @return The precision to generate on certain output operations. -<span class="lineNum"> 613 </span> : * -<span class="lineNum"> 614 </span> : * Be careful if you try to give a definition of "precision" here; see -<span class="lineNum"> 615 </span> : * DR 189. -<span class="lineNum"> 616 </span> : */ -<span class="lineNum"> 617 </span> : streamsize -<span class="lineNum"> 618 </span> : precision() const -<span class="lineNum"> 619 </span> : { return _M_precision; } -<span class="lineNum"> 620 </span> : -<span class="lineNum"> 621 </span> : /** -<span class="lineNum"> 622 </span> : * @brief Changing flags. -<span class="lineNum"> 623 </span> : * @param prec The new precision value. -<span class="lineNum"> 624 </span> : * @return The previous value of precision(). -<span class="lineNum"> 625 </span> : */ -<span class="lineNum"> 626 </span> : streamsize -<span class="lineNum"> 627 </span> : precision(streamsize __prec) -<span class="lineNum"> 628 </span> : { -<span class="lineNum"> 629 </span> : streamsize __old = _M_precision; -<span class="lineNum"> 630 </span> : _M_precision = __prec; -<span class="lineNum"> 631 </span> : return __old; -<span class="lineNum"> 632 </span> : } -<span class="lineNum"> 633 </span> : -<span class="lineNum"> 634 </span> : /** -<span class="lineNum"> 635 </span> : * @brief Flags access. -<span class="lineNum"> 636 </span> : * @return The minimum field width to generate on output operations. -<span class="lineNum"> 637 </span> : * -<span class="lineNum"> 638 </span> : * "Minimum field width" refers to the number of characters. -<span class="lineNum"> 639 </span> : */ -<span class="lineNum"> 640 </span> : streamsize -<span class="lineNum"> 641 </span> : width() const -<span class="lineNum"> 642 </span> : { return _M_width; } -<span class="lineNum"> 643 </span> : -<span class="lineNum"> 644 </span> : /** -<span class="lineNum"> 645 </span> : * @brief Changing flags. -<span class="lineNum"> 646 </span> : * @param wide The new width value. -<span class="lineNum"> 647 </span> : * @return The previous value of width(). -<span class="lineNum"> 648 </span> : */ -<span class="lineNum"> 649 </span> : streamsize -<span class="lineNum"> 650 </span><span class="lineNoCov"> 0 : width(streamsize __wide)</span> -<span class="lineNum"> 651 </span> : { -<span class="lineNum"> 652 </span><span class="lineNoCov"> 0 : streamsize __old = _M_width;</span> -<span class="lineNum"> 653 </span><span class="lineNoCov"> 0 : _M_width = __wide;</span> -<span class="lineNum"> 654 </span><span class="lineNoCov"> 0 : return __old;</span> -<span class="lineNum"> 655 </span> : } -<span class="lineNum"> 656 </span> : -<span class="lineNum"> 657 </span> : // [27.4.2.4] ios_base static members -<span class="lineNum"> 658 </span> : /** -<span class="lineNum"> 659 </span> : * @brief Interaction with the standard C I/O objects. -<span class="lineNum"> 660 </span> : * @param sync Whether to synchronize or not. -<span class="lineNum"> 661 </span> : * @return True if the standard streams were previously synchronized. -<span class="lineNum"> 662 </span> : * -<span class="lineNum"> 663 </span> : * The synchronization referred to is @e only that between the standard -<span class="lineNum"> 664 </span> : * C facilities (e.g., stdout) and the standard C++ objects (e.g., -<span class="lineNum"> 665 </span> : * cout). User-declared streams are unaffected. See -<span class="lineNum"> 666 </span> : * http://gcc.gnu.org/onlinedocs/libstdc++/27_io/howto.html#8 for more. -<span class="lineNum"> 667 </span> : */ -<span class="lineNum"> 668 </span> : static bool -<span class="lineNum"> 669 </span> : sync_with_stdio(bool __sync = true); -<span class="lineNum"> 670 </span> : -<span class="lineNum"> 671 </span> : // [27.4.2.3] ios_base locale functions -<span class="lineNum"> 672 </span> : /** -<span class="lineNum"> 673 </span> : * @brief Setting a new locale. -<span class="lineNum"> 674 </span> : * @param loc The new locale. -<span class="lineNum"> 675 </span> : * @return The previous locale. -<span class="lineNum"> 676 </span> : * -<span class="lineNum"> 677 </span> : * Sets the new locale for this stream, and then invokes each callback -<span class="lineNum"> 678 </span> : * with imbue_event. -<span class="lineNum"> 679 </span> : */ -<span class="lineNum"> 680 </span> : locale -<span class="lineNum"> 681 </span> : imbue(const locale& __loc); -<span class="lineNum"> 682 </span> : -<span class="lineNum"> 683 </span> : /** -<span class="lineNum"> 684 </span> : * @brief Locale access -<span class="lineNum"> 685 </span> : * @return A copy of the current locale. -<span class="lineNum"> 686 </span> : * -<span class="lineNum"> 687 </span> : * If @c imbue(loc) has previously been called, then this function -<span class="lineNum"> 688 </span> : * returns @c loc. Otherwise, it returns a copy of @c std::locale(), -<span class="lineNum"> 689 </span> : * the global C++ locale. -<span class="lineNum"> 690 </span> : */ -<span class="lineNum"> 691 </span> : locale -<span class="lineNum"> 692 </span> : getloc() const -<span class="lineNum"> 693 </span> : { return _M_ios_locale; } -<span class="lineNum"> 694 </span> : -<span class="lineNum"> 695 </span> : /** -<span class="lineNum"> 696 </span> : * @brief Locale access -<span class="lineNum"> 697 </span> : * @return A reference to the current locale. -<span class="lineNum"> 698 </span> : * -<span class="lineNum"> 699 </span> : * Like getloc above, but returns a reference instead of -<span class="lineNum"> 700 </span> : * generating a copy. -<span class="lineNum"> 701 </span> : */ -<span class="lineNum"> 702 </span> : const locale& -<span class="lineNum"> 703 </span> : _M_getloc() const -<span class="lineNum"> 704 </span> : { return _M_ios_locale; } -<span class="lineNum"> 705 </span> : -<span class="lineNum"> 706 </span> : // [27.4.2.5] ios_base storage functions -<span class="lineNum"> 707 </span> : /** -<span class="lineNum"> 708 </span> : * @brief Access to unique indices. -<span class="lineNum"> 709 </span> : * @return An integer different from all previous calls. -<span class="lineNum"> 710 </span> : * -<span class="lineNum"> 711 </span> : * This function returns a unique integer every time it is called. It -<span class="lineNum"> 712 </span> : * can be used for any purpose, but is primarily intended to be a unique -<span class="lineNum"> 713 </span> : * index for the iword and pword functions. The expectation is that an -<span class="lineNum"> 714 </span> : * application calls xalloc in order to obtain an index in the iword and -<span class="lineNum"> 715 </span> : * pword arrays that can be used without fear of conflict. -<span class="lineNum"> 716 </span> : * -<span class="lineNum"> 717 </span> : * The implementation maintains a static variable that is incremented and -<span class="lineNum"> 718 </span> : * returned on each invocation. xalloc is guaranteed to return an index -<span class="lineNum"> 719 </span> : * that is safe to use in the iword and pword arrays. -<span class="lineNum"> 720 </span> : */ -<span class="lineNum"> 721 </span> : static int -<span class="lineNum"> 722 </span> : xalloc() throw(); -<span class="lineNum"> 723 </span> : -<span class="lineNum"> 724 </span> : /** -<span class="lineNum"> 725 </span> : * @brief Access to integer array. -<span class="lineNum"> 726 </span> : * @param __ix Index into the array. -<span class="lineNum"> 727 </span> : * @return A reference to an integer associated with the index. -<span class="lineNum"> 728 </span> : * -<span class="lineNum"> 729 </span> : * The iword function provides access to an array of integers that can be -<span class="lineNum"> 730 </span> : * used for any purpose. The array grows as required to hold the -<span class="lineNum"> 731 </span> : * supplied index. All integers in the array are initialized to 0. -<span class="lineNum"> 732 </span> : * -<span class="lineNum"> 733 </span> : * The implementation reserves several indices. You should use xalloc to -<span class="lineNum"> 734 </span> : * obtain an index that is safe to use. Also note that since the array -<span class="lineNum"> 735 </span> : * can grow dynamically, it is not safe to hold onto the reference. -<span class="lineNum"> 736 </span> : */ -<span class="lineNum"> 737 </span> : long& -<span class="lineNum"> 738 </span> : iword(int __ix) -<span class="lineNum"> 739 </span> : { -<span class="lineNum"> 740 </span> : _Words& __word = (__ix < _M_word_size) -<span class="lineNum"> 741 </span> : ? _M_word[__ix] : _M_grow_words(__ix, true); -<span class="lineNum"> 742 </span> : return __word._M_iword; -<span class="lineNum"> 743 </span> : } -<span class="lineNum"> 744 </span> : -<span class="lineNum"> 745 </span> : /** -<span class="lineNum"> 746 </span> : * @brief Access to void pointer array. -<span class="lineNum"> 747 </span> : * @param __ix Index into the array. -<span class="lineNum"> 748 </span> : * @return A reference to a void* associated with the index. -<span class="lineNum"> 749 </span> : * -<span class="lineNum"> 750 </span> : * The pword function provides access to an array of pointers that can be -<span class="lineNum"> 751 </span> : * used for any purpose. The array grows as required to hold the -<span class="lineNum"> 752 </span> : * supplied index. All pointers in the array are initialized to 0. -<span class="lineNum"> 753 </span> : * -<span class="lineNum"> 754 </span> : * The implementation reserves several indices. You should use xalloc to -<span class="lineNum"> 755 </span> : * obtain an index that is safe to use. Also note that since the array -<span class="lineNum"> 756 </span> : * can grow dynamically, it is not safe to hold onto the reference. -<span class="lineNum"> 757 </span> : */ -<span class="lineNum"> 758 </span> : void*& -<span class="lineNum"> 759 </span> : pword(int __ix) -<span class="lineNum"> 760 </span> : { -<span class="lineNum"> 761 </span> : _Words& __word = (__ix < _M_word_size) -<span class="lineNum"> 762 </span> : ? _M_word[__ix] : _M_grow_words(__ix, false); -<span class="lineNum"> 763 </span> : return __word._M_pword; -<span class="lineNum"> 764 </span> : } -<span class="lineNum"> 765 </span> : -<span class="lineNum"> 766 </span> : // Destructor -<span class="lineNum"> 767 </span> : /** -<span class="lineNum"> 768 </span> : * Invokes each callback with erase_event. Destroys local storage. -<span class="lineNum"> 769 </span> : * -<span class="lineNum"> 770 </span> : * Note that the ios_base object for the standard streams never gets -<span class="lineNum"> 771 </span> : * destroyed. As a result, any callbacks registered with the standard -<span class="lineNum"> 772 </span> : * streams will not get invoked with erase_event (unless copyfmt is -<span class="lineNum"> 773 </span> : * used). -<span class="lineNum"> 774 </span> : */ -<span class="lineNum"> 775 </span> : virtual ~ios_base(); -<span class="lineNum"> 776 </span> : -<span class="lineNum"> 777 </span> : protected: -<span class="lineNum"> 778 </span> : ios_base(); -<span class="lineNum"> 779 </span> : -<span class="lineNum"> 780 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 781 </span> : // 50. Copy constructor and assignment operator of ios_base -<span class="lineNum"> 782 </span> : private: -<span class="lineNum"> 783 </span> : ios_base(const ios_base&); -<span class="lineNum"> 784 </span> : -<span class="lineNum"> 785 </span> : ios_base& -<span class="lineNum"> 786 </span> : operator=(const ios_base&); -<span class="lineNum"> 787 </span> : }; -<span class="lineNum"> 788 </span> : -<span class="lineNum"> 789 </span> : // [27.4.5.1] fmtflags manipulators -<span class="lineNum"> 790 </span> : /// Calls base.setf(ios_base::boolalpha). -<span class="lineNum"> 791 </span> : inline ios_base& -<span class="lineNum"> 792 </span> : boolalpha(ios_base& __base) -<span class="lineNum"> 793 </span> : { -<span class="lineNum"> 794 </span> : __base.setf(ios_base::boolalpha); -<span class="lineNum"> 795 </span> : return __base; -<span class="lineNum"> 796 </span> : } -<span class="lineNum"> 797 </span> : -<span class="lineNum"> 798 </span> : /// Calls base.unsetf(ios_base::boolalpha). -<span class="lineNum"> 799 </span> : inline ios_base& -<span class="lineNum"> 800 </span> : noboolalpha(ios_base& __base) -<span class="lineNum"> 801 </span> : { -<span class="lineNum"> 802 </span> : __base.unsetf(ios_base::boolalpha); -<span class="lineNum"> 803 </span> : return __base; -<span class="lineNum"> 804 </span> : } -<span class="lineNum"> 805 </span> : -<span class="lineNum"> 806 </span> : /// Calls base.setf(ios_base::showbase). -<span class="lineNum"> 807 </span> : inline ios_base& -<span class="lineNum"> 808 </span> : showbase(ios_base& __base) -<span class="lineNum"> 809 </span> : { -<span class="lineNum"> 810 </span> : __base.setf(ios_base::showbase); -<span class="lineNum"> 811 </span> : return __base; -<span class="lineNum"> 812 </span> : } -<span class="lineNum"> 813 </span> : -<span class="lineNum"> 814 </span> : /// Calls base.unsetf(ios_base::showbase). -<span class="lineNum"> 815 </span> : inline ios_base& -<span class="lineNum"> 816 </span> : noshowbase(ios_base& __base) -<span class="lineNum"> 817 </span> : { -<span class="lineNum"> 818 </span> : __base.unsetf(ios_base::showbase); -<span class="lineNum"> 819 </span> : return __base; -<span class="lineNum"> 820 </span> : } -<span class="lineNum"> 821 </span> : -<span class="lineNum"> 822 </span> : /// Calls base.setf(ios_base::showpoint). -<span class="lineNum"> 823 </span> : inline ios_base& -<span class="lineNum"> 824 </span> : showpoint(ios_base& __base) -<span class="lineNum"> 825 </span> : { -<span class="lineNum"> 826 </span> : __base.setf(ios_base::showpoint); -<span class="lineNum"> 827 </span> : return __base; -<span class="lineNum"> 828 </span> : } -<span class="lineNum"> 829 </span> : -<span class="lineNum"> 830 </span> : /// Calls base.unsetf(ios_base::showpoint). -<span class="lineNum"> 831 </span> : inline ios_base& -<span class="lineNum"> 832 </span> : noshowpoint(ios_base& __base) -<span class="lineNum"> 833 </span> : { -<span class="lineNum"> 834 </span> : __base.unsetf(ios_base::showpoint); -<span class="lineNum"> 835 </span> : return __base; -<span class="lineNum"> 836 </span> : } -<span class="lineNum"> 837 </span> : -<span class="lineNum"> 838 </span> : /// Calls base.setf(ios_base::showpos). -<span class="lineNum"> 839 </span> : inline ios_base& -<span class="lineNum"> 840 </span> : showpos(ios_base& __base) -<span class="lineNum"> 841 </span> : { -<span class="lineNum"> 842 </span> : __base.setf(ios_base::showpos); -<span class="lineNum"> 843 </span> : return __base; -<span class="lineNum"> 844 </span> : } -<span class="lineNum"> 845 </span> : -<span class="lineNum"> 846 </span> : /// Calls base.unsetf(ios_base::showpos). -<span class="lineNum"> 847 </span> : inline ios_base& -<span class="lineNum"> 848 </span> : noshowpos(ios_base& __base) -<span class="lineNum"> 849 </span> : { -<span class="lineNum"> 850 </span> : __base.unsetf(ios_base::showpos); -<span class="lineNum"> 851 </span> : return __base; -<span class="lineNum"> 852 </span> : } -<span class="lineNum"> 853 </span> : -<span class="lineNum"> 854 </span> : /// Calls base.setf(ios_base::skipws). -<span class="lineNum"> 855 </span> : inline ios_base& -<span class="lineNum"> 856 </span> : skipws(ios_base& __base) -<span class="lineNum"> 857 </span> : { -<span class="lineNum"> 858 </span> : __base.setf(ios_base::skipws); -<span class="lineNum"> 859 </span> : return __base; -<span class="lineNum"> 860 </span> : } -<span class="lineNum"> 861 </span> : -<span class="lineNum"> 862 </span> : /// Calls base.unsetf(ios_base::skipws). -<span class="lineNum"> 863 </span> : inline ios_base& -<span class="lineNum"> 864 </span> : noskipws(ios_base& __base) -<span class="lineNum"> 865 </span> : { -<span class="lineNum"> 866 </span> : __base.unsetf(ios_base::skipws); -<span class="lineNum"> 867 </span> : return __base; -<span class="lineNum"> 868 </span> : } -<span class="lineNum"> 869 </span> : -<span class="lineNum"> 870 </span> : /// Calls base.setf(ios_base::uppercase). -<span class="lineNum"> 871 </span> : inline ios_base& -<span class="lineNum"> 872 </span> : uppercase(ios_base& __base) -<span class="lineNum"> 873 </span> : { -<span class="lineNum"> 874 </span> : __base.setf(ios_base::uppercase); -<span class="lineNum"> 875 </span> : return __base; -<span class="lineNum"> 876 </span> : } -<span class="lineNum"> 877 </span> : -<span class="lineNum"> 878 </span> : /// Calls base.unsetf(ios_base::uppercase). -<span class="lineNum"> 879 </span> : inline ios_base& -<span class="lineNum"> 880 </span> : nouppercase(ios_base& __base) -<span class="lineNum"> 881 </span> : { -<span class="lineNum"> 882 </span> : __base.unsetf(ios_base::uppercase); -<span class="lineNum"> 883 </span> : return __base; -<span class="lineNum"> 884 </span> : } -<span class="lineNum"> 885 </span> : -<span class="lineNum"> 886 </span> : /// Calls base.setf(ios_base::unitbuf). -<span class="lineNum"> 887 </span> : inline ios_base& -<span class="lineNum"> 888 </span> : unitbuf(ios_base& __base) -<span class="lineNum"> 889 </span> : { -<span class="lineNum"> 890 </span> : __base.setf(ios_base::unitbuf); -<span class="lineNum"> 891 </span> : return __base; -<span class="lineNum"> 892 </span> : } -<span class="lineNum"> 893 </span> : -<span class="lineNum"> 894 </span> : /// Calls base.unsetf(ios_base::unitbuf). -<span class="lineNum"> 895 </span> : inline ios_base& -<span class="lineNum"> 896 </span> : nounitbuf(ios_base& __base) -<span class="lineNum"> 897 </span> : { -<span class="lineNum"> 898 </span> : __base.unsetf(ios_base::unitbuf); -<span class="lineNum"> 899 </span> : return __base; -<span class="lineNum"> 900 </span> : } -<span class="lineNum"> 901 </span> : -<span class="lineNum"> 902 </span> : // [27.4.5.2] adjustfield manipulators -<span class="lineNum"> 903 </span> : /// Calls base.setf(ios_base::internal, ios_base::adjustfield). -<span class="lineNum"> 904 </span> : inline ios_base& -<span class="lineNum"> 905 </span><span class="lineCov"> 33 : internal(ios_base& __base)</span> -<span class="lineNum"> 906 </span> : { -<span class="lineNum"> 907 </span><span class="lineCov"> 33 : __base.setf(ios_base::internal, ios_base::adjustfield);</span> -<span class="lineNum"> 908 </span><span class="lineCov"> 33 : return __base;</span> -<span class="lineNum"> 909 </span> : } -<span class="lineNum"> 910 </span> : -<span class="lineNum"> 911 </span> : /// Calls base.setf(ios_base::left, ios_base::adjustfield). -<span class="lineNum"> 912 </span> : inline ios_base& -<span class="lineNum"> 913 </span> : left(ios_base& __base) -<span class="lineNum"> 914 </span> : { -<span class="lineNum"> 915 </span> : __base.setf(ios_base::left, ios_base::adjustfield); -<span class="lineNum"> 916 </span> : return __base; -<span class="lineNum"> 917 </span> : } -<span class="lineNum"> 918 </span> : -<span class="lineNum"> 919 </span> : /// Calls base.setf(ios_base::right, ios_base::adjustfield). -<span class="lineNum"> 920 </span> : inline ios_base& -<span class="lineNum"> 921 </span> : right(ios_base& __base) -<span class="lineNum"> 922 </span> : { -<span class="lineNum"> 923 </span> : __base.setf(ios_base::right, ios_base::adjustfield); -<span class="lineNum"> 924 </span> : return __base; -<span class="lineNum"> 925 </span> : } -<span class="lineNum"> 926 </span> : -<span class="lineNum"> 927 </span> : // [27.4.5.3] basefield manipulators -<span class="lineNum"> 928 </span> : /// Calls base.setf(ios_base::dec, ios_base::basefield). -<span class="lineNum"> 929 </span> : inline ios_base& -<span class="lineNum"> 930 </span> : dec(ios_base& __base) -<span class="lineNum"> 931 </span> : { -<span class="lineNum"> 932 </span> : __base.setf(ios_base::dec, ios_base::basefield); -<span class="lineNum"> 933 </span> : return __base; -<span class="lineNum"> 934 </span> : } -<span class="lineNum"> 935 </span> : -<span class="lineNum"> 936 </span> : /// Calls base.setf(ios_base::hex, ios_base::basefield). -<span class="lineNum"> 937 </span> : inline ios_base& -<span class="lineNum"> 938 </span> : hex(ios_base& __base) -<span class="lineNum"> 939 </span> : { -<span class="lineNum"> 940 </span> : __base.setf(ios_base::hex, ios_base::basefield); -<span class="lineNum"> 941 </span> : return __base; -<span class="lineNum"> 942 </span> : } -<span class="lineNum"> 943 </span> : -<span class="lineNum"> 944 </span> : /// Calls base.setf(ios_base::oct, ios_base::basefield). -<span class="lineNum"> 945 </span> : inline ios_base& -<span class="lineNum"> 946 </span> : oct(ios_base& __base) -<span class="lineNum"> 947 </span> : { -<span class="lineNum"> 948 </span> : __base.setf(ios_base::oct, ios_base::basefield); -<span class="lineNum"> 949 </span> : return __base; -<span class="lineNum"> 950 </span> : } -<span class="lineNum"> 951 </span> : -<span class="lineNum"> 952 </span> : // [27.4.5.4] floatfield manipulators -<span class="lineNum"> 953 </span> : /// Calls base.setf(ios_base::fixed, ios_base::floatfield). -<span class="lineNum"> 954 </span> : inline ios_base& -<span class="lineNum"> 955 </span> : fixed(ios_base& __base) -<span class="lineNum"> 956 </span> : { -<span class="lineNum"> 957 </span> : __base.setf(ios_base::fixed, ios_base::floatfield); -<span class="lineNum"> 958 </span> : return __base; -<span class="lineNum"> 959 </span> : } -<span class="lineNum"> 960 </span> : -<span class="lineNum"> 961 </span> : /// Calls base.setf(ios_base::scientific, ios_base::floatfield). -<span class="lineNum"> 962 </span> : inline ios_base& -<span class="lineNum"> 963 </span> : scientific(ios_base& __base) -<span class="lineNum"> 964 </span> : { -<span class="lineNum"> 965 </span> : __base.setf(ios_base::scientific, ios_base::floatfield); -<span class="lineNum"> 966 </span> : return __base; -<span class="lineNum"> 967 </span> : } -<span class="lineNum"> 968 </span> : -<span class="lineNum"> 969 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 970 </span> : -<span class="lineNum"> 971 </span> : #endif /* _IOS_BASE_H */ -<span class="lineNum"> 972 </span> : -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/list.tcc.gcov.html b/rep/usr/include/c++/4.3/bits/list.tcc.gcov.html deleted file mode 100644 index 18b3b6a..0000000 --- a/rep/usr/include/c++/4.3/bits/list.tcc.gcov.html +++ /dev/null @@ -1,484 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/list.tcc</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - list.tcc</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">11</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">11</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // List implementation (out of line) -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file list.tcc -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _LIST_TCC -<span class="lineNum"> 63 </span> : #define _LIST_TCC 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 68 </span> : void -<span class="lineNum"> 69 </span> : _List_base<_Tp, _Alloc>:: -<span class="lineNum"> 70 </span><span class="lineCov"> 19 : _M_clear()</span> -<span class="lineNum"> 71 </span> : { -<span class="lineNum"> 72 </span> : typedef _List_node<_Tp> _Node; -<span class="lineNum"> 73 </span><span class="lineCov"> 19 : _Node* __cur = static_cast<_Node*>(this->_M_impl._M_node._M_next);</span> -<span class="lineNum"> 74 </span><span class="lineCov"> 60 : while (__cur != &this->_M_impl._M_node)</span> -<span class="lineNum"> 75 </span> : { -<span class="lineNum"> 76 </span><span class="lineCov"> 22 : _Node* __tmp = __cur;</span> -<span class="lineNum"> 77 </span><span class="lineCov"> 22 : __cur = static_cast<_Node*>(__cur->_M_next);</span> -<span class="lineNum"> 78 </span><span class="lineCov"> 22 : _M_get_Tp_allocator().destroy(&__tmp->_M_data);</span> -<span class="lineNum"> 79 </span><span class="lineCov"> 22 : _M_put_node(__tmp);</span> -<span class="lineNum"> 80 </span> : } -<span class="lineNum"> 81 </span><span class="lineCov"> 19 : }</span> -<span class="lineNum"> 82 </span> : -<span class="lineNum"> 83 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 84 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 85 </span> : template<typename... _Args> -<span class="lineNum"> 86 </span> : typename list<_Tp, _Alloc>::iterator -<span class="lineNum"> 87 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 88 </span> : emplace(iterator __position, _Args&&... __args) -<span class="lineNum"> 89 </span> : { -<span class="lineNum"> 90 </span> : _Node* __tmp = _M_create_node(std::forward<_Args>(__args)...); -<span class="lineNum"> 91 </span> : __tmp->hook(__position._M_node); -<span class="lineNum"> 92 </span> : return iterator(__tmp); -<span class="lineNum"> 93 </span> : } -<span class="lineNum"> 94 </span> : #endif -<span class="lineNum"> 95 </span> : -<span class="lineNum"> 96 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 97 </span> : typename list<_Tp, _Alloc>::iterator -<span class="lineNum"> 98 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 99 </span> : insert(iterator __position, const value_type& __x) -<span class="lineNum"> 100 </span> : { -<span class="lineNum"> 101 </span> : _Node* __tmp = _M_create_node(__x); -<span class="lineNum"> 102 </span> : __tmp->hook(__position._M_node); -<span class="lineNum"> 103 </span> : return iterator(__tmp); -<span class="lineNum"> 104 </span> : } -<span class="lineNum"> 105 </span> : -<span class="lineNum"> 106 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 107 </span> : typename list<_Tp, _Alloc>::iterator -<span class="lineNum"> 108 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 109 </span><span class="lineCov"> 25 : erase(iterator __position)</span> -<span class="lineNum"> 110 </span> : { -<span class="lineNum"> 111 </span><span class="lineCov"> 25 : iterator __ret = iterator(__position._M_node->_M_next);</span> -<span class="lineNum"> 112 </span><span class="lineCov"> 25 : _M_erase(__position);</span> -<span class="lineNum"> 113 </span> : return __ret; -<span class="lineNum"> 114 </span> : } -<span class="lineNum"> 115 </span> : -<span class="lineNum"> 116 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 117 </span> : void -<span class="lineNum"> 118 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 119 </span> : resize(size_type __new_size, value_type __x) -<span class="lineNum"> 120 </span> : { -<span class="lineNum"> 121 </span> : iterator __i = begin(); -<span class="lineNum"> 122 </span> : size_type __len = 0; -<span class="lineNum"> 123 </span> : for (; __i != end() && __len < __new_size; ++__i, ++__len) -<span class="lineNum"> 124 </span> : ; -<span class="lineNum"> 125 </span> : if (__len == __new_size) -<span class="lineNum"> 126 </span> : erase(__i, end()); -<span class="lineNum"> 127 </span> : else // __i == end() -<span class="lineNum"> 128 </span> : insert(end(), __new_size - __len, __x); -<span class="lineNum"> 129 </span> : } -<span class="lineNum"> 130 </span> : -<span class="lineNum"> 131 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 132 </span> : list<_Tp, _Alloc>& -<span class="lineNum"> 133 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 134 </span> : operator=(const list& __x) -<span class="lineNum"> 135 </span> : { -<span class="lineNum"> 136 </span> : if (this != &__x) -<span class="lineNum"> 137 </span> : { -<span class="lineNum"> 138 </span> : iterator __first1 = begin(); -<span class="lineNum"> 139 </span> : iterator __last1 = end(); -<span class="lineNum"> 140 </span> : const_iterator __first2 = __x.begin(); -<span class="lineNum"> 141 </span> : const_iterator __last2 = __x.end(); -<span class="lineNum"> 142 </span> : for (; __first1 != __last1 && __first2 != __last2; -<span class="lineNum"> 143 </span> : ++__first1, ++__first2) -<span class="lineNum"> 144 </span> : *__first1 = *__first2; -<span class="lineNum"> 145 </span> : if (__first2 == __last2) -<span class="lineNum"> 146 </span> : erase(__first1, __last1); -<span class="lineNum"> 147 </span> : else -<span class="lineNum"> 148 </span> : insert(__last1, __first2, __last2); -<span class="lineNum"> 149 </span> : } -<span class="lineNum"> 150 </span> : return *this; -<span class="lineNum"> 151 </span> : } -<span class="lineNum"> 152 </span> : -<span class="lineNum"> 153 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 154 </span> : void -<span class="lineNum"> 155 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 156 </span> : _M_fill_assign(size_type __n, const value_type& __val) -<span class="lineNum"> 157 </span> : { -<span class="lineNum"> 158 </span> : iterator __i = begin(); -<span class="lineNum"> 159 </span> : for (; __i != end() && __n > 0; ++__i, --__n) -<span class="lineNum"> 160 </span> : *__i = __val; -<span class="lineNum"> 161 </span> : if (__n > 0) -<span class="lineNum"> 162 </span> : insert(end(), __n, __val); -<span class="lineNum"> 163 </span> : else -<span class="lineNum"> 164 </span> : erase(__i, end()); -<span class="lineNum"> 165 </span> : } -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 168 </span> : template <typename _InputIterator> -<span class="lineNum"> 169 </span> : void -<span class="lineNum"> 170 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 171 </span> : _M_assign_dispatch(_InputIterator __first2, _InputIterator __last2, -<span class="lineNum"> 172 </span> : __false_type) -<span class="lineNum"> 173 </span> : { -<span class="lineNum"> 174 </span> : iterator __first1 = begin(); -<span class="lineNum"> 175 </span> : iterator __last1 = end(); -<span class="lineNum"> 176 </span> : for (; __first1 != __last1 && __first2 != __last2; -<span class="lineNum"> 177 </span> : ++__first1, ++__first2) -<span class="lineNum"> 178 </span> : *__first1 = *__first2; -<span class="lineNum"> 179 </span> : if (__first2 == __last2) -<span class="lineNum"> 180 </span> : erase(__first1, __last1); -<span class="lineNum"> 181 </span> : else -<span class="lineNum"> 182 </span> : insert(__last1, __first2, __last2); -<span class="lineNum"> 183 </span> : } -<span class="lineNum"> 184 </span> : -<span class="lineNum"> 185 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 186 </span> : void -<span class="lineNum"> 187 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 188 </span> : remove(const value_type& __value) -<span class="lineNum"> 189 </span> : { -<span class="lineNum"> 190 </span> : iterator __first = begin(); -<span class="lineNum"> 191 </span> : iterator __last = end(); -<span class="lineNum"> 192 </span> : iterator __extra = __last; -<span class="lineNum"> 193 </span> : while (__first != __last) -<span class="lineNum"> 194 </span> : { -<span class="lineNum"> 195 </span> : iterator __next = __first; -<span class="lineNum"> 196 </span> : ++__next; -<span class="lineNum"> 197 </span> : if (*__first == __value) -<span class="lineNum"> 198 </span> : { -<span class="lineNum"> 199 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 200 </span> : // 526. Is it undefined if a function in the standard changes -<span class="lineNum"> 201 </span> : // in parameters? -<span class="lineNum"> 202 </span> : if (&*__first != &__value) -<span class="lineNum"> 203 </span> : _M_erase(__first); -<span class="lineNum"> 204 </span> : else -<span class="lineNum"> 205 </span> : __extra = __first; -<span class="lineNum"> 206 </span> : } -<span class="lineNum"> 207 </span> : __first = __next; -<span class="lineNum"> 208 </span> : } -<span class="lineNum"> 209 </span> : if (__extra != __last) -<span class="lineNum"> 210 </span> : _M_erase(__extra); -<span class="lineNum"> 211 </span> : } -<span class="lineNum"> 212 </span> : -<span class="lineNum"> 213 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 214 </span> : void -<span class="lineNum"> 215 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 216 </span> : unique() -<span class="lineNum"> 217 </span> : { -<span class="lineNum"> 218 </span> : iterator __first = begin(); -<span class="lineNum"> 219 </span> : iterator __last = end(); -<span class="lineNum"> 220 </span> : if (__first == __last) -<span class="lineNum"> 221 </span> : return; -<span class="lineNum"> 222 </span> : iterator __next = __first; -<span class="lineNum"> 223 </span> : while (++__next != __last) -<span class="lineNum"> 224 </span> : { -<span class="lineNum"> 225 </span> : if (*__first == *__next) -<span class="lineNum"> 226 </span> : _M_erase(__next); -<span class="lineNum"> 227 </span> : else -<span class="lineNum"> 228 </span> : __first = __next; -<span class="lineNum"> 229 </span> : __next = __first; -<span class="lineNum"> 230 </span> : } -<span class="lineNum"> 231 </span> : } -<span class="lineNum"> 232 </span> : -<span class="lineNum"> 233 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 234 </span> : void -<span class="lineNum"> 235 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 236 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 237 </span> : merge(list&& __x) -<span class="lineNum"> 238 </span> : #else -<span class="lineNum"> 239 </span> : merge(list& __x) -<span class="lineNum"> 240 </span> : #endif -<span class="lineNum"> 241 </span> : { -<span class="lineNum"> 242 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 243 </span> : // 300. list::merge() specification incomplete -<span class="lineNum"> 244 </span> : if (this != &__x) -<span class="lineNum"> 245 </span> : { -<span class="lineNum"> 246 </span> : _M_check_equal_allocators(__x); -<span class="lineNum"> 247 </span> : -<span class="lineNum"> 248 </span> : iterator __first1 = begin(); -<span class="lineNum"> 249 </span> : iterator __last1 = end(); -<span class="lineNum"> 250 </span> : iterator __first2 = __x.begin(); -<span class="lineNum"> 251 </span> : iterator __last2 = __x.end(); -<span class="lineNum"> 252 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 253 </span> : if (*__first2 < *__first1) -<span class="lineNum"> 254 </span> : { -<span class="lineNum"> 255 </span> : iterator __next = __first2; -<span class="lineNum"> 256 </span> : _M_transfer(__first1, __first2, ++__next); -<span class="lineNum"> 257 </span> : __first2 = __next; -<span class="lineNum"> 258 </span> : } -<span class="lineNum"> 259 </span> : else -<span class="lineNum"> 260 </span> : ++__first1; -<span class="lineNum"> 261 </span> : if (__first2 != __last2) -<span class="lineNum"> 262 </span> : _M_transfer(__last1, __first2, __last2); -<span class="lineNum"> 263 </span> : } -<span class="lineNum"> 264 </span> : } -<span class="lineNum"> 265 </span> : -<span class="lineNum"> 266 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 267 </span> : template <typename _StrictWeakOrdering> -<span class="lineNum"> 268 </span> : void -<span class="lineNum"> 269 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 270 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 271 </span> : merge(list&& __x, _StrictWeakOrdering __comp) -<span class="lineNum"> 272 </span> : #else -<span class="lineNum"> 273 </span> : merge(list& __x, _StrictWeakOrdering __comp) -<span class="lineNum"> 274 </span> : #endif -<span class="lineNum"> 275 </span> : { -<span class="lineNum"> 276 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 277 </span> : // 300. list::merge() specification incomplete -<span class="lineNum"> 278 </span> : if (this != &__x) -<span class="lineNum"> 279 </span> : { -<span class="lineNum"> 280 </span> : _M_check_equal_allocators(__x); -<span class="lineNum"> 281 </span> : -<span class="lineNum"> 282 </span> : iterator __first1 = begin(); -<span class="lineNum"> 283 </span> : iterator __last1 = end(); -<span class="lineNum"> 284 </span> : iterator __first2 = __x.begin(); -<span class="lineNum"> 285 </span> : iterator __last2 = __x.end(); -<span class="lineNum"> 286 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 287 </span> : if (__comp(*__first2, *__first1)) -<span class="lineNum"> 288 </span> : { -<span class="lineNum"> 289 </span> : iterator __next = __first2; -<span class="lineNum"> 290 </span> : _M_transfer(__first1, __first2, ++__next); -<span class="lineNum"> 291 </span> : __first2 = __next; -<span class="lineNum"> 292 </span> : } -<span class="lineNum"> 293 </span> : else -<span class="lineNum"> 294 </span> : ++__first1; -<span class="lineNum"> 295 </span> : if (__first2 != __last2) -<span class="lineNum"> 296 </span> : _M_transfer(__last1, __first2, __last2); -<span class="lineNum"> 297 </span> : } -<span class="lineNum"> 298 </span> : } -<span class="lineNum"> 299 </span> : -<span class="lineNum"> 300 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 301 </span> : void -<span class="lineNum"> 302 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 303 </span> : sort() -<span class="lineNum"> 304 </span> : { -<span class="lineNum"> 305 </span> : // Do nothing if the list has length 0 or 1. -<span class="lineNum"> 306 </span> : if (this->_M_impl._M_node._M_next != &this->_M_impl._M_node -<span class="lineNum"> 307 </span> : && this->_M_impl._M_node._M_next->_M_next != &this->_M_impl._M_node) -<span class="lineNum"> 308 </span> : { -<span class="lineNum"> 309 </span> : list __carry; -<span class="lineNum"> 310 </span> : list __tmp[64]; -<span class="lineNum"> 311 </span> : list * __fill = &__tmp[0]; -<span class="lineNum"> 312 </span> : list * __counter; -<span class="lineNum"> 313 </span> : -<span class="lineNum"> 314 </span> : do -<span class="lineNum"> 315 </span> : { -<span class="lineNum"> 316 </span> : __carry.splice(__carry.begin(), *this, begin()); -<span class="lineNum"> 317 </span> : -<span class="lineNum"> 318 </span> : for(__counter = &__tmp[0]; -<span class="lineNum"> 319 </span> : __counter != __fill && !__counter->empty(); -<span class="lineNum"> 320 </span> : ++__counter) -<span class="lineNum"> 321 </span> : { -<span class="lineNum"> 322 </span> : __counter->merge(__carry); -<span class="lineNum"> 323 </span> : __carry.swap(*__counter); -<span class="lineNum"> 324 </span> : } -<span class="lineNum"> 325 </span> : __carry.swap(*__counter); -<span class="lineNum"> 326 </span> : if (__counter == __fill) -<span class="lineNum"> 327 </span> : ++__fill; -<span class="lineNum"> 328 </span> : } -<span class="lineNum"> 329 </span> : while ( !empty() ); -<span class="lineNum"> 330 </span> : -<span class="lineNum"> 331 </span> : for (__counter = &__tmp[1]; __counter != __fill; ++__counter) -<span class="lineNum"> 332 </span> : __counter->merge(*(__counter - 1)); -<span class="lineNum"> 333 </span> : swap( *(__fill - 1) ); -<span class="lineNum"> 334 </span> : } -<span class="lineNum"> 335 </span> : } -<span class="lineNum"> 336 </span> : -<span class="lineNum"> 337 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 338 </span> : template <typename _Predicate> -<span class="lineNum"> 339 </span> : void -<span class="lineNum"> 340 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 341 </span> : remove_if(_Predicate __pred) -<span class="lineNum"> 342 </span> : { -<span class="lineNum"> 343 </span> : iterator __first = begin(); -<span class="lineNum"> 344 </span> : iterator __last = end(); -<span class="lineNum"> 345 </span> : while (__first != __last) -<span class="lineNum"> 346 </span> : { -<span class="lineNum"> 347 </span> : iterator __next = __first; -<span class="lineNum"> 348 </span> : ++__next; -<span class="lineNum"> 349 </span> : if (__pred(*__first)) -<span class="lineNum"> 350 </span> : _M_erase(__first); -<span class="lineNum"> 351 </span> : __first = __next; -<span class="lineNum"> 352 </span> : } -<span class="lineNum"> 353 </span> : } -<span class="lineNum"> 354 </span> : -<span class="lineNum"> 355 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 356 </span> : template <typename _BinaryPredicate> -<span class="lineNum"> 357 </span> : void -<span class="lineNum"> 358 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 359 </span> : unique(_BinaryPredicate __binary_pred) -<span class="lineNum"> 360 </span> : { -<span class="lineNum"> 361 </span> : iterator __first = begin(); -<span class="lineNum"> 362 </span> : iterator __last = end(); -<span class="lineNum"> 363 </span> : if (__first == __last) -<span class="lineNum"> 364 </span> : return; -<span class="lineNum"> 365 </span> : iterator __next = __first; -<span class="lineNum"> 366 </span> : while (++__next != __last) -<span class="lineNum"> 367 </span> : { -<span class="lineNum"> 368 </span> : if (__binary_pred(*__first, *__next)) -<span class="lineNum"> 369 </span> : _M_erase(__next); -<span class="lineNum"> 370 </span> : else -<span class="lineNum"> 371 </span> : __first = __next; -<span class="lineNum"> 372 </span> : __next = __first; -<span class="lineNum"> 373 </span> : } -<span class="lineNum"> 374 </span> : } -<span class="lineNum"> 375 </span> : -<span class="lineNum"> 376 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 377 </span> : template <typename _StrictWeakOrdering> -<span class="lineNum"> 378 </span> : void -<span class="lineNum"> 379 </span> : list<_Tp, _Alloc>:: -<span class="lineNum"> 380 </span> : sort(_StrictWeakOrdering __comp) -<span class="lineNum"> 381 </span> : { -<span class="lineNum"> 382 </span> : // Do nothing if the list has length 0 or 1. -<span class="lineNum"> 383 </span> : if (this->_M_impl._M_node._M_next != &this->_M_impl._M_node -<span class="lineNum"> 384 </span> : && this->_M_impl._M_node._M_next->_M_next != &this->_M_impl._M_node) -<span class="lineNum"> 385 </span> : { -<span class="lineNum"> 386 </span> : list __carry; -<span class="lineNum"> 387 </span> : list __tmp[64]; -<span class="lineNum"> 388 </span> : list * __fill = &__tmp[0]; -<span class="lineNum"> 389 </span> : list * __counter; -<span class="lineNum"> 390 </span> : -<span class="lineNum"> 391 </span> : do -<span class="lineNum"> 392 </span> : { -<span class="lineNum"> 393 </span> : __carry.splice(__carry.begin(), *this, begin()); -<span class="lineNum"> 394 </span> : -<span class="lineNum"> 395 </span> : for(__counter = &__tmp[0]; -<span class="lineNum"> 396 </span> : __counter != __fill && !__counter->empty(); -<span class="lineNum"> 397 </span> : ++__counter) -<span class="lineNum"> 398 </span> : { -<span class="lineNum"> 399 </span> : __counter->merge(__carry, __comp); -<span class="lineNum"> 400 </span> : __carry.swap(*__counter); -<span class="lineNum"> 401 </span> : } -<span class="lineNum"> 402 </span> : __carry.swap(*__counter); -<span class="lineNum"> 403 </span> : if (__counter == __fill) -<span class="lineNum"> 404 </span> : ++__fill; -<span class="lineNum"> 405 </span> : } -<span class="lineNum"> 406 </span> : while ( !empty() ); -<span class="lineNum"> 407 </span> : -<span class="lineNum"> 408 </span> : for (__counter = &__tmp[1]; __counter != __fill; ++__counter) -<span class="lineNum"> 409 </span> : __counter->merge(*(__counter - 1), __comp); -<span class="lineNum"> 410 </span> : swap(*(__fill - 1)); -<span class="lineNum"> 411 </span> : } -<span class="lineNum"> 412 </span> : } -<span class="lineNum"> 413 </span> : -<span class="lineNum"> 414 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span> : #endif /* _LIST_TCC */ -<span class="lineNum"> 417 </span> : -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/locale_facets.h.gcov.html b/rep/usr/include/c++/4.3/bits/locale_facets.h.gcov.html deleted file mode 100644 index d54e58e..0000000 --- a/rep/usr/include/c++/4.3/bits/locale_facets.h.gcov.html +++ /dev/null @@ -1,2705 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/locale_facets.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - locale_facets.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">13</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">0.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">0</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Locale support -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file locale_facets.h -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : // -<span class="lineNum"> 38 </span> : // ISO C++ 14882: 22.1 Locales -<span class="lineNum"> 39 </span> : // -<span class="lineNum"> 40 </span> : -<span class="lineNum"> 41 </span> : #ifndef _LOCALE_FACETS_H -<span class="lineNum"> 42 </span> : #define _LOCALE_FACETS_H 1 -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : #pragma GCC system_header -<span class="lineNum"> 45 </span> : -<span class="lineNum"> 46 </span> : #include <cwctype> // For wctype_t -<span class="lineNum"> 47 </span> : #include <cctype> -<span class="lineNum"> 48 </span> : #include <bits/ctype_base.h> -<span class="lineNum"> 49 </span> : #include <iosfwd> -<span class="lineNum"> 50 </span> : #include <bits/ios_base.h> // For ios_base, ios_base::iostate -<span class="lineNum"> 51 </span> : #include <streambuf> -<span class="lineNum"> 52 </span> : #include <bits/cpp_type_traits.h> -<span class="lineNum"> 53 </span> : #include <ext/type_traits.h> -<span class="lineNum"> 54 </span> : #include <ext/numeric_traits.h> -<span class="lineNum"> 55 </span> : #include <bits/streambuf_iterator.h> -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 58 </span> : -<span class="lineNum"> 59 </span> : // NB: Don't instantiate required wchar_t facets if no wchar_t support. -<span class="lineNum"> 60 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 61 </span> : # define _GLIBCXX_NUM_FACETS 28 -<span class="lineNum"> 62 </span> : #else -<span class="lineNum"> 63 </span> : # define _GLIBCXX_NUM_FACETS 14 -<span class="lineNum"> 64 </span> : #endif -<span class="lineNum"> 65 </span> : -<span class="lineNum"> 66 </span> : // Convert string to numeric value of type _Tv and store results. -<span class="lineNum"> 67 </span> : // NB: This is specialized for all required types, there is no -<span class="lineNum"> 68 </span> : // generic definition. -<span class="lineNum"> 69 </span> : template<typename _Tv> -<span class="lineNum"> 70 </span> : void -<span class="lineNum"> 71 </span> : __convert_to_v(const char* __in, _Tv& __out, ios_base::iostate& __err, -<span class="lineNum"> 72 </span> : const __c_locale& __cloc); -<span class="lineNum"> 73 </span> : -<span class="lineNum"> 74 </span> : // Explicit specializations for required types. -<span class="lineNum"> 75 </span> : template<> -<span class="lineNum"> 76 </span> : void -<span class="lineNum"> 77 </span> : __convert_to_v(const char*, float&, ios_base::iostate&, -<span class="lineNum"> 78 </span> : const __c_locale&); -<span class="lineNum"> 79 </span> : -<span class="lineNum"> 80 </span> : template<> -<span class="lineNum"> 81 </span> : void -<span class="lineNum"> 82 </span> : __convert_to_v(const char*, double&, ios_base::iostate&, -<span class="lineNum"> 83 </span> : const __c_locale&); -<span class="lineNum"> 84 </span> : -<span class="lineNum"> 85 </span> : template<> -<span class="lineNum"> 86 </span> : void -<span class="lineNum"> 87 </span> : __convert_to_v(const char*, long double&, ios_base::iostate&, -<span class="lineNum"> 88 </span> : const __c_locale&); -<span class="lineNum"> 89 </span> : -<span class="lineNum"> 90 </span> : // NB: __pad is a struct, rather than a function, so it can be -<span class="lineNum"> 91 </span> : // partially-specialized. -<span class="lineNum"> 92 </span> : template<typename _CharT, typename _Traits> -<span class="lineNum"> 93 </span> : struct __pad -<span class="lineNum"> 94 </span> : { -<span class="lineNum"> 95 </span> : static void -<span class="lineNum"> 96 </span> : _S_pad(ios_base& __io, _CharT __fill, _CharT* __news, -<span class="lineNum"> 97 </span> : const _CharT* __olds, const streamsize __newlen, -<span class="lineNum"> 98 </span> : const streamsize __oldlen); -<span class="lineNum"> 99 </span> : }; -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : // Used by both numeric and monetary facets. -<span class="lineNum"> 102 </span> : // Inserts "group separator" characters into an array of characters. -<span class="lineNum"> 103 </span> : // It's recursive, one iteration per group. It moves the characters -<span class="lineNum"> 104 </span> : // in the buffer this way: "xxxx12345" -> "12,345xxx". Call this -<span class="lineNum"> 105 </span> : // only with __gsize != 0. -<span class="lineNum"> 106 </span> : template<typename _CharT> -<span class="lineNum"> 107 </span> : _CharT* -<span class="lineNum"> 108 </span> : __add_grouping(_CharT* __s, _CharT __sep, -<span class="lineNum"> 109 </span> : const char* __gbeg, size_t __gsize, -<span class="lineNum"> 110 </span> : const _CharT* __first, const _CharT* __last); -<span class="lineNum"> 111 </span> : -<span class="lineNum"> 112 </span> : // This template permits specializing facet output code for -<span class="lineNum"> 113 </span> : // ostreambuf_iterator. For ostreambuf_iterator, sputn is -<span class="lineNum"> 114 </span> : // significantly more efficient than incrementing iterators. -<span class="lineNum"> 115 </span> : template<typename _CharT> -<span class="lineNum"> 116 </span> : inline -<span class="lineNum"> 117 </span> : ostreambuf_iterator<_CharT> -<span class="lineNum"> 118 </span> : __write(ostreambuf_iterator<_CharT> __s, const _CharT* __ws, int __len) -<span class="lineNum"> 119 </span> : { -<span class="lineNum"> 120 </span> : __s._M_put(__ws, __len); -<span class="lineNum"> 121 </span> : return __s; -<span class="lineNum"> 122 </span> : } -<span class="lineNum"> 123 </span> : -<span class="lineNum"> 124 </span> : // This is the unspecialized form of the template. -<span class="lineNum"> 125 </span> : template<typename _CharT, typename _OutIter> -<span class="lineNum"> 126 </span> : inline -<span class="lineNum"> 127 </span> : _OutIter -<span class="lineNum"> 128 </span> : __write(_OutIter __s, const _CharT* __ws, int __len) -<span class="lineNum"> 129 </span> : { -<span class="lineNum"> 130 </span> : for (int __j = 0; __j < __len; __j++, ++__s) -<span class="lineNum"> 131 </span> : *__s = __ws[__j]; -<span class="lineNum"> 132 </span> : return __s; -<span class="lineNum"> 133 </span> : } -<span class="lineNum"> 134 </span> : -<span class="lineNum"> 135 </span> : -<span class="lineNum"> 136 </span> : // 22.2.1.1 Template class ctype -<span class="lineNum"> 137 </span> : // Include host and configuration specific ctype enums for ctype_base. -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : // Common base for ctype<_CharT>. -<span class="lineNum"> 140 </span> : /** -<span class="lineNum"> 141 </span> : * @brief Common base for ctype facet -<span class="lineNum"> 142 </span> : * -<span class="lineNum"> 143 </span> : * This template class provides implementations of the public functions -<span class="lineNum"> 144 </span> : * that forward to the protected virtual functions. -<span class="lineNum"> 145 </span> : * -<span class="lineNum"> 146 </span> : * This template also provides abstract stubs for the protected virtual -<span class="lineNum"> 147 </span> : * functions. -<span class="lineNum"> 148 </span> : */ -<span class="lineNum"> 149 </span> : template<typename _CharT> -<span class="lineNum"> 150 </span> : class __ctype_abstract_base : public locale::facet, public ctype_base -<span class="lineNum"> 151 </span> : { -<span class="lineNum"> 152 </span> : public: -<span class="lineNum"> 153 </span> : // Types: -<span class="lineNum"> 154 </span> : /// Typedef for the template parameter -<span class="lineNum"> 155 </span> : typedef _CharT char_type; -<span class="lineNum"> 156 </span> : -<span class="lineNum"> 157 </span> : /** -<span class="lineNum"> 158 </span> : * @brief Test char_type classification. -<span class="lineNum"> 159 </span> : * -<span class="lineNum"> 160 </span> : * This function finds a mask M for @a c and compares it to mask @a m. -<span class="lineNum"> 161 </span> : * It does so by returning the value of ctype<char_type>::do_is(). -<span class="lineNum"> 162 </span> : * -<span class="lineNum"> 163 </span> : * @param c The char_type to compare the mask of. -<span class="lineNum"> 164 </span> : * @param m The mask to compare against. -<span class="lineNum"> 165 </span> : * @return (M & m) != 0. -<span class="lineNum"> 166 </span> : */ -<span class="lineNum"> 167 </span> : bool -<span class="lineNum"> 168 </span> : is(mask __m, char_type __c) const -<span class="lineNum"> 169 </span> : { return this->do_is(__m, __c); } -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : /** -<span class="lineNum"> 172 </span> : * @brief Return a mask array. -<span class="lineNum"> 173 </span> : * -<span class="lineNum"> 174 </span> : * This function finds the mask for each char_type in the range [lo,hi) -<span class="lineNum"> 175 </span> : * and successively writes it to vec. vec must have as many elements -<span class="lineNum"> 176 </span> : * as the char array. It does so by returning the value of -<span class="lineNum"> 177 </span> : * ctype<char_type>::do_is(). -<span class="lineNum"> 178 </span> : * -<span class="lineNum"> 179 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 180 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 181 </span> : * @param vec Pointer to an array of mask storage. -<span class="lineNum"> 182 </span> : * @return @a hi. -<span class="lineNum"> 183 </span> : */ -<span class="lineNum"> 184 </span> : const char_type* -<span class="lineNum"> 185 </span> : is(const char_type *__lo, const char_type *__hi, mask *__vec) const -<span class="lineNum"> 186 </span> : { return this->do_is(__lo, __hi, __vec); } -<span class="lineNum"> 187 </span> : -<span class="lineNum"> 188 </span> : /** -<span class="lineNum"> 189 </span> : * @brief Find char_type matching a mask -<span class="lineNum"> 190 </span> : * -<span class="lineNum"> 191 </span> : * This function searches for and returns the first char_type c in -<span class="lineNum"> 192 </span> : * [lo,hi) for which is(m,c) is true. It does so by returning -<span class="lineNum"> 193 </span> : * ctype<char_type>::do_scan_is(). -<span class="lineNum"> 194 </span> : * -<span class="lineNum"> 195 </span> : * @param m The mask to compare against. -<span class="lineNum"> 196 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 197 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 198 </span> : * @return Pointer to matching char_type if found, else @a hi. -<span class="lineNum"> 199 </span> : */ -<span class="lineNum"> 200 </span> : const char_type* -<span class="lineNum"> 201 </span> : scan_is(mask __m, const char_type* __lo, const char_type* __hi) const -<span class="lineNum"> 202 </span> : { return this->do_scan_is(__m, __lo, __hi); } -<span class="lineNum"> 203 </span> : -<span class="lineNum"> 204 </span> : /** -<span class="lineNum"> 205 </span> : * @brief Find char_type not matching a mask -<span class="lineNum"> 206 </span> : * -<span class="lineNum"> 207 </span> : * This function searches for and returns the first char_type c in -<span class="lineNum"> 208 </span> : * [lo,hi) for which is(m,c) is false. It does so by returning -<span class="lineNum"> 209 </span> : * ctype<char_type>::do_scan_not(). -<span class="lineNum"> 210 </span> : * -<span class="lineNum"> 211 </span> : * @param m The mask to compare against. -<span class="lineNum"> 212 </span> : * @param lo Pointer to first char in range. -<span class="lineNum"> 213 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 214 </span> : * @return Pointer to non-matching char if found, else @a hi. -<span class="lineNum"> 215 </span> : */ -<span class="lineNum"> 216 </span> : const char_type* -<span class="lineNum"> 217 </span> : scan_not(mask __m, const char_type* __lo, const char_type* __hi) const -<span class="lineNum"> 218 </span> : { return this->do_scan_not(__m, __lo, __hi); } -<span class="lineNum"> 219 </span> : -<span class="lineNum"> 220 </span> : /** -<span class="lineNum"> 221 </span> : * @brief Convert to uppercase. -<span class="lineNum"> 222 </span> : * -<span class="lineNum"> 223 </span> : * This function converts the argument to uppercase if possible. -<span class="lineNum"> 224 </span> : * If not possible (for example, '2'), returns the argument. It does -<span class="lineNum"> 225 </span> : * so by returning ctype<char_type>::do_toupper(). -<span class="lineNum"> 226 </span> : * -<span class="lineNum"> 227 </span> : * @param c The char_type to convert. -<span class="lineNum"> 228 </span> : * @return The uppercase char_type if convertible, else @a c. -<span class="lineNum"> 229 </span> : */ -<span class="lineNum"> 230 </span> : char_type -<span class="lineNum"> 231 </span> : toupper(char_type __c) const -<span class="lineNum"> 232 </span> : { return this->do_toupper(__c); } -<span class="lineNum"> 233 </span> : -<span class="lineNum"> 234 </span> : /** -<span class="lineNum"> 235 </span> : * @brief Convert array to uppercase. -<span class="lineNum"> 236 </span> : * -<span class="lineNum"> 237 </span> : * This function converts each char_type in the range [lo,hi) to -<span class="lineNum"> 238 </span> : * uppercase if possible. Other elements remain untouched. It does so -<span class="lineNum"> 239 </span> : * by returning ctype<char_type>:: do_toupper(lo, hi). -<span class="lineNum"> 240 </span> : * -<span class="lineNum"> 241 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 242 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 243 </span> : * @return @a hi. -<span class="lineNum"> 244 </span> : */ -<span class="lineNum"> 245 </span> : const char_type* -<span class="lineNum"> 246 </span> : toupper(char_type *__lo, const char_type* __hi) const -<span class="lineNum"> 247 </span> : { return this->do_toupper(__lo, __hi); } -<span class="lineNum"> 248 </span> : -<span class="lineNum"> 249 </span> : /** -<span class="lineNum"> 250 </span> : * @brief Convert to lowercase. -<span class="lineNum"> 251 </span> : * -<span class="lineNum"> 252 </span> : * This function converts the argument to lowercase if possible. If -<span class="lineNum"> 253 </span> : * not possible (for example, '2'), returns the argument. It does so -<span class="lineNum"> 254 </span> : * by returning ctype<char_type>::do_tolower(c). -<span class="lineNum"> 255 </span> : * -<span class="lineNum"> 256 </span> : * @param c The char_type to convert. -<span class="lineNum"> 257 </span> : * @return The lowercase char_type if convertible, else @a c. -<span class="lineNum"> 258 </span> : */ -<span class="lineNum"> 259 </span> : char_type -<span class="lineNum"> 260 </span> : tolower(char_type __c) const -<span class="lineNum"> 261 </span> : { return this->do_tolower(__c); } -<span class="lineNum"> 262 </span> : -<span class="lineNum"> 263 </span> : /** -<span class="lineNum"> 264 </span> : * @brief Convert array to lowercase. -<span class="lineNum"> 265 </span> : * -<span class="lineNum"> 266 </span> : * This function converts each char_type in the range [lo,hi) to -<span class="lineNum"> 267 </span> : * lowercase if possible. Other elements remain untouched. It does so -<span class="lineNum"> 268 </span> : * by returning ctype<char_type>:: do_tolower(lo, hi). -<span class="lineNum"> 269 </span> : * -<span class="lineNum"> 270 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 271 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 272 </span> : * @return @a hi. -<span class="lineNum"> 273 </span> : */ -<span class="lineNum"> 274 </span> : const char_type* -<span class="lineNum"> 275 </span> : tolower(char_type* __lo, const char_type* __hi) const -<span class="lineNum"> 276 </span> : { return this->do_tolower(__lo, __hi); } -<span class="lineNum"> 277 </span> : -<span class="lineNum"> 278 </span> : /** -<span class="lineNum"> 279 </span> : * @brief Widen char to char_type -<span class="lineNum"> 280 </span> : * -<span class="lineNum"> 281 </span> : * This function converts the char argument to char_type using the -<span class="lineNum"> 282 </span> : * simplest reasonable transformation. It does so by returning -<span class="lineNum"> 283 </span> : * ctype<char_type>::do_widen(c). -<span class="lineNum"> 284 </span> : * -<span class="lineNum"> 285 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 286 </span> : * codecvt for that. -<span class="lineNum"> 287 </span> : * -<span class="lineNum"> 288 </span> : * @param c The char to convert. -<span class="lineNum"> 289 </span> : * @return The converted char_type. -<span class="lineNum"> 290 </span> : */ -<span class="lineNum"> 291 </span> : char_type -<span class="lineNum"> 292 </span> : widen(char __c) const -<span class="lineNum"> 293 </span> : { return this->do_widen(__c); } -<span class="lineNum"> 294 </span> : -<span class="lineNum"> 295 </span> : /** -<span class="lineNum"> 296 </span> : * @brief Widen array to char_type -<span class="lineNum"> 297 </span> : * -<span class="lineNum"> 298 </span> : * This function converts each char in the input to char_type using the -<span class="lineNum"> 299 </span> : * simplest reasonable transformation. It does so by returning -<span class="lineNum"> 300 </span> : * ctype<char_type>::do_widen(c). -<span class="lineNum"> 301 </span> : * -<span class="lineNum"> 302 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 303 </span> : * codecvt for that. -<span class="lineNum"> 304 </span> : * -<span class="lineNum"> 305 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 306 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 307 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 308 </span> : * @return @a hi. -<span class="lineNum"> 309 </span> : */ -<span class="lineNum"> 310 </span> : const char* -<span class="lineNum"> 311 </span> : widen(const char* __lo, const char* __hi, char_type* __to) const -<span class="lineNum"> 312 </span> : { return this->do_widen(__lo, __hi, __to); } -<span class="lineNum"> 313 </span> : -<span class="lineNum"> 314 </span> : /** -<span class="lineNum"> 315 </span> : * @brief Narrow char_type to char -<span class="lineNum"> 316 </span> : * -<span class="lineNum"> 317 </span> : * This function converts the char_type to char using the simplest -<span class="lineNum"> 318 </span> : * reasonable transformation. If the conversion fails, dfault is -<span class="lineNum"> 319 </span> : * returned instead. It does so by returning -<span class="lineNum"> 320 </span> : * ctype<char_type>::do_narrow(c). -<span class="lineNum"> 321 </span> : * -<span class="lineNum"> 322 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 323 </span> : * codecvt for that. -<span class="lineNum"> 324 </span> : * -<span class="lineNum"> 325 </span> : * @param c The char_type to convert. -<span class="lineNum"> 326 </span> : * @param dfault Char to return if conversion fails. -<span class="lineNum"> 327 </span> : * @return The converted char. -<span class="lineNum"> 328 </span> : */ -<span class="lineNum"> 329 </span> : char -<span class="lineNum"> 330 </span> : narrow(char_type __c, char __dfault) const -<span class="lineNum"> 331 </span> : { return this->do_narrow(__c, __dfault); } -<span class="lineNum"> 332 </span> : -<span class="lineNum"> 333 </span> : /** -<span class="lineNum"> 334 </span> : * @brief Narrow array to char array -<span class="lineNum"> 335 </span> : * -<span class="lineNum"> 336 </span> : * This function converts each char_type in the input to char using the -<span class="lineNum"> 337 </span> : * simplest reasonable transformation and writes the results to the -<span class="lineNum"> 338 </span> : * destination array. For any char_type in the input that cannot be -<span class="lineNum"> 339 </span> : * converted, @a dfault is used instead. It does so by returning -<span class="lineNum"> 340 </span> : * ctype<char_type>::do_narrow(lo, hi, dfault, to). -<span class="lineNum"> 341 </span> : * -<span class="lineNum"> 342 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 343 </span> : * codecvt for that. -<span class="lineNum"> 344 </span> : * -<span class="lineNum"> 345 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 346 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 347 </span> : * @param dfault Char to use if conversion fails. -<span class="lineNum"> 348 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 349 </span> : * @return @a hi. -<span class="lineNum"> 350 </span> : */ -<span class="lineNum"> 351 </span> : const char_type* -<span class="lineNum"> 352 </span> : narrow(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 353 </span> : char __dfault, char *__to) const -<span class="lineNum"> 354 </span> : { return this->do_narrow(__lo, __hi, __dfault, __to); } -<span class="lineNum"> 355 </span> : -<span class="lineNum"> 356 </span> : protected: -<span class="lineNum"> 357 </span> : explicit -<span class="lineNum"> 358 </span> : __ctype_abstract_base(size_t __refs = 0): facet(__refs) { } -<span class="lineNum"> 359 </span> : -<span class="lineNum"> 360 </span> : virtual -<span class="lineNum"> 361 </span> : ~__ctype_abstract_base() { } -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : /** -<span class="lineNum"> 364 </span> : * @brief Test char_type classification. -<span class="lineNum"> 365 </span> : * -<span class="lineNum"> 366 </span> : * This function finds a mask M for @a c and compares it to mask @a m. -<span class="lineNum"> 367 </span> : * -<span class="lineNum"> 368 </span> : * do_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 369 </span> : * classifying. do_is() must always return the same result for the -<span class="lineNum"> 370 </span> : * same input. -<span class="lineNum"> 371 </span> : * -<span class="lineNum"> 372 </span> : * @param c The char_type to find the mask of. -<span class="lineNum"> 373 </span> : * @param m The mask to compare against. -<span class="lineNum"> 374 </span> : * @return (M & m) != 0. -<span class="lineNum"> 375 </span> : */ -<span class="lineNum"> 376 </span> : virtual bool -<span class="lineNum"> 377 </span> : do_is(mask __m, char_type __c) const = 0; -<span class="lineNum"> 378 </span> : -<span class="lineNum"> 379 </span> : /** -<span class="lineNum"> 380 </span> : * @brief Return a mask array. -<span class="lineNum"> 381 </span> : * -<span class="lineNum"> 382 </span> : * This function finds the mask for each char_type in the range [lo,hi) -<span class="lineNum"> 383 </span> : * and successively writes it to vec. vec must have as many elements -<span class="lineNum"> 384 </span> : * as the input. -<span class="lineNum"> 385 </span> : * -<span class="lineNum"> 386 </span> : * do_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 387 </span> : * classifying. do_is() must always return the same result for the -<span class="lineNum"> 388 </span> : * same input. -<span class="lineNum"> 389 </span> : * -<span class="lineNum"> 390 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 391 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 392 </span> : * @param vec Pointer to an array of mask storage. -<span class="lineNum"> 393 </span> : * @return @a hi. -<span class="lineNum"> 394 </span> : */ -<span class="lineNum"> 395 </span> : virtual const char_type* -<span class="lineNum"> 396 </span> : do_is(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 397 </span> : mask* __vec) const = 0; -<span class="lineNum"> 398 </span> : -<span class="lineNum"> 399 </span> : /** -<span class="lineNum"> 400 </span> : * @brief Find char_type matching mask -<span class="lineNum"> 401 </span> : * -<span class="lineNum"> 402 </span> : * This function searches for and returns the first char_type c in -<span class="lineNum"> 403 </span> : * [lo,hi) for which is(m,c) is true. -<span class="lineNum"> 404 </span> : * -<span class="lineNum"> 405 </span> : * do_scan_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 406 </span> : * match searching. do_is() must always return the same result for the -<span class="lineNum"> 407 </span> : * same input. -<span class="lineNum"> 408 </span> : * -<span class="lineNum"> 409 </span> : * @param m The mask to compare against. -<span class="lineNum"> 410 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 411 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 412 </span> : * @return Pointer to a matching char_type if found, else @a hi. -<span class="lineNum"> 413 </span> : */ -<span class="lineNum"> 414 </span> : virtual const char_type* -<span class="lineNum"> 415 </span> : do_scan_is(mask __m, const char_type* __lo, -<span class="lineNum"> 416 </span> : const char_type* __hi) const = 0; -<span class="lineNum"> 417 </span> : -<span class="lineNum"> 418 </span> : /** -<span class="lineNum"> 419 </span> : * @brief Find char_type not matching mask -<span class="lineNum"> 420 </span> : * -<span class="lineNum"> 421 </span> : * This function searches for and returns a pointer to the first -<span class="lineNum"> 422 </span> : * char_type c of [lo,hi) for which is(m,c) is false. -<span class="lineNum"> 423 </span> : * -<span class="lineNum"> 424 </span> : * do_scan_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 425 </span> : * match searching. do_is() must always return the same result for the -<span class="lineNum"> 426 </span> : * same input. -<span class="lineNum"> 427 </span> : * -<span class="lineNum"> 428 </span> : * @param m The mask to compare against. -<span class="lineNum"> 429 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 430 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 431 </span> : * @return Pointer to a non-matching char_type if found, else @a hi. -<span class="lineNum"> 432 </span> : */ -<span class="lineNum"> 433 </span> : virtual const char_type* -<span class="lineNum"> 434 </span> : do_scan_not(mask __m, const char_type* __lo, -<span class="lineNum"> 435 </span> : const char_type* __hi) const = 0; -<span class="lineNum"> 436 </span> : -<span class="lineNum"> 437 </span> : /** -<span class="lineNum"> 438 </span> : * @brief Convert to uppercase. -<span class="lineNum"> 439 </span> : * -<span class="lineNum"> 440 </span> : * This virtual function converts the char_type argument to uppercase -<span class="lineNum"> 441 </span> : * if possible. If not possible (for example, '2'), returns the -<span class="lineNum"> 442 </span> : * argument. -<span class="lineNum"> 443 </span> : * -<span class="lineNum"> 444 </span> : * do_toupper() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 445 </span> : * uppercasing. do_toupper() must always return the same result for -<span class="lineNum"> 446 </span> : * the same input. -<span class="lineNum"> 447 </span> : * -<span class="lineNum"> 448 </span> : * @param c The char_type to convert. -<span class="lineNum"> 449 </span> : * @return The uppercase char_type if convertible, else @a c. -<span class="lineNum"> 450 </span> : */ -<span class="lineNum"> 451 </span> : virtual char_type -<span class="lineNum"> 452 </span> : do_toupper(char_type) const = 0; -<span class="lineNum"> 453 </span> : -<span class="lineNum"> 454 </span> : /** -<span class="lineNum"> 455 </span> : * @brief Convert array to uppercase. -<span class="lineNum"> 456 </span> : * -<span class="lineNum"> 457 </span> : * This virtual function converts each char_type in the range [lo,hi) -<span class="lineNum"> 458 </span> : * to uppercase if possible. Other elements remain untouched. -<span class="lineNum"> 459 </span> : * -<span class="lineNum"> 460 </span> : * do_toupper() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 461 </span> : * uppercasing. do_toupper() must always return the same result for -<span class="lineNum"> 462 </span> : * the same input. -<span class="lineNum"> 463 </span> : * -<span class="lineNum"> 464 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 465 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 466 </span> : * @return @a hi. -<span class="lineNum"> 467 </span> : */ -<span class="lineNum"> 468 </span> : virtual const char_type* -<span class="lineNum"> 469 </span> : do_toupper(char_type* __lo, const char_type* __hi) const = 0; -<span class="lineNum"> 470 </span> : -<span class="lineNum"> 471 </span> : /** -<span class="lineNum"> 472 </span> : * @brief Convert to lowercase. -<span class="lineNum"> 473 </span> : * -<span class="lineNum"> 474 </span> : * This virtual function converts the argument to lowercase if -<span class="lineNum"> 475 </span> : * possible. If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 476 </span> : * -<span class="lineNum"> 477 </span> : * do_tolower() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 478 </span> : * lowercasing. do_tolower() must always return the same result for -<span class="lineNum"> 479 </span> : * the same input. -<span class="lineNum"> 480 </span> : * -<span class="lineNum"> 481 </span> : * @param c The char_type to convert. -<span class="lineNum"> 482 </span> : * @return The lowercase char_type if convertible, else @a c. -<span class="lineNum"> 483 </span> : */ -<span class="lineNum"> 484 </span> : virtual char_type -<span class="lineNum"> 485 </span> : do_tolower(char_type) const = 0; -<span class="lineNum"> 486 </span> : -<span class="lineNum"> 487 </span> : /** -<span class="lineNum"> 488 </span> : * @brief Convert array to lowercase. -<span class="lineNum"> 489 </span> : * -<span class="lineNum"> 490 </span> : * This virtual function converts each char_type in the range [lo,hi) -<span class="lineNum"> 491 </span> : * to lowercase if possible. Other elements remain untouched. -<span class="lineNum"> 492 </span> : * -<span class="lineNum"> 493 </span> : * do_tolower() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 494 </span> : * lowercasing. do_tolower() must always return the same result for -<span class="lineNum"> 495 </span> : * the same input. -<span class="lineNum"> 496 </span> : * -<span class="lineNum"> 497 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 498 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 499 </span> : * @return @a hi. -<span class="lineNum"> 500 </span> : */ -<span class="lineNum"> 501 </span> : virtual const char_type* -<span class="lineNum"> 502 </span> : do_tolower(char_type* __lo, const char_type* __hi) const = 0; -<span class="lineNum"> 503 </span> : -<span class="lineNum"> 504 </span> : /** -<span class="lineNum"> 505 </span> : * @brief Widen char -<span class="lineNum"> 506 </span> : * -<span class="lineNum"> 507 </span> : * This virtual function converts the char to char_type using the -<span class="lineNum"> 508 </span> : * simplest reasonable transformation. -<span class="lineNum"> 509 </span> : * -<span class="lineNum"> 510 </span> : * do_widen() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 511 </span> : * widening. do_widen() must always return the same result for the -<span class="lineNum"> 512 </span> : * same input. -<span class="lineNum"> 513 </span> : * -<span class="lineNum"> 514 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 515 </span> : * codecvt for that. -<span class="lineNum"> 516 </span> : * -<span class="lineNum"> 517 </span> : * @param c The char to convert. -<span class="lineNum"> 518 </span> : * @return The converted char_type -<span class="lineNum"> 519 </span> : */ -<span class="lineNum"> 520 </span> : virtual char_type -<span class="lineNum"> 521 </span> : do_widen(char) const = 0; -<span class="lineNum"> 522 </span> : -<span class="lineNum"> 523 </span> : /** -<span class="lineNum"> 524 </span> : * @brief Widen char array -<span class="lineNum"> 525 </span> : * -<span class="lineNum"> 526 </span> : * This function converts each char in the input to char_type using the -<span class="lineNum"> 527 </span> : * simplest reasonable transformation. -<span class="lineNum"> 528 </span> : * -<span class="lineNum"> 529 </span> : * do_widen() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 530 </span> : * widening. do_widen() must always return the same result for the -<span class="lineNum"> 531 </span> : * same input. -<span class="lineNum"> 532 </span> : * -<span class="lineNum"> 533 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 534 </span> : * codecvt for that. -<span class="lineNum"> 535 </span> : * -<span class="lineNum"> 536 </span> : * @param lo Pointer to start range. -<span class="lineNum"> 537 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 538 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 539 </span> : * @return @a hi. -<span class="lineNum"> 540 </span> : */ -<span class="lineNum"> 541 </span> : virtual const char* -<span class="lineNum"> 542 </span> : do_widen(const char* __lo, const char* __hi, -<span class="lineNum"> 543 </span> : char_type* __dest) const = 0; -<span class="lineNum"> 544 </span> : -<span class="lineNum"> 545 </span> : /** -<span class="lineNum"> 546 </span> : * @brief Narrow char_type to char -<span class="lineNum"> 547 </span> : * -<span class="lineNum"> 548 </span> : * This virtual function converts the argument to char using the -<span class="lineNum"> 549 </span> : * simplest reasonable transformation. If the conversion fails, dfault -<span class="lineNum"> 550 </span> : * is returned instead. -<span class="lineNum"> 551 </span> : * -<span class="lineNum"> 552 </span> : * do_narrow() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 553 </span> : * narrowing. do_narrow() must always return the same result for the -<span class="lineNum"> 554 </span> : * same input. -<span class="lineNum"> 555 </span> : * -<span class="lineNum"> 556 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 557 </span> : * codecvt for that. -<span class="lineNum"> 558 </span> : * -<span class="lineNum"> 559 </span> : * @param c The char_type to convert. -<span class="lineNum"> 560 </span> : * @param dfault Char to return if conversion fails. -<span class="lineNum"> 561 </span> : * @return The converted char. -<span class="lineNum"> 562 </span> : */ -<span class="lineNum"> 563 </span> : virtual char -<span class="lineNum"> 564 </span> : do_narrow(char_type, char __dfault) const = 0; -<span class="lineNum"> 565 </span> : -<span class="lineNum"> 566 </span> : /** -<span class="lineNum"> 567 </span> : * @brief Narrow char_type array to char -<span class="lineNum"> 568 </span> : * -<span class="lineNum"> 569 </span> : * This virtual function converts each char_type in the range [lo,hi) to -<span class="lineNum"> 570 </span> : * char using the simplest reasonable transformation and writes the -<span class="lineNum"> 571 </span> : * results to the destination array. For any element in the input that -<span class="lineNum"> 572 </span> : * cannot be converted, @a dfault is used instead. -<span class="lineNum"> 573 </span> : * -<span class="lineNum"> 574 </span> : * do_narrow() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 575 </span> : * narrowing. do_narrow() must always return the same result for the -<span class="lineNum"> 576 </span> : * same input. -<span class="lineNum"> 577 </span> : * -<span class="lineNum"> 578 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 579 </span> : * codecvt for that. -<span class="lineNum"> 580 </span> : * -<span class="lineNum"> 581 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 582 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 583 </span> : * @param dfault Char to use if conversion fails. -<span class="lineNum"> 584 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 585 </span> : * @return @a hi. -<span class="lineNum"> 586 </span> : */ -<span class="lineNum"> 587 </span> : virtual const char_type* -<span class="lineNum"> 588 </span> : do_narrow(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 589 </span> : char __dfault, char* __dest) const = 0; -<span class="lineNum"> 590 </span> : }; -<span class="lineNum"> 591 </span> : -<span class="lineNum"> 592 </span> : // NB: Generic, mostly useless implementation. -<span class="lineNum"> 593 </span> : /** -<span class="lineNum"> 594 </span> : * @brief Template ctype facet -<span class="lineNum"> 595 </span> : * -<span class="lineNum"> 596 </span> : * This template class defines classification and conversion functions for -<span class="lineNum"> 597 </span> : * character sets. It wraps <cctype> functionality. Ctype gets used by -<span class="lineNum"> 598 </span> : * streams for many I/O operations. -<span class="lineNum"> 599 </span> : * -<span class="lineNum"> 600 </span> : * This template provides the protected virtual functions the developer -<span class="lineNum"> 601 </span> : * will have to replace in a derived class or specialization to make a -<span class="lineNum"> 602 </span> : * working facet. The public functions that access them are defined in -<span class="lineNum"> 603 </span> : * __ctype_abstract_base, to allow for implementation flexibility. See -<span class="lineNum"> 604 </span> : * ctype<wchar_t> for an example. The functions are documented in -<span class="lineNum"> 605 </span> : * __ctype_abstract_base. -<span class="lineNum"> 606 </span> : * -<span class="lineNum"> 607 </span> : * Note: implementations are provided for all the protected virtual -<span class="lineNum"> 608 </span> : * functions, but will likely not be useful. -<span class="lineNum"> 609 </span> : */ -<span class="lineNum"> 610 </span> : template<typename _CharT> -<span class="lineNum"> 611 </span> : class ctype : public __ctype_abstract_base<_CharT> -<span class="lineNum"> 612 </span> : { -<span class="lineNum"> 613 </span> : public: -<span class="lineNum"> 614 </span> : // Types: -<span class="lineNum"> 615 </span> : typedef _CharT char_type; -<span class="lineNum"> 616 </span> : typedef typename __ctype_abstract_base<_CharT>::mask mask; -<span class="lineNum"> 617 </span> : -<span class="lineNum"> 618 </span> : /// The facet id for ctype<char_type> -<span class="lineNum"> 619 </span> : static locale::id id; -<span class="lineNum"> 620 </span> : -<span class="lineNum"> 621 </span> : explicit -<span class="lineNum"> 622 </span> : ctype(size_t __refs = 0) : __ctype_abstract_base<_CharT>(__refs) { } -<span class="lineNum"> 623 </span> : -<span class="lineNum"> 624 </span> : protected: -<span class="lineNum"> 625 </span> : virtual -<span class="lineNum"> 626 </span> : ~ctype(); -<span class="lineNum"> 627 </span> : -<span class="lineNum"> 628 </span> : virtual bool -<span class="lineNum"> 629 </span> : do_is(mask __m, char_type __c) const; -<span class="lineNum"> 630 </span> : -<span class="lineNum"> 631 </span> : virtual const char_type* -<span class="lineNum"> 632 </span> : do_is(const char_type* __lo, const char_type* __hi, mask* __vec) const; -<span class="lineNum"> 633 </span> : -<span class="lineNum"> 634 </span> : virtual const char_type* -<span class="lineNum"> 635 </span> : do_scan_is(mask __m, const char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 636 </span> : -<span class="lineNum"> 637 </span> : virtual const char_type* -<span class="lineNum"> 638 </span> : do_scan_not(mask __m, const char_type* __lo, -<span class="lineNum"> 639 </span> : const char_type* __hi) const; -<span class="lineNum"> 640 </span> : -<span class="lineNum"> 641 </span> : virtual char_type -<span class="lineNum"> 642 </span> : do_toupper(char_type __c) const; -<span class="lineNum"> 643 </span> : -<span class="lineNum"> 644 </span> : virtual const char_type* -<span class="lineNum"> 645 </span> : do_toupper(char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 646 </span> : -<span class="lineNum"> 647 </span> : virtual char_type -<span class="lineNum"> 648 </span> : do_tolower(char_type __c) const; -<span class="lineNum"> 649 </span> : -<span class="lineNum"> 650 </span> : virtual const char_type* -<span class="lineNum"> 651 </span> : do_tolower(char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 652 </span> : -<span class="lineNum"> 653 </span> : virtual char_type -<span class="lineNum"> 654 </span> : do_widen(char __c) const; -<span class="lineNum"> 655 </span> : -<span class="lineNum"> 656 </span> : virtual const char* -<span class="lineNum"> 657 </span> : do_widen(const char* __lo, const char* __hi, char_type* __dest) const; -<span class="lineNum"> 658 </span> : -<span class="lineNum"> 659 </span> : virtual char -<span class="lineNum"> 660 </span> : do_narrow(char_type, char __dfault) const; -<span class="lineNum"> 661 </span> : -<span class="lineNum"> 662 </span> : virtual const char_type* -<span class="lineNum"> 663 </span> : do_narrow(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 664 </span> : char __dfault, char* __dest) const; -<span class="lineNum"> 665 </span> : }; -<span class="lineNum"> 666 </span> : -<span class="lineNum"> 667 </span> : template<typename _CharT> -<span class="lineNum"> 668 </span> : locale::id ctype<_CharT>::id; -<span class="lineNum"> 669 </span> : -<span class="lineNum"> 670 </span> : // 22.2.1.3 ctype<char> specialization. -<span class="lineNum"> 671 </span> : /** -<span class="lineNum"> 672 </span> : * @brief The ctype<char> specialization. -<span class="lineNum"> 673 </span> : * -<span class="lineNum"> 674 </span> : * This class defines classification and conversion functions for -<span class="lineNum"> 675 </span> : * the char type. It gets used by char streams for many I/O -<span class="lineNum"> 676 </span> : * operations. The char specialization provides a number of -<span class="lineNum"> 677 </span> : * optimizations as well. -<span class="lineNum"> 678 </span> : */ -<span class="lineNum"> 679 </span> : template<> -<span class="lineNum"> 680 </span> : class ctype<char> : public locale::facet, public ctype_base -<span class="lineNum"> 681 </span> : { -<span class="lineNum"> 682 </span> : public: -<span class="lineNum"> 683 </span> : // Types: -<span class="lineNum"> 684 </span> : /// Typedef for the template parameter char. -<span class="lineNum"> 685 </span> : typedef char char_type; -<span class="lineNum"> 686 </span> : -<span class="lineNum"> 687 </span> : protected: -<span class="lineNum"> 688 </span> : // Data Members: -<span class="lineNum"> 689 </span> : __c_locale _M_c_locale_ctype; -<span class="lineNum"> 690 </span> : bool _M_del; -<span class="lineNum"> 691 </span> : __to_type _M_toupper; -<span class="lineNum"> 692 </span> : __to_type _M_tolower; -<span class="lineNum"> 693 </span> : const mask* _M_table; -<span class="lineNum"> 694 </span> : mutable char _M_widen_ok; -<span class="lineNum"> 695 </span> : mutable char _M_widen[1 + static_cast<unsigned char>(-1)]; -<span class="lineNum"> 696 </span> : mutable char _M_narrow[1 + static_cast<unsigned char>(-1)]; -<span class="lineNum"> 697 </span> : mutable char _M_narrow_ok; // 0 uninitialized, 1 init, -<span class="lineNum"> 698 </span> : // 2 memcpy can't be used -<span class="lineNum"> 699 </span> : -<span class="lineNum"> 700 </span> : public: -<span class="lineNum"> 701 </span> : /// The facet id for ctype<char> -<span class="lineNum"> 702 </span> : static locale::id id; -<span class="lineNum"> 703 </span> : /// The size of the mask table. It is SCHAR_MAX + 1. -<span class="lineNum"> 704 </span> : static const size_t table_size = 1 + static_cast<unsigned char>(-1); -<span class="lineNum"> 705 </span> : -<span class="lineNum"> 706 </span> : /** -<span class="lineNum"> 707 </span> : * @brief Constructor performs initialization. -<span class="lineNum"> 708 </span> : * -<span class="lineNum"> 709 </span> : * This is the constructor provided by the standard. -<span class="lineNum"> 710 </span> : * -<span class="lineNum"> 711 </span> : * @param table If non-zero, table is used as the per-char mask. -<span class="lineNum"> 712 </span> : * Else classic_table() is used. -<span class="lineNum"> 713 </span> : * @param del If true, passes ownership of table to this facet. -<span class="lineNum"> 714 </span> : * @param refs Passed to the base facet class. -<span class="lineNum"> 715 </span> : */ -<span class="lineNum"> 716 </span> : explicit -<span class="lineNum"> 717 </span> : ctype(const mask* __table = 0, bool __del = false, size_t __refs = 0); -<span class="lineNum"> 718 </span> : -<span class="lineNum"> 719 </span> : /** -<span class="lineNum"> 720 </span> : * @brief Constructor performs static initialization. -<span class="lineNum"> 721 </span> : * -<span class="lineNum"> 722 </span> : * This constructor is used to construct the initial C locale facet. -<span class="lineNum"> 723 </span> : * -<span class="lineNum"> 724 </span> : * @param cloc Handle to C locale data. -<span class="lineNum"> 725 </span> : * @param table If non-zero, table is used as the per-char mask. -<span class="lineNum"> 726 </span> : * @param del If true, passes ownership of table to this facet. -<span class="lineNum"> 727 </span> : * @param refs Passed to the base facet class. -<span class="lineNum"> 728 </span> : */ -<span class="lineNum"> 729 </span> : explicit -<span class="lineNum"> 730 </span> : ctype(__c_locale __cloc, const mask* __table = 0, bool __del = false, -<span class="lineNum"> 731 </span> : size_t __refs = 0); -<span class="lineNum"> 732 </span> : -<span class="lineNum"> 733 </span> : /** -<span class="lineNum"> 734 </span> : * @brief Test char classification. -<span class="lineNum"> 735 </span> : * -<span class="lineNum"> 736 </span> : * This function compares the mask table[c] to @a m. -<span class="lineNum"> 737 </span> : * -<span class="lineNum"> 738 </span> : * @param c The char to compare the mask of. -<span class="lineNum"> 739 </span> : * @param m The mask to compare against. -<span class="lineNum"> 740 </span> : * @return True if m & table[c] is true, false otherwise. -<span class="lineNum"> 741 </span> : */ -<span class="lineNum"> 742 </span> : inline bool -<span class="lineNum"> 743 </span> : is(mask __m, char __c) const; -<span class="lineNum"> 744 </span> : -<span class="lineNum"> 745 </span> : /** -<span class="lineNum"> 746 </span> : * @brief Return a mask array. -<span class="lineNum"> 747 </span> : * -<span class="lineNum"> 748 </span> : * This function finds the mask for each char in the range [lo, hi) and -<span class="lineNum"> 749 </span> : * successively writes it to vec. vec must have as many elements as -<span class="lineNum"> 750 </span> : * the char array. -<span class="lineNum"> 751 </span> : * -<span class="lineNum"> 752 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 753 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 754 </span> : * @param vec Pointer to an array of mask storage. -<span class="lineNum"> 755 </span> : * @return @a hi. -<span class="lineNum"> 756 </span> : */ -<span class="lineNum"> 757 </span> : inline const char* -<span class="lineNum"> 758 </span> : is(const char* __lo, const char* __hi, mask* __vec) const; -<span class="lineNum"> 759 </span> : -<span class="lineNum"> 760 </span> : /** -<span class="lineNum"> 761 </span> : * @brief Find char matching a mask -<span class="lineNum"> 762 </span> : * -<span class="lineNum"> 763 </span> : * This function searches for and returns the first char in [lo,hi) for -<span class="lineNum"> 764 </span> : * which is(m,char) is true. -<span class="lineNum"> 765 </span> : * -<span class="lineNum"> 766 </span> : * @param m The mask to compare against. -<span class="lineNum"> 767 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 768 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 769 </span> : * @return Pointer to a matching char if found, else @a hi. -<span class="lineNum"> 770 </span> : */ -<span class="lineNum"> 771 </span> : inline const char* -<span class="lineNum"> 772 </span> : scan_is(mask __m, const char* __lo, const char* __hi) const; -<span class="lineNum"> 773 </span> : -<span class="lineNum"> 774 </span> : /** -<span class="lineNum"> 775 </span> : * @brief Find char not matching a mask -<span class="lineNum"> 776 </span> : * -<span class="lineNum"> 777 </span> : * This function searches for and returns a pointer to the first char -<span class="lineNum"> 778 </span> : * in [lo,hi) for which is(m,char) is false. -<span class="lineNum"> 779 </span> : * -<span class="lineNum"> 780 </span> : * @param m The mask to compare against. -<span class="lineNum"> 781 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 782 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 783 </span> : * @return Pointer to a non-matching char if found, else @a hi. -<span class="lineNum"> 784 </span> : */ -<span class="lineNum"> 785 </span> : inline const char* -<span class="lineNum"> 786 </span> : scan_not(mask __m, const char* __lo, const char* __hi) const; -<span class="lineNum"> 787 </span> : -<span class="lineNum"> 788 </span> : /** -<span class="lineNum"> 789 </span> : * @brief Convert to uppercase. -<span class="lineNum"> 790 </span> : * -<span class="lineNum"> 791 </span> : * This function converts the char argument to uppercase if possible. -<span class="lineNum"> 792 </span> : * If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 793 </span> : * -<span class="lineNum"> 794 </span> : * toupper() acts as if it returns ctype<char>::do_toupper(c). -<span class="lineNum"> 795 </span> : * do_toupper() must always return the same result for the same input. -<span class="lineNum"> 796 </span> : * -<span class="lineNum"> 797 </span> : * @param c The char to convert. -<span class="lineNum"> 798 </span> : * @return The uppercase char if convertible, else @a c. -<span class="lineNum"> 799 </span> : */ -<span class="lineNum"> 800 </span> : char_type -<span class="lineNum"> 801 </span> : toupper(char_type __c) const -<span class="lineNum"> 802 </span> : { return this->do_toupper(__c); } -<span class="lineNum"> 803 </span> : -<span class="lineNum"> 804 </span> : /** -<span class="lineNum"> 805 </span> : * @brief Convert array to uppercase. -<span class="lineNum"> 806 </span> : * -<span class="lineNum"> 807 </span> : * This function converts each char in the range [lo,hi) to uppercase -<span class="lineNum"> 808 </span> : * if possible. Other chars remain untouched. -<span class="lineNum"> 809 </span> : * -<span class="lineNum"> 810 </span> : * toupper() acts as if it returns ctype<char>:: do_toupper(lo, hi). -<span class="lineNum"> 811 </span> : * do_toupper() must always return the same result for the same input. -<span class="lineNum"> 812 </span> : * -<span class="lineNum"> 813 </span> : * @param lo Pointer to first char in range. -<span class="lineNum"> 814 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 815 </span> : * @return @a hi. -<span class="lineNum"> 816 </span> : */ -<span class="lineNum"> 817 </span> : const char_type* -<span class="lineNum"> 818 </span> : toupper(char_type *__lo, const char_type* __hi) const -<span class="lineNum"> 819 </span> : { return this->do_toupper(__lo, __hi); } -<span class="lineNum"> 820 </span> : -<span class="lineNum"> 821 </span> : /** -<span class="lineNum"> 822 </span> : * @brief Convert to lowercase. -<span class="lineNum"> 823 </span> : * -<span class="lineNum"> 824 </span> : * This function converts the char argument to lowercase if possible. -<span class="lineNum"> 825 </span> : * If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 826 </span> : * -<span class="lineNum"> 827 </span> : * tolower() acts as if it returns ctype<char>::do_tolower(c). -<span class="lineNum"> 828 </span> : * do_tolower() must always return the same result for the same input. -<span class="lineNum"> 829 </span> : * -<span class="lineNum"> 830 </span> : * @param c The char to convert. -<span class="lineNum"> 831 </span> : * @return The lowercase char if convertible, else @a c. -<span class="lineNum"> 832 </span> : */ -<span class="lineNum"> 833 </span> : char_type -<span class="lineNum"> 834 </span> : tolower(char_type __c) const -<span class="lineNum"> 835 </span> : { return this->do_tolower(__c); } -<span class="lineNum"> 836 </span> : -<span class="lineNum"> 837 </span> : /** -<span class="lineNum"> 838 </span> : * @brief Convert array to lowercase. -<span class="lineNum"> 839 </span> : * -<span class="lineNum"> 840 </span> : * This function converts each char in the range [lo,hi) to lowercase -<span class="lineNum"> 841 </span> : * if possible. Other chars remain untouched. -<span class="lineNum"> 842 </span> : * -<span class="lineNum"> 843 </span> : * tolower() acts as if it returns ctype<char>:: do_tolower(lo, hi). -<span class="lineNum"> 844 </span> : * do_tolower() must always return the same result for the same input. -<span class="lineNum"> 845 </span> : * -<span class="lineNum"> 846 </span> : * @param lo Pointer to first char in range. -<span class="lineNum"> 847 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 848 </span> : * @return @a hi. -<span class="lineNum"> 849 </span> : */ -<span class="lineNum"> 850 </span> : const char_type* -<span class="lineNum"> 851 </span> : tolower(char_type* __lo, const char_type* __hi) const -<span class="lineNum"> 852 </span> : { return this->do_tolower(__lo, __hi); } -<span class="lineNum"> 853 </span> : -<span class="lineNum"> 854 </span> : /** -<span class="lineNum"> 855 </span> : * @brief Widen char -<span class="lineNum"> 856 </span> : * -<span class="lineNum"> 857 </span> : * This function converts the char to char_type using the simplest -<span class="lineNum"> 858 </span> : * reasonable transformation. For an underived ctype<char> facet, the -<span class="lineNum"> 859 </span> : * argument will be returned unchanged. -<span class="lineNum"> 860 </span> : * -<span class="lineNum"> 861 </span> : * This function works as if it returns ctype<char>::do_widen(c). -<span class="lineNum"> 862 </span> : * do_widen() must always return the same result for the same input. -<span class="lineNum"> 863 </span> : * -<span class="lineNum"> 864 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 865 </span> : * codecvt for that. -<span class="lineNum"> 866 </span> : * -<span class="lineNum"> 867 </span> : * @param c The char to convert. -<span class="lineNum"> 868 </span> : * @return The converted character. -<span class="lineNum"> 869 </span> : */ -<span class="lineNum"> 870 </span> : char_type -<span class="lineNum"> 871 </span><span class="lineNoCov"> 0 : widen(char __c) const</span> -<span class="lineNum"> 872 </span> : { -<span class="lineNum"> 873 </span><span class="lineNoCov"> 0 : if (_M_widen_ok)</span> -<span class="lineNum"> 874 </span><span class="lineNoCov"> 0 : return _M_widen[static_cast<unsigned char>(__c)];</span> -<span class="lineNum"> 875 </span><span class="lineNoCov"> 0 : this->_M_widen_init();</span> -<span class="lineNum"> 876 </span><span class="lineNoCov"> 0 : return this->do_widen(__c);</span> -<span class="lineNum"> 877 </span> : } -<span class="lineNum"> 878 </span> : -<span class="lineNum"> 879 </span> : /** -<span class="lineNum"> 880 </span> : * @brief Widen char array -<span class="lineNum"> 881 </span> : * -<span class="lineNum"> 882 </span> : * This function converts each char in the input to char using the -<span class="lineNum"> 883 </span> : * simplest reasonable transformation. For an underived ctype<char> -<span class="lineNum"> 884 </span> : * facet, the argument will be copied unchanged. -<span class="lineNum"> 885 </span> : * -<span class="lineNum"> 886 </span> : * This function works as if it returns ctype<char>::do_widen(c). -<span class="lineNum"> 887 </span> : * do_widen() must always return the same result for the same input. -<span class="lineNum"> 888 </span> : * -<span class="lineNum"> 889 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 890 </span> : * codecvt for that. -<span class="lineNum"> 891 </span> : * -<span class="lineNum"> 892 </span> : * @param lo Pointer to first char in range. -<span class="lineNum"> 893 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 894 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 895 </span> : * @return @a hi. -<span class="lineNum"> 896 </span> : */ -<span class="lineNum"> 897 </span> : const char* -<span class="lineNum"> 898 </span> : widen(const char* __lo, const char* __hi, char_type* __to) const -<span class="lineNum"> 899 </span> : { -<span class="lineNum"> 900 </span> : if (_M_widen_ok == 1) -<span class="lineNum"> 901 </span> : { -<span class="lineNum"> 902 </span> : __builtin_memcpy(__to, __lo, __hi - __lo); -<span class="lineNum"> 903 </span> : return __hi; -<span class="lineNum"> 904 </span> : } -<span class="lineNum"> 905 </span> : if (!_M_widen_ok) -<span class="lineNum"> 906 </span> : _M_widen_init(); -<span class="lineNum"> 907 </span> : return this->do_widen(__lo, __hi, __to); -<span class="lineNum"> 908 </span> : } -<span class="lineNum"> 909 </span> : -<span class="lineNum"> 910 </span> : /** -<span class="lineNum"> 911 </span> : * @brief Narrow char -<span class="lineNum"> 912 </span> : * -<span class="lineNum"> 913 </span> : * This function converts the char to char using the simplest -<span class="lineNum"> 914 </span> : * reasonable transformation. If the conversion fails, dfault is -<span class="lineNum"> 915 </span> : * returned instead. For an underived ctype<char> facet, @a c -<span class="lineNum"> 916 </span> : * will be returned unchanged. -<span class="lineNum"> 917 </span> : * -<span class="lineNum"> 918 </span> : * This function works as if it returns ctype<char>::do_narrow(c). -<span class="lineNum"> 919 </span> : * do_narrow() must always return the same result for the same input. -<span class="lineNum"> 920 </span> : * -<span class="lineNum"> 921 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 922 </span> : * codecvt for that. -<span class="lineNum"> 923 </span> : * -<span class="lineNum"> 924 </span> : * @param c The char to convert. -<span class="lineNum"> 925 </span> : * @param dfault Char to return if conversion fails. -<span class="lineNum"> 926 </span> : * @return The converted character. -<span class="lineNum"> 927 </span> : */ -<span class="lineNum"> 928 </span> : char -<span class="lineNum"> 929 </span> : narrow(char_type __c, char __dfault) const -<span class="lineNum"> 930 </span> : { -<span class="lineNum"> 931 </span> : if (_M_narrow[static_cast<unsigned char>(__c)]) -<span class="lineNum"> 932 </span> : return _M_narrow[static_cast<unsigned char>(__c)]; -<span class="lineNum"> 933 </span> : const char __t = do_narrow(__c, __dfault); -<span class="lineNum"> 934 </span> : if (__t != __dfault) -<span class="lineNum"> 935 </span> : _M_narrow[static_cast<unsigned char>(__c)] = __t; -<span class="lineNum"> 936 </span> : return __t; -<span class="lineNum"> 937 </span> : } -<span class="lineNum"> 938 </span> : -<span class="lineNum"> 939 </span> : /** -<span class="lineNum"> 940 </span> : * @brief Narrow char array -<span class="lineNum"> 941 </span> : * -<span class="lineNum"> 942 </span> : * This function converts each char in the input to char using the -<span class="lineNum"> 943 </span> : * simplest reasonable transformation and writes the results to the -<span class="lineNum"> 944 </span> : * destination array. For any char in the input that cannot be -<span class="lineNum"> 945 </span> : * converted, @a dfault is used instead. For an underived ctype<char> -<span class="lineNum"> 946 </span> : * facet, the argument will be copied unchanged. -<span class="lineNum"> 947 </span> : * -<span class="lineNum"> 948 </span> : * This function works as if it returns ctype<char>::do_narrow(lo, hi, -<span class="lineNum"> 949 </span> : * dfault, to). do_narrow() must always return the same result for the -<span class="lineNum"> 950 </span> : * same input. -<span class="lineNum"> 951 </span> : * -<span class="lineNum"> 952 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 953 </span> : * codecvt for that. -<span class="lineNum"> 954 </span> : * -<span class="lineNum"> 955 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 956 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 957 </span> : * @param dfault Char to use if conversion fails. -<span class="lineNum"> 958 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 959 </span> : * @return @a hi. -<span class="lineNum"> 960 </span> : */ -<span class="lineNum"> 961 </span> : const char_type* -<span class="lineNum"> 962 </span> : narrow(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 963 </span> : char __dfault, char *__to) const -<span class="lineNum"> 964 </span> : { -<span class="lineNum"> 965 </span> : if (__builtin_expect(_M_narrow_ok == 1, true)) -<span class="lineNum"> 966 </span> : { -<span class="lineNum"> 967 </span> : __builtin_memcpy(__to, __lo, __hi - __lo); -<span class="lineNum"> 968 </span> : return __hi; -<span class="lineNum"> 969 </span> : } -<span class="lineNum"> 970 </span> : if (!_M_narrow_ok) -<span class="lineNum"> 971 </span> : _M_narrow_init(); -<span class="lineNum"> 972 </span> : return this->do_narrow(__lo, __hi, __dfault, __to); -<span class="lineNum"> 973 </span> : } -<span class="lineNum"> 974 </span> : -<span class="lineNum"> 975 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 976 </span> : // DR 695. ctype<char>::classic_table() not accessible. -<span class="lineNum"> 977 </span> : /// Returns a pointer to the mask table provided to the constructor, or -<span class="lineNum"> 978 </span> : /// the default from classic_table() if none was provided. -<span class="lineNum"> 979 </span> : const mask* -<span class="lineNum"> 980 </span> : table() const throw() -<span class="lineNum"> 981 </span> : { return _M_table; } -<span class="lineNum"> 982 </span> : -<span class="lineNum"> 983 </span> : /// Returns a pointer to the C locale mask table. -<span class="lineNum"> 984 </span> : static const mask* -<span class="lineNum"> 985 </span> : classic_table() throw(); -<span class="lineNum"> 986 </span> : protected: -<span class="lineNum"> 987 </span> : -<span class="lineNum"> 988 </span> : /** -<span class="lineNum"> 989 </span> : * @brief Destructor. -<span class="lineNum"> 990 </span> : * -<span class="lineNum"> 991 </span> : * This function deletes table() if @a del was true in the -<span class="lineNum"> 992 </span> : * constructor. -<span class="lineNum"> 993 </span> : */ -<span class="lineNum"> 994 </span> : virtual -<span class="lineNum"> 995 </span> : ~ctype(); -<span class="lineNum"> 996 </span> : -<span class="lineNum"> 997 </span> : /** -<span class="lineNum"> 998 </span> : * @brief Convert to uppercase. -<span class="lineNum"> 999 </span> : * -<span class="lineNum"> 1000 </span> : * This virtual function converts the char argument to uppercase if -<span class="lineNum"> 1001 </span> : * possible. If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 1002 </span> : * -<span class="lineNum"> 1003 </span> : * do_toupper() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1004 </span> : * uppercasing. do_toupper() must always return the same result for -<span class="lineNum"> 1005 </span> : * the same input. -<span class="lineNum"> 1006 </span> : * -<span class="lineNum"> 1007 </span> : * @param c The char to convert. -<span class="lineNum"> 1008 </span> : * @return The uppercase char if convertible, else @a c. -<span class="lineNum"> 1009 </span> : */ -<span class="lineNum"> 1010 </span> : virtual char_type -<span class="lineNum"> 1011 </span> : do_toupper(char_type) const; -<span class="lineNum"> 1012 </span> : -<span class="lineNum"> 1013 </span> : /** -<span class="lineNum"> 1014 </span> : * @brief Convert array to uppercase. -<span class="lineNum"> 1015 </span> : * -<span class="lineNum"> 1016 </span> : * This virtual function converts each char in the range [lo,hi) to -<span class="lineNum"> 1017 </span> : * uppercase if possible. Other chars remain untouched. -<span class="lineNum"> 1018 </span> : * -<span class="lineNum"> 1019 </span> : * do_toupper() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1020 </span> : * uppercasing. do_toupper() must always return the same result for -<span class="lineNum"> 1021 </span> : * the same input. -<span class="lineNum"> 1022 </span> : * -<span class="lineNum"> 1023 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1024 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1025 </span> : * @return @a hi. -<span class="lineNum"> 1026 </span> : */ -<span class="lineNum"> 1027 </span> : virtual const char_type* -<span class="lineNum"> 1028 </span> : do_toupper(char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 1029 </span> : -<span class="lineNum"> 1030 </span> : /** -<span class="lineNum"> 1031 </span> : * @brief Convert to lowercase. -<span class="lineNum"> 1032 </span> : * -<span class="lineNum"> 1033 </span> : * This virtual function converts the char argument to lowercase if -<span class="lineNum"> 1034 </span> : * possible. If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 1035 </span> : * -<span class="lineNum"> 1036 </span> : * do_tolower() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1037 </span> : * lowercasing. do_tolower() must always return the same result for -<span class="lineNum"> 1038 </span> : * the same input. -<span class="lineNum"> 1039 </span> : * -<span class="lineNum"> 1040 </span> : * @param c The char to convert. -<span class="lineNum"> 1041 </span> : * @return The lowercase char if convertible, else @a c. -<span class="lineNum"> 1042 </span> : */ -<span class="lineNum"> 1043 </span> : virtual char_type -<span class="lineNum"> 1044 </span> : do_tolower(char_type) const; -<span class="lineNum"> 1045 </span> : -<span class="lineNum"> 1046 </span> : /** -<span class="lineNum"> 1047 </span> : * @brief Convert array to lowercase. -<span class="lineNum"> 1048 </span> : * -<span class="lineNum"> 1049 </span> : * This virtual function converts each char in the range [lo,hi) to -<span class="lineNum"> 1050 </span> : * lowercase if possible. Other chars remain untouched. -<span class="lineNum"> 1051 </span> : * -<span class="lineNum"> 1052 </span> : * do_tolower() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1053 </span> : * lowercasing. do_tolower() must always return the same result for -<span class="lineNum"> 1054 </span> : * the same input. -<span class="lineNum"> 1055 </span> : * -<span class="lineNum"> 1056 </span> : * @param lo Pointer to first char in range. -<span class="lineNum"> 1057 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1058 </span> : * @return @a hi. -<span class="lineNum"> 1059 </span> : */ -<span class="lineNum"> 1060 </span> : virtual const char_type* -<span class="lineNum"> 1061 </span> : do_tolower(char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 1062 </span> : -<span class="lineNum"> 1063 </span> : /** -<span class="lineNum"> 1064 </span> : * @brief Widen char -<span class="lineNum"> 1065 </span> : * -<span class="lineNum"> 1066 </span> : * This virtual function converts the char to char using the simplest -<span class="lineNum"> 1067 </span> : * reasonable transformation. For an underived ctype<char> facet, the -<span class="lineNum"> 1068 </span> : * argument will be returned unchanged. -<span class="lineNum"> 1069 </span> : * -<span class="lineNum"> 1070 </span> : * do_widen() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1071 </span> : * widening. do_widen() must always return the same result for the -<span class="lineNum"> 1072 </span> : * same input. -<span class="lineNum"> 1073 </span> : * -<span class="lineNum"> 1074 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1075 </span> : * codecvt for that. -<span class="lineNum"> 1076 </span> : * -<span class="lineNum"> 1077 </span> : * @param c The char to convert. -<span class="lineNum"> 1078 </span> : * @return The converted character. -<span class="lineNum"> 1079 </span> : */ -<span class="lineNum"> 1080 </span> : virtual char_type -<span class="lineNum"> 1081 </span> : do_widen(char __c) const -<span class="lineNum"> 1082 </span> : { return __c; } -<span class="lineNum"> 1083 </span> : -<span class="lineNum"> 1084 </span> : /** -<span class="lineNum"> 1085 </span> : * @brief Widen char array -<span class="lineNum"> 1086 </span> : * -<span class="lineNum"> 1087 </span> : * This function converts each char in the range [lo,hi) to char using -<span class="lineNum"> 1088 </span> : * the simplest reasonable transformation. For an underived -<span class="lineNum"> 1089 </span> : * ctype<char> facet, the argument will be copied unchanged. -<span class="lineNum"> 1090 </span> : * -<span class="lineNum"> 1091 </span> : * do_widen() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1092 </span> : * widening. do_widen() must always return the same result for the -<span class="lineNum"> 1093 </span> : * same input. -<span class="lineNum"> 1094 </span> : * -<span class="lineNum"> 1095 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1096 </span> : * codecvt for that. -<span class="lineNum"> 1097 </span> : * -<span class="lineNum"> 1098 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1099 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1100 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 1101 </span> : * @return @a hi. -<span class="lineNum"> 1102 </span> : */ -<span class="lineNum"> 1103 </span> : virtual const char* -<span class="lineNum"> 1104 </span> : do_widen(const char* __lo, const char* __hi, char_type* __dest) const -<span class="lineNum"> 1105 </span> : { -<span class="lineNum"> 1106 </span> : __builtin_memcpy(__dest, __lo, __hi - __lo); -<span class="lineNum"> 1107 </span> : return __hi; -<span class="lineNum"> 1108 </span> : } -<span class="lineNum"> 1109 </span> : -<span class="lineNum"> 1110 </span> : /** -<span class="lineNum"> 1111 </span> : * @brief Narrow char -<span class="lineNum"> 1112 </span> : * -<span class="lineNum"> 1113 </span> : * This virtual function converts the char to char using the simplest -<span class="lineNum"> 1114 </span> : * reasonable transformation. If the conversion fails, dfault is -<span class="lineNum"> 1115 </span> : * returned instead. For an underived ctype<char> facet, @a c will be -<span class="lineNum"> 1116 </span> : * returned unchanged. -<span class="lineNum"> 1117 </span> : * -<span class="lineNum"> 1118 </span> : * do_narrow() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1119 </span> : * narrowing. do_narrow() must always return the same result for the -<span class="lineNum"> 1120 </span> : * same input. -<span class="lineNum"> 1121 </span> : * -<span class="lineNum"> 1122 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1123 </span> : * codecvt for that. -<span class="lineNum"> 1124 </span> : * -<span class="lineNum"> 1125 </span> : * @param c The char to convert. -<span class="lineNum"> 1126 </span> : * @param dfault Char to return if conversion fails. -<span class="lineNum"> 1127 </span> : * @return The converted char. -<span class="lineNum"> 1128 </span> : */ -<span class="lineNum"> 1129 </span> : virtual char -<span class="lineNum"> 1130 </span> : do_narrow(char_type __c, char) const -<span class="lineNum"> 1131 </span> : { return __c; } -<span class="lineNum"> 1132 </span> : -<span class="lineNum"> 1133 </span> : /** -<span class="lineNum"> 1134 </span> : * @brief Narrow char array to char array -<span class="lineNum"> 1135 </span> : * -<span class="lineNum"> 1136 </span> : * This virtual function converts each char in the range [lo,hi) to -<span class="lineNum"> 1137 </span> : * char using the simplest reasonable transformation and writes the -<span class="lineNum"> 1138 </span> : * results to the destination array. For any char in the input that -<span class="lineNum"> 1139 </span> : * cannot be converted, @a dfault is used instead. For an underived -<span class="lineNum"> 1140 </span> : * ctype<char> facet, the argument will be copied unchanged. -<span class="lineNum"> 1141 </span> : * -<span class="lineNum"> 1142 </span> : * do_narrow() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1143 </span> : * narrowing. do_narrow() must always return the same result for the -<span class="lineNum"> 1144 </span> : * same input. -<span class="lineNum"> 1145 </span> : * -<span class="lineNum"> 1146 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1147 </span> : * codecvt for that. -<span class="lineNum"> 1148 </span> : * -<span class="lineNum"> 1149 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1150 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1151 </span> : * @param dfault Char to use if conversion fails. -<span class="lineNum"> 1152 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 1153 </span> : * @return @a hi. -<span class="lineNum"> 1154 </span> : */ -<span class="lineNum"> 1155 </span> : virtual const char_type* -<span class="lineNum"> 1156 </span> : do_narrow(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 1157 </span> : char, char* __dest) const -<span class="lineNum"> 1158 </span> : { -<span class="lineNum"> 1159 </span> : __builtin_memcpy(__dest, __lo, __hi - __lo); -<span class="lineNum"> 1160 </span> : return __hi; -<span class="lineNum"> 1161 </span> : } -<span class="lineNum"> 1162 </span> : -<span class="lineNum"> 1163 </span> : private: -<span class="lineNum"> 1164 </span> : -<span class="lineNum"> 1165 </span><span class="lineNoCov"> 0 : void _M_widen_init() const</span> -<span class="lineNum"> 1166 </span> : { -<span class="lineNum"> 1167 </span> : char __tmp[sizeof(_M_widen)]; -<span class="lineNum"> 1168 </span><span class="lineNoCov"> 0 : for (size_t __i = 0; __i < sizeof(_M_widen); ++__i)</span> -<span class="lineNum"> 1169 </span><span class="lineNoCov"> 0 : __tmp[__i] = __i;</span> -<span class="lineNum"> 1170 </span><span class="lineNoCov"> 0 : do_widen(__tmp, __tmp + sizeof(__tmp), _M_widen);</span> -<span class="lineNum"> 1171 </span> : -<span class="lineNum"> 1172 </span><span class="lineNoCov"> 0 : _M_widen_ok = 1;</span> -<span class="lineNum"> 1173 </span> : // Set _M_widen_ok to 2 if memcpy can't be used. -<span class="lineNum"> 1174 </span><span class="lineNoCov"> 0 : if (__builtin_memcmp(__tmp, _M_widen, sizeof(_M_widen)))</span> -<span class="lineNum"> 1175 </span><span class="lineNoCov"> 0 : _M_widen_ok = 2;</span> -<span class="lineNum"> 1176 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1177 </span> : -<span class="lineNum"> 1178 </span> : // Fill in the narrowing cache and flag whether all values are -<span class="lineNum"> 1179 </span> : // valid or not. _M_narrow_ok is set to 2 if memcpy can't -<span class="lineNum"> 1180 </span> : // be used. -<span class="lineNum"> 1181 </span> : void _M_narrow_init() const -<span class="lineNum"> 1182 </span> : { -<span class="lineNum"> 1183 </span> : char __tmp[sizeof(_M_narrow)]; -<span class="lineNum"> 1184 </span> : for (size_t __i = 0; __i < sizeof(_M_narrow); ++__i) -<span class="lineNum"> 1185 </span> : __tmp[__i] = __i; -<span class="lineNum"> 1186 </span> : do_narrow(__tmp, __tmp + sizeof(__tmp), 0, _M_narrow); -<span class="lineNum"> 1187 </span> : -<span class="lineNum"> 1188 </span> : _M_narrow_ok = 1; -<span class="lineNum"> 1189 </span> : if (__builtin_memcmp(__tmp, _M_narrow, sizeof(_M_narrow))) -<span class="lineNum"> 1190 </span> : _M_narrow_ok = 2; -<span class="lineNum"> 1191 </span> : else -<span class="lineNum"> 1192 </span> : { -<span class="lineNum"> 1193 </span> : // Deal with the special case of zero: renarrow with a -<span class="lineNum"> 1194 </span> : // different default and compare. -<span class="lineNum"> 1195 </span> : char __c; -<span class="lineNum"> 1196 </span> : do_narrow(__tmp, __tmp + 1, 1, &__c); -<span class="lineNum"> 1197 </span> : if (__c == 1) -<span class="lineNum"> 1198 </span> : _M_narrow_ok = 2; -<span class="lineNum"> 1199 </span> : } -<span class="lineNum"> 1200 </span> : } -<span class="lineNum"> 1201 </span> : }; -<span class="lineNum"> 1202 </span> : -<span class="lineNum"> 1203 </span> : template<> -<span class="lineNum"> 1204 </span> : const ctype<char>& -<span class="lineNum"> 1205 </span> : use_facet<ctype<char> >(const locale& __loc); -<span class="lineNum"> 1206 </span> : -<span class="lineNum"> 1207 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 1208 </span> : // 22.2.1.3 ctype<wchar_t> specialization -<span class="lineNum"> 1209 </span> : /** -<span class="lineNum"> 1210 </span> : * @brief The ctype<wchar_t> specialization. -<span class="lineNum"> 1211 </span> : * -<span class="lineNum"> 1212 </span> : * This class defines classification and conversion functions for the -<span class="lineNum"> 1213 </span> : * wchar_t type. It gets used by wchar_t streams for many I/O operations. -<span class="lineNum"> 1214 </span> : * The wchar_t specialization provides a number of optimizations as well. -<span class="lineNum"> 1215 </span> : * -<span class="lineNum"> 1216 </span> : * ctype<wchar_t> inherits its public methods from -<span class="lineNum"> 1217 </span> : * __ctype_abstract_base<wchar_t>. -<span class="lineNum"> 1218 </span> : */ -<span class="lineNum"> 1219 </span> : template<> -<span class="lineNum"> 1220 </span> : class ctype<wchar_t> : public __ctype_abstract_base<wchar_t> -<span class="lineNum"> 1221 </span> : { -<span class="lineNum"> 1222 </span> : public: -<span class="lineNum"> 1223 </span> : // Types: -<span class="lineNum"> 1224 </span> : /// Typedef for the template parameter wchar_t. -<span class="lineNum"> 1225 </span> : typedef wchar_t char_type; -<span class="lineNum"> 1226 </span> : typedef wctype_t __wmask_type; -<span class="lineNum"> 1227 </span> : -<span class="lineNum"> 1228 </span> : protected: -<span class="lineNum"> 1229 </span> : __c_locale _M_c_locale_ctype; -<span class="lineNum"> 1230 </span> : -<span class="lineNum"> 1231 </span> : // Pre-computed narrowed and widened chars. -<span class="lineNum"> 1232 </span> : bool _M_narrow_ok; -<span class="lineNum"> 1233 </span> : char _M_narrow[128]; -<span class="lineNum"> 1234 </span> : wint_t _M_widen[1 + static_cast<unsigned char>(-1)]; -<span class="lineNum"> 1235 </span> : -<span class="lineNum"> 1236 </span> : // Pre-computed elements for do_is. -<span class="lineNum"> 1237 </span> : mask _M_bit[16]; -<span class="lineNum"> 1238 </span> : __wmask_type _M_wmask[16]; -<span class="lineNum"> 1239 </span> : -<span class="lineNum"> 1240 </span> : public: -<span class="lineNum"> 1241 </span> : // Data Members: -<span class="lineNum"> 1242 </span> : /// The facet id for ctype<wchar_t> -<span class="lineNum"> 1243 </span> : static locale::id id; -<span class="lineNum"> 1244 </span> : -<span class="lineNum"> 1245 </span> : /** -<span class="lineNum"> 1246 </span> : * @brief Constructor performs initialization. -<span class="lineNum"> 1247 </span> : * -<span class="lineNum"> 1248 </span> : * This is the constructor provided by the standard. -<span class="lineNum"> 1249 </span> : * -<span class="lineNum"> 1250 </span> : * @param refs Passed to the base facet class. -<span class="lineNum"> 1251 </span> : */ -<span class="lineNum"> 1252 </span> : explicit -<span class="lineNum"> 1253 </span> : ctype(size_t __refs = 0); -<span class="lineNum"> 1254 </span> : -<span class="lineNum"> 1255 </span> : /** -<span class="lineNum"> 1256 </span> : * @brief Constructor performs static initialization. -<span class="lineNum"> 1257 </span> : * -<span class="lineNum"> 1258 </span> : * This constructor is used to construct the initial C locale facet. -<span class="lineNum"> 1259 </span> : * -<span class="lineNum"> 1260 </span> : * @param cloc Handle to C locale data. -<span class="lineNum"> 1261 </span> : * @param refs Passed to the base facet class. -<span class="lineNum"> 1262 </span> : */ -<span class="lineNum"> 1263 </span> : explicit -<span class="lineNum"> 1264 </span> : ctype(__c_locale __cloc, size_t __refs = 0); -<span class="lineNum"> 1265 </span> : -<span class="lineNum"> 1266 </span> : protected: -<span class="lineNum"> 1267 </span> : __wmask_type -<span class="lineNum"> 1268 </span> : _M_convert_to_wmask(const mask __m) const; -<span class="lineNum"> 1269 </span> : -<span class="lineNum"> 1270 </span> : /// Destructor -<span class="lineNum"> 1271 </span> : virtual -<span class="lineNum"> 1272 </span> : ~ctype(); -<span class="lineNum"> 1273 </span> : -<span class="lineNum"> 1274 </span> : /** -<span class="lineNum"> 1275 </span> : * @brief Test wchar_t classification. -<span class="lineNum"> 1276 </span> : * -<span class="lineNum"> 1277 </span> : * This function finds a mask M for @a c and compares it to mask @a m. -<span class="lineNum"> 1278 </span> : * -<span class="lineNum"> 1279 </span> : * do_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1280 </span> : * classifying. do_is() must always return the same result for the -<span class="lineNum"> 1281 </span> : * same input. -<span class="lineNum"> 1282 </span> : * -<span class="lineNum"> 1283 </span> : * @param c The wchar_t to find the mask of. -<span class="lineNum"> 1284 </span> : * @param m The mask to compare against. -<span class="lineNum"> 1285 </span> : * @return (M & m) != 0. -<span class="lineNum"> 1286 </span> : */ -<span class="lineNum"> 1287 </span> : virtual bool -<span class="lineNum"> 1288 </span> : do_is(mask __m, char_type __c) const; -<span class="lineNum"> 1289 </span> : -<span class="lineNum"> 1290 </span> : /** -<span class="lineNum"> 1291 </span> : * @brief Return a mask array. -<span class="lineNum"> 1292 </span> : * -<span class="lineNum"> 1293 </span> : * This function finds the mask for each wchar_t in the range [lo,hi) -<span class="lineNum"> 1294 </span> : * and successively writes it to vec. vec must have as many elements -<span class="lineNum"> 1295 </span> : * as the input. -<span class="lineNum"> 1296 </span> : * -<span class="lineNum"> 1297 </span> : * do_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1298 </span> : * classifying. do_is() must always return the same result for the -<span class="lineNum"> 1299 </span> : * same input. -<span class="lineNum"> 1300 </span> : * -<span class="lineNum"> 1301 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1302 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1303 </span> : * @param vec Pointer to an array of mask storage. -<span class="lineNum"> 1304 </span> : * @return @a hi. -<span class="lineNum"> 1305 </span> : */ -<span class="lineNum"> 1306 </span> : virtual const char_type* -<span class="lineNum"> 1307 </span> : do_is(const char_type* __lo, const char_type* __hi, mask* __vec) const; -<span class="lineNum"> 1308 </span> : -<span class="lineNum"> 1309 </span> : /** -<span class="lineNum"> 1310 </span> : * @brief Find wchar_t matching mask -<span class="lineNum"> 1311 </span> : * -<span class="lineNum"> 1312 </span> : * This function searches for and returns the first wchar_t c in -<span class="lineNum"> 1313 </span> : * [lo,hi) for which is(m,c) is true. -<span class="lineNum"> 1314 </span> : * -<span class="lineNum"> 1315 </span> : * do_scan_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1316 </span> : * match searching. do_is() must always return the same result for the -<span class="lineNum"> 1317 </span> : * same input. -<span class="lineNum"> 1318 </span> : * -<span class="lineNum"> 1319 </span> : * @param m The mask to compare against. -<span class="lineNum"> 1320 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1321 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1322 </span> : * @return Pointer to a matching wchar_t if found, else @a hi. -<span class="lineNum"> 1323 </span> : */ -<span class="lineNum"> 1324 </span> : virtual const char_type* -<span class="lineNum"> 1325 </span> : do_scan_is(mask __m, const char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 1326 </span> : -<span class="lineNum"> 1327 </span> : /** -<span class="lineNum"> 1328 </span> : * @brief Find wchar_t not matching mask -<span class="lineNum"> 1329 </span> : * -<span class="lineNum"> 1330 </span> : * This function searches for and returns a pointer to the first -<span class="lineNum"> 1331 </span> : * wchar_t c of [lo,hi) for which is(m,c) is false. -<span class="lineNum"> 1332 </span> : * -<span class="lineNum"> 1333 </span> : * do_scan_is() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1334 </span> : * match searching. do_is() must always return the same result for the -<span class="lineNum"> 1335 </span> : * same input. -<span class="lineNum"> 1336 </span> : * -<span class="lineNum"> 1337 </span> : * @param m The mask to compare against. -<span class="lineNum"> 1338 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1339 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1340 </span> : * @return Pointer to a non-matching wchar_t if found, else @a hi. -<span class="lineNum"> 1341 </span> : */ -<span class="lineNum"> 1342 </span> : virtual const char_type* -<span class="lineNum"> 1343 </span> : do_scan_not(mask __m, const char_type* __lo, -<span class="lineNum"> 1344 </span> : const char_type* __hi) const; -<span class="lineNum"> 1345 </span> : -<span class="lineNum"> 1346 </span> : /** -<span class="lineNum"> 1347 </span> : * @brief Convert to uppercase. -<span class="lineNum"> 1348 </span> : * -<span class="lineNum"> 1349 </span> : * This virtual function converts the wchar_t argument to uppercase if -<span class="lineNum"> 1350 </span> : * possible. If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 1351 </span> : * -<span class="lineNum"> 1352 </span> : * do_toupper() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1353 </span> : * uppercasing. do_toupper() must always return the same result for -<span class="lineNum"> 1354 </span> : * the same input. -<span class="lineNum"> 1355 </span> : * -<span class="lineNum"> 1356 </span> : * @param c The wchar_t to convert. -<span class="lineNum"> 1357 </span> : * @return The uppercase wchar_t if convertible, else @a c. -<span class="lineNum"> 1358 </span> : */ -<span class="lineNum"> 1359 </span> : virtual char_type -<span class="lineNum"> 1360 </span> : do_toupper(char_type) const; -<span class="lineNum"> 1361 </span> : -<span class="lineNum"> 1362 </span> : /** -<span class="lineNum"> 1363 </span> : * @brief Convert array to uppercase. -<span class="lineNum"> 1364 </span> : * -<span class="lineNum"> 1365 </span> : * This virtual function converts each wchar_t in the range [lo,hi) to -<span class="lineNum"> 1366 </span> : * uppercase if possible. Other elements remain untouched. -<span class="lineNum"> 1367 </span> : * -<span class="lineNum"> 1368 </span> : * do_toupper() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1369 </span> : * uppercasing. do_toupper() must always return the same result for -<span class="lineNum"> 1370 </span> : * the same input. -<span class="lineNum"> 1371 </span> : * -<span class="lineNum"> 1372 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1373 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1374 </span> : * @return @a hi. -<span class="lineNum"> 1375 </span> : */ -<span class="lineNum"> 1376 </span> : virtual const char_type* -<span class="lineNum"> 1377 </span> : do_toupper(char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 1378 </span> : -<span class="lineNum"> 1379 </span> : /** -<span class="lineNum"> 1380 </span> : * @brief Convert to lowercase. -<span class="lineNum"> 1381 </span> : * -<span class="lineNum"> 1382 </span> : * This virtual function converts the argument to lowercase if -<span class="lineNum"> 1383 </span> : * possible. If not possible (for example, '2'), returns the argument. -<span class="lineNum"> 1384 </span> : * -<span class="lineNum"> 1385 </span> : * do_tolower() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1386 </span> : * lowercasing. do_tolower() must always return the same result for -<span class="lineNum"> 1387 </span> : * the same input. -<span class="lineNum"> 1388 </span> : * -<span class="lineNum"> 1389 </span> : * @param c The wchar_t to convert. -<span class="lineNum"> 1390 </span> : * @return The lowercase wchar_t if convertible, else @a c. -<span class="lineNum"> 1391 </span> : */ -<span class="lineNum"> 1392 </span> : virtual char_type -<span class="lineNum"> 1393 </span> : do_tolower(char_type) const; -<span class="lineNum"> 1394 </span> : -<span class="lineNum"> 1395 </span> : /** -<span class="lineNum"> 1396 </span> : * @brief Convert array to lowercase. -<span class="lineNum"> 1397 </span> : * -<span class="lineNum"> 1398 </span> : * This virtual function converts each wchar_t in the range [lo,hi) to -<span class="lineNum"> 1399 </span> : * lowercase if possible. Other elements remain untouched. -<span class="lineNum"> 1400 </span> : * -<span class="lineNum"> 1401 </span> : * do_tolower() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1402 </span> : * lowercasing. do_tolower() must always return the same result for -<span class="lineNum"> 1403 </span> : * the same input. -<span class="lineNum"> 1404 </span> : * -<span class="lineNum"> 1405 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1406 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1407 </span> : * @return @a hi. -<span class="lineNum"> 1408 </span> : */ -<span class="lineNum"> 1409 </span> : virtual const char_type* -<span class="lineNum"> 1410 </span> : do_tolower(char_type* __lo, const char_type* __hi) const; -<span class="lineNum"> 1411 </span> : -<span class="lineNum"> 1412 </span> : /** -<span class="lineNum"> 1413 </span> : * @brief Widen char to wchar_t -<span class="lineNum"> 1414 </span> : * -<span class="lineNum"> 1415 </span> : * This virtual function converts the char to wchar_t using the -<span class="lineNum"> 1416 </span> : * simplest reasonable transformation. For an underived ctype<wchar_t> -<span class="lineNum"> 1417 </span> : * facet, the argument will be cast to wchar_t. -<span class="lineNum"> 1418 </span> : * -<span class="lineNum"> 1419 </span> : * do_widen() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1420 </span> : * widening. do_widen() must always return the same result for the -<span class="lineNum"> 1421 </span> : * same input. -<span class="lineNum"> 1422 </span> : * -<span class="lineNum"> 1423 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1424 </span> : * codecvt for that. -<span class="lineNum"> 1425 </span> : * -<span class="lineNum"> 1426 </span> : * @param c The char to convert. -<span class="lineNum"> 1427 </span> : * @return The converted wchar_t. -<span class="lineNum"> 1428 </span> : */ -<span class="lineNum"> 1429 </span> : virtual char_type -<span class="lineNum"> 1430 </span> : do_widen(char) const; -<span class="lineNum"> 1431 </span> : -<span class="lineNum"> 1432 </span> : /** -<span class="lineNum"> 1433 </span> : * @brief Widen char array to wchar_t array -<span class="lineNum"> 1434 </span> : * -<span class="lineNum"> 1435 </span> : * This function converts each char in the input to wchar_t using the -<span class="lineNum"> 1436 </span> : * simplest reasonable transformation. For an underived ctype<wchar_t> -<span class="lineNum"> 1437 </span> : * facet, the argument will be copied, casting each element to wchar_t. -<span class="lineNum"> 1438 </span> : * -<span class="lineNum"> 1439 </span> : * do_widen() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1440 </span> : * widening. do_widen() must always return the same result for the -<span class="lineNum"> 1441 </span> : * same input. -<span class="lineNum"> 1442 </span> : * -<span class="lineNum"> 1443 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1444 </span> : * codecvt for that. -<span class="lineNum"> 1445 </span> : * -<span class="lineNum"> 1446 </span> : * @param lo Pointer to start range. -<span class="lineNum"> 1447 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1448 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 1449 </span> : * @return @a hi. -<span class="lineNum"> 1450 </span> : */ -<span class="lineNum"> 1451 </span> : virtual const char* -<span class="lineNum"> 1452 </span> : do_widen(const char* __lo, const char* __hi, char_type* __dest) const; -<span class="lineNum"> 1453 </span> : -<span class="lineNum"> 1454 </span> : /** -<span class="lineNum"> 1455 </span> : * @brief Narrow wchar_t to char -<span class="lineNum"> 1456 </span> : * -<span class="lineNum"> 1457 </span> : * This virtual function converts the argument to char using -<span class="lineNum"> 1458 </span> : * the simplest reasonable transformation. If the conversion -<span class="lineNum"> 1459 </span> : * fails, dfault is returned instead. For an underived -<span class="lineNum"> 1460 </span> : * ctype<wchar_t> facet, @a c will be cast to char and -<span class="lineNum"> 1461 </span> : * returned. -<span class="lineNum"> 1462 </span> : * -<span class="lineNum"> 1463 </span> : * do_narrow() is a hook for a derived facet to change the -<span class="lineNum"> 1464 </span> : * behavior of narrowing. do_narrow() must always return the -<span class="lineNum"> 1465 </span> : * same result for the same input. -<span class="lineNum"> 1466 </span> : * -<span class="lineNum"> 1467 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1468 </span> : * codecvt for that. -<span class="lineNum"> 1469 </span> : * -<span class="lineNum"> 1470 </span> : * @param c The wchar_t to convert. -<span class="lineNum"> 1471 </span> : * @param dfault Char to return if conversion fails. -<span class="lineNum"> 1472 </span> : * @return The converted char. -<span class="lineNum"> 1473 </span> : */ -<span class="lineNum"> 1474 </span> : virtual char -<span class="lineNum"> 1475 </span> : do_narrow(char_type, char __dfault) const; -<span class="lineNum"> 1476 </span> : -<span class="lineNum"> 1477 </span> : /** -<span class="lineNum"> 1478 </span> : * @brief Narrow wchar_t array to char array -<span class="lineNum"> 1479 </span> : * -<span class="lineNum"> 1480 </span> : * This virtual function converts each wchar_t in the range [lo,hi) to -<span class="lineNum"> 1481 </span> : * char using the simplest reasonable transformation and writes the -<span class="lineNum"> 1482 </span> : * results to the destination array. For any wchar_t in the input that -<span class="lineNum"> 1483 </span> : * cannot be converted, @a dfault is used instead. For an underived -<span class="lineNum"> 1484 </span> : * ctype<wchar_t> facet, the argument will be copied, casting each -<span class="lineNum"> 1485 </span> : * element to char. -<span class="lineNum"> 1486 </span> : * -<span class="lineNum"> 1487 </span> : * do_narrow() is a hook for a derived facet to change the behavior of -<span class="lineNum"> 1488 </span> : * narrowing. do_narrow() must always return the same result for the -<span class="lineNum"> 1489 </span> : * same input. -<span class="lineNum"> 1490 </span> : * -<span class="lineNum"> 1491 </span> : * Note: this is not what you want for codepage conversions. See -<span class="lineNum"> 1492 </span> : * codecvt for that. -<span class="lineNum"> 1493 </span> : * -<span class="lineNum"> 1494 </span> : * @param lo Pointer to start of range. -<span class="lineNum"> 1495 </span> : * @param hi Pointer to end of range. -<span class="lineNum"> 1496 </span> : * @param dfault Char to use if conversion fails. -<span class="lineNum"> 1497 </span> : * @param to Pointer to the destination array. -<span class="lineNum"> 1498 </span> : * @return @a hi. -<span class="lineNum"> 1499 </span> : */ -<span class="lineNum"> 1500 </span> : virtual const char_type* -<span class="lineNum"> 1501 </span> : do_narrow(const char_type* __lo, const char_type* __hi, -<span class="lineNum"> 1502 </span> : char __dfault, char* __dest) const; -<span class="lineNum"> 1503 </span> : -<span class="lineNum"> 1504 </span> : // For use at construction time only. -<span class="lineNum"> 1505 </span> : void -<span class="lineNum"> 1506 </span> : _M_initialize_ctype(); -<span class="lineNum"> 1507 </span> : }; -<span class="lineNum"> 1508 </span> : -<span class="lineNum"> 1509 </span> : template<> -<span class="lineNum"> 1510 </span> : const ctype<wchar_t>& -<span class="lineNum"> 1511 </span> : use_facet<ctype<wchar_t> >(const locale& __loc); -<span class="lineNum"> 1512 </span> : #endif //_GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 1513 </span> : -<span class="lineNum"> 1514 </span> : /// class ctype_byname [22.2.1.2]. -<span class="lineNum"> 1515 </span> : template<typename _CharT> -<span class="lineNum"> 1516 </span> : class ctype_byname : public ctype<_CharT> -<span class="lineNum"> 1517 </span> : { -<span class="lineNum"> 1518 </span> : public: -<span class="lineNum"> 1519 </span> : typedef typename ctype<_CharT>::mask mask; -<span class="lineNum"> 1520 </span> : -<span class="lineNum"> 1521 </span> : explicit -<span class="lineNum"> 1522 </span> : ctype_byname(const char* __s, size_t __refs = 0); -<span class="lineNum"> 1523 </span> : -<span class="lineNum"> 1524 </span> : protected: -<span class="lineNum"> 1525 </span> : virtual -<span class="lineNum"> 1526 </span> : ~ctype_byname() { }; -<span class="lineNum"> 1527 </span> : }; -<span class="lineNum"> 1528 </span> : -<span class="lineNum"> 1529 </span> : /// 22.2.1.4 Class ctype_byname specializations. -<span class="lineNum"> 1530 </span> : template<> -<span class="lineNum"> 1531 </span> : class ctype_byname<char> : public ctype<char> -<span class="lineNum"> 1532 </span> : { -<span class="lineNum"> 1533 </span> : public: -<span class="lineNum"> 1534 </span> : explicit -<span class="lineNum"> 1535 </span> : ctype_byname(const char* __s, size_t __refs = 0); -<span class="lineNum"> 1536 </span> : -<span class="lineNum"> 1537 </span> : protected: -<span class="lineNum"> 1538 </span> : virtual -<span class="lineNum"> 1539 </span> : ~ctype_byname(); -<span class="lineNum"> 1540 </span> : }; -<span class="lineNum"> 1541 </span> : -<span class="lineNum"> 1542 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 1543 </span> : template<> -<span class="lineNum"> 1544 </span> : class ctype_byname<wchar_t> : public ctype<wchar_t> -<span class="lineNum"> 1545 </span> : { -<span class="lineNum"> 1546 </span> : public: -<span class="lineNum"> 1547 </span> : explicit -<span class="lineNum"> 1548 </span> : ctype_byname(const char* __s, size_t __refs = 0); -<span class="lineNum"> 1549 </span> : -<span class="lineNum"> 1550 </span> : protected: -<span class="lineNum"> 1551 </span> : virtual -<span class="lineNum"> 1552 </span> : ~ctype_byname(); -<span class="lineNum"> 1553 </span> : }; -<span class="lineNum"> 1554 </span> : #endif -<span class="lineNum"> 1555 </span> : -<span class="lineNum"> 1556 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 1557 </span> : -<span class="lineNum"> 1558 </span> : // Include host and configuration specific ctype inlines. -<span class="lineNum"> 1559 </span> : #include <bits/ctype_inline.h> -<span class="lineNum"> 1560 </span> : -<span class="lineNum"> 1561 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 1562 </span> : -<span class="lineNum"> 1563 </span> : // 22.2.2 The numeric category. -<span class="lineNum"> 1564 </span> : class __num_base -<span class="lineNum"> 1565 </span> : { -<span class="lineNum"> 1566 </span> : public: -<span class="lineNum"> 1567 </span> : // NB: Code depends on the order of _S_atoms_out elements. -<span class="lineNum"> 1568 </span> : // Below are the indices into _S_atoms_out. -<span class="lineNum"> 1569 </span> : enum -<span class="lineNum"> 1570 </span> : { -<span class="lineNum"> 1571 </span> : _S_ominus, -<span class="lineNum"> 1572 </span> : _S_oplus, -<span class="lineNum"> 1573 </span> : _S_ox, -<span class="lineNum"> 1574 </span> : _S_oX, -<span class="lineNum"> 1575 </span> : _S_odigits, -<span class="lineNum"> 1576 </span> : _S_odigits_end = _S_odigits + 16, -<span class="lineNum"> 1577 </span> : _S_oudigits = _S_odigits_end, -<span class="lineNum"> 1578 </span> : _S_oudigits_end = _S_oudigits + 16, -<span class="lineNum"> 1579 </span> : _S_oe = _S_odigits + 14, // For scientific notation, 'e' -<span class="lineNum"> 1580 </span> : _S_oE = _S_oudigits + 14, // For scientific notation, 'E' -<span class="lineNum"> 1581 </span> : _S_oend = _S_oudigits_end -<span class="lineNum"> 1582 </span> : }; -<span class="lineNum"> 1583 </span> : -<span class="lineNum"> 1584 </span> : // A list of valid numeric literals for output. This array -<span class="lineNum"> 1585 </span> : // contains chars that will be passed through the current locale's -<span class="lineNum"> 1586 </span> : // ctype<_CharT>.widen() and then used to render numbers. -<span class="lineNum"> 1587 </span> : // For the standard "C" locale, this is -<span class="lineNum"> 1588 </span> : // "-+xX0123456789abcdef0123456789ABCDEF". -<span class="lineNum"> 1589 </span> : static const char* _S_atoms_out; -<span class="lineNum"> 1590 </span> : -<span class="lineNum"> 1591 </span> : // String literal of acceptable (narrow) input, for num_get. -<span class="lineNum"> 1592 </span> : // "-+xX0123456789abcdefABCDEF" -<span class="lineNum"> 1593 </span> : static const char* _S_atoms_in; -<span class="lineNum"> 1594 </span> : -<span class="lineNum"> 1595 </span> : enum -<span class="lineNum"> 1596 </span> : { -<span class="lineNum"> 1597 </span> : _S_iminus, -<span class="lineNum"> 1598 </span> : _S_iplus, -<span class="lineNum"> 1599 </span> : _S_ix, -<span class="lineNum"> 1600 </span> : _S_iX, -<span class="lineNum"> 1601 </span> : _S_izero, -<span class="lineNum"> 1602 </span> : _S_ie = _S_izero + 14, -<span class="lineNum"> 1603 </span> : _S_iE = _S_izero + 20, -<span class="lineNum"> 1604 </span> : _S_iend = 26 -<span class="lineNum"> 1605 </span> : }; -<span class="lineNum"> 1606 </span> : -<span class="lineNum"> 1607 </span> : // num_put -<span class="lineNum"> 1608 </span> : // Construct and return valid scanf format for floating point types. -<span class="lineNum"> 1609 </span> : static void -<span class="lineNum"> 1610 </span> : _S_format_float(const ios_base& __io, char* __fptr, char __mod); -<span class="lineNum"> 1611 </span> : }; -<span class="lineNum"> 1612 </span> : -<span class="lineNum"> 1613 </span> : template<typename _CharT> -<span class="lineNum"> 1614 </span> : struct __numpunct_cache : public locale::facet -<span class="lineNum"> 1615 </span> : { -<span class="lineNum"> 1616 </span> : const char* _M_grouping; -<span class="lineNum"> 1617 </span> : size_t _M_grouping_size; -<span class="lineNum"> 1618 </span> : bool _M_use_grouping; -<span class="lineNum"> 1619 </span> : const _CharT* _M_truename; -<span class="lineNum"> 1620 </span> : size_t _M_truename_size; -<span class="lineNum"> 1621 </span> : const _CharT* _M_falsename; -<span class="lineNum"> 1622 </span> : size_t _M_falsename_size; -<span class="lineNum"> 1623 </span> : _CharT _M_decimal_point; -<span class="lineNum"> 1624 </span> : _CharT _M_thousands_sep; -<span class="lineNum"> 1625 </span> : -<span class="lineNum"> 1626 </span> : // A list of valid numeric literals for output: in the standard -<span class="lineNum"> 1627 </span> : // "C" locale, this is "-+xX0123456789abcdef0123456789ABCDEF". -<span class="lineNum"> 1628 </span> : // This array contains the chars after having been passed -<span class="lineNum"> 1629 </span> : // through the current locale's ctype<_CharT>.widen(). -<span class="lineNum"> 1630 </span> : _CharT _M_atoms_out[__num_base::_S_oend]; -<span class="lineNum"> 1631 </span> : -<span class="lineNum"> 1632 </span> : // A list of valid numeric literals for input: in the standard -<span class="lineNum"> 1633 </span> : // "C" locale, this is "-+xX0123456789abcdefABCDEF" -<span class="lineNum"> 1634 </span> : // This array contains the chars after having been passed -<span class="lineNum"> 1635 </span> : // through the current locale's ctype<_CharT>.widen(). -<span class="lineNum"> 1636 </span> : _CharT _M_atoms_in[__num_base::_S_iend]; -<span class="lineNum"> 1637 </span> : -<span class="lineNum"> 1638 </span> : bool _M_allocated; -<span class="lineNum"> 1639 </span> : -<span class="lineNum"> 1640 </span> : __numpunct_cache(size_t __refs = 0) : facet(__refs), -<span class="lineNum"> 1641 </span> : _M_grouping(NULL), _M_grouping_size(0), _M_use_grouping(false), -<span class="lineNum"> 1642 </span> : _M_truename(NULL), _M_truename_size(0), _M_falsename(NULL), -<span class="lineNum"> 1643 </span> : _M_falsename_size(0), _M_decimal_point(_CharT()), -<span class="lineNum"> 1644 </span> : _M_thousands_sep(_CharT()), _M_allocated(false) -<span class="lineNum"> 1645 </span> : { } -<span class="lineNum"> 1646 </span> : -<span class="lineNum"> 1647 </span> : ~__numpunct_cache(); -<span class="lineNum"> 1648 </span> : -<span class="lineNum"> 1649 </span> : void -<span class="lineNum"> 1650 </span> : _M_cache(const locale& __loc); -<span class="lineNum"> 1651 </span> : -<span class="lineNum"> 1652 </span> : private: -<span class="lineNum"> 1653 </span> : __numpunct_cache& -<span class="lineNum"> 1654 </span> : operator=(const __numpunct_cache&); -<span class="lineNum"> 1655 </span> : -<span class="lineNum"> 1656 </span> : explicit -<span class="lineNum"> 1657 </span> : __numpunct_cache(const __numpunct_cache&); -<span class="lineNum"> 1658 </span> : }; -<span class="lineNum"> 1659 </span> : -<span class="lineNum"> 1660 </span> : template<typename _CharT> -<span class="lineNum"> 1661 </span> : __numpunct_cache<_CharT>::~__numpunct_cache() -<span class="lineNum"> 1662 </span> : { -<span class="lineNum"> 1663 </span> : if (_M_allocated) -<span class="lineNum"> 1664 </span> : { -<span class="lineNum"> 1665 </span> : delete [] _M_grouping; -<span class="lineNum"> 1666 </span> : delete [] _M_truename; -<span class="lineNum"> 1667 </span> : delete [] _M_falsename; -<span class="lineNum"> 1668 </span> : } -<span class="lineNum"> 1669 </span> : } -<span class="lineNum"> 1670 </span> : -<span class="lineNum"> 1671 </span> : /** -<span class="lineNum"> 1672 </span> : * @brief Numpunct facet. -<span class="lineNum"> 1673 </span> : * -<span class="lineNum"> 1674 </span> : * This facet stores several pieces of information related to printing and -<span class="lineNum"> 1675 </span> : * scanning numbers, such as the decimal point character. It takes a -<span class="lineNum"> 1676 </span> : * template parameter specifying the char type. The numpunct facet is -<span class="lineNum"> 1677 </span> : * used by streams for many I/O operations involving numbers. -<span class="lineNum"> 1678 </span> : * -<span class="lineNum"> 1679 </span> : * The numpunct template uses protected virtual functions to provide the -<span class="lineNum"> 1680 </span> : * actual results. The public accessors forward the call to the virtual -<span class="lineNum"> 1681 </span> : * functions. These virtual functions are hooks for developers to -<span class="lineNum"> 1682 </span> : * implement the behavior they require from a numpunct facet. -<span class="lineNum"> 1683 </span> : */ -<span class="lineNum"> 1684 </span> : template<typename _CharT> -<span class="lineNum"> 1685 </span> : class numpunct : public locale::facet -<span class="lineNum"> 1686 </span> : { -<span class="lineNum"> 1687 </span> : public: -<span class="lineNum"> 1688 </span> : // Types: -<span class="lineNum"> 1689 </span> : //@{ -<span class="lineNum"> 1690 </span> : /// Public typedefs -<span class="lineNum"> 1691 </span> : typedef _CharT char_type; -<span class="lineNum"> 1692 </span> : typedef basic_string<_CharT> string_type; -<span class="lineNum"> 1693 </span> : //@} -<span class="lineNum"> 1694 </span> : typedef __numpunct_cache<_CharT> __cache_type; -<span class="lineNum"> 1695 </span> : -<span class="lineNum"> 1696 </span> : protected: -<span class="lineNum"> 1697 </span> : __cache_type* _M_data; -<span class="lineNum"> 1698 </span> : -<span class="lineNum"> 1699 </span> : public: -<span class="lineNum"> 1700 </span> : /// Numpunct facet id. -<span class="lineNum"> 1701 </span> : static locale::id id; -<span class="lineNum"> 1702 </span> : -<span class="lineNum"> 1703 </span> : /** -<span class="lineNum"> 1704 </span> : * @brief Numpunct constructor. -<span class="lineNum"> 1705 </span> : * -<span class="lineNum"> 1706 </span> : * @param refs Refcount to pass to the base class. -<span class="lineNum"> 1707 </span> : */ -<span class="lineNum"> 1708 </span> : explicit -<span class="lineNum"> 1709 </span> : numpunct(size_t __refs = 0) : facet(__refs), _M_data(NULL) -<span class="lineNum"> 1710 </span> : { _M_initialize_numpunct(); } -<span class="lineNum"> 1711 </span> : -<span class="lineNum"> 1712 </span> : /** -<span class="lineNum"> 1713 </span> : * @brief Internal constructor. Not for general use. -<span class="lineNum"> 1714 </span> : * -<span class="lineNum"> 1715 </span> : * This is a constructor for use by the library itself to set up the -<span class="lineNum"> 1716 </span> : * predefined locale facets. -<span class="lineNum"> 1717 </span> : * -<span class="lineNum"> 1718 </span> : * @param cache __numpunct_cache object. -<span class="lineNum"> 1719 </span> : * @param refs Refcount to pass to the base class. -<span class="lineNum"> 1720 </span> : */ -<span class="lineNum"> 1721 </span> : explicit -<span class="lineNum"> 1722 </span> : numpunct(__cache_type* __cache, size_t __refs = 0) -<span class="lineNum"> 1723 </span> : : facet(__refs), _M_data(__cache) -<span class="lineNum"> 1724 </span> : { _M_initialize_numpunct(); } -<span class="lineNum"> 1725 </span> : -<span class="lineNum"> 1726 </span> : /** -<span class="lineNum"> 1727 </span> : * @brief Internal constructor. Not for general use. -<span class="lineNum"> 1728 </span> : * -<span class="lineNum"> 1729 </span> : * This is a constructor for use by the library itself to set up new -<span class="lineNum"> 1730 </span> : * locales. -<span class="lineNum"> 1731 </span> : * -<span class="lineNum"> 1732 </span> : * @param cloc The "C" locale. -<span class="lineNum"> 1733 </span> : * @param refs Refcount to pass to the base class. -<span class="lineNum"> 1734 </span> : */ -<span class="lineNum"> 1735 </span> : explicit -<span class="lineNum"> 1736 </span> : numpunct(__c_locale __cloc, size_t __refs = 0) -<span class="lineNum"> 1737 </span> : : facet(__refs), _M_data(NULL) -<span class="lineNum"> 1738 </span> : { _M_initialize_numpunct(__cloc); } -<span class="lineNum"> 1739 </span> : -<span class="lineNum"> 1740 </span> : /** -<span class="lineNum"> 1741 </span> : * @brief Return decimal point character. -<span class="lineNum"> 1742 </span> : * -<span class="lineNum"> 1743 </span> : * This function returns a char_type to use as a decimal point. It -<span class="lineNum"> 1744 </span> : * does so by returning returning -<span class="lineNum"> 1745 </span> : * numpunct<char_type>::do_decimal_point(). -<span class="lineNum"> 1746 </span> : * -<span class="lineNum"> 1747 </span> : * @return @a char_type representing a decimal point. -<span class="lineNum"> 1748 </span> : */ -<span class="lineNum"> 1749 </span> : char_type -<span class="lineNum"> 1750 </span> : decimal_point() const -<span class="lineNum"> 1751 </span> : { return this->do_decimal_point(); } -<span class="lineNum"> 1752 </span> : -<span class="lineNum"> 1753 </span> : /** -<span class="lineNum"> 1754 </span> : * @brief Return thousands separator character. -<span class="lineNum"> 1755 </span> : * -<span class="lineNum"> 1756 </span> : * This function returns a char_type to use as a thousands -<span class="lineNum"> 1757 </span> : * separator. It does so by returning returning -<span class="lineNum"> 1758 </span> : * numpunct<char_type>::do_thousands_sep(). -<span class="lineNum"> 1759 </span> : * -<span class="lineNum"> 1760 </span> : * @return char_type representing a thousands separator. -<span class="lineNum"> 1761 </span> : */ -<span class="lineNum"> 1762 </span> : char_type -<span class="lineNum"> 1763 </span> : thousands_sep() const -<span class="lineNum"> 1764 </span> : { return this->do_thousands_sep(); } -<span class="lineNum"> 1765 </span> : -<span class="lineNum"> 1766 </span> : /** -<span class="lineNum"> 1767 </span> : * @brief Return grouping specification. -<span class="lineNum"> 1768 </span> : * -<span class="lineNum"> 1769 </span> : * This function returns a string representing groupings for the -<span class="lineNum"> 1770 </span> : * integer part of a number. Groupings indicate where thousands -<span class="lineNum"> 1771 </span> : * separators should be inserted in the integer part of a number. -<span class="lineNum"> 1772 </span> : * -<span class="lineNum"> 1773 </span> : * Each char in the return string is interpret as an integer -<span class="lineNum"> 1774 </span> : * rather than a character. These numbers represent the number -<span class="lineNum"> 1775 </span> : * of digits in a group. The first char in the string -<span class="lineNum"> 1776 </span> : * represents the number of digits in the least significant -<span class="lineNum"> 1777 </span> : * group. If a char is negative, it indicates an unlimited -<span class="lineNum"> 1778 </span> : * number of digits for the group. If more chars from the -<span class="lineNum"> 1779 </span> : * string are required to group a number, the last char is used -<span class="lineNum"> 1780 </span> : * repeatedly. -<span class="lineNum"> 1781 </span> : * -<span class="lineNum"> 1782 </span> : * For example, if the grouping() returns "\003\002" and is -<span class="lineNum"> 1783 </span> : * applied to the number 123456789, this corresponds to -<span class="lineNum"> 1784 </span> : * 12,34,56,789. Note that if the string was "32", this would -<span class="lineNum"> 1785 </span> : * put more than 50 digits into the least significant group if -<span class="lineNum"> 1786 </span> : * the character set is ASCII. -<span class="lineNum"> 1787 </span> : * -<span class="lineNum"> 1788 </span> : * The string is returned by calling -<span class="lineNum"> 1789 </span> : * numpunct<char_type>::do_grouping(). -<span class="lineNum"> 1790 </span> : * -<span class="lineNum"> 1791 </span> : * @return string representing grouping specification. -<span class="lineNum"> 1792 </span> : */ -<span class="lineNum"> 1793 </span> : string -<span class="lineNum"> 1794 </span> : grouping() const -<span class="lineNum"> 1795 </span> : { return this->do_grouping(); } -<span class="lineNum"> 1796 </span> : -<span class="lineNum"> 1797 </span> : /** -<span class="lineNum"> 1798 </span> : * @brief Return string representation of bool true. -<span class="lineNum"> 1799 </span> : * -<span class="lineNum"> 1800 </span> : * This function returns a string_type containing the text -<span class="lineNum"> 1801 </span> : * representation for true bool variables. It does so by calling -<span class="lineNum"> 1802 </span> : * numpunct<char_type>::do_truename(). -<span class="lineNum"> 1803 </span> : * -<span class="lineNum"> 1804 </span> : * @return string_type representing printed form of true. -<span class="lineNum"> 1805 </span> : */ -<span class="lineNum"> 1806 </span> : string_type -<span class="lineNum"> 1807 </span> : truename() const -<span class="lineNum"> 1808 </span> : { return this->do_truename(); } -<span class="lineNum"> 1809 </span> : -<span class="lineNum"> 1810 </span> : /** -<span class="lineNum"> 1811 </span> : * @brief Return string representation of bool false. -<span class="lineNum"> 1812 </span> : * -<span class="lineNum"> 1813 </span> : * This function returns a string_type containing the text -<span class="lineNum"> 1814 </span> : * representation for false bool variables. It does so by calling -<span class="lineNum"> 1815 </span> : * numpunct<char_type>::do_falsename(). -<span class="lineNum"> 1816 </span> : * -<span class="lineNum"> 1817 </span> : * @return string_type representing printed form of false. -<span class="lineNum"> 1818 </span> : */ -<span class="lineNum"> 1819 </span> : string_type -<span class="lineNum"> 1820 </span> : falsename() const -<span class="lineNum"> 1821 </span> : { return this->do_falsename(); } -<span class="lineNum"> 1822 </span> : -<span class="lineNum"> 1823 </span> : protected: -<span class="lineNum"> 1824 </span> : /// Destructor. -<span class="lineNum"> 1825 </span> : virtual -<span class="lineNum"> 1826 </span> : ~numpunct(); -<span class="lineNum"> 1827 </span> : -<span class="lineNum"> 1828 </span> : /** -<span class="lineNum"> 1829 </span> : * @brief Return decimal point character. -<span class="lineNum"> 1830 </span> : * -<span class="lineNum"> 1831 </span> : * Returns a char_type to use as a decimal point. This function is a -<span class="lineNum"> 1832 </span> : * hook for derived classes to change the value returned. -<span class="lineNum"> 1833 </span> : * -<span class="lineNum"> 1834 </span> : * @return @a char_type representing a decimal point. -<span class="lineNum"> 1835 </span> : */ -<span class="lineNum"> 1836 </span> : virtual char_type -<span class="lineNum"> 1837 </span> : do_decimal_point() const -<span class="lineNum"> 1838 </span> : { return _M_data->_M_decimal_point; } -<span class="lineNum"> 1839 </span> : -<span class="lineNum"> 1840 </span> : /** -<span class="lineNum"> 1841 </span> : * @brief Return thousands separator character. -<span class="lineNum"> 1842 </span> : * -<span class="lineNum"> 1843 </span> : * Returns a char_type to use as a thousands separator. This function -<span class="lineNum"> 1844 </span> : * is a hook for derived classes to change the value returned. -<span class="lineNum"> 1845 </span> : * -<span class="lineNum"> 1846 </span> : * @return @a char_type representing a thousands separator. -<span class="lineNum"> 1847 </span> : */ -<span class="lineNum"> 1848 </span> : virtual char_type -<span class="lineNum"> 1849 </span> : do_thousands_sep() const -<span class="lineNum"> 1850 </span> : { return _M_data->_M_thousands_sep; } -<span class="lineNum"> 1851 </span> : -<span class="lineNum"> 1852 </span> : /** -<span class="lineNum"> 1853 </span> : * @brief Return grouping specification. -<span class="lineNum"> 1854 </span> : * -<span class="lineNum"> 1855 </span> : * Returns a string representing groupings for the integer part of a -<span class="lineNum"> 1856 </span> : * number. This function is a hook for derived classes to change the -<span class="lineNum"> 1857 </span> : * value returned. @see grouping() for details. -<span class="lineNum"> 1858 </span> : * -<span class="lineNum"> 1859 </span> : * @return String representing grouping specification. -<span class="lineNum"> 1860 </span> : */ -<span class="lineNum"> 1861 </span> : virtual string -<span class="lineNum"> 1862 </span> : do_grouping() const -<span class="lineNum"> 1863 </span> : { return _M_data->_M_grouping; } -<span class="lineNum"> 1864 </span> : -<span class="lineNum"> 1865 </span> : /** -<span class="lineNum"> 1866 </span> : * @brief Return string representation of bool true. -<span class="lineNum"> 1867 </span> : * -<span class="lineNum"> 1868 </span> : * Returns a string_type containing the text representation for true -<span class="lineNum"> 1869 </span> : * bool variables. This function is a hook for derived classes to -<span class="lineNum"> 1870 </span> : * change the value returned. -<span class="lineNum"> 1871 </span> : * -<span class="lineNum"> 1872 </span> : * @return string_type representing printed form of true. -<span class="lineNum"> 1873 </span> : */ -<span class="lineNum"> 1874 </span> : virtual string_type -<span class="lineNum"> 1875 </span> : do_truename() const -<span class="lineNum"> 1876 </span> : { return _M_data->_M_truename; } -<span class="lineNum"> 1877 </span> : -<span class="lineNum"> 1878 </span> : /** -<span class="lineNum"> 1879 </span> : * @brief Return string representation of bool false. -<span class="lineNum"> 1880 </span> : * -<span class="lineNum"> 1881 </span> : * Returns a string_type containing the text representation for false -<span class="lineNum"> 1882 </span> : * bool variables. This function is a hook for derived classes to -<span class="lineNum"> 1883 </span> : * change the value returned. -<span class="lineNum"> 1884 </span> : * -<span class="lineNum"> 1885 </span> : * @return string_type representing printed form of false. -<span class="lineNum"> 1886 </span> : */ -<span class="lineNum"> 1887 </span> : virtual string_type -<span class="lineNum"> 1888 </span> : do_falsename() const -<span class="lineNum"> 1889 </span> : { return _M_data->_M_falsename; } -<span class="lineNum"> 1890 </span> : -<span class="lineNum"> 1891 </span> : // For use at construction time only. -<span class="lineNum"> 1892 </span> : void -<span class="lineNum"> 1893 </span> : _M_initialize_numpunct(__c_locale __cloc = NULL); -<span class="lineNum"> 1894 </span> : }; -<span class="lineNum"> 1895 </span> : -<span class="lineNum"> 1896 </span> : template<typename _CharT> -<span class="lineNum"> 1897 </span> : locale::id numpunct<_CharT>::id; -<span class="lineNum"> 1898 </span> : -<span class="lineNum"> 1899 </span> : template<> -<span class="lineNum"> 1900 </span> : numpunct<char>::~numpunct(); -<span class="lineNum"> 1901 </span> : -<span class="lineNum"> 1902 </span> : template<> -<span class="lineNum"> 1903 </span> : void -<span class="lineNum"> 1904 </span> : numpunct<char>::_M_initialize_numpunct(__c_locale __cloc); -<span class="lineNum"> 1905 </span> : -<span class="lineNum"> 1906 </span> : #ifdef _GLIBCXX_USE_WCHAR_T -<span class="lineNum"> 1907 </span> : template<> -<span class="lineNum"> 1908 </span> : numpunct<wchar_t>::~numpunct(); -<span class="lineNum"> 1909 </span> : -<span class="lineNum"> 1910 </span> : template<> -<span class="lineNum"> 1911 </span> : void -<span class="lineNum"> 1912 </span> : numpunct<wchar_t>::_M_initialize_numpunct(__c_locale __cloc); -<span class="lineNum"> 1913 </span> : #endif -<span class="lineNum"> 1914 </span> : -<span class="lineNum"> 1915 </span> : /// class numpunct_byname [22.2.3.2]. -<span class="lineNum"> 1916 </span> : template<typename _CharT> -<span class="lineNum"> 1917 </span> : class numpunct_byname : public numpunct<_CharT> -<span class="lineNum"> 1918 </span> : { -<span class="lineNum"> 1919 </span> : public: -<span class="lineNum"> 1920 </span> : typedef _CharT char_type; -<span class="lineNum"> 1921 </span> : typedef basic_string<_CharT> string_type; -<span class="lineNum"> 1922 </span> : -<span class="lineNum"> 1923 </span> : explicit -<span class="lineNum"> 1924 </span> : numpunct_byname(const char* __s, size_t __refs = 0) -<span class="lineNum"> 1925 </span> : : numpunct<_CharT>(__refs) -<span class="lineNum"> 1926 </span> : { -<span class="lineNum"> 1927 </span> : if (__builtin_strcmp(__s, "C") != 0 -<span class="lineNum"> 1928 </span> : && __builtin_strcmp(__s, "POSIX") != 0) -<span class="lineNum"> 1929 </span> : { -<span class="lineNum"> 1930 </span> : __c_locale __tmp; -<span class="lineNum"> 1931 </span> : this->_S_create_c_locale(__tmp, __s); -<span class="lineNum"> 1932 </span> : this->_M_initialize_numpunct(__tmp); -<span class="lineNum"> 1933 </span> : this->_S_destroy_c_locale(__tmp); -<span class="lineNum"> 1934 </span> : } -<span class="lineNum"> 1935 </span> : } -<span class="lineNum"> 1936 </span> : -<span class="lineNum"> 1937 </span> : protected: -<span class="lineNum"> 1938 </span> : virtual -<span class="lineNum"> 1939 </span> : ~numpunct_byname() { } -<span class="lineNum"> 1940 </span> : }; -<span class="lineNum"> 1941 </span> : -<span class="lineNum"> 1942 </span> : _GLIBCXX_BEGIN_LDBL_NAMESPACE -<span class="lineNum"> 1943 </span> : -<span class="lineNum"> 1944 </span> : /** -<span class="lineNum"> 1945 </span> : * @brief Facet for parsing number strings. -<span class="lineNum"> 1946 </span> : * -<span class="lineNum"> 1947 </span> : * This facet encapsulates the code to parse and return a number -<span class="lineNum"> 1948 </span> : * from a string. It is used by the istream numeric extraction -<span class="lineNum"> 1949 </span> : * operators. -<span class="lineNum"> 1950 </span> : * -<span class="lineNum"> 1951 </span> : * The num_get template uses protected virtual functions to provide the -<span class="lineNum"> 1952 </span> : * actual results. The public accessors forward the call to the virtual -<span class="lineNum"> 1953 </span> : * functions. These virtual functions are hooks for developers to -<span class="lineNum"> 1954 </span> : * implement the behavior they require from the num_get facet. -<span class="lineNum"> 1955 </span> : */ -<span class="lineNum"> 1956 </span> : template<typename _CharT, typename _InIter> -<span class="lineNum"> 1957 </span> : class num_get : public locale::facet -<span class="lineNum"> 1958 </span> : { -<span class="lineNum"> 1959 </span> : public: -<span class="lineNum"> 1960 </span> : // Types: -<span class="lineNum"> 1961 </span> : //@{ -<span class="lineNum"> 1962 </span> : /// Public typedefs -<span class="lineNum"> 1963 </span> : typedef _CharT char_type; -<span class="lineNum"> 1964 </span> : typedef _InIter iter_type; -<span class="lineNum"> 1965 </span> : //@} -<span class="lineNum"> 1966 </span> : -<span class="lineNum"> 1967 </span> : /// Numpunct facet id. -<span class="lineNum"> 1968 </span> : static locale::id id; -<span class="lineNum"> 1969 </span> : -<span class="lineNum"> 1970 </span> : /** -<span class="lineNum"> 1971 </span> : * @brief Constructor performs initialization. -<span class="lineNum"> 1972 </span> : * -<span class="lineNum"> 1973 </span> : * This is the constructor provided by the standard. -<span class="lineNum"> 1974 </span> : * -<span class="lineNum"> 1975 </span> : * @param refs Passed to the base facet class. -<span class="lineNum"> 1976 </span> : */ -<span class="lineNum"> 1977 </span> : explicit -<span class="lineNum"> 1978 </span> : num_get(size_t __refs = 0) : facet(__refs) { } -<span class="lineNum"> 1979 </span> : -<span class="lineNum"> 1980 </span> : /** -<span class="lineNum"> 1981 </span> : * @brief Numeric parsing. -<span class="lineNum"> 1982 </span> : * -<span class="lineNum"> 1983 </span> : * Parses the input stream into the bool @a v. It does so by calling -<span class="lineNum"> 1984 </span> : * num_get::do_get(). -<span class="lineNum"> 1985 </span> : * -<span class="lineNum"> 1986 </span> : * If ios_base::boolalpha is set, attempts to read -<span class="lineNum"> 1987 </span> : * ctype<CharT>::truename() or ctype<CharT>::falsename(). Sets -<span class="lineNum"> 1988 </span> : * @a v to true or false if successful. Sets err to -<span class="lineNum"> 1989 </span> : * ios_base::failbit if reading the string fails. Sets err to -<span class="lineNum"> 1990 </span> : * ios_base::eofbit if the stream is emptied. -<span class="lineNum"> 1991 </span> : * -<span class="lineNum"> 1992 </span> : * If ios_base::boolalpha is not set, proceeds as with reading a long, -<span class="lineNum"> 1993 </span> : * except if the value is 1, sets @a v to true, if the value is 0, sets -<span class="lineNum"> 1994 </span> : * @a v to false, and otherwise set err to ios_base::failbit. -<span class="lineNum"> 1995 </span> : * -<span class="lineNum"> 1996 </span> : * @param in Start of input stream. -<span class="lineNum"> 1997 </span> : * @param end End of input stream. -<span class="lineNum"> 1998 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 1999 </span> : * @param err Error flags to set. -<span class="lineNum"> 2000 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2001 </span> : * @return Iterator after reading. -<span class="lineNum"> 2002 </span> : */ -<span class="lineNum"> 2003 </span> : iter_type -<span class="lineNum"> 2004 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2005 </span> : ios_base::iostate& __err, bool& __v) const -<span class="lineNum"> 2006 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2007 </span> : -<span class="lineNum"> 2008 </span> : //@{ -<span class="lineNum"> 2009 </span> : /** -<span class="lineNum"> 2010 </span> : * @brief Numeric parsing. -<span class="lineNum"> 2011 </span> : * -<span class="lineNum"> 2012 </span> : * Parses the input stream into the integral variable @a v. It does so -<span class="lineNum"> 2013 </span> : * by calling num_get::do_get(). -<span class="lineNum"> 2014 </span> : * -<span class="lineNum"> 2015 </span> : * Parsing is affected by the flag settings in @a io. -<span class="lineNum"> 2016 </span> : * -<span class="lineNum"> 2017 </span> : * The basic parse is affected by the value of io.flags() & -<span class="lineNum"> 2018 </span> : * ios_base::basefield. If equal to ios_base::oct, parses like the -<span class="lineNum"> 2019 </span> : * scanf %o specifier. Else if equal to ios_base::hex, parses like %X -<span class="lineNum"> 2020 </span> : * specifier. Else if basefield equal to 0, parses like the %i -<span class="lineNum"> 2021 </span> : * specifier. Otherwise, parses like %d for signed and %u for unsigned -<span class="lineNum"> 2022 </span> : * types. The matching type length modifier is also used. -<span class="lineNum"> 2023 </span> : * -<span class="lineNum"> 2024 </span> : * Digit grouping is interpreted according to numpunct::grouping() and -<span class="lineNum"> 2025 </span> : * numpunct::thousands_sep(). If the pattern of digit groups isn't -<span class="lineNum"> 2026 </span> : * consistent, sets err to ios_base::failbit. -<span class="lineNum"> 2027 </span> : * -<span class="lineNum"> 2028 </span> : * If parsing the string yields a valid value for @a v, @a v is set. -<span class="lineNum"> 2029 </span> : * Otherwise, sets err to ios_base::failbit and leaves @a v unaltered. -<span class="lineNum"> 2030 </span> : * Sets err to ios_base::eofbit if the stream is emptied. -<span class="lineNum"> 2031 </span> : * -<span class="lineNum"> 2032 </span> : * @param in Start of input stream. -<span class="lineNum"> 2033 </span> : * @param end End of input stream. -<span class="lineNum"> 2034 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2035 </span> : * @param err Error flags to set. -<span class="lineNum"> 2036 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2037 </span> : * @return Iterator after reading. -<span class="lineNum"> 2038 </span> : */ -<span class="lineNum"> 2039 </span> : iter_type -<span class="lineNum"> 2040 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2041 </span> : ios_base::iostate& __err, long& __v) const -<span class="lineNum"> 2042 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2043 </span> : -<span class="lineNum"> 2044 </span> : iter_type -<span class="lineNum"> 2045 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2046 </span> : ios_base::iostate& __err, unsigned short& __v) const -<span class="lineNum"> 2047 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2048 </span> : -<span class="lineNum"> 2049 </span> : iter_type -<span class="lineNum"> 2050 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2051 </span> : ios_base::iostate& __err, unsigned int& __v) const -<span class="lineNum"> 2052 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2053 </span> : -<span class="lineNum"> 2054 </span> : iter_type -<span class="lineNum"> 2055 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2056 </span> : ios_base::iostate& __err, unsigned long& __v) const -<span class="lineNum"> 2057 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2058 </span> : -<span class="lineNum"> 2059 </span> : #ifdef _GLIBCXX_USE_LONG_LONG -<span class="lineNum"> 2060 </span> : iter_type -<span class="lineNum"> 2061 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2062 </span> : ios_base::iostate& __err, long long& __v) const -<span class="lineNum"> 2063 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2064 </span> : -<span class="lineNum"> 2065 </span> : iter_type -<span class="lineNum"> 2066 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2067 </span> : ios_base::iostate& __err, unsigned long long& __v) const -<span class="lineNum"> 2068 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2069 </span> : #endif -<span class="lineNum"> 2070 </span> : //@} -<span class="lineNum"> 2071 </span> : -<span class="lineNum"> 2072 </span> : //@{ -<span class="lineNum"> 2073 </span> : /** -<span class="lineNum"> 2074 </span> : * @brief Numeric parsing. -<span class="lineNum"> 2075 </span> : * -<span class="lineNum"> 2076 </span> : * Parses the input stream into the integral variable @a v. It does so -<span class="lineNum"> 2077 </span> : * by calling num_get::do_get(). -<span class="lineNum"> 2078 </span> : * -<span class="lineNum"> 2079 </span> : * The input characters are parsed like the scanf %g specifier. The -<span class="lineNum"> 2080 </span> : * matching type length modifier is also used. -<span class="lineNum"> 2081 </span> : * -<span class="lineNum"> 2082 </span> : * The decimal point character used is numpunct::decimal_point(). -<span class="lineNum"> 2083 </span> : * Digit grouping is interpreted according to numpunct::grouping() and -<span class="lineNum"> 2084 </span> : * numpunct::thousands_sep(). If the pattern of digit groups isn't -<span class="lineNum"> 2085 </span> : * consistent, sets err to ios_base::failbit. -<span class="lineNum"> 2086 </span> : * -<span class="lineNum"> 2087 </span> : * If parsing the string yields a valid value for @a v, @a v is set. -<span class="lineNum"> 2088 </span> : * Otherwise, sets err to ios_base::failbit and leaves @a v unaltered. -<span class="lineNum"> 2089 </span> : * Sets err to ios_base::eofbit if the stream is emptied. -<span class="lineNum"> 2090 </span> : * -<span class="lineNum"> 2091 </span> : * @param in Start of input stream. -<span class="lineNum"> 2092 </span> : * @param end End of input stream. -<span class="lineNum"> 2093 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2094 </span> : * @param err Error flags to set. -<span class="lineNum"> 2095 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2096 </span> : * @return Iterator after reading. -<span class="lineNum"> 2097 </span> : */ -<span class="lineNum"> 2098 </span> : iter_type -<span class="lineNum"> 2099 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2100 </span> : ios_base::iostate& __err, float& __v) const -<span class="lineNum"> 2101 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2102 </span> : -<span class="lineNum"> 2103 </span> : iter_type -<span class="lineNum"> 2104 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2105 </span> : ios_base::iostate& __err, double& __v) const -<span class="lineNum"> 2106 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2107 </span> : -<span class="lineNum"> 2108 </span> : iter_type -<span class="lineNum"> 2109 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2110 </span> : ios_base::iostate& __err, long double& __v) const -<span class="lineNum"> 2111 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2112 </span> : //@} -<span class="lineNum"> 2113 </span> : -<span class="lineNum"> 2114 </span> : /** -<span class="lineNum"> 2115 </span> : * @brief Numeric parsing. -<span class="lineNum"> 2116 </span> : * -<span class="lineNum"> 2117 </span> : * Parses the input stream into the pointer variable @a v. It does so -<span class="lineNum"> 2118 </span> : * by calling num_get::do_get(). -<span class="lineNum"> 2119 </span> : * -<span class="lineNum"> 2120 </span> : * The input characters are parsed like the scanf %p specifier. -<span class="lineNum"> 2121 </span> : * -<span class="lineNum"> 2122 </span> : * Digit grouping is interpreted according to numpunct::grouping() and -<span class="lineNum"> 2123 </span> : * numpunct::thousands_sep(). If the pattern of digit groups isn't -<span class="lineNum"> 2124 </span> : * consistent, sets err to ios_base::failbit. -<span class="lineNum"> 2125 </span> : * -<span class="lineNum"> 2126 </span> : * Note that the digit grouping effect for pointers is a bit ambiguous -<span class="lineNum"> 2127 </span> : * in the standard and shouldn't be relied on. See DR 344. -<span class="lineNum"> 2128 </span> : * -<span class="lineNum"> 2129 </span> : * If parsing the string yields a valid value for @a v, @a v is set. -<span class="lineNum"> 2130 </span> : * Otherwise, sets err to ios_base::failbit and leaves @a v unaltered. -<span class="lineNum"> 2131 </span> : * Sets err to ios_base::eofbit if the stream is emptied. -<span class="lineNum"> 2132 </span> : * -<span class="lineNum"> 2133 </span> : * @param in Start of input stream. -<span class="lineNum"> 2134 </span> : * @param end End of input stream. -<span class="lineNum"> 2135 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2136 </span> : * @param err Error flags to set. -<span class="lineNum"> 2137 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2138 </span> : * @return Iterator after reading. -<span class="lineNum"> 2139 </span> : */ -<span class="lineNum"> 2140 </span> : iter_type -<span class="lineNum"> 2141 </span> : get(iter_type __in, iter_type __end, ios_base& __io, -<span class="lineNum"> 2142 </span> : ios_base::iostate& __err, void*& __v) const -<span class="lineNum"> 2143 </span> : { return this->do_get(__in, __end, __io, __err, __v); } -<span class="lineNum"> 2144 </span> : -<span class="lineNum"> 2145 </span> : protected: -<span class="lineNum"> 2146 </span> : /// Destructor. -<span class="lineNum"> 2147 </span> : virtual ~num_get() { } -<span class="lineNum"> 2148 </span> : -<span class="lineNum"> 2149 </span> : iter_type -<span class="lineNum"> 2150 </span> : _M_extract_float(iter_type, iter_type, ios_base&, ios_base::iostate&, -<span class="lineNum"> 2151 </span> : string& __xtrc) const; -<span class="lineNum"> 2152 </span> : -<span class="lineNum"> 2153 </span> : template<typename _ValueT> -<span class="lineNum"> 2154 </span> : iter_type -<span class="lineNum"> 2155 </span> : _M_extract_int(iter_type, iter_type, ios_base&, ios_base::iostate&, -<span class="lineNum"> 2156 </span> : _ValueT& __v) const; -<span class="lineNum"> 2157 </span> : -<span class="lineNum"> 2158 </span> : template<typename _CharT2> -<span class="lineNum"> 2159 </span> : typename __gnu_cxx::__enable_if<__is_char<_CharT2>::__value, int>::__type -<span class="lineNum"> 2160 </span> : _M_find(const _CharT2*, size_t __len, _CharT2 __c) const -<span class="lineNum"> 2161 </span> : { -<span class="lineNum"> 2162 </span> : int __ret = -1; -<span class="lineNum"> 2163 </span> : if (__len <= 10) -<span class="lineNum"> 2164 </span> : { -<span class="lineNum"> 2165 </span> : if (__c >= _CharT2('0') && __c < _CharT2(_CharT2('0') + __len)) -<span class="lineNum"> 2166 </span> : __ret = __c - _CharT2('0'); -<span class="lineNum"> 2167 </span> : } -<span class="lineNum"> 2168 </span> : else -<span class="lineNum"> 2169 </span> : { -<span class="lineNum"> 2170 </span> : if (__c >= _CharT2('0') && __c <= _CharT2('9')) -<span class="lineNum"> 2171 </span> : __ret = __c - _CharT2('0'); -<span class="lineNum"> 2172 </span> : else if (__c >= _CharT2('a') && __c <= _CharT2('f')) -<span class="lineNum"> 2173 </span> : __ret = 10 + (__c - _CharT2('a')); -<span class="lineNum"> 2174 </span> : else if (__c >= _CharT2('A') && __c <= _CharT2('F')) -<span class="lineNum"> 2175 </span> : __ret = 10 + (__c - _CharT2('A')); -<span class="lineNum"> 2176 </span> : } -<span class="lineNum"> 2177 </span> : return __ret; -<span class="lineNum"> 2178 </span> : } -<span class="lineNum"> 2179 </span> : -<span class="lineNum"> 2180 </span> : template<typename _CharT2> -<span class="lineNum"> 2181 </span> : typename __gnu_cxx::__enable_if<!__is_char<_CharT2>::__value, -<span class="lineNum"> 2182 </span> : int>::__type -<span class="lineNum"> 2183 </span> : _M_find(const _CharT2* __zero, size_t __len, _CharT2 __c) const -<span class="lineNum"> 2184 </span> : { -<span class="lineNum"> 2185 </span> : int __ret = -1; -<span class="lineNum"> 2186 </span> : const char_type* __q = char_traits<_CharT2>::find(__zero, __len, __c); -<span class="lineNum"> 2187 </span> : if (__q) -<span class="lineNum"> 2188 </span> : { -<span class="lineNum"> 2189 </span> : __ret = __q - __zero; -<span class="lineNum"> 2190 </span> : if (__ret > 15) -<span class="lineNum"> 2191 </span> : __ret -= 6; -<span class="lineNum"> 2192 </span> : } -<span class="lineNum"> 2193 </span> : return __ret; -<span class="lineNum"> 2194 </span> : } -<span class="lineNum"> 2195 </span> : -<span class="lineNum"> 2196 </span> : //@{ -<span class="lineNum"> 2197 </span> : /** -<span class="lineNum"> 2198 </span> : * @brief Numeric parsing. -<span class="lineNum"> 2199 </span> : * -<span class="lineNum"> 2200 </span> : * Parses the input stream into the variable @a v. This function is a -<span class="lineNum"> 2201 </span> : * hook for derived classes to change the value returned. @see get() -<span class="lineNum"> 2202 </span> : * for more details. -<span class="lineNum"> 2203 </span> : * -<span class="lineNum"> 2204 </span> : * @param in Start of input stream. -<span class="lineNum"> 2205 </span> : * @param end End of input stream. -<span class="lineNum"> 2206 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2207 </span> : * @param err Error flags to set. -<span class="lineNum"> 2208 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2209 </span> : * @return Iterator after reading. -<span class="lineNum"> 2210 </span> : */ -<span class="lineNum"> 2211 </span> : virtual iter_type -<span class="lineNum"> 2212 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate&, bool&) const; -<span class="lineNum"> 2213 </span> : -<span class="lineNum"> 2214 </span> : -<span class="lineNum"> 2215 </span> : virtual iter_type -<span class="lineNum"> 2216 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate&, long&) const; -<span class="lineNum"> 2217 </span> : -<span class="lineNum"> 2218 </span> : virtual iter_type -<span class="lineNum"> 2219 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2220 </span> : unsigned short&) const; -<span class="lineNum"> 2221 </span> : -<span class="lineNum"> 2222 </span> : virtual iter_type -<span class="lineNum"> 2223 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2224 </span> : unsigned int&) const; -<span class="lineNum"> 2225 </span> : -<span class="lineNum"> 2226 </span> : virtual iter_type -<span class="lineNum"> 2227 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2228 </span> : unsigned long&) const; -<span class="lineNum"> 2229 </span> : -<span class="lineNum"> 2230 </span> : #ifdef _GLIBCXX_USE_LONG_LONG -<span class="lineNum"> 2231 </span> : virtual iter_type -<span class="lineNum"> 2232 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2233 </span> : long long&) const; -<span class="lineNum"> 2234 </span> : -<span class="lineNum"> 2235 </span> : virtual iter_type -<span class="lineNum"> 2236 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2237 </span> : unsigned long long&) const; -<span class="lineNum"> 2238 </span> : #endif -<span class="lineNum"> 2239 </span> : -<span class="lineNum"> 2240 </span> : virtual iter_type -<span class="lineNum"> 2241 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2242 </span> : float&) const; -<span class="lineNum"> 2243 </span> : -<span class="lineNum"> 2244 </span> : virtual iter_type -<span class="lineNum"> 2245 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2246 </span> : double&) const; -<span class="lineNum"> 2247 </span> : -<span class="lineNum"> 2248 </span> : // XXX GLIBCXX_ABI Deprecated -<span class="lineNum"> 2249 </span> : #if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -<span class="lineNum"> 2250 </span> : virtual iter_type -<span class="lineNum"> 2251 </span> : __do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2252 </span> : double&) const; -<span class="lineNum"> 2253 </span> : #else -<span class="lineNum"> 2254 </span> : virtual iter_type -<span class="lineNum"> 2255 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2256 </span> : long double&) const; -<span class="lineNum"> 2257 </span> : #endif -<span class="lineNum"> 2258 </span> : -<span class="lineNum"> 2259 </span> : virtual iter_type -<span class="lineNum"> 2260 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2261 </span> : void*&) const; -<span class="lineNum"> 2262 </span> : -<span class="lineNum"> 2263 </span> : // XXX GLIBCXX_ABI Deprecated -<span class="lineNum"> 2264 </span> : #if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -<span class="lineNum"> 2265 </span> : virtual iter_type -<span class="lineNum"> 2266 </span> : do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -<span class="lineNum"> 2267 </span> : long double&) const; -<span class="lineNum"> 2268 </span> : #endif -<span class="lineNum"> 2269 </span> : //@} -<span class="lineNum"> 2270 </span> : }; -<span class="lineNum"> 2271 </span> : -<span class="lineNum"> 2272 </span> : template<typename _CharT, typename _InIter> -<span class="lineNum"> 2273 </span> : locale::id num_get<_CharT, _InIter>::id; -<span class="lineNum"> 2274 </span> : -<span class="lineNum"> 2275 </span> : -<span class="lineNum"> 2276 </span> : /** -<span class="lineNum"> 2277 </span> : * @brief Facet for converting numbers to strings. -<span class="lineNum"> 2278 </span> : * -<span class="lineNum"> 2279 </span> : * This facet encapsulates the code to convert a number to a string. It is -<span class="lineNum"> 2280 </span> : * used by the ostream numeric insertion operators. -<span class="lineNum"> 2281 </span> : * -<span class="lineNum"> 2282 </span> : * The num_put template uses protected virtual functions to provide the -<span class="lineNum"> 2283 </span> : * actual results. The public accessors forward the call to the virtual -<span class="lineNum"> 2284 </span> : * functions. These virtual functions are hooks for developers to -<span class="lineNum"> 2285 </span> : * implement the behavior they require from the num_put facet. -<span class="lineNum"> 2286 </span> : */ -<span class="lineNum"> 2287 </span> : template<typename _CharT, typename _OutIter> -<span class="lineNum"> 2288 </span> : class num_put : public locale::facet -<span class="lineNum"> 2289 </span> : { -<span class="lineNum"> 2290 </span> : public: -<span class="lineNum"> 2291 </span> : // Types: -<span class="lineNum"> 2292 </span> : //@{ -<span class="lineNum"> 2293 </span> : /// Public typedefs -<span class="lineNum"> 2294 </span> : typedef _CharT char_type; -<span class="lineNum"> 2295 </span> : typedef _OutIter iter_type; -<span class="lineNum"> 2296 </span> : //@} -<span class="lineNum"> 2297 </span> : -<span class="lineNum"> 2298 </span> : /// Numpunct facet id. -<span class="lineNum"> 2299 </span> : static locale::id id; -<span class="lineNum"> 2300 </span> : -<span class="lineNum"> 2301 </span> : /** -<span class="lineNum"> 2302 </span> : * @brief Constructor performs initialization. -<span class="lineNum"> 2303 </span> : * -<span class="lineNum"> 2304 </span> : * This is the constructor provided by the standard. -<span class="lineNum"> 2305 </span> : * -<span class="lineNum"> 2306 </span> : * @param refs Passed to the base facet class. -<span class="lineNum"> 2307 </span> : */ -<span class="lineNum"> 2308 </span> : explicit -<span class="lineNum"> 2309 </span> : num_put(size_t __refs = 0) : facet(__refs) { } -<span class="lineNum"> 2310 </span> : -<span class="lineNum"> 2311 </span> : /** -<span class="lineNum"> 2312 </span> : * @brief Numeric formatting. -<span class="lineNum"> 2313 </span> : * -<span class="lineNum"> 2314 </span> : * Formats the boolean @a v and inserts it into a stream. It does so -<span class="lineNum"> 2315 </span> : * by calling num_put::do_put(). -<span class="lineNum"> 2316 </span> : * -<span class="lineNum"> 2317 </span> : * If ios_base::boolalpha is set, writes ctype<CharT>::truename() or -<span class="lineNum"> 2318 </span> : * ctype<CharT>::falsename(). Otherwise formats @a v as an int. -<span class="lineNum"> 2319 </span> : * -<span class="lineNum"> 2320 </span> : * @param s Stream to write to. -<span class="lineNum"> 2321 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2322 </span> : * @param fill Char_type to use for filling. -<span class="lineNum"> 2323 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2324 </span> : * @return Iterator after writing. -<span class="lineNum"> 2325 </span> : */ -<span class="lineNum"> 2326 </span> : iter_type -<span class="lineNum"> 2327 </span> : put(iter_type __s, ios_base& __f, char_type __fill, bool __v) const -<span class="lineNum"> 2328 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2329 </span> : -<span class="lineNum"> 2330 </span> : //@{ -<span class="lineNum"> 2331 </span> : /** -<span class="lineNum"> 2332 </span> : * @brief Numeric formatting. -<span class="lineNum"> 2333 </span> : * -<span class="lineNum"> 2334 </span> : * Formats the integral value @a v and inserts it into a -<span class="lineNum"> 2335 </span> : * stream. It does so by calling num_put::do_put(). -<span class="lineNum"> 2336 </span> : * -<span class="lineNum"> 2337 </span> : * Formatting is affected by the flag settings in @a io. -<span class="lineNum"> 2338 </span> : * -<span class="lineNum"> 2339 </span> : * The basic format is affected by the value of io.flags() & -<span class="lineNum"> 2340 </span> : * ios_base::basefield. If equal to ios_base::oct, formats like the -<span class="lineNum"> 2341 </span> : * printf %o specifier. Else if equal to ios_base::hex, formats like -<span class="lineNum"> 2342 </span> : * %x or %X with ios_base::uppercase unset or set respectively. -<span class="lineNum"> 2343 </span> : * Otherwise, formats like %d, %ld, %lld for signed and %u, %lu, %llu -<span class="lineNum"> 2344 </span> : * for unsigned values. Note that if both oct and hex are set, neither -<span class="lineNum"> 2345 </span> : * will take effect. -<span class="lineNum"> 2346 </span> : * -<span class="lineNum"> 2347 </span> : * If ios_base::showpos is set, '+' is output before positive values. -<span class="lineNum"> 2348 </span> : * If ios_base::showbase is set, '0' precedes octal values (except 0) -<span class="lineNum"> 2349 </span> : * and '0[xX]' precedes hex values. -<span class="lineNum"> 2350 </span> : * -<span class="lineNum"> 2351 </span> : * Thousands separators are inserted according to numpunct::grouping() -<span class="lineNum"> 2352 </span> : * and numpunct::thousands_sep(). The decimal point character used is -<span class="lineNum"> 2353 </span> : * numpunct::decimal_point(). -<span class="lineNum"> 2354 </span> : * -<span class="lineNum"> 2355 </span> : * If io.width() is non-zero, enough @a fill characters are inserted to -<span class="lineNum"> 2356 </span> : * make the result at least that wide. If -<span class="lineNum"> 2357 </span> : * (io.flags() & ios_base::adjustfield) == ios_base::left, result is -<span class="lineNum"> 2358 </span> : * padded at the end. If ios_base::internal, then padding occurs -<span class="lineNum"> 2359 </span> : * immediately after either a '+' or '-' or after '0x' or '0X'. -<span class="lineNum"> 2360 </span> : * Otherwise, padding occurs at the beginning. -<span class="lineNum"> 2361 </span> : * -<span class="lineNum"> 2362 </span> : * @param s Stream to write to. -<span class="lineNum"> 2363 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2364 </span> : * @param fill Char_type to use for filling. -<span class="lineNum"> 2365 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2366 </span> : * @return Iterator after writing. -<span class="lineNum"> 2367 </span> : */ -<span class="lineNum"> 2368 </span> : iter_type -<span class="lineNum"> 2369 </span> : put(iter_type __s, ios_base& __f, char_type __fill, long __v) const -<span class="lineNum"> 2370 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2371 </span> : -<span class="lineNum"> 2372 </span> : iter_type -<span class="lineNum"> 2373 </span> : put(iter_type __s, ios_base& __f, char_type __fill, -<span class="lineNum"> 2374 </span> : unsigned long __v) const -<span class="lineNum"> 2375 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2376 </span> : -<span class="lineNum"> 2377 </span> : #ifdef _GLIBCXX_USE_LONG_LONG -<span class="lineNum"> 2378 </span> : iter_type -<span class="lineNum"> 2379 </span> : put(iter_type __s, ios_base& __f, char_type __fill, long long __v) const -<span class="lineNum"> 2380 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2381 </span> : -<span class="lineNum"> 2382 </span> : iter_type -<span class="lineNum"> 2383 </span> : put(iter_type __s, ios_base& __f, char_type __fill, -<span class="lineNum"> 2384 </span> : unsigned long long __v) const -<span class="lineNum"> 2385 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2386 </span> : #endif -<span class="lineNum"> 2387 </span> : //@} -<span class="lineNum"> 2388 </span> : -<span class="lineNum"> 2389 </span> : //@{ -<span class="lineNum"> 2390 </span> : /** -<span class="lineNum"> 2391 </span> : * @brief Numeric formatting. -<span class="lineNum"> 2392 </span> : * -<span class="lineNum"> 2393 </span> : * Formats the floating point value @a v and inserts it into a stream. -<span class="lineNum"> 2394 </span> : * It does so by calling num_put::do_put(). -<span class="lineNum"> 2395 </span> : * -<span class="lineNum"> 2396 </span> : * Formatting is affected by the flag settings in @a io. -<span class="lineNum"> 2397 </span> : * -<span class="lineNum"> 2398 </span> : * The basic format is affected by the value of io.flags() & -<span class="lineNum"> 2399 </span> : * ios_base::floatfield. If equal to ios_base::fixed, formats like the -<span class="lineNum"> 2400 </span> : * printf %f specifier. Else if equal to ios_base::scientific, formats -<span class="lineNum"> 2401 </span> : * like %e or %E with ios_base::uppercase unset or set respectively. -<span class="lineNum"> 2402 </span> : * Otherwise, formats like %g or %G depending on uppercase. Note that -<span class="lineNum"> 2403 </span> : * if both fixed and scientific are set, the effect will also be like -<span class="lineNum"> 2404 </span> : * %g or %G. -<span class="lineNum"> 2405 </span> : * -<span class="lineNum"> 2406 </span> : * The output precision is given by io.precision(). This precision is -<span class="lineNum"> 2407 </span> : * capped at numeric_limits::digits10 + 2 (different for double and -<span class="lineNum"> 2408 </span> : * long double). The default precision is 6. -<span class="lineNum"> 2409 </span> : * -<span class="lineNum"> 2410 </span> : * If ios_base::showpos is set, '+' is output before positive values. -<span class="lineNum"> 2411 </span> : * If ios_base::showpoint is set, a decimal point will always be -<span class="lineNum"> 2412 </span> : * output. -<span class="lineNum"> 2413 </span> : * -<span class="lineNum"> 2414 </span> : * Thousands separators are inserted according to numpunct::grouping() -<span class="lineNum"> 2415 </span> : * and numpunct::thousands_sep(). The decimal point character used is -<span class="lineNum"> 2416 </span> : * numpunct::decimal_point(). -<span class="lineNum"> 2417 </span> : * -<span class="lineNum"> 2418 </span> : * If io.width() is non-zero, enough @a fill characters are inserted to -<span class="lineNum"> 2419 </span> : * make the result at least that wide. If -<span class="lineNum"> 2420 </span> : * (io.flags() & ios_base::adjustfield) == ios_base::left, result is -<span class="lineNum"> 2421 </span> : * padded at the end. If ios_base::internal, then padding occurs -<span class="lineNum"> 2422 </span> : * immediately after either a '+' or '-' or after '0x' or '0X'. -<span class="lineNum"> 2423 </span> : * Otherwise, padding occurs at the beginning. -<span class="lineNum"> 2424 </span> : * -<span class="lineNum"> 2425 </span> : * @param s Stream to write to. -<span class="lineNum"> 2426 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2427 </span> : * @param fill Char_type to use for filling. -<span class="lineNum"> 2428 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2429 </span> : * @return Iterator after writing. -<span class="lineNum"> 2430 </span> : */ -<span class="lineNum"> 2431 </span> : iter_type -<span class="lineNum"> 2432 </span> : put(iter_type __s, ios_base& __f, char_type __fill, double __v) const -<span class="lineNum"> 2433 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2434 </span> : -<span class="lineNum"> 2435 </span> : iter_type -<span class="lineNum"> 2436 </span> : put(iter_type __s, ios_base& __f, char_type __fill, -<span class="lineNum"> 2437 </span> : long double __v) const -<span class="lineNum"> 2438 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2439 </span> : //@} -<span class="lineNum"> 2440 </span> : -<span class="lineNum"> 2441 </span> : /** -<span class="lineNum"> 2442 </span> : * @brief Numeric formatting. -<span class="lineNum"> 2443 </span> : * -<span class="lineNum"> 2444 </span> : * Formats the pointer value @a v and inserts it into a stream. It -<span class="lineNum"> 2445 </span> : * does so by calling num_put::do_put(). -<span class="lineNum"> 2446 </span> : * -<span class="lineNum"> 2447 </span> : * This function formats @a v as an unsigned long with ios_base::hex -<span class="lineNum"> 2448 </span> : * and ios_base::showbase set. -<span class="lineNum"> 2449 </span> : * -<span class="lineNum"> 2450 </span> : * @param s Stream to write to. -<span class="lineNum"> 2451 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2452 </span> : * @param fill Char_type to use for filling. -<span class="lineNum"> 2453 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2454 </span> : * @return Iterator after writing. -<span class="lineNum"> 2455 </span> : */ -<span class="lineNum"> 2456 </span> : iter_type -<span class="lineNum"> 2457 </span> : put(iter_type __s, ios_base& __f, char_type __fill, -<span class="lineNum"> 2458 </span> : const void* __v) const -<span class="lineNum"> 2459 </span> : { return this->do_put(__s, __f, __fill, __v); } -<span class="lineNum"> 2460 </span> : -<span class="lineNum"> 2461 </span> : protected: -<span class="lineNum"> 2462 </span> : template<typename _ValueT> -<span class="lineNum"> 2463 </span> : iter_type -<span class="lineNum"> 2464 </span> : _M_insert_float(iter_type, ios_base& __io, char_type __fill, -<span class="lineNum"> 2465 </span> : char __mod, _ValueT __v) const; -<span class="lineNum"> 2466 </span> : -<span class="lineNum"> 2467 </span> : void -<span class="lineNum"> 2468 </span> : _M_group_float(const char* __grouping, size_t __grouping_size, -<span class="lineNum"> 2469 </span> : char_type __sep, const char_type* __p, char_type* __new, -<span class="lineNum"> 2470 </span> : char_type* __cs, int& __len) const; -<span class="lineNum"> 2471 </span> : -<span class="lineNum"> 2472 </span> : template<typename _ValueT> -<span class="lineNum"> 2473 </span> : iter_type -<span class="lineNum"> 2474 </span> : _M_insert_int(iter_type, ios_base& __io, char_type __fill, -<span class="lineNum"> 2475 </span> : _ValueT __v) const; -<span class="lineNum"> 2476 </span> : -<span class="lineNum"> 2477 </span> : void -<span class="lineNum"> 2478 </span> : _M_group_int(const char* __grouping, size_t __grouping_size, -<span class="lineNum"> 2479 </span> : char_type __sep, ios_base& __io, char_type* __new, -<span class="lineNum"> 2480 </span> : char_type* __cs, int& __len) const; -<span class="lineNum"> 2481 </span> : -<span class="lineNum"> 2482 </span> : void -<span class="lineNum"> 2483 </span> : _M_pad(char_type __fill, streamsize __w, ios_base& __io, -<span class="lineNum"> 2484 </span> : char_type* __new, const char_type* __cs, int& __len) const; -<span class="lineNum"> 2485 </span> : -<span class="lineNum"> 2486 </span> : /// Destructor. -<span class="lineNum"> 2487 </span> : virtual -<span class="lineNum"> 2488 </span> : ~num_put() { }; -<span class="lineNum"> 2489 </span> : -<span class="lineNum"> 2490 </span> : //@{ -<span class="lineNum"> 2491 </span> : /** -<span class="lineNum"> 2492 </span> : * @brief Numeric formatting. -<span class="lineNum"> 2493 </span> : * -<span class="lineNum"> 2494 </span> : * These functions do the work of formatting numeric values and -<span class="lineNum"> 2495 </span> : * inserting them into a stream. This function is a hook for derived -<span class="lineNum"> 2496 </span> : * classes to change the value returned. -<span class="lineNum"> 2497 </span> : * -<span class="lineNum"> 2498 </span> : * @param s Stream to write to. -<span class="lineNum"> 2499 </span> : * @param io Source of locale and flags. -<span class="lineNum"> 2500 </span> : * @param fill Char_type to use for filling. -<span class="lineNum"> 2501 </span> : * @param v Value to format and insert. -<span class="lineNum"> 2502 </span> : * @return Iterator after writing. -<span class="lineNum"> 2503 </span> : */ -<span class="lineNum"> 2504 </span> : virtual iter_type -<span class="lineNum"> 2505 </span> : do_put(iter_type, ios_base&, char_type __fill, bool __v) const; -<span class="lineNum"> 2506 </span> : -<span class="lineNum"> 2507 </span> : virtual iter_type -<span class="lineNum"> 2508 </span> : do_put(iter_type, ios_base&, char_type __fill, long __v) const; -<span class="lineNum"> 2509 </span> : -<span class="lineNum"> 2510 </span> : virtual iter_type -<span class="lineNum"> 2511 </span> : do_put(iter_type, ios_base&, char_type __fill, unsigned long) const; -<span class="lineNum"> 2512 </span> : -<span class="lineNum"> 2513 </span> : #ifdef _GLIBCXX_USE_LONG_LONG -<span class="lineNum"> 2514 </span> : virtual iter_type -<span class="lineNum"> 2515 </span> : do_put(iter_type, ios_base&, char_type __fill, long long __v) const; -<span class="lineNum"> 2516 </span> : -<span class="lineNum"> 2517 </span> : virtual iter_type -<span class="lineNum"> 2518 </span> : do_put(iter_type, ios_base&, char_type __fill, unsigned long long) const; -<span class="lineNum"> 2519 </span> : #endif -<span class="lineNum"> 2520 </span> : -<span class="lineNum"> 2521 </span> : virtual iter_type -<span class="lineNum"> 2522 </span> : do_put(iter_type, ios_base&, char_type __fill, double __v) const; -<span class="lineNum"> 2523 </span> : -<span class="lineNum"> 2524 </span> : // XXX GLIBCXX_ABI Deprecated -<span class="lineNum"> 2525 </span> : #if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -<span class="lineNum"> 2526 </span> : virtual iter_type -<span class="lineNum"> 2527 </span> : __do_put(iter_type, ios_base&, char_type __fill, double __v) const; -<span class="lineNum"> 2528 </span> : #else -<span class="lineNum"> 2529 </span> : virtual iter_type -<span class="lineNum"> 2530 </span> : do_put(iter_type, ios_base&, char_type __fill, long double __v) const; -<span class="lineNum"> 2531 </span> : #endif -<span class="lineNum"> 2532 </span> : -<span class="lineNum"> 2533 </span> : virtual iter_type -<span class="lineNum"> 2534 </span> : do_put(iter_type, ios_base&, char_type __fill, const void* __v) const; -<span class="lineNum"> 2535 </span> : -<span class="lineNum"> 2536 </span> : // XXX GLIBCXX_ABI Deprecated -<span class="lineNum"> 2537 </span> : #if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -<span class="lineNum"> 2538 </span> : virtual iter_type -<span class="lineNum"> 2539 </span> : do_put(iter_type, ios_base&, char_type __fill, long double __v) const; -<span class="lineNum"> 2540 </span> : #endif -<span class="lineNum"> 2541 </span> : //@} -<span class="lineNum"> 2542 </span> : }; -<span class="lineNum"> 2543 </span> : -<span class="lineNum"> 2544 </span> : template <typename _CharT, typename _OutIter> -<span class="lineNum"> 2545 </span> : locale::id num_put<_CharT, _OutIter>::id; -<span class="lineNum"> 2546 </span> : -<span class="lineNum"> 2547 </span> : _GLIBCXX_END_LDBL_NAMESPACE -<span class="lineNum"> 2548 </span> : -<span class="lineNum"> 2549 </span> : // Subclause convenience interfaces, inlines. -<span class="lineNum"> 2550 </span> : // NB: These are inline because, when used in a loop, some compilers -<span class="lineNum"> 2551 </span> : // can hoist the body out of the loop; then it's just as fast as the -<span class="lineNum"> 2552 </span> : // C is*() function. -<span class="lineNum"> 2553 </span> : -<span class="lineNum"> 2554 </span> : /// Convenience interface to ctype.is(ctype_base::space, __c). -<span class="lineNum"> 2555 </span> : template<typename _CharT> -<span class="lineNum"> 2556 </span> : inline bool -<span class="lineNum"> 2557 </span> : isspace(_CharT __c, const locale& __loc) -<span class="lineNum"> 2558 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::space, __c); } -<span class="lineNum"> 2559 </span> : -<span class="lineNum"> 2560 </span> : /// Convenience interface to ctype.is(ctype_base::print, __c). -<span class="lineNum"> 2561 </span> : template<typename _CharT> -<span class="lineNum"> 2562 </span> : inline bool -<span class="lineNum"> 2563 </span> : isprint(_CharT __c, const locale& __loc) -<span class="lineNum"> 2564 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::print, __c); } -<span class="lineNum"> 2565 </span> : -<span class="lineNum"> 2566 </span> : /// Convenience interface to ctype.is(ctype_base::cntrl, __c). -<span class="lineNum"> 2567 </span> : template<typename _CharT> -<span class="lineNum"> 2568 </span> : inline bool -<span class="lineNum"> 2569 </span> : iscntrl(_CharT __c, const locale& __loc) -<span class="lineNum"> 2570 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::cntrl, __c); } -<span class="lineNum"> 2571 </span> : -<span class="lineNum"> 2572 </span> : /// Convenience interface to ctype.is(ctype_base::upper, __c). -<span class="lineNum"> 2573 </span> : template<typename _CharT> -<span class="lineNum"> 2574 </span> : inline bool -<span class="lineNum"> 2575 </span> : isupper(_CharT __c, const locale& __loc) -<span class="lineNum"> 2576 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::upper, __c); } -<span class="lineNum"> 2577 </span> : -<span class="lineNum"> 2578 </span> : /// Convenience interface to ctype.is(ctype_base::lower, __c). -<span class="lineNum"> 2579 </span> : template<typename _CharT> -<span class="lineNum"> 2580 </span> : inline bool -<span class="lineNum"> 2581 </span> : islower(_CharT __c, const locale& __loc) -<span class="lineNum"> 2582 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::lower, __c); } -<span class="lineNum"> 2583 </span> : -<span class="lineNum"> 2584 </span> : /// Convenience interface to ctype.is(ctype_base::alpha, __c). -<span class="lineNum"> 2585 </span> : template<typename _CharT> -<span class="lineNum"> 2586 </span> : inline bool -<span class="lineNum"> 2587 </span> : isalpha(_CharT __c, const locale& __loc) -<span class="lineNum"> 2588 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::alpha, __c); } -<span class="lineNum"> 2589 </span> : -<span class="lineNum"> 2590 </span> : /// Convenience interface to ctype.is(ctype_base::digit, __c). -<span class="lineNum"> 2591 </span> : template<typename _CharT> -<span class="lineNum"> 2592 </span> : inline bool -<span class="lineNum"> 2593 </span> : isdigit(_CharT __c, const locale& __loc) -<span class="lineNum"> 2594 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::digit, __c); } -<span class="lineNum"> 2595 </span> : -<span class="lineNum"> 2596 </span> : /// Convenience interface to ctype.is(ctype_base::punct, __c). -<span class="lineNum"> 2597 </span> : template<typename _CharT> -<span class="lineNum"> 2598 </span> : inline bool -<span class="lineNum"> 2599 </span> : ispunct(_CharT __c, const locale& __loc) -<span class="lineNum"> 2600 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::punct, __c); } -<span class="lineNum"> 2601 </span> : -<span class="lineNum"> 2602 </span> : /// Convenience interface to ctype.is(ctype_base::xdigit, __c). -<span class="lineNum"> 2603 </span> : template<typename _CharT> -<span class="lineNum"> 2604 </span> : inline bool -<span class="lineNum"> 2605 </span> : isxdigit(_CharT __c, const locale& __loc) -<span class="lineNum"> 2606 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::xdigit, __c); } -<span class="lineNum"> 2607 </span> : -<span class="lineNum"> 2608 </span> : /// Convenience interface to ctype.is(ctype_base::alnum, __c). -<span class="lineNum"> 2609 </span> : template<typename _CharT> -<span class="lineNum"> 2610 </span> : inline bool -<span class="lineNum"> 2611 </span> : isalnum(_CharT __c, const locale& __loc) -<span class="lineNum"> 2612 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::alnum, __c); } -<span class="lineNum"> 2613 </span> : -<span class="lineNum"> 2614 </span> : /// Convenience interface to ctype.is(ctype_base::graph, __c). -<span class="lineNum"> 2615 </span> : template<typename _CharT> -<span class="lineNum"> 2616 </span> : inline bool -<span class="lineNum"> 2617 </span> : isgraph(_CharT __c, const locale& __loc) -<span class="lineNum"> 2618 </span> : { return use_facet<ctype<_CharT> >(__loc).is(ctype_base::graph, __c); } -<span class="lineNum"> 2619 </span> : -<span class="lineNum"> 2620 </span> : /// Convenience interface to ctype.toupper(__c). -<span class="lineNum"> 2621 </span> : template<typename _CharT> -<span class="lineNum"> 2622 </span> : inline _CharT -<span class="lineNum"> 2623 </span> : toupper(_CharT __c, const locale& __loc) -<span class="lineNum"> 2624 </span> : { return use_facet<ctype<_CharT> >(__loc).toupper(__c); } -<span class="lineNum"> 2625 </span> : -<span class="lineNum"> 2626 </span> : /// Convenience interface to ctype.tolower(__c). -<span class="lineNum"> 2627 </span> : template<typename _CharT> -<span class="lineNum"> 2628 </span> : inline _CharT -<span class="lineNum"> 2629 </span> : tolower(_CharT __c, const locale& __loc) -<span class="lineNum"> 2630 </span> : { return use_facet<ctype<_CharT> >(__loc).tolower(__c); } -<span class="lineNum"> 2631 </span> : -<span class="lineNum"> 2632 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 2633 </span> : -<span class="lineNum"> 2634 </span> : #ifndef _GLIBCXX_EXPORT_TEMPLATE -<span class="lineNum"> 2635 </span> : # include <bits/locale_facets.tcc> -<span class="lineNum"> 2636 </span> : #endif -<span class="lineNum"> 2637 </span> : -<span class="lineNum"> 2638 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/postypes.h.gcov.html b/rep/usr/include/c++/4.3/bits/postypes.h.gcov.html deleted file mode 100644 index 9775ab9..0000000 --- a/rep/usr/include/c++/4.3/bits/postypes.h.gcov.html +++ /dev/null @@ -1,280 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/postypes.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - postypes.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">3</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">0.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">0</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Position types -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, -<span class="lineNum"> 4 </span> : // 2006, 2007, 2008 -<span class="lineNum"> 5 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 6 </span> : // -<span class="lineNum"> 7 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 8 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 9 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 10 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 11 </span> : // any later version. -<span class="lineNum"> 12 </span> : -<span class="lineNum"> 13 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 14 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 15 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 16 </span> : // GNU General Public License for more details. -<span class="lineNum"> 17 </span> : -<span class="lineNum"> 18 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 19 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 20 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 21 </span> : // USA. -<span class="lineNum"> 22 </span> : -<span class="lineNum"> 23 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 24 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 25 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 26 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 27 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 29 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 30 </span> : // the GNU General Public License. -<span class="lineNum"> 31 </span> : -<span class="lineNum"> 32 </span> : /** @file postypes.h -<span class="lineNum"> 33 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 34 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 35 </span> : */ -<span class="lineNum"> 36 </span> : -<span class="lineNum"> 37 </span> : // -<span class="lineNum"> 38 </span> : // ISO C++ 14882: 27.4.1 - Types -<span class="lineNum"> 39 </span> : // ISO C++ 14882: 27.4.3 - Template class fpos -<span class="lineNum"> 40 </span> : // -<span class="lineNum"> 41 </span> : -<span class="lineNum"> 42 </span> : #ifndef _GLIBCXX_POSTYPES_H -<span class="lineNum"> 43 </span> : #define _GLIBCXX_POSTYPES_H 1 -<span class="lineNum"> 44 </span> : -<span class="lineNum"> 45 </span> : #pragma GCC system_header -<span class="lineNum"> 46 </span> : -<span class="lineNum"> 47 </span> : #include <cwchar> // For mbstate_t -<span class="lineNum"> 48 </span> : -<span class="lineNum"> 49 </span> : #ifdef _GLIBCXX_HAVE_STDINT_H -<span class="lineNum"> 50 </span> : #include <stdint.h> // For int64_t -<span class="lineNum"> 51 </span> : #endif -<span class="lineNum"> 52 </span> : -<span class="lineNum"> 53 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 54 </span> : -<span class="lineNum"> 55 </span> : // The types streamoff, streampos and wstreampos and the class -<span class="lineNum"> 56 </span> : // template fpos<> are described in clauses 21.1.2, 21.1.3, 27.1.2, -<span class="lineNum"> 57 </span> : // 27.2, 27.4.1, 27.4.3 and D.6. Despite all this verbiage, the -<span class="lineNum"> 58 </span> : // behaviour of these types is mostly implementation defined or -<span class="lineNum"> 59 </span> : // unspecified. The behaviour in this implementation is as noted -<span class="lineNum"> 60 </span> : // below. -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : /** -<span class="lineNum"> 63 </span> : * @brief Type used by fpos, char_traits<char>, and char_traits<wchar_t>. -<span class="lineNum"> 64 </span> : * -<span class="lineNum"> 65 </span> : * In clauses 21.1.3.1 and 27.4.1 streamoff is described as an -<span class="lineNum"> 66 </span> : * implementation defined type. -<span class="lineNum"> 67 </span> : * Note: In versions of GCC up to and including GCC 3.3, streamoff -<span class="lineNum"> 68 </span> : * was typedef long. -<span class="lineNum"> 69 </span> : */ -<span class="lineNum"> 70 </span> : #ifdef _GLIBCXX_HAVE_INT64_T -<span class="lineNum"> 71 </span> : typedef int64_t streamoff; -<span class="lineNum"> 72 </span> : #else -<span class="lineNum"> 73 </span> : typedef long long streamoff; -<span class="lineNum"> 74 </span> : #endif -<span class="lineNum"> 75 </span> : -<span class="lineNum"> 76 </span> : /// Integral type for I/O operation counts and buffer sizes. -<span class="lineNum"> 77 </span> : typedef ptrdiff_t streamsize; // Signed integral type -<span class="lineNum"> 78 </span> : -<span class="lineNum"> 79 </span> : /** -<span class="lineNum"> 80 </span> : * @brief Class representing stream positions. -<span class="lineNum"> 81 </span> : * -<span class="lineNum"> 82 </span> : * The standard places no requirements upon the template parameter StateT. -<span class="lineNum"> 83 </span> : * In this implementation StateT must be DefaultConstructible, -<span class="lineNum"> 84 </span> : * CopyConstructible and Assignable. The standard only requires that fpos -<span class="lineNum"> 85 </span> : * should contain a member of type StateT. In this implementation it also -<span class="lineNum"> 86 </span> : * contains an offset stored as a signed integer. -<span class="lineNum"> 87 </span> : * -<span class="lineNum"> 88 </span> : * @param StateT Type passed to and returned from state(). -<span class="lineNum"> 89 </span> : */ -<span class="lineNum"> 90 </span> : template<typename _StateT> -<span class="lineNum"> 91 </span> : class fpos -<span class="lineNum"> 92 </span> : { -<span class="lineNum"> 93 </span> : private: -<span class="lineNum"> 94 </span> : streamoff _M_off; -<span class="lineNum"> 95 </span> : _StateT _M_state; -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : public: -<span class="lineNum"> 98 </span> : // The standard doesn't require that fpos objects can be default -<span class="lineNum"> 99 </span> : // constructed. This implementation provides a default -<span class="lineNum"> 100 </span> : // constructor that initializes the offset to 0 and default -<span class="lineNum"> 101 </span> : // constructs the state. -<span class="lineNum"> 102 </span> : fpos() -<span class="lineNum"> 103 </span> : : _M_off(0), _M_state() { } -<span class="lineNum"> 104 </span> : -<span class="lineNum"> 105 </span> : // The standard requires that fpos objects can be constructed -<span class="lineNum"> 106 </span> : // from streamoff objects using the constructor syntax, and -<span class="lineNum"> 107 </span> : // fails to give any meaningful semantics. In this -<span class="lineNum"> 108 </span> : // implementation implicit conversion is also allowed, and this -<span class="lineNum"> 109 </span> : // constructor stores the streamoff as the offset and default -<span class="lineNum"> 110 </span> : // constructs the state. -<span class="lineNum"> 111 </span> : /// Construct position from offset. -<span class="lineNum"> 112 </span><span class="lineNoCov"> 0 : fpos(streamoff __off)</span> -<span class="lineNum"> 113 </span><span class="lineNoCov"> 0 : : _M_off(__off), _M_state() { }</span> -<span class="lineNum"> 114 </span> : -<span class="lineNum"> 115 </span> : /// Convert to streamoff. -<span class="lineNum"> 116 </span><span class="lineNoCov"> 0 : operator streamoff() const { return _M_off; }</span> -<span class="lineNum"> 117 </span> : -<span class="lineNum"> 118 </span> : /// Remember the value of @a st. -<span class="lineNum"> 119 </span> : void -<span class="lineNum"> 120 </span> : state(_StateT __st) -<span class="lineNum"> 121 </span> : { _M_state = __st; } -<span class="lineNum"> 122 </span> : -<span class="lineNum"> 123 </span> : /// Return the last set value of @a st. -<span class="lineNum"> 124 </span> : _StateT -<span class="lineNum"> 125 </span> : state() const -<span class="lineNum"> 126 </span> : { return _M_state; } -<span class="lineNum"> 127 </span> : -<span class="lineNum"> 128 </span> : // The standard requires that this operator must be defined, but -<span class="lineNum"> 129 </span> : // gives no semantics. In this implementation it just adds its -<span class="lineNum"> 130 </span> : // argument to the stored offset and returns *this. -<span class="lineNum"> 131 </span> : /// Add offset to this position. -<span class="lineNum"> 132 </span> : fpos& -<span class="lineNum"> 133 </span> : operator+=(streamoff __off) -<span class="lineNum"> 134 </span> : { -<span class="lineNum"> 135 </span> : _M_off += __off; -<span class="lineNum"> 136 </span> : return *this; -<span class="lineNum"> 137 </span> : } -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : // The standard requires that this operator must be defined, but -<span class="lineNum"> 140 </span> : // gives no semantics. In this implementation it just subtracts -<span class="lineNum"> 141 </span> : // its argument from the stored offset and returns *this. -<span class="lineNum"> 142 </span> : /// Subtract offset from this position. -<span class="lineNum"> 143 </span> : fpos& -<span class="lineNum"> 144 </span> : operator-=(streamoff __off) -<span class="lineNum"> 145 </span> : { -<span class="lineNum"> 146 </span> : _M_off -= __off; -<span class="lineNum"> 147 </span> : return *this; -<span class="lineNum"> 148 </span> : } -<span class="lineNum"> 149 </span> : -<span class="lineNum"> 150 </span> : // The standard requires that this operator must be defined, but -<span class="lineNum"> 151 </span> : // defines its semantics only in terms of operator-. In this -<span class="lineNum"> 152 </span> : // implementation it constructs a copy of *this, adds the -<span class="lineNum"> 153 </span> : // argument to that copy using operator+= and then returns the -<span class="lineNum"> 154 </span> : // copy. -<span class="lineNum"> 155 </span> : /// Add position and offset. -<span class="lineNum"> 156 </span> : fpos -<span class="lineNum"> 157 </span> : operator+(streamoff __off) const -<span class="lineNum"> 158 </span> : { -<span class="lineNum"> 159 </span> : fpos __pos(*this); -<span class="lineNum"> 160 </span> : __pos += __off; -<span class="lineNum"> 161 </span> : return __pos; -<span class="lineNum"> 162 </span> : } -<span class="lineNum"> 163 </span> : -<span class="lineNum"> 164 </span> : // The standard requires that this operator must be defined, but -<span class="lineNum"> 165 </span> : // defines its semantics only in terms of operator+. In this -<span class="lineNum"> 166 </span> : // implementation it constructs a copy of *this, subtracts the -<span class="lineNum"> 167 </span> : // argument from that copy using operator-= and then returns the -<span class="lineNum"> 168 </span> : // copy. -<span class="lineNum"> 169 </span> : /// Subtract offset from position. -<span class="lineNum"> 170 </span> : fpos -<span class="lineNum"> 171 </span> : operator-(streamoff __off) const -<span class="lineNum"> 172 </span> : { -<span class="lineNum"> 173 </span> : fpos __pos(*this); -<span class="lineNum"> 174 </span> : __pos -= __off; -<span class="lineNum"> 175 </span> : return __pos; -<span class="lineNum"> 176 </span> : } -<span class="lineNum"> 177 </span> : -<span class="lineNum"> 178 </span> : // The standard requires that this operator must be defined, but -<span class="lineNum"> 179 </span> : // defines its semantics only in terms of operator+. In this -<span class="lineNum"> 180 </span> : // implementation it returns the difference between the offset -<span class="lineNum"> 181 </span> : // stored in *this and in the argument. -<span class="lineNum"> 182 </span> : /// Subtract position to return offset. -<span class="lineNum"> 183 </span> : streamoff -<span class="lineNum"> 184 </span> : operator-(const fpos& __other) const -<span class="lineNum"> 185 </span> : { return _M_off - __other._M_off; } -<span class="lineNum"> 186 </span> : }; -<span class="lineNum"> 187 </span> : -<span class="lineNum"> 188 </span> : // The standard only requires that operator== must be an -<span class="lineNum"> 189 </span> : // equivalence relation. In this implementation two fpos<StateT> -<span class="lineNum"> 190 </span> : // objects belong to the same equivalence class if the contained -<span class="lineNum"> 191 </span> : // offsets compare equal. -<span class="lineNum"> 192 </span> : /// Test if equivalent to another position. -<span class="lineNum"> 193 </span> : template<typename _StateT> -<span class="lineNum"> 194 </span> : inline bool -<span class="lineNum"> 195 </span> : operator==(const fpos<_StateT>& __lhs, const fpos<_StateT>& __rhs) -<span class="lineNum"> 196 </span> : { return streamoff(__lhs) == streamoff(__rhs); } -<span class="lineNum"> 197 </span> : -<span class="lineNum"> 198 </span> : template<typename _StateT> -<span class="lineNum"> 199 </span> : inline bool -<span class="lineNum"> 200 </span> : operator!=(const fpos<_StateT>& __lhs, const fpos<_StateT>& __rhs) -<span class="lineNum"> 201 </span> : { return streamoff(__lhs) != streamoff(__rhs); } -<span class="lineNum"> 202 </span> : -<span class="lineNum"> 203 </span> : // Clauses 21.1.3.1 and 21.1.3.2 describe streampos and wstreampos -<span class="lineNum"> 204 </span> : // as implementation defined types, but clause 27.2 requires that -<span class="lineNum"> 205 </span> : // they must both be typedefs for fpos<mbstate_t> -<span class="lineNum"> 206 </span> : /// File position for char streams. -<span class="lineNum"> 207 </span> : typedef fpos<mbstate_t> streampos; -<span class="lineNum"> 208 </span> : /// File position for wchar_t streams. -<span class="lineNum"> 209 </span> : typedef fpos<mbstate_t> wstreampos; -<span class="lineNum"> 210 </span> : -<span class="lineNum"> 211 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 212 </span> : -<span class="lineNum"> 213 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_algo.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_algo.h.gcov.html deleted file mode 100644 index bb0c409..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_algo.h.gcov.html +++ /dev/null @@ -1,5703 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_algo.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_algo.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">226</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">85.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">192</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Algorithm implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_algo.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_ALGO_H -<span class="lineNum"> 63 </span> : #define _STL_ALGO_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <cstdlib> // for rand -<span class="lineNum"> 66 </span> : #include <bits/algorithmfwd.h> -<span class="lineNum"> 67 </span> : #include <bits/stl_heap.h> -<span class="lineNum"> 68 </span> : #include <bits/stl_tempbuf.h> // for _Temporary_buffer -<span class="lineNum"> 69 </span> : #include <debug/debug.h> -<span class="lineNum"> 70 </span> : -<span class="lineNum"> 71 </span> : // See concept_check.h for the __glibcxx_*_requires macros. -<span class="lineNum"> 72 </span> : -<span class="lineNum"> 73 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 74 </span> : -<span class="lineNum"> 75 </span> : /** -<span class="lineNum"> 76 </span> : * @brief Find the median of three values. -<span class="lineNum"> 77 </span> : * @param a A value. -<span class="lineNum"> 78 </span> : * @param b A value. -<span class="lineNum"> 79 </span> : * @param c A value. -<span class="lineNum"> 80 </span> : * @return One of @p a, @p b or @p c. -<span class="lineNum"> 81 </span> : * -<span class="lineNum"> 82 </span> : * If @c {l,m,n} is some convolution of @p {a,b,c} such that @c l<=m<=n -<span class="lineNum"> 83 </span> : * then the value returned will be @c m. -<span class="lineNum"> 84 </span> : * This is an SGI extension. -<span class="lineNum"> 85 </span> : * @ingroup SGIextensions -<span class="lineNum"> 86 </span> : */ -<span class="lineNum"> 87 </span> : template<typename _Tp> -<span class="lineNum"> 88 </span> : inline const _Tp& -<span class="lineNum"> 89 </span><span class="lineCov"> 133 : __median(const _Tp& __a, const _Tp& __b, const _Tp& __c)</span> -<span class="lineNum"> 90 </span> : { -<span class="lineNum"> 91 </span> : // concept requirements -<span class="lineNum"> 92 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_Tp>) -<span class="lineNum"> 93 </span><span class="lineCov"> 133 : if (__a < __b)</span> -<span class="lineNum"> 94 </span><span class="lineCov"> 132 : if (__b < __c)</span> -<span class="lineNum"> 95 </span><span class="lineCov"> 132 : return __b;</span> -<span class="lineNum"> 96 </span><span class="lineNoCov"> 0 : else if (__a < __c)</span> -<span class="lineNum"> 97 </span><span class="lineNoCov"> 0 : return __c;</span> -<span class="lineNum"> 98 </span> : else -<span class="lineNum"> 99 </span><span class="lineNoCov"> 0 : return __a;</span> -<span class="lineNum"> 100 </span><span class="lineCov"> 1 : else if (__a < __c)</span> -<span class="lineNum"> 101 </span><span class="lineNoCov"> 0 : return __a;</span> -<span class="lineNum"> 102 </span><span class="lineCov"> 1 : else if (__b < __c)</span> -<span class="lineNum"> 103 </span><span class="lineNoCov"> 0 : return __c;</span> -<span class="lineNum"> 104 </span> : else -<span class="lineNum"> 105 </span><span class="lineCov"> 1 : return __b;</span> -<span class="lineNum"> 106 </span> : } -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : /** -<span class="lineNum"> 109 </span> : * @brief Find the median of three values using a predicate for comparison. -<span class="lineNum"> 110 </span> : * @param a A value. -<span class="lineNum"> 111 </span> : * @param b A value. -<span class="lineNum"> 112 </span> : * @param c A value. -<span class="lineNum"> 113 </span> : * @param comp A binary predicate. -<span class="lineNum"> 114 </span> : * @return One of @p a, @p b or @p c. -<span class="lineNum"> 115 </span> : * -<span class="lineNum"> 116 </span> : * If @c {l,m,n} is some convolution of @p {a,b,c} such that @p comp(l,m) -<span class="lineNum"> 117 </span> : * and @p comp(m,n) are both true then the value returned will be @c m. -<span class="lineNum"> 118 </span> : * This is an SGI extension. -<span class="lineNum"> 119 </span> : * @ingroup SGIextensions -<span class="lineNum"> 120 </span> : */ -<span class="lineNum"> 121 </span> : template<typename _Tp, typename _Compare> -<span class="lineNum"> 122 </span> : inline const _Tp& -<span class="lineNum"> 123 </span><span class="lineCov"> 710 : __median(const _Tp& __a, const _Tp& __b, const _Tp& __c, _Compare __comp)</span> -<span class="lineNum"> 124 </span> : { -<span class="lineNum"> 125 </span> : // concept requirements -<span class="lineNum"> 126 </span> : __glibcxx_function_requires(_BinaryFunctionConcept<_Compare, bool, -<span class="lineNum"> 127 </span> : _Tp, _Tp>) -<span class="lineNum"> 128 </span><span class="lineCov"> 710 : if (__comp(__a, __b))</span> -<span class="lineNum"> 129 </span><span class="lineCov"> 433 : if (__comp(__b, __c))</span> -<span class="lineNum"> 130 </span><span class="lineCov"> 143 : return __b;</span> -<span class="lineNum"> 131 </span><span class="lineCov"> 290 : else if (__comp(__a, __c))</span> -<span class="lineNum"> 132 </span><span class="lineCov"> 54 : return __c;</span> -<span class="lineNum"> 133 </span> : else -<span class="lineNum"> 134 </span><span class="lineCov"> 236 : return __a;</span> -<span class="lineNum"> 135 </span><span class="lineCov"> 277 : else if (__comp(__a, __c))</span> -<span class="lineNum"> 136 </span><span class="lineCov"> 81 : return __a;</span> -<span class="lineNum"> 137 </span><span class="lineCov"> 196 : else if (__comp(__b, __c))</span> -<span class="lineNum"> 138 </span><span class="lineCov"> 99 : return __c;</span> -<span class="lineNum"> 139 </span> : else -<span class="lineNum"> 140 </span><span class="lineCov"> 97 : return __b;</span> -<span class="lineNum"> 141 </span> : } -<span class="lineNum"> 142 </span> : -<span class="lineNum"> 143 </span> : // for_each -<span class="lineNum"> 144 </span> : -<span class="lineNum"> 145 </span> : /// This is an overload used by find() for the Input Iterator case. -<span class="lineNum"> 146 </span> : template<typename _InputIterator, typename _Tp> -<span class="lineNum"> 147 </span> : inline _InputIterator -<span class="lineNum"> 148 </span> : __find(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 149 </span> : const _Tp& __val, input_iterator_tag) -<span class="lineNum"> 150 </span> : { -<span class="lineNum"> 151 </span> : while (__first != __last && !(*__first == __val)) -<span class="lineNum"> 152 </span> : ++__first; -<span class="lineNum"> 153 </span> : return __first; -<span class="lineNum"> 154 </span> : } -<span class="lineNum"> 155 </span> : -<span class="lineNum"> 156 </span> : /// This is an overload used by find_if() for the Input Iterator case. -<span class="lineNum"> 157 </span> : template<typename _InputIterator, typename _Predicate> -<span class="lineNum"> 158 </span> : inline _InputIterator -<span class="lineNum"> 159 </span> : __find_if(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 160 </span><span class="lineCov"> 3 : _Predicate __pred, input_iterator_tag)</span> -<span class="lineNum"> 161 </span> : { -<span class="lineNum"> 162 </span><span class="lineCov"> 7 : while (__first != __last && !bool(__pred(*__first)))</span> -<span class="lineNum"> 163 </span><span class="lineCov"> 1 : ++__first;</span> -<span class="lineNum"> 164 </span><span class="lineCov"> 3 : return __first;</span> -<span class="lineNum"> 165 </span> : } -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : /// This is an overload used by find() for the RAI case. -<span class="lineNum"> 168 </span> : template<typename _RandomAccessIterator, typename _Tp> -<span class="lineNum"> 169 </span> : _RandomAccessIterator -<span class="lineNum"> 170 </span> : __find(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 171 </span><span class="lineCov"> 3362 : const _Tp& __val, random_access_iterator_tag)</span> -<span class="lineNum"> 172 </span> : { -<span class="lineNum"> 173 </span> : typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 174 </span><span class="lineCov"> 3362 : __trip_count = (__last - __first) >> 2;</span> -<span class="lineNum"> 175 </span> : -<span class="lineNum"> 176 </span><span class="lineCov"> 5967 : for (; __trip_count > 0; --__trip_count)</span> -<span class="lineNum"> 177 </span> : { -<span class="lineNum"> 178 </span><span class="lineCov"> 3337 : if (*__first == __val)</span> -<span class="lineNum"> 179 </span><span class="lineCov"> 42 : return __first;</span> -<span class="lineNum"> 180 </span><span class="lineCov"> 3295 : ++__first;</span> -<span class="lineNum"> 181 </span> : -<span class="lineNum"> 182 </span><span class="lineCov"> 3295 : if (*__first == __val)</span> -<span class="lineNum"> 183 </span><span class="lineCov"> 16 : return __first;</span> -<span class="lineNum"> 184 </span><span class="lineCov"> 3279 : ++__first;</span> -<span class="lineNum"> 185 </span> : -<span class="lineNum"> 186 </span><span class="lineCov"> 3279 : if (*__first == __val)</span> -<span class="lineNum"> 187 </span><span class="lineCov"> 42 : return __first;</span> -<span class="lineNum"> 188 </span><span class="lineCov"> 3237 : ++__first;</span> -<span class="lineNum"> 189 </span> : -<span class="lineNum"> 190 </span><span class="lineCov"> 3237 : if (*__first == __val)</span> -<span class="lineNum"> 191 </span><span class="lineCov"> 632 : return __first;</span> -<span class="lineNum"> 192 </span><span class="lineCov"> 2605 : ++__first;</span> -<span class="lineNum"> 193 </span> : } -<span class="lineNum"> 194 </span> : -<span class="lineNum"> 195 </span><span class="lineCov"> 2630 : switch (__last - __first)</span> -<span class="lineNum"> 196 </span> : { -<span class="lineNum"> 197 </span> : case 3: -<span class="lineNum"> 198 </span><span class="lineCov"> 107 : if (*__first == __val)</span> -<span class="lineNum"> 199 </span><span class="lineNoCov"> 0 : return __first;</span> -<span class="lineNum"> 200 </span><span class="lineCov"> 107 : ++__first;</span> -<span class="lineNum"> 201 </span> : case 2: -<span class="lineNum"> 202 </span><span class="lineCov"> 243 : if (*__first == __val)</span> -<span class="lineNum"> 203 </span><span class="lineNoCov"> 0 : return __first;</span> -<span class="lineNum"> 204 </span><span class="lineCov"> 243 : ++__first;</span> -<span class="lineNum"> 205 </span> : case 1: -<span class="lineNum"> 206 </span><span class="lineCov"> 370 : if (*__first == __val)</span> -<span class="lineNum"> 207 </span><span class="lineCov"> 370 : return __first;</span> -<span class="lineNum"> 208 </span><span class="lineNoCov"> 0 : ++__first;</span> -<span class="lineNum"> 209 </span> : case 0: -<span class="lineNum"> 210 </span> : default: -<span class="lineNum"> 211 </span><span class="lineCov"> 2260 : return __last;</span> -<span class="lineNum"> 212 </span> : } -<span class="lineNum"> 213 </span> : } -<span class="lineNum"> 214 </span> : -<span class="lineNum"> 215 </span> : /// This is an overload used by find_if() for the RAI case. -<span class="lineNum"> 216 </span> : template<typename _RandomAccessIterator, typename _Predicate> -<span class="lineNum"> 217 </span> : _RandomAccessIterator -<span class="lineNum"> 218 </span> : __find_if(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 219 </span> : _Predicate __pred, random_access_iterator_tag) -<span class="lineNum"> 220 </span> : { -<span class="lineNum"> 221 </span> : typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 222 </span> : __trip_count = (__last - __first) >> 2; -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : for (; __trip_count > 0; --__trip_count) -<span class="lineNum"> 225 </span> : { -<span class="lineNum"> 226 </span> : if (__pred(*__first)) -<span class="lineNum"> 227 </span> : return __first; -<span class="lineNum"> 228 </span> : ++__first; -<span class="lineNum"> 229 </span> : -<span class="lineNum"> 230 </span> : if (__pred(*__first)) -<span class="lineNum"> 231 </span> : return __first; -<span class="lineNum"> 232 </span> : ++__first; -<span class="lineNum"> 233 </span> : -<span class="lineNum"> 234 </span> : if (__pred(*__first)) -<span class="lineNum"> 235 </span> : return __first; -<span class="lineNum"> 236 </span> : ++__first; -<span class="lineNum"> 237 </span> : -<span class="lineNum"> 238 </span> : if (__pred(*__first)) -<span class="lineNum"> 239 </span> : return __first; -<span class="lineNum"> 240 </span> : ++__first; -<span class="lineNum"> 241 </span> : } -<span class="lineNum"> 242 </span> : -<span class="lineNum"> 243 </span> : switch (__last - __first) -<span class="lineNum"> 244 </span> : { -<span class="lineNum"> 245 </span> : case 3: -<span class="lineNum"> 246 </span> : if (__pred(*__first)) -<span class="lineNum"> 247 </span> : return __first; -<span class="lineNum"> 248 </span> : ++__first; -<span class="lineNum"> 249 </span> : case 2: -<span class="lineNum"> 250 </span> : if (__pred(*__first)) -<span class="lineNum"> 251 </span> : return __first; -<span class="lineNum"> 252 </span> : ++__first; -<span class="lineNum"> 253 </span> : case 1: -<span class="lineNum"> 254 </span> : if (__pred(*__first)) -<span class="lineNum"> 255 </span> : return __first; -<span class="lineNum"> 256 </span> : ++__first; -<span class="lineNum"> 257 </span> : case 0: -<span class="lineNum"> 258 </span> : default: -<span class="lineNum"> 259 </span> : return __last; -<span class="lineNum"> 260 </span> : } -<span class="lineNum"> 261 </span> : } -<span class="lineNum"> 262 </span> : -<span class="lineNum"> 263 </span> : // set_difference -<span class="lineNum"> 264 </span> : // set_intersection -<span class="lineNum"> 265 </span> : // set_symmetric_difference -<span class="lineNum"> 266 </span> : // set_union -<span class="lineNum"> 267 </span> : // for_each -<span class="lineNum"> 268 </span> : // find -<span class="lineNum"> 269 </span> : // find_if -<span class="lineNum"> 270 </span> : // find_first_of -<span class="lineNum"> 271 </span> : // adjacent_find -<span class="lineNum"> 272 </span> : // count -<span class="lineNum"> 273 </span> : // count_if -<span class="lineNum"> 274 </span> : // search -<span class="lineNum"> 275 </span> : -<span class="lineNum"> 276 </span> : /** -<span class="lineNum"> 277 </span> : * This is an uglified -<span class="lineNum"> 278 </span> : * search_n(_ForwardIterator, _ForwardIterator, _Integer, const _Tp&) -<span class="lineNum"> 279 </span> : * overloaded for forward iterators. -<span class="lineNum"> 280 </span> : */ -<span class="lineNum"> 281 </span> : template<typename _ForwardIterator, typename _Integer, typename _Tp> -<span class="lineNum"> 282 </span> : _ForwardIterator -<span class="lineNum"> 283 </span> : __search_n(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 284 </span> : _Integer __count, const _Tp& __val, -<span class="lineNum"> 285 </span> : std::forward_iterator_tag) -<span class="lineNum"> 286 </span> : { -<span class="lineNum"> 287 </span> : __first = _GLIBCXX_STD_P::find(__first, __last, __val); -<span class="lineNum"> 288 </span> : while (__first != __last) -<span class="lineNum"> 289 </span> : { -<span class="lineNum"> 290 </span> : typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 291 </span> : __n = __count; -<span class="lineNum"> 292 </span> : _ForwardIterator __i = __first; -<span class="lineNum"> 293 </span> : ++__i; -<span class="lineNum"> 294 </span> : while (__i != __last && __n != 1 && *__i == __val) -<span class="lineNum"> 295 </span> : { -<span class="lineNum"> 296 </span> : ++__i; -<span class="lineNum"> 297 </span> : --__n; -<span class="lineNum"> 298 </span> : } -<span class="lineNum"> 299 </span> : if (__n == 1) -<span class="lineNum"> 300 </span> : return __first; -<span class="lineNum"> 301 </span> : if (__i == __last) -<span class="lineNum"> 302 </span> : return __last; -<span class="lineNum"> 303 </span> : __first = _GLIBCXX_STD_P::find(++__i, __last, __val); -<span class="lineNum"> 304 </span> : } -<span class="lineNum"> 305 </span> : return __last; -<span class="lineNum"> 306 </span> : } -<span class="lineNum"> 307 </span> : -<span class="lineNum"> 308 </span> : /** -<span class="lineNum"> 309 </span> : * This is an uglified -<span class="lineNum"> 310 </span> : * search_n(_ForwardIterator, _ForwardIterator, _Integer, const _Tp&) -<span class="lineNum"> 311 </span> : * overloaded for random access iterators. -<span class="lineNum"> 312 </span> : */ -<span class="lineNum"> 313 </span> : template<typename _RandomAccessIter, typename _Integer, typename _Tp> -<span class="lineNum"> 314 </span> : _RandomAccessIter -<span class="lineNum"> 315 </span> : __search_n(_RandomAccessIter __first, _RandomAccessIter __last, -<span class="lineNum"> 316 </span> : _Integer __count, const _Tp& __val, -<span class="lineNum"> 317 </span> : std::random_access_iterator_tag) -<span class="lineNum"> 318 </span> : { -<span class="lineNum"> 319 </span> : -<span class="lineNum"> 320 </span> : typedef typename std::iterator_traits<_RandomAccessIter>::difference_type -<span class="lineNum"> 321 </span> : _DistanceType; -<span class="lineNum"> 322 </span> : -<span class="lineNum"> 323 </span> : _DistanceType __tailSize = __last - __first; -<span class="lineNum"> 324 </span> : const _DistanceType __pattSize = __count; -<span class="lineNum"> 325 </span> : -<span class="lineNum"> 326 </span> : if (__tailSize < __pattSize) -<span class="lineNum"> 327 </span> : return __last; -<span class="lineNum"> 328 </span> : -<span class="lineNum"> 329 </span> : const _DistanceType __skipOffset = __pattSize - 1; -<span class="lineNum"> 330 </span> : _RandomAccessIter __lookAhead = __first + __skipOffset; -<span class="lineNum"> 331 </span> : __tailSize -= __pattSize; -<span class="lineNum"> 332 </span> : -<span class="lineNum"> 333 </span> : while (1) // the main loop... -<span class="lineNum"> 334 </span> : { -<span class="lineNum"> 335 </span> : // __lookAhead here is always pointing to the last element of next -<span class="lineNum"> 336 </span> : // possible match. -<span class="lineNum"> 337 </span> : while (!(*__lookAhead == __val)) // the skip loop... -<span class="lineNum"> 338 </span> : { -<span class="lineNum"> 339 </span> : if (__tailSize < __pattSize) -<span class="lineNum"> 340 </span> : return __last; // Failure -<span class="lineNum"> 341 </span> : __lookAhead += __pattSize; -<span class="lineNum"> 342 </span> : __tailSize -= __pattSize; -<span class="lineNum"> 343 </span> : } -<span class="lineNum"> 344 </span> : _DistanceType __remainder = __skipOffset; -<span class="lineNum"> 345 </span> : for (_RandomAccessIter __backTrack = __lookAhead - 1; -<span class="lineNum"> 346 </span> : *__backTrack == __val; --__backTrack) -<span class="lineNum"> 347 </span> : { -<span class="lineNum"> 348 </span> : if (--__remainder == 0) -<span class="lineNum"> 349 </span> : return (__lookAhead - __skipOffset); // Success -<span class="lineNum"> 350 </span> : } -<span class="lineNum"> 351 </span> : if (__remainder > __tailSize) -<span class="lineNum"> 352 </span> : return __last; // Failure -<span class="lineNum"> 353 </span> : __lookAhead += __remainder; -<span class="lineNum"> 354 </span> : __tailSize -= __remainder; -<span class="lineNum"> 355 </span> : } -<span class="lineNum"> 356 </span> : } -<span class="lineNum"> 357 </span> : -<span class="lineNum"> 358 </span> : // search_n -<span class="lineNum"> 359 </span> : -<span class="lineNum"> 360 </span> : /** -<span class="lineNum"> 361 </span> : * This is an uglified -<span class="lineNum"> 362 </span> : * search_n(_ForwardIterator, _ForwardIterator, _Integer, const _Tp&, -<span class="lineNum"> 363 </span> : * _BinaryPredicate) -<span class="lineNum"> 364 </span> : * overloaded for forward iterators. -<span class="lineNum"> 365 </span> : */ -<span class="lineNum"> 366 </span> : template<typename _ForwardIterator, typename _Integer, typename _Tp, -<span class="lineNum"> 367 </span> : typename _BinaryPredicate> -<span class="lineNum"> 368 </span> : _ForwardIterator -<span class="lineNum"> 369 </span> : __search_n(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 370 </span> : _Integer __count, const _Tp& __val, -<span class="lineNum"> 371 </span> : _BinaryPredicate __binary_pred, std::forward_iterator_tag) -<span class="lineNum"> 372 </span> : { -<span class="lineNum"> 373 </span> : while (__first != __last && !bool(__binary_pred(*__first, __val))) -<span class="lineNum"> 374 </span> : ++__first; -<span class="lineNum"> 375 </span> : -<span class="lineNum"> 376 </span> : while (__first != __last) -<span class="lineNum"> 377 </span> : { -<span class="lineNum"> 378 </span> : typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 379 </span> : __n = __count; -<span class="lineNum"> 380 </span> : _ForwardIterator __i = __first; -<span class="lineNum"> 381 </span> : ++__i; -<span class="lineNum"> 382 </span> : while (__i != __last && __n != 1 && bool(__binary_pred(*__i, __val))) -<span class="lineNum"> 383 </span> : { -<span class="lineNum"> 384 </span> : ++__i; -<span class="lineNum"> 385 </span> : --__n; -<span class="lineNum"> 386 </span> : } -<span class="lineNum"> 387 </span> : if (__n == 1) -<span class="lineNum"> 388 </span> : return __first; -<span class="lineNum"> 389 </span> : if (__i == __last) -<span class="lineNum"> 390 </span> : return __last; -<span class="lineNum"> 391 </span> : __first = ++__i; -<span class="lineNum"> 392 </span> : while (__first != __last -<span class="lineNum"> 393 </span> : && !bool(__binary_pred(*__first, __val))) -<span class="lineNum"> 394 </span> : ++__first; -<span class="lineNum"> 395 </span> : } -<span class="lineNum"> 396 </span> : return __last; -<span class="lineNum"> 397 </span> : } -<span class="lineNum"> 398 </span> : -<span class="lineNum"> 399 </span> : /** -<span class="lineNum"> 400 </span> : * This is an uglified -<span class="lineNum"> 401 </span> : * search_n(_ForwardIterator, _ForwardIterator, _Integer, const _Tp&, -<span class="lineNum"> 402 </span> : * _BinaryPredicate) -<span class="lineNum"> 403 </span> : * overloaded for random access iterators. -<span class="lineNum"> 404 </span> : */ -<span class="lineNum"> 405 </span> : template<typename _RandomAccessIter, typename _Integer, typename _Tp, -<span class="lineNum"> 406 </span> : typename _BinaryPredicate> -<span class="lineNum"> 407 </span> : _RandomAccessIter -<span class="lineNum"> 408 </span> : __search_n(_RandomAccessIter __first, _RandomAccessIter __last, -<span class="lineNum"> 409 </span> : _Integer __count, const _Tp& __val, -<span class="lineNum"> 410 </span> : _BinaryPredicate __binary_pred, std::random_access_iterator_tag) -<span class="lineNum"> 411 </span> : { -<span class="lineNum"> 412 </span> : -<span class="lineNum"> 413 </span> : typedef typename std::iterator_traits<_RandomAccessIter>::difference_type -<span class="lineNum"> 414 </span> : _DistanceType; -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span> : _DistanceType __tailSize = __last - __first; -<span class="lineNum"> 417 </span> : const _DistanceType __pattSize = __count; -<span class="lineNum"> 418 </span> : -<span class="lineNum"> 419 </span> : if (__tailSize < __pattSize) -<span class="lineNum"> 420 </span> : return __last; -<span class="lineNum"> 421 </span> : -<span class="lineNum"> 422 </span> : const _DistanceType __skipOffset = __pattSize - 1; -<span class="lineNum"> 423 </span> : _RandomAccessIter __lookAhead = __first + __skipOffset; -<span class="lineNum"> 424 </span> : __tailSize -= __pattSize; -<span class="lineNum"> 425 </span> : -<span class="lineNum"> 426 </span> : while (1) // the main loop... -<span class="lineNum"> 427 </span> : { -<span class="lineNum"> 428 </span> : // __lookAhead here is always pointing to the last element of next -<span class="lineNum"> 429 </span> : // possible match. -<span class="lineNum"> 430 </span> : while (!bool(__binary_pred(*__lookAhead, __val))) // the skip loop... -<span class="lineNum"> 431 </span> : { -<span class="lineNum"> 432 </span> : if (__tailSize < __pattSize) -<span class="lineNum"> 433 </span> : return __last; // Failure -<span class="lineNum"> 434 </span> : __lookAhead += __pattSize; -<span class="lineNum"> 435 </span> : __tailSize -= __pattSize; -<span class="lineNum"> 436 </span> : } -<span class="lineNum"> 437 </span> : _DistanceType __remainder = __skipOffset; -<span class="lineNum"> 438 </span> : for (_RandomAccessIter __backTrack = __lookAhead - 1; -<span class="lineNum"> 439 </span> : __binary_pred(*__backTrack, __val); --__backTrack) -<span class="lineNum"> 440 </span> : { -<span class="lineNum"> 441 </span> : if (--__remainder == 0) -<span class="lineNum"> 442 </span> : return (__lookAhead - __skipOffset); // Success -<span class="lineNum"> 443 </span> : } -<span class="lineNum"> 444 </span> : if (__remainder > __tailSize) -<span class="lineNum"> 445 </span> : return __last; // Failure -<span class="lineNum"> 446 </span> : __lookAhead += __remainder; -<span class="lineNum"> 447 </span> : __tailSize -= __remainder; -<span class="lineNum"> 448 </span> : } -<span class="lineNum"> 449 </span> : } -<span class="lineNum"> 450 </span> : -<span class="lineNum"> 451 </span> : // find_end for forward iterators. -<span class="lineNum"> 452 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 453 </span> : _ForwardIterator1 -<span class="lineNum"> 454 </span> : __find_end(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 455 </span> : _ForwardIterator2 __first2, _ForwardIterator2 __last2, -<span class="lineNum"> 456 </span> : forward_iterator_tag, forward_iterator_tag) -<span class="lineNum"> 457 </span> : { -<span class="lineNum"> 458 </span> : if (__first2 == __last2) -<span class="lineNum"> 459 </span> : return __last1; -<span class="lineNum"> 460 </span> : else -<span class="lineNum"> 461 </span> : { -<span class="lineNum"> 462 </span> : _ForwardIterator1 __result = __last1; -<span class="lineNum"> 463 </span> : while (1) -<span class="lineNum"> 464 </span> : { -<span class="lineNum"> 465 </span> : _ForwardIterator1 __new_result -<span class="lineNum"> 466 </span> : = _GLIBCXX_STD_P::search(__first1, __last1, __first2, __last2); -<span class="lineNum"> 467 </span> : if (__new_result == __last1) -<span class="lineNum"> 468 </span> : return __result; -<span class="lineNum"> 469 </span> : else -<span class="lineNum"> 470 </span> : { -<span class="lineNum"> 471 </span> : __result = __new_result; -<span class="lineNum"> 472 </span> : __first1 = __new_result; -<span class="lineNum"> 473 </span> : ++__first1; -<span class="lineNum"> 474 </span> : } -<span class="lineNum"> 475 </span> : } -<span class="lineNum"> 476 </span> : } -<span class="lineNum"> 477 </span> : } -<span class="lineNum"> 478 </span> : -<span class="lineNum"> 479 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2, -<span class="lineNum"> 480 </span> : typename _BinaryPredicate> -<span class="lineNum"> 481 </span> : _ForwardIterator1 -<span class="lineNum"> 482 </span> : __find_end(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 483 </span> : _ForwardIterator2 __first2, _ForwardIterator2 __last2, -<span class="lineNum"> 484 </span> : forward_iterator_tag, forward_iterator_tag, -<span class="lineNum"> 485 </span> : _BinaryPredicate __comp) -<span class="lineNum"> 486 </span> : { -<span class="lineNum"> 487 </span> : if (__first2 == __last2) -<span class="lineNum"> 488 </span> : return __last1; -<span class="lineNum"> 489 </span> : else -<span class="lineNum"> 490 </span> : { -<span class="lineNum"> 491 </span> : _ForwardIterator1 __result = __last1; -<span class="lineNum"> 492 </span> : while (1) -<span class="lineNum"> 493 </span> : { -<span class="lineNum"> 494 </span> : _ForwardIterator1 __new_result -<span class="lineNum"> 495 </span> : = _GLIBCXX_STD_P::search(__first1, __last1, __first2, -<span class="lineNum"> 496 </span> : __last2, __comp); -<span class="lineNum"> 497 </span> : if (__new_result == __last1) -<span class="lineNum"> 498 </span> : return __result; -<span class="lineNum"> 499 </span> : else -<span class="lineNum"> 500 </span> : { -<span class="lineNum"> 501 </span> : __result = __new_result; -<span class="lineNum"> 502 </span> : __first1 = __new_result; -<span class="lineNum"> 503 </span> : ++__first1; -<span class="lineNum"> 504 </span> : } -<span class="lineNum"> 505 </span> : } -<span class="lineNum"> 506 </span> : } -<span class="lineNum"> 507 </span> : } -<span class="lineNum"> 508 </span> : -<span class="lineNum"> 509 </span> : // find_end for bidirectional iterators (much faster). -<span class="lineNum"> 510 </span> : template<typename _BidirectionalIterator1, typename _BidirectionalIterator2> -<span class="lineNum"> 511 </span> : _BidirectionalIterator1 -<span class="lineNum"> 512 </span> : __find_end(_BidirectionalIterator1 __first1, -<span class="lineNum"> 513 </span> : _BidirectionalIterator1 __last1, -<span class="lineNum"> 514 </span> : _BidirectionalIterator2 __first2, -<span class="lineNum"> 515 </span> : _BidirectionalIterator2 __last2, -<span class="lineNum"> 516 </span> : bidirectional_iterator_tag, bidirectional_iterator_tag) -<span class="lineNum"> 517 </span> : { -<span class="lineNum"> 518 </span> : // concept requirements -<span class="lineNum"> 519 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 520 </span> : _BidirectionalIterator1>) -<span class="lineNum"> 521 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 522 </span> : _BidirectionalIterator2>) -<span class="lineNum"> 523 </span> : -<span class="lineNum"> 524 </span> : typedef reverse_iterator<_BidirectionalIterator1> _RevIterator1; -<span class="lineNum"> 525 </span> : typedef reverse_iterator<_BidirectionalIterator2> _RevIterator2; -<span class="lineNum"> 526 </span> : -<span class="lineNum"> 527 </span> : _RevIterator1 __rlast1(__first1); -<span class="lineNum"> 528 </span> : _RevIterator2 __rlast2(__first2); -<span class="lineNum"> 529 </span> : _RevIterator1 __rresult = _GLIBCXX_STD_P::search(_RevIterator1(__last1), -<span class="lineNum"> 530 </span> : __rlast1, -<span class="lineNum"> 531 </span> : _RevIterator2(__last2), -<span class="lineNum"> 532 </span> : __rlast2); -<span class="lineNum"> 533 </span> : -<span class="lineNum"> 534 </span> : if (__rresult == __rlast1) -<span class="lineNum"> 535 </span> : return __last1; -<span class="lineNum"> 536 </span> : else -<span class="lineNum"> 537 </span> : { -<span class="lineNum"> 538 </span> : _BidirectionalIterator1 __result = __rresult.base(); -<span class="lineNum"> 539 </span> : std::advance(__result, -std::distance(__first2, __last2)); -<span class="lineNum"> 540 </span> : return __result; -<span class="lineNum"> 541 </span> : } -<span class="lineNum"> 542 </span> : } -<span class="lineNum"> 543 </span> : -<span class="lineNum"> 544 </span> : template<typename _BidirectionalIterator1, typename _BidirectionalIterator2, -<span class="lineNum"> 545 </span> : typename _BinaryPredicate> -<span class="lineNum"> 546 </span> : _BidirectionalIterator1 -<span class="lineNum"> 547 </span> : __find_end(_BidirectionalIterator1 __first1, -<span class="lineNum"> 548 </span> : _BidirectionalIterator1 __last1, -<span class="lineNum"> 549 </span> : _BidirectionalIterator2 __first2, -<span class="lineNum"> 550 </span> : _BidirectionalIterator2 __last2, -<span class="lineNum"> 551 </span> : bidirectional_iterator_tag, bidirectional_iterator_tag, -<span class="lineNum"> 552 </span> : _BinaryPredicate __comp) -<span class="lineNum"> 553 </span> : { -<span class="lineNum"> 554 </span> : // concept requirements -<span class="lineNum"> 555 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 556 </span> : _BidirectionalIterator1>) -<span class="lineNum"> 557 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 558 </span> : _BidirectionalIterator2>) -<span class="lineNum"> 559 </span> : -<span class="lineNum"> 560 </span> : typedef reverse_iterator<_BidirectionalIterator1> _RevIterator1; -<span class="lineNum"> 561 </span> : typedef reverse_iterator<_BidirectionalIterator2> _RevIterator2; -<span class="lineNum"> 562 </span> : -<span class="lineNum"> 563 </span> : _RevIterator1 __rlast1(__first1); -<span class="lineNum"> 564 </span> : _RevIterator2 __rlast2(__first2); -<span class="lineNum"> 565 </span> : _RevIterator1 __rresult = std::search(_RevIterator1(__last1), __rlast1, -<span class="lineNum"> 566 </span> : _RevIterator2(__last2), __rlast2, -<span class="lineNum"> 567 </span> : __comp); -<span class="lineNum"> 568 </span> : -<span class="lineNum"> 569 </span> : if (__rresult == __rlast1) -<span class="lineNum"> 570 </span> : return __last1; -<span class="lineNum"> 571 </span> : else -<span class="lineNum"> 572 </span> : { -<span class="lineNum"> 573 </span> : _BidirectionalIterator1 __result = __rresult.base(); -<span class="lineNum"> 574 </span> : std::advance(__result, -std::distance(__first2, __last2)); -<span class="lineNum"> 575 </span> : return __result; -<span class="lineNum"> 576 </span> : } -<span class="lineNum"> 577 </span> : } -<span class="lineNum"> 578 </span> : -<span class="lineNum"> 579 </span> : /** -<span class="lineNum"> 580 </span> : * @brief Find last matching subsequence in a sequence. -<span class="lineNum"> 581 </span> : * @param first1 Start of range to search. -<span class="lineNum"> 582 </span> : * @param last1 End of range to search. -<span class="lineNum"> 583 </span> : * @param first2 Start of sequence to match. -<span class="lineNum"> 584 </span> : * @param last2 End of sequence to match. -<span class="lineNum"> 585 </span> : * @return The last iterator @c i in the range -<span class="lineNum"> 586 </span> : * @p [first1,last1-(last2-first2)) such that @c *(i+N) == @p *(first2+N) -<span class="lineNum"> 587 </span> : * for each @c N in the range @p [0,last2-first2), or @p last1 if no -<span class="lineNum"> 588 </span> : * such iterator exists. -<span class="lineNum"> 589 </span> : * -<span class="lineNum"> 590 </span> : * Searches the range @p [first1,last1) for a sub-sequence that compares -<span class="lineNum"> 591 </span> : * equal value-by-value with the sequence given by @p [first2,last2) and -<span class="lineNum"> 592 </span> : * returns an iterator to the first element of the sub-sequence, or -<span class="lineNum"> 593 </span> : * @p last1 if the sub-sequence is not found. The sub-sequence will be the -<span class="lineNum"> 594 </span> : * last such subsequence contained in [first,last1). -<span class="lineNum"> 595 </span> : * -<span class="lineNum"> 596 </span> : * Because the sub-sequence must lie completely within the range -<span class="lineNum"> 597 </span> : * @p [first1,last1) it must start at a position less than -<span class="lineNum"> 598 </span> : * @p last1-(last2-first2) where @p last2-first2 is the length of the -<span class="lineNum"> 599 </span> : * sub-sequence. -<span class="lineNum"> 600 </span> : * This means that the returned iterator @c i will be in the range -<span class="lineNum"> 601 </span> : * @p [first1,last1-(last2-first2)) -<span class="lineNum"> 602 </span> : */ -<span class="lineNum"> 603 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 604 </span> : inline _ForwardIterator1 -<span class="lineNum"> 605 </span> : find_end(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 606 </span> : _ForwardIterator2 __first2, _ForwardIterator2 __last2) -<span class="lineNum"> 607 </span> : { -<span class="lineNum"> 608 </span> : // concept requirements -<span class="lineNum"> 609 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator1>) -<span class="lineNum"> 610 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator2>) -<span class="lineNum"> 611 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 612 </span> : typename iterator_traits<_ForwardIterator1>::value_type, -<span class="lineNum"> 613 </span> : typename iterator_traits<_ForwardIterator2>::value_type>) -<span class="lineNum"> 614 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 615 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 616 </span> : -<span class="lineNum"> 617 </span> : return std::__find_end(__first1, __last1, __first2, __last2, -<span class="lineNum"> 618 </span> : std::__iterator_category(__first1), -<span class="lineNum"> 619 </span> : std::__iterator_category(__first2)); -<span class="lineNum"> 620 </span> : } -<span class="lineNum"> 621 </span> : -<span class="lineNum"> 622 </span> : /** -<span class="lineNum"> 623 </span> : * @brief Find last matching subsequence in a sequence using a predicate. -<span class="lineNum"> 624 </span> : * @param first1 Start of range to search. -<span class="lineNum"> 625 </span> : * @param last1 End of range to search. -<span class="lineNum"> 626 </span> : * @param first2 Start of sequence to match. -<span class="lineNum"> 627 </span> : * @param last2 End of sequence to match. -<span class="lineNum"> 628 </span> : * @param comp The predicate to use. -<span class="lineNum"> 629 </span> : * @return The last iterator @c i in the range -<span class="lineNum"> 630 </span> : * @p [first1,last1-(last2-first2)) such that @c predicate(*(i+N), @p -<span class="lineNum"> 631 </span> : * (first2+N)) is true for each @c N in the range @p [0,last2-first2), or -<span class="lineNum"> 632 </span> : * @p last1 if no such iterator exists. -<span class="lineNum"> 633 </span> : * -<span class="lineNum"> 634 </span> : * Searches the range @p [first1,last1) for a sub-sequence that compares -<span class="lineNum"> 635 </span> : * equal value-by-value with the sequence given by @p [first2,last2) using -<span class="lineNum"> 636 </span> : * comp as a predicate and returns an iterator to the first element of the -<span class="lineNum"> 637 </span> : * sub-sequence, or @p last1 if the sub-sequence is not found. The -<span class="lineNum"> 638 </span> : * sub-sequence will be the last such subsequence contained in -<span class="lineNum"> 639 </span> : * [first,last1). -<span class="lineNum"> 640 </span> : * -<span class="lineNum"> 641 </span> : * Because the sub-sequence must lie completely within the range -<span class="lineNum"> 642 </span> : * @p [first1,last1) it must start at a position less than -<span class="lineNum"> 643 </span> : * @p last1-(last2-first2) where @p last2-first2 is the length of the -<span class="lineNum"> 644 </span> : * sub-sequence. -<span class="lineNum"> 645 </span> : * This means that the returned iterator @c i will be in the range -<span class="lineNum"> 646 </span> : * @p [first1,last1-(last2-first2)) -<span class="lineNum"> 647 </span> : */ -<span class="lineNum"> 648 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2, -<span class="lineNum"> 649 </span> : typename _BinaryPredicate> -<span class="lineNum"> 650 </span> : inline _ForwardIterator1 -<span class="lineNum"> 651 </span> : find_end(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 652 </span> : _ForwardIterator2 __first2, _ForwardIterator2 __last2, -<span class="lineNum"> 653 </span> : _BinaryPredicate __comp) -<span class="lineNum"> 654 </span> : { -<span class="lineNum"> 655 </span> : // concept requirements -<span class="lineNum"> 656 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator1>) -<span class="lineNum"> 657 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator2>) -<span class="lineNum"> 658 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 659 </span> : typename iterator_traits<_ForwardIterator1>::value_type, -<span class="lineNum"> 660 </span> : typename iterator_traits<_ForwardIterator2>::value_type>) -<span class="lineNum"> 661 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 662 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 663 </span> : -<span class="lineNum"> 664 </span> : return std::__find_end(__first1, __last1, __first2, __last2, -<span class="lineNum"> 665 </span> : std::__iterator_category(__first1), -<span class="lineNum"> 666 </span> : std::__iterator_category(__first2), -<span class="lineNum"> 667 </span> : __comp); -<span class="lineNum"> 668 </span> : } -<span class="lineNum"> 669 </span> : -<span class="lineNum"> 670 </span> : -<span class="lineNum"> 671 </span> : /** -<span class="lineNum"> 672 </span> : * @brief Copy a sequence, removing elements of a given value. -<span class="lineNum"> 673 </span> : * @param first An input iterator. -<span class="lineNum"> 674 </span> : * @param last An input iterator. -<span class="lineNum"> 675 </span> : * @param result An output iterator. -<span class="lineNum"> 676 </span> : * @param value The value to be removed. -<span class="lineNum"> 677 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 678 </span> : * -<span class="lineNum"> 679 </span> : * Copies each element in the range @p [first,last) not equal to @p value -<span class="lineNum"> 680 </span> : * to the range beginning at @p result. -<span class="lineNum"> 681 </span> : * remove_copy() is stable, so the relative order of elements that are -<span class="lineNum"> 682 </span> : * copied is unchanged. -<span class="lineNum"> 683 </span> : */ -<span class="lineNum"> 684 </span> : template<typename _InputIterator, typename _OutputIterator, typename _Tp> -<span class="lineNum"> 685 </span> : _OutputIterator -<span class="lineNum"> 686 </span> : remove_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 687 </span> : _OutputIterator __result, const _Tp& __value) -<span class="lineNum"> 688 </span> : { -<span class="lineNum"> 689 </span> : // concept requirements -<span class="lineNum"> 690 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 691 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 692 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 693 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 694 </span> : typename iterator_traits<_InputIterator>::value_type, _Tp>) -<span class="lineNum"> 695 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 696 </span> : -<span class="lineNum"> 697 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 698 </span> : if (!(*__first == __value)) -<span class="lineNum"> 699 </span> : { -<span class="lineNum"> 700 </span> : *__result = *__first; -<span class="lineNum"> 701 </span> : ++__result; -<span class="lineNum"> 702 </span> : } -<span class="lineNum"> 703 </span> : return __result; -<span class="lineNum"> 704 </span> : } -<span class="lineNum"> 705 </span> : -<span class="lineNum"> 706 </span> : /** -<span class="lineNum"> 707 </span> : * @brief Copy a sequence, removing elements for which a predicate is true. -<span class="lineNum"> 708 </span> : * @param first An input iterator. -<span class="lineNum"> 709 </span> : * @param last An input iterator. -<span class="lineNum"> 710 </span> : * @param result An output iterator. -<span class="lineNum"> 711 </span> : * @param pred A predicate. -<span class="lineNum"> 712 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 713 </span> : * -<span class="lineNum"> 714 </span> : * Copies each element in the range @p [first,last) for which -<span class="lineNum"> 715 </span> : * @p pred returns false to the range beginning at @p result. -<span class="lineNum"> 716 </span> : * -<span class="lineNum"> 717 </span> : * remove_copy_if() is stable, so the relative order of elements that are -<span class="lineNum"> 718 </span> : * copied is unchanged. -<span class="lineNum"> 719 </span> : */ -<span class="lineNum"> 720 </span> : template<typename _InputIterator, typename _OutputIterator, -<span class="lineNum"> 721 </span> : typename _Predicate> -<span class="lineNum"> 722 </span> : _OutputIterator -<span class="lineNum"> 723 </span> : remove_copy_if(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 724 </span><span class="lineCov"> 16 : _OutputIterator __result, _Predicate __pred)</span> -<span class="lineNum"> 725 </span> : { -<span class="lineNum"> 726 </span> : // concept requirements -<span class="lineNum"> 727 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 728 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 729 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 730 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 731 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 732 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 733 </span> : -<span class="lineNum"> 734 </span><span class="lineCov"> 80 : for (; __first != __last; ++__first)</span> -<span class="lineNum"> 735 </span><span class="lineCov"> 64 : if (!bool(__pred(*__first)))</span> -<span class="lineNum"> 736 </span> : { -<span class="lineNum"> 737 </span><span class="lineCov"> 48 : *__result = *__first;</span> -<span class="lineNum"> 738 </span><span class="lineCov"> 48 : ++__result;</span> -<span class="lineNum"> 739 </span> : } -<span class="lineNum"> 740 </span><span class="lineCov"> 16 : return __result;</span> -<span class="lineNum"> 741 </span> : } -<span class="lineNum"> 742 </span> : -<span class="lineNum"> 743 </span> : /** -<span class="lineNum"> 744 </span> : * @brief Remove elements from a sequence. -<span class="lineNum"> 745 </span> : * @param first An input iterator. -<span class="lineNum"> 746 </span> : * @param last An input iterator. -<span class="lineNum"> 747 </span> : * @param value The value to be removed. -<span class="lineNum"> 748 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 749 </span> : * -<span class="lineNum"> 750 </span> : * All elements equal to @p value are removed from the range -<span class="lineNum"> 751 </span> : * @p [first,last). -<span class="lineNum"> 752 </span> : * -<span class="lineNum"> 753 </span> : * remove() is stable, so the relative order of elements that are -<span class="lineNum"> 754 </span> : * not removed is unchanged. -<span class="lineNum"> 755 </span> : * -<span class="lineNum"> 756 </span> : * Elements between the end of the resulting sequence and @p last -<span class="lineNum"> 757 </span> : * are still present, but their value is unspecified. -<span class="lineNum"> 758 </span> : */ -<span class="lineNum"> 759 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 760 </span> : _ForwardIterator -<span class="lineNum"> 761 </span> : remove(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 762 </span> : const _Tp& __value) -<span class="lineNum"> 763 </span> : { -<span class="lineNum"> 764 </span> : // concept requirements -<span class="lineNum"> 765 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 766 </span> : _ForwardIterator>) -<span class="lineNum"> 767 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 768 </span> : typename iterator_traits<_ForwardIterator>::value_type, _Tp>) -<span class="lineNum"> 769 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 770 </span> : -<span class="lineNum"> 771 </span> : __first = _GLIBCXX_STD_P::find(__first, __last, __value); -<span class="lineNum"> 772 </span> : if(__first == __last) -<span class="lineNum"> 773 </span> : return __first; -<span class="lineNum"> 774 </span> : _ForwardIterator __result = __first; -<span class="lineNum"> 775 </span> : ++__first; -<span class="lineNum"> 776 </span> : for(; __first != __last; ++__first) -<span class="lineNum"> 777 </span> : if(!(*__first == __value)) -<span class="lineNum"> 778 </span> : { -<span class="lineNum"> 779 </span> : *__result = _GLIBCXX_MOVE(*__first); -<span class="lineNum"> 780 </span> : ++__result; -<span class="lineNum"> 781 </span> : } -<span class="lineNum"> 782 </span> : return __result; -<span class="lineNum"> 783 </span> : } -<span class="lineNum"> 784 </span> : -<span class="lineNum"> 785 </span> : /** -<span class="lineNum"> 786 </span> : * @brief Remove elements from a sequence using a predicate. -<span class="lineNum"> 787 </span> : * @param first A forward iterator. -<span class="lineNum"> 788 </span> : * @param last A forward iterator. -<span class="lineNum"> 789 </span> : * @param pred A predicate. -<span class="lineNum"> 790 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 791 </span> : * -<span class="lineNum"> 792 </span> : * All elements for which @p pred returns true are removed from the range -<span class="lineNum"> 793 </span> : * @p [first,last). -<span class="lineNum"> 794 </span> : * -<span class="lineNum"> 795 </span> : * remove_if() is stable, so the relative order of elements that are -<span class="lineNum"> 796 </span> : * not removed is unchanged. -<span class="lineNum"> 797 </span> : * -<span class="lineNum"> 798 </span> : * Elements between the end of the resulting sequence and @p last -<span class="lineNum"> 799 </span> : * are still present, but their value is unspecified. -<span class="lineNum"> 800 </span> : */ -<span class="lineNum"> 801 </span> : template<typename _ForwardIterator, typename _Predicate> -<span class="lineNum"> 802 </span> : _ForwardIterator -<span class="lineNum"> 803 </span> : remove_if(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 804 </span> : _Predicate __pred) -<span class="lineNum"> 805 </span> : { -<span class="lineNum"> 806 </span> : // concept requirements -<span class="lineNum"> 807 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 808 </span> : _ForwardIterator>) -<span class="lineNum"> 809 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 810 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 811 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 812 </span> : -<span class="lineNum"> 813 </span> : __first = _GLIBCXX_STD_P::find_if(__first, __last, __pred); -<span class="lineNum"> 814 </span> : if(__first == __last) -<span class="lineNum"> 815 </span> : return __first; -<span class="lineNum"> 816 </span> : _ForwardIterator __result = __first; -<span class="lineNum"> 817 </span> : ++__first; -<span class="lineNum"> 818 </span> : for(; __first != __last; ++__first) -<span class="lineNum"> 819 </span> : if(!bool(__pred(*__first))) -<span class="lineNum"> 820 </span> : { -<span class="lineNum"> 821 </span> : *__result = _GLIBCXX_MOVE(*__first); -<span class="lineNum"> 822 </span> : ++__result; -<span class="lineNum"> 823 </span> : } -<span class="lineNum"> 824 </span> : return __result; -<span class="lineNum"> 825 </span> : } -<span class="lineNum"> 826 </span> : -<span class="lineNum"> 827 </span> : /** -<span class="lineNum"> 828 </span> : * @brief Remove consecutive duplicate values from a sequence. -<span class="lineNum"> 829 </span> : * @param first A forward iterator. -<span class="lineNum"> 830 </span> : * @param last A forward iterator. -<span class="lineNum"> 831 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 832 </span> : * -<span class="lineNum"> 833 </span> : * Removes all but the first element from each group of consecutive -<span class="lineNum"> 834 </span> : * values that compare equal. -<span class="lineNum"> 835 </span> : * unique() is stable, so the relative order of elements that are -<span class="lineNum"> 836 </span> : * not removed is unchanged. -<span class="lineNum"> 837 </span> : * Elements between the end of the resulting sequence and @p last -<span class="lineNum"> 838 </span> : * are still present, but their value is unspecified. -<span class="lineNum"> 839 </span> : */ -<span class="lineNum"> 840 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 841 </span> : _ForwardIterator -<span class="lineNum"> 842 </span> : unique(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 843 </span> : { -<span class="lineNum"> 844 </span> : // concept requirements -<span class="lineNum"> 845 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 846 </span> : _ForwardIterator>) -<span class="lineNum"> 847 </span> : __glibcxx_function_requires(_EqualityComparableConcept< -<span class="lineNum"> 848 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 849 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 850 </span> : -<span class="lineNum"> 851 </span> : // Skip the beginning, if already unique. -<span class="lineNum"> 852 </span> : __first = _GLIBCXX_STD_P::adjacent_find(__first, __last); -<span class="lineNum"> 853 </span> : if (__first == __last) -<span class="lineNum"> 854 </span> : return __last; -<span class="lineNum"> 855 </span> : -<span class="lineNum"> 856 </span> : // Do the real copy work. -<span class="lineNum"> 857 </span> : _ForwardIterator __dest = __first; -<span class="lineNum"> 858 </span> : ++__first; -<span class="lineNum"> 859 </span> : while (++__first != __last) -<span class="lineNum"> 860 </span> : if (!(*__dest == *__first)) -<span class="lineNum"> 861 </span> : *++__dest = _GLIBCXX_MOVE(*__first); -<span class="lineNum"> 862 </span> : return ++__dest; -<span class="lineNum"> 863 </span> : } -<span class="lineNum"> 864 </span> : -<span class="lineNum"> 865 </span> : /** -<span class="lineNum"> 866 </span> : * @brief Remove consecutive values from a sequence using a predicate. -<span class="lineNum"> 867 </span> : * @param first A forward iterator. -<span class="lineNum"> 868 </span> : * @param last A forward iterator. -<span class="lineNum"> 869 </span> : * @param binary_pred A binary predicate. -<span class="lineNum"> 870 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 871 </span> : * -<span class="lineNum"> 872 </span> : * Removes all but the first element from each group of consecutive -<span class="lineNum"> 873 </span> : * values for which @p binary_pred returns true. -<span class="lineNum"> 874 </span> : * unique() is stable, so the relative order of elements that are -<span class="lineNum"> 875 </span> : * not removed is unchanged. -<span class="lineNum"> 876 </span> : * Elements between the end of the resulting sequence and @p last -<span class="lineNum"> 877 </span> : * are still present, but their value is unspecified. -<span class="lineNum"> 878 </span> : */ -<span class="lineNum"> 879 </span> : template<typename _ForwardIterator, typename _BinaryPredicate> -<span class="lineNum"> 880 </span> : _ForwardIterator -<span class="lineNum"> 881 </span> : unique(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 882 </span> : _BinaryPredicate __binary_pred) -<span class="lineNum"> 883 </span> : { -<span class="lineNum"> 884 </span> : // concept requirements -<span class="lineNum"> 885 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 886 </span> : _ForwardIterator>) -<span class="lineNum"> 887 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 888 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 889 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 890 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 891 </span> : -<span class="lineNum"> 892 </span> : // Skip the beginning, if already unique. -<span class="lineNum"> 893 </span> : __first = _GLIBCXX_STD_P::adjacent_find(__first, __last, __binary_pred); -<span class="lineNum"> 894 </span> : if (__first == __last) -<span class="lineNum"> 895 </span> : return __last; -<span class="lineNum"> 896 </span> : -<span class="lineNum"> 897 </span> : // Do the real copy work. -<span class="lineNum"> 898 </span> : _ForwardIterator __dest = __first; -<span class="lineNum"> 899 </span> : ++__first; -<span class="lineNum"> 900 </span> : while (++__first != __last) -<span class="lineNum"> 901 </span> : if (!bool(__binary_pred(*__dest, *__first))) -<span class="lineNum"> 902 </span> : *++__dest = _GLIBCXX_MOVE(*__first); -<span class="lineNum"> 903 </span> : return ++__dest; -<span class="lineNum"> 904 </span> : } -<span class="lineNum"> 905 </span> : -<span class="lineNum"> 906 </span> : /** -<span class="lineNum"> 907 </span> : * This is an uglified unique_copy(_InputIterator, _InputIterator, -<span class="lineNum"> 908 </span> : * _OutputIterator) -<span class="lineNum"> 909 </span> : * overloaded for forward iterators and output iterator as result. -<span class="lineNum"> 910 </span> : */ -<span class="lineNum"> 911 </span> : template<typename _ForwardIterator, typename _OutputIterator> -<span class="lineNum"> 912 </span> : _OutputIterator -<span class="lineNum"> 913 </span> : __unique_copy(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 914 </span> : _OutputIterator __result, -<span class="lineNum"> 915 </span> : forward_iterator_tag, output_iterator_tag) -<span class="lineNum"> 916 </span> : { -<span class="lineNum"> 917 </span> : // concept requirements -- taken care of in dispatching function -<span class="lineNum"> 918 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 919 </span> : *__result = *__first; -<span class="lineNum"> 920 </span> : while (++__next != __last) -<span class="lineNum"> 921 </span> : if (!(*__first == *__next)) -<span class="lineNum"> 922 </span> : { -<span class="lineNum"> 923 </span> : __first = __next; -<span class="lineNum"> 924 </span> : *++__result = *__first; -<span class="lineNum"> 925 </span> : } -<span class="lineNum"> 926 </span> : return ++__result; -<span class="lineNum"> 927 </span> : } -<span class="lineNum"> 928 </span> : -<span class="lineNum"> 929 </span> : /** -<span class="lineNum"> 930 </span> : * This is an uglified unique_copy(_InputIterator, _InputIterator, -<span class="lineNum"> 931 </span> : * _OutputIterator) -<span class="lineNum"> 932 </span> : * overloaded for input iterators and output iterator as result. -<span class="lineNum"> 933 </span> : */ -<span class="lineNum"> 934 </span> : template<typename _InputIterator, typename _OutputIterator> -<span class="lineNum"> 935 </span> : _OutputIterator -<span class="lineNum"> 936 </span> : __unique_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 937 </span> : _OutputIterator __result, -<span class="lineNum"> 938 </span> : input_iterator_tag, output_iterator_tag) -<span class="lineNum"> 939 </span> : { -<span class="lineNum"> 940 </span> : // concept requirements -- taken care of in dispatching function -<span class="lineNum"> 941 </span> : typename iterator_traits<_InputIterator>::value_type __value = *__first; -<span class="lineNum"> 942 </span> : *__result = __value; -<span class="lineNum"> 943 </span> : while (++__first != __last) -<span class="lineNum"> 944 </span> : if (!(__value == *__first)) -<span class="lineNum"> 945 </span> : { -<span class="lineNum"> 946 </span> : __value = *__first; -<span class="lineNum"> 947 </span> : *++__result = __value; -<span class="lineNum"> 948 </span> : } -<span class="lineNum"> 949 </span> : return ++__result; -<span class="lineNum"> 950 </span> : } -<span class="lineNum"> 951 </span> : -<span class="lineNum"> 952 </span> : /** -<span class="lineNum"> 953 </span> : * This is an uglified unique_copy(_InputIterator, _InputIterator, -<span class="lineNum"> 954 </span> : * _OutputIterator) -<span class="lineNum"> 955 </span> : * overloaded for input iterators and forward iterator as result. -<span class="lineNum"> 956 </span> : */ -<span class="lineNum"> 957 </span> : template<typename _InputIterator, typename _ForwardIterator> -<span class="lineNum"> 958 </span> : _ForwardIterator -<span class="lineNum"> 959 </span> : __unique_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 960 </span> : _ForwardIterator __result, -<span class="lineNum"> 961 </span> : input_iterator_tag, forward_iterator_tag) -<span class="lineNum"> 962 </span> : { -<span class="lineNum"> 963 </span> : // concept requirements -- taken care of in dispatching function -<span class="lineNum"> 964 </span> : *__result = *__first; -<span class="lineNum"> 965 </span> : while (++__first != __last) -<span class="lineNum"> 966 </span> : if (!(*__result == *__first)) -<span class="lineNum"> 967 </span> : *++__result = *__first; -<span class="lineNum"> 968 </span> : return ++__result; -<span class="lineNum"> 969 </span> : } -<span class="lineNum"> 970 </span> : -<span class="lineNum"> 971 </span> : /** -<span class="lineNum"> 972 </span> : * This is an uglified -<span class="lineNum"> 973 </span> : * unique_copy(_InputIterator, _InputIterator, _OutputIterator, -<span class="lineNum"> 974 </span> : * _BinaryPredicate) -<span class="lineNum"> 975 </span> : * overloaded for forward iterators and output iterator as result. -<span class="lineNum"> 976 </span> : */ -<span class="lineNum"> 977 </span> : template<typename _ForwardIterator, typename _OutputIterator, -<span class="lineNum"> 978 </span> : typename _BinaryPredicate> -<span class="lineNum"> 979 </span> : _OutputIterator -<span class="lineNum"> 980 </span> : __unique_copy(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 981 </span> : _OutputIterator __result, _BinaryPredicate __binary_pred, -<span class="lineNum"> 982 </span> : forward_iterator_tag, output_iterator_tag) -<span class="lineNum"> 983 </span> : { -<span class="lineNum"> 984 </span> : // concept requirements -- iterators already checked -<span class="lineNum"> 985 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 986 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 987 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 988 </span> : -<span class="lineNum"> 989 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 990 </span> : *__result = *__first; -<span class="lineNum"> 991 </span> : while (++__next != __last) -<span class="lineNum"> 992 </span> : if (!bool(__binary_pred(*__first, *__next))) -<span class="lineNum"> 993 </span> : { -<span class="lineNum"> 994 </span> : __first = __next; -<span class="lineNum"> 995 </span> : *++__result = *__first; -<span class="lineNum"> 996 </span> : } -<span class="lineNum"> 997 </span> : return ++__result; -<span class="lineNum"> 998 </span> : } -<span class="lineNum"> 999 </span> : -<span class="lineNum"> 1000 </span> : /** -<span class="lineNum"> 1001 </span> : * This is an uglified -<span class="lineNum"> 1002 </span> : * unique_copy(_InputIterator, _InputIterator, _OutputIterator, -<span class="lineNum"> 1003 </span> : * _BinaryPredicate) -<span class="lineNum"> 1004 </span> : * overloaded for input iterators and output iterator as result. -<span class="lineNum"> 1005 </span> : */ -<span class="lineNum"> 1006 </span> : template<typename _InputIterator, typename _OutputIterator, -<span class="lineNum"> 1007 </span> : typename _BinaryPredicate> -<span class="lineNum"> 1008 </span> : _OutputIterator -<span class="lineNum"> 1009 </span> : __unique_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1010 </span> : _OutputIterator __result, _BinaryPredicate __binary_pred, -<span class="lineNum"> 1011 </span> : input_iterator_tag, output_iterator_tag) -<span class="lineNum"> 1012 </span> : { -<span class="lineNum"> 1013 </span> : // concept requirements -- iterators already checked -<span class="lineNum"> 1014 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 1015 </span> : typename iterator_traits<_InputIterator>::value_type, -<span class="lineNum"> 1016 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 1017 </span> : -<span class="lineNum"> 1018 </span> : typename iterator_traits<_InputIterator>::value_type __value = *__first; -<span class="lineNum"> 1019 </span> : *__result = __value; -<span class="lineNum"> 1020 </span> : while (++__first != __last) -<span class="lineNum"> 1021 </span> : if (!bool(__binary_pred(__value, *__first))) -<span class="lineNum"> 1022 </span> : { -<span class="lineNum"> 1023 </span> : __value = *__first; -<span class="lineNum"> 1024 </span> : *++__result = __value; -<span class="lineNum"> 1025 </span> : } -<span class="lineNum"> 1026 </span> : return ++__result; -<span class="lineNum"> 1027 </span> : } -<span class="lineNum"> 1028 </span> : -<span class="lineNum"> 1029 </span> : /** -<span class="lineNum"> 1030 </span> : * This is an uglified -<span class="lineNum"> 1031 </span> : * unique_copy(_InputIterator, _InputIterator, _OutputIterator, -<span class="lineNum"> 1032 </span> : * _BinaryPredicate) -<span class="lineNum"> 1033 </span> : * overloaded for input iterators and forward iterator as result. -<span class="lineNum"> 1034 </span> : */ -<span class="lineNum"> 1035 </span> : template<typename _InputIterator, typename _ForwardIterator, -<span class="lineNum"> 1036 </span> : typename _BinaryPredicate> -<span class="lineNum"> 1037 </span> : _ForwardIterator -<span class="lineNum"> 1038 </span> : __unique_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1039 </span> : _ForwardIterator __result, _BinaryPredicate __binary_pred, -<span class="lineNum"> 1040 </span> : input_iterator_tag, forward_iterator_tag) -<span class="lineNum"> 1041 </span> : { -<span class="lineNum"> 1042 </span> : // concept requirements -- iterators already checked -<span class="lineNum"> 1043 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 1044 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 1045 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 1046 </span> : -<span class="lineNum"> 1047 </span> : *__result = *__first; -<span class="lineNum"> 1048 </span> : while (++__first != __last) -<span class="lineNum"> 1049 </span> : if (!bool(__binary_pred(*__result, *__first))) -<span class="lineNum"> 1050 </span> : *++__result = *__first; -<span class="lineNum"> 1051 </span> : return ++__result; -<span class="lineNum"> 1052 </span> : } -<span class="lineNum"> 1053 </span> : -<span class="lineNum"> 1054 </span> : /** -<span class="lineNum"> 1055 </span> : * This is an uglified reverse(_BidirectionalIterator, -<span class="lineNum"> 1056 </span> : * _BidirectionalIterator) -<span class="lineNum"> 1057 </span> : * overloaded for bidirectional iterators. -<span class="lineNum"> 1058 </span> : */ -<span class="lineNum"> 1059 </span> : template<typename _BidirectionalIterator> -<span class="lineNum"> 1060 </span> : void -<span class="lineNum"> 1061 </span> : __reverse(_BidirectionalIterator __first, _BidirectionalIterator __last, -<span class="lineNum"> 1062 </span> : bidirectional_iterator_tag) -<span class="lineNum"> 1063 </span> : { -<span class="lineNum"> 1064 </span> : while (true) -<span class="lineNum"> 1065 </span> : if (__first == __last || __first == --__last) -<span class="lineNum"> 1066 </span> : return; -<span class="lineNum"> 1067 </span> : else -<span class="lineNum"> 1068 </span> : { -<span class="lineNum"> 1069 </span> : std::iter_swap(__first, __last); -<span class="lineNum"> 1070 </span> : ++__first; -<span class="lineNum"> 1071 </span> : } -<span class="lineNum"> 1072 </span> : } -<span class="lineNum"> 1073 </span> : -<span class="lineNum"> 1074 </span> : /** -<span class="lineNum"> 1075 </span> : * This is an uglified reverse(_BidirectionalIterator, -<span class="lineNum"> 1076 </span> : * _BidirectionalIterator) -<span class="lineNum"> 1077 </span> : * overloaded for random access iterators. -<span class="lineNum"> 1078 </span> : */ -<span class="lineNum"> 1079 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 1080 </span> : void -<span class="lineNum"> 1081 </span> : __reverse(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 1082 </span> : random_access_iterator_tag) -<span class="lineNum"> 1083 </span> : { -<span class="lineNum"> 1084 </span> : if (__first == __last) -<span class="lineNum"> 1085 </span> : return; -<span class="lineNum"> 1086 </span> : --__last; -<span class="lineNum"> 1087 </span> : while (__first < __last) -<span class="lineNum"> 1088 </span> : { -<span class="lineNum"> 1089 </span> : std::iter_swap(__first, __last); -<span class="lineNum"> 1090 </span> : ++__first; -<span class="lineNum"> 1091 </span> : --__last; -<span class="lineNum"> 1092 </span> : } -<span class="lineNum"> 1093 </span> : } -<span class="lineNum"> 1094 </span> : -<span class="lineNum"> 1095 </span> : /** -<span class="lineNum"> 1096 </span> : * @brief Reverse a sequence. -<span class="lineNum"> 1097 </span> : * @param first A bidirectional iterator. -<span class="lineNum"> 1098 </span> : * @param last A bidirectional iterator. -<span class="lineNum"> 1099 </span> : * @return reverse() returns no value. -<span class="lineNum"> 1100 </span> : * -<span class="lineNum"> 1101 </span> : * Reverses the order of the elements in the range @p [first,last), -<span class="lineNum"> 1102 </span> : * so that the first element becomes the last etc. -<span class="lineNum"> 1103 </span> : * For every @c i such that @p 0<=i<=(last-first)/2), @p reverse() -<span class="lineNum"> 1104 </span> : * swaps @p *(first+i) and @p *(last-(i+1)) -<span class="lineNum"> 1105 </span> : */ -<span class="lineNum"> 1106 </span> : template<typename _BidirectionalIterator> -<span class="lineNum"> 1107 </span> : inline void -<span class="lineNum"> 1108 </span> : reverse(_BidirectionalIterator __first, _BidirectionalIterator __last) -<span class="lineNum"> 1109 </span> : { -<span class="lineNum"> 1110 </span> : // concept requirements -<span class="lineNum"> 1111 </span> : __glibcxx_function_requires(_Mutable_BidirectionalIteratorConcept< -<span class="lineNum"> 1112 </span> : _BidirectionalIterator>) -<span class="lineNum"> 1113 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 1114 </span> : std::__reverse(__first, __last, std::__iterator_category(__first)); -<span class="lineNum"> 1115 </span> : } -<span class="lineNum"> 1116 </span> : -<span class="lineNum"> 1117 </span> : /** -<span class="lineNum"> 1118 </span> : * @brief Copy a sequence, reversing its elements. -<span class="lineNum"> 1119 </span> : * @param first A bidirectional iterator. -<span class="lineNum"> 1120 </span> : * @param last A bidirectional iterator. -<span class="lineNum"> 1121 </span> : * @param result An output iterator. -<span class="lineNum"> 1122 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 1123 </span> : * -<span class="lineNum"> 1124 </span> : * Copies the elements in the range @p [first,last) to the range -<span class="lineNum"> 1125 </span> : * @p [result,result+(last-first)) such that the order of the -<span class="lineNum"> 1126 </span> : * elements is reversed. -<span class="lineNum"> 1127 </span> : * For every @c i such that @p 0<=i<=(last-first), @p reverse_copy() -<span class="lineNum"> 1128 </span> : * performs the assignment @p *(result+(last-first)-i) = *(first+i). -<span class="lineNum"> 1129 </span> : * The ranges @p [first,last) and @p [result,result+(last-first)) -<span class="lineNum"> 1130 </span> : * must not overlap. -<span class="lineNum"> 1131 </span> : */ -<span class="lineNum"> 1132 </span> : template<typename _BidirectionalIterator, typename _OutputIterator> -<span class="lineNum"> 1133 </span> : _OutputIterator -<span class="lineNum"> 1134 </span> : reverse_copy(_BidirectionalIterator __first, _BidirectionalIterator __last, -<span class="lineNum"> 1135 </span> : _OutputIterator __result) -<span class="lineNum"> 1136 </span> : { -<span class="lineNum"> 1137 </span> : // concept requirements -<span class="lineNum"> 1138 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 1139 </span> : _BidirectionalIterator>) -<span class="lineNum"> 1140 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 1141 </span> : typename iterator_traits<_BidirectionalIterator>::value_type>) -<span class="lineNum"> 1142 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 1143 </span> : -<span class="lineNum"> 1144 </span> : while (__first != __last) -<span class="lineNum"> 1145 </span> : { -<span class="lineNum"> 1146 </span> : --__last; -<span class="lineNum"> 1147 </span> : *__result = *__last; -<span class="lineNum"> 1148 </span> : ++__result; -<span class="lineNum"> 1149 </span> : } -<span class="lineNum"> 1150 </span> : return __result; -<span class="lineNum"> 1151 </span> : } -<span class="lineNum"> 1152 </span> : -<span class="lineNum"> 1153 </span> : /** -<span class="lineNum"> 1154 </span> : * This is a helper function for the rotate algorithm specialized on RAIs. -<span class="lineNum"> 1155 </span> : * It returns the greatest common divisor of two integer values. -<span class="lineNum"> 1156 </span> : */ -<span class="lineNum"> 1157 </span> : template<typename _EuclideanRingElement> -<span class="lineNum"> 1158 </span> : _EuclideanRingElement -<span class="lineNum"> 1159 </span> : __gcd(_EuclideanRingElement __m, _EuclideanRingElement __n) -<span class="lineNum"> 1160 </span> : { -<span class="lineNum"> 1161 </span> : while (__n != 0) -<span class="lineNum"> 1162 </span> : { -<span class="lineNum"> 1163 </span> : _EuclideanRingElement __t = __m % __n; -<span class="lineNum"> 1164 </span> : __m = __n; -<span class="lineNum"> 1165 </span> : __n = __t; -<span class="lineNum"> 1166 </span> : } -<span class="lineNum"> 1167 </span> : return __m; -<span class="lineNum"> 1168 </span> : } -<span class="lineNum"> 1169 </span> : -<span class="lineNum"> 1170 </span> : /// This is a helper function for the rotate algorithm. -<span class="lineNum"> 1171 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1172 </span> : void -<span class="lineNum"> 1173 </span> : __rotate(_ForwardIterator __first, -<span class="lineNum"> 1174 </span> : _ForwardIterator __middle, -<span class="lineNum"> 1175 </span> : _ForwardIterator __last, -<span class="lineNum"> 1176 </span> : forward_iterator_tag) -<span class="lineNum"> 1177 </span> : { -<span class="lineNum"> 1178 </span> : if (__first == __middle || __last == __middle) -<span class="lineNum"> 1179 </span> : return; -<span class="lineNum"> 1180 </span> : -<span class="lineNum"> 1181 </span> : _ForwardIterator __first2 = __middle; -<span class="lineNum"> 1182 </span> : do -<span class="lineNum"> 1183 </span> : { -<span class="lineNum"> 1184 </span> : std::iter_swap(__first, __first2); -<span class="lineNum"> 1185 </span> : ++__first; -<span class="lineNum"> 1186 </span> : ++__first2; -<span class="lineNum"> 1187 </span> : if (__first == __middle) -<span class="lineNum"> 1188 </span> : __middle = __first2; -<span class="lineNum"> 1189 </span> : } -<span class="lineNum"> 1190 </span> : while (__first2 != __last); -<span class="lineNum"> 1191 </span> : -<span class="lineNum"> 1192 </span> : __first2 = __middle; -<span class="lineNum"> 1193 </span> : -<span class="lineNum"> 1194 </span> : while (__first2 != __last) -<span class="lineNum"> 1195 </span> : { -<span class="lineNum"> 1196 </span> : std::iter_swap(__first, __first2); -<span class="lineNum"> 1197 </span> : ++__first; -<span class="lineNum"> 1198 </span> : ++__first2; -<span class="lineNum"> 1199 </span> : if (__first == __middle) -<span class="lineNum"> 1200 </span> : __middle = __first2; -<span class="lineNum"> 1201 </span> : else if (__first2 == __last) -<span class="lineNum"> 1202 </span> : __first2 = __middle; -<span class="lineNum"> 1203 </span> : } -<span class="lineNum"> 1204 </span> : } -<span class="lineNum"> 1205 </span> : -<span class="lineNum"> 1206 </span> : /// This is a helper function for the rotate algorithm. -<span class="lineNum"> 1207 </span> : template<typename _BidirectionalIterator> -<span class="lineNum"> 1208 </span> : void -<span class="lineNum"> 1209 </span> : __rotate(_BidirectionalIterator __first, -<span class="lineNum"> 1210 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 1211 </span> : _BidirectionalIterator __last, -<span class="lineNum"> 1212 </span> : bidirectional_iterator_tag) -<span class="lineNum"> 1213 </span> : { -<span class="lineNum"> 1214 </span> : // concept requirements -<span class="lineNum"> 1215 </span> : __glibcxx_function_requires(_Mutable_BidirectionalIteratorConcept< -<span class="lineNum"> 1216 </span> : _BidirectionalIterator>) -<span class="lineNum"> 1217 </span> : -<span class="lineNum"> 1218 </span> : if (__first == __middle || __last == __middle) -<span class="lineNum"> 1219 </span> : return; -<span class="lineNum"> 1220 </span> : -<span class="lineNum"> 1221 </span> : std::__reverse(__first, __middle, bidirectional_iterator_tag()); -<span class="lineNum"> 1222 </span> : std::__reverse(__middle, __last, bidirectional_iterator_tag()); -<span class="lineNum"> 1223 </span> : -<span class="lineNum"> 1224 </span> : while (__first != __middle && __middle != __last) -<span class="lineNum"> 1225 </span> : { -<span class="lineNum"> 1226 </span> : std::iter_swap(__first, --__last); -<span class="lineNum"> 1227 </span> : ++__first; -<span class="lineNum"> 1228 </span> : } -<span class="lineNum"> 1229 </span> : -<span class="lineNum"> 1230 </span> : if (__first == __middle) -<span class="lineNum"> 1231 </span> : std::__reverse(__middle, __last, bidirectional_iterator_tag()); -<span class="lineNum"> 1232 </span> : else -<span class="lineNum"> 1233 </span> : std::__reverse(__first, __middle, bidirectional_iterator_tag()); -<span class="lineNum"> 1234 </span> : } -<span class="lineNum"> 1235 </span> : -<span class="lineNum"> 1236 </span> : /// This is a helper function for the rotate algorithm. -<span class="lineNum"> 1237 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 1238 </span> : void -<span class="lineNum"> 1239 </span> : __rotate(_RandomAccessIterator __first, -<span class="lineNum"> 1240 </span> : _RandomAccessIterator __middle, -<span class="lineNum"> 1241 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 1242 </span> : random_access_iterator_tag) -<span class="lineNum"> 1243 </span> : { -<span class="lineNum"> 1244 </span> : // concept requirements -<span class="lineNum"> 1245 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 1246 </span> : _RandomAccessIterator>) -<span class="lineNum"> 1247 </span> : -<span class="lineNum"> 1248 </span> : if (__first == __middle || __last == __middle) -<span class="lineNum"> 1249 </span> : return; -<span class="lineNum"> 1250 </span> : -<span class="lineNum"> 1251 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 1252 </span> : _Distance; -<span class="lineNum"> 1253 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1254 </span> : _ValueType; -<span class="lineNum"> 1255 </span> : -<span class="lineNum"> 1256 </span> : const _Distance __n = __last - __first; -<span class="lineNum"> 1257 </span> : const _Distance __k = __middle - __first; -<span class="lineNum"> 1258 </span> : const _Distance __l = __n - __k; -<span class="lineNum"> 1259 </span> : -<span class="lineNum"> 1260 </span> : if (__k == __l) -<span class="lineNum"> 1261 </span> : { -<span class="lineNum"> 1262 </span> : std::swap_ranges(__first, __middle, __middle); -<span class="lineNum"> 1263 </span> : return; -<span class="lineNum"> 1264 </span> : } -<span class="lineNum"> 1265 </span> : -<span class="lineNum"> 1266 </span> : const _Distance __d = std::__gcd(__n, __k); -<span class="lineNum"> 1267 </span> : -<span class="lineNum"> 1268 </span> : for (_Distance __i = 0; __i < __d; __i++) -<span class="lineNum"> 1269 </span> : { -<span class="lineNum"> 1270 </span> : _ValueType __tmp = _GLIBCXX_MOVE(*__first); -<span class="lineNum"> 1271 </span> : _RandomAccessIterator __p = __first; -<span class="lineNum"> 1272 </span> : -<span class="lineNum"> 1273 </span> : if (__k < __l) -<span class="lineNum"> 1274 </span> : { -<span class="lineNum"> 1275 </span> : for (_Distance __j = 0; __j < __l / __d; __j++) -<span class="lineNum"> 1276 </span> : { -<span class="lineNum"> 1277 </span> : if (__p > __first + __l) -<span class="lineNum"> 1278 </span> : { -<span class="lineNum"> 1279 </span> : *__p = _GLIBCXX_MOVE(*(__p - __l)); -<span class="lineNum"> 1280 </span> : __p -= __l; -<span class="lineNum"> 1281 </span> : } -<span class="lineNum"> 1282 </span> : -<span class="lineNum"> 1283 </span> : *__p = _GLIBCXX_MOVE(*(__p + __k)); -<span class="lineNum"> 1284 </span> : __p += __k; -<span class="lineNum"> 1285 </span> : } -<span class="lineNum"> 1286 </span> : } -<span class="lineNum"> 1287 </span> : else -<span class="lineNum"> 1288 </span> : { -<span class="lineNum"> 1289 </span> : for (_Distance __j = 0; __j < __k / __d - 1; __j ++) -<span class="lineNum"> 1290 </span> : { -<span class="lineNum"> 1291 </span> : if (__p < __last - __k) -<span class="lineNum"> 1292 </span> : { -<span class="lineNum"> 1293 </span> : *__p = _GLIBCXX_MOVE(*(__p + __k)); -<span class="lineNum"> 1294 </span> : __p += __k; -<span class="lineNum"> 1295 </span> : } -<span class="lineNum"> 1296 </span> : *__p = _GLIBCXX_MOVE(*(__p - __l)); -<span class="lineNum"> 1297 </span> : __p -= __l; -<span class="lineNum"> 1298 </span> : } -<span class="lineNum"> 1299 </span> : } -<span class="lineNum"> 1300 </span> : -<span class="lineNum"> 1301 </span> : *__p = _GLIBCXX_MOVE(__tmp); -<span class="lineNum"> 1302 </span> : ++__first; -<span class="lineNum"> 1303 </span> : } -<span class="lineNum"> 1304 </span> : } -<span class="lineNum"> 1305 </span> : -<span class="lineNum"> 1306 </span> : /** -<span class="lineNum"> 1307 </span> : * @brief Rotate the elements of a sequence. -<span class="lineNum"> 1308 </span> : * @param first A forward iterator. -<span class="lineNum"> 1309 </span> : * @param middle A forward iterator. -<span class="lineNum"> 1310 </span> : * @param last A forward iterator. -<span class="lineNum"> 1311 </span> : * @return Nothing. -<span class="lineNum"> 1312 </span> : * -<span class="lineNum"> 1313 </span> : * Rotates the elements of the range @p [first,last) by @p (middle-first) -<span class="lineNum"> 1314 </span> : * positions so that the element at @p middle is moved to @p first, the -<span class="lineNum"> 1315 </span> : * element at @p middle+1 is moved to @first+1 and so on for each element -<span class="lineNum"> 1316 </span> : * in the range @p [first,last). -<span class="lineNum"> 1317 </span> : * -<span class="lineNum"> 1318 </span> : * This effectively swaps the ranges @p [first,middle) and -<span class="lineNum"> 1319 </span> : * @p [middle,last). -<span class="lineNum"> 1320 </span> : * -<span class="lineNum"> 1321 </span> : * Performs @p *(first+(n+(last-middle))%(last-first))=*(first+n) for -<span class="lineNum"> 1322 </span> : * each @p n in the range @p [0,last-first). -<span class="lineNum"> 1323 </span> : */ -<span class="lineNum"> 1324 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1325 </span> : inline void -<span class="lineNum"> 1326 </span> : rotate(_ForwardIterator __first, _ForwardIterator __middle, -<span class="lineNum"> 1327 </span> : _ForwardIterator __last) -<span class="lineNum"> 1328 </span> : { -<span class="lineNum"> 1329 </span> : // concept requirements -<span class="lineNum"> 1330 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 1331 </span> : _ForwardIterator>) -<span class="lineNum"> 1332 </span> : __glibcxx_requires_valid_range(__first, __middle); -<span class="lineNum"> 1333 </span> : __glibcxx_requires_valid_range(__middle, __last); -<span class="lineNum"> 1334 </span> : -<span class="lineNum"> 1335 </span> : typedef typename iterator_traits<_ForwardIterator>::iterator_category -<span class="lineNum"> 1336 </span> : _IterType; -<span class="lineNum"> 1337 </span> : std::__rotate(__first, __middle, __last, _IterType()); -<span class="lineNum"> 1338 </span> : } -<span class="lineNum"> 1339 </span> : -<span class="lineNum"> 1340 </span> : /** -<span class="lineNum"> 1341 </span> : * @brief Copy a sequence, rotating its elements. -<span class="lineNum"> 1342 </span> : * @param first A forward iterator. -<span class="lineNum"> 1343 </span> : * @param middle A forward iterator. -<span class="lineNum"> 1344 </span> : * @param last A forward iterator. -<span class="lineNum"> 1345 </span> : * @param result An output iterator. -<span class="lineNum"> 1346 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 1347 </span> : * -<span class="lineNum"> 1348 </span> : * Copies the elements of the range @p [first,last) to the range -<span class="lineNum"> 1349 </span> : * beginning at @result, rotating the copied elements by @p (middle-first) -<span class="lineNum"> 1350 </span> : * positions so that the element at @p middle is moved to @p result, the -<span class="lineNum"> 1351 </span> : * element at @p middle+1 is moved to @result+1 and so on for each element -<span class="lineNum"> 1352 </span> : * in the range @p [first,last). -<span class="lineNum"> 1353 </span> : * -<span class="lineNum"> 1354 </span> : * Performs @p *(result+(n+(last-middle))%(last-first))=*(first+n) for -<span class="lineNum"> 1355 </span> : * each @p n in the range @p [0,last-first). -<span class="lineNum"> 1356 </span> : */ -<span class="lineNum"> 1357 </span> : template<typename _ForwardIterator, typename _OutputIterator> -<span class="lineNum"> 1358 </span> : _OutputIterator -<span class="lineNum"> 1359 </span> : rotate_copy(_ForwardIterator __first, _ForwardIterator __middle, -<span class="lineNum"> 1360 </span> : _ForwardIterator __last, _OutputIterator __result) -<span class="lineNum"> 1361 </span> : { -<span class="lineNum"> 1362 </span> : // concept requirements -<span class="lineNum"> 1363 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 1364 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 1365 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 1366 </span> : __glibcxx_requires_valid_range(__first, __middle); -<span class="lineNum"> 1367 </span> : __glibcxx_requires_valid_range(__middle, __last); -<span class="lineNum"> 1368 </span> : -<span class="lineNum"> 1369 </span> : return std::copy(__first, __middle, -<span class="lineNum"> 1370 </span> : std::copy(__middle, __last, __result)); -<span class="lineNum"> 1371 </span> : } -<span class="lineNum"> 1372 </span> : -<span class="lineNum"> 1373 </span> : /// This is a helper function... -<span class="lineNum"> 1374 </span> : template<typename _ForwardIterator, typename _Predicate> -<span class="lineNum"> 1375 </span> : _ForwardIterator -<span class="lineNum"> 1376 </span> : __partition(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 1377 </span> : _Predicate __pred, forward_iterator_tag) -<span class="lineNum"> 1378 </span> : { -<span class="lineNum"> 1379 </span> : if (__first == __last) -<span class="lineNum"> 1380 </span> : return __first; -<span class="lineNum"> 1381 </span> : -<span class="lineNum"> 1382 </span> : while (__pred(*__first)) -<span class="lineNum"> 1383 </span> : if (++__first == __last) -<span class="lineNum"> 1384 </span> : return __first; -<span class="lineNum"> 1385 </span> : -<span class="lineNum"> 1386 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 1387 </span> : -<span class="lineNum"> 1388 </span> : while (++__next != __last) -<span class="lineNum"> 1389 </span> : if (__pred(*__next)) -<span class="lineNum"> 1390 </span> : { -<span class="lineNum"> 1391 </span> : std::iter_swap(__first, __next); -<span class="lineNum"> 1392 </span> : ++__first; -<span class="lineNum"> 1393 </span> : } -<span class="lineNum"> 1394 </span> : -<span class="lineNum"> 1395 </span> : return __first; -<span class="lineNum"> 1396 </span> : } -<span class="lineNum"> 1397 </span> : -<span class="lineNum"> 1398 </span> : /// This is a helper function... -<span class="lineNum"> 1399 </span> : template<typename _BidirectionalIterator, typename _Predicate> -<span class="lineNum"> 1400 </span> : _BidirectionalIterator -<span class="lineNum"> 1401 </span> : __partition(_BidirectionalIterator __first, _BidirectionalIterator __last, -<span class="lineNum"> 1402 </span> : _Predicate __pred, bidirectional_iterator_tag) -<span class="lineNum"> 1403 </span> : { -<span class="lineNum"> 1404 </span> : while (true) -<span class="lineNum"> 1405 </span> : { -<span class="lineNum"> 1406 </span> : while (true) -<span class="lineNum"> 1407 </span> : if (__first == __last) -<span class="lineNum"> 1408 </span> : return __first; -<span class="lineNum"> 1409 </span> : else if (__pred(*__first)) -<span class="lineNum"> 1410 </span> : ++__first; -<span class="lineNum"> 1411 </span> : else -<span class="lineNum"> 1412 </span> : break; -<span class="lineNum"> 1413 </span> : --__last; -<span class="lineNum"> 1414 </span> : while (true) -<span class="lineNum"> 1415 </span> : if (__first == __last) -<span class="lineNum"> 1416 </span> : return __first; -<span class="lineNum"> 1417 </span> : else if (!bool(__pred(*__last))) -<span class="lineNum"> 1418 </span> : --__last; -<span class="lineNum"> 1419 </span> : else -<span class="lineNum"> 1420 </span> : break; -<span class="lineNum"> 1421 </span> : std::iter_swap(__first, __last); -<span class="lineNum"> 1422 </span> : ++__first; -<span class="lineNum"> 1423 </span> : } -<span class="lineNum"> 1424 </span> : } -<span class="lineNum"> 1425 </span> : -<span class="lineNum"> 1426 </span> : // partition -<span class="lineNum"> 1427 </span> : -<span class="lineNum"> 1428 </span> : /// This is a helper function... -<span class="lineNum"> 1429 </span> : template<typename _ForwardIterator, typename _Predicate, typename _Distance> -<span class="lineNum"> 1430 </span> : _ForwardIterator -<span class="lineNum"> 1431 </span> : __inplace_stable_partition(_ForwardIterator __first, -<span class="lineNum"> 1432 </span> : _ForwardIterator __last, -<span class="lineNum"> 1433 </span> : _Predicate __pred, _Distance __len) -<span class="lineNum"> 1434 </span> : { -<span class="lineNum"> 1435 </span> : if (__len == 1) -<span class="lineNum"> 1436 </span> : return __pred(*__first) ? __last : __first; -<span class="lineNum"> 1437 </span> : _ForwardIterator __middle = __first; -<span class="lineNum"> 1438 </span> : std::advance(__middle, __len / 2); -<span class="lineNum"> 1439 </span> : _ForwardIterator __begin = std::__inplace_stable_partition(__first, -<span class="lineNum"> 1440 </span> : __middle, -<span class="lineNum"> 1441 </span> : __pred, -<span class="lineNum"> 1442 </span> : __len / 2); -<span class="lineNum"> 1443 </span> : _ForwardIterator __end = std::__inplace_stable_partition(__middle, __last, -<span class="lineNum"> 1444 </span> : __pred, -<span class="lineNum"> 1445 </span> : __len -<span class="lineNum"> 1446 </span> : - __len / 2); -<span class="lineNum"> 1447 </span> : std::rotate(__begin, __middle, __end); -<span class="lineNum"> 1448 </span> : std::advance(__begin, std::distance(__middle, __end)); -<span class="lineNum"> 1449 </span> : return __begin; -<span class="lineNum"> 1450 </span> : } -<span class="lineNum"> 1451 </span> : -<span class="lineNum"> 1452 </span> : /// This is a helper function... -<span class="lineNum"> 1453 </span> : template<typename _ForwardIterator, typename _Pointer, typename _Predicate, -<span class="lineNum"> 1454 </span> : typename _Distance> -<span class="lineNum"> 1455 </span> : _ForwardIterator -<span class="lineNum"> 1456 </span> : __stable_partition_adaptive(_ForwardIterator __first, -<span class="lineNum"> 1457 </span> : _ForwardIterator __last, -<span class="lineNum"> 1458 </span> : _Predicate __pred, _Distance __len, -<span class="lineNum"> 1459 </span> : _Pointer __buffer, -<span class="lineNum"> 1460 </span> : _Distance __buffer_size) -<span class="lineNum"> 1461 </span> : { -<span class="lineNum"> 1462 </span> : if (__len <= __buffer_size) -<span class="lineNum"> 1463 </span> : { -<span class="lineNum"> 1464 </span> : _ForwardIterator __result1 = __first; -<span class="lineNum"> 1465 </span> : _Pointer __result2 = __buffer; -<span class="lineNum"> 1466 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 1467 </span> : if (__pred(*__first)) -<span class="lineNum"> 1468 </span> : { -<span class="lineNum"> 1469 </span> : *__result1 = *__first; -<span class="lineNum"> 1470 </span> : ++__result1; -<span class="lineNum"> 1471 </span> : } -<span class="lineNum"> 1472 </span> : else -<span class="lineNum"> 1473 </span> : { -<span class="lineNum"> 1474 </span> : *__result2 = *__first; -<span class="lineNum"> 1475 </span> : ++__result2; -<span class="lineNum"> 1476 </span> : } -<span class="lineNum"> 1477 </span> : std::copy(__buffer, __result2, __result1); -<span class="lineNum"> 1478 </span> : return __result1; -<span class="lineNum"> 1479 </span> : } -<span class="lineNum"> 1480 </span> : else -<span class="lineNum"> 1481 </span> : { -<span class="lineNum"> 1482 </span> : _ForwardIterator __middle = __first; -<span class="lineNum"> 1483 </span> : std::advance(__middle, __len / 2); -<span class="lineNum"> 1484 </span> : _ForwardIterator __begin = -<span class="lineNum"> 1485 </span> : std::__stable_partition_adaptive(__first, __middle, __pred, -<span class="lineNum"> 1486 </span> : __len / 2, __buffer, -<span class="lineNum"> 1487 </span> : __buffer_size); -<span class="lineNum"> 1488 </span> : _ForwardIterator __end = -<span class="lineNum"> 1489 </span> : std::__stable_partition_adaptive(__middle, __last, __pred, -<span class="lineNum"> 1490 </span> : __len - __len / 2, -<span class="lineNum"> 1491 </span> : __buffer, __buffer_size); -<span class="lineNum"> 1492 </span> : std::rotate(__begin, __middle, __end); -<span class="lineNum"> 1493 </span> : std::advance(__begin, std::distance(__middle, __end)); -<span class="lineNum"> 1494 </span> : return __begin; -<span class="lineNum"> 1495 </span> : } -<span class="lineNum"> 1496 </span> : } -<span class="lineNum"> 1497 </span> : -<span class="lineNum"> 1498 </span> : /** -<span class="lineNum"> 1499 </span> : * @brief Move elements for which a predicate is true to the beginning -<span class="lineNum"> 1500 </span> : * of a sequence, preserving relative ordering. -<span class="lineNum"> 1501 </span> : * @param first A forward iterator. -<span class="lineNum"> 1502 </span> : * @param last A forward iterator. -<span class="lineNum"> 1503 </span> : * @param pred A predicate functor. -<span class="lineNum"> 1504 </span> : * @return An iterator @p middle such that @p pred(i) is true for each -<span class="lineNum"> 1505 </span> : * iterator @p i in the range @p [first,middle) and false for each @p i -<span class="lineNum"> 1506 </span> : * in the range @p [middle,last). -<span class="lineNum"> 1507 </span> : * -<span class="lineNum"> 1508 </span> : * Performs the same function as @p partition() with the additional -<span class="lineNum"> 1509 </span> : * guarantee that the relative ordering of elements in each group is -<span class="lineNum"> 1510 </span> : * preserved, so any two elements @p x and @p y in the range -<span class="lineNum"> 1511 </span> : * @p [first,last) such that @p pred(x)==pred(y) will have the same -<span class="lineNum"> 1512 </span> : * relative ordering after calling @p stable_partition(). -<span class="lineNum"> 1513 </span> : */ -<span class="lineNum"> 1514 </span> : template<typename _ForwardIterator, typename _Predicate> -<span class="lineNum"> 1515 </span> : _ForwardIterator -<span class="lineNum"> 1516 </span> : stable_partition(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 1517 </span> : _Predicate __pred) -<span class="lineNum"> 1518 </span> : { -<span class="lineNum"> 1519 </span> : // concept requirements -<span class="lineNum"> 1520 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 1521 </span> : _ForwardIterator>) -<span class="lineNum"> 1522 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 1523 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 1524 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 1525 </span> : -<span class="lineNum"> 1526 </span> : if (__first == __last) -<span class="lineNum"> 1527 </span> : return __first; -<span class="lineNum"> 1528 </span> : else -<span class="lineNum"> 1529 </span> : { -<span class="lineNum"> 1530 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 1531 </span> : _ValueType; -<span class="lineNum"> 1532 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 1533 </span> : _DistanceType; -<span class="lineNum"> 1534 </span> : -<span class="lineNum"> 1535 </span> : _Temporary_buffer<_ForwardIterator, _ValueType> __buf(__first, -<span class="lineNum"> 1536 </span> : __last); -<span class="lineNum"> 1537 </span> : if (__buf.size() > 0) -<span class="lineNum"> 1538 </span> : return -<span class="lineNum"> 1539 </span> : std::__stable_partition_adaptive(__first, __last, __pred, -<span class="lineNum"> 1540 </span> : _DistanceType(__buf.requested_size()), -<span class="lineNum"> 1541 </span> : __buf.begin(), -<span class="lineNum"> 1542 </span> : _DistanceType(__buf.size())); -<span class="lineNum"> 1543 </span> : else -<span class="lineNum"> 1544 </span> : return -<span class="lineNum"> 1545 </span> : std::__inplace_stable_partition(__first, __last, __pred, -<span class="lineNum"> 1546 </span> : _DistanceType(__buf.requested_size())); -<span class="lineNum"> 1547 </span> : } -<span class="lineNum"> 1548 </span> : } -<span class="lineNum"> 1549 </span> : -<span class="lineNum"> 1550 </span> : /// This is a helper function for the sort routines. -<span class="lineNum"> 1551 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 1552 </span> : void -<span class="lineNum"> 1553 </span> : __heap_select(_RandomAccessIterator __first, -<span class="lineNum"> 1554 </span> : _RandomAccessIterator __middle, -<span class="lineNum"> 1555 </span><span class="lineNoCov"> 0 : _RandomAccessIterator __last)</span> -<span class="lineNum"> 1556 </span> : { -<span class="lineNum"> 1557 </span><span class="lineNoCov"> 0 : std::make_heap(__first, __middle);</span> -<span class="lineNum"> 1558 </span><span class="lineNoCov"> 0 : for (_RandomAccessIterator __i = __middle; __i < __last; ++__i)</span> -<span class="lineNum"> 1559 </span><span class="lineNoCov"> 0 : if (*__i < *__first)</span> -<span class="lineNum"> 1560 </span><span class="lineNoCov"> 0 : std::__pop_heap(__first, __middle, __i);</span> -<span class="lineNum"> 1561 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1562 </span> : -<span class="lineNum"> 1563 </span> : /// This is a helper function for the sort routines. -<span class="lineNum"> 1564 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 1565 </span> : void -<span class="lineNum"> 1566 </span> : __heap_select(_RandomAccessIterator __first, -<span class="lineNum"> 1567 </span> : _RandomAccessIterator __middle, -<span class="lineNum"> 1568 </span><span class="lineNoCov"> 0 : _RandomAccessIterator __last, _Compare __comp)</span> -<span class="lineNum"> 1569 </span> : { -<span class="lineNum"> 1570 </span><span class="lineNoCov"> 0 : std::make_heap(__first, __middle, __comp);</span> -<span class="lineNum"> 1571 </span><span class="lineNoCov"> 0 : for (_RandomAccessIterator __i = __middle; __i < __last; ++__i)</span> -<span class="lineNum"> 1572 </span><span class="lineNoCov"> 0 : if (__comp(*__i, *__first))</span> -<span class="lineNum"> 1573 </span><span class="lineNoCov"> 0 : std::__pop_heap(__first, __middle, __i, __comp);</span> -<span class="lineNum"> 1574 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1575 </span> : -<span class="lineNum"> 1576 </span> : // partial_sort -<span class="lineNum"> 1577 </span> : -<span class="lineNum"> 1578 </span> : /** -<span class="lineNum"> 1579 </span> : * @brief Copy the smallest elements of a sequence. -<span class="lineNum"> 1580 </span> : * @param first An iterator. -<span class="lineNum"> 1581 </span> : * @param last Another iterator. -<span class="lineNum"> 1582 </span> : * @param result_first A random-access iterator. -<span class="lineNum"> 1583 </span> : * @param result_last Another random-access iterator. -<span class="lineNum"> 1584 </span> : * @return An iterator indicating the end of the resulting sequence. -<span class="lineNum"> 1585 </span> : * -<span class="lineNum"> 1586 </span> : * Copies and sorts the smallest N values from the range @p [first,last) -<span class="lineNum"> 1587 </span> : * to the range beginning at @p result_first, where the number of -<span class="lineNum"> 1588 </span> : * elements to be copied, @p N, is the smaller of @p (last-first) and -<span class="lineNum"> 1589 </span> : * @p (result_last-result_first). -<span class="lineNum"> 1590 </span> : * After the sort if @p i and @j are iterators in the range -<span class="lineNum"> 1591 </span> : * @p [result_first,result_first+N) such that @i precedes @j then -<span class="lineNum"> 1592 </span> : * @p *j<*i is false. -<span class="lineNum"> 1593 </span> : * The value returned is @p result_first+N. -<span class="lineNum"> 1594 </span> : */ -<span class="lineNum"> 1595 </span> : template<typename _InputIterator, typename _RandomAccessIterator> -<span class="lineNum"> 1596 </span> : _RandomAccessIterator -<span class="lineNum"> 1597 </span> : partial_sort_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1598 </span> : _RandomAccessIterator __result_first, -<span class="lineNum"> 1599 </span> : _RandomAccessIterator __result_last) -<span class="lineNum"> 1600 </span> : { -<span class="lineNum"> 1601 </span> : typedef typename iterator_traits<_InputIterator>::value_type -<span class="lineNum"> 1602 </span> : _InputValueType; -<span class="lineNum"> 1603 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1604 </span> : _OutputValueType; -<span class="lineNum"> 1605 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 1606 </span> : _DistanceType; -<span class="lineNum"> 1607 </span> : -<span class="lineNum"> 1608 </span> : // concept requirements -<span class="lineNum"> 1609 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 1610 </span> : __glibcxx_function_requires(_ConvertibleConcept<_InputValueType, -<span class="lineNum"> 1611 </span> : _OutputValueType>) -<span class="lineNum"> 1612 </span> : __glibcxx_function_requires(_LessThanOpConcept<_InputValueType, -<span class="lineNum"> 1613 </span> : _OutputValueType>) -<span class="lineNum"> 1614 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_OutputValueType>) -<span class="lineNum"> 1615 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 1616 </span> : __glibcxx_requires_valid_range(__result_first, __result_last); -<span class="lineNum"> 1617 </span> : -<span class="lineNum"> 1618 </span> : if (__result_first == __result_last) -<span class="lineNum"> 1619 </span> : return __result_last; -<span class="lineNum"> 1620 </span> : _RandomAccessIterator __result_real_last = __result_first; -<span class="lineNum"> 1621 </span> : while(__first != __last && __result_real_last != __result_last) -<span class="lineNum"> 1622 </span> : { -<span class="lineNum"> 1623 </span> : *__result_real_last = *__first; -<span class="lineNum"> 1624 </span> : ++__result_real_last; -<span class="lineNum"> 1625 </span> : ++__first; -<span class="lineNum"> 1626 </span> : } -<span class="lineNum"> 1627 </span> : std::make_heap(__result_first, __result_real_last); -<span class="lineNum"> 1628 </span> : while (__first != __last) -<span class="lineNum"> 1629 </span> : { -<span class="lineNum"> 1630 </span> : if (*__first < *__result_first) -<span class="lineNum"> 1631 </span> : std::__adjust_heap(__result_first, _DistanceType(0), -<span class="lineNum"> 1632 </span> : _DistanceType(__result_real_last -<span class="lineNum"> 1633 </span> : - __result_first), -<span class="lineNum"> 1634 </span> : _InputValueType(*__first)); -<span class="lineNum"> 1635 </span> : ++__first; -<span class="lineNum"> 1636 </span> : } -<span class="lineNum"> 1637 </span> : std::sort_heap(__result_first, __result_real_last); -<span class="lineNum"> 1638 </span> : return __result_real_last; -<span class="lineNum"> 1639 </span> : } -<span class="lineNum"> 1640 </span> : -<span class="lineNum"> 1641 </span> : /** -<span class="lineNum"> 1642 </span> : * @brief Copy the smallest elements of a sequence using a predicate for -<span class="lineNum"> 1643 </span> : * comparison. -<span class="lineNum"> 1644 </span> : * @param first An input iterator. -<span class="lineNum"> 1645 </span> : * @param last Another input iterator. -<span class="lineNum"> 1646 </span> : * @param result_first A random-access iterator. -<span class="lineNum"> 1647 </span> : * @param result_last Another random-access iterator. -<span class="lineNum"> 1648 </span> : * @param comp A comparison functor. -<span class="lineNum"> 1649 </span> : * @return An iterator indicating the end of the resulting sequence. -<span class="lineNum"> 1650 </span> : * -<span class="lineNum"> 1651 </span> : * Copies and sorts the smallest N values from the range @p [first,last) -<span class="lineNum"> 1652 </span> : * to the range beginning at @p result_first, where the number of -<span class="lineNum"> 1653 </span> : * elements to be copied, @p N, is the smaller of @p (last-first) and -<span class="lineNum"> 1654 </span> : * @p (result_last-result_first). -<span class="lineNum"> 1655 </span> : * After the sort if @p i and @j are iterators in the range -<span class="lineNum"> 1656 </span> : * @p [result_first,result_first+N) such that @i precedes @j then -<span class="lineNum"> 1657 </span> : * @p comp(*j,*i) is false. -<span class="lineNum"> 1658 </span> : * The value returned is @p result_first+N. -<span class="lineNum"> 1659 </span> : */ -<span class="lineNum"> 1660 </span> : template<typename _InputIterator, typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 1661 </span> : _RandomAccessIterator -<span class="lineNum"> 1662 </span> : partial_sort_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1663 </span> : _RandomAccessIterator __result_first, -<span class="lineNum"> 1664 </span> : _RandomAccessIterator __result_last, -<span class="lineNum"> 1665 </span> : _Compare __comp) -<span class="lineNum"> 1666 </span> : { -<span class="lineNum"> 1667 </span> : typedef typename iterator_traits<_InputIterator>::value_type -<span class="lineNum"> 1668 </span> : _InputValueType; -<span class="lineNum"> 1669 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1670 </span> : _OutputValueType; -<span class="lineNum"> 1671 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 1672 </span> : _DistanceType; -<span class="lineNum"> 1673 </span> : -<span class="lineNum"> 1674 </span> : // concept requirements -<span class="lineNum"> 1675 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 1676 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 1677 </span> : _RandomAccessIterator>) -<span class="lineNum"> 1678 </span> : __glibcxx_function_requires(_ConvertibleConcept<_InputValueType, -<span class="lineNum"> 1679 </span> : _OutputValueType>) -<span class="lineNum"> 1680 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 1681 </span> : _InputValueType, _OutputValueType>) -<span class="lineNum"> 1682 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 1683 </span> : _OutputValueType, _OutputValueType>) -<span class="lineNum"> 1684 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 1685 </span> : __glibcxx_requires_valid_range(__result_first, __result_last); -<span class="lineNum"> 1686 </span> : -<span class="lineNum"> 1687 </span> : if (__result_first == __result_last) -<span class="lineNum"> 1688 </span> : return __result_last; -<span class="lineNum"> 1689 </span> : _RandomAccessIterator __result_real_last = __result_first; -<span class="lineNum"> 1690 </span> : while(__first != __last && __result_real_last != __result_last) -<span class="lineNum"> 1691 </span> : { -<span class="lineNum"> 1692 </span> : *__result_real_last = *__first; -<span class="lineNum"> 1693 </span> : ++__result_real_last; -<span class="lineNum"> 1694 </span> : ++__first; -<span class="lineNum"> 1695 </span> : } -<span class="lineNum"> 1696 </span> : std::make_heap(__result_first, __result_real_last, __comp); -<span class="lineNum"> 1697 </span> : while (__first != __last) -<span class="lineNum"> 1698 </span> : { -<span class="lineNum"> 1699 </span> : if (__comp(*__first, *__result_first)) -<span class="lineNum"> 1700 </span> : std::__adjust_heap(__result_first, _DistanceType(0), -<span class="lineNum"> 1701 </span> : _DistanceType(__result_real_last -<span class="lineNum"> 1702 </span> : - __result_first), -<span class="lineNum"> 1703 </span> : _InputValueType(*__first), -<span class="lineNum"> 1704 </span> : __comp); -<span class="lineNum"> 1705 </span> : ++__first; -<span class="lineNum"> 1706 </span> : } -<span class="lineNum"> 1707 </span> : std::sort_heap(__result_first, __result_real_last, __comp); -<span class="lineNum"> 1708 </span> : return __result_real_last; -<span class="lineNum"> 1709 </span> : } -<span class="lineNum"> 1710 </span> : -<span class="lineNum"> 1711 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1712 </span> : template<typename _RandomAccessIterator, typename _Tp> -<span class="lineNum"> 1713 </span> : void -<span class="lineNum"> 1714 </span><span class="lineCov"> 2369 : __unguarded_linear_insert(_RandomAccessIterator __last, _Tp __val)</span> -<span class="lineNum"> 1715 </span> : { -<span class="lineNum"> 1716 </span><span class="lineCov"> 2369 : _RandomAccessIterator __next = __last;</span> -<span class="lineNum"> 1717 </span><span class="lineCov"> 2369 : --__next;</span> -<span class="lineNum"> 1718 </span><span class="lineCov"> 5033 : while (__val < *__next)</span> -<span class="lineNum"> 1719 </span> : { -<span class="lineNum"> 1720 </span><span class="lineCov"> 295 : *__last = *__next;</span> -<span class="lineNum"> 1721 </span><span class="lineCov"> 295 : __last = __next;</span> -<span class="lineNum"> 1722 </span><span class="lineCov"> 295 : --__next;</span> -<span class="lineNum"> 1723 </span> : } -<span class="lineNum"> 1724 </span><span class="lineCov"> 2369 : *__last = __val;</span> -<span class="lineNum"> 1725 </span><span class="lineCov"> 2369 : }</span> -<span class="lineNum"> 1726 </span> : -<span class="lineNum"> 1727 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1728 </span> : template<typename _RandomAccessIterator, typename _Tp, typename _Compare> -<span class="lineNum"> 1729 </span> : void -<span class="lineNum"> 1730 </span> : __unguarded_linear_insert(_RandomAccessIterator __last, _Tp __val, -<span class="lineNum"> 1731 </span><span class="lineCov"> 48163 : _Compare __comp)</span> -<span class="lineNum"> 1732 </span> : { -<span class="lineNum"> 1733 </span><span class="lineCov"> 48163 : _RandomAccessIterator __next = __last;</span> -<span class="lineNum"> 1734 </span><span class="lineCov"> 48163 : --__next;</span> -<span class="lineNum"> 1735 </span><span class="lineCov"> 273339 : while (__comp(__val, *__next))</span> -<span class="lineNum"> 1736 </span> : { -<span class="lineNum"> 1737 </span><span class="lineCov"> 177013 : *__last = *__next;</span> -<span class="lineNum"> 1738 </span><span class="lineCov"> 177013 : __last = __next;</span> -<span class="lineNum"> 1739 </span><span class="lineCov"> 177013 : --__next;</span> -<span class="lineNum"> 1740 </span> : } -<span class="lineNum"> 1741 </span><span class="lineCov"> 48163 : *__last = __val;</span> -<span class="lineNum"> 1742 </span><span class="lineCov"> 48163 : }</span> -<span class="lineNum"> 1743 </span> : -<span class="lineNum"> 1744 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1745 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 1746 </span> : void -<span class="lineNum"> 1747 </span> : __insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 1748 </span><span class="lineCov"> 81 : _RandomAccessIterator __last)</span> -<span class="lineNum"> 1749 </span> : { -<span class="lineNum"> 1750 </span><span class="lineCov"> 81 : if (__first == __last)</span> -<span class="lineNum"> 1751 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 1752 </span> : -<span class="lineNum"> 1753 </span><span class="lineCov"> 503 : for (_RandomAccessIterator __i = __first + 1; __i != __last; ++__i)</span> -<span class="lineNum"> 1754 </span> : { -<span class="lineNum"> 1755 </span> : typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1756 </span><span class="lineCov"> 422 : __val = *__i;</span> -<span class="lineNum"> 1757 </span><span class="lineCov"> 422 : if (__val < *__first)</span> -<span class="lineNum"> 1758 </span> : { -<span class="lineNum"> 1759 </span><span class="lineCov"> 151 : std::copy_backward(__first, __i, __i + 1);</span> -<span class="lineNum"> 1760 </span><span class="lineCov"> 151 : *__first = __val;</span> -<span class="lineNum"> 1761 </span> : } -<span class="lineNum"> 1762 </span> : else -<span class="lineNum"> 1763 </span><span class="lineCov"> 271 : std::__unguarded_linear_insert(__i, __val);</span> -<span class="lineNum"> 1764 </span> : } -<span class="lineNum"> 1765 </span> : } -<span class="lineNum"> 1766 </span> : -<span class="lineNum"> 1767 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1768 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 1769 </span> : void -<span class="lineNum"> 1770 </span> : __insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 1771 </span><span class="lineCov"> 3938 : _RandomAccessIterator __last, _Compare __comp)</span> -<span class="lineNum"> 1772 </span> : { -<span class="lineNum"> 1773 </span><span class="lineCov"> 3938 : if (__first == __last) return;</span> -<span class="lineNum"> 1774 </span> : -<span class="lineNum"> 1775 </span><span class="lineCov"> 55255 : for (_RandomAccessIterator __i = __first + 1; __i != __last; ++__i)</span> -<span class="lineNum"> 1776 </span> : { -<span class="lineNum"> 1777 </span> : typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1778 </span><span class="lineCov"> 51317 : __val = *__i;</span> -<span class="lineNum"> 1779 </span><span class="lineCov"> 51317 : if (__comp(__val, *__first))</span> -<span class="lineNum"> 1780 </span> : { -<span class="lineNum"> 1781 </span><span class="lineCov"> 7625 : std::copy_backward(__first, __i, __i + 1);</span> -<span class="lineNum"> 1782 </span><span class="lineCov"> 7625 : *__first = __val;</span> -<span class="lineNum"> 1783 </span> : } -<span class="lineNum"> 1784 </span> : else -<span class="lineNum"> 1785 </span><span class="lineCov"> 43692 : std::__unguarded_linear_insert(__i, __val, __comp);</span> -<span class="lineNum"> 1786 </span> : } -<span class="lineNum"> 1787 </span> : } -<span class="lineNum"> 1788 </span> : -<span class="lineNum"> 1789 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1790 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 1791 </span> : inline void -<span class="lineNum"> 1792 </span> : __unguarded_insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 1793 </span><span class="lineCov"> 3 : _RandomAccessIterator __last)</span> -<span class="lineNum"> 1794 </span> : { -<span class="lineNum"> 1795 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1796 </span> : _ValueType; -<span class="lineNum"> 1797 </span> : -<span class="lineNum"> 1798 </span><span class="lineCov"> 2101 : for (_RandomAccessIterator __i = __first; __i != __last; ++__i)</span> -<span class="lineNum"> 1799 </span><span class="lineCov"> 2098 : std::__unguarded_linear_insert(__i, _ValueType(*__i));</span> -<span class="lineNum"> 1800 </span><span class="lineCov"> 3 : }</span> -<span class="lineNum"> 1801 </span> : -<span class="lineNum"> 1802 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1803 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 1804 </span> : inline void -<span class="lineNum"> 1805 </span> : __unguarded_insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 1806 </span><span class="lineCov"> 261 : _RandomAccessIterator __last, _Compare __comp)</span> -<span class="lineNum"> 1807 </span> : { -<span class="lineNum"> 1808 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1809 </span> : _ValueType; -<span class="lineNum"> 1810 </span> : -<span class="lineNum"> 1811 </span><span class="lineCov"> 4732 : for (_RandomAccessIterator __i = __first; __i != __last; ++__i)</span> -<span class="lineNum"> 1812 </span><span class="lineCov"> 4471 : std::__unguarded_linear_insert(__i, _ValueType(*__i), __comp);</span> -<span class="lineNum"> 1813 </span><span class="lineCov"> 261 : }</span> -<span class="lineNum"> 1814 </span> : -<span class="lineNum"> 1815 </span> : /** -<span class="lineNum"> 1816 </span> : * @doctodo -<span class="lineNum"> 1817 </span> : * This controls some aspect of the sort routines. -<span class="lineNum"> 1818 </span> : */ -<span class="lineNum"> 1819 </span> : enum { _S_threshold = 16 }; -<span class="lineNum"> 1820 </span> : -<span class="lineNum"> 1821 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1822 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 1823 </span> : void -<span class="lineNum"> 1824 </span> : __final_insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 1825 </span><span class="lineCov"> 81 : _RandomAccessIterator __last)</span> -<span class="lineNum"> 1826 </span> : { -<span class="lineNum"> 1827 </span><span class="lineCov"> 81 : if (__last - __first > int(_S_threshold))</span> -<span class="lineNum"> 1828 </span> : { -<span class="lineNum"> 1829 </span><span class="lineCov"> 3 : std::__insertion_sort(__first, __first + int(_S_threshold));</span> -<span class="lineNum"> 1830 </span><span class="lineCov"> 3 : std::__unguarded_insertion_sort(__first + int(_S_threshold), __last);</span> -<span class="lineNum"> 1831 </span> : } -<span class="lineNum"> 1832 </span> : else -<span class="lineNum"> 1833 </span><span class="lineCov"> 78 : std::__insertion_sort(__first, __last);</span> -<span class="lineNum"> 1834 </span><span class="lineCov"> 81 : }</span> -<span class="lineNum"> 1835 </span> : -<span class="lineNum"> 1836 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1837 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 1838 </span> : void -<span class="lineNum"> 1839 </span> : __final_insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 1840 </span><span class="lineCov"> 3938 : _RandomAccessIterator __last, _Compare __comp)</span> -<span class="lineNum"> 1841 </span> : { -<span class="lineNum"> 1842 </span><span class="lineCov"> 3938 : if (__last - __first > int(_S_threshold))</span> -<span class="lineNum"> 1843 </span> : { -<span class="lineNum"> 1844 </span><span class="lineCov"> 261 : std::__insertion_sort(__first, __first + int(_S_threshold), __comp);</span> -<span class="lineNum"> 1845 </span><span class="lineCov"> 261 : std::__unguarded_insertion_sort(__first + int(_S_threshold), __last,</span> -<span class="lineNum"> 1846 </span> : __comp); -<span class="lineNum"> 1847 </span> : } -<span class="lineNum"> 1848 </span> : else -<span class="lineNum"> 1849 </span><span class="lineCov"> 3677 : std::__insertion_sort(__first, __last, __comp);</span> -<span class="lineNum"> 1850 </span><span class="lineCov"> 3938 : }</span> -<span class="lineNum"> 1851 </span> : -<span class="lineNum"> 1852 </span> : /// This is a helper function... -<span class="lineNum"> 1853 </span> : template<typename _RandomAccessIterator, typename _Tp> -<span class="lineNum"> 1854 </span> : _RandomAccessIterator -<span class="lineNum"> 1855 </span> : __unguarded_partition(_RandomAccessIterator __first, -<span class="lineNum"> 1856 </span><span class="lineCov"> 183 : _RandomAccessIterator __last, _Tp __pivot)</span> -<span class="lineNum"> 1857 </span> : { -<span class="lineNum"> 1858 </span><span class="lineCov"> 50 : while (true)</span> -<span class="lineNum"> 1859 </span> : { -<span class="lineNum"> 1860 </span><span class="lineCov"> 6596 : while (*__first < __pivot)</span> -<span class="lineNum"> 1861 </span><span class="lineCov"> 6230 : ++__first;</span> -<span class="lineNum"> 1862 </span><span class="lineCov"> 183 : --__last;</span> -<span class="lineNum"> 1863 </span><span class="lineCov"> 6480 : while (__pivot < *__last)</span> -<span class="lineNum"> 1864 </span><span class="lineCov"> 6114 : --__last;</span> -<span class="lineNum"> 1865 </span><span class="lineCov"> 183 : if (!(__first < __last))</span> -<span class="lineNum"> 1866 </span><span class="lineCov"> 133 : return __first;</span> -<span class="lineNum"> 1867 </span><span class="lineCov"> 50 : std::iter_swap(__first, __last);</span> -<span class="lineNum"> 1868 </span><span class="lineCov"> 50 : ++__first;</span> -<span class="lineNum"> 1869 </span> : } -<span class="lineNum"> 1870 </span> : } -<span class="lineNum"> 1871 </span> : -<span class="lineNum"> 1872 </span> : /// This is a helper function... -<span class="lineNum"> 1873 </span> : template<typename _RandomAccessIterator, typename _Tp, typename _Compare> -<span class="lineNum"> 1874 </span> : _RandomAccessIterator -<span class="lineNum"> 1875 </span> : __unguarded_partition(_RandomAccessIterator __first, -<span class="lineNum"> 1876 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 1877 </span><span class="lineCov"> 7740 : _Tp __pivot, _Compare __comp)</span> -<span class="lineNum"> 1878 </span> : { -<span class="lineNum"> 1879 </span><span class="lineCov"> 7030 : while (true)</span> -<span class="lineNum"> 1880 </span> : { -<span class="lineNum"> 1881 </span><span class="lineCov"> 25088 : while (__comp(*__first, __pivot))</span> -<span class="lineNum"> 1882 </span><span class="lineCov"> 9608 : ++__first;</span> -<span class="lineNum"> 1883 </span><span class="lineCov"> 7740 : --__last;</span> -<span class="lineNum"> 1884 </span><span class="lineCov"> 23207 : while (__comp(__pivot, *__last))</span> -<span class="lineNum"> 1885 </span><span class="lineCov"> 7727 : --__last;</span> -<span class="lineNum"> 1886 </span><span class="lineCov"> 7740 : if (!(__first < __last))</span> -<span class="lineNum"> 1887 </span><span class="lineCov"> 710 : return __first;</span> -<span class="lineNum"> 1888 </span><span class="lineCov"> 7030 : std::iter_swap(__first, __last);</span> -<span class="lineNum"> 1889 </span><span class="lineCov"> 7030 : ++__first;</span> -<span class="lineNum"> 1890 </span> : } -<span class="lineNum"> 1891 </span> : } -<span class="lineNum"> 1892 </span> : -<span class="lineNum"> 1893 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1894 </span> : template<typename _RandomAccessIterator, typename _Size> -<span class="lineNum"> 1895 </span> : void -<span class="lineNum"> 1896 </span> : __introsort_loop(_RandomAccessIterator __first, -<span class="lineNum"> 1897 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 1898 </span><span class="lineCov"> 214 : _Size __depth_limit)</span> -<span class="lineNum"> 1899 </span> : { -<span class="lineNum"> 1900 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1901 </span> : _ValueType; -<span class="lineNum"> 1902 </span> : -<span class="lineNum"> 1903 </span><span class="lineCov"> 561 : while (__last - __first > int(_S_threshold))</span> -<span class="lineNum"> 1904 </span> : { -<span class="lineNum"> 1905 </span><span class="lineCov"> 133 : if (__depth_limit == 0)</span> -<span class="lineNum"> 1906 </span> : { -<span class="lineNum"> 1907 </span><span class="lineNoCov"> 0 : _GLIBCXX_STD_P::partial_sort(__first, __last, __last);</span> -<span class="lineNum"> 1908 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 1909 </span> : } -<span class="lineNum"> 1910 </span><span class="lineCov"> 133 : --__depth_limit;</span> -<span class="lineNum"> 1911 </span> : _RandomAccessIterator __cut = -<span class="lineNum"> 1912 </span> : std::__unguarded_partition(__first, __last, -<span class="lineNum"> 1913 </span> : _ValueType(std::__median(*__first, -<span class="lineNum"> 1914 </span> : *(__first -<span class="lineNum"> 1915 </span> : + (__last -<span class="lineNum"> 1916 </span> : - __first) -<span class="lineNum"> 1917 </span> : / 2), -<span class="lineNum"> 1918 </span> : *(__last -<span class="lineNum"> 1919 </span><span class="lineCov"> 133 : - 1))));</span> -<span class="lineNum"> 1920 </span><span class="lineCov"> 133 : std::__introsort_loop(__cut, __last, __depth_limit);</span> -<span class="lineNum"> 1921 </span><span class="lineCov"> 133 : __last = __cut;</span> -<span class="lineNum"> 1922 </span> : } -<span class="lineNum"> 1923 </span> : } -<span class="lineNum"> 1924 </span> : -<span class="lineNum"> 1925 </span> : /// This is a helper function for the sort routine. -<span class="lineNum"> 1926 </span> : template<typename _RandomAccessIterator, typename _Size, typename _Compare> -<span class="lineNum"> 1927 </span> : void -<span class="lineNum"> 1928 </span> : __introsort_loop(_RandomAccessIterator __first, -<span class="lineNum"> 1929 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 1930 </span><span class="lineCov"> 4648 : _Size __depth_limit, _Compare __comp)</span> -<span class="lineNum"> 1931 </span> : { -<span class="lineNum"> 1932 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1933 </span> : _ValueType; -<span class="lineNum"> 1934 </span> : -<span class="lineNum"> 1935 </span><span class="lineCov"> 10006 : while (__last - __first > int(_S_threshold))</span> -<span class="lineNum"> 1936 </span> : { -<span class="lineNum"> 1937 </span><span class="lineCov"> 710 : if (__depth_limit == 0)</span> -<span class="lineNum"> 1938 </span> : { -<span class="lineNum"> 1939 </span><span class="lineNoCov"> 0 : _GLIBCXX_STD_P::partial_sort(__first, __last, __last, __comp);</span> -<span class="lineNum"> 1940 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 1941 </span> : } -<span class="lineNum"> 1942 </span><span class="lineCov"> 710 : --__depth_limit;</span> -<span class="lineNum"> 1943 </span> : _RandomAccessIterator __cut = -<span class="lineNum"> 1944 </span> : std::__unguarded_partition(__first, __last, -<span class="lineNum"> 1945 </span> : _ValueType(std::__median(*__first, -<span class="lineNum"> 1946 </span> : *(__first -<span class="lineNum"> 1947 </span> : + (__last -<span class="lineNum"> 1948 </span> : - __first) -<span class="lineNum"> 1949 </span> : / 2), -<span class="lineNum"> 1950 </span> : *(__last - 1), -<span class="lineNum"> 1951 </span> : __comp)), -<span class="lineNum"> 1952 </span><span class="lineCov"> 710 : __comp);</span> -<span class="lineNum"> 1953 </span><span class="lineCov"> 710 : std::__introsort_loop(__cut, __last, __depth_limit, __comp);</span> -<span class="lineNum"> 1954 </span><span class="lineCov"> 710 : __last = __cut;</span> -<span class="lineNum"> 1955 </span> : } -<span class="lineNum"> 1956 </span> : } -<span class="lineNum"> 1957 </span> : -<span class="lineNum"> 1958 </span> : /// This is a helper function for the sort routines. Precondition: __n > 0. -<span class="lineNum"> 1959 </span> : template<typename _Size> -<span class="lineNum"> 1960 </span> : inline _Size -<span class="lineNum"> 1961 </span> : __lg(_Size __n) -<span class="lineNum"> 1962 </span> : { -<span class="lineNum"> 1963 </span> : _Size __k; -<span class="lineNum"> 1964 </span> : for (__k = 0; __n != 0; __n >>= 1) -<span class="lineNum"> 1965 </span> : ++__k; -<span class="lineNum"> 1966 </span> : return __k - 1; -<span class="lineNum"> 1967 </span> : } -<span class="lineNum"> 1968 </span> : -<span class="lineNum"> 1969 </span> : inline int -<span class="lineNum"> 1970 </span><span class="lineCov"> 3946 : __lg(int __n)</span> -<span class="lineNum"> 1971 </span><span class="lineCov"> 3946 : { return sizeof(int) * __CHAR_BIT__ - 1 - __builtin_clz(__n); }</span> -<span class="lineNum"> 1972 </span> : -<span class="lineNum"> 1973 </span> : inline long -<span class="lineNum"> 1974 </span> : __lg(long __n) -<span class="lineNum"> 1975 </span> : { return sizeof(long) * __CHAR_BIT__ - 1 - __builtin_clzl(__n); } -<span class="lineNum"> 1976 </span> : -<span class="lineNum"> 1977 </span> : inline long long -<span class="lineNum"> 1978 </span> : __lg(long long __n) -<span class="lineNum"> 1979 </span> : { return sizeof(long long) * __CHAR_BIT__ - 1 - __builtin_clzll(__n); } -<span class="lineNum"> 1980 </span> : -<span class="lineNum"> 1981 </span> : // sort -<span class="lineNum"> 1982 </span> : -<span class="lineNum"> 1983 </span> : template<typename _RandomAccessIterator, typename _Size> -<span class="lineNum"> 1984 </span> : void -<span class="lineNum"> 1985 </span> : __introselect(_RandomAccessIterator __first, _RandomAccessIterator __nth, -<span class="lineNum"> 1986 </span> : _RandomAccessIterator __last, _Size __depth_limit) -<span class="lineNum"> 1987 </span> : { -<span class="lineNum"> 1988 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 1989 </span> : _ValueType; -<span class="lineNum"> 1990 </span> : -<span class="lineNum"> 1991 </span> : while (__last - __first > 3) -<span class="lineNum"> 1992 </span> : { -<span class="lineNum"> 1993 </span> : if (__depth_limit == 0) -<span class="lineNum"> 1994 </span> : { -<span class="lineNum"> 1995 </span> : std::__heap_select(__first, __nth + 1, __last); -<span class="lineNum"> 1996 </span> : -<span class="lineNum"> 1997 </span> : // Place the nth largest element in its final position. -<span class="lineNum"> 1998 </span> : std::iter_swap(__first, __nth); -<span class="lineNum"> 1999 </span> : return; -<span class="lineNum"> 2000 </span> : } -<span class="lineNum"> 2001 </span> : --__depth_limit; -<span class="lineNum"> 2002 </span> : _RandomAccessIterator __cut = -<span class="lineNum"> 2003 </span> : std::__unguarded_partition(__first, __last, -<span class="lineNum"> 2004 </span> : _ValueType(std::__median(*__first, -<span class="lineNum"> 2005 </span> : *(__first -<span class="lineNum"> 2006 </span> : + (__last -<span class="lineNum"> 2007 </span> : - __first) -<span class="lineNum"> 2008 </span> : / 2), -<span class="lineNum"> 2009 </span> : *(__last -<span class="lineNum"> 2010 </span> : - 1)))); -<span class="lineNum"> 2011 </span> : if (__cut <= __nth) -<span class="lineNum"> 2012 </span> : __first = __cut; -<span class="lineNum"> 2013 </span> : else -<span class="lineNum"> 2014 </span> : __last = __cut; -<span class="lineNum"> 2015 </span> : } -<span class="lineNum"> 2016 </span> : std::__insertion_sort(__first, __last); -<span class="lineNum"> 2017 </span> : } -<span class="lineNum"> 2018 </span> : -<span class="lineNum"> 2019 </span> : template<typename _RandomAccessIterator, typename _Size, typename _Compare> -<span class="lineNum"> 2020 </span> : void -<span class="lineNum"> 2021 </span> : __introselect(_RandomAccessIterator __first, _RandomAccessIterator __nth, -<span class="lineNum"> 2022 </span> : _RandomAccessIterator __last, _Size __depth_limit, -<span class="lineNum"> 2023 </span> : _Compare __comp) -<span class="lineNum"> 2024 </span> : { -<span class="lineNum"> 2025 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 2026 </span> : _ValueType; -<span class="lineNum"> 2027 </span> : -<span class="lineNum"> 2028 </span> : while (__last - __first > 3) -<span class="lineNum"> 2029 </span> : { -<span class="lineNum"> 2030 </span> : if (__depth_limit == 0) -<span class="lineNum"> 2031 </span> : { -<span class="lineNum"> 2032 </span> : std::__heap_select(__first, __nth + 1, __last, __comp); -<span class="lineNum"> 2033 </span> : // Place the nth largest element in its final position. -<span class="lineNum"> 2034 </span> : std::iter_swap(__first, __nth); -<span class="lineNum"> 2035 </span> : return; -<span class="lineNum"> 2036 </span> : } -<span class="lineNum"> 2037 </span> : --__depth_limit; -<span class="lineNum"> 2038 </span> : _RandomAccessIterator __cut = -<span class="lineNum"> 2039 </span> : std::__unguarded_partition(__first, __last, -<span class="lineNum"> 2040 </span> : _ValueType(std::__median(*__first, -<span class="lineNum"> 2041 </span> : *(__first -<span class="lineNum"> 2042 </span> : + (__last -<span class="lineNum"> 2043 </span> : - __first) -<span class="lineNum"> 2044 </span> : / 2), -<span class="lineNum"> 2045 </span> : *(__last - 1), -<span class="lineNum"> 2046 </span> : __comp)), -<span class="lineNum"> 2047 </span> : __comp); -<span class="lineNum"> 2048 </span> : if (__cut <= __nth) -<span class="lineNum"> 2049 </span> : __first = __cut; -<span class="lineNum"> 2050 </span> : else -<span class="lineNum"> 2051 </span> : __last = __cut; -<span class="lineNum"> 2052 </span> : } -<span class="lineNum"> 2053 </span> : std::__insertion_sort(__first, __last, __comp); -<span class="lineNum"> 2054 </span> : } -<span class="lineNum"> 2055 </span> : -<span class="lineNum"> 2056 </span> : // nth_element -<span class="lineNum"> 2057 </span> : -<span class="lineNum"> 2058 </span> : /** -<span class="lineNum"> 2059 </span> : * @brief Finds the first position in which @a val could be inserted -<span class="lineNum"> 2060 </span> : * without changing the ordering. -<span class="lineNum"> 2061 </span> : * @param first An iterator. -<span class="lineNum"> 2062 </span> : * @param last Another iterator. -<span class="lineNum"> 2063 </span> : * @param val The search term. -<span class="lineNum"> 2064 </span> : * @return An iterator pointing to the first element "not less -<span class="lineNum"> 2065 </span> : * than" @a val, or end() if every element is less than -<span class="lineNum"> 2066 </span> : * @a val. -<span class="lineNum"> 2067 </span> : * @ingroup binarysearch -<span class="lineNum"> 2068 </span> : */ -<span class="lineNum"> 2069 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 2070 </span> : _ForwardIterator -<span class="lineNum"> 2071 </span> : lower_bound(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2072 </span> : const _Tp& __val) -<span class="lineNum"> 2073 </span> : { -<span class="lineNum"> 2074 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2075 </span> : _ValueType; -<span class="lineNum"> 2076 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 2077 </span> : _DistanceType; -<span class="lineNum"> 2078 </span> : -<span class="lineNum"> 2079 </span> : // concept requirements -<span class="lineNum"> 2080 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2081 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType, _Tp>) -<span class="lineNum"> 2082 </span> : __glibcxx_requires_partitioned_lower(__first, __last, __val); -<span class="lineNum"> 2083 </span> : -<span class="lineNum"> 2084 </span> : _DistanceType __len = std::distance(__first, __last); -<span class="lineNum"> 2085 </span> : _DistanceType __half; -<span class="lineNum"> 2086 </span> : _ForwardIterator __middle; -<span class="lineNum"> 2087 </span> : -<span class="lineNum"> 2088 </span> : while (__len > 0) -<span class="lineNum"> 2089 </span> : { -<span class="lineNum"> 2090 </span> : __half = __len >> 1; -<span class="lineNum"> 2091 </span> : __middle = __first; -<span class="lineNum"> 2092 </span> : std::advance(__middle, __half); -<span class="lineNum"> 2093 </span> : if (*__middle < __val) -<span class="lineNum"> 2094 </span> : { -<span class="lineNum"> 2095 </span> : __first = __middle; -<span class="lineNum"> 2096 </span> : ++__first; -<span class="lineNum"> 2097 </span> : __len = __len - __half - 1; -<span class="lineNum"> 2098 </span> : } -<span class="lineNum"> 2099 </span> : else -<span class="lineNum"> 2100 </span> : __len = __half; -<span class="lineNum"> 2101 </span> : } -<span class="lineNum"> 2102 </span> : return __first; -<span class="lineNum"> 2103 </span> : } -<span class="lineNum"> 2104 </span> : -<span class="lineNum"> 2105 </span> : /** -<span class="lineNum"> 2106 </span> : * @brief Finds the first position in which @a val could be inserted -<span class="lineNum"> 2107 </span> : * without changing the ordering. -<span class="lineNum"> 2108 </span> : * @param first An iterator. -<span class="lineNum"> 2109 </span> : * @param last Another iterator. -<span class="lineNum"> 2110 </span> : * @param val The search term. -<span class="lineNum"> 2111 </span> : * @param comp A functor to use for comparisons. -<span class="lineNum"> 2112 </span> : * @return An iterator pointing to the first element "not less than" @a val, -<span class="lineNum"> 2113 </span> : * or end() if every element is less than @a val. -<span class="lineNum"> 2114 </span> : * @ingroup binarysearch -<span class="lineNum"> 2115 </span> : * -<span class="lineNum"> 2116 </span> : * The comparison function should have the same effects on ordering as -<span class="lineNum"> 2117 </span> : * the function used for the initial sort. -<span class="lineNum"> 2118 </span> : */ -<span class="lineNum"> 2119 </span> : template<typename _ForwardIterator, typename _Tp, typename _Compare> -<span class="lineNum"> 2120 </span> : _ForwardIterator -<span class="lineNum"> 2121 </span> : lower_bound(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2122 </span> : const _Tp& __val, _Compare __comp) -<span class="lineNum"> 2123 </span> : { -<span class="lineNum"> 2124 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2125 </span> : _ValueType; -<span class="lineNum"> 2126 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 2127 </span> : _DistanceType; -<span class="lineNum"> 2128 </span> : -<span class="lineNum"> 2129 </span> : // concept requirements -<span class="lineNum"> 2130 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2131 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 2132 </span> : _ValueType, _Tp>) -<span class="lineNum"> 2133 </span> : __glibcxx_requires_partitioned_lower_pred(__first, __last, -<span class="lineNum"> 2134 </span> : __val, __comp); -<span class="lineNum"> 2135 </span> : -<span class="lineNum"> 2136 </span> : _DistanceType __len = std::distance(__first, __last); -<span class="lineNum"> 2137 </span> : _DistanceType __half; -<span class="lineNum"> 2138 </span> : _ForwardIterator __middle; -<span class="lineNum"> 2139 </span> : -<span class="lineNum"> 2140 </span> : while (__len > 0) -<span class="lineNum"> 2141 </span> : { -<span class="lineNum"> 2142 </span> : __half = __len >> 1; -<span class="lineNum"> 2143 </span> : __middle = __first; -<span class="lineNum"> 2144 </span> : std::advance(__middle, __half); -<span class="lineNum"> 2145 </span> : if (__comp(*__middle, __val)) -<span class="lineNum"> 2146 </span> : { -<span class="lineNum"> 2147 </span> : __first = __middle; -<span class="lineNum"> 2148 </span> : ++__first; -<span class="lineNum"> 2149 </span> : __len = __len - __half - 1; -<span class="lineNum"> 2150 </span> : } -<span class="lineNum"> 2151 </span> : else -<span class="lineNum"> 2152 </span> : __len = __half; -<span class="lineNum"> 2153 </span> : } -<span class="lineNum"> 2154 </span> : return __first; -<span class="lineNum"> 2155 </span> : } -<span class="lineNum"> 2156 </span> : -<span class="lineNum"> 2157 </span> : /** -<span class="lineNum"> 2158 </span> : * @brief Finds the last position in which @a val could be inserted -<span class="lineNum"> 2159 </span> : * without changing the ordering. -<span class="lineNum"> 2160 </span> : * @param first An iterator. -<span class="lineNum"> 2161 </span> : * @param last Another iterator. -<span class="lineNum"> 2162 </span> : * @param val The search term. -<span class="lineNum"> 2163 </span> : * @return An iterator pointing to the first element greater than @a val, -<span class="lineNum"> 2164 </span> : * or end() if no elements are greater than @a val. -<span class="lineNum"> 2165 </span> : * @ingroup binarysearch -<span class="lineNum"> 2166 </span> : */ -<span class="lineNum"> 2167 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 2168 </span> : _ForwardIterator -<span class="lineNum"> 2169 </span> : upper_bound(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2170 </span> : const _Tp& __val) -<span class="lineNum"> 2171 </span> : { -<span class="lineNum"> 2172 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2173 </span> : _ValueType; -<span class="lineNum"> 2174 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 2175 </span> : _DistanceType; -<span class="lineNum"> 2176 </span> : -<span class="lineNum"> 2177 </span> : // concept requirements -<span class="lineNum"> 2178 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2179 </span> : __glibcxx_function_requires(_LessThanOpConcept<_Tp, _ValueType>) -<span class="lineNum"> 2180 </span> : __glibcxx_requires_partitioned_upper(__first, __last, __val); -<span class="lineNum"> 2181 </span> : -<span class="lineNum"> 2182 </span> : _DistanceType __len = std::distance(__first, __last); -<span class="lineNum"> 2183 </span> : _DistanceType __half; -<span class="lineNum"> 2184 </span> : _ForwardIterator __middle; -<span class="lineNum"> 2185 </span> : -<span class="lineNum"> 2186 </span> : while (__len > 0) -<span class="lineNum"> 2187 </span> : { -<span class="lineNum"> 2188 </span> : __half = __len >> 1; -<span class="lineNum"> 2189 </span> : __middle = __first; -<span class="lineNum"> 2190 </span> : std::advance(__middle, __half); -<span class="lineNum"> 2191 </span> : if (__val < *__middle) -<span class="lineNum"> 2192 </span> : __len = __half; -<span class="lineNum"> 2193 </span> : else -<span class="lineNum"> 2194 </span> : { -<span class="lineNum"> 2195 </span> : __first = __middle; -<span class="lineNum"> 2196 </span> : ++__first; -<span class="lineNum"> 2197 </span> : __len = __len - __half - 1; -<span class="lineNum"> 2198 </span> : } -<span class="lineNum"> 2199 </span> : } -<span class="lineNum"> 2200 </span> : return __first; -<span class="lineNum"> 2201 </span> : } -<span class="lineNum"> 2202 </span> : -<span class="lineNum"> 2203 </span> : /** -<span class="lineNum"> 2204 </span> : * @brief Finds the last position in which @a val could be inserted -<span class="lineNum"> 2205 </span> : * without changing the ordering. -<span class="lineNum"> 2206 </span> : * @param first An iterator. -<span class="lineNum"> 2207 </span> : * @param last Another iterator. -<span class="lineNum"> 2208 </span> : * @param val The search term. -<span class="lineNum"> 2209 </span> : * @param comp A functor to use for comparisons. -<span class="lineNum"> 2210 </span> : * @return An iterator pointing to the first element greater than @a val, -<span class="lineNum"> 2211 </span> : * or end() if no elements are greater than @a val. -<span class="lineNum"> 2212 </span> : * @ingroup binarysearch -<span class="lineNum"> 2213 </span> : * -<span class="lineNum"> 2214 </span> : * The comparison function should have the same effects on ordering as -<span class="lineNum"> 2215 </span> : * the function used for the initial sort. -<span class="lineNum"> 2216 </span> : */ -<span class="lineNum"> 2217 </span> : template<typename _ForwardIterator, typename _Tp, typename _Compare> -<span class="lineNum"> 2218 </span> : _ForwardIterator -<span class="lineNum"> 2219 </span> : upper_bound(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2220 </span> : const _Tp& __val, _Compare __comp) -<span class="lineNum"> 2221 </span> : { -<span class="lineNum"> 2222 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2223 </span> : _ValueType; -<span class="lineNum"> 2224 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 2225 </span> : _DistanceType; -<span class="lineNum"> 2226 </span> : -<span class="lineNum"> 2227 </span> : // concept requirements -<span class="lineNum"> 2228 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2229 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 2230 </span> : _Tp, _ValueType>) -<span class="lineNum"> 2231 </span> : __glibcxx_requires_partitioned_upper_pred(__first, __last, -<span class="lineNum"> 2232 </span> : __val, __comp); -<span class="lineNum"> 2233 </span> : -<span class="lineNum"> 2234 </span> : _DistanceType __len = std::distance(__first, __last); -<span class="lineNum"> 2235 </span> : _DistanceType __half; -<span class="lineNum"> 2236 </span> : _ForwardIterator __middle; -<span class="lineNum"> 2237 </span> : -<span class="lineNum"> 2238 </span> : while (__len > 0) -<span class="lineNum"> 2239 </span> : { -<span class="lineNum"> 2240 </span> : __half = __len >> 1; -<span class="lineNum"> 2241 </span> : __middle = __first; -<span class="lineNum"> 2242 </span> : std::advance(__middle, __half); -<span class="lineNum"> 2243 </span> : if (__comp(__val, *__middle)) -<span class="lineNum"> 2244 </span> : __len = __half; -<span class="lineNum"> 2245 </span> : else -<span class="lineNum"> 2246 </span> : { -<span class="lineNum"> 2247 </span> : __first = __middle; -<span class="lineNum"> 2248 </span> : ++__first; -<span class="lineNum"> 2249 </span> : __len = __len - __half - 1; -<span class="lineNum"> 2250 </span> : } -<span class="lineNum"> 2251 </span> : } -<span class="lineNum"> 2252 </span> : return __first; -<span class="lineNum"> 2253 </span> : } -<span class="lineNum"> 2254 </span> : -<span class="lineNum"> 2255 </span> : /** -<span class="lineNum"> 2256 </span> : * @brief Finds the largest subrange in which @a val could be inserted -<span class="lineNum"> 2257 </span> : * at any place in it without changing the ordering. -<span class="lineNum"> 2258 </span> : * @param first An iterator. -<span class="lineNum"> 2259 </span> : * @param last Another iterator. -<span class="lineNum"> 2260 </span> : * @param val The search term. -<span class="lineNum"> 2261 </span> : * @return An pair of iterators defining the subrange. -<span class="lineNum"> 2262 </span> : * @ingroup binarysearch -<span class="lineNum"> 2263 </span> : * -<span class="lineNum"> 2264 </span> : * This is equivalent to -<span class="lineNum"> 2265 </span> : * @code -<span class="lineNum"> 2266 </span> : * std::make_pair(lower_bound(first, last, val), -<span class="lineNum"> 2267 </span> : * upper_bound(first, last, val)) -<span class="lineNum"> 2268 </span> : * @endcode -<span class="lineNum"> 2269 </span> : * but does not actually call those functions. -<span class="lineNum"> 2270 </span> : */ -<span class="lineNum"> 2271 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 2272 </span> : pair<_ForwardIterator, _ForwardIterator> -<span class="lineNum"> 2273 </span> : equal_range(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2274 </span> : const _Tp& __val) -<span class="lineNum"> 2275 </span> : { -<span class="lineNum"> 2276 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2277 </span> : _ValueType; -<span class="lineNum"> 2278 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 2279 </span> : _DistanceType; -<span class="lineNum"> 2280 </span> : -<span class="lineNum"> 2281 </span> : // concept requirements -<span class="lineNum"> 2282 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2283 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType, _Tp>) -<span class="lineNum"> 2284 </span> : __glibcxx_function_requires(_LessThanOpConcept<_Tp, _ValueType>) -<span class="lineNum"> 2285 </span> : __glibcxx_requires_partitioned_lower(__first, __last, __val); -<span class="lineNum"> 2286 </span> : __glibcxx_requires_partitioned_upper(__first, __last, __val); -<span class="lineNum"> 2287 </span> : -<span class="lineNum"> 2288 </span> : _DistanceType __len = std::distance(__first, __last); -<span class="lineNum"> 2289 </span> : _DistanceType __half; -<span class="lineNum"> 2290 </span> : _ForwardIterator __middle, __left, __right; -<span class="lineNum"> 2291 </span> : -<span class="lineNum"> 2292 </span> : while (__len > 0) -<span class="lineNum"> 2293 </span> : { -<span class="lineNum"> 2294 </span> : __half = __len >> 1; -<span class="lineNum"> 2295 </span> : __middle = __first; -<span class="lineNum"> 2296 </span> : std::advance(__middle, __half); -<span class="lineNum"> 2297 </span> : if (*__middle < __val) -<span class="lineNum"> 2298 </span> : { -<span class="lineNum"> 2299 </span> : __first = __middle; -<span class="lineNum"> 2300 </span> : ++__first; -<span class="lineNum"> 2301 </span> : __len = __len - __half - 1; -<span class="lineNum"> 2302 </span> : } -<span class="lineNum"> 2303 </span> : else if (__val < *__middle) -<span class="lineNum"> 2304 </span> : __len = __half; -<span class="lineNum"> 2305 </span> : else -<span class="lineNum"> 2306 </span> : { -<span class="lineNum"> 2307 </span> : __left = std::lower_bound(__first, __middle, __val); -<span class="lineNum"> 2308 </span> : std::advance(__first, __len); -<span class="lineNum"> 2309 </span> : __right = std::upper_bound(++__middle, __first, __val); -<span class="lineNum"> 2310 </span> : return pair<_ForwardIterator, _ForwardIterator>(__left, __right); -<span class="lineNum"> 2311 </span> : } -<span class="lineNum"> 2312 </span> : } -<span class="lineNum"> 2313 </span> : return pair<_ForwardIterator, _ForwardIterator>(__first, __first); -<span class="lineNum"> 2314 </span> : } -<span class="lineNum"> 2315 </span> : -<span class="lineNum"> 2316 </span> : /** -<span class="lineNum"> 2317 </span> : * @brief Finds the largest subrange in which @a val could be inserted -<span class="lineNum"> 2318 </span> : * at any place in it without changing the ordering. -<span class="lineNum"> 2319 </span> : * @param first An iterator. -<span class="lineNum"> 2320 </span> : * @param last Another iterator. -<span class="lineNum"> 2321 </span> : * @param val The search term. -<span class="lineNum"> 2322 </span> : * @param comp A functor to use for comparisons. -<span class="lineNum"> 2323 </span> : * @return An pair of iterators defining the subrange. -<span class="lineNum"> 2324 </span> : * @ingroup binarysearch -<span class="lineNum"> 2325 </span> : * -<span class="lineNum"> 2326 </span> : * This is equivalent to -<span class="lineNum"> 2327 </span> : * @code -<span class="lineNum"> 2328 </span> : * std::make_pair(lower_bound(first, last, val, comp), -<span class="lineNum"> 2329 </span> : * upper_bound(first, last, val, comp)) -<span class="lineNum"> 2330 </span> : * @endcode -<span class="lineNum"> 2331 </span> : * but does not actually call those functions. -<span class="lineNum"> 2332 </span> : */ -<span class="lineNum"> 2333 </span> : template<typename _ForwardIterator, typename _Tp, typename _Compare> -<span class="lineNum"> 2334 </span> : pair<_ForwardIterator, _ForwardIterator> -<span class="lineNum"> 2335 </span> : equal_range(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2336 </span> : const _Tp& __val, -<span class="lineNum"> 2337 </span> : _Compare __comp) -<span class="lineNum"> 2338 </span> : { -<span class="lineNum"> 2339 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2340 </span> : _ValueType; -<span class="lineNum"> 2341 </span> : typedef typename iterator_traits<_ForwardIterator>::difference_type -<span class="lineNum"> 2342 </span> : _DistanceType; -<span class="lineNum"> 2343 </span> : -<span class="lineNum"> 2344 </span> : // concept requirements -<span class="lineNum"> 2345 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2346 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 2347 </span> : _ValueType, _Tp>) -<span class="lineNum"> 2348 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 2349 </span> : _Tp, _ValueType>) -<span class="lineNum"> 2350 </span> : __glibcxx_requires_partitioned_lower_pred(__first, __last, -<span class="lineNum"> 2351 </span> : __val, __comp); -<span class="lineNum"> 2352 </span> : __glibcxx_requires_partitioned_upper_pred(__first, __last, -<span class="lineNum"> 2353 </span> : __val, __comp); -<span class="lineNum"> 2354 </span> : -<span class="lineNum"> 2355 </span> : _DistanceType __len = std::distance(__first, __last); -<span class="lineNum"> 2356 </span> : _DistanceType __half; -<span class="lineNum"> 2357 </span> : _ForwardIterator __middle, __left, __right; -<span class="lineNum"> 2358 </span> : -<span class="lineNum"> 2359 </span> : while (__len > 0) -<span class="lineNum"> 2360 </span> : { -<span class="lineNum"> 2361 </span> : __half = __len >> 1; -<span class="lineNum"> 2362 </span> : __middle = __first; -<span class="lineNum"> 2363 </span> : std::advance(__middle, __half); -<span class="lineNum"> 2364 </span> : if (__comp(*__middle, __val)) -<span class="lineNum"> 2365 </span> : { -<span class="lineNum"> 2366 </span> : __first = __middle; -<span class="lineNum"> 2367 </span> : ++__first; -<span class="lineNum"> 2368 </span> : __len = __len - __half - 1; -<span class="lineNum"> 2369 </span> : } -<span class="lineNum"> 2370 </span> : else if (__comp(__val, *__middle)) -<span class="lineNum"> 2371 </span> : __len = __half; -<span class="lineNum"> 2372 </span> : else -<span class="lineNum"> 2373 </span> : { -<span class="lineNum"> 2374 </span> : __left = std::lower_bound(__first, __middle, __val, __comp); -<span class="lineNum"> 2375 </span> : std::advance(__first, __len); -<span class="lineNum"> 2376 </span> : __right = std::upper_bound(++__middle, __first, __val, __comp); -<span class="lineNum"> 2377 </span> : return pair<_ForwardIterator, _ForwardIterator>(__left, __right); -<span class="lineNum"> 2378 </span> : } -<span class="lineNum"> 2379 </span> : } -<span class="lineNum"> 2380 </span> : return pair<_ForwardIterator, _ForwardIterator>(__first, __first); -<span class="lineNum"> 2381 </span> : } -<span class="lineNum"> 2382 </span> : -<span class="lineNum"> 2383 </span> : /** -<span class="lineNum"> 2384 </span> : * @brief Determines whether an element exists in a range. -<span class="lineNum"> 2385 </span> : * @param first An iterator. -<span class="lineNum"> 2386 </span> : * @param last Another iterator. -<span class="lineNum"> 2387 </span> : * @param val The search term. -<span class="lineNum"> 2388 </span> : * @return True if @a val (or its equivalent) is in [@a first,@a last ]. -<span class="lineNum"> 2389 </span> : * @ingroup binarysearch -<span class="lineNum"> 2390 </span> : * -<span class="lineNum"> 2391 </span> : * Note that this does not actually return an iterator to @a val. For -<span class="lineNum"> 2392 </span> : * that, use std::find or a container's specialized find member functions. -<span class="lineNum"> 2393 </span> : */ -<span class="lineNum"> 2394 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 2395 </span> : bool -<span class="lineNum"> 2396 </span> : binary_search(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2397 </span> : const _Tp& __val) -<span class="lineNum"> 2398 </span> : { -<span class="lineNum"> 2399 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2400 </span> : _ValueType; -<span class="lineNum"> 2401 </span> : -<span class="lineNum"> 2402 </span> : // concept requirements -<span class="lineNum"> 2403 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2404 </span> : __glibcxx_function_requires(_LessThanOpConcept<_Tp, _ValueType>) -<span class="lineNum"> 2405 </span> : __glibcxx_requires_partitioned_lower(__first, __last, __val); -<span class="lineNum"> 2406 </span> : __glibcxx_requires_partitioned_upper(__first, __last, __val); -<span class="lineNum"> 2407 </span> : -<span class="lineNum"> 2408 </span> : _ForwardIterator __i = std::lower_bound(__first, __last, __val); -<span class="lineNum"> 2409 </span> : return __i != __last && !(__val < *__i); -<span class="lineNum"> 2410 </span> : } -<span class="lineNum"> 2411 </span> : -<span class="lineNum"> 2412 </span> : /** -<span class="lineNum"> 2413 </span> : * @brief Determines whether an element exists in a range. -<span class="lineNum"> 2414 </span> : * @param first An iterator. -<span class="lineNum"> 2415 </span> : * @param last Another iterator. -<span class="lineNum"> 2416 </span> : * @param val The search term. -<span class="lineNum"> 2417 </span> : * @param comp A functor to use for comparisons. -<span class="lineNum"> 2418 </span> : * @return True if @a val (or its equivalent) is in [@a first,@a last ]. -<span class="lineNum"> 2419 </span> : * @ingroup binarysearch -<span class="lineNum"> 2420 </span> : * -<span class="lineNum"> 2421 </span> : * Note that this does not actually return an iterator to @a val. For -<span class="lineNum"> 2422 </span> : * that, use std::find or a container's specialized find member functions. -<span class="lineNum"> 2423 </span> : * -<span class="lineNum"> 2424 </span> : * The comparison function should have the same effects on ordering as -<span class="lineNum"> 2425 </span> : * the function used for the initial sort. -<span class="lineNum"> 2426 </span> : */ -<span class="lineNum"> 2427 </span> : template<typename _ForwardIterator, typename _Tp, typename _Compare> -<span class="lineNum"> 2428 </span> : bool -<span class="lineNum"> 2429 </span> : binary_search(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 2430 </span> : const _Tp& __val, _Compare __comp) -<span class="lineNum"> 2431 </span> : { -<span class="lineNum"> 2432 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 2433 </span> : _ValueType; -<span class="lineNum"> 2434 </span> : -<span class="lineNum"> 2435 </span> : // concept requirements -<span class="lineNum"> 2436 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 2437 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 2438 </span> : _Tp, _ValueType>) -<span class="lineNum"> 2439 </span> : __glibcxx_requires_partitioned_lower_pred(__first, __last, -<span class="lineNum"> 2440 </span> : __val, __comp); -<span class="lineNum"> 2441 </span> : __glibcxx_requires_partitioned_upper_pred(__first, __last, -<span class="lineNum"> 2442 </span> : __val, __comp); -<span class="lineNum"> 2443 </span> : -<span class="lineNum"> 2444 </span> : _ForwardIterator __i = std::lower_bound(__first, __last, __val, __comp); -<span class="lineNum"> 2445 </span> : return __i != __last && !bool(__comp(__val, *__i)); -<span class="lineNum"> 2446 </span> : } -<span class="lineNum"> 2447 </span> : -<span class="lineNum"> 2448 </span> : // merge -<span class="lineNum"> 2449 </span> : -<span class="lineNum"> 2450 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2451 </span> : template<typename _BidirectionalIterator1, typename _BidirectionalIterator2, -<span class="lineNum"> 2452 </span> : typename _BidirectionalIterator3> -<span class="lineNum"> 2453 </span> : _BidirectionalIterator3 -<span class="lineNum"> 2454 </span> : __merge_backward(_BidirectionalIterator1 __first1, -<span class="lineNum"> 2455 </span> : _BidirectionalIterator1 __last1, -<span class="lineNum"> 2456 </span> : _BidirectionalIterator2 __first2, -<span class="lineNum"> 2457 </span> : _BidirectionalIterator2 __last2, -<span class="lineNum"> 2458 </span> : _BidirectionalIterator3 __result) -<span class="lineNum"> 2459 </span> : { -<span class="lineNum"> 2460 </span> : if (__first1 == __last1) -<span class="lineNum"> 2461 </span> : return std::copy_backward(__first2, __last2, __result); -<span class="lineNum"> 2462 </span> : if (__first2 == __last2) -<span class="lineNum"> 2463 </span> : return std::copy_backward(__first1, __last1, __result); -<span class="lineNum"> 2464 </span> : --__last1; -<span class="lineNum"> 2465 </span> : --__last2; -<span class="lineNum"> 2466 </span> : while (true) -<span class="lineNum"> 2467 </span> : { -<span class="lineNum"> 2468 </span> : if (*__last2 < *__last1) -<span class="lineNum"> 2469 </span> : { -<span class="lineNum"> 2470 </span> : *--__result = *__last1; -<span class="lineNum"> 2471 </span> : if (__first1 == __last1) -<span class="lineNum"> 2472 </span> : return std::copy_backward(__first2, ++__last2, __result); -<span class="lineNum"> 2473 </span> : --__last1; -<span class="lineNum"> 2474 </span> : } -<span class="lineNum"> 2475 </span> : else -<span class="lineNum"> 2476 </span> : { -<span class="lineNum"> 2477 </span> : *--__result = *__last2; -<span class="lineNum"> 2478 </span> : if (__first2 == __last2) -<span class="lineNum"> 2479 </span> : return std::copy_backward(__first1, ++__last1, __result); -<span class="lineNum"> 2480 </span> : --__last2; -<span class="lineNum"> 2481 </span> : } -<span class="lineNum"> 2482 </span> : } -<span class="lineNum"> 2483 </span> : } -<span class="lineNum"> 2484 </span> : -<span class="lineNum"> 2485 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2486 </span> : template<typename _BidirectionalIterator1, typename _BidirectionalIterator2, -<span class="lineNum"> 2487 </span> : typename _BidirectionalIterator3, typename _Compare> -<span class="lineNum"> 2488 </span> : _BidirectionalIterator3 -<span class="lineNum"> 2489 </span> : __merge_backward(_BidirectionalIterator1 __first1, -<span class="lineNum"> 2490 </span> : _BidirectionalIterator1 __last1, -<span class="lineNum"> 2491 </span> : _BidirectionalIterator2 __first2, -<span class="lineNum"> 2492 </span> : _BidirectionalIterator2 __last2, -<span class="lineNum"> 2493 </span> : _BidirectionalIterator3 __result, -<span class="lineNum"> 2494 </span> : _Compare __comp) -<span class="lineNum"> 2495 </span> : { -<span class="lineNum"> 2496 </span> : if (__first1 == __last1) -<span class="lineNum"> 2497 </span> : return std::copy_backward(__first2, __last2, __result); -<span class="lineNum"> 2498 </span> : if (__first2 == __last2) -<span class="lineNum"> 2499 </span> : return std::copy_backward(__first1, __last1, __result); -<span class="lineNum"> 2500 </span> : --__last1; -<span class="lineNum"> 2501 </span> : --__last2; -<span class="lineNum"> 2502 </span> : while (true) -<span class="lineNum"> 2503 </span> : { -<span class="lineNum"> 2504 </span> : if (__comp(*__last2, *__last1)) -<span class="lineNum"> 2505 </span> : { -<span class="lineNum"> 2506 </span> : *--__result = *__last1; -<span class="lineNum"> 2507 </span> : if (__first1 == __last1) -<span class="lineNum"> 2508 </span> : return std::copy_backward(__first2, ++__last2, __result); -<span class="lineNum"> 2509 </span> : --__last1; -<span class="lineNum"> 2510 </span> : } -<span class="lineNum"> 2511 </span> : else -<span class="lineNum"> 2512 </span> : { -<span class="lineNum"> 2513 </span> : *--__result = *__last2; -<span class="lineNum"> 2514 </span> : if (__first2 == __last2) -<span class="lineNum"> 2515 </span> : return std::copy_backward(__first1, ++__last1, __result); -<span class="lineNum"> 2516 </span> : --__last2; -<span class="lineNum"> 2517 </span> : } -<span class="lineNum"> 2518 </span> : } -<span class="lineNum"> 2519 </span> : } -<span class="lineNum"> 2520 </span> : -<span class="lineNum"> 2521 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2522 </span> : template<typename _BidirectionalIterator1, typename _BidirectionalIterator2, -<span class="lineNum"> 2523 </span> : typename _Distance> -<span class="lineNum"> 2524 </span> : _BidirectionalIterator1 -<span class="lineNum"> 2525 </span> : __rotate_adaptive(_BidirectionalIterator1 __first, -<span class="lineNum"> 2526 </span> : _BidirectionalIterator1 __middle, -<span class="lineNum"> 2527 </span> : _BidirectionalIterator1 __last, -<span class="lineNum"> 2528 </span> : _Distance __len1, _Distance __len2, -<span class="lineNum"> 2529 </span> : _BidirectionalIterator2 __buffer, -<span class="lineNum"> 2530 </span> : _Distance __buffer_size) -<span class="lineNum"> 2531 </span> : { -<span class="lineNum"> 2532 </span> : _BidirectionalIterator2 __buffer_end; -<span class="lineNum"> 2533 </span> : if (__len1 > __len2 && __len2 <= __buffer_size) -<span class="lineNum"> 2534 </span> : { -<span class="lineNum"> 2535 </span> : __buffer_end = std::copy(__middle, __last, __buffer); -<span class="lineNum"> 2536 </span> : std::copy_backward(__first, __middle, __last); -<span class="lineNum"> 2537 </span> : return std::copy(__buffer, __buffer_end, __first); -<span class="lineNum"> 2538 </span> : } -<span class="lineNum"> 2539 </span> : else if (__len1 <= __buffer_size) -<span class="lineNum"> 2540 </span> : { -<span class="lineNum"> 2541 </span> : __buffer_end = std::copy(__first, __middle, __buffer); -<span class="lineNum"> 2542 </span> : std::copy(__middle, __last, __first); -<span class="lineNum"> 2543 </span> : return std::copy_backward(__buffer, __buffer_end, __last); -<span class="lineNum"> 2544 </span> : } -<span class="lineNum"> 2545 </span> : else -<span class="lineNum"> 2546 </span> : { -<span class="lineNum"> 2547 </span> : std::rotate(__first, __middle, __last); -<span class="lineNum"> 2548 </span> : std::advance(__first, std::distance(__middle, __last)); -<span class="lineNum"> 2549 </span> : return __first; -<span class="lineNum"> 2550 </span> : } -<span class="lineNum"> 2551 </span> : } -<span class="lineNum"> 2552 </span> : -<span class="lineNum"> 2553 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2554 </span> : template<typename _BidirectionalIterator, typename _Distance, -<span class="lineNum"> 2555 </span> : typename _Pointer> -<span class="lineNum"> 2556 </span> : void -<span class="lineNum"> 2557 </span> : __merge_adaptive(_BidirectionalIterator __first, -<span class="lineNum"> 2558 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 2559 </span> : _BidirectionalIterator __last, -<span class="lineNum"> 2560 </span> : _Distance __len1, _Distance __len2, -<span class="lineNum"> 2561 </span> : _Pointer __buffer, _Distance __buffer_size) -<span class="lineNum"> 2562 </span> : { -<span class="lineNum"> 2563 </span> : if (__len1 <= __len2 && __len1 <= __buffer_size) -<span class="lineNum"> 2564 </span> : { -<span class="lineNum"> 2565 </span> : _Pointer __buffer_end = std::copy(__first, __middle, __buffer); -<span class="lineNum"> 2566 </span> : _GLIBCXX_STD_P::merge(__buffer, __buffer_end, __middle, __last, -<span class="lineNum"> 2567 </span> : __first); -<span class="lineNum"> 2568 </span> : } -<span class="lineNum"> 2569 </span> : else if (__len2 <= __buffer_size) -<span class="lineNum"> 2570 </span> : { -<span class="lineNum"> 2571 </span> : _Pointer __buffer_end = std::copy(__middle, __last, __buffer); -<span class="lineNum"> 2572 </span> : std::__merge_backward(__first, __middle, __buffer, -<span class="lineNum"> 2573 </span> : __buffer_end, __last); -<span class="lineNum"> 2574 </span> : } -<span class="lineNum"> 2575 </span> : else -<span class="lineNum"> 2576 </span> : { -<span class="lineNum"> 2577 </span> : _BidirectionalIterator __first_cut = __first; -<span class="lineNum"> 2578 </span> : _BidirectionalIterator __second_cut = __middle; -<span class="lineNum"> 2579 </span> : _Distance __len11 = 0; -<span class="lineNum"> 2580 </span> : _Distance __len22 = 0; -<span class="lineNum"> 2581 </span> : if (__len1 > __len2) -<span class="lineNum"> 2582 </span> : { -<span class="lineNum"> 2583 </span> : __len11 = __len1 / 2; -<span class="lineNum"> 2584 </span> : std::advance(__first_cut, __len11); -<span class="lineNum"> 2585 </span> : __second_cut = std::lower_bound(__middle, __last, -<span class="lineNum"> 2586 </span> : *__first_cut); -<span class="lineNum"> 2587 </span> : __len22 = std::distance(__middle, __second_cut); -<span class="lineNum"> 2588 </span> : } -<span class="lineNum"> 2589 </span> : else -<span class="lineNum"> 2590 </span> : { -<span class="lineNum"> 2591 </span> : __len22 = __len2 / 2; -<span class="lineNum"> 2592 </span> : std::advance(__second_cut, __len22); -<span class="lineNum"> 2593 </span> : __first_cut = std::upper_bound(__first, __middle, -<span class="lineNum"> 2594 </span> : *__second_cut); -<span class="lineNum"> 2595 </span> : __len11 = std::distance(__first, __first_cut); -<span class="lineNum"> 2596 </span> : } -<span class="lineNum"> 2597 </span> : _BidirectionalIterator __new_middle = -<span class="lineNum"> 2598 </span> : std::__rotate_adaptive(__first_cut, __middle, __second_cut, -<span class="lineNum"> 2599 </span> : __len1 - __len11, __len22, __buffer, -<span class="lineNum"> 2600 </span> : __buffer_size); -<span class="lineNum"> 2601 </span> : std::__merge_adaptive(__first, __first_cut, __new_middle, __len11, -<span class="lineNum"> 2602 </span> : __len22, __buffer, __buffer_size); -<span class="lineNum"> 2603 </span> : std::__merge_adaptive(__new_middle, __second_cut, __last, -<span class="lineNum"> 2604 </span> : __len1 - __len11, -<span class="lineNum"> 2605 </span> : __len2 - __len22, __buffer, __buffer_size); -<span class="lineNum"> 2606 </span> : } -<span class="lineNum"> 2607 </span> : } -<span class="lineNum"> 2608 </span> : -<span class="lineNum"> 2609 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2610 </span> : template<typename _BidirectionalIterator, typename _Distance, -<span class="lineNum"> 2611 </span> : typename _Pointer, typename _Compare> -<span class="lineNum"> 2612 </span> : void -<span class="lineNum"> 2613 </span> : __merge_adaptive(_BidirectionalIterator __first, -<span class="lineNum"> 2614 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 2615 </span> : _BidirectionalIterator __last, -<span class="lineNum"> 2616 </span> : _Distance __len1, _Distance __len2, -<span class="lineNum"> 2617 </span> : _Pointer __buffer, _Distance __buffer_size, -<span class="lineNum"> 2618 </span> : _Compare __comp) -<span class="lineNum"> 2619 </span> : { -<span class="lineNum"> 2620 </span> : if (__len1 <= __len2 && __len1 <= __buffer_size) -<span class="lineNum"> 2621 </span> : { -<span class="lineNum"> 2622 </span> : _Pointer __buffer_end = std::copy(__first, __middle, __buffer); -<span class="lineNum"> 2623 </span> : _GLIBCXX_STD_P::merge(__buffer, __buffer_end, __middle, __last, -<span class="lineNum"> 2624 </span> : __first, __comp); -<span class="lineNum"> 2625 </span> : } -<span class="lineNum"> 2626 </span> : else if (__len2 <= __buffer_size) -<span class="lineNum"> 2627 </span> : { -<span class="lineNum"> 2628 </span> : _Pointer __buffer_end = std::copy(__middle, __last, __buffer); -<span class="lineNum"> 2629 </span> : std::__merge_backward(__first, __middle, __buffer, __buffer_end, -<span class="lineNum"> 2630 </span> : __last, __comp); -<span class="lineNum"> 2631 </span> : } -<span class="lineNum"> 2632 </span> : else -<span class="lineNum"> 2633 </span> : { -<span class="lineNum"> 2634 </span> : _BidirectionalIterator __first_cut = __first; -<span class="lineNum"> 2635 </span> : _BidirectionalIterator __second_cut = __middle; -<span class="lineNum"> 2636 </span> : _Distance __len11 = 0; -<span class="lineNum"> 2637 </span> : _Distance __len22 = 0; -<span class="lineNum"> 2638 </span> : if (__len1 > __len2) -<span class="lineNum"> 2639 </span> : { -<span class="lineNum"> 2640 </span> : __len11 = __len1 / 2; -<span class="lineNum"> 2641 </span> : std::advance(__first_cut, __len11); -<span class="lineNum"> 2642 </span> : __second_cut = std::lower_bound(__middle, __last, *__first_cut, -<span class="lineNum"> 2643 </span> : __comp); -<span class="lineNum"> 2644 </span> : __len22 = std::distance(__middle, __second_cut); -<span class="lineNum"> 2645 </span> : } -<span class="lineNum"> 2646 </span> : else -<span class="lineNum"> 2647 </span> : { -<span class="lineNum"> 2648 </span> : __len22 = __len2 / 2; -<span class="lineNum"> 2649 </span> : std::advance(__second_cut, __len22); -<span class="lineNum"> 2650 </span> : __first_cut = std::upper_bound(__first, __middle, *__second_cut, -<span class="lineNum"> 2651 </span> : __comp); -<span class="lineNum"> 2652 </span> : __len11 = std::distance(__first, __first_cut); -<span class="lineNum"> 2653 </span> : } -<span class="lineNum"> 2654 </span> : _BidirectionalIterator __new_middle = -<span class="lineNum"> 2655 </span> : std::__rotate_adaptive(__first_cut, __middle, __second_cut, -<span class="lineNum"> 2656 </span> : __len1 - __len11, __len22, __buffer, -<span class="lineNum"> 2657 </span> : __buffer_size); -<span class="lineNum"> 2658 </span> : std::__merge_adaptive(__first, __first_cut, __new_middle, __len11, -<span class="lineNum"> 2659 </span> : __len22, __buffer, __buffer_size, __comp); -<span class="lineNum"> 2660 </span> : std::__merge_adaptive(__new_middle, __second_cut, __last, -<span class="lineNum"> 2661 </span> : __len1 - __len11, -<span class="lineNum"> 2662 </span> : __len2 - __len22, __buffer, -<span class="lineNum"> 2663 </span> : __buffer_size, __comp); -<span class="lineNum"> 2664 </span> : } -<span class="lineNum"> 2665 </span> : } -<span class="lineNum"> 2666 </span> : -<span class="lineNum"> 2667 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2668 </span> : template<typename _BidirectionalIterator, typename _Distance> -<span class="lineNum"> 2669 </span> : void -<span class="lineNum"> 2670 </span> : __merge_without_buffer(_BidirectionalIterator __first, -<span class="lineNum"> 2671 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 2672 </span> : _BidirectionalIterator __last, -<span class="lineNum"> 2673 </span> : _Distance __len1, _Distance __len2) -<span class="lineNum"> 2674 </span> : { -<span class="lineNum"> 2675 </span> : if (__len1 == 0 || __len2 == 0) -<span class="lineNum"> 2676 </span> : return; -<span class="lineNum"> 2677 </span> : if (__len1 + __len2 == 2) -<span class="lineNum"> 2678 </span> : { -<span class="lineNum"> 2679 </span> : if (*__middle < *__first) -<span class="lineNum"> 2680 </span> : std::iter_swap(__first, __middle); -<span class="lineNum"> 2681 </span> : return; -<span class="lineNum"> 2682 </span> : } -<span class="lineNum"> 2683 </span> : _BidirectionalIterator __first_cut = __first; -<span class="lineNum"> 2684 </span> : _BidirectionalIterator __second_cut = __middle; -<span class="lineNum"> 2685 </span> : _Distance __len11 = 0; -<span class="lineNum"> 2686 </span> : _Distance __len22 = 0; -<span class="lineNum"> 2687 </span> : if (__len1 > __len2) -<span class="lineNum"> 2688 </span> : { -<span class="lineNum"> 2689 </span> : __len11 = __len1 / 2; -<span class="lineNum"> 2690 </span> : std::advance(__first_cut, __len11); -<span class="lineNum"> 2691 </span> : __second_cut = std::lower_bound(__middle, __last, *__first_cut); -<span class="lineNum"> 2692 </span> : __len22 = std::distance(__middle, __second_cut); -<span class="lineNum"> 2693 </span> : } -<span class="lineNum"> 2694 </span> : else -<span class="lineNum"> 2695 </span> : { -<span class="lineNum"> 2696 </span> : __len22 = __len2 / 2; -<span class="lineNum"> 2697 </span> : std::advance(__second_cut, __len22); -<span class="lineNum"> 2698 </span> : __first_cut = std::upper_bound(__first, __middle, *__second_cut); -<span class="lineNum"> 2699 </span> : __len11 = std::distance(__first, __first_cut); -<span class="lineNum"> 2700 </span> : } -<span class="lineNum"> 2701 </span> : std::rotate(__first_cut, __middle, __second_cut); -<span class="lineNum"> 2702 </span> : _BidirectionalIterator __new_middle = __first_cut; -<span class="lineNum"> 2703 </span> : std::advance(__new_middle, std::distance(__middle, __second_cut)); -<span class="lineNum"> 2704 </span> : std::__merge_without_buffer(__first, __first_cut, __new_middle, -<span class="lineNum"> 2705 </span> : __len11, __len22); -<span class="lineNum"> 2706 </span> : std::__merge_without_buffer(__new_middle, __second_cut, __last, -<span class="lineNum"> 2707 </span> : __len1 - __len11, __len2 - __len22); -<span class="lineNum"> 2708 </span> : } -<span class="lineNum"> 2709 </span> : -<span class="lineNum"> 2710 </span> : /// This is a helper function for the merge routines. -<span class="lineNum"> 2711 </span> : template<typename _BidirectionalIterator, typename _Distance, -<span class="lineNum"> 2712 </span> : typename _Compare> -<span class="lineNum"> 2713 </span> : void -<span class="lineNum"> 2714 </span> : __merge_without_buffer(_BidirectionalIterator __first, -<span class="lineNum"> 2715 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 2716 </span> : _BidirectionalIterator __last, -<span class="lineNum"> 2717 </span> : _Distance __len1, _Distance __len2, -<span class="lineNum"> 2718 </span> : _Compare __comp) -<span class="lineNum"> 2719 </span> : { -<span class="lineNum"> 2720 </span> : if (__len1 == 0 || __len2 == 0) -<span class="lineNum"> 2721 </span> : return; -<span class="lineNum"> 2722 </span> : if (__len1 + __len2 == 2) -<span class="lineNum"> 2723 </span> : { -<span class="lineNum"> 2724 </span> : if (__comp(*__middle, *__first)) -<span class="lineNum"> 2725 </span> : std::iter_swap(__first, __middle); -<span class="lineNum"> 2726 </span> : return; -<span class="lineNum"> 2727 </span> : } -<span class="lineNum"> 2728 </span> : _BidirectionalIterator __first_cut = __first; -<span class="lineNum"> 2729 </span> : _BidirectionalIterator __second_cut = __middle; -<span class="lineNum"> 2730 </span> : _Distance __len11 = 0; -<span class="lineNum"> 2731 </span> : _Distance __len22 = 0; -<span class="lineNum"> 2732 </span> : if (__len1 > __len2) -<span class="lineNum"> 2733 </span> : { -<span class="lineNum"> 2734 </span> : __len11 = __len1 / 2; -<span class="lineNum"> 2735 </span> : std::advance(__first_cut, __len11); -<span class="lineNum"> 2736 </span> : __second_cut = std::lower_bound(__middle, __last, *__first_cut, -<span class="lineNum"> 2737 </span> : __comp); -<span class="lineNum"> 2738 </span> : __len22 = std::distance(__middle, __second_cut); -<span class="lineNum"> 2739 </span> : } -<span class="lineNum"> 2740 </span> : else -<span class="lineNum"> 2741 </span> : { -<span class="lineNum"> 2742 </span> : __len22 = __len2 / 2; -<span class="lineNum"> 2743 </span> : std::advance(__second_cut, __len22); -<span class="lineNum"> 2744 </span> : __first_cut = std::upper_bound(__first, __middle, *__second_cut, -<span class="lineNum"> 2745 </span> : __comp); -<span class="lineNum"> 2746 </span> : __len11 = std::distance(__first, __first_cut); -<span class="lineNum"> 2747 </span> : } -<span class="lineNum"> 2748 </span> : std::rotate(__first_cut, __middle, __second_cut); -<span class="lineNum"> 2749 </span> : _BidirectionalIterator __new_middle = __first_cut; -<span class="lineNum"> 2750 </span> : std::advance(__new_middle, std::distance(__middle, __second_cut)); -<span class="lineNum"> 2751 </span> : std::__merge_without_buffer(__first, __first_cut, __new_middle, -<span class="lineNum"> 2752 </span> : __len11, __len22, __comp); -<span class="lineNum"> 2753 </span> : std::__merge_without_buffer(__new_middle, __second_cut, __last, -<span class="lineNum"> 2754 </span> : __len1 - __len11, __len2 - __len22, __comp); -<span class="lineNum"> 2755 </span> : } -<span class="lineNum"> 2756 </span> : -<span class="lineNum"> 2757 </span> : /** -<span class="lineNum"> 2758 </span> : * @brief Merges two sorted ranges in place. -<span class="lineNum"> 2759 </span> : * @param first An iterator. -<span class="lineNum"> 2760 </span> : * @param middle Another iterator. -<span class="lineNum"> 2761 </span> : * @param last Another iterator. -<span class="lineNum"> 2762 </span> : * @return Nothing. -<span class="lineNum"> 2763 </span> : * -<span class="lineNum"> 2764 </span> : * Merges two sorted and consecutive ranges, [first,middle) and -<span class="lineNum"> 2765 </span> : * [middle,last), and puts the result in [first,last). The output will -<span class="lineNum"> 2766 </span> : * be sorted. The sort is @e stable, that is, for equivalent -<span class="lineNum"> 2767 </span> : * elements in the two ranges, elements from the first range will always -<span class="lineNum"> 2768 </span> : * come before elements from the second. -<span class="lineNum"> 2769 </span> : * -<span class="lineNum"> 2770 </span> : * If enough additional memory is available, this takes (last-first)-1 -<span class="lineNum"> 2771 </span> : * comparisons. Otherwise an NlogN algorithm is used, where N is -<span class="lineNum"> 2772 </span> : * distance(first,last). -<span class="lineNum"> 2773 </span> : */ -<span class="lineNum"> 2774 </span> : template<typename _BidirectionalIterator> -<span class="lineNum"> 2775 </span> : void -<span class="lineNum"> 2776 </span> : inplace_merge(_BidirectionalIterator __first, -<span class="lineNum"> 2777 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 2778 </span> : _BidirectionalIterator __last) -<span class="lineNum"> 2779 </span> : { -<span class="lineNum"> 2780 </span> : typedef typename iterator_traits<_BidirectionalIterator>::value_type -<span class="lineNum"> 2781 </span> : _ValueType; -<span class="lineNum"> 2782 </span> : typedef typename iterator_traits<_BidirectionalIterator>::difference_type -<span class="lineNum"> 2783 </span> : _DistanceType; -<span class="lineNum"> 2784 </span> : -<span class="lineNum"> 2785 </span> : // concept requirements -<span class="lineNum"> 2786 </span> : __glibcxx_function_requires(_Mutable_BidirectionalIteratorConcept< -<span class="lineNum"> 2787 </span> : _BidirectionalIterator>) -<span class="lineNum"> 2788 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 2789 </span> : __glibcxx_requires_sorted(__first, __middle); -<span class="lineNum"> 2790 </span> : __glibcxx_requires_sorted(__middle, __last); -<span class="lineNum"> 2791 </span> : -<span class="lineNum"> 2792 </span> : if (__first == __middle || __middle == __last) -<span class="lineNum"> 2793 </span> : return; -<span class="lineNum"> 2794 </span> : -<span class="lineNum"> 2795 </span> : _DistanceType __len1 = std::distance(__first, __middle); -<span class="lineNum"> 2796 </span> : _DistanceType __len2 = std::distance(__middle, __last); -<span class="lineNum"> 2797 </span> : -<span class="lineNum"> 2798 </span> : _Temporary_buffer<_BidirectionalIterator, _ValueType> __buf(__first, -<span class="lineNum"> 2799 </span> : __last); -<span class="lineNum"> 2800 </span> : if (__buf.begin() == 0) -<span class="lineNum"> 2801 </span> : std::__merge_without_buffer(__first, __middle, __last, __len1, __len2); -<span class="lineNum"> 2802 </span> : else -<span class="lineNum"> 2803 </span> : std::__merge_adaptive(__first, __middle, __last, __len1, __len2, -<span class="lineNum"> 2804 </span> : __buf.begin(), _DistanceType(__buf.size())); -<span class="lineNum"> 2805 </span> : } -<span class="lineNum"> 2806 </span> : -<span class="lineNum"> 2807 </span> : /** -<span class="lineNum"> 2808 </span> : * @brief Merges two sorted ranges in place. -<span class="lineNum"> 2809 </span> : * @param first An iterator. -<span class="lineNum"> 2810 </span> : * @param middle Another iterator. -<span class="lineNum"> 2811 </span> : * @param last Another iterator. -<span class="lineNum"> 2812 </span> : * @param comp A functor to use for comparisons. -<span class="lineNum"> 2813 </span> : * @return Nothing. -<span class="lineNum"> 2814 </span> : * -<span class="lineNum"> 2815 </span> : * Merges two sorted and consecutive ranges, [first,middle) and -<span class="lineNum"> 2816 </span> : * [middle,last), and puts the result in [first,last). The output will -<span class="lineNum"> 2817 </span> : * be sorted. The sort is @e stable, that is, for equivalent -<span class="lineNum"> 2818 </span> : * elements in the two ranges, elements from the first range will always -<span class="lineNum"> 2819 </span> : * come before elements from the second. -<span class="lineNum"> 2820 </span> : * -<span class="lineNum"> 2821 </span> : * If enough additional memory is available, this takes (last-first)-1 -<span class="lineNum"> 2822 </span> : * comparisons. Otherwise an NlogN algorithm is used, where N is -<span class="lineNum"> 2823 </span> : * distance(first,last). -<span class="lineNum"> 2824 </span> : * -<span class="lineNum"> 2825 </span> : * The comparison function should have the same effects on ordering as -<span class="lineNum"> 2826 </span> : * the function used for the initial sort. -<span class="lineNum"> 2827 </span> : */ -<span class="lineNum"> 2828 </span> : template<typename _BidirectionalIterator, typename _Compare> -<span class="lineNum"> 2829 </span> : void -<span class="lineNum"> 2830 </span> : inplace_merge(_BidirectionalIterator __first, -<span class="lineNum"> 2831 </span> : _BidirectionalIterator __middle, -<span class="lineNum"> 2832 </span> : _BidirectionalIterator __last, -<span class="lineNum"> 2833 </span> : _Compare __comp) -<span class="lineNum"> 2834 </span> : { -<span class="lineNum"> 2835 </span> : typedef typename iterator_traits<_BidirectionalIterator>::value_type -<span class="lineNum"> 2836 </span> : _ValueType; -<span class="lineNum"> 2837 </span> : typedef typename iterator_traits<_BidirectionalIterator>::difference_type -<span class="lineNum"> 2838 </span> : _DistanceType; -<span class="lineNum"> 2839 </span> : -<span class="lineNum"> 2840 </span> : // concept requirements -<span class="lineNum"> 2841 </span> : __glibcxx_function_requires(_Mutable_BidirectionalIteratorConcept< -<span class="lineNum"> 2842 </span> : _BidirectionalIterator>) -<span class="lineNum"> 2843 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 2844 </span> : _ValueType, _ValueType>) -<span class="lineNum"> 2845 </span> : __glibcxx_requires_sorted_pred(__first, __middle, __comp); -<span class="lineNum"> 2846 </span> : __glibcxx_requires_sorted_pred(__middle, __last, __comp); -<span class="lineNum"> 2847 </span> : -<span class="lineNum"> 2848 </span> : if (__first == __middle || __middle == __last) -<span class="lineNum"> 2849 </span> : return; -<span class="lineNum"> 2850 </span> : -<span class="lineNum"> 2851 </span> : const _DistanceType __len1 = std::distance(__first, __middle); -<span class="lineNum"> 2852 </span> : const _DistanceType __len2 = std::distance(__middle, __last); -<span class="lineNum"> 2853 </span> : -<span class="lineNum"> 2854 </span> : _Temporary_buffer<_BidirectionalIterator, _ValueType> __buf(__first, -<span class="lineNum"> 2855 </span> : __last); -<span class="lineNum"> 2856 </span> : if (__buf.begin() == 0) -<span class="lineNum"> 2857 </span> : std::__merge_without_buffer(__first, __middle, __last, __len1, -<span class="lineNum"> 2858 </span> : __len2, __comp); -<span class="lineNum"> 2859 </span> : else -<span class="lineNum"> 2860 </span> : std::__merge_adaptive(__first, __middle, __last, __len1, __len2, -<span class="lineNum"> 2861 </span> : __buf.begin(), _DistanceType(__buf.size()), -<span class="lineNum"> 2862 </span> : __comp); -<span class="lineNum"> 2863 </span> : } -<span class="lineNum"> 2864 </span> : -<span class="lineNum"> 2865 </span> : template<typename _RandomAccessIterator1, typename _RandomAccessIterator2, -<span class="lineNum"> 2866 </span> : typename _Distance> -<span class="lineNum"> 2867 </span> : void -<span class="lineNum"> 2868 </span> : __merge_sort_loop(_RandomAccessIterator1 __first, -<span class="lineNum"> 2869 </span> : _RandomAccessIterator1 __last, -<span class="lineNum"> 2870 </span> : _RandomAccessIterator2 __result, -<span class="lineNum"> 2871 </span> : _Distance __step_size) -<span class="lineNum"> 2872 </span> : { -<span class="lineNum"> 2873 </span> : const _Distance __two_step = 2 * __step_size; -<span class="lineNum"> 2874 </span> : -<span class="lineNum"> 2875 </span> : while (__last - __first >= __two_step) -<span class="lineNum"> 2876 </span> : { -<span class="lineNum"> 2877 </span> : __result = _GLIBCXX_STD_P::merge(__first, __first + __step_size, -<span class="lineNum"> 2878 </span> : __first + __step_size, -<span class="lineNum"> 2879 </span> : __first + __two_step, -<span class="lineNum"> 2880 </span> : __result); -<span class="lineNum"> 2881 </span> : __first += __two_step; -<span class="lineNum"> 2882 </span> : } -<span class="lineNum"> 2883 </span> : -<span class="lineNum"> 2884 </span> : __step_size = std::min(_Distance(__last - __first), __step_size); -<span class="lineNum"> 2885 </span> : _GLIBCXX_STD_P::merge(__first, __first + __step_size, -<span class="lineNum"> 2886 </span> : __first + __step_size, __last, -<span class="lineNum"> 2887 </span> : __result); -<span class="lineNum"> 2888 </span> : } -<span class="lineNum"> 2889 </span> : -<span class="lineNum"> 2890 </span> : template<typename _RandomAccessIterator1, typename _RandomAccessIterator2, -<span class="lineNum"> 2891 </span> : typename _Distance, typename _Compare> -<span class="lineNum"> 2892 </span> : void -<span class="lineNum"> 2893 </span> : __merge_sort_loop(_RandomAccessIterator1 __first, -<span class="lineNum"> 2894 </span> : _RandomAccessIterator1 __last, -<span class="lineNum"> 2895 </span> : _RandomAccessIterator2 __result, _Distance __step_size, -<span class="lineNum"> 2896 </span> : _Compare __comp) -<span class="lineNum"> 2897 </span> : { -<span class="lineNum"> 2898 </span> : const _Distance __two_step = 2 * __step_size; -<span class="lineNum"> 2899 </span> : -<span class="lineNum"> 2900 </span> : while (__last - __first >= __two_step) -<span class="lineNum"> 2901 </span> : { -<span class="lineNum"> 2902 </span> : __result = _GLIBCXX_STD_P::merge(__first, __first + __step_size, -<span class="lineNum"> 2903 </span> : __first + __step_size, __first + __two_step, -<span class="lineNum"> 2904 </span> : __result, -<span class="lineNum"> 2905 </span> : __comp); -<span class="lineNum"> 2906 </span> : __first += __two_step; -<span class="lineNum"> 2907 </span> : } -<span class="lineNum"> 2908 </span> : __step_size = std::min(_Distance(__last - __first), __step_size); -<span class="lineNum"> 2909 </span> : -<span class="lineNum"> 2910 </span> : _GLIBCXX_STD_P::merge(__first, __first + __step_size, -<span class="lineNum"> 2911 </span> : __first + __step_size, __last, __result, __comp); -<span class="lineNum"> 2912 </span> : } -<span class="lineNum"> 2913 </span> : -<span class="lineNum"> 2914 </span> : template<typename _RandomAccessIterator, typename _Distance> -<span class="lineNum"> 2915 </span> : void -<span class="lineNum"> 2916 </span> : __chunk_insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 2917 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 2918 </span> : _Distance __chunk_size) -<span class="lineNum"> 2919 </span> : { -<span class="lineNum"> 2920 </span> : while (__last - __first >= __chunk_size) -<span class="lineNum"> 2921 </span> : { -<span class="lineNum"> 2922 </span> : std::__insertion_sort(__first, __first + __chunk_size); -<span class="lineNum"> 2923 </span> : __first += __chunk_size; -<span class="lineNum"> 2924 </span> : } -<span class="lineNum"> 2925 </span> : std::__insertion_sort(__first, __last); -<span class="lineNum"> 2926 </span> : } -<span class="lineNum"> 2927 </span> : -<span class="lineNum"> 2928 </span> : template<typename _RandomAccessIterator, typename _Distance, -<span class="lineNum"> 2929 </span> : typename _Compare> -<span class="lineNum"> 2930 </span> : void -<span class="lineNum"> 2931 </span> : __chunk_insertion_sort(_RandomAccessIterator __first, -<span class="lineNum"> 2932 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 2933 </span> : _Distance __chunk_size, _Compare __comp) -<span class="lineNum"> 2934 </span> : { -<span class="lineNum"> 2935 </span> : while (__last - __first >= __chunk_size) -<span class="lineNum"> 2936 </span> : { -<span class="lineNum"> 2937 </span> : std::__insertion_sort(__first, __first + __chunk_size, __comp); -<span class="lineNum"> 2938 </span> : __first += __chunk_size; -<span class="lineNum"> 2939 </span> : } -<span class="lineNum"> 2940 </span> : std::__insertion_sort(__first, __last, __comp); -<span class="lineNum"> 2941 </span> : } -<span class="lineNum"> 2942 </span> : -<span class="lineNum"> 2943 </span> : enum { _S_chunk_size = 7 }; -<span class="lineNum"> 2944 </span> : -<span class="lineNum"> 2945 </span> : template<typename _RandomAccessIterator, typename _Pointer> -<span class="lineNum"> 2946 </span> : void -<span class="lineNum"> 2947 </span> : __merge_sort_with_buffer(_RandomAccessIterator __first, -<span class="lineNum"> 2948 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 2949 </span> : _Pointer __buffer) -<span class="lineNum"> 2950 </span> : { -<span class="lineNum"> 2951 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 2952 </span> : _Distance; -<span class="lineNum"> 2953 </span> : -<span class="lineNum"> 2954 </span> : const _Distance __len = __last - __first; -<span class="lineNum"> 2955 </span> : const _Pointer __buffer_last = __buffer + __len; -<span class="lineNum"> 2956 </span> : -<span class="lineNum"> 2957 </span> : _Distance __step_size = _S_chunk_size; -<span class="lineNum"> 2958 </span> : std::__chunk_insertion_sort(__first, __last, __step_size); -<span class="lineNum"> 2959 </span> : -<span class="lineNum"> 2960 </span> : while (__step_size < __len) -<span class="lineNum"> 2961 </span> : { -<span class="lineNum"> 2962 </span> : std::__merge_sort_loop(__first, __last, __buffer, __step_size); -<span class="lineNum"> 2963 </span> : __step_size *= 2; -<span class="lineNum"> 2964 </span> : std::__merge_sort_loop(__buffer, __buffer_last, __first, __step_size); -<span class="lineNum"> 2965 </span> : __step_size *= 2; -<span class="lineNum"> 2966 </span> : } -<span class="lineNum"> 2967 </span> : } -<span class="lineNum"> 2968 </span> : -<span class="lineNum"> 2969 </span> : template<typename _RandomAccessIterator, typename _Pointer, typename _Compare> -<span class="lineNum"> 2970 </span> : void -<span class="lineNum"> 2971 </span> : __merge_sort_with_buffer(_RandomAccessIterator __first, -<span class="lineNum"> 2972 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 2973 </span> : _Pointer __buffer, _Compare __comp) -<span class="lineNum"> 2974 </span> : { -<span class="lineNum"> 2975 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 2976 </span> : _Distance; -<span class="lineNum"> 2977 </span> : -<span class="lineNum"> 2978 </span> : const _Distance __len = __last - __first; -<span class="lineNum"> 2979 </span> : const _Pointer __buffer_last = __buffer + __len; -<span class="lineNum"> 2980 </span> : -<span class="lineNum"> 2981 </span> : _Distance __step_size = _S_chunk_size; -<span class="lineNum"> 2982 </span> : std::__chunk_insertion_sort(__first, __last, __step_size, __comp); -<span class="lineNum"> 2983 </span> : -<span class="lineNum"> 2984 </span> : while (__step_size < __len) -<span class="lineNum"> 2985 </span> : { -<span class="lineNum"> 2986 </span> : std::__merge_sort_loop(__first, __last, __buffer, -<span class="lineNum"> 2987 </span> : __step_size, __comp); -<span class="lineNum"> 2988 </span> : __step_size *= 2; -<span class="lineNum"> 2989 </span> : std::__merge_sort_loop(__buffer, __buffer_last, __first, -<span class="lineNum"> 2990 </span> : __step_size, __comp); -<span class="lineNum"> 2991 </span> : __step_size *= 2; -<span class="lineNum"> 2992 </span> : } -<span class="lineNum"> 2993 </span> : } -<span class="lineNum"> 2994 </span> : -<span class="lineNum"> 2995 </span> : template<typename _RandomAccessIterator, typename _Pointer, -<span class="lineNum"> 2996 </span> : typename _Distance> -<span class="lineNum"> 2997 </span> : void -<span class="lineNum"> 2998 </span> : __stable_sort_adaptive(_RandomAccessIterator __first, -<span class="lineNum"> 2999 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 3000 </span> : _Pointer __buffer, _Distance __buffer_size) -<span class="lineNum"> 3001 </span> : { -<span class="lineNum"> 3002 </span> : const _Distance __len = (__last - __first + 1) / 2; -<span class="lineNum"> 3003 </span> : const _RandomAccessIterator __middle = __first + __len; -<span class="lineNum"> 3004 </span> : if (__len > __buffer_size) -<span class="lineNum"> 3005 </span> : { -<span class="lineNum"> 3006 </span> : std::__stable_sort_adaptive(__first, __middle, -<span class="lineNum"> 3007 </span> : __buffer, __buffer_size); -<span class="lineNum"> 3008 </span> : std::__stable_sort_adaptive(__middle, __last, -<span class="lineNum"> 3009 </span> : __buffer, __buffer_size); -<span class="lineNum"> 3010 </span> : } -<span class="lineNum"> 3011 </span> : else -<span class="lineNum"> 3012 </span> : { -<span class="lineNum"> 3013 </span> : std::__merge_sort_with_buffer(__first, __middle, __buffer); -<span class="lineNum"> 3014 </span> : std::__merge_sort_with_buffer(__middle, __last, __buffer); -<span class="lineNum"> 3015 </span> : } -<span class="lineNum"> 3016 </span> : std::__merge_adaptive(__first, __middle, __last, -<span class="lineNum"> 3017 </span> : _Distance(__middle - __first), -<span class="lineNum"> 3018 </span> : _Distance(__last - __middle), -<span class="lineNum"> 3019 </span> : __buffer, __buffer_size); -<span class="lineNum"> 3020 </span> : } -<span class="lineNum"> 3021 </span> : -<span class="lineNum"> 3022 </span> : template<typename _RandomAccessIterator, typename _Pointer, -<span class="lineNum"> 3023 </span> : typename _Distance, typename _Compare> -<span class="lineNum"> 3024 </span> : void -<span class="lineNum"> 3025 </span> : __stable_sort_adaptive(_RandomAccessIterator __first, -<span class="lineNum"> 3026 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 3027 </span> : _Pointer __buffer, _Distance __buffer_size, -<span class="lineNum"> 3028 </span> : _Compare __comp) -<span class="lineNum"> 3029 </span> : { -<span class="lineNum"> 3030 </span> : const _Distance __len = (__last - __first + 1) / 2; -<span class="lineNum"> 3031 </span> : const _RandomAccessIterator __middle = __first + __len; -<span class="lineNum"> 3032 </span> : if (__len > __buffer_size) -<span class="lineNum"> 3033 </span> : { -<span class="lineNum"> 3034 </span> : std::__stable_sort_adaptive(__first, __middle, __buffer, -<span class="lineNum"> 3035 </span> : __buffer_size, __comp); -<span class="lineNum"> 3036 </span> : std::__stable_sort_adaptive(__middle, __last, __buffer, -<span class="lineNum"> 3037 </span> : __buffer_size, __comp); -<span class="lineNum"> 3038 </span> : } -<span class="lineNum"> 3039 </span> : else -<span class="lineNum"> 3040 </span> : { -<span class="lineNum"> 3041 </span> : std::__merge_sort_with_buffer(__first, __middle, __buffer, __comp); -<span class="lineNum"> 3042 </span> : std::__merge_sort_with_buffer(__middle, __last, __buffer, __comp); -<span class="lineNum"> 3043 </span> : } -<span class="lineNum"> 3044 </span> : std::__merge_adaptive(__first, __middle, __last, -<span class="lineNum"> 3045 </span> : _Distance(__middle - __first), -<span class="lineNum"> 3046 </span> : _Distance(__last - __middle), -<span class="lineNum"> 3047 </span> : __buffer, __buffer_size, -<span class="lineNum"> 3048 </span> : __comp); -<span class="lineNum"> 3049 </span> : } -<span class="lineNum"> 3050 </span> : -<span class="lineNum"> 3051 </span> : /// This is a helper function for the stable sorting routines. -<span class="lineNum"> 3052 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 3053 </span> : void -<span class="lineNum"> 3054 </span> : __inplace_stable_sort(_RandomAccessIterator __first, -<span class="lineNum"> 3055 </span> : _RandomAccessIterator __last) -<span class="lineNum"> 3056 </span> : { -<span class="lineNum"> 3057 </span> : if (__last - __first < 15) -<span class="lineNum"> 3058 </span> : { -<span class="lineNum"> 3059 </span> : std::__insertion_sort(__first, __last); -<span class="lineNum"> 3060 </span> : return; -<span class="lineNum"> 3061 </span> : } -<span class="lineNum"> 3062 </span> : _RandomAccessIterator __middle = __first + (__last - __first) / 2; -<span class="lineNum"> 3063 </span> : std::__inplace_stable_sort(__first, __middle); -<span class="lineNum"> 3064 </span> : std::__inplace_stable_sort(__middle, __last); -<span class="lineNum"> 3065 </span> : std::__merge_without_buffer(__first, __middle, __last, -<span class="lineNum"> 3066 </span> : __middle - __first, -<span class="lineNum"> 3067 </span> : __last - __middle); -<span class="lineNum"> 3068 </span> : } -<span class="lineNum"> 3069 </span> : -<span class="lineNum"> 3070 </span> : /// This is a helper function for the stable sorting routines. -<span class="lineNum"> 3071 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 3072 </span> : void -<span class="lineNum"> 3073 </span> : __inplace_stable_sort(_RandomAccessIterator __first, -<span class="lineNum"> 3074 </span> : _RandomAccessIterator __last, _Compare __comp) -<span class="lineNum"> 3075 </span> : { -<span class="lineNum"> 3076 </span> : if (__last - __first < 15) -<span class="lineNum"> 3077 </span> : { -<span class="lineNum"> 3078 </span> : std::__insertion_sort(__first, __last, __comp); -<span class="lineNum"> 3079 </span> : return; -<span class="lineNum"> 3080 </span> : } -<span class="lineNum"> 3081 </span> : _RandomAccessIterator __middle = __first + (__last - __first) / 2; -<span class="lineNum"> 3082 </span> : std::__inplace_stable_sort(__first, __middle, __comp); -<span class="lineNum"> 3083 </span> : std::__inplace_stable_sort(__middle, __last, __comp); -<span class="lineNum"> 3084 </span> : std::__merge_without_buffer(__first, __middle, __last, -<span class="lineNum"> 3085 </span> : __middle - __first, -<span class="lineNum"> 3086 </span> : __last - __middle, -<span class="lineNum"> 3087 </span> : __comp); -<span class="lineNum"> 3088 </span> : } -<span class="lineNum"> 3089 </span> : -<span class="lineNum"> 3090 </span> : // stable_sort -<span class="lineNum"> 3091 </span> : -<span class="lineNum"> 3092 </span> : // Set algorithms: includes, set_union, set_intersection, set_difference, -<span class="lineNum"> 3093 </span> : // set_symmetric_difference. All of these algorithms have the precondition -<span class="lineNum"> 3094 </span> : // that their input ranges are sorted and the postcondition that their output -<span class="lineNum"> 3095 </span> : // ranges are sorted. -<span class="lineNum"> 3096 </span> : -<span class="lineNum"> 3097 </span> : /** -<span class="lineNum"> 3098 </span> : * @brief Determines whether all elements of a sequence exists in a range. -<span class="lineNum"> 3099 </span> : * @param first1 Start of search range. -<span class="lineNum"> 3100 </span> : * @param last1 End of search range. -<span class="lineNum"> 3101 </span> : * @param first2 Start of sequence -<span class="lineNum"> 3102 </span> : * @param last2 End of sequence. -<span class="lineNum"> 3103 </span> : * @return True if each element in [first2,last2) is contained in order -<span class="lineNum"> 3104 </span> : * within [first1,last1). False otherwise. -<span class="lineNum"> 3105 </span> : * @ingroup setoperations -<span class="lineNum"> 3106 </span> : * -<span class="lineNum"> 3107 </span> : * This operation expects both [first1,last1) and [first2,last2) to be -<span class="lineNum"> 3108 </span> : * sorted. Searches for the presence of each element in [first2,last2) -<span class="lineNum"> 3109 </span> : * within [first1,last1). The iterators over each range only move forward, -<span class="lineNum"> 3110 </span> : * so this is a linear algorithm. If an element in [first2,last2) is not -<span class="lineNum"> 3111 </span> : * found before the search iterator reaches @a last2, false is returned. -<span class="lineNum"> 3112 </span> : */ -<span class="lineNum"> 3113 </span> : template<typename _InputIterator1, typename _InputIterator2> -<span class="lineNum"> 3114 </span> : bool -<span class="lineNum"> 3115 </span> : includes(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 3116 </span> : _InputIterator2 __first2, _InputIterator2 __last2) -<span class="lineNum"> 3117 </span> : { -<span class="lineNum"> 3118 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 3119 </span> : _ValueType1; -<span class="lineNum"> 3120 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 3121 </span> : _ValueType2; -<span class="lineNum"> 3122 </span> : -<span class="lineNum"> 3123 </span> : // concept requirements -<span class="lineNum"> 3124 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 3125 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 3126 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType1, _ValueType2>) -<span class="lineNum"> 3127 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 3128 </span> : __glibcxx_requires_sorted_set(__first1, __last1, __first2); -<span class="lineNum"> 3129 </span> : __glibcxx_requires_sorted_set(__first2, __last2, __first1); -<span class="lineNum"> 3130 </span> : -<span class="lineNum"> 3131 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 3132 </span> : if (*__first2 < *__first1) -<span class="lineNum"> 3133 </span> : return false; -<span class="lineNum"> 3134 </span> : else if(*__first1 < *__first2) -<span class="lineNum"> 3135 </span> : ++__first1; -<span class="lineNum"> 3136 </span> : else -<span class="lineNum"> 3137 </span> : ++__first1, ++__first2; -<span class="lineNum"> 3138 </span> : -<span class="lineNum"> 3139 </span> : return __first2 == __last2; -<span class="lineNum"> 3140 </span> : } -<span class="lineNum"> 3141 </span> : -<span class="lineNum"> 3142 </span> : /** -<span class="lineNum"> 3143 </span> : * @brief Determines whether all elements of a sequence exists in a range -<span class="lineNum"> 3144 </span> : * using comparison. -<span class="lineNum"> 3145 </span> : * @param first1 Start of search range. -<span class="lineNum"> 3146 </span> : * @param last1 End of search range. -<span class="lineNum"> 3147 </span> : * @param first2 Start of sequence -<span class="lineNum"> 3148 </span> : * @param last2 End of sequence. -<span class="lineNum"> 3149 </span> : * @param comp Comparison function to use. -<span class="lineNum"> 3150 </span> : * @return True if each element in [first2,last2) is contained in order -<span class="lineNum"> 3151 </span> : * within [first1,last1) according to comp. False otherwise. -<span class="lineNum"> 3152 </span> : * @ingroup setoperations -<span class="lineNum"> 3153 </span> : * -<span class="lineNum"> 3154 </span> : * This operation expects both [first1,last1) and [first2,last2) to be -<span class="lineNum"> 3155 </span> : * sorted. Searches for the presence of each element in [first2,last2) -<span class="lineNum"> 3156 </span> : * within [first1,last1), using comp to decide. The iterators over each -<span class="lineNum"> 3157 </span> : * range only move forward, so this is a linear algorithm. If an element -<span class="lineNum"> 3158 </span> : * in [first2,last2) is not found before the search iterator reaches @a -<span class="lineNum"> 3159 </span> : * last2, false is returned. -<span class="lineNum"> 3160 </span> : */ -<span class="lineNum"> 3161 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 3162 </span> : typename _Compare> -<span class="lineNum"> 3163 </span> : bool -<span class="lineNum"> 3164 </span> : includes(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 3165 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 3166 </span> : _Compare __comp) -<span class="lineNum"> 3167 </span> : { -<span class="lineNum"> 3168 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 3169 </span> : _ValueType1; -<span class="lineNum"> 3170 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 3171 </span> : _ValueType2; -<span class="lineNum"> 3172 </span> : -<span class="lineNum"> 3173 </span> : // concept requirements -<span class="lineNum"> 3174 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 3175 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 3176 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 3177 </span> : _ValueType1, _ValueType2>) -<span class="lineNum"> 3178 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 3179 </span> : _ValueType2, _ValueType1>) -<span class="lineNum"> 3180 </span> : __glibcxx_requires_sorted_set_pred(__first1, __last1, __first2, __comp); -<span class="lineNum"> 3181 </span> : __glibcxx_requires_sorted_set_pred(__first2, __last2, __first1, __comp); -<span class="lineNum"> 3182 </span> : -<span class="lineNum"> 3183 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 3184 </span> : if (__comp(*__first2, *__first1)) -<span class="lineNum"> 3185 </span> : return false; -<span class="lineNum"> 3186 </span> : else if(__comp(*__first1, *__first2)) -<span class="lineNum"> 3187 </span> : ++__first1; -<span class="lineNum"> 3188 </span> : else -<span class="lineNum"> 3189 </span> : ++__first1, ++__first2; -<span class="lineNum"> 3190 </span> : -<span class="lineNum"> 3191 </span> : return __first2 == __last2; -<span class="lineNum"> 3192 </span> : } -<span class="lineNum"> 3193 </span> : -<span class="lineNum"> 3194 </span> : // nth_element -<span class="lineNum"> 3195 </span> : // merge -<span class="lineNum"> 3196 </span> : // set_difference -<span class="lineNum"> 3197 </span> : // set_intersection -<span class="lineNum"> 3198 </span> : // set_union -<span class="lineNum"> 3199 </span> : // stable_sort -<span class="lineNum"> 3200 </span> : // set_symmetric_difference -<span class="lineNum"> 3201 </span> : // min_element -<span class="lineNum"> 3202 </span> : // max_element -<span class="lineNum"> 3203 </span> : -<span class="lineNum"> 3204 </span> : /** -<span class="lineNum"> 3205 </span> : * @brief Permute range into the next "dictionary" ordering. -<span class="lineNum"> 3206 </span> : * @param first Start of range. -<span class="lineNum"> 3207 </span> : * @param last End of range. -<span class="lineNum"> 3208 </span> : * @return False if wrapped to first permutation, true otherwise. -<span class="lineNum"> 3209 </span> : * -<span class="lineNum"> 3210 </span> : * Treats all permutations of the range as a set of "dictionary" sorted -<span class="lineNum"> 3211 </span> : * sequences. Permutes the current sequence into the next one of this set. -<span class="lineNum"> 3212 </span> : * Returns true if there are more sequences to generate. If the sequence -<span class="lineNum"> 3213 </span> : * is the largest of the set, the smallest is generated and false returned. -<span class="lineNum"> 3214 </span> : */ -<span class="lineNum"> 3215 </span> : template<typename _BidirectionalIterator> -<span class="lineNum"> 3216 </span> : bool -<span class="lineNum"> 3217 </span> : next_permutation(_BidirectionalIterator __first, -<span class="lineNum"> 3218 </span> : _BidirectionalIterator __last) -<span class="lineNum"> 3219 </span> : { -<span class="lineNum"> 3220 </span> : // concept requirements -<span class="lineNum"> 3221 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 3222 </span> : _BidirectionalIterator>) -<span class="lineNum"> 3223 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 3224 </span> : typename iterator_traits<_BidirectionalIterator>::value_type>) -<span class="lineNum"> 3225 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3226 </span> : -<span class="lineNum"> 3227 </span> : if (__first == __last) -<span class="lineNum"> 3228 </span> : return false; -<span class="lineNum"> 3229 </span> : _BidirectionalIterator __i = __first; -<span class="lineNum"> 3230 </span> : ++__i; -<span class="lineNum"> 3231 </span> : if (__i == __last) -<span class="lineNum"> 3232 </span> : return false; -<span class="lineNum"> 3233 </span> : __i = __last; -<span class="lineNum"> 3234 </span> : --__i; -<span class="lineNum"> 3235 </span> : -<span class="lineNum"> 3236 </span> : for(;;) -<span class="lineNum"> 3237 </span> : { -<span class="lineNum"> 3238 </span> : _BidirectionalIterator __ii = __i; -<span class="lineNum"> 3239 </span> : --__i; -<span class="lineNum"> 3240 </span> : if (*__i < *__ii) -<span class="lineNum"> 3241 </span> : { -<span class="lineNum"> 3242 </span> : _BidirectionalIterator __j = __last; -<span class="lineNum"> 3243 </span> : while (!(*__i < *--__j)) -<span class="lineNum"> 3244 </span> : {} -<span class="lineNum"> 3245 </span> : std::iter_swap(__i, __j); -<span class="lineNum"> 3246 </span> : std::reverse(__ii, __last); -<span class="lineNum"> 3247 </span> : return true; -<span class="lineNum"> 3248 </span> : } -<span class="lineNum"> 3249 </span> : if (__i == __first) -<span class="lineNum"> 3250 </span> : { -<span class="lineNum"> 3251 </span> : std::reverse(__first, __last); -<span class="lineNum"> 3252 </span> : return false; -<span class="lineNum"> 3253 </span> : } -<span class="lineNum"> 3254 </span> : } -<span class="lineNum"> 3255 </span> : } -<span class="lineNum"> 3256 </span> : -<span class="lineNum"> 3257 </span> : /** -<span class="lineNum"> 3258 </span> : * @brief Permute range into the next "dictionary" ordering using -<span class="lineNum"> 3259 </span> : * comparison functor. -<span class="lineNum"> 3260 </span> : * @param first Start of range. -<span class="lineNum"> 3261 </span> : * @param last End of range. -<span class="lineNum"> 3262 </span> : * @param comp A comparison functor. -<span class="lineNum"> 3263 </span> : * @return False if wrapped to first permutation, true otherwise. -<span class="lineNum"> 3264 </span> : * -<span class="lineNum"> 3265 </span> : * Treats all permutations of the range [first,last) as a set of -<span class="lineNum"> 3266 </span> : * "dictionary" sorted sequences ordered by @a comp. Permutes the current -<span class="lineNum"> 3267 </span> : * sequence into the next one of this set. Returns true if there are more -<span class="lineNum"> 3268 </span> : * sequences to generate. If the sequence is the largest of the set, the -<span class="lineNum"> 3269 </span> : * smallest is generated and false returned. -<span class="lineNum"> 3270 </span> : */ -<span class="lineNum"> 3271 </span> : template<typename _BidirectionalIterator, typename _Compare> -<span class="lineNum"> 3272 </span> : bool -<span class="lineNum"> 3273 </span> : next_permutation(_BidirectionalIterator __first, -<span class="lineNum"> 3274 </span> : _BidirectionalIterator __last, _Compare __comp) -<span class="lineNum"> 3275 </span> : { -<span class="lineNum"> 3276 </span> : // concept requirements -<span class="lineNum"> 3277 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 3278 </span> : _BidirectionalIterator>) -<span class="lineNum"> 3279 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 3280 </span> : typename iterator_traits<_BidirectionalIterator>::value_type, -<span class="lineNum"> 3281 </span> : typename iterator_traits<_BidirectionalIterator>::value_type>) -<span class="lineNum"> 3282 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3283 </span> : -<span class="lineNum"> 3284 </span> : if (__first == __last) -<span class="lineNum"> 3285 </span> : return false; -<span class="lineNum"> 3286 </span> : _BidirectionalIterator __i = __first; -<span class="lineNum"> 3287 </span> : ++__i; -<span class="lineNum"> 3288 </span> : if (__i == __last) -<span class="lineNum"> 3289 </span> : return false; -<span class="lineNum"> 3290 </span> : __i = __last; -<span class="lineNum"> 3291 </span> : --__i; -<span class="lineNum"> 3292 </span> : -<span class="lineNum"> 3293 </span> : for(;;) -<span class="lineNum"> 3294 </span> : { -<span class="lineNum"> 3295 </span> : _BidirectionalIterator __ii = __i; -<span class="lineNum"> 3296 </span> : --__i; -<span class="lineNum"> 3297 </span> : if (__comp(*__i, *__ii)) -<span class="lineNum"> 3298 </span> : { -<span class="lineNum"> 3299 </span> : _BidirectionalIterator __j = __last; -<span class="lineNum"> 3300 </span> : while (!bool(__comp(*__i, *--__j))) -<span class="lineNum"> 3301 </span> : {} -<span class="lineNum"> 3302 </span> : std::iter_swap(__i, __j); -<span class="lineNum"> 3303 </span> : std::reverse(__ii, __last); -<span class="lineNum"> 3304 </span> : return true; -<span class="lineNum"> 3305 </span> : } -<span class="lineNum"> 3306 </span> : if (__i == __first) -<span class="lineNum"> 3307 </span> : { -<span class="lineNum"> 3308 </span> : std::reverse(__first, __last); -<span class="lineNum"> 3309 </span> : return false; -<span class="lineNum"> 3310 </span> : } -<span class="lineNum"> 3311 </span> : } -<span class="lineNum"> 3312 </span> : } -<span class="lineNum"> 3313 </span> : -<span class="lineNum"> 3314 </span> : /** -<span class="lineNum"> 3315 </span> : * @brief Permute range into the previous "dictionary" ordering. -<span class="lineNum"> 3316 </span> : * @param first Start of range. -<span class="lineNum"> 3317 </span> : * @param last End of range. -<span class="lineNum"> 3318 </span> : * @return False if wrapped to last permutation, true otherwise. -<span class="lineNum"> 3319 </span> : * -<span class="lineNum"> 3320 </span> : * Treats all permutations of the range as a set of "dictionary" sorted -<span class="lineNum"> 3321 </span> : * sequences. Permutes the current sequence into the previous one of this -<span class="lineNum"> 3322 </span> : * set. Returns true if there are more sequences to generate. If the -<span class="lineNum"> 3323 </span> : * sequence is the smallest of the set, the largest is generated and false -<span class="lineNum"> 3324 </span> : * returned. -<span class="lineNum"> 3325 </span> : */ -<span class="lineNum"> 3326 </span> : template<typename _BidirectionalIterator> -<span class="lineNum"> 3327 </span> : bool -<span class="lineNum"> 3328 </span> : prev_permutation(_BidirectionalIterator __first, -<span class="lineNum"> 3329 </span> : _BidirectionalIterator __last) -<span class="lineNum"> 3330 </span> : { -<span class="lineNum"> 3331 </span> : // concept requirements -<span class="lineNum"> 3332 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 3333 </span> : _BidirectionalIterator>) -<span class="lineNum"> 3334 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 3335 </span> : typename iterator_traits<_BidirectionalIterator>::value_type>) -<span class="lineNum"> 3336 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3337 </span> : -<span class="lineNum"> 3338 </span> : if (__first == __last) -<span class="lineNum"> 3339 </span> : return false; -<span class="lineNum"> 3340 </span> : _BidirectionalIterator __i = __first; -<span class="lineNum"> 3341 </span> : ++__i; -<span class="lineNum"> 3342 </span> : if (__i == __last) -<span class="lineNum"> 3343 </span> : return false; -<span class="lineNum"> 3344 </span> : __i = __last; -<span class="lineNum"> 3345 </span> : --__i; -<span class="lineNum"> 3346 </span> : -<span class="lineNum"> 3347 </span> : for(;;) -<span class="lineNum"> 3348 </span> : { -<span class="lineNum"> 3349 </span> : _BidirectionalIterator __ii = __i; -<span class="lineNum"> 3350 </span> : --__i; -<span class="lineNum"> 3351 </span> : if (*__ii < *__i) -<span class="lineNum"> 3352 </span> : { -<span class="lineNum"> 3353 </span> : _BidirectionalIterator __j = __last; -<span class="lineNum"> 3354 </span> : while (!(*--__j < *__i)) -<span class="lineNum"> 3355 </span> : {} -<span class="lineNum"> 3356 </span> : std::iter_swap(__i, __j); -<span class="lineNum"> 3357 </span> : std::reverse(__ii, __last); -<span class="lineNum"> 3358 </span> : return true; -<span class="lineNum"> 3359 </span> : } -<span class="lineNum"> 3360 </span> : if (__i == __first) -<span class="lineNum"> 3361 </span> : { -<span class="lineNum"> 3362 </span> : std::reverse(__first, __last); -<span class="lineNum"> 3363 </span> : return false; -<span class="lineNum"> 3364 </span> : } -<span class="lineNum"> 3365 </span> : } -<span class="lineNum"> 3366 </span> : } -<span class="lineNum"> 3367 </span> : -<span class="lineNum"> 3368 </span> : /** -<span class="lineNum"> 3369 </span> : * @brief Permute range into the previous "dictionary" ordering using -<span class="lineNum"> 3370 </span> : * comparison functor. -<span class="lineNum"> 3371 </span> : * @param first Start of range. -<span class="lineNum"> 3372 </span> : * @param last End of range. -<span class="lineNum"> 3373 </span> : * @param comp A comparison functor. -<span class="lineNum"> 3374 </span> : * @return False if wrapped to last permutation, true otherwise. -<span class="lineNum"> 3375 </span> : * -<span class="lineNum"> 3376 </span> : * Treats all permutations of the range [first,last) as a set of -<span class="lineNum"> 3377 </span> : * "dictionary" sorted sequences ordered by @a comp. Permutes the current -<span class="lineNum"> 3378 </span> : * sequence into the previous one of this set. Returns true if there are -<span class="lineNum"> 3379 </span> : * more sequences to generate. If the sequence is the smallest of the set, -<span class="lineNum"> 3380 </span> : * the largest is generated and false returned. -<span class="lineNum"> 3381 </span> : */ -<span class="lineNum"> 3382 </span> : template<typename _BidirectionalIterator, typename _Compare> -<span class="lineNum"> 3383 </span> : bool -<span class="lineNum"> 3384 </span> : prev_permutation(_BidirectionalIterator __first, -<span class="lineNum"> 3385 </span> : _BidirectionalIterator __last, _Compare __comp) -<span class="lineNum"> 3386 </span> : { -<span class="lineNum"> 3387 </span> : // concept requirements -<span class="lineNum"> 3388 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 3389 </span> : _BidirectionalIterator>) -<span class="lineNum"> 3390 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 3391 </span> : typename iterator_traits<_BidirectionalIterator>::value_type, -<span class="lineNum"> 3392 </span> : typename iterator_traits<_BidirectionalIterator>::value_type>) -<span class="lineNum"> 3393 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3394 </span> : -<span class="lineNum"> 3395 </span> : if (__first == __last) -<span class="lineNum"> 3396 </span> : return false; -<span class="lineNum"> 3397 </span> : _BidirectionalIterator __i = __first; -<span class="lineNum"> 3398 </span> : ++__i; -<span class="lineNum"> 3399 </span> : if (__i == __last) -<span class="lineNum"> 3400 </span> : return false; -<span class="lineNum"> 3401 </span> : __i = __last; -<span class="lineNum"> 3402 </span> : --__i; -<span class="lineNum"> 3403 </span> : -<span class="lineNum"> 3404 </span> : for(;;) -<span class="lineNum"> 3405 </span> : { -<span class="lineNum"> 3406 </span> : _BidirectionalIterator __ii = __i; -<span class="lineNum"> 3407 </span> : --__i; -<span class="lineNum"> 3408 </span> : if (__comp(*__ii, *__i)) -<span class="lineNum"> 3409 </span> : { -<span class="lineNum"> 3410 </span> : _BidirectionalIterator __j = __last; -<span class="lineNum"> 3411 </span> : while (!bool(__comp(*--__j, *__i))) -<span class="lineNum"> 3412 </span> : {} -<span class="lineNum"> 3413 </span> : std::iter_swap(__i, __j); -<span class="lineNum"> 3414 </span> : std::reverse(__ii, __last); -<span class="lineNum"> 3415 </span> : return true; -<span class="lineNum"> 3416 </span> : } -<span class="lineNum"> 3417 </span> : if (__i == __first) -<span class="lineNum"> 3418 </span> : { -<span class="lineNum"> 3419 </span> : std::reverse(__first, __last); -<span class="lineNum"> 3420 </span> : return false; -<span class="lineNum"> 3421 </span> : } -<span class="lineNum"> 3422 </span> : } -<span class="lineNum"> 3423 </span> : } -<span class="lineNum"> 3424 </span> : -<span class="lineNum"> 3425 </span> : // replace -<span class="lineNum"> 3426 </span> : // replace_if -<span class="lineNum"> 3427 </span> : -<span class="lineNum"> 3428 </span> : /** -<span class="lineNum"> 3429 </span> : * @brief Copy a sequence, replacing each element of one value with another -<span class="lineNum"> 3430 </span> : * value. -<span class="lineNum"> 3431 </span> : * @param first An input iterator. -<span class="lineNum"> 3432 </span> : * @param last An input iterator. -<span class="lineNum"> 3433 </span> : * @param result An output iterator. -<span class="lineNum"> 3434 </span> : * @param old_value The value to be replaced. -<span class="lineNum"> 3435 </span> : * @param new_value The replacement value. -<span class="lineNum"> 3436 </span> : * @return The end of the output sequence, @p result+(last-first). -<span class="lineNum"> 3437 </span> : * -<span class="lineNum"> 3438 </span> : * Copies each element in the input range @p [first,last) to the -<span class="lineNum"> 3439 </span> : * output range @p [result,result+(last-first)) replacing elements -<span class="lineNum"> 3440 </span> : * equal to @p old_value with @p new_value. -<span class="lineNum"> 3441 </span> : */ -<span class="lineNum"> 3442 </span> : template<typename _InputIterator, typename _OutputIterator, typename _Tp> -<span class="lineNum"> 3443 </span> : _OutputIterator -<span class="lineNum"> 3444 </span> : replace_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 3445 </span> : _OutputIterator __result, -<span class="lineNum"> 3446 </span> : const _Tp& __old_value, const _Tp& __new_value) -<span class="lineNum"> 3447 </span> : { -<span class="lineNum"> 3448 </span> : // concept requirements -<span class="lineNum"> 3449 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3450 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 3451 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 3452 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 3453 </span> : typename iterator_traits<_InputIterator>::value_type, _Tp>) -<span class="lineNum"> 3454 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3455 </span> : -<span class="lineNum"> 3456 </span> : for (; __first != __last; ++__first, ++__result) -<span class="lineNum"> 3457 </span> : if (*__first == __old_value) -<span class="lineNum"> 3458 </span> : *__result = __new_value; -<span class="lineNum"> 3459 </span> : else -<span class="lineNum"> 3460 </span> : *__result = *__first; -<span class="lineNum"> 3461 </span> : return __result; -<span class="lineNum"> 3462 </span> : } -<span class="lineNum"> 3463 </span> : -<span class="lineNum"> 3464 </span> : /** -<span class="lineNum"> 3465 </span> : * @brief Copy a sequence, replacing each value for which a predicate -<span class="lineNum"> 3466 </span> : * returns true with another value. -<span class="lineNum"> 3467 </span> : * @param first An input iterator. -<span class="lineNum"> 3468 </span> : * @param last An input iterator. -<span class="lineNum"> 3469 </span> : * @param result An output iterator. -<span class="lineNum"> 3470 </span> : * @param pred A predicate. -<span class="lineNum"> 3471 </span> : * @param new_value The replacement value. -<span class="lineNum"> 3472 </span> : * @return The end of the output sequence, @p result+(last-first). -<span class="lineNum"> 3473 </span> : * -<span class="lineNum"> 3474 </span> : * Copies each element in the range @p [first,last) to the range -<span class="lineNum"> 3475 </span> : * @p [result,result+(last-first)) replacing elements for which -<span class="lineNum"> 3476 </span> : * @p pred returns true with @p new_value. -<span class="lineNum"> 3477 </span> : */ -<span class="lineNum"> 3478 </span> : template<typename _InputIterator, typename _OutputIterator, -<span class="lineNum"> 3479 </span> : typename _Predicate, typename _Tp> -<span class="lineNum"> 3480 </span> : _OutputIterator -<span class="lineNum"> 3481 </span> : replace_copy_if(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 3482 </span> : _OutputIterator __result, -<span class="lineNum"> 3483 </span> : _Predicate __pred, const _Tp& __new_value) -<span class="lineNum"> 3484 </span> : { -<span class="lineNum"> 3485 </span> : // concept requirements -<span class="lineNum"> 3486 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3487 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 3488 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 3489 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 3490 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 3491 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3492 </span> : -<span class="lineNum"> 3493 </span> : for (; __first != __last; ++__first, ++__result) -<span class="lineNum"> 3494 </span> : if (__pred(*__first)) -<span class="lineNum"> 3495 </span> : *__result = __new_value; -<span class="lineNum"> 3496 </span> : else -<span class="lineNum"> 3497 </span> : *__result = *__first; -<span class="lineNum"> 3498 </span> : return __result; -<span class="lineNum"> 3499 </span> : } -<span class="lineNum"> 3500 </span> : -<span class="lineNum"> 3501 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 3502 </span> : /** -<span class="lineNum"> 3503 </span> : * @brief Determines whether the elements of a sequence are sorted. -<span class="lineNum"> 3504 </span> : * @param first An iterator. -<span class="lineNum"> 3505 </span> : * @param last Another iterator. -<span class="lineNum"> 3506 </span> : * @return True if the elements are sorted, false otherwise. -<span class="lineNum"> 3507 </span> : */ -<span class="lineNum"> 3508 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 3509 </span> : inline bool -<span class="lineNum"> 3510 </span> : is_sorted(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 3511 </span> : { return std::is_sorted_until(__first, __last) == __last; } -<span class="lineNum"> 3512 </span> : -<span class="lineNum"> 3513 </span> : /** -<span class="lineNum"> 3514 </span> : * @brief Determines whether the elements of a sequence are sorted -<span class="lineNum"> 3515 </span> : * according to a comparison functor. -<span class="lineNum"> 3516 </span> : * @param first An iterator. -<span class="lineNum"> 3517 </span> : * @param last Another iterator. -<span class="lineNum"> 3518 </span> : * @param comp A comparison functor. -<span class="lineNum"> 3519 </span> : * @return True if the elements are sorted, false otherwise. -<span class="lineNum"> 3520 </span> : */ -<span class="lineNum"> 3521 </span> : template<typename _ForwardIterator, typename _Compare> -<span class="lineNum"> 3522 </span> : inline bool -<span class="lineNum"> 3523 </span> : is_sorted(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 3524 </span> : _Compare __comp) -<span class="lineNum"> 3525 </span> : { return std::is_sorted_until(__first, __last, __comp) == __last; } -<span class="lineNum"> 3526 </span> : -<span class="lineNum"> 3527 </span> : /** -<span class="lineNum"> 3528 </span> : * @brief Determines the end of a sorted sequence. -<span class="lineNum"> 3529 </span> : * @param first An iterator. -<span class="lineNum"> 3530 </span> : * @param last Another iterator. -<span class="lineNum"> 3531 </span> : * @return An iterator pointing to the last iterator i in [first, last) -<span class="lineNum"> 3532 </span> : * for which the range [first, i) is sorted. -<span class="lineNum"> 3533 </span> : */ -<span class="lineNum"> 3534 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 3535 </span> : _ForwardIterator -<span class="lineNum"> 3536 </span> : is_sorted_until(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 3537 </span> : { -<span class="lineNum"> 3538 </span> : // concept requirements -<span class="lineNum"> 3539 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3540 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 3541 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3542 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3543 </span> : -<span class="lineNum"> 3544 </span> : if (__first == __last) -<span class="lineNum"> 3545 </span> : return __last; -<span class="lineNum"> 3546 </span> : -<span class="lineNum"> 3547 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 3548 </span> : for (++__next; __next != __last; __first = __next, ++__next) -<span class="lineNum"> 3549 </span> : if (*__next < *__first) -<span class="lineNum"> 3550 </span> : return __next; -<span class="lineNum"> 3551 </span> : return __next; -<span class="lineNum"> 3552 </span> : } -<span class="lineNum"> 3553 </span> : -<span class="lineNum"> 3554 </span> : /** -<span class="lineNum"> 3555 </span> : * @brief Determines the end of a sorted sequence using comparison functor. -<span class="lineNum"> 3556 </span> : * @param first An iterator. -<span class="lineNum"> 3557 </span> : * @param last Another iterator. -<span class="lineNum"> 3558 </span> : * @param comp A comparison functor. -<span class="lineNum"> 3559 </span> : * @return An iterator pointing to the last iterator i in [first, last) -<span class="lineNum"> 3560 </span> : * for which the range [first, i) is sorted. -<span class="lineNum"> 3561 </span> : */ -<span class="lineNum"> 3562 </span> : template<typename _ForwardIterator, typename _Compare> -<span class="lineNum"> 3563 </span> : _ForwardIterator -<span class="lineNum"> 3564 </span> : is_sorted_until(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 3565 </span> : _Compare __comp) -<span class="lineNum"> 3566 </span> : { -<span class="lineNum"> 3567 </span> : // concept requirements -<span class="lineNum"> 3568 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3569 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 3570 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 3571 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3572 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3573 </span> : -<span class="lineNum"> 3574 </span> : if (__first == __last) -<span class="lineNum"> 3575 </span> : return __last; -<span class="lineNum"> 3576 </span> : -<span class="lineNum"> 3577 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 3578 </span> : for (++__next; __next != __last; __first = __next, ++__next) -<span class="lineNum"> 3579 </span> : if (__comp(*__next, *__first)) -<span class="lineNum"> 3580 </span> : return __next; -<span class="lineNum"> 3581 </span> : return __next; -<span class="lineNum"> 3582 </span> : } -<span class="lineNum"> 3583 </span> : -<span class="lineNum"> 3584 </span> : /** -<span class="lineNum"> 3585 </span> : * @brief Determines min and max at once as an ordered pair. -<span class="lineNum"> 3586 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 3587 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 3588 </span> : * @return A pair(b, a) if b is smaller than a, pair(a, b) otherwise. -<span class="lineNum"> 3589 </span> : */ -<span class="lineNum"> 3590 </span> : template<typename _Tp> -<span class="lineNum"> 3591 </span> : inline pair<const _Tp&, const _Tp&> -<span class="lineNum"> 3592 </span> : minmax(const _Tp& __a, const _Tp& __b) -<span class="lineNum"> 3593 </span> : { -<span class="lineNum"> 3594 </span> : // concept requirements -<span class="lineNum"> 3595 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_Tp>) -<span class="lineNum"> 3596 </span> : -<span class="lineNum"> 3597 </span> : return __b < __a ? pair<const _Tp&, const _Tp&>(__b, __a) -<span class="lineNum"> 3598 </span> : : pair<const _Tp&, const _Tp&>(__a, __b); -<span class="lineNum"> 3599 </span> : } -<span class="lineNum"> 3600 </span> : -<span class="lineNum"> 3601 </span> : /** -<span class="lineNum"> 3602 </span> : * @brief Determines min and max at once as an ordered pair. -<span class="lineNum"> 3603 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 3604 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 3605 </span> : * @param comp A @link s20_3_3_comparisons comparison functor@endlink. -<span class="lineNum"> 3606 </span> : * @return A pair(b, a) if b is smaller than a, pair(a, b) otherwise. -<span class="lineNum"> 3607 </span> : */ -<span class="lineNum"> 3608 </span> : template<typename _Tp, typename _Compare> -<span class="lineNum"> 3609 </span> : inline pair<const _Tp&, const _Tp&> -<span class="lineNum"> 3610 </span> : minmax(const _Tp& __a, const _Tp& __b, _Compare __comp) -<span class="lineNum"> 3611 </span> : { -<span class="lineNum"> 3612 </span> : return __comp(__b, __a) ? pair<const _Tp&, const _Tp&>(__b, __a) -<span class="lineNum"> 3613 </span> : : pair<const _Tp&, const _Tp&>(__a, __b); -<span class="lineNum"> 3614 </span> : } -<span class="lineNum"> 3615 </span> : -<span class="lineNum"> 3616 </span> : /** -<span class="lineNum"> 3617 </span> : * @brief Return a pair of iterators pointing to the minimum and maximum -<span class="lineNum"> 3618 </span> : * elements in a range. -<span class="lineNum"> 3619 </span> : * @param first Start of range. -<span class="lineNum"> 3620 </span> : * @param last End of range. -<span class="lineNum"> 3621 </span> : * @return make_pair(m, M), where m is the first iterator i in -<span class="lineNum"> 3622 </span> : * [first, last) such that no other element in the range is -<span class="lineNum"> 3623 </span> : * smaller, and where M is the last iterator i in [first, last) -<span class="lineNum"> 3624 </span> : * such that no other element in the range is larger. -<span class="lineNum"> 3625 </span> : */ -<span class="lineNum"> 3626 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 3627 </span> : pair<_ForwardIterator, _ForwardIterator> -<span class="lineNum"> 3628 </span> : minmax_element(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 3629 </span> : { -<span class="lineNum"> 3630 </span> : // concept requirements -<span class="lineNum"> 3631 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3632 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 3633 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3634 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3635 </span> : -<span class="lineNum"> 3636 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 3637 </span> : if (__first == __last -<span class="lineNum"> 3638 </span> : || ++__next == __last) -<span class="lineNum"> 3639 </span> : return std::make_pair(__first, __first); -<span class="lineNum"> 3640 </span> : -<span class="lineNum"> 3641 </span> : _ForwardIterator __min, __max; -<span class="lineNum"> 3642 </span> : if (*__next < *__first) -<span class="lineNum"> 3643 </span> : { -<span class="lineNum"> 3644 </span> : __min = __next; -<span class="lineNum"> 3645 </span> : __max = __first; -<span class="lineNum"> 3646 </span> : } -<span class="lineNum"> 3647 </span> : else -<span class="lineNum"> 3648 </span> : { -<span class="lineNum"> 3649 </span> : __min = __first; -<span class="lineNum"> 3650 </span> : __max = __next; -<span class="lineNum"> 3651 </span> : } -<span class="lineNum"> 3652 </span> : -<span class="lineNum"> 3653 </span> : __first = __next; -<span class="lineNum"> 3654 </span> : ++__first; -<span class="lineNum"> 3655 </span> : -<span class="lineNum"> 3656 </span> : while (__first != __last) -<span class="lineNum"> 3657 </span> : { -<span class="lineNum"> 3658 </span> : __next = __first; -<span class="lineNum"> 3659 </span> : if (++__next == __last) -<span class="lineNum"> 3660 </span> : { -<span class="lineNum"> 3661 </span> : if (*__first < *__min) -<span class="lineNum"> 3662 </span> : __min = __first; -<span class="lineNum"> 3663 </span> : else if (!(*__first < *__max)) -<span class="lineNum"> 3664 </span> : __max = __first; -<span class="lineNum"> 3665 </span> : break; -<span class="lineNum"> 3666 </span> : } -<span class="lineNum"> 3667 </span> : -<span class="lineNum"> 3668 </span> : if (*__next < *__first) -<span class="lineNum"> 3669 </span> : { -<span class="lineNum"> 3670 </span> : if (*__next < *__min) -<span class="lineNum"> 3671 </span> : __min = __next; -<span class="lineNum"> 3672 </span> : if (!(*__first < *__max)) -<span class="lineNum"> 3673 </span> : __max = __first; -<span class="lineNum"> 3674 </span> : } -<span class="lineNum"> 3675 </span> : else -<span class="lineNum"> 3676 </span> : { -<span class="lineNum"> 3677 </span> : if (*__first < *__min) -<span class="lineNum"> 3678 </span> : __min = __first; -<span class="lineNum"> 3679 </span> : if (!(*__next < *__max)) -<span class="lineNum"> 3680 </span> : __max = __next; -<span class="lineNum"> 3681 </span> : } -<span class="lineNum"> 3682 </span> : -<span class="lineNum"> 3683 </span> : __first = __next; -<span class="lineNum"> 3684 </span> : ++__first; -<span class="lineNum"> 3685 </span> : } -<span class="lineNum"> 3686 </span> : -<span class="lineNum"> 3687 </span> : return std::make_pair(__min, __max); -<span class="lineNum"> 3688 </span> : } -<span class="lineNum"> 3689 </span> : -<span class="lineNum"> 3690 </span> : /** -<span class="lineNum"> 3691 </span> : * @brief Return a pair of iterators pointing to the minimum and maximum -<span class="lineNum"> 3692 </span> : * elements in a range. -<span class="lineNum"> 3693 </span> : * @param first Start of range. -<span class="lineNum"> 3694 </span> : * @param last End of range. -<span class="lineNum"> 3695 </span> : * @param comp Comparison functor. -<span class="lineNum"> 3696 </span> : * @return make_pair(m, M), where m is the first iterator i in -<span class="lineNum"> 3697 </span> : * [first, last) such that no other element in the range is -<span class="lineNum"> 3698 </span> : * smaller, and where M is the last iterator i in [first, last) -<span class="lineNum"> 3699 </span> : * such that no other element in the range is larger. -<span class="lineNum"> 3700 </span> : */ -<span class="lineNum"> 3701 </span> : template<typename _ForwardIterator, typename _Compare> -<span class="lineNum"> 3702 </span> : pair<_ForwardIterator, _ForwardIterator> -<span class="lineNum"> 3703 </span> : minmax_element(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 3704 </span> : _Compare __comp) -<span class="lineNum"> 3705 </span> : { -<span class="lineNum"> 3706 </span> : // concept requirements -<span class="lineNum"> 3707 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3708 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 3709 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 3710 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3711 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3712 </span> : -<span class="lineNum"> 3713 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 3714 </span> : if (__first == __last -<span class="lineNum"> 3715 </span> : || ++__next == __last) -<span class="lineNum"> 3716 </span> : return std::make_pair(__first, __first); -<span class="lineNum"> 3717 </span> : -<span class="lineNum"> 3718 </span> : _ForwardIterator __min, __max; -<span class="lineNum"> 3719 </span> : if (__comp(*__next, *__first)) -<span class="lineNum"> 3720 </span> : { -<span class="lineNum"> 3721 </span> : __min = __next; -<span class="lineNum"> 3722 </span> : __max = __first; -<span class="lineNum"> 3723 </span> : } -<span class="lineNum"> 3724 </span> : else -<span class="lineNum"> 3725 </span> : { -<span class="lineNum"> 3726 </span> : __min = __first; -<span class="lineNum"> 3727 </span> : __max = __next; -<span class="lineNum"> 3728 </span> : } -<span class="lineNum"> 3729 </span> : -<span class="lineNum"> 3730 </span> : __first = __next; -<span class="lineNum"> 3731 </span> : ++__first; -<span class="lineNum"> 3732 </span> : -<span class="lineNum"> 3733 </span> : while (__first != __last) -<span class="lineNum"> 3734 </span> : { -<span class="lineNum"> 3735 </span> : __next = __first; -<span class="lineNum"> 3736 </span> : if (++__next == __last) -<span class="lineNum"> 3737 </span> : { -<span class="lineNum"> 3738 </span> : if (__comp(*__first, *__min)) -<span class="lineNum"> 3739 </span> : __min = __first; -<span class="lineNum"> 3740 </span> : else if (!__comp(*__first, *__max)) -<span class="lineNum"> 3741 </span> : __max = __first; -<span class="lineNum"> 3742 </span> : break; -<span class="lineNum"> 3743 </span> : } -<span class="lineNum"> 3744 </span> : -<span class="lineNum"> 3745 </span> : if (__comp(*__next, *__first)) -<span class="lineNum"> 3746 </span> : { -<span class="lineNum"> 3747 </span> : if (__comp(*__next, *__min)) -<span class="lineNum"> 3748 </span> : __min = __next; -<span class="lineNum"> 3749 </span> : if (!__comp(*__first, *__max)) -<span class="lineNum"> 3750 </span> : __max = __first; -<span class="lineNum"> 3751 </span> : } -<span class="lineNum"> 3752 </span> : else -<span class="lineNum"> 3753 </span> : { -<span class="lineNum"> 3754 </span> : if (__comp(*__first, *__min)) -<span class="lineNum"> 3755 </span> : __min = __first; -<span class="lineNum"> 3756 </span> : if (!__comp(*__next, *__max)) -<span class="lineNum"> 3757 </span> : __max = __next; -<span class="lineNum"> 3758 </span> : } -<span class="lineNum"> 3759 </span> : -<span class="lineNum"> 3760 </span> : __first = __next; -<span class="lineNum"> 3761 </span> : ++__first; -<span class="lineNum"> 3762 </span> : } -<span class="lineNum"> 3763 </span> : -<span class="lineNum"> 3764 </span> : return std::make_pair(__min, __max); -<span class="lineNum"> 3765 </span> : } -<span class="lineNum"> 3766 </span> : #endif // __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 3767 </span> : -<span class="lineNum"> 3768 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 3769 </span> : -<span class="lineNum"> 3770 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_P) -<span class="lineNum"> 3771 </span> : -<span class="lineNum"> 3772 </span> : /** -<span class="lineNum"> 3773 </span> : * @brief Apply a function to every element of a sequence. -<span class="lineNum"> 3774 </span> : * @param first An input iterator. -<span class="lineNum"> 3775 </span> : * @param last An input iterator. -<span class="lineNum"> 3776 </span> : * @param f A unary function object. -<span class="lineNum"> 3777 </span> : * @return @p f. -<span class="lineNum"> 3778 </span> : * -<span class="lineNum"> 3779 </span> : * Applies the function object @p f to each element in the range -<span class="lineNum"> 3780 </span> : * @p [first,last). @p f must not modify the order of the sequence. -<span class="lineNum"> 3781 </span> : * If @p f has a return value it is ignored. -<span class="lineNum"> 3782 </span> : */ -<span class="lineNum"> 3783 </span> : template<typename _InputIterator, typename _Function> -<span class="lineNum"> 3784 </span> : _Function -<span class="lineNum"> 3785 </span> : for_each(_InputIterator __first, _InputIterator __last, _Function __f) -<span class="lineNum"> 3786 </span> : { -<span class="lineNum"> 3787 </span> : // concept requirements -<span class="lineNum"> 3788 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3789 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3790 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 3791 </span> : __f(*__first); -<span class="lineNum"> 3792 </span> : return __f; -<span class="lineNum"> 3793 </span> : } -<span class="lineNum"> 3794 </span> : -<span class="lineNum"> 3795 </span> : /** -<span class="lineNum"> 3796 </span> : * @brief Find the first occurrence of a value in a sequence. -<span class="lineNum"> 3797 </span> : * @param first An input iterator. -<span class="lineNum"> 3798 </span> : * @param last An input iterator. -<span class="lineNum"> 3799 </span> : * @param val The value to find. -<span class="lineNum"> 3800 </span> : * @return The first iterator @c i in the range @p [first,last) -<span class="lineNum"> 3801 </span> : * such that @c *i == @p val, or @p last if no such iterator exists. -<span class="lineNum"> 3802 </span> : */ -<span class="lineNum"> 3803 </span> : template<typename _InputIterator, typename _Tp> -<span class="lineNum"> 3804 </span> : inline _InputIterator -<span class="lineNum"> 3805 </span> : find(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 3806 </span><span class="lineCov"> 3362 : const _Tp& __val)</span> -<span class="lineNum"> 3807 </span> : { -<span class="lineNum"> 3808 </span> : // concept requirements -<span class="lineNum"> 3809 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3810 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 3811 </span> : typename iterator_traits<_InputIterator>::value_type, _Tp>) -<span class="lineNum"> 3812 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3813 </span> : return std::__find(__first, __last, __val, -<span class="lineNum"> 3814 </span><span class="lineCov"> 3362 : std::__iterator_category(__first));</span> -<span class="lineNum"> 3815 </span> : } -<span class="lineNum"> 3816 </span> : -<span class="lineNum"> 3817 </span> : /** -<span class="lineNum"> 3818 </span> : * @brief Find the first element in a sequence for which a -<span class="lineNum"> 3819 </span> : * predicate is true. -<span class="lineNum"> 3820 </span> : * @param first An input iterator. -<span class="lineNum"> 3821 </span> : * @param last An input iterator. -<span class="lineNum"> 3822 </span> : * @param pred A predicate. -<span class="lineNum"> 3823 </span> : * @return The first iterator @c i in the range @p [first,last) -<span class="lineNum"> 3824 </span> : * such that @p pred(*i) is true, or @p last if no such iterator exists. -<span class="lineNum"> 3825 </span> : */ -<span class="lineNum"> 3826 </span> : template<typename _InputIterator, typename _Predicate> -<span class="lineNum"> 3827 </span> : inline _InputIterator -<span class="lineNum"> 3828 </span> : find_if(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 3829 </span><span class="lineCov"> 3 : _Predicate __pred)</span> -<span class="lineNum"> 3830 </span> : { -<span class="lineNum"> 3831 </span> : // concept requirements -<span class="lineNum"> 3832 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3833 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 3834 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 3835 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3836 </span> : return std::__find_if(__first, __last, __pred, -<span class="lineNum"> 3837 </span><span class="lineCov"> 3 : std::__iterator_category(__first));</span> -<span class="lineNum"> 3838 </span> : } -<span class="lineNum"> 3839 </span> : -<span class="lineNum"> 3840 </span> : /** -<span class="lineNum"> 3841 </span> : * @brief Find element from a set in a sequence. -<span class="lineNum"> 3842 </span> : * @param first1 Start of range to search. -<span class="lineNum"> 3843 </span> : * @param last1 End of range to search. -<span class="lineNum"> 3844 </span> : * @param first2 Start of match candidates. -<span class="lineNum"> 3845 </span> : * @param last2 End of match candidates. -<span class="lineNum"> 3846 </span> : * @return The first iterator @c i in the range -<span class="lineNum"> 3847 </span> : * @p [first1,last1) such that @c *i == @p *(i2) such that i2 is an -<span class="lineNum"> 3848 </span> : * iterator in [first2,last2), or @p last1 if no such iterator exists. -<span class="lineNum"> 3849 </span> : * -<span class="lineNum"> 3850 </span> : * Searches the range @p [first1,last1) for an element that is equal to -<span class="lineNum"> 3851 </span> : * some element in the range [first2,last2). If found, returns an iterator -<span class="lineNum"> 3852 </span> : * in the range [first1,last1), otherwise returns @p last1. -<span class="lineNum"> 3853 </span> : */ -<span class="lineNum"> 3854 </span> : template<typename _InputIterator, typename _ForwardIterator> -<span class="lineNum"> 3855 </span> : _InputIterator -<span class="lineNum"> 3856 </span> : find_first_of(_InputIterator __first1, _InputIterator __last1, -<span class="lineNum"> 3857 </span> : _ForwardIterator __first2, _ForwardIterator __last2) -<span class="lineNum"> 3858 </span> : { -<span class="lineNum"> 3859 </span> : // concept requirements -<span class="lineNum"> 3860 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3861 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3862 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 3863 </span> : typename iterator_traits<_InputIterator>::value_type, -<span class="lineNum"> 3864 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3865 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 3866 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 3867 </span> : -<span class="lineNum"> 3868 </span> : for (; __first1 != __last1; ++__first1) -<span class="lineNum"> 3869 </span> : for (_ForwardIterator __iter = __first2; __iter != __last2; ++__iter) -<span class="lineNum"> 3870 </span> : if (*__first1 == *__iter) -<span class="lineNum"> 3871 </span> : return __first1; -<span class="lineNum"> 3872 </span> : return __last1; -<span class="lineNum"> 3873 </span> : } -<span class="lineNum"> 3874 </span> : -<span class="lineNum"> 3875 </span> : /** -<span class="lineNum"> 3876 </span> : * @brief Find element from a set in a sequence using a predicate. -<span class="lineNum"> 3877 </span> : * @param first1 Start of range to search. -<span class="lineNum"> 3878 </span> : * @param last1 End of range to search. -<span class="lineNum"> 3879 </span> : * @param first2 Start of match candidates. -<span class="lineNum"> 3880 </span> : * @param last2 End of match candidates. -<span class="lineNum"> 3881 </span> : * @param comp Predicate to use. -<span class="lineNum"> 3882 </span> : * @return The first iterator @c i in the range -<span class="lineNum"> 3883 </span> : * @p [first1,last1) such that @c comp(*i, @p *(i2)) is true and i2 is an -<span class="lineNum"> 3884 </span> : * iterator in [first2,last2), or @p last1 if no such iterator exists. -<span class="lineNum"> 3885 </span> : * -<span class="lineNum"> 3886 </span> : -<span class="lineNum"> 3887 </span> : * Searches the range @p [first1,last1) for an element that is -<span class="lineNum"> 3888 </span> : * equal to some element in the range [first2,last2). If found, -<span class="lineNum"> 3889 </span> : * returns an iterator in the range [first1,last1), otherwise -<span class="lineNum"> 3890 </span> : * returns @p last1. -<span class="lineNum"> 3891 </span> : */ -<span class="lineNum"> 3892 </span> : template<typename _InputIterator, typename _ForwardIterator, -<span class="lineNum"> 3893 </span> : typename _BinaryPredicate> -<span class="lineNum"> 3894 </span> : _InputIterator -<span class="lineNum"> 3895 </span> : find_first_of(_InputIterator __first1, _InputIterator __last1, -<span class="lineNum"> 3896 </span> : _ForwardIterator __first2, _ForwardIterator __last2, -<span class="lineNum"> 3897 </span> : _BinaryPredicate __comp) -<span class="lineNum"> 3898 </span> : { -<span class="lineNum"> 3899 </span> : // concept requirements -<span class="lineNum"> 3900 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3901 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3902 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 3903 </span> : typename iterator_traits<_InputIterator>::value_type, -<span class="lineNum"> 3904 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3905 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 3906 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 3907 </span> : -<span class="lineNum"> 3908 </span> : for (; __first1 != __last1; ++__first1) -<span class="lineNum"> 3909 </span> : for (_ForwardIterator __iter = __first2; __iter != __last2; ++__iter) -<span class="lineNum"> 3910 </span> : if (__comp(*__first1, *__iter)) -<span class="lineNum"> 3911 </span> : return __first1; -<span class="lineNum"> 3912 </span> : return __last1; -<span class="lineNum"> 3913 </span> : } -<span class="lineNum"> 3914 </span> : -<span class="lineNum"> 3915 </span> : /** -<span class="lineNum"> 3916 </span> : * @brief Find two adjacent values in a sequence that are equal. -<span class="lineNum"> 3917 </span> : * @param first A forward iterator. -<span class="lineNum"> 3918 </span> : * @param last A forward iterator. -<span class="lineNum"> 3919 </span> : * @return The first iterator @c i such that @c i and @c i+1 are both -<span class="lineNum"> 3920 </span> : * valid iterators in @p [first,last) and such that @c *i == @c *(i+1), -<span class="lineNum"> 3921 </span> : * or @p last if no such iterator exists. -<span class="lineNum"> 3922 </span> : */ -<span class="lineNum"> 3923 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 3924 </span> : _ForwardIterator -<span class="lineNum"> 3925 </span> : adjacent_find(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 3926 </span> : { -<span class="lineNum"> 3927 </span> : // concept requirements -<span class="lineNum"> 3928 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3929 </span> : __glibcxx_function_requires(_EqualityComparableConcept< -<span class="lineNum"> 3930 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3931 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3932 </span> : if (__first == __last) -<span class="lineNum"> 3933 </span> : return __last; -<span class="lineNum"> 3934 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 3935 </span> : while(++__next != __last) -<span class="lineNum"> 3936 </span> : { -<span class="lineNum"> 3937 </span> : if (*__first == *__next) -<span class="lineNum"> 3938 </span> : return __first; -<span class="lineNum"> 3939 </span> : __first = __next; -<span class="lineNum"> 3940 </span> : } -<span class="lineNum"> 3941 </span> : return __last; -<span class="lineNum"> 3942 </span> : } -<span class="lineNum"> 3943 </span> : -<span class="lineNum"> 3944 </span> : /** -<span class="lineNum"> 3945 </span> : * @brief Find two adjacent values in a sequence using a predicate. -<span class="lineNum"> 3946 </span> : * @param first A forward iterator. -<span class="lineNum"> 3947 </span> : * @param last A forward iterator. -<span class="lineNum"> 3948 </span> : * @param binary_pred A binary predicate. -<span class="lineNum"> 3949 </span> : * @return The first iterator @c i such that @c i and @c i+1 are both -<span class="lineNum"> 3950 </span> : * valid iterators in @p [first,last) and such that -<span class="lineNum"> 3951 </span> : * @p binary_pred(*i,*(i+1)) is true, or @p last if no such iterator -<span class="lineNum"> 3952 </span> : * exists. -<span class="lineNum"> 3953 </span> : */ -<span class="lineNum"> 3954 </span> : template<typename _ForwardIterator, typename _BinaryPredicate> -<span class="lineNum"> 3955 </span> : _ForwardIterator -<span class="lineNum"> 3956 </span> : adjacent_find(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 3957 </span> : _BinaryPredicate __binary_pred) -<span class="lineNum"> 3958 </span> : { -<span class="lineNum"> 3959 </span> : // concept requirements -<span class="lineNum"> 3960 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 3961 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 3962 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 3963 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 3964 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3965 </span> : if (__first == __last) -<span class="lineNum"> 3966 </span> : return __last; -<span class="lineNum"> 3967 </span> : _ForwardIterator __next = __first; -<span class="lineNum"> 3968 </span> : while(++__next != __last) -<span class="lineNum"> 3969 </span> : { -<span class="lineNum"> 3970 </span> : if (__binary_pred(*__first, *__next)) -<span class="lineNum"> 3971 </span> : return __first; -<span class="lineNum"> 3972 </span> : __first = __next; -<span class="lineNum"> 3973 </span> : } -<span class="lineNum"> 3974 </span> : return __last; -<span class="lineNum"> 3975 </span> : } -<span class="lineNum"> 3976 </span> : -<span class="lineNum"> 3977 </span> : /** -<span class="lineNum"> 3978 </span> : * @brief Count the number of copies of a value in a sequence. -<span class="lineNum"> 3979 </span> : * @param first An input iterator. -<span class="lineNum"> 3980 </span> : * @param last An input iterator. -<span class="lineNum"> 3981 </span> : * @param value The value to be counted. -<span class="lineNum"> 3982 </span> : * @return The number of iterators @c i in the range @p [first,last) -<span class="lineNum"> 3983 </span> : * for which @c *i == @p value -<span class="lineNum"> 3984 </span> : */ -<span class="lineNum"> 3985 </span> : template<typename _InputIterator, typename _Tp> -<span class="lineNum"> 3986 </span> : typename iterator_traits<_InputIterator>::difference_type -<span class="lineNum"> 3987 </span> : count(_InputIterator __first, _InputIterator __last, const _Tp& __value) -<span class="lineNum"> 3988 </span> : { -<span class="lineNum"> 3989 </span> : // concept requirements -<span class="lineNum"> 3990 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 3991 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 3992 </span> : typename iterator_traits<_InputIterator>::value_type, _Tp>) -<span class="lineNum"> 3993 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 3994 </span> : typename iterator_traits<_InputIterator>::difference_type __n = 0; -<span class="lineNum"> 3995 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 3996 </span> : if (*__first == __value) -<span class="lineNum"> 3997 </span> : ++__n; -<span class="lineNum"> 3998 </span> : return __n; -<span class="lineNum"> 3999 </span> : } -<span class="lineNum"> 4000 </span> : -<span class="lineNum"> 4001 </span> : /** -<span class="lineNum"> 4002 </span> : * @brief Count the elements of a sequence for which a predicate is true. -<span class="lineNum"> 4003 </span> : * @param first An input iterator. -<span class="lineNum"> 4004 </span> : * @param last An input iterator. -<span class="lineNum"> 4005 </span> : * @param pred A predicate. -<span class="lineNum"> 4006 </span> : * @return The number of iterators @c i in the range @p [first,last) -<span class="lineNum"> 4007 </span> : * for which @p pred(*i) is true. -<span class="lineNum"> 4008 </span> : */ -<span class="lineNum"> 4009 </span> : template<typename _InputIterator, typename _Predicate> -<span class="lineNum"> 4010 </span> : typename iterator_traits<_InputIterator>::difference_type -<span class="lineNum"> 4011 </span> : count_if(_InputIterator __first, _InputIterator __last, _Predicate __pred) -<span class="lineNum"> 4012 </span> : { -<span class="lineNum"> 4013 </span> : // concept requirements -<span class="lineNum"> 4014 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 4015 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 4016 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 4017 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4018 </span> : typename iterator_traits<_InputIterator>::difference_type __n = 0; -<span class="lineNum"> 4019 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 4020 </span> : if (__pred(*__first)) -<span class="lineNum"> 4021 </span> : ++__n; -<span class="lineNum"> 4022 </span> : return __n; -<span class="lineNum"> 4023 </span> : } -<span class="lineNum"> 4024 </span> : -<span class="lineNum"> 4025 </span> : /** -<span class="lineNum"> 4026 </span> : * @brief Search a sequence for a matching sub-sequence. -<span class="lineNum"> 4027 </span> : * @param first1 A forward iterator. -<span class="lineNum"> 4028 </span> : * @param last1 A forward iterator. -<span class="lineNum"> 4029 </span> : * @param first2 A forward iterator. -<span class="lineNum"> 4030 </span> : * @param last2 A forward iterator. -<span class="lineNum"> 4031 </span> : * @return The first iterator @c i in the range -<span class="lineNum"> 4032 </span> : * @p [first1,last1-(last2-first2)) such that @c *(i+N) == @p *(first2+N) -<span class="lineNum"> 4033 </span> : * for each @c N in the range @p [0,last2-first2), or @p last1 if no -<span class="lineNum"> 4034 </span> : * such iterator exists. -<span class="lineNum"> 4035 </span> : * -<span class="lineNum"> 4036 </span> : * Searches the range @p [first1,last1) for a sub-sequence that compares -<span class="lineNum"> 4037 </span> : * equal value-by-value with the sequence given by @p [first2,last2) and -<span class="lineNum"> 4038 </span> : * returns an iterator to the first element of the sub-sequence, or -<span class="lineNum"> 4039 </span> : * @p last1 if the sub-sequence is not found. -<span class="lineNum"> 4040 </span> : * -<span class="lineNum"> 4041 </span> : * Because the sub-sequence must lie completely within the range -<span class="lineNum"> 4042 </span> : * @p [first1,last1) it must start at a position less than -<span class="lineNum"> 4043 </span> : * @p last1-(last2-first2) where @p last2-first2 is the length of the -<span class="lineNum"> 4044 </span> : * sub-sequence. -<span class="lineNum"> 4045 </span> : * This means that the returned iterator @c i will be in the range -<span class="lineNum"> 4046 </span> : * @p [first1,last1-(last2-first2)) -<span class="lineNum"> 4047 </span> : */ -<span class="lineNum"> 4048 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 4049 </span> : _ForwardIterator1 -<span class="lineNum"> 4050 </span> : search(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 4051 </span> : _ForwardIterator2 __first2, _ForwardIterator2 __last2) -<span class="lineNum"> 4052 </span> : { -<span class="lineNum"> 4053 </span> : // concept requirements -<span class="lineNum"> 4054 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator1>) -<span class="lineNum"> 4055 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator2>) -<span class="lineNum"> 4056 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 4057 </span> : typename iterator_traits<_ForwardIterator1>::value_type, -<span class="lineNum"> 4058 </span> : typename iterator_traits<_ForwardIterator2>::value_type>) -<span class="lineNum"> 4059 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 4060 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 4061 </span> : -<span class="lineNum"> 4062 </span> : // Test for empty ranges -<span class="lineNum"> 4063 </span> : if (__first1 == __last1 || __first2 == __last2) -<span class="lineNum"> 4064 </span> : return __first1; -<span class="lineNum"> 4065 </span> : -<span class="lineNum"> 4066 </span> : // Test for a pattern of length 1. -<span class="lineNum"> 4067 </span> : _ForwardIterator2 __p1(__first2); -<span class="lineNum"> 4068 </span> : if (++__p1 == __last2) -<span class="lineNum"> 4069 </span> : return _GLIBCXX_STD_P::find(__first1, __last1, *__first2); -<span class="lineNum"> 4070 </span> : -<span class="lineNum"> 4071 </span> : // General case. -<span class="lineNum"> 4072 </span> : _ForwardIterator2 __p; -<span class="lineNum"> 4073 </span> : _ForwardIterator1 __current = __first1; -<span class="lineNum"> 4074 </span> : -<span class="lineNum"> 4075 </span> : for (;;) -<span class="lineNum"> 4076 </span> : { -<span class="lineNum"> 4077 </span> : __first1 = _GLIBCXX_STD_P::find(__first1, __last1, *__first2); -<span class="lineNum"> 4078 </span> : if (__first1 == __last1) -<span class="lineNum"> 4079 </span> : return __last1; -<span class="lineNum"> 4080 </span> : -<span class="lineNum"> 4081 </span> : __p = __p1; -<span class="lineNum"> 4082 </span> : __current = __first1; -<span class="lineNum"> 4083 </span> : if (++__current == __last1) -<span class="lineNum"> 4084 </span> : return __last1; -<span class="lineNum"> 4085 </span> : -<span class="lineNum"> 4086 </span> : while (*__current == *__p) -<span class="lineNum"> 4087 </span> : { -<span class="lineNum"> 4088 </span> : if (++__p == __last2) -<span class="lineNum"> 4089 </span> : return __first1; -<span class="lineNum"> 4090 </span> : if (++__current == __last1) -<span class="lineNum"> 4091 </span> : return __last1; -<span class="lineNum"> 4092 </span> : } -<span class="lineNum"> 4093 </span> : ++__first1; -<span class="lineNum"> 4094 </span> : } -<span class="lineNum"> 4095 </span> : return __first1; -<span class="lineNum"> 4096 </span> : } -<span class="lineNum"> 4097 </span> : -<span class="lineNum"> 4098 </span> : /** -<span class="lineNum"> 4099 </span> : * @brief Search a sequence for a matching sub-sequence using a predicate. -<span class="lineNum"> 4100 </span> : * @param first1 A forward iterator. -<span class="lineNum"> 4101 </span> : * @param last1 A forward iterator. -<span class="lineNum"> 4102 </span> : * @param first2 A forward iterator. -<span class="lineNum"> 4103 </span> : * @param last2 A forward iterator. -<span class="lineNum"> 4104 </span> : * @param predicate A binary predicate. -<span class="lineNum"> 4105 </span> : * @return The first iterator @c i in the range -<span class="lineNum"> 4106 </span> : * @p [first1,last1-(last2-first2)) such that -<span class="lineNum"> 4107 </span> : * @p predicate(*(i+N),*(first2+N)) is true for each @c N in the range -<span class="lineNum"> 4108 </span> : * @p [0,last2-first2), or @p last1 if no such iterator exists. -<span class="lineNum"> 4109 </span> : * -<span class="lineNum"> 4110 </span> : * Searches the range @p [first1,last1) for a sub-sequence that compares -<span class="lineNum"> 4111 </span> : * equal value-by-value with the sequence given by @p [first2,last2), -<span class="lineNum"> 4112 </span> : * using @p predicate to determine equality, and returns an iterator -<span class="lineNum"> 4113 </span> : * to the first element of the sub-sequence, or @p last1 if no such -<span class="lineNum"> 4114 </span> : * iterator exists. -<span class="lineNum"> 4115 </span> : * -<span class="lineNum"> 4116 </span> : * @see search(_ForwardIter1, _ForwardIter1, _ForwardIter2, _ForwardIter2) -<span class="lineNum"> 4117 </span> : */ -<span class="lineNum"> 4118 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2, -<span class="lineNum"> 4119 </span> : typename _BinaryPredicate> -<span class="lineNum"> 4120 </span> : _ForwardIterator1 -<span class="lineNum"> 4121 </span> : search(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 4122 </span> : _ForwardIterator2 __first2, _ForwardIterator2 __last2, -<span class="lineNum"> 4123 </span> : _BinaryPredicate __predicate) -<span class="lineNum"> 4124 </span> : { -<span class="lineNum"> 4125 </span> : // concept requirements -<span class="lineNum"> 4126 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator1>) -<span class="lineNum"> 4127 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator2>) -<span class="lineNum"> 4128 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 4129 </span> : typename iterator_traits<_ForwardIterator1>::value_type, -<span class="lineNum"> 4130 </span> : typename iterator_traits<_ForwardIterator2>::value_type>) -<span class="lineNum"> 4131 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 4132 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 4133 </span> : -<span class="lineNum"> 4134 </span> : // Test for empty ranges -<span class="lineNum"> 4135 </span> : if (__first1 == __last1 || __first2 == __last2) -<span class="lineNum"> 4136 </span> : return __first1; -<span class="lineNum"> 4137 </span> : -<span class="lineNum"> 4138 </span> : // Test for a pattern of length 1. -<span class="lineNum"> 4139 </span> : _ForwardIterator2 __p1(__first2); -<span class="lineNum"> 4140 </span> : if (++__p1 == __last2) -<span class="lineNum"> 4141 </span> : { -<span class="lineNum"> 4142 </span> : while (__first1 != __last1 -<span class="lineNum"> 4143 </span> : && !bool(__predicate(*__first1, *__first2))) -<span class="lineNum"> 4144 </span> : ++__first1; -<span class="lineNum"> 4145 </span> : return __first1; -<span class="lineNum"> 4146 </span> : } -<span class="lineNum"> 4147 </span> : -<span class="lineNum"> 4148 </span> : // General case. -<span class="lineNum"> 4149 </span> : _ForwardIterator2 __p; -<span class="lineNum"> 4150 </span> : _ForwardIterator1 __current = __first1; -<span class="lineNum"> 4151 </span> : -<span class="lineNum"> 4152 </span> : for (;;) -<span class="lineNum"> 4153 </span> : { -<span class="lineNum"> 4154 </span> : while (__first1 != __last1 -<span class="lineNum"> 4155 </span> : && !bool(__predicate(*__first1, *__first2))) -<span class="lineNum"> 4156 </span> : ++__first1; -<span class="lineNum"> 4157 </span> : if (__first1 == __last1) -<span class="lineNum"> 4158 </span> : return __last1; -<span class="lineNum"> 4159 </span> : -<span class="lineNum"> 4160 </span> : __p = __p1; -<span class="lineNum"> 4161 </span> : __current = __first1; -<span class="lineNum"> 4162 </span> : if (++__current == __last1) -<span class="lineNum"> 4163 </span> : return __last1; -<span class="lineNum"> 4164 </span> : -<span class="lineNum"> 4165 </span> : while (__predicate(*__current, *__p)) -<span class="lineNum"> 4166 </span> : { -<span class="lineNum"> 4167 </span> : if (++__p == __last2) -<span class="lineNum"> 4168 </span> : return __first1; -<span class="lineNum"> 4169 </span> : if (++__current == __last1) -<span class="lineNum"> 4170 </span> : return __last1; -<span class="lineNum"> 4171 </span> : } -<span class="lineNum"> 4172 </span> : ++__first1; -<span class="lineNum"> 4173 </span> : } -<span class="lineNum"> 4174 </span> : return __first1; -<span class="lineNum"> 4175 </span> : } -<span class="lineNum"> 4176 </span> : -<span class="lineNum"> 4177 </span> : -<span class="lineNum"> 4178 </span> : /** -<span class="lineNum"> 4179 </span> : * @brief Search a sequence for a number of consecutive values. -<span class="lineNum"> 4180 </span> : * @param first A forward iterator. -<span class="lineNum"> 4181 </span> : * @param last A forward iterator. -<span class="lineNum"> 4182 </span> : * @param count The number of consecutive values. -<span class="lineNum"> 4183 </span> : * @param val The value to find. -<span class="lineNum"> 4184 </span> : * @return The first iterator @c i in the range @p [first,last-count) -<span class="lineNum"> 4185 </span> : * such that @c *(i+N) == @p val for each @c N in the range @p [0,count), -<span class="lineNum"> 4186 </span> : * or @p last if no such iterator exists. -<span class="lineNum"> 4187 </span> : * -<span class="lineNum"> 4188 </span> : * Searches the range @p [first,last) for @p count consecutive elements -<span class="lineNum"> 4189 </span> : * equal to @p val. -<span class="lineNum"> 4190 </span> : */ -<span class="lineNum"> 4191 </span> : template<typename _ForwardIterator, typename _Integer, typename _Tp> -<span class="lineNum"> 4192 </span> : _ForwardIterator -<span class="lineNum"> 4193 </span> : search_n(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 4194 </span> : _Integer __count, const _Tp& __val) -<span class="lineNum"> 4195 </span> : { -<span class="lineNum"> 4196 </span> : // concept requirements -<span class="lineNum"> 4197 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 4198 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 4199 </span> : typename iterator_traits<_ForwardIterator>::value_type, _Tp>) -<span class="lineNum"> 4200 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4201 </span> : -<span class="lineNum"> 4202 </span> : if (__count <= 0) -<span class="lineNum"> 4203 </span> : return __first; -<span class="lineNum"> 4204 </span> : if (__count == 1) -<span class="lineNum"> 4205 </span> : return _GLIBCXX_STD_P::find(__first, __last, __val); -<span class="lineNum"> 4206 </span> : return std::__search_n(__first, __last, __count, __val, -<span class="lineNum"> 4207 </span> : std::__iterator_category(__first)); -<span class="lineNum"> 4208 </span> : } -<span class="lineNum"> 4209 </span> : -<span class="lineNum"> 4210 </span> : -<span class="lineNum"> 4211 </span> : /** -<span class="lineNum"> 4212 </span> : * @brief Search a sequence for a number of consecutive values using a -<span class="lineNum"> 4213 </span> : * predicate. -<span class="lineNum"> 4214 </span> : * @param first A forward iterator. -<span class="lineNum"> 4215 </span> : * @param last A forward iterator. -<span class="lineNum"> 4216 </span> : * @param count The number of consecutive values. -<span class="lineNum"> 4217 </span> : * @param val The value to find. -<span class="lineNum"> 4218 </span> : * @param binary_pred A binary predicate. -<span class="lineNum"> 4219 </span> : * @return The first iterator @c i in the range @p [first,last-count) -<span class="lineNum"> 4220 </span> : * such that @p binary_pred(*(i+N),val) is true for each @c N in the -<span class="lineNum"> 4221 </span> : * range @p [0,count), or @p last if no such iterator exists. -<span class="lineNum"> 4222 </span> : * -<span class="lineNum"> 4223 </span> : * Searches the range @p [first,last) for @p count consecutive elements -<span class="lineNum"> 4224 </span> : * for which the predicate returns true. -<span class="lineNum"> 4225 </span> : */ -<span class="lineNum"> 4226 </span> : template<typename _ForwardIterator, typename _Integer, typename _Tp, -<span class="lineNum"> 4227 </span> : typename _BinaryPredicate> -<span class="lineNum"> 4228 </span> : _ForwardIterator -<span class="lineNum"> 4229 </span> : search_n(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 4230 </span> : _Integer __count, const _Tp& __val, -<span class="lineNum"> 4231 </span> : _BinaryPredicate __binary_pred) -<span class="lineNum"> 4232 </span> : { -<span class="lineNum"> 4233 </span> : // concept requirements -<span class="lineNum"> 4234 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 4235 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_BinaryPredicate, -<span class="lineNum"> 4236 </span> : typename iterator_traits<_ForwardIterator>::value_type, _Tp>) -<span class="lineNum"> 4237 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4238 </span> : -<span class="lineNum"> 4239 </span> : if (__count <= 0) -<span class="lineNum"> 4240 </span> : return __first; -<span class="lineNum"> 4241 </span> : if (__count == 1) -<span class="lineNum"> 4242 </span> : { -<span class="lineNum"> 4243 </span> : while (__first != __last && !bool(__binary_pred(*__first, __val))) -<span class="lineNum"> 4244 </span> : ++__first; -<span class="lineNum"> 4245 </span> : return __first; -<span class="lineNum"> 4246 </span> : } -<span class="lineNum"> 4247 </span> : return std::__search_n(__first, __last, __count, __val, __binary_pred, -<span class="lineNum"> 4248 </span> : std::__iterator_category(__first)); -<span class="lineNum"> 4249 </span> : } -<span class="lineNum"> 4250 </span> : -<span class="lineNum"> 4251 </span> : -<span class="lineNum"> 4252 </span> : /** -<span class="lineNum"> 4253 </span> : * @brief Perform an operation on a sequence. -<span class="lineNum"> 4254 </span> : * @param first An input iterator. -<span class="lineNum"> 4255 </span> : * @param last An input iterator. -<span class="lineNum"> 4256 </span> : * @param result An output iterator. -<span class="lineNum"> 4257 </span> : * @param unary_op A unary operator. -<span class="lineNum"> 4258 </span> : * @return An output iterator equal to @p result+(last-first). -<span class="lineNum"> 4259 </span> : * -<span class="lineNum"> 4260 </span> : * Applies the operator to each element in the input range and assigns -<span class="lineNum"> 4261 </span> : * the results to successive elements of the output sequence. -<span class="lineNum"> 4262 </span> : * Evaluates @p *(result+N)=unary_op(*(first+N)) for each @c N in the -<span class="lineNum"> 4263 </span> : * range @p [0,last-first). -<span class="lineNum"> 4264 </span> : * -<span class="lineNum"> 4265 </span> : * @p unary_op must not alter its argument. -<span class="lineNum"> 4266 </span> : */ -<span class="lineNum"> 4267 </span> : template<typename _InputIterator, typename _OutputIterator, -<span class="lineNum"> 4268 </span> : typename _UnaryOperation> -<span class="lineNum"> 4269 </span> : _OutputIterator -<span class="lineNum"> 4270 </span> : transform(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 4271 </span> : _OutputIterator __result, _UnaryOperation __unary_op) -<span class="lineNum"> 4272 </span> : { -<span class="lineNum"> 4273 </span> : // concept requirements -<span class="lineNum"> 4274 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 4275 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4276 </span> : // "the type returned by a _UnaryOperation" -<span class="lineNum"> 4277 </span> : __typeof__(__unary_op(*__first))>) -<span class="lineNum"> 4278 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4279 </span> : -<span class="lineNum"> 4280 </span> : for (; __first != __last; ++__first, ++__result) -<span class="lineNum"> 4281 </span> : *__result = __unary_op(*__first); -<span class="lineNum"> 4282 </span> : return __result; -<span class="lineNum"> 4283 </span> : } -<span class="lineNum"> 4284 </span> : -<span class="lineNum"> 4285 </span> : /** -<span class="lineNum"> 4286 </span> : * @brief Perform an operation on corresponding elements of two sequences. -<span class="lineNum"> 4287 </span> : * @param first1 An input iterator. -<span class="lineNum"> 4288 </span> : * @param last1 An input iterator. -<span class="lineNum"> 4289 </span> : * @param first2 An input iterator. -<span class="lineNum"> 4290 </span> : * @param result An output iterator. -<span class="lineNum"> 4291 </span> : * @param binary_op A binary operator. -<span class="lineNum"> 4292 </span> : * @return An output iterator equal to @p result+(last-first). -<span class="lineNum"> 4293 </span> : * -<span class="lineNum"> 4294 </span> : * Applies the operator to the corresponding elements in the two -<span class="lineNum"> 4295 </span> : * input ranges and assigns the results to successive elements of the -<span class="lineNum"> 4296 </span> : * output sequence. -<span class="lineNum"> 4297 </span> : * Evaluates @p *(result+N)=binary_op(*(first1+N),*(first2+N)) for each -<span class="lineNum"> 4298 </span> : * @c N in the range @p [0,last1-first1). -<span class="lineNum"> 4299 </span> : * -<span class="lineNum"> 4300 </span> : * @p binary_op must not alter either of its arguments. -<span class="lineNum"> 4301 </span> : */ -<span class="lineNum"> 4302 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 4303 </span> : typename _OutputIterator, typename _BinaryOperation> -<span class="lineNum"> 4304 </span> : _OutputIterator -<span class="lineNum"> 4305 </span> : transform(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 4306 </span> : _InputIterator2 __first2, _OutputIterator __result, -<span class="lineNum"> 4307 </span> : _BinaryOperation __binary_op) -<span class="lineNum"> 4308 </span> : { -<span class="lineNum"> 4309 </span> : // concept requirements -<span class="lineNum"> 4310 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 4311 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 4312 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4313 </span> : // "the type returned by a _BinaryOperation" -<span class="lineNum"> 4314 </span> : __typeof__(__binary_op(*__first1,*__first2))>) -<span class="lineNum"> 4315 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 4316 </span> : -<span class="lineNum"> 4317 </span> : for (; __first1 != __last1; ++__first1, ++__first2, ++__result) -<span class="lineNum"> 4318 </span> : *__result = __binary_op(*__first1, *__first2); -<span class="lineNum"> 4319 </span> : return __result; -<span class="lineNum"> 4320 </span> : } -<span class="lineNum"> 4321 </span> : -<span class="lineNum"> 4322 </span> : /** -<span class="lineNum"> 4323 </span> : * @brief Replace each occurrence of one value in a sequence with another -<span class="lineNum"> 4324 </span> : * value. -<span class="lineNum"> 4325 </span> : * @param first A forward iterator. -<span class="lineNum"> 4326 </span> : * @param last A forward iterator. -<span class="lineNum"> 4327 </span> : * @param old_value The value to be replaced. -<span class="lineNum"> 4328 </span> : * @param new_value The replacement value. -<span class="lineNum"> 4329 </span> : * @return replace() returns no value. -<span class="lineNum"> 4330 </span> : * -<span class="lineNum"> 4331 </span> : * For each iterator @c i in the range @p [first,last) if @c *i == -<span class="lineNum"> 4332 </span> : * @p old_value then the assignment @c *i = @p new_value is performed. -<span class="lineNum"> 4333 </span> : */ -<span class="lineNum"> 4334 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 4335 </span> : void -<span class="lineNum"> 4336 </span> : replace(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 4337 </span> : const _Tp& __old_value, const _Tp& __new_value) -<span class="lineNum"> 4338 </span> : { -<span class="lineNum"> 4339 </span> : // concept requirements -<span class="lineNum"> 4340 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 4341 </span> : _ForwardIterator>) -<span class="lineNum"> 4342 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 4343 </span> : typename iterator_traits<_ForwardIterator>::value_type, _Tp>) -<span class="lineNum"> 4344 </span> : __glibcxx_function_requires(_ConvertibleConcept<_Tp, -<span class="lineNum"> 4345 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 4346 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4347 </span> : -<span class="lineNum"> 4348 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 4349 </span> : if (*__first == __old_value) -<span class="lineNum"> 4350 </span> : *__first = __new_value; -<span class="lineNum"> 4351 </span> : } -<span class="lineNum"> 4352 </span> : -<span class="lineNum"> 4353 </span> : /** -<span class="lineNum"> 4354 </span> : * @brief Replace each value in a sequence for which a predicate returns -<span class="lineNum"> 4355 </span> : * true with another value. -<span class="lineNum"> 4356 </span> : * @param first A forward iterator. -<span class="lineNum"> 4357 </span> : * @param last A forward iterator. -<span class="lineNum"> 4358 </span> : * @param pred A predicate. -<span class="lineNum"> 4359 </span> : * @param new_value The replacement value. -<span class="lineNum"> 4360 </span> : * @return replace_if() returns no value. -<span class="lineNum"> 4361 </span> : * -<span class="lineNum"> 4362 </span> : * For each iterator @c i in the range @p [first,last) if @p pred(*i) -<span class="lineNum"> 4363 </span> : * is true then the assignment @c *i = @p new_value is performed. -<span class="lineNum"> 4364 </span> : */ -<span class="lineNum"> 4365 </span> : template<typename _ForwardIterator, typename _Predicate, typename _Tp> -<span class="lineNum"> 4366 </span> : void -<span class="lineNum"> 4367 </span> : replace_if(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 4368 </span> : _Predicate __pred, const _Tp& __new_value) -<span class="lineNum"> 4369 </span> : { -<span class="lineNum"> 4370 </span> : // concept requirements -<span class="lineNum"> 4371 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 4372 </span> : _ForwardIterator>) -<span class="lineNum"> 4373 </span> : __glibcxx_function_requires(_ConvertibleConcept<_Tp, -<span class="lineNum"> 4374 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 4375 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 4376 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 4377 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4378 </span> : -<span class="lineNum"> 4379 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 4380 </span> : if (__pred(*__first)) -<span class="lineNum"> 4381 </span> : *__first = __new_value; -<span class="lineNum"> 4382 </span> : } -<span class="lineNum"> 4383 </span> : -<span class="lineNum"> 4384 </span> : /** -<span class="lineNum"> 4385 </span> : * @brief Assign the result of a function object to each value in a -<span class="lineNum"> 4386 </span> : * sequence. -<span class="lineNum"> 4387 </span> : * @param first A forward iterator. -<span class="lineNum"> 4388 </span> : * @param last A forward iterator. -<span class="lineNum"> 4389 </span> : * @param gen A function object taking no arguments and returning -<span class="lineNum"> 4390 </span> : * std::iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 4391 </span> : * @return generate() returns no value. -<span class="lineNum"> 4392 </span> : * -<span class="lineNum"> 4393 </span> : * Performs the assignment @c *i = @p gen() for each @c i in the range -<span class="lineNum"> 4394 </span> : * @p [first,last). -<span class="lineNum"> 4395 </span> : */ -<span class="lineNum"> 4396 </span> : template<typename _ForwardIterator, typename _Generator> -<span class="lineNum"> 4397 </span> : void -<span class="lineNum"> 4398 </span> : generate(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 4399 </span> : _Generator __gen) -<span class="lineNum"> 4400 </span> : { -<span class="lineNum"> 4401 </span> : // concept requirements -<span class="lineNum"> 4402 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 4403 </span> : __glibcxx_function_requires(_GeneratorConcept<_Generator, -<span class="lineNum"> 4404 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 4405 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4406 </span> : -<span class="lineNum"> 4407 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 4408 </span> : *__first = __gen(); -<span class="lineNum"> 4409 </span> : } -<span class="lineNum"> 4410 </span> : -<span class="lineNum"> 4411 </span> : /** -<span class="lineNum"> 4412 </span> : * @brief Assign the result of a function object to each value in a -<span class="lineNum"> 4413 </span> : * sequence. -<span class="lineNum"> 4414 </span> : * @param first A forward iterator. -<span class="lineNum"> 4415 </span> : * @param n The length of the sequence. -<span class="lineNum"> 4416 </span> : * @param gen A function object taking no arguments and returning -<span class="lineNum"> 4417 </span> : * std::iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 4418 </span> : * @return The end of the sequence, @p first+n -<span class="lineNum"> 4419 </span> : * -<span class="lineNum"> 4420 </span> : * Performs the assignment @c *i = @p gen() for each @c i in the range -<span class="lineNum"> 4421 </span> : * @p [first,first+n). -<span class="lineNum"> 4422 </span> : */ -<span class="lineNum"> 4423 </span> : template<typename _OutputIterator, typename _Size, typename _Generator> -<span class="lineNum"> 4424 </span> : _OutputIterator -<span class="lineNum"> 4425 </span> : generate_n(_OutputIterator __first, _Size __n, _Generator __gen) -<span class="lineNum"> 4426 </span> : { -<span class="lineNum"> 4427 </span> : // concept requirements -<span class="lineNum"> 4428 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4429 </span> : // "the type returned by a _Generator" -<span class="lineNum"> 4430 </span> : __typeof__(__gen())>) -<span class="lineNum"> 4431 </span> : -<span class="lineNum"> 4432 </span> : for (; __n > 0; --__n, ++__first) -<span class="lineNum"> 4433 </span> : *__first = __gen(); -<span class="lineNum"> 4434 </span> : return __first; -<span class="lineNum"> 4435 </span> : } -<span class="lineNum"> 4436 </span> : -<span class="lineNum"> 4437 </span> : -<span class="lineNum"> 4438 </span> : /** -<span class="lineNum"> 4439 </span> : * @brief Copy a sequence, removing consecutive duplicate values. -<span class="lineNum"> 4440 </span> : * @param first An input iterator. -<span class="lineNum"> 4441 </span> : * @param last An input iterator. -<span class="lineNum"> 4442 </span> : * @param result An output iterator. -<span class="lineNum"> 4443 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 4444 </span> : * -<span class="lineNum"> 4445 </span> : * Copies each element in the range @p [first,last) to the range -<span class="lineNum"> 4446 </span> : * beginning at @p result, except that only the first element is copied -<span class="lineNum"> 4447 </span> : * from groups of consecutive elements that compare equal. -<span class="lineNum"> 4448 </span> : * unique_copy() is stable, so the relative order of elements that are -<span class="lineNum"> 4449 </span> : * copied is unchanged. -<span class="lineNum"> 4450 </span> : * -<span class="lineNum"> 4451 </span> : * _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 4452 </span> : * DR 241. Does unique_copy() require CopyConstructible and Assignable? -<span class="lineNum"> 4453 </span> : * -<span class="lineNum"> 4454 </span> : * _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 4455 </span> : * DR 538. 241 again: Does unique_copy() require CopyConstructible and -<span class="lineNum"> 4456 </span> : * Assignable? -<span class="lineNum"> 4457 </span> : */ -<span class="lineNum"> 4458 </span> : template<typename _InputIterator, typename _OutputIterator> -<span class="lineNum"> 4459 </span> : inline _OutputIterator -<span class="lineNum"> 4460 </span> : unique_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 4461 </span> : _OutputIterator __result) -<span class="lineNum"> 4462 </span> : { -<span class="lineNum"> 4463 </span> : // concept requirements -<span class="lineNum"> 4464 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 4465 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4466 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 4467 </span> : __glibcxx_function_requires(_EqualityComparableConcept< -<span class="lineNum"> 4468 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 4469 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4470 </span> : -<span class="lineNum"> 4471 </span> : if (__first == __last) -<span class="lineNum"> 4472 </span> : return __result; -<span class="lineNum"> 4473 </span> : return std::__unique_copy(__first, __last, __result, -<span class="lineNum"> 4474 </span> : std::__iterator_category(__first), -<span class="lineNum"> 4475 </span> : std::__iterator_category(__result)); -<span class="lineNum"> 4476 </span> : } -<span class="lineNum"> 4477 </span> : -<span class="lineNum"> 4478 </span> : /** -<span class="lineNum"> 4479 </span> : * @brief Copy a sequence, removing consecutive values using a predicate. -<span class="lineNum"> 4480 </span> : * @param first An input iterator. -<span class="lineNum"> 4481 </span> : * @param last An input iterator. -<span class="lineNum"> 4482 </span> : * @param result An output iterator. -<span class="lineNum"> 4483 </span> : * @param binary_pred A binary predicate. -<span class="lineNum"> 4484 </span> : * @return An iterator designating the end of the resulting sequence. -<span class="lineNum"> 4485 </span> : * -<span class="lineNum"> 4486 </span> : * Copies each element in the range @p [first,last) to the range -<span class="lineNum"> 4487 </span> : * beginning at @p result, except that only the first element is copied -<span class="lineNum"> 4488 </span> : * from groups of consecutive elements for which @p binary_pred returns -<span class="lineNum"> 4489 </span> : * true. -<span class="lineNum"> 4490 </span> : * unique_copy() is stable, so the relative order of elements that are -<span class="lineNum"> 4491 </span> : * copied is unchanged. -<span class="lineNum"> 4492 </span> : * -<span class="lineNum"> 4493 </span> : * _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 4494 </span> : * DR 241. Does unique_copy() require CopyConstructible and Assignable? -<span class="lineNum"> 4495 </span> : */ -<span class="lineNum"> 4496 </span> : template<typename _InputIterator, typename _OutputIterator, -<span class="lineNum"> 4497 </span> : typename _BinaryPredicate> -<span class="lineNum"> 4498 </span> : inline _OutputIterator -<span class="lineNum"> 4499 </span> : unique_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 4500 </span> : _OutputIterator __result, -<span class="lineNum"> 4501 </span> : _BinaryPredicate __binary_pred) -<span class="lineNum"> 4502 </span> : { -<span class="lineNum"> 4503 </span> : // concept requirements -- predicates checked later -<span class="lineNum"> 4504 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 4505 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4506 </span> : typename iterator_traits<_InputIterator>::value_type>) -<span class="lineNum"> 4507 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4508 </span> : -<span class="lineNum"> 4509 </span> : if (__first == __last) -<span class="lineNum"> 4510 </span> : return __result; -<span class="lineNum"> 4511 </span> : return std::__unique_copy(__first, __last, __result, __binary_pred, -<span class="lineNum"> 4512 </span> : std::__iterator_category(__first), -<span class="lineNum"> 4513 </span> : std::__iterator_category(__result)); -<span class="lineNum"> 4514 </span> : } -<span class="lineNum"> 4515 </span> : -<span class="lineNum"> 4516 </span> : -<span class="lineNum"> 4517 </span> : /** -<span class="lineNum"> 4518 </span> : * @brief Randomly shuffle the elements of a sequence. -<span class="lineNum"> 4519 </span> : * @param first A forward iterator. -<span class="lineNum"> 4520 </span> : * @param last A forward iterator. -<span class="lineNum"> 4521 </span> : * @return Nothing. -<span class="lineNum"> 4522 </span> : * -<span class="lineNum"> 4523 </span> : * Reorder the elements in the range @p [first,last) using a random -<span class="lineNum"> 4524 </span> : * distribution, so that every possible ordering of the sequence is -<span class="lineNum"> 4525 </span> : * equally likely. -<span class="lineNum"> 4526 </span> : */ -<span class="lineNum"> 4527 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 4528 </span> : inline void -<span class="lineNum"> 4529 </span> : random_shuffle(_RandomAccessIterator __first, _RandomAccessIterator __last) -<span class="lineNum"> 4530 </span> : { -<span class="lineNum"> 4531 </span> : // concept requirements -<span class="lineNum"> 4532 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4533 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4534 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4535 </span> : -<span class="lineNum"> 4536 </span> : if (__first != __last) -<span class="lineNum"> 4537 </span> : for (_RandomAccessIterator __i = __first + 1; __i != __last; ++__i) -<span class="lineNum"> 4538 </span> : std::iter_swap(__i, __first + (std::rand() % ((__i - __first) + 1))); -<span class="lineNum"> 4539 </span> : } -<span class="lineNum"> 4540 </span> : -<span class="lineNum"> 4541 </span> : /** -<span class="lineNum"> 4542 </span> : * @brief Shuffle the elements of a sequence using a random number -<span class="lineNum"> 4543 </span> : * generator. -<span class="lineNum"> 4544 </span> : * @param first A forward iterator. -<span class="lineNum"> 4545 </span> : * @param last A forward iterator. -<span class="lineNum"> 4546 </span> : * @param rand The RNG functor or function. -<span class="lineNum"> 4547 </span> : * @return Nothing. -<span class="lineNum"> 4548 </span> : * -<span class="lineNum"> 4549 </span> : * Reorders the elements in the range @p [first,last) using @p rand to -<span class="lineNum"> 4550 </span> : * provide a random distribution. Calling @p rand(N) for a positive -<span class="lineNum"> 4551 </span> : * integer @p N should return a randomly chosen integer from the -<span class="lineNum"> 4552 </span> : * range [0,N). -<span class="lineNum"> 4553 </span> : */ -<span class="lineNum"> 4554 </span> : template<typename _RandomAccessIterator, typename _RandomNumberGenerator> -<span class="lineNum"> 4555 </span> : void -<span class="lineNum"> 4556 </span> : random_shuffle(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 4557 </span> : _RandomNumberGenerator& __rand) -<span class="lineNum"> 4558 </span> : { -<span class="lineNum"> 4559 </span> : // concept requirements -<span class="lineNum"> 4560 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4561 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4562 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4563 </span> : -<span class="lineNum"> 4564 </span> : if (__first == __last) -<span class="lineNum"> 4565 </span> : return; -<span class="lineNum"> 4566 </span> : for (_RandomAccessIterator __i = __first + 1; __i != __last; ++__i) -<span class="lineNum"> 4567 </span> : std::iter_swap(__i, __first + __rand((__i - __first) + 1)); -<span class="lineNum"> 4568 </span> : } -<span class="lineNum"> 4569 </span> : -<span class="lineNum"> 4570 </span> : -<span class="lineNum"> 4571 </span> : /** -<span class="lineNum"> 4572 </span> : * @brief Move elements for which a predicate is true to the beginning -<span class="lineNum"> 4573 </span> : * of a sequence. -<span class="lineNum"> 4574 </span> : * @param first A forward iterator. -<span class="lineNum"> 4575 </span> : * @param last A forward iterator. -<span class="lineNum"> 4576 </span> : * @param pred A predicate functor. -<span class="lineNum"> 4577 </span> : * @return An iterator @p middle such that @p pred(i) is true for each -<span class="lineNum"> 4578 </span> : * iterator @p i in the range @p [first,middle) and false for each @p i -<span class="lineNum"> 4579 </span> : * in the range @p [middle,last). -<span class="lineNum"> 4580 </span> : * -<span class="lineNum"> 4581 </span> : * @p pred must not modify its operand. @p partition() does not preserve -<span class="lineNum"> 4582 </span> : * the relative ordering of elements in each group, use -<span class="lineNum"> 4583 </span> : * @p stable_partition() if this is needed. -<span class="lineNum"> 4584 </span> : */ -<span class="lineNum"> 4585 </span> : template<typename _ForwardIterator, typename _Predicate> -<span class="lineNum"> 4586 </span> : inline _ForwardIterator -<span class="lineNum"> 4587 </span> : partition(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 4588 </span> : _Predicate __pred) -<span class="lineNum"> 4589 </span> : { -<span class="lineNum"> 4590 </span> : // concept requirements -<span class="lineNum"> 4591 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 4592 </span> : _ForwardIterator>) -<span class="lineNum"> 4593 </span> : __glibcxx_function_requires(_UnaryPredicateConcept<_Predicate, -<span class="lineNum"> 4594 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 4595 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4596 </span> : -<span class="lineNum"> 4597 </span> : return std::__partition(__first, __last, __pred, -<span class="lineNum"> 4598 </span> : std::__iterator_category(__first)); -<span class="lineNum"> 4599 </span> : } -<span class="lineNum"> 4600 </span> : -<span class="lineNum"> 4601 </span> : -<span class="lineNum"> 4602 </span> : -<span class="lineNum"> 4603 </span> : /** -<span class="lineNum"> 4604 </span> : * @brief Sort the smallest elements of a sequence. -<span class="lineNum"> 4605 </span> : * @param first An iterator. -<span class="lineNum"> 4606 </span> : * @param middle Another iterator. -<span class="lineNum"> 4607 </span> : * @param last Another iterator. -<span class="lineNum"> 4608 </span> : * @return Nothing. -<span class="lineNum"> 4609 </span> : * -<span class="lineNum"> 4610 </span> : * Sorts the smallest @p (middle-first) elements in the range -<span class="lineNum"> 4611 </span> : * @p [first,last) and moves them to the range @p [first,middle). The -<span class="lineNum"> 4612 </span> : * order of the remaining elements in the range @p [middle,last) is -<span class="lineNum"> 4613 </span> : * undefined. -<span class="lineNum"> 4614 </span> : * After the sort if @p i and @j are iterators in the range -<span class="lineNum"> 4615 </span> : * @p [first,middle) such that @i precedes @j and @k is an iterator in -<span class="lineNum"> 4616 </span> : * the range @p [middle,last) then @p *j<*i and @p *k<*i are both false. -<span class="lineNum"> 4617 </span> : */ -<span class="lineNum"> 4618 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 4619 </span> : inline void -<span class="lineNum"> 4620 </span> : partial_sort(_RandomAccessIterator __first, -<span class="lineNum"> 4621 </span> : _RandomAccessIterator __middle, -<span class="lineNum"> 4622 </span><span class="lineNoCov"> 0 : _RandomAccessIterator __last)</span> -<span class="lineNum"> 4623 </span> : { -<span class="lineNum"> 4624 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4625 </span> : _ValueType; -<span class="lineNum"> 4626 </span> : -<span class="lineNum"> 4627 </span> : // concept requirements -<span class="lineNum"> 4628 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4629 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4630 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 4631 </span> : __glibcxx_requires_valid_range(__first, __middle); -<span class="lineNum"> 4632 </span> : __glibcxx_requires_valid_range(__middle, __last); -<span class="lineNum"> 4633 </span> : -<span class="lineNum"> 4634 </span><span class="lineNoCov"> 0 : std::__heap_select(__first, __middle, __last);</span> -<span class="lineNum"> 4635 </span><span class="lineNoCov"> 0 : std::sort_heap(__first, __middle);</span> -<span class="lineNum"> 4636 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 4637 </span> : -<span class="lineNum"> 4638 </span> : /** -<span class="lineNum"> 4639 </span> : * @brief Sort the smallest elements of a sequence using a predicate -<span class="lineNum"> 4640 </span> : * for comparison. -<span class="lineNum"> 4641 </span> : * @param first An iterator. -<span class="lineNum"> 4642 </span> : * @param middle Another iterator. -<span class="lineNum"> 4643 </span> : * @param last Another iterator. -<span class="lineNum"> 4644 </span> : * @param comp A comparison functor. -<span class="lineNum"> 4645 </span> : * @return Nothing. -<span class="lineNum"> 4646 </span> : * -<span class="lineNum"> 4647 </span> : * Sorts the smallest @p (middle-first) elements in the range -<span class="lineNum"> 4648 </span> : * @p [first,last) and moves them to the range @p [first,middle). The -<span class="lineNum"> 4649 </span> : * order of the remaining elements in the range @p [middle,last) is -<span class="lineNum"> 4650 </span> : * undefined. -<span class="lineNum"> 4651 </span> : * After the sort if @p i and @j are iterators in the range -<span class="lineNum"> 4652 </span> : * @p [first,middle) such that @i precedes @j and @k is an iterator in -<span class="lineNum"> 4653 </span> : * the range @p [middle,last) then @p *comp(j,*i) and @p comp(*k,*i) -<span class="lineNum"> 4654 </span> : * are both false. -<span class="lineNum"> 4655 </span> : */ -<span class="lineNum"> 4656 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 4657 </span> : inline void -<span class="lineNum"> 4658 </span> : partial_sort(_RandomAccessIterator __first, -<span class="lineNum"> 4659 </span> : _RandomAccessIterator __middle, -<span class="lineNum"> 4660 </span> : _RandomAccessIterator __last, -<span class="lineNum"> 4661 </span><span class="lineNoCov"> 0 : _Compare __comp)</span> -<span class="lineNum"> 4662 </span> : { -<span class="lineNum"> 4663 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4664 </span> : _ValueType; -<span class="lineNum"> 4665 </span> : -<span class="lineNum"> 4666 </span> : // concept requirements -<span class="lineNum"> 4667 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4668 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4669 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 4670 </span> : _ValueType, _ValueType>) -<span class="lineNum"> 4671 </span> : __glibcxx_requires_valid_range(__first, __middle); -<span class="lineNum"> 4672 </span> : __glibcxx_requires_valid_range(__middle, __last); -<span class="lineNum"> 4673 </span> : -<span class="lineNum"> 4674 </span><span class="lineNoCov"> 0 : std::__heap_select(__first, __middle, __last, __comp);</span> -<span class="lineNum"> 4675 </span><span class="lineNoCov"> 0 : std::sort_heap(__first, __middle, __comp);</span> -<span class="lineNum"> 4676 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 4677 </span> : -<span class="lineNum"> 4678 </span> : /** -<span class="lineNum"> 4679 </span> : * @brief Sort a sequence just enough to find a particular position. -<span class="lineNum"> 4680 </span> : * @param first An iterator. -<span class="lineNum"> 4681 </span> : * @param nth Another iterator. -<span class="lineNum"> 4682 </span> : * @param last Another iterator. -<span class="lineNum"> 4683 </span> : * @return Nothing. -<span class="lineNum"> 4684 </span> : * -<span class="lineNum"> 4685 </span> : * Rearranges the elements in the range @p [first,last) so that @p *nth -<span class="lineNum"> 4686 </span> : * is the same element that would have been in that position had the -<span class="lineNum"> 4687 </span> : * whole sequence been sorted. -<span class="lineNum"> 4688 </span> : * whole sequence been sorted. The elements either side of @p *nth are -<span class="lineNum"> 4689 </span> : * not completely sorted, but for any iterator @i in the range -<span class="lineNum"> 4690 </span> : * @p [first,nth) and any iterator @j in the range @p [nth,last) it -<span class="lineNum"> 4691 </span> : * holds that @p *j<*i is false. -<span class="lineNum"> 4692 </span> : */ -<span class="lineNum"> 4693 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 4694 </span> : inline void -<span class="lineNum"> 4695 </span> : nth_element(_RandomAccessIterator __first, _RandomAccessIterator __nth, -<span class="lineNum"> 4696 </span> : _RandomAccessIterator __last) -<span class="lineNum"> 4697 </span> : { -<span class="lineNum"> 4698 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4699 </span> : _ValueType; -<span class="lineNum"> 4700 </span> : -<span class="lineNum"> 4701 </span> : // concept requirements -<span class="lineNum"> 4702 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4703 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4704 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 4705 </span> : __glibcxx_requires_valid_range(__first, __nth); -<span class="lineNum"> 4706 </span> : __glibcxx_requires_valid_range(__nth, __last); -<span class="lineNum"> 4707 </span> : -<span class="lineNum"> 4708 </span> : if (__first == __last || __nth == __last) -<span class="lineNum"> 4709 </span> : return; -<span class="lineNum"> 4710 </span> : -<span class="lineNum"> 4711 </span> : std::__introselect(__first, __nth, __last, -<span class="lineNum"> 4712 </span> : std::__lg(__last - __first) * 2); -<span class="lineNum"> 4713 </span> : } -<span class="lineNum"> 4714 </span> : -<span class="lineNum"> 4715 </span> : /** -<span class="lineNum"> 4716 </span> : * @brief Sort a sequence just enough to find a particular position -<span class="lineNum"> 4717 </span> : * using a predicate for comparison. -<span class="lineNum"> 4718 </span> : * @param first An iterator. -<span class="lineNum"> 4719 </span> : * @param nth Another iterator. -<span class="lineNum"> 4720 </span> : * @param last Another iterator. -<span class="lineNum"> 4721 </span> : * @param comp A comparison functor. -<span class="lineNum"> 4722 </span> : * @return Nothing. -<span class="lineNum"> 4723 </span> : * -<span class="lineNum"> 4724 </span> : * Rearranges the elements in the range @p [first,last) so that @p *nth -<span class="lineNum"> 4725 </span> : * is the same element that would have been in that position had the -<span class="lineNum"> 4726 </span> : * whole sequence been sorted. The elements either side of @p *nth are -<span class="lineNum"> 4727 </span> : * not completely sorted, but for any iterator @i in the range -<span class="lineNum"> 4728 </span> : * @p [first,nth) and any iterator @j in the range @p [nth,last) it -<span class="lineNum"> 4729 </span> : * holds that @p comp(*j,*i) is false. -<span class="lineNum"> 4730 </span> : */ -<span class="lineNum"> 4731 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 4732 </span> : inline void -<span class="lineNum"> 4733 </span> : nth_element(_RandomAccessIterator __first, _RandomAccessIterator __nth, -<span class="lineNum"> 4734 </span> : _RandomAccessIterator __last, _Compare __comp) -<span class="lineNum"> 4735 </span> : { -<span class="lineNum"> 4736 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4737 </span> : _ValueType; -<span class="lineNum"> 4738 </span> : -<span class="lineNum"> 4739 </span> : // concept requirements -<span class="lineNum"> 4740 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4741 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4742 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 4743 </span> : _ValueType, _ValueType>) -<span class="lineNum"> 4744 </span> : __glibcxx_requires_valid_range(__first, __nth); -<span class="lineNum"> 4745 </span> : __glibcxx_requires_valid_range(__nth, __last); -<span class="lineNum"> 4746 </span> : -<span class="lineNum"> 4747 </span> : if (__first == __last || __nth == __last) -<span class="lineNum"> 4748 </span> : return; -<span class="lineNum"> 4749 </span> : -<span class="lineNum"> 4750 </span> : std::__introselect(__first, __nth, __last, -<span class="lineNum"> 4751 </span> : std::__lg(__last - __first) * 2, __comp); -<span class="lineNum"> 4752 </span> : } -<span class="lineNum"> 4753 </span> : -<span class="lineNum"> 4754 </span> : -<span class="lineNum"> 4755 </span> : /** -<span class="lineNum"> 4756 </span> : * @brief Sort the elements of a sequence. -<span class="lineNum"> 4757 </span> : * @param first An iterator. -<span class="lineNum"> 4758 </span> : * @param last Another iterator. -<span class="lineNum"> 4759 </span> : * @return Nothing. -<span class="lineNum"> 4760 </span> : * -<span class="lineNum"> 4761 </span> : * Sorts the elements in the range @p [first,last) in ascending order, -<span class="lineNum"> 4762 </span> : * such that @p *(i+1)<*i is false for each iterator @p i in the range -<span class="lineNum"> 4763 </span> : * @p [first,last-1). -<span class="lineNum"> 4764 </span> : * -<span class="lineNum"> 4765 </span> : * The relative ordering of equivalent elements is not preserved, use -<span class="lineNum"> 4766 </span> : * @p stable_sort() if this is needed. -<span class="lineNum"> 4767 </span> : */ -<span class="lineNum"> 4768 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 4769 </span> : inline void -<span class="lineNum"> 4770 </span><span class="lineCov"> 8 : sort(_RandomAccessIterator __first, _RandomAccessIterator __last)</span> -<span class="lineNum"> 4771 </span> : { -<span class="lineNum"> 4772 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4773 </span> : _ValueType; -<span class="lineNum"> 4774 </span> : -<span class="lineNum"> 4775 </span> : // concept requirements -<span class="lineNum"> 4776 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4777 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4778 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 4779 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4780 </span> : -<span class="lineNum"> 4781 </span><span class="lineCov"> 8 : if (__first != __last)</span> -<span class="lineNum"> 4782 </span> : { -<span class="lineNum"> 4783 </span><span class="lineCov"> 8 : std::__introsort_loop(__first, __last,</span> -<span class="lineNum"> 4784 </span> : std::__lg(__last - __first) * 2); -<span class="lineNum"> 4785 </span><span class="lineCov"> 8 : std::__final_insertion_sort(__first, __last);</span> -<span class="lineNum"> 4786 </span> : } -<span class="lineNum"> 4787 </span><span class="lineCov"> 8 : }</span> -<span class="lineNum"> 4788 </span> : -<span class="lineNum"> 4789 </span> : /** -<span class="lineNum"> 4790 </span> : * @brief Sort the elements of a sequence using a predicate for comparison. -<span class="lineNum"> 4791 </span> : * @param first An iterator. -<span class="lineNum"> 4792 </span> : * @param last Another iterator. -<span class="lineNum"> 4793 </span> : * @param comp A comparison functor. -<span class="lineNum"> 4794 </span> : * @return Nothing. -<span class="lineNum"> 4795 </span> : * -<span class="lineNum"> 4796 </span> : * Sorts the elements in the range @p [first,last) in ascending order, -<span class="lineNum"> 4797 </span> : * such that @p comp(*(i+1),*i) is false for every iterator @p i in the -<span class="lineNum"> 4798 </span> : * range @p [first,last-1). -<span class="lineNum"> 4799 </span> : * -<span class="lineNum"> 4800 </span> : * The relative ordering of equivalent elements is not preserved, use -<span class="lineNum"> 4801 </span> : * @p stable_sort() if this is needed. -<span class="lineNum"> 4802 </span> : */ -<span class="lineNum"> 4803 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 4804 </span> : inline void -<span class="lineNum"> 4805 </span> : sort(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 4806 </span><span class="lineCov"> 3938 : _Compare __comp)</span> -<span class="lineNum"> 4807 </span> : { -<span class="lineNum"> 4808 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4809 </span> : _ValueType; -<span class="lineNum"> 4810 </span> : -<span class="lineNum"> 4811 </span> : // concept requirements -<span class="lineNum"> 4812 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4813 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4814 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, _ValueType, -<span class="lineNum"> 4815 </span> : _ValueType>) -<span class="lineNum"> 4816 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4817 </span> : -<span class="lineNum"> 4818 </span><span class="lineCov"> 3938 : if (__first != __last)</span> -<span class="lineNum"> 4819 </span> : { -<span class="lineNum"> 4820 </span><span class="lineCov"> 3938 : std::__introsort_loop(__first, __last,</span> -<span class="lineNum"> 4821 </span> : std::__lg(__last - __first) * 2, __comp); -<span class="lineNum"> 4822 </span><span class="lineCov"> 3938 : std::__final_insertion_sort(__first, __last, __comp);</span> -<span class="lineNum"> 4823 </span> : } -<span class="lineNum"> 4824 </span><span class="lineCov"> 3938 : }</span> -<span class="lineNum"> 4825 </span> : -<span class="lineNum"> 4826 </span> : /** -<span class="lineNum"> 4827 </span> : * @brief Merges two sorted ranges. -<span class="lineNum"> 4828 </span> : * @param first1 An iterator. -<span class="lineNum"> 4829 </span> : * @param first2 Another iterator. -<span class="lineNum"> 4830 </span> : * @param last1 Another iterator. -<span class="lineNum"> 4831 </span> : * @param last2 Another iterator. -<span class="lineNum"> 4832 </span> : * @param result An iterator pointing to the end of the merged range. -<span class="lineNum"> 4833 </span> : * @return An iterator pointing to the first element "not less -<span class="lineNum"> 4834 </span> : * than" @a val. -<span class="lineNum"> 4835 </span> : * -<span class="lineNum"> 4836 </span> : * Merges the ranges [first1,last1) and [first2,last2) into the sorted range -<span class="lineNum"> 4837 </span> : * [result, result + (last1-first1) + (last2-first2)). Both input ranges -<span class="lineNum"> 4838 </span> : * must be sorted, and the output range must not overlap with either of -<span class="lineNum"> 4839 </span> : * the input ranges. The sort is @e stable, that is, for equivalent -<span class="lineNum"> 4840 </span> : * elements in the two ranges, elements from the first range will always -<span class="lineNum"> 4841 </span> : * come before elements from the second. -<span class="lineNum"> 4842 </span> : */ -<span class="lineNum"> 4843 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 4844 </span> : typename _OutputIterator> -<span class="lineNum"> 4845 </span> : _OutputIterator -<span class="lineNum"> 4846 </span> : merge(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 4847 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 4848 </span> : _OutputIterator __result) -<span class="lineNum"> 4849 </span> : { -<span class="lineNum"> 4850 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 4851 </span> : _ValueType1; -<span class="lineNum"> 4852 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 4853 </span> : _ValueType2; -<span class="lineNum"> 4854 </span> : -<span class="lineNum"> 4855 </span> : // concept requirements -<span class="lineNum"> 4856 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 4857 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 4858 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4859 </span> : _ValueType1>) -<span class="lineNum"> 4860 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4861 </span> : _ValueType2>) -<span class="lineNum"> 4862 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 4863 </span> : __glibcxx_requires_sorted_set(__first1, __last1, __first2); -<span class="lineNum"> 4864 </span> : __glibcxx_requires_sorted_set(__first2, __last2, __first1); -<span class="lineNum"> 4865 </span> : -<span class="lineNum"> 4866 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 4867 </span> : { -<span class="lineNum"> 4868 </span> : if (*__first2 < *__first1) -<span class="lineNum"> 4869 </span> : { -<span class="lineNum"> 4870 </span> : *__result = *__first2; -<span class="lineNum"> 4871 </span> : ++__first2; -<span class="lineNum"> 4872 </span> : } -<span class="lineNum"> 4873 </span> : else -<span class="lineNum"> 4874 </span> : { -<span class="lineNum"> 4875 </span> : *__result = *__first1; -<span class="lineNum"> 4876 </span> : ++__first1; -<span class="lineNum"> 4877 </span> : } -<span class="lineNum"> 4878 </span> : ++__result; -<span class="lineNum"> 4879 </span> : } -<span class="lineNum"> 4880 </span> : return std::copy(__first2, __last2, std::copy(__first1, __last1, -<span class="lineNum"> 4881 </span> : __result)); -<span class="lineNum"> 4882 </span> : } -<span class="lineNum"> 4883 </span> : -<span class="lineNum"> 4884 </span> : /** -<span class="lineNum"> 4885 </span> : * @brief Merges two sorted ranges. -<span class="lineNum"> 4886 </span> : * @param first1 An iterator. -<span class="lineNum"> 4887 </span> : * @param first2 Another iterator. -<span class="lineNum"> 4888 </span> : * @param last1 Another iterator. -<span class="lineNum"> 4889 </span> : * @param last2 Another iterator. -<span class="lineNum"> 4890 </span> : * @param result An iterator pointing to the end of the merged range. -<span class="lineNum"> 4891 </span> : * @param comp A functor to use for comparisons. -<span class="lineNum"> 4892 </span> : * @return An iterator pointing to the first element "not less -<span class="lineNum"> 4893 </span> : * than" @a val. -<span class="lineNum"> 4894 </span> : * -<span class="lineNum"> 4895 </span> : * Merges the ranges [first1,last1) and [first2,last2) into the sorted range -<span class="lineNum"> 4896 </span> : * [result, result + (last1-first1) + (last2-first2)). Both input ranges -<span class="lineNum"> 4897 </span> : * must be sorted, and the output range must not overlap with either of -<span class="lineNum"> 4898 </span> : * the input ranges. The sort is @e stable, that is, for equivalent -<span class="lineNum"> 4899 </span> : * elements in the two ranges, elements from the first range will always -<span class="lineNum"> 4900 </span> : * come before elements from the second. -<span class="lineNum"> 4901 </span> : * -<span class="lineNum"> 4902 </span> : * The comparison function should have the same effects on ordering as -<span class="lineNum"> 4903 </span> : * the function used for the initial sort. -<span class="lineNum"> 4904 </span> : */ -<span class="lineNum"> 4905 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 4906 </span> : typename _OutputIterator, typename _Compare> -<span class="lineNum"> 4907 </span> : _OutputIterator -<span class="lineNum"> 4908 </span> : merge(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 4909 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 4910 </span> : _OutputIterator __result, _Compare __comp) -<span class="lineNum"> 4911 </span> : { -<span class="lineNum"> 4912 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 4913 </span> : _ValueType1; -<span class="lineNum"> 4914 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 4915 </span> : _ValueType2; -<span class="lineNum"> 4916 </span> : -<span class="lineNum"> 4917 </span> : // concept requirements -<span class="lineNum"> 4918 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 4919 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 4920 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4921 </span> : _ValueType1>) -<span class="lineNum"> 4922 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 4923 </span> : _ValueType2>) -<span class="lineNum"> 4924 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 4925 </span> : _ValueType2, _ValueType1>) -<span class="lineNum"> 4926 </span> : __glibcxx_requires_sorted_set_pred(__first1, __last1, __first2, __comp); -<span class="lineNum"> 4927 </span> : __glibcxx_requires_sorted_set_pred(__first2, __last2, __first1, __comp); -<span class="lineNum"> 4928 </span> : -<span class="lineNum"> 4929 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 4930 </span> : { -<span class="lineNum"> 4931 </span> : if (__comp(*__first2, *__first1)) -<span class="lineNum"> 4932 </span> : { -<span class="lineNum"> 4933 </span> : *__result = *__first2; -<span class="lineNum"> 4934 </span> : ++__first2; -<span class="lineNum"> 4935 </span> : } -<span class="lineNum"> 4936 </span> : else -<span class="lineNum"> 4937 </span> : { -<span class="lineNum"> 4938 </span> : *__result = *__first1; -<span class="lineNum"> 4939 </span> : ++__first1; -<span class="lineNum"> 4940 </span> : } -<span class="lineNum"> 4941 </span> : ++__result; -<span class="lineNum"> 4942 </span> : } -<span class="lineNum"> 4943 </span> : return std::copy(__first2, __last2, std::copy(__first1, __last1, -<span class="lineNum"> 4944 </span> : __result)); -<span class="lineNum"> 4945 </span> : } -<span class="lineNum"> 4946 </span> : -<span class="lineNum"> 4947 </span> : -<span class="lineNum"> 4948 </span> : /** -<span class="lineNum"> 4949 </span> : * @brief Sort the elements of a sequence, preserving the relative order -<span class="lineNum"> 4950 </span> : * of equivalent elements. -<span class="lineNum"> 4951 </span> : * @param first An iterator. -<span class="lineNum"> 4952 </span> : * @param last Another iterator. -<span class="lineNum"> 4953 </span> : * @return Nothing. -<span class="lineNum"> 4954 </span> : * -<span class="lineNum"> 4955 </span> : * Sorts the elements in the range @p [first,last) in ascending order, -<span class="lineNum"> 4956 </span> : * such that @p *(i+1)<*i is false for each iterator @p i in the range -<span class="lineNum"> 4957 </span> : * @p [first,last-1). -<span class="lineNum"> 4958 </span> : * -<span class="lineNum"> 4959 </span> : * The relative ordering of equivalent elements is preserved, so any two -<span class="lineNum"> 4960 </span> : * elements @p x and @p y in the range @p [first,last) such that -<span class="lineNum"> 4961 </span> : * @p x<y is false and @p y<x is false will have the same relative -<span class="lineNum"> 4962 </span> : * ordering after calling @p stable_sort(). -<span class="lineNum"> 4963 </span> : */ -<span class="lineNum"> 4964 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 4965 </span> : inline void -<span class="lineNum"> 4966 </span> : stable_sort(_RandomAccessIterator __first, _RandomAccessIterator __last) -<span class="lineNum"> 4967 </span> : { -<span class="lineNum"> 4968 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 4969 </span> : _ValueType; -<span class="lineNum"> 4970 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 4971 </span> : _DistanceType; -<span class="lineNum"> 4972 </span> : -<span class="lineNum"> 4973 </span> : // concept requirements -<span class="lineNum"> 4974 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 4975 </span> : _RandomAccessIterator>) -<span class="lineNum"> 4976 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 4977 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 4978 </span> : -<span class="lineNum"> 4979 </span> : _Temporary_buffer<_RandomAccessIterator, _ValueType> __buf(__first, -<span class="lineNum"> 4980 </span> : __last); -<span class="lineNum"> 4981 </span> : if (__buf.begin() == 0) -<span class="lineNum"> 4982 </span> : std::__inplace_stable_sort(__first, __last); -<span class="lineNum"> 4983 </span> : else -<span class="lineNum"> 4984 </span> : std::__stable_sort_adaptive(__first, __last, __buf.begin(), -<span class="lineNum"> 4985 </span> : _DistanceType(__buf.size())); -<span class="lineNum"> 4986 </span> : } -<span class="lineNum"> 4987 </span> : -<span class="lineNum"> 4988 </span> : /** -<span class="lineNum"> 4989 </span> : * @brief Sort the elements of a sequence using a predicate for comparison, -<span class="lineNum"> 4990 </span> : * preserving the relative order of equivalent elements. -<span class="lineNum"> 4991 </span> : * @param first An iterator. -<span class="lineNum"> 4992 </span> : * @param last Another iterator. -<span class="lineNum"> 4993 </span> : * @param comp A comparison functor. -<span class="lineNum"> 4994 </span> : * @return Nothing. -<span class="lineNum"> 4995 </span> : * -<span class="lineNum"> 4996 </span> : * Sorts the elements in the range @p [first,last) in ascending order, -<span class="lineNum"> 4997 </span> : * such that @p comp(*(i+1),*i) is false for each iterator @p i in the -<span class="lineNum"> 4998 </span> : * range @p [first,last-1). -<span class="lineNum"> 4999 </span> : * -<span class="lineNum"> 5000 </span> : * The relative ordering of equivalent elements is preserved, so any two -<span class="lineNum"> 5001 </span> : * elements @p x and @p y in the range @p [first,last) such that -<span class="lineNum"> 5002 </span> : * @p comp(x,y) is false and @p comp(y,x) is false will have the same -<span class="lineNum"> 5003 </span> : * relative ordering after calling @p stable_sort(). -<span class="lineNum"> 5004 </span> : */ -<span class="lineNum"> 5005 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 5006 </span> : inline void -<span class="lineNum"> 5007 </span> : stable_sort(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 5008 </span> : _Compare __comp) -<span class="lineNum"> 5009 </span> : { -<span class="lineNum"> 5010 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 5011 </span> : _ValueType; -<span class="lineNum"> 5012 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 5013 </span> : _DistanceType; -<span class="lineNum"> 5014 </span> : -<span class="lineNum"> 5015 </span> : // concept requirements -<span class="lineNum"> 5016 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 5017 </span> : _RandomAccessIterator>) -<span class="lineNum"> 5018 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5019 </span> : _ValueType, -<span class="lineNum"> 5020 </span> : _ValueType>) -<span class="lineNum"> 5021 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 5022 </span> : -<span class="lineNum"> 5023 </span> : _Temporary_buffer<_RandomAccessIterator, _ValueType> __buf(__first, -<span class="lineNum"> 5024 </span> : __last); -<span class="lineNum"> 5025 </span> : if (__buf.begin() == 0) -<span class="lineNum"> 5026 </span> : std::__inplace_stable_sort(__first, __last, __comp); -<span class="lineNum"> 5027 </span> : else -<span class="lineNum"> 5028 </span> : std::__stable_sort_adaptive(__first, __last, __buf.begin(), -<span class="lineNum"> 5029 </span> : _DistanceType(__buf.size()), __comp); -<span class="lineNum"> 5030 </span> : } -<span class="lineNum"> 5031 </span> : -<span class="lineNum"> 5032 </span> : -<span class="lineNum"> 5033 </span> : /** -<span class="lineNum"> 5034 </span> : * @brief Return the union of two sorted ranges. -<span class="lineNum"> 5035 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5036 </span> : * @param last1 End of first range. -<span class="lineNum"> 5037 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5038 </span> : * @param last2 End of second range. -<span class="lineNum"> 5039 </span> : * @return End of the output range. -<span class="lineNum"> 5040 </span> : * @ingroup setoperations -<span class="lineNum"> 5041 </span> : * -<span class="lineNum"> 5042 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5043 </span> : * each range in order to the output range. Iterators increment for each -<span class="lineNum"> 5044 </span> : * range. When the current element of one range is less than the other, -<span class="lineNum"> 5045 </span> : * that element is copied and the iterator advanced. If an element is -<span class="lineNum"> 5046 </span> : * contained in both ranges, the element from the first range is copied and -<span class="lineNum"> 5047 </span> : * both ranges advance. The output range may not overlap either input -<span class="lineNum"> 5048 </span> : * range. -<span class="lineNum"> 5049 </span> : */ -<span class="lineNum"> 5050 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5051 </span> : typename _OutputIterator> -<span class="lineNum"> 5052 </span> : _OutputIterator -<span class="lineNum"> 5053 </span> : set_union(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5054 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5055 </span><span class="lineCov"> 21150 : _OutputIterator __result)</span> -<span class="lineNum"> 5056 </span> : { -<span class="lineNum"> 5057 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5058 </span> : _ValueType1; -<span class="lineNum"> 5059 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5060 </span> : _ValueType2; -<span class="lineNum"> 5061 </span> : -<span class="lineNum"> 5062 </span> : // concept requirements -<span class="lineNum"> 5063 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5064 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5065 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5066 </span> : _ValueType1>) -<span class="lineNum"> 5067 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5068 </span> : _ValueType2>) -<span class="lineNum"> 5069 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType1, _ValueType2>) -<span class="lineNum"> 5070 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 5071 </span> : __glibcxx_requires_sorted_set(__first1, __last1, __first2); -<span class="lineNum"> 5072 </span> : __glibcxx_requires_sorted_set(__first2, __last2, __first1); -<span class="lineNum"> 5073 </span> : -<span class="lineNum"> 5074 </span><span class="lineCov"> 42309 : while (__first1 != __last1 && __first2 != __last2)</span> -<span class="lineNum"> 5075 </span> : { -<span class="lineNum"> 5076 </span><span class="lineCov"> 9 : if (*__first1 < *__first2)</span> -<span class="lineNum"> 5077 </span> : { -<span class="lineNum"> 5078 </span><span class="lineCov"> 7 : *__result = *__first1;</span> -<span class="lineNum"> 5079 </span><span class="lineCov"> 7 : ++__first1;</span> -<span class="lineNum"> 5080 </span> : } -<span class="lineNum"> 5081 </span><span class="lineCov"> 2 : else if (*__first2 < *__first1)</span> -<span class="lineNum"> 5082 </span> : { -<span class="lineNum"> 5083 </span><span class="lineCov"> 1 : *__result = *__first2;</span> -<span class="lineNum"> 5084 </span><span class="lineCov"> 1 : ++__first2;</span> -<span class="lineNum"> 5085 </span> : } -<span class="lineNum"> 5086 </span> : else -<span class="lineNum"> 5087 </span> : { -<span class="lineNum"> 5088 </span><span class="lineCov"> 1 : *__result = *__first1;</span> -<span class="lineNum"> 5089 </span><span class="lineCov"> 1 : ++__first1;</span> -<span class="lineNum"> 5090 </span><span class="lineCov"> 1 : ++__first2;</span> -<span class="lineNum"> 5091 </span> : } -<span class="lineNum"> 5092 </span><span class="lineCov"> 9 : ++__result;</span> -<span class="lineNum"> 5093 </span> : } -<span class="lineNum"> 5094 </span> : return std::copy(__first2, __last2, std::copy(__first1, __last1, -<span class="lineNum"> 5095 </span><span class="lineCov"> 21150 : __result));</span> -<span class="lineNum"> 5096 </span> : } -<span class="lineNum"> 5097 </span> : -<span class="lineNum"> 5098 </span> : /** -<span class="lineNum"> 5099 </span> : * @brief Return the union of two sorted ranges using a comparison functor. -<span class="lineNum"> 5100 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5101 </span> : * @param last1 End of first range. -<span class="lineNum"> 5102 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5103 </span> : * @param last2 End of second range. -<span class="lineNum"> 5104 </span> : * @param comp The comparison functor. -<span class="lineNum"> 5105 </span> : * @return End of the output range. -<span class="lineNum"> 5106 </span> : * @ingroup setoperations -<span class="lineNum"> 5107 </span> : * -<span class="lineNum"> 5108 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5109 </span> : * each range in order to the output range. Iterators increment for each -<span class="lineNum"> 5110 </span> : * range. When the current element of one range is less than the other -<span class="lineNum"> 5111 </span> : * according to @a comp, that element is copied and the iterator advanced. -<span class="lineNum"> 5112 </span> : * If an equivalent element according to @a comp is contained in both -<span class="lineNum"> 5113 </span> : * ranges, the element from the first range is copied and both ranges -<span class="lineNum"> 5114 </span> : * advance. The output range may not overlap either input range. -<span class="lineNum"> 5115 </span> : */ -<span class="lineNum"> 5116 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5117 </span> : typename _OutputIterator, typename _Compare> -<span class="lineNum"> 5118 </span> : _OutputIterator -<span class="lineNum"> 5119 </span> : set_union(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5120 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5121 </span> : _OutputIterator __result, _Compare __comp) -<span class="lineNum"> 5122 </span> : { -<span class="lineNum"> 5123 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5124 </span> : _ValueType1; -<span class="lineNum"> 5125 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5126 </span> : _ValueType2; -<span class="lineNum"> 5127 </span> : -<span class="lineNum"> 5128 </span> : // concept requirements -<span class="lineNum"> 5129 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5130 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5131 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5132 </span> : _ValueType1>) -<span class="lineNum"> 5133 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5134 </span> : _ValueType2>) -<span class="lineNum"> 5135 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5136 </span> : _ValueType1, _ValueType2>) -<span class="lineNum"> 5137 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5138 </span> : _ValueType2, _ValueType1>) -<span class="lineNum"> 5139 </span> : __glibcxx_requires_sorted_set_pred(__first1, __last1, __first2, __comp); -<span class="lineNum"> 5140 </span> : __glibcxx_requires_sorted_set_pred(__first2, __last2, __first1, __comp); -<span class="lineNum"> 5141 </span> : -<span class="lineNum"> 5142 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 5143 </span> : { -<span class="lineNum"> 5144 </span> : if (__comp(*__first1, *__first2)) -<span class="lineNum"> 5145 </span> : { -<span class="lineNum"> 5146 </span> : *__result = *__first1; -<span class="lineNum"> 5147 </span> : ++__first1; -<span class="lineNum"> 5148 </span> : } -<span class="lineNum"> 5149 </span> : else if (__comp(*__first2, *__first1)) -<span class="lineNum"> 5150 </span> : { -<span class="lineNum"> 5151 </span> : *__result = *__first2; -<span class="lineNum"> 5152 </span> : ++__first2; -<span class="lineNum"> 5153 </span> : } -<span class="lineNum"> 5154 </span> : else -<span class="lineNum"> 5155 </span> : { -<span class="lineNum"> 5156 </span> : *__result = *__first1; -<span class="lineNum"> 5157 </span> : ++__first1; -<span class="lineNum"> 5158 </span> : ++__first2; -<span class="lineNum"> 5159 </span> : } -<span class="lineNum"> 5160 </span> : ++__result; -<span class="lineNum"> 5161 </span> : } -<span class="lineNum"> 5162 </span> : return std::copy(__first2, __last2, std::copy(__first1, __last1, -<span class="lineNum"> 5163 </span> : __result)); -<span class="lineNum"> 5164 </span> : } -<span class="lineNum"> 5165 </span> : -<span class="lineNum"> 5166 </span> : /** -<span class="lineNum"> 5167 </span> : * @brief Return the intersection of two sorted ranges. -<span class="lineNum"> 5168 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5169 </span> : * @param last1 End of first range. -<span class="lineNum"> 5170 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5171 </span> : * @param last2 End of second range. -<span class="lineNum"> 5172 </span> : * @return End of the output range. -<span class="lineNum"> 5173 </span> : * @ingroup setoperations -<span class="lineNum"> 5174 </span> : * -<span class="lineNum"> 5175 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5176 </span> : * both ranges in order to the output range. Iterators increment for each -<span class="lineNum"> 5177 </span> : * range. When the current element of one range is less than the other, -<span class="lineNum"> 5178 </span> : * that iterator advances. If an element is contained in both ranges, the -<span class="lineNum"> 5179 </span> : * element from the first range is copied and both ranges advance. The -<span class="lineNum"> 5180 </span> : * output range may not overlap either input range. -<span class="lineNum"> 5181 </span> : */ -<span class="lineNum"> 5182 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5183 </span> : typename _OutputIterator> -<span class="lineNum"> 5184 </span> : _OutputIterator -<span class="lineNum"> 5185 </span> : set_intersection(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5186 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5187 </span><span class="lineCov"> 2 : _OutputIterator __result)</span> -<span class="lineNum"> 5188 </span> : { -<span class="lineNum"> 5189 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5190 </span> : _ValueType1; -<span class="lineNum"> 5191 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5192 </span> : _ValueType2; -<span class="lineNum"> 5193 </span> : -<span class="lineNum"> 5194 </span> : // concept requirements -<span class="lineNum"> 5195 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5196 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5197 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5198 </span> : _ValueType1>) -<span class="lineNum"> 5199 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType1, _ValueType2>) -<span class="lineNum"> 5200 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 5201 </span> : __glibcxx_requires_sorted_set(__first1, __last1, __first2); -<span class="lineNum"> 5202 </span> : __glibcxx_requires_sorted_set(__first2, __last2, __first1); -<span class="lineNum"> 5203 </span> : -<span class="lineNum"> 5204 </span><span class="lineCov"> 8 : while (__first1 != __last1 && __first2 != __last2)</span> -<span class="lineNum"> 5205 </span><span class="lineCov"> 4 : if (*__first1 < *__first2)</span> -<span class="lineNum"> 5206 </span><span class="lineCov"> 1 : ++__first1;</span> -<span class="lineNum"> 5207 </span><span class="lineCov"> 3 : else if (*__first2 < *__first1)</span> -<span class="lineNum"> 5208 </span><span class="lineCov"> 1 : ++__first2;</span> -<span class="lineNum"> 5209 </span> : else -<span class="lineNum"> 5210 </span> : { -<span class="lineNum"> 5211 </span><span class="lineCov"> 2 : *__result = *__first1;</span> -<span class="lineNum"> 5212 </span><span class="lineCov"> 2 : ++__first1;</span> -<span class="lineNum"> 5213 </span><span class="lineCov"> 2 : ++__first2;</span> -<span class="lineNum"> 5214 </span><span class="lineCov"> 2 : ++__result;</span> -<span class="lineNum"> 5215 </span> : } -<span class="lineNum"> 5216 </span><span class="lineCov"> 2 : return __result;</span> -<span class="lineNum"> 5217 </span> : } -<span class="lineNum"> 5218 </span> : -<span class="lineNum"> 5219 </span> : /** -<span class="lineNum"> 5220 </span> : * @brief Return the intersection of two sorted ranges using comparison -<span class="lineNum"> 5221 </span> : * functor. -<span class="lineNum"> 5222 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5223 </span> : * @param last1 End of first range. -<span class="lineNum"> 5224 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5225 </span> : * @param last2 End of second range. -<span class="lineNum"> 5226 </span> : * @param comp The comparison functor. -<span class="lineNum"> 5227 </span> : * @return End of the output range. -<span class="lineNum"> 5228 </span> : * @ingroup setoperations -<span class="lineNum"> 5229 </span> : * -<span class="lineNum"> 5230 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5231 </span> : * both ranges in order to the output range. Iterators increment for each -<span class="lineNum"> 5232 </span> : * range. When the current element of one range is less than the other -<span class="lineNum"> 5233 </span> : * according to @a comp, that iterator advances. If an element is -<span class="lineNum"> 5234 </span> : * contained in both ranges according to @a comp, the element from the -<span class="lineNum"> 5235 </span> : * first range is copied and both ranges advance. The output range may not -<span class="lineNum"> 5236 </span> : * overlap either input range. -<span class="lineNum"> 5237 </span> : */ -<span class="lineNum"> 5238 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5239 </span> : typename _OutputIterator, typename _Compare> -<span class="lineNum"> 5240 </span> : _OutputIterator -<span class="lineNum"> 5241 </span> : set_intersection(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5242 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5243 </span> : _OutputIterator __result, _Compare __comp) -<span class="lineNum"> 5244 </span> : { -<span class="lineNum"> 5245 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5246 </span> : _ValueType1; -<span class="lineNum"> 5247 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5248 </span> : _ValueType2; -<span class="lineNum"> 5249 </span> : -<span class="lineNum"> 5250 </span> : // concept requirements -<span class="lineNum"> 5251 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5252 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5253 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5254 </span> : _ValueType1>) -<span class="lineNum"> 5255 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5256 </span> : _ValueType1, _ValueType2>) -<span class="lineNum"> 5257 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5258 </span> : _ValueType2, _ValueType1>) -<span class="lineNum"> 5259 </span> : __glibcxx_requires_sorted_set_pred(__first1, __last1, __first2, __comp); -<span class="lineNum"> 5260 </span> : __glibcxx_requires_sorted_set_pred(__first2, __last2, __first1, __comp); -<span class="lineNum"> 5261 </span> : -<span class="lineNum"> 5262 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 5263 </span> : if (__comp(*__first1, *__first2)) -<span class="lineNum"> 5264 </span> : ++__first1; -<span class="lineNum"> 5265 </span> : else if (__comp(*__first2, *__first1)) -<span class="lineNum"> 5266 </span> : ++__first2; -<span class="lineNum"> 5267 </span> : else -<span class="lineNum"> 5268 </span> : { -<span class="lineNum"> 5269 </span> : *__result = *__first1; -<span class="lineNum"> 5270 </span> : ++__first1; -<span class="lineNum"> 5271 </span> : ++__first2; -<span class="lineNum"> 5272 </span> : ++__result; -<span class="lineNum"> 5273 </span> : } -<span class="lineNum"> 5274 </span> : return __result; -<span class="lineNum"> 5275 </span> : } -<span class="lineNum"> 5276 </span> : -<span class="lineNum"> 5277 </span> : /** -<span class="lineNum"> 5278 </span> : * @brief Return the difference of two sorted ranges. -<span class="lineNum"> 5279 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5280 </span> : * @param last1 End of first range. -<span class="lineNum"> 5281 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5282 </span> : * @param last2 End of second range. -<span class="lineNum"> 5283 </span> : * @return End of the output range. -<span class="lineNum"> 5284 </span> : * @ingroup setoperations -<span class="lineNum"> 5285 </span> : * -<span class="lineNum"> 5286 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5287 </span> : * the first range but not the second in order to the output range. -<span class="lineNum"> 5288 </span> : * Iterators increment for each range. When the current element of the -<span class="lineNum"> 5289 </span> : * first range is less than the second, that element is copied and the -<span class="lineNum"> 5290 </span> : * iterator advances. If the current element of the second range is less, -<span class="lineNum"> 5291 </span> : * the iterator advances, but no element is copied. If an element is -<span class="lineNum"> 5292 </span> : * contained in both ranges, no elements are copied and both ranges -<span class="lineNum"> 5293 </span> : * advance. The output range may not overlap either input range. -<span class="lineNum"> 5294 </span> : */ -<span class="lineNum"> 5295 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5296 </span> : typename _OutputIterator> -<span class="lineNum"> 5297 </span> : _OutputIterator -<span class="lineNum"> 5298 </span> : set_difference(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5299 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5300 </span><span class="lineCov"> 10 : _OutputIterator __result)</span> -<span class="lineNum"> 5301 </span> : { -<span class="lineNum"> 5302 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5303 </span> : _ValueType1; -<span class="lineNum"> 5304 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5305 </span> : _ValueType2; -<span class="lineNum"> 5306 </span> : -<span class="lineNum"> 5307 </span> : // concept requirements -<span class="lineNum"> 5308 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5309 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5310 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5311 </span> : _ValueType1>) -<span class="lineNum"> 5312 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType1, _ValueType2>) -<span class="lineNum"> 5313 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 5314 </span> : __glibcxx_requires_sorted_set(__first1, __last1, __first2); -<span class="lineNum"> 5315 </span> : __glibcxx_requires_sorted_set(__first2, __last2, __first1); -<span class="lineNum"> 5316 </span> : -<span class="lineNum"> 5317 </span><span class="lineCov"> 22 : while (__first1 != __last1 && __first2 != __last2)</span> -<span class="lineNum"> 5318 </span><span class="lineCov"> 2 : if (*__first1 < *__first2)</span> -<span class="lineNum"> 5319 </span> : { -<span class="lineNum"> 5320 </span><span class="lineCov"> 1 : *__result = *__first1;</span> -<span class="lineNum"> 5321 </span><span class="lineCov"> 1 : ++__first1;</span> -<span class="lineNum"> 5322 </span><span class="lineCov"> 1 : ++__result;</span> -<span class="lineNum"> 5323 </span> : } -<span class="lineNum"> 5324 </span><span class="lineCov"> 1 : else if (*__first2 < *__first1)</span> -<span class="lineNum"> 5325 </span><span class="lineNoCov"> 0 : ++__first2;</span> -<span class="lineNum"> 5326 </span> : else -<span class="lineNum"> 5327 </span> : { -<span class="lineNum"> 5328 </span><span class="lineCov"> 1 : ++__first1;</span> -<span class="lineNum"> 5329 </span><span class="lineCov"> 1 : ++__first2;</span> -<span class="lineNum"> 5330 </span> : } -<span class="lineNum"> 5331 </span><span class="lineCov"> 10 : return std::copy(__first1, __last1, __result);</span> -<span class="lineNum"> 5332 </span> : } -<span class="lineNum"> 5333 </span> : -<span class="lineNum"> 5334 </span> : /** -<span class="lineNum"> 5335 </span> : * @brief Return the difference of two sorted ranges using comparison -<span class="lineNum"> 5336 </span> : * functor. -<span class="lineNum"> 5337 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5338 </span> : * @param last1 End of first range. -<span class="lineNum"> 5339 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5340 </span> : * @param last2 End of second range. -<span class="lineNum"> 5341 </span> : * @param comp The comparison functor. -<span class="lineNum"> 5342 </span> : * @return End of the output range. -<span class="lineNum"> 5343 </span> : * @ingroup setoperations -<span class="lineNum"> 5344 </span> : * -<span class="lineNum"> 5345 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5346 </span> : * the first range but not the second in order to the output range. -<span class="lineNum"> 5347 </span> : * Iterators increment for each range. When the current element of the -<span class="lineNum"> 5348 </span> : * first range is less than the second according to @a comp, that element -<span class="lineNum"> 5349 </span> : * is copied and the iterator advances. If the current element of the -<span class="lineNum"> 5350 </span> : * second range is less, no element is copied and the iterator advances. -<span class="lineNum"> 5351 </span> : * If an element is contained in both ranges according to @a comp, no -<span class="lineNum"> 5352 </span> : * elements are copied and both ranges advance. The output range may not -<span class="lineNum"> 5353 </span> : * overlap either input range. -<span class="lineNum"> 5354 </span> : */ -<span class="lineNum"> 5355 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5356 </span> : typename _OutputIterator, typename _Compare> -<span class="lineNum"> 5357 </span> : _OutputIterator -<span class="lineNum"> 5358 </span> : set_difference(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5359 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5360 </span> : _OutputIterator __result, _Compare __comp) -<span class="lineNum"> 5361 </span> : { -<span class="lineNum"> 5362 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5363 </span> : _ValueType1; -<span class="lineNum"> 5364 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5365 </span> : _ValueType2; -<span class="lineNum"> 5366 </span> : -<span class="lineNum"> 5367 </span> : // concept requirements -<span class="lineNum"> 5368 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5369 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5370 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5371 </span> : _ValueType1>) -<span class="lineNum"> 5372 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5373 </span> : _ValueType1, _ValueType2>) -<span class="lineNum"> 5374 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5375 </span> : _ValueType2, _ValueType1>) -<span class="lineNum"> 5376 </span> : __glibcxx_requires_sorted_set_pred(__first1, __last1, __first2, __comp); -<span class="lineNum"> 5377 </span> : __glibcxx_requires_sorted_set_pred(__first2, __last2, __first1, __comp); -<span class="lineNum"> 5378 </span> : -<span class="lineNum"> 5379 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 5380 </span> : if (__comp(*__first1, *__first2)) -<span class="lineNum"> 5381 </span> : { -<span class="lineNum"> 5382 </span> : *__result = *__first1; -<span class="lineNum"> 5383 </span> : ++__first1; -<span class="lineNum"> 5384 </span> : ++__result; -<span class="lineNum"> 5385 </span> : } -<span class="lineNum"> 5386 </span> : else if (__comp(*__first2, *__first1)) -<span class="lineNum"> 5387 </span> : ++__first2; -<span class="lineNum"> 5388 </span> : else -<span class="lineNum"> 5389 </span> : { -<span class="lineNum"> 5390 </span> : ++__first1; -<span class="lineNum"> 5391 </span> : ++__first2; -<span class="lineNum"> 5392 </span> : } -<span class="lineNum"> 5393 </span> : return std::copy(__first1, __last1, __result); -<span class="lineNum"> 5394 </span> : } -<span class="lineNum"> 5395 </span> : -<span class="lineNum"> 5396 </span> : /** -<span class="lineNum"> 5397 </span> : * @brief Return the symmetric difference of two sorted ranges. -<span class="lineNum"> 5398 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5399 </span> : * @param last1 End of first range. -<span class="lineNum"> 5400 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5401 </span> : * @param last2 End of second range. -<span class="lineNum"> 5402 </span> : * @return End of the output range. -<span class="lineNum"> 5403 </span> : * @ingroup setoperations -<span class="lineNum"> 5404 </span> : * -<span class="lineNum"> 5405 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5406 </span> : * one range but not the other in order to the output range. Iterators -<span class="lineNum"> 5407 </span> : * increment for each range. When the current element of one range is less -<span class="lineNum"> 5408 </span> : * than the other, that element is copied and the iterator advances. If an -<span class="lineNum"> 5409 </span> : * element is contained in both ranges, no elements are copied and both -<span class="lineNum"> 5410 </span> : * ranges advance. The output range may not overlap either input range. -<span class="lineNum"> 5411 </span> : */ -<span class="lineNum"> 5412 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5413 </span> : typename _OutputIterator> -<span class="lineNum"> 5414 </span> : _OutputIterator -<span class="lineNum"> 5415 </span> : set_symmetric_difference(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5416 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5417 </span> : _OutputIterator __result) -<span class="lineNum"> 5418 </span> : { -<span class="lineNum"> 5419 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5420 </span> : _ValueType1; -<span class="lineNum"> 5421 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5422 </span> : _ValueType2; -<span class="lineNum"> 5423 </span> : -<span class="lineNum"> 5424 </span> : // concept requirements -<span class="lineNum"> 5425 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5426 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5427 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5428 </span> : _ValueType1>) -<span class="lineNum"> 5429 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5430 </span> : _ValueType2>) -<span class="lineNum"> 5431 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType1, _ValueType2>) -<span class="lineNum"> 5432 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 5433 </span> : __glibcxx_requires_sorted_set(__first1, __last1, __first2); -<span class="lineNum"> 5434 </span> : __glibcxx_requires_sorted_set(__first2, __last2, __first1); -<span class="lineNum"> 5435 </span> : -<span class="lineNum"> 5436 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 5437 </span> : if (*__first1 < *__first2) -<span class="lineNum"> 5438 </span> : { -<span class="lineNum"> 5439 </span> : *__result = *__first1; -<span class="lineNum"> 5440 </span> : ++__first1; -<span class="lineNum"> 5441 </span> : ++__result; -<span class="lineNum"> 5442 </span> : } -<span class="lineNum"> 5443 </span> : else if (*__first2 < *__first1) -<span class="lineNum"> 5444 </span> : { -<span class="lineNum"> 5445 </span> : *__result = *__first2; -<span class="lineNum"> 5446 </span> : ++__first2; -<span class="lineNum"> 5447 </span> : ++__result; -<span class="lineNum"> 5448 </span> : } -<span class="lineNum"> 5449 </span> : else -<span class="lineNum"> 5450 </span> : { -<span class="lineNum"> 5451 </span> : ++__first1; -<span class="lineNum"> 5452 </span> : ++__first2; -<span class="lineNum"> 5453 </span> : } -<span class="lineNum"> 5454 </span> : return std::copy(__first2, __last2, std::copy(__first1, -<span class="lineNum"> 5455 </span> : __last1, __result)); -<span class="lineNum"> 5456 </span> : } -<span class="lineNum"> 5457 </span> : -<span class="lineNum"> 5458 </span> : /** -<span class="lineNum"> 5459 </span> : * @brief Return the symmetric difference of two sorted ranges using -<span class="lineNum"> 5460 </span> : * comparison functor. -<span class="lineNum"> 5461 </span> : * @param first1 Start of first range. -<span class="lineNum"> 5462 </span> : * @param last1 End of first range. -<span class="lineNum"> 5463 </span> : * @param first2 Start of second range. -<span class="lineNum"> 5464 </span> : * @param last2 End of second range. -<span class="lineNum"> 5465 </span> : * @param comp The comparison functor. -<span class="lineNum"> 5466 </span> : * @return End of the output range. -<span class="lineNum"> 5467 </span> : * @ingroup setoperations -<span class="lineNum"> 5468 </span> : * -<span class="lineNum"> 5469 </span> : * This operation iterates over both ranges, copying elements present in -<span class="lineNum"> 5470 </span> : * one range but not the other in order to the output range. Iterators -<span class="lineNum"> 5471 </span> : * increment for each range. When the current element of one range is less -<span class="lineNum"> 5472 </span> : * than the other according to @a comp, that element is copied and the -<span class="lineNum"> 5473 </span> : * iterator advances. If an element is contained in both ranges according -<span class="lineNum"> 5474 </span> : * to @a comp, no elements are copied and both ranges advance. The output -<span class="lineNum"> 5475 </span> : * range may not overlap either input range. -<span class="lineNum"> 5476 </span> : */ -<span class="lineNum"> 5477 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 5478 </span> : typename _OutputIterator, typename _Compare> -<span class="lineNum"> 5479 </span> : _OutputIterator -<span class="lineNum"> 5480 </span> : set_symmetric_difference(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 5481 </span> : _InputIterator2 __first2, _InputIterator2 __last2, -<span class="lineNum"> 5482 </span> : _OutputIterator __result, -<span class="lineNum"> 5483 </span> : _Compare __comp) -<span class="lineNum"> 5484 </span> : { -<span class="lineNum"> 5485 </span> : typedef typename iterator_traits<_InputIterator1>::value_type -<span class="lineNum"> 5486 </span> : _ValueType1; -<span class="lineNum"> 5487 </span> : typedef typename iterator_traits<_InputIterator2>::value_type -<span class="lineNum"> 5488 </span> : _ValueType2; -<span class="lineNum"> 5489 </span> : -<span class="lineNum"> 5490 </span> : // concept requirements -<span class="lineNum"> 5491 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 5492 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 5493 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5494 </span> : _ValueType1>) -<span class="lineNum"> 5495 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OutputIterator, -<span class="lineNum"> 5496 </span> : _ValueType2>) -<span class="lineNum"> 5497 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5498 </span> : _ValueType1, _ValueType2>) -<span class="lineNum"> 5499 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5500 </span> : _ValueType2, _ValueType1>) -<span class="lineNum"> 5501 </span> : __glibcxx_requires_sorted_set_pred(__first1, __last1, __first2, __comp); -<span class="lineNum"> 5502 </span> : __glibcxx_requires_sorted_set_pred(__first2, __last2, __first1, __comp); -<span class="lineNum"> 5503 </span> : -<span class="lineNum"> 5504 </span> : while (__first1 != __last1 && __first2 != __last2) -<span class="lineNum"> 5505 </span> : if (__comp(*__first1, *__first2)) -<span class="lineNum"> 5506 </span> : { -<span class="lineNum"> 5507 </span> : *__result = *__first1; -<span class="lineNum"> 5508 </span> : ++__first1; -<span class="lineNum"> 5509 </span> : ++__result; -<span class="lineNum"> 5510 </span> : } -<span class="lineNum"> 5511 </span> : else if (__comp(*__first2, *__first1)) -<span class="lineNum"> 5512 </span> : { -<span class="lineNum"> 5513 </span> : *__result = *__first2; -<span class="lineNum"> 5514 </span> : ++__first2; -<span class="lineNum"> 5515 </span> : ++__result; -<span class="lineNum"> 5516 </span> : } -<span class="lineNum"> 5517 </span> : else -<span class="lineNum"> 5518 </span> : { -<span class="lineNum"> 5519 </span> : ++__first1; -<span class="lineNum"> 5520 </span> : ++__first2; -<span class="lineNum"> 5521 </span> : } -<span class="lineNum"> 5522 </span> : return std::copy(__first2, __last2, -<span class="lineNum"> 5523 </span> : std::copy(__first1, __last1, __result)); -<span class="lineNum"> 5524 </span> : } -<span class="lineNum"> 5525 </span> : -<span class="lineNum"> 5526 </span> : -<span class="lineNum"> 5527 </span> : /** -<span class="lineNum"> 5528 </span> : * @brief Return the minimum element in a range. -<span class="lineNum"> 5529 </span> : * @param first Start of range. -<span class="lineNum"> 5530 </span> : * @param last End of range. -<span class="lineNum"> 5531 </span> : * @return Iterator referencing the first instance of the smallest value. -<span class="lineNum"> 5532 </span> : */ -<span class="lineNum"> 5533 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 5534 </span> : _ForwardIterator -<span class="lineNum"> 5535 </span> : min_element(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 5536 </span> : { -<span class="lineNum"> 5537 </span> : // concept requirements -<span class="lineNum"> 5538 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 5539 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 5540 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 5541 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 5542 </span> : -<span class="lineNum"> 5543 </span> : if (__first == __last) -<span class="lineNum"> 5544 </span> : return __first; -<span class="lineNum"> 5545 </span> : _ForwardIterator __result = __first; -<span class="lineNum"> 5546 </span> : while (++__first != __last) -<span class="lineNum"> 5547 </span> : if (*__first < *__result) -<span class="lineNum"> 5548 </span> : __result = __first; -<span class="lineNum"> 5549 </span> : return __result; -<span class="lineNum"> 5550 </span> : } -<span class="lineNum"> 5551 </span> : -<span class="lineNum"> 5552 </span> : /** -<span class="lineNum"> 5553 </span> : * @brief Return the minimum element in a range using comparison functor. -<span class="lineNum"> 5554 </span> : * @param first Start of range. -<span class="lineNum"> 5555 </span> : * @param last End of range. -<span class="lineNum"> 5556 </span> : * @param comp Comparison functor. -<span class="lineNum"> 5557 </span> : * @return Iterator referencing the first instance of the smallest value -<span class="lineNum"> 5558 </span> : * according to comp. -<span class="lineNum"> 5559 </span> : */ -<span class="lineNum"> 5560 </span> : template<typename _ForwardIterator, typename _Compare> -<span class="lineNum"> 5561 </span> : _ForwardIterator -<span class="lineNum"> 5562 </span> : min_element(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 5563 </span> : _Compare __comp) -<span class="lineNum"> 5564 </span> : { -<span class="lineNum"> 5565 </span> : // concept requirements -<span class="lineNum"> 5566 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 5567 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5568 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 5569 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 5570 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 5571 </span> : -<span class="lineNum"> 5572 </span> : if (__first == __last) -<span class="lineNum"> 5573 </span> : return __first; -<span class="lineNum"> 5574 </span> : _ForwardIterator __result = __first; -<span class="lineNum"> 5575 </span> : while (++__first != __last) -<span class="lineNum"> 5576 </span> : if (__comp(*__first, *__result)) -<span class="lineNum"> 5577 </span> : __result = __first; -<span class="lineNum"> 5578 </span> : return __result; -<span class="lineNum"> 5579 </span> : } -<span class="lineNum"> 5580 </span> : -<span class="lineNum"> 5581 </span> : /** -<span class="lineNum"> 5582 </span> : * @brief Return the maximum element in a range. -<span class="lineNum"> 5583 </span> : * @param first Start of range. -<span class="lineNum"> 5584 </span> : * @param last End of range. -<span class="lineNum"> 5585 </span> : * @return Iterator referencing the first instance of the largest value. -<span class="lineNum"> 5586 </span> : */ -<span class="lineNum"> 5587 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 5588 </span> : _ForwardIterator -<span class="lineNum"> 5589 </span> : max_element(_ForwardIterator __first, _ForwardIterator __last) -<span class="lineNum"> 5590 </span> : { -<span class="lineNum"> 5591 </span> : // concept requirements -<span class="lineNum"> 5592 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 5593 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 5594 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 5595 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 5596 </span> : -<span class="lineNum"> 5597 </span> : if (__first == __last) -<span class="lineNum"> 5598 </span> : return __first; -<span class="lineNum"> 5599 </span> : _ForwardIterator __result = __first; -<span class="lineNum"> 5600 </span> : while (++__first != __last) -<span class="lineNum"> 5601 </span> : if (*__result < *__first) -<span class="lineNum"> 5602 </span> : __result = __first; -<span class="lineNum"> 5603 </span> : return __result; -<span class="lineNum"> 5604 </span> : } -<span class="lineNum"> 5605 </span> : -<span class="lineNum"> 5606 </span> : /** -<span class="lineNum"> 5607 </span> : * @brief Return the maximum element in a range using comparison functor. -<span class="lineNum"> 5608 </span> : * @param first Start of range. -<span class="lineNum"> 5609 </span> : * @param last End of range. -<span class="lineNum"> 5610 </span> : * @param comp Comparison functor. -<span class="lineNum"> 5611 </span> : * @return Iterator referencing the first instance of the largest value -<span class="lineNum"> 5612 </span> : * according to comp. -<span class="lineNum"> 5613 </span> : */ -<span class="lineNum"> 5614 </span> : template<typename _ForwardIterator, typename _Compare> -<span class="lineNum"> 5615 </span> : _ForwardIterator -<span class="lineNum"> 5616 </span> : max_element(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 5617 </span> : _Compare __comp) -<span class="lineNum"> 5618 </span> : { -<span class="lineNum"> 5619 </span> : // concept requirements -<span class="lineNum"> 5620 </span> : __glibcxx_function_requires(_ForwardIteratorConcept<_ForwardIterator>) -<span class="lineNum"> 5621 </span> : __glibcxx_function_requires(_BinaryPredicateConcept<_Compare, -<span class="lineNum"> 5622 </span> : typename iterator_traits<_ForwardIterator>::value_type, -<span class="lineNum"> 5623 </span> : typename iterator_traits<_ForwardIterator>::value_type>) -<span class="lineNum"> 5624 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 5625 </span> : -<span class="lineNum"> 5626 </span> : if (__first == __last) return __first; -<span class="lineNum"> 5627 </span> : _ForwardIterator __result = __first; -<span class="lineNum"> 5628 </span> : while (++__first != __last) -<span class="lineNum"> 5629 </span> : if (__comp(*__result, *__first)) -<span class="lineNum"> 5630 </span> : __result = __first; -<span class="lineNum"> 5631 </span> : return __result; -<span class="lineNum"> 5632 </span> : } -<span class="lineNum"> 5633 </span> : -<span class="lineNum"> 5634 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 5635 </span> : -<span class="lineNum"> 5636 </span> : #endif /* _STL_ALGO_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_algobase.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_algobase.h.gcov.html deleted file mode 100644 index 3535447..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_algobase.h.gcov.html +++ /dev/null @@ -1,1207 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_algobase.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_algobase.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">79</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">91.1 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">72</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Core algorithmic facilities -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996-1998 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_algobase.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_ALGOBASE_H -<span class="lineNum"> 63 </span> : #define _STL_ALGOBASE_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/c++config.h> -<span class="lineNum"> 66 </span> : #include <cstddef> -<span class="lineNum"> 67 </span> : #include <bits/functexcept.h> -<span class="lineNum"> 68 </span> : #include <bits/cpp_type_traits.h> -<span class="lineNum"> 69 </span> : #include <ext/type_traits.h> -<span class="lineNum"> 70 </span> : #include <ext/numeric_traits.h> -<span class="lineNum"> 71 </span> : #include <bits/stl_pair.h> -<span class="lineNum"> 72 </span> : #include <bits/stl_iterator_base_types.h> -<span class="lineNum"> 73 </span> : #include <bits/stl_iterator_base_funcs.h> -<span class="lineNum"> 74 </span> : #include <bits/stl_iterator.h> -<span class="lineNum"> 75 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 76 </span> : #include <debug/debug.h> -<span class="lineNum"> 77 </span> : #include <bits/stl_move.h> // For std::swap and _GLIBCXX_MOVE -<span class="lineNum"> 78 </span> : -<span class="lineNum"> 79 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 80 </span> : -<span class="lineNum"> 81 </span> : // See http://gcc.gnu.org/ml/libstdc++/2004-08/msg00167.html: in a -<span class="lineNum"> 82 </span> : // nutshell, we are partially implementing the resolution of DR 187, -<span class="lineNum"> 83 </span> : // when it's safe, i.e., the value_types are equal. -<span class="lineNum"> 84 </span> : template<bool _BoolType> -<span class="lineNum"> 85 </span> : struct __iter_swap -<span class="lineNum"> 86 </span> : { -<span class="lineNum"> 87 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 88 </span> : static void -<span class="lineNum"> 89 </span> : iter_swap(_ForwardIterator1 __a, _ForwardIterator2 __b) -<span class="lineNum"> 90 </span> : { -<span class="lineNum"> 91 </span> : typedef typename iterator_traits<_ForwardIterator1>::value_type -<span class="lineNum"> 92 </span> : _ValueType1; -<span class="lineNum"> 93 </span> : _ValueType1 __tmp = _GLIBCXX_MOVE(*__a); -<span class="lineNum"> 94 </span> : *__a = _GLIBCXX_MOVE(*__b); -<span class="lineNum"> 95 </span> : *__b = _GLIBCXX_MOVE(__tmp); -<span class="lineNum"> 96 </span> : } -<span class="lineNum"> 97 </span> : }; -<span class="lineNum"> 98 </span> : -<span class="lineNum"> 99 </span> : template<> -<span class="lineNum"> 100 </span> : struct __iter_swap<true> -<span class="lineNum"> 101 </span> : { -<span class="lineNum"> 102 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 103 </span> : static void -<span class="lineNum"> 104 </span><span class="lineCov"> 7080 : iter_swap(_ForwardIterator1 __a, _ForwardIterator2 __b)</span> -<span class="lineNum"> 105 </span> : { -<span class="lineNum"> 106 </span><span class="lineCov"> 7080 : swap(*__a, *__b);</span> -<span class="lineNum"> 107 </span><span class="lineCov"> 7080 : }</span> -<span class="lineNum"> 108 </span> : }; -<span class="lineNum"> 109 </span> : -<span class="lineNum"> 110 </span> : /** -<span class="lineNum"> 111 </span> : * @brief Swaps the contents of two iterators. -<span class="lineNum"> 112 </span> : * @param a An iterator. -<span class="lineNum"> 113 </span> : * @param b Another iterator. -<span class="lineNum"> 114 </span> : * @return Nothing. -<span class="lineNum"> 115 </span> : * -<span class="lineNum"> 116 </span> : * This function swaps the values pointed to by two iterators, not the -<span class="lineNum"> 117 </span> : * iterators themselves. -<span class="lineNum"> 118 </span> : */ -<span class="lineNum"> 119 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 120 </span> : inline void -<span class="lineNum"> 121 </span><span class="lineCov"> 7080 : iter_swap(_ForwardIterator1 __a, _ForwardIterator2 __b)</span> -<span class="lineNum"> 122 </span> : { -<span class="lineNum"> 123 </span> : typedef typename iterator_traits<_ForwardIterator1>::value_type -<span class="lineNum"> 124 </span> : _ValueType1; -<span class="lineNum"> 125 </span> : typedef typename iterator_traits<_ForwardIterator2>::value_type -<span class="lineNum"> 126 </span> : _ValueType2; -<span class="lineNum"> 127 </span> : -<span class="lineNum"> 128 </span> : // concept requirements -<span class="lineNum"> 129 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 130 </span> : _ForwardIterator1>) -<span class="lineNum"> 131 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 132 </span> : _ForwardIterator2>) -<span class="lineNum"> 133 </span> : __glibcxx_function_requires(_ConvertibleConcept<_ValueType1, -<span class="lineNum"> 134 </span> : _ValueType2>) -<span class="lineNum"> 135 </span> : __glibcxx_function_requires(_ConvertibleConcept<_ValueType2, -<span class="lineNum"> 136 </span> : _ValueType1>) -<span class="lineNum"> 137 </span> : -<span class="lineNum"> 138 </span> : typedef typename iterator_traits<_ForwardIterator1>::reference -<span class="lineNum"> 139 </span> : _ReferenceType1; -<span class="lineNum"> 140 </span> : typedef typename iterator_traits<_ForwardIterator2>::reference -<span class="lineNum"> 141 </span> : _ReferenceType2; -<span class="lineNum"> 142 </span><span class="lineCov"> 7080 : std::__iter_swap<__are_same<_ValueType1, _ValueType2>::__value</span> -<span class="lineNum"> 143 </span> : && __are_same<_ValueType1&, _ReferenceType1>::__value -<span class="lineNum"> 144 </span> : && __are_same<_ValueType2&, _ReferenceType2>::__value>:: -<span class="lineNum"> 145 </span> : iter_swap(__a, __b); -<span class="lineNum"> 146 </span><span class="lineCov"> 7080 : }</span> -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : /** -<span class="lineNum"> 149 </span> : * @brief Swap the elements of two sequences. -<span class="lineNum"> 150 </span> : * @param first1 A forward iterator. -<span class="lineNum"> 151 </span> : * @param last1 A forward iterator. -<span class="lineNum"> 152 </span> : * @param first2 A forward iterator. -<span class="lineNum"> 153 </span> : * @return An iterator equal to @p first2+(last1-first1). -<span class="lineNum"> 154 </span> : * -<span class="lineNum"> 155 </span> : * Swaps each element in the range @p [first1,last1) with the -<span class="lineNum"> 156 </span> : * corresponding element in the range @p [first2,(last1-first1)). -<span class="lineNum"> 157 </span> : * The ranges must not overlap. -<span class="lineNum"> 158 </span> : */ -<span class="lineNum"> 159 </span> : template<typename _ForwardIterator1, typename _ForwardIterator2> -<span class="lineNum"> 160 </span> : _ForwardIterator2 -<span class="lineNum"> 161 </span> : swap_ranges(_ForwardIterator1 __first1, _ForwardIterator1 __last1, -<span class="lineNum"> 162 </span> : _ForwardIterator2 __first2) -<span class="lineNum"> 163 </span> : { -<span class="lineNum"> 164 </span> : // concept requirements -<span class="lineNum"> 165 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 166 </span> : _ForwardIterator1>) -<span class="lineNum"> 167 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 168 </span> : _ForwardIterator2>) -<span class="lineNum"> 169 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : for (; __first1 != __last1; ++__first1, ++__first2) -<span class="lineNum"> 172 </span> : std::iter_swap(__first1, __first2); -<span class="lineNum"> 173 </span> : return __first2; -<span class="lineNum"> 174 </span> : } -<span class="lineNum"> 175 </span> : -<span class="lineNum"> 176 </span> : /** -<span class="lineNum"> 177 </span> : * @brief This does what you think it does. -<span class="lineNum"> 178 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 179 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 180 </span> : * @return The lesser of the parameters. -<span class="lineNum"> 181 </span> : * -<span class="lineNum"> 182 </span> : * This is the simple classic generic implementation. It will work on -<span class="lineNum"> 183 </span> : * temporary expressions, since they are only evaluated once, unlike a -<span class="lineNum"> 184 </span> : * preprocessor macro. -<span class="lineNum"> 185 </span> : */ -<span class="lineNum"> 186 </span> : template<typename _Tp> -<span class="lineNum"> 187 </span> : inline const _Tp& -<span class="lineNum"> 188 </span><span class="lineNoCov"> 0 : min(const _Tp& __a, const _Tp& __b)</span> -<span class="lineNum"> 189 </span> : { -<span class="lineNum"> 190 </span> : // concept requirements -<span class="lineNum"> 191 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_Tp>) -<span class="lineNum"> 192 </span> : //return __b < __a ? __b : __a; -<span class="lineNum"> 193 </span><span class="lineNoCov"> 0 : if (__b < __a)</span> -<span class="lineNum"> 194 </span><span class="lineNoCov"> 0 : return __b;</span> -<span class="lineNum"> 195 </span><span class="lineNoCov"> 0 : return __a;</span> -<span class="lineNum"> 196 </span> : } -<span class="lineNum"> 197 </span> : -<span class="lineNum"> 198 </span> : /** -<span class="lineNum"> 199 </span> : * @brief This does what you think it does. -<span class="lineNum"> 200 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 201 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 202 </span> : * @return The greater of the parameters. -<span class="lineNum"> 203 </span> : * -<span class="lineNum"> 204 </span> : * This is the simple classic generic implementation. It will work on -<span class="lineNum"> 205 </span> : * temporary expressions, since they are only evaluated once, unlike a -<span class="lineNum"> 206 </span> : * preprocessor macro. -<span class="lineNum"> 207 </span> : */ -<span class="lineNum"> 208 </span> : template<typename _Tp> -<span class="lineNum"> 209 </span> : inline const _Tp& -<span class="lineNum"> 210 </span><span class="lineCov"> 20743 : max(const _Tp& __a, const _Tp& __b)</span> -<span class="lineNum"> 211 </span> : { -<span class="lineNum"> 212 </span> : // concept requirements -<span class="lineNum"> 213 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_Tp>) -<span class="lineNum"> 214 </span> : //return __a < __b ? __b : __a; -<span class="lineNum"> 215 </span><span class="lineCov"> 20743 : if (__a < __b)</span> -<span class="lineNum"> 216 </span><span class="lineCov"> 4790 : return __b;</span> -<span class="lineNum"> 217 </span><span class="lineCov"> 15953 : return __a;</span> -<span class="lineNum"> 218 </span> : } -<span class="lineNum"> 219 </span> : -<span class="lineNum"> 220 </span> : /** -<span class="lineNum"> 221 </span> : * @brief This does what you think it does. -<span class="lineNum"> 222 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 223 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 224 </span> : * @param comp A @link s20_3_3_comparisons comparison functor@endlink. -<span class="lineNum"> 225 </span> : * @return The lesser of the parameters. -<span class="lineNum"> 226 </span> : * -<span class="lineNum"> 227 </span> : * This will work on temporary expressions, since they are only evaluated -<span class="lineNum"> 228 </span> : * once, unlike a preprocessor macro. -<span class="lineNum"> 229 </span> : */ -<span class="lineNum"> 230 </span> : template<typename _Tp, typename _Compare> -<span class="lineNum"> 231 </span> : inline const _Tp& -<span class="lineNum"> 232 </span> : min(const _Tp& __a, const _Tp& __b, _Compare __comp) -<span class="lineNum"> 233 </span> : { -<span class="lineNum"> 234 </span> : //return __comp(__b, __a) ? __b : __a; -<span class="lineNum"> 235 </span> : if (__comp(__b, __a)) -<span class="lineNum"> 236 </span> : return __b; -<span class="lineNum"> 237 </span> : return __a; -<span class="lineNum"> 238 </span> : } -<span class="lineNum"> 239 </span> : -<span class="lineNum"> 240 </span> : /** -<span class="lineNum"> 241 </span> : * @brief This does what you think it does. -<span class="lineNum"> 242 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 243 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 244 </span> : * @param comp A @link s20_3_3_comparisons comparison functor@endlink. -<span class="lineNum"> 245 </span> : * @return The greater of the parameters. -<span class="lineNum"> 246 </span> : * -<span class="lineNum"> 247 </span> : * This will work on temporary expressions, since they are only evaluated -<span class="lineNum"> 248 </span> : * once, unlike a preprocessor macro. -<span class="lineNum"> 249 </span> : */ -<span class="lineNum"> 250 </span> : template<typename _Tp, typename _Compare> -<span class="lineNum"> 251 </span> : inline const _Tp& -<span class="lineNum"> 252 </span> : max(const _Tp& __a, const _Tp& __b, _Compare __comp) -<span class="lineNum"> 253 </span> : { -<span class="lineNum"> 254 </span> : //return __comp(__a, __b) ? __b : __a; -<span class="lineNum"> 255 </span> : if (__comp(__a, __b)) -<span class="lineNum"> 256 </span> : return __b; -<span class="lineNum"> 257 </span> : return __a; -<span class="lineNum"> 258 </span> : } -<span class="lineNum"> 259 </span> : -<span class="lineNum"> 260 </span> : -<span class="lineNum"> 261 </span> : // If _Iterator is a __normal_iterator return its base (a plain pointer, -<span class="lineNum"> 262 </span> : // normally) otherwise return it untouched. See copy, fill, ... -<span class="lineNum"> 263 </span> : template<typename _Iterator, -<span class="lineNum"> 264 </span> : bool _IsNormal = __is_normal_iterator<_Iterator>::__value> -<span class="lineNum"> 265 </span> : struct __niter_base -<span class="lineNum"> 266 </span> : { -<span class="lineNum"> 267 </span> : static _Iterator -<span class="lineNum"> 268 </span><span class="lineCov"> 256058 : __b(_Iterator __it)</span> -<span class="lineNum"> 269 </span><span class="lineCov"> 256058 : { return __it; }</span> -<span class="lineNum"> 270 </span> : }; -<span class="lineNum"> 271 </span> : -<span class="lineNum"> 272 </span> : template<typename _Iterator> -<span class="lineNum"> 273 </span> : struct __niter_base<_Iterator, true> -<span class="lineNum"> 274 </span> : { -<span class="lineNum"> 275 </span> : static typename _Iterator::iterator_type -<span class="lineNum"> 276 </span><span class="lineCov"> 23362 : __b(_Iterator __it)</span> -<span class="lineNum"> 277 </span><span class="lineCov"> 23362 : { return __it.base(); }</span> -<span class="lineNum"> 278 </span> : }; -<span class="lineNum"> 279 </span> : -<span class="lineNum"> 280 </span> : // Likewise, for move_iterator. -<span class="lineNum"> 281 </span> : template<typename _Iterator, -<span class="lineNum"> 282 </span> : bool _IsMove = __is_move_iterator<_Iterator>::__value> -<span class="lineNum"> 283 </span> : struct __miter_base -<span class="lineNum"> 284 </span> : { -<span class="lineNum"> 285 </span> : static _Iterator -<span class="lineNum"> 286 </span><span class="lineCov"> 156418 : __b(_Iterator __it)</span> -<span class="lineNum"> 287 </span><span class="lineCov"> 156418 : { return __it; }</span> -<span class="lineNum"> 288 </span> : }; -<span class="lineNum"> 289 </span> : -<span class="lineNum"> 290 </span> : template<typename _Iterator> -<span class="lineNum"> 291 </span> : struct __miter_base<_Iterator, true> -<span class="lineNum"> 292 </span> : { -<span class="lineNum"> 293 </span> : static typename _Iterator::iterator_type -<span class="lineNum"> 294 </span> : __b(_Iterator __it) -<span class="lineNum"> 295 </span> : { return __it.base(); } -<span class="lineNum"> 296 </span> : }; -<span class="lineNum"> 297 </span> : -<span class="lineNum"> 298 </span> : // All of these auxiliary structs serve two purposes. (1) Replace -<span class="lineNum"> 299 </span> : // calls to copy with memmove whenever possible. (Memmove, not memcpy, -<span class="lineNum"> 300 </span> : // because the input and output ranges are permitted to overlap.) -<span class="lineNum"> 301 </span> : // (2) If we're using random access iterators, then write the loop as -<span class="lineNum"> 302 </span> : // a for loop with an explicit count. -<span class="lineNum"> 303 </span> : -<span class="lineNum"> 304 </span> : template<bool, bool, typename> -<span class="lineNum"> 305 </span> : struct __copy_move -<span class="lineNum"> 306 </span> : { -<span class="lineNum"> 307 </span> : template<typename _II, typename _OI> -<span class="lineNum"> 308 </span> : static _OI -<span class="lineNum"> 309 </span><span class="lineCov"> 42335 : __copy_m(_II __first, _II __last, _OI __result)</span> -<span class="lineNum"> 310 </span> : { -<span class="lineNum"> 311 </span><span class="lineCov"> 159330 : for (; __first != __last; ++__result, ++__first)</span> -<span class="lineNum"> 312 </span><span class="lineCov"> 112959 : *__result = *__first;</span> -<span class="lineNum"> 313 </span><span class="lineCov"> 42335 : return __result;</span> -<span class="lineNum"> 314 </span> : } -<span class="lineNum"> 315 </span> : }; -<span class="lineNum"> 316 </span> : -<span class="lineNum"> 317 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 318 </span> : template<typename _Category> -<span class="lineNum"> 319 </span> : struct __copy_move<true, false, _Category> -<span class="lineNum"> 320 </span> : { -<span class="lineNum"> 321 </span> : template<typename _II, typename _OI> -<span class="lineNum"> 322 </span> : static _OI -<span class="lineNum"> 323 </span> : __copy_m(_II __first, _II __last, _OI __result) -<span class="lineNum"> 324 </span> : { -<span class="lineNum"> 325 </span> : for (; __first != __last; ++__result, ++__first) -<span class="lineNum"> 326 </span> : *__result = std::move(*__first); -<span class="lineNum"> 327 </span> : return __result; -<span class="lineNum"> 328 </span> : } -<span class="lineNum"> 329 </span> : }; -<span class="lineNum"> 330 </span> : #endif -<span class="lineNum"> 331 </span> : -<span class="lineNum"> 332 </span> : template<> -<span class="lineNum"> 333 </span> : struct __copy_move<false, false, random_access_iterator_tag> -<span class="lineNum"> 334 </span> : { -<span class="lineNum"> 335 </span> : template<typename _II, typename _OI> -<span class="lineNum"> 336 </span> : static _OI -<span class="lineNum"> 337 </span><span class="lineCov"> 945 : __copy_m(_II __first, _II __last, _OI __result)</span> -<span class="lineNum"> 338 </span> : { -<span class="lineNum"> 339 </span> : typedef typename iterator_traits<_II>::difference_type _Distance; -<span class="lineNum"> 340 </span><span class="lineCov"> 12957 : for(_Distance __n = __last - __first; __n > 0; --__n)</span> -<span class="lineNum"> 341 </span> : { -<span class="lineNum"> 342 </span><span class="lineCov"> 12012 : *__result = *__first;</span> -<span class="lineNum"> 343 </span><span class="lineCov"> 12012 : ++__first;</span> -<span class="lineNum"> 344 </span><span class="lineCov"> 12012 : ++__result;</span> -<span class="lineNum"> 345 </span> : } -<span class="lineNum"> 346 </span><span class="lineCov"> 945 : return __result;</span> -<span class="lineNum"> 347 </span> : } -<span class="lineNum"> 348 </span> : }; -<span class="lineNum"> 349 </span> : -<span class="lineNum"> 350 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 351 </span> : template<> -<span class="lineNum"> 352 </span> : struct __copy_move<true, false, random_access_iterator_tag> -<span class="lineNum"> 353 </span> : { -<span class="lineNum"> 354 </span> : template<typename _II, typename _OI> -<span class="lineNum"> 355 </span> : static _OI -<span class="lineNum"> 356 </span> : __copy_m(_II __first, _II __last, _OI __result) -<span class="lineNum"> 357 </span> : { -<span class="lineNum"> 358 </span> : typedef typename iterator_traits<_II>::difference_type _Distance; -<span class="lineNum"> 359 </span> : for(_Distance __n = __last - __first; __n > 0; --__n) -<span class="lineNum"> 360 </span> : { -<span class="lineNum"> 361 </span> : *__result = std::move(*__first); -<span class="lineNum"> 362 </span> : ++__first; -<span class="lineNum"> 363 </span> : ++__result; -<span class="lineNum"> 364 </span> : } -<span class="lineNum"> 365 </span> : return __result; -<span class="lineNum"> 366 </span> : } -<span class="lineNum"> 367 </span> : }; -<span class="lineNum"> 368 </span> : #endif -<span class="lineNum"> 369 </span> : -<span class="lineNum"> 370 </span> : template<bool _IsMove> -<span class="lineNum"> 371 </span> : struct __copy_move<_IsMove, true, random_access_iterator_tag> -<span class="lineNum"> 372 </span> : { -<span class="lineNum"> 373 </span> : template<typename _Tp> -<span class="lineNum"> 374 </span> : static _Tp* -<span class="lineNum"> 375 </span><span class="lineCov"> 27153 : __copy_m(const _Tp* __first, const _Tp* __last, _Tp* __result)</span> -<span class="lineNum"> 376 </span> : { -<span class="lineNum"> 377 </span><span class="lineCov"> 27153 : __builtin_memmove(__result, __first,</span> -<span class="lineNum"> 378 </span> : sizeof(_Tp) * (__last - __first)); -<span class="lineNum"> 379 </span><span class="lineCov"> 27153 : return __result + (__last - __first);</span> -<span class="lineNum"> 380 </span> : } -<span class="lineNum"> 381 </span> : }; -<span class="lineNum"> 382 </span> : -<span class="lineNum"> 383 </span> : template<bool _IsMove, typename _II, typename _OI> -<span class="lineNum"> 384 </span> : inline _OI -<span class="lineNum"> 385 </span><span class="lineCov"> 70433 : __copy_move_a(_II __first, _II __last, _OI __result)</span> -<span class="lineNum"> 386 </span> : { -<span class="lineNum"> 387 </span> : typedef typename iterator_traits<_II>::value_type _ValueTypeI; -<span class="lineNum"> 388 </span> : typedef typename iterator_traits<_OI>::value_type _ValueTypeO; -<span class="lineNum"> 389 </span> : typedef typename iterator_traits<_II>::iterator_category _Category; -<span class="lineNum"> 390 </span> : const bool __simple = (__is_pod(_ValueTypeI) -<span class="lineNum"> 391 </span> : && __is_pointer<_II>::__value -<span class="lineNum"> 392 </span> : && __is_pointer<_OI>::__value -<span class="lineNum"> 393 </span><span class="lineCov"> 70433 : && __are_same<_ValueTypeI, _ValueTypeO>::__value);</span> -<span class="lineNum"> 394 </span> : -<span class="lineNum"> 395 </span> : return std::__copy_move<_IsMove, __simple, -<span class="lineNum"> 396 </span><span class="lineCov"> 70433 : _Category>::__copy_m(__first, __last, __result);</span> -<span class="lineNum"> 397 </span> : } -<span class="lineNum"> 398 </span> : -<span class="lineNum"> 399 </span> : // Helpers for streambuf iterators (either istream or ostream). -<span class="lineNum"> 400 </span> : // NB: avoid including <iosfwd>, relatively large. -<span class="lineNum"> 401 </span> : template<typename _CharT> -<span class="lineNum"> 402 </span> : struct char_traits; -<span class="lineNum"> 403 </span> : -<span class="lineNum"> 404 </span> : template<typename _CharT, typename _Traits> -<span class="lineNum"> 405 </span> : class istreambuf_iterator; -<span class="lineNum"> 406 </span> : -<span class="lineNum"> 407 </span> : template<typename _CharT, typename _Traits> -<span class="lineNum"> 408 </span> : class ostreambuf_iterator; -<span class="lineNum"> 409 </span> : -<span class="lineNum"> 410 </span> : template<bool _IsMove, typename _CharT> -<span class="lineNum"> 411 </span> : typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, -<span class="lineNum"> 412 </span> : ostreambuf_iterator<_CharT, char_traits<_CharT> > >::__type -<span class="lineNum"> 413 </span> : __copy_move_a2(_CharT*, _CharT*, -<span class="lineNum"> 414 </span> : ostreambuf_iterator<_CharT, char_traits<_CharT> >); -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span> : template<bool _IsMove, typename _CharT> -<span class="lineNum"> 417 </span> : typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, -<span class="lineNum"> 418 </span> : ostreambuf_iterator<_CharT, char_traits<_CharT> > >::__type -<span class="lineNum"> 419 </span> : __copy_move_a2(const _CharT*, const _CharT*, -<span class="lineNum"> 420 </span> : ostreambuf_iterator<_CharT, char_traits<_CharT> >); -<span class="lineNum"> 421 </span> : -<span class="lineNum"> 422 </span> : template<bool _IsMove, typename _CharT> -<span class="lineNum"> 423 </span> : typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, -<span class="lineNum"> 424 </span> : _CharT*>::__type -<span class="lineNum"> 425 </span> : __copy_move_a2(istreambuf_iterator<_CharT, char_traits<_CharT> >, -<span class="lineNum"> 426 </span> : istreambuf_iterator<_CharT, char_traits<_CharT> >, _CharT*); -<span class="lineNum"> 427 </span> : -<span class="lineNum"> 428 </span> : template<bool _IsMove, typename _II, typename _OI> -<span class="lineNum"> 429 </span> : inline _OI -<span class="lineNum"> 430 </span><span class="lineCov"> 70433 : __copy_move_a2(_II __first, _II __last, _OI __result)</span> -<span class="lineNum"> 431 </span> : { -<span class="lineNum"> 432 </span> : return _OI(std::__copy_move_a<_IsMove> -<span class="lineNum"> 433 </span> : (std::__niter_base<_II>::__b(__first), -<span class="lineNum"> 434 </span> : std::__niter_base<_II>::__b(__last), -<span class="lineNum"> 435 </span><span class="lineCov"> 70433 : std::__niter_base<_OI>::__b(__result)));</span> -<span class="lineNum"> 436 </span> : } -<span class="lineNum"> 437 </span> : -<span class="lineNum"> 438 </span> : /** -<span class="lineNum"> 439 </span> : * @brief Copies the range [first,last) into result. -<span class="lineNum"> 440 </span> : * @param first An input iterator. -<span class="lineNum"> 441 </span> : * @param last An input iterator. -<span class="lineNum"> 442 </span> : * @param result An output iterator. -<span class="lineNum"> 443 </span> : * @return result + (first - last) -<span class="lineNum"> 444 </span> : * -<span class="lineNum"> 445 </span> : * This inline function will boil down to a call to @c memmove whenever -<span class="lineNum"> 446 </span> : * possible. Failing that, if random access iterators are passed, then the -<span class="lineNum"> 447 </span> : * loop count will be known (and therefore a candidate for compiler -<span class="lineNum"> 448 </span> : * optimizations such as unrolling). Result may not be contained within -<span class="lineNum"> 449 </span> : * [first,last); the copy_backward function should be used instead. -<span class="lineNum"> 450 </span> : * -<span class="lineNum"> 451 </span> : * Note that the end of the output range is permitted to be contained -<span class="lineNum"> 452 </span> : * within [first,last). -<span class="lineNum"> 453 </span> : */ -<span class="lineNum"> 454 </span> : template<typename _II, typename _OI> -<span class="lineNum"> 455 </span> : inline _OI -<span class="lineNum"> 456 </span><span class="lineCov"> 70433 : copy(_II __first, _II __last, _OI __result)</span> -<span class="lineNum"> 457 </span> : { -<span class="lineNum"> 458 </span> : // concept requirements -<span class="lineNum"> 459 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II>) -<span class="lineNum"> 460 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OI, -<span class="lineNum"> 461 </span> : typename iterator_traits<_II>::value_type>) -<span class="lineNum"> 462 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 463 </span> : -<span class="lineNum"> 464 </span> : return (std::__copy_move_a2<__is_move_iterator<_II>::__value> -<span class="lineNum"> 465 </span> : (std::__miter_base<_II>::__b(__first), -<span class="lineNum"> 466 </span><span class="lineCov"> 70433 : std::__miter_base<_II>::__b(__last), __result));</span> -<span class="lineNum"> 467 </span> : } -<span class="lineNum"> 468 </span> : -<span class="lineNum"> 469 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 470 </span> : /** -<span class="lineNum"> 471 </span> : * @brief Moves the range [first,last) into result. -<span class="lineNum"> 472 </span> : * @param first An input iterator. -<span class="lineNum"> 473 </span> : * @param last An input iterator. -<span class="lineNum"> 474 </span> : * @param result An output iterator. -<span class="lineNum"> 475 </span> : * @return result + (first - last) -<span class="lineNum"> 476 </span> : * -<span class="lineNum"> 477 </span> : * This inline function will boil down to a call to @c memmove whenever -<span class="lineNum"> 478 </span> : * possible. Failing that, if random access iterators are passed, then the -<span class="lineNum"> 479 </span> : * loop count will be known (and therefore a candidate for compiler -<span class="lineNum"> 480 </span> : * optimizations such as unrolling). Result may not be contained within -<span class="lineNum"> 481 </span> : * [first,last); the move_backward function should be used instead. -<span class="lineNum"> 482 </span> : * -<span class="lineNum"> 483 </span> : * Note that the end of the output range is permitted to be contained -<span class="lineNum"> 484 </span> : * within [first,last). -<span class="lineNum"> 485 </span> : */ -<span class="lineNum"> 486 </span> : template<typename _II, typename _OI> -<span class="lineNum"> 487 </span> : inline _OI -<span class="lineNum"> 488 </span> : move(_II __first, _II __last, _OI __result) -<span class="lineNum"> 489 </span> : { -<span class="lineNum"> 490 </span> : // concept requirements -<span class="lineNum"> 491 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II>) -<span class="lineNum"> 492 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OI, -<span class="lineNum"> 493 </span> : typename iterator_traits<_II>::value_type>) -<span class="lineNum"> 494 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 495 </span> : -<span class="lineNum"> 496 </span> : return (std::__copy_move_a2<true> -<span class="lineNum"> 497 </span> : (std::__miter_base<_II>::__b(__first), -<span class="lineNum"> 498 </span> : std::__miter_base<_II>::__b(__last), __result)); -<span class="lineNum"> 499 </span> : } -<span class="lineNum"> 500 </span> : -<span class="lineNum"> 501 </span> : #define _GLIBCXX_MOVE3(_Tp, _Up, _Vp) std::move(_Tp, _Up, _Vp) -<span class="lineNum"> 502 </span> : #else -<span class="lineNum"> 503 </span> : #define _GLIBCXX_MOVE3(_Tp, _Up, _Vp) std::copy(_Tp, _Up, _Vp) -<span class="lineNum"> 504 </span> : #endif -<span class="lineNum"> 505 </span> : -<span class="lineNum"> 506 </span> : template<bool, bool, typename> -<span class="lineNum"> 507 </span> : struct __copy_move_backward -<span class="lineNum"> 508 </span> : { -<span class="lineNum"> 509 </span> : template<typename _BI1, typename _BI2> -<span class="lineNum"> 510 </span> : static _BI2 -<span class="lineNum"> 511 </span> : __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) -<span class="lineNum"> 512 </span> : { -<span class="lineNum"> 513 </span> : while (__first != __last) -<span class="lineNum"> 514 </span> : *--__result = *--__last; -<span class="lineNum"> 515 </span> : return __result; -<span class="lineNum"> 516 </span> : } -<span class="lineNum"> 517 </span> : }; -<span class="lineNum"> 518 </span> : -<span class="lineNum"> 519 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 520 </span> : template<typename _Category> -<span class="lineNum"> 521 </span> : struct __copy_move_backward<true, false, _Category> -<span class="lineNum"> 522 </span> : { -<span class="lineNum"> 523 </span> : template<typename _BI1, typename _BI2> -<span class="lineNum"> 524 </span> : static _BI2 -<span class="lineNum"> 525 </span> : __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) -<span class="lineNum"> 526 </span> : { -<span class="lineNum"> 527 </span> : while (__first != __last) -<span class="lineNum"> 528 </span> : *--__result = std::move(*--__last); -<span class="lineNum"> 529 </span> : return __result; -<span class="lineNum"> 530 </span> : } -<span class="lineNum"> 531 </span> : }; -<span class="lineNum"> 532 </span> : #endif -<span class="lineNum"> 533 </span> : -<span class="lineNum"> 534 </span> : template<> -<span class="lineNum"> 535 </span> : struct __copy_move_backward<false, false, random_access_iterator_tag> -<span class="lineNum"> 536 </span> : { -<span class="lineNum"> 537 </span> : template<typename _BI1, typename _BI2> -<span class="lineNum"> 538 </span> : static _BI2 -<span class="lineNum"> 539 </span><span class="lineCov"> 150 : __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result)</span> -<span class="lineNum"> 540 </span> : { -<span class="lineNum"> 541 </span> : typename iterator_traits<_BI1>::difference_type __n; -<span class="lineNum"> 542 </span><span class="lineCov"> 524 : for (__n = __last - __first; __n > 0; --__n)</span> -<span class="lineNum"> 543 </span><span class="lineCov"> 374 : *--__result = *--__last;</span> -<span class="lineNum"> 544 </span><span class="lineCov"> 150 : return __result;</span> -<span class="lineNum"> 545 </span> : } -<span class="lineNum"> 546 </span> : }; -<span class="lineNum"> 547 </span> : -<span class="lineNum"> 548 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 549 </span> : template<> -<span class="lineNum"> 550 </span> : struct __copy_move_backward<true, false, random_access_iterator_tag> -<span class="lineNum"> 551 </span> : { -<span class="lineNum"> 552 </span> : template<typename _BI1, typename _BI2> -<span class="lineNum"> 553 </span> : static _BI2 -<span class="lineNum"> 554 </span> : __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) -<span class="lineNum"> 555 </span> : { -<span class="lineNum"> 556 </span> : typename iterator_traits<_BI1>::difference_type __n; -<span class="lineNum"> 557 </span> : for (__n = __last - __first; __n > 0; --__n) -<span class="lineNum"> 558 </span> : *--__result = std::move(*--__last); -<span class="lineNum"> 559 </span> : return __result; -<span class="lineNum"> 560 </span> : } -<span class="lineNum"> 561 </span> : }; -<span class="lineNum"> 562 </span> : #endif -<span class="lineNum"> 563 </span> : -<span class="lineNum"> 564 </span> : template<bool _IsMove> -<span class="lineNum"> 565 </span> : struct __copy_move_backward<_IsMove, true, random_access_iterator_tag> -<span class="lineNum"> 566 </span> : { -<span class="lineNum"> 567 </span> : template<typename _Tp> -<span class="lineNum"> 568 </span> : static _Tp* -<span class="lineNum"> 569 </span><span class="lineCov"> 7626 : __copy_move_b(const _Tp* __first, const _Tp* __last, _Tp* __result)</span> -<span class="lineNum"> 570 </span> : { -<span class="lineNum"> 571 </span><span class="lineCov"> 7626 : const ptrdiff_t _Num = __last - __first;</span> -<span class="lineNum"> 572 </span><span class="lineCov"> 7626 : __builtin_memmove(__result - _Num, __first, sizeof(_Tp) * _Num);</span> -<span class="lineNum"> 573 </span><span class="lineCov"> 7626 : return __result - _Num;</span> -<span class="lineNum"> 574 </span> : } -<span class="lineNum"> 575 </span> : }; -<span class="lineNum"> 576 </span> : -<span class="lineNum"> 577 </span> : template<bool _IsMove, typename _BI1, typename _BI2> -<span class="lineNum"> 578 </span> : inline _BI2 -<span class="lineNum"> 579 </span><span class="lineCov"> 7776 : __copy_move_backward_a(_BI1 __first, _BI1 __last, _BI2 __result)</span> -<span class="lineNum"> 580 </span> : { -<span class="lineNum"> 581 </span> : typedef typename iterator_traits<_BI1>::value_type _ValueType1; -<span class="lineNum"> 582 </span> : typedef typename iterator_traits<_BI2>::value_type _ValueType2; -<span class="lineNum"> 583 </span> : typedef typename iterator_traits<_BI1>::iterator_category _Category; -<span class="lineNum"> 584 </span> : const bool __simple = (__is_pod(_ValueType1) -<span class="lineNum"> 585 </span> : && __is_pointer<_BI1>::__value -<span class="lineNum"> 586 </span> : && __is_pointer<_BI2>::__value -<span class="lineNum"> 587 </span><span class="lineCov"> 7776 : && __are_same<_ValueType1, _ValueType2>::__value);</span> -<span class="lineNum"> 588 </span> : -<span class="lineNum"> 589 </span> : return std::__copy_move_backward<_IsMove, __simple, -<span class="lineNum"> 590 </span> : _Category>::__copy_move_b(__first, -<span class="lineNum"> 591 </span> : __last, -<span class="lineNum"> 592 </span><span class="lineCov"> 7776 : __result);</span> -<span class="lineNum"> 593 </span> : } -<span class="lineNum"> 594 </span> : -<span class="lineNum"> 595 </span> : template<bool _IsMove, typename _BI1, typename _BI2> -<span class="lineNum"> 596 </span> : inline _BI2 -<span class="lineNum"> 597 </span><span class="lineCov"> 7776 : __copy_move_backward_a2(_BI1 __first, _BI1 __last, _BI2 __result)</span> -<span class="lineNum"> 598 </span> : { -<span class="lineNum"> 599 </span> : return _BI2(std::__copy_move_backward_a<_IsMove> -<span class="lineNum"> 600 </span> : (std::__niter_base<_BI1>::__b(__first), -<span class="lineNum"> 601 </span> : std::__niter_base<_BI1>::__b(__last), -<span class="lineNum"> 602 </span><span class="lineCov"> 7776 : std::__niter_base<_BI2>::__b(__result)));</span> -<span class="lineNum"> 603 </span> : } -<span class="lineNum"> 604 </span> : -<span class="lineNum"> 605 </span> : /** -<span class="lineNum"> 606 </span> : * @brief Copies the range [first,last) into result. -<span class="lineNum"> 607 </span> : * @param first A bidirectional iterator. -<span class="lineNum"> 608 </span> : * @param last A bidirectional iterator. -<span class="lineNum"> 609 </span> : * @param result A bidirectional iterator. -<span class="lineNum"> 610 </span> : * @return result - (first - last) -<span class="lineNum"> 611 </span> : * -<span class="lineNum"> 612 </span> : * The function has the same effect as copy, but starts at the end of the -<span class="lineNum"> 613 </span> : * range and works its way to the start, returning the start of the result. -<span class="lineNum"> 614 </span> : * This inline function will boil down to a call to @c memmove whenever -<span class="lineNum"> 615 </span> : * possible. Failing that, if random access iterators are passed, then the -<span class="lineNum"> 616 </span> : * loop count will be known (and therefore a candidate for compiler -<span class="lineNum"> 617 </span> : * optimizations such as unrolling). -<span class="lineNum"> 618 </span> : * -<span class="lineNum"> 619 </span> : * Result may not be in the range [first,last). Use copy instead. Note -<span class="lineNum"> 620 </span> : * that the start of the output range may overlap [first,last). -<span class="lineNum"> 621 </span> : */ -<span class="lineNum"> 622 </span> : template<typename _BI1, typename _BI2> -<span class="lineNum"> 623 </span> : inline _BI2 -<span class="lineNum"> 624 </span><span class="lineCov"> 7776 : copy_backward(_BI1 __first, _BI1 __last, _BI2 __result)</span> -<span class="lineNum"> 625 </span> : { -<span class="lineNum"> 626 </span> : // concept requirements -<span class="lineNum"> 627 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept<_BI1>) -<span class="lineNum"> 628 </span> : __glibcxx_function_requires(_Mutable_BidirectionalIteratorConcept<_BI2>) -<span class="lineNum"> 629 </span> : __glibcxx_function_requires(_ConvertibleConcept< -<span class="lineNum"> 630 </span> : typename iterator_traits<_BI1>::value_type, -<span class="lineNum"> 631 </span> : typename iterator_traits<_BI2>::value_type>) -<span class="lineNum"> 632 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 633 </span> : -<span class="lineNum"> 634 </span> : return (std::__copy_move_backward_a2<__is_move_iterator<_BI1>::__value> -<span class="lineNum"> 635 </span> : (std::__miter_base<_BI1>::__b(__first), -<span class="lineNum"> 636 </span><span class="lineCov"> 7776 : std::__miter_base<_BI1>::__b(__last), __result));</span> -<span class="lineNum"> 637 </span> : } -<span class="lineNum"> 638 </span> : -<span class="lineNum"> 639 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 640 </span> : /** -<span class="lineNum"> 641 </span> : * @brief Moves the range [first,last) into result. -<span class="lineNum"> 642 </span> : * @param first A bidirectional iterator. -<span class="lineNum"> 643 </span> : * @param last A bidirectional iterator. -<span class="lineNum"> 644 </span> : * @param result A bidirectional iterator. -<span class="lineNum"> 645 </span> : * @return result - (first - last) -<span class="lineNum"> 646 </span> : * -<span class="lineNum"> 647 </span> : * The function has the same effect as move, but starts at the end of the -<span class="lineNum"> 648 </span> : * range and works its way to the start, returning the start of the result. -<span class="lineNum"> 649 </span> : * This inline function will boil down to a call to @c memmove whenever -<span class="lineNum"> 650 </span> : * possible. Failing that, if random access iterators are passed, then the -<span class="lineNum"> 651 </span> : * loop count will be known (and therefore a candidate for compiler -<span class="lineNum"> 652 </span> : * optimizations such as unrolling). -<span class="lineNum"> 653 </span> : * -<span class="lineNum"> 654 </span> : * Result may not be in the range [first,last). Use move instead. Note -<span class="lineNum"> 655 </span> : * that the start of the output range may overlap [first,last). -<span class="lineNum"> 656 </span> : */ -<span class="lineNum"> 657 </span> : template<typename _BI1, typename _BI2> -<span class="lineNum"> 658 </span> : inline _BI2 -<span class="lineNum"> 659 </span> : move_backward(_BI1 __first, _BI1 __last, _BI2 __result) -<span class="lineNum"> 660 </span> : { -<span class="lineNum"> 661 </span> : // concept requirements -<span class="lineNum"> 662 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept<_BI1>) -<span class="lineNum"> 663 </span> : __glibcxx_function_requires(_Mutable_BidirectionalIteratorConcept<_BI2>) -<span class="lineNum"> 664 </span> : __glibcxx_function_requires(_ConvertibleConcept< -<span class="lineNum"> 665 </span> : typename iterator_traits<_BI1>::value_type, -<span class="lineNum"> 666 </span> : typename iterator_traits<_BI2>::value_type>) -<span class="lineNum"> 667 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 668 </span> : -<span class="lineNum"> 669 </span> : return (std::__copy_move_backward_a2<true> -<span class="lineNum"> 670 </span> : (std::__miter_base<_BI1>::__b(__first), -<span class="lineNum"> 671 </span> : std::__miter_base<_BI1>::__b(__last), __result)); -<span class="lineNum"> 672 </span> : } -<span class="lineNum"> 673 </span> : -<span class="lineNum"> 674 </span> : #define _GLIBCXX_MOVE_BACKWARD3(_Tp, _Up, _Vp) std::move_backward(_Tp, _Up, _Vp) -<span class="lineNum"> 675 </span> : #else -<span class="lineNum"> 676 </span> : #define _GLIBCXX_MOVE_BACKWARD3(_Tp, _Up, _Vp) std::copy_backward(_Tp, _Up, _Vp) -<span class="lineNum"> 677 </span> : #endif -<span class="lineNum"> 678 </span> : -<span class="lineNum"> 679 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 680 </span> : inline typename -<span class="lineNum"> 681 </span> : __gnu_cxx::__enable_if<!__is_scalar<_Tp>::__value, void>::__type -<span class="lineNum"> 682 </span> : __fill_a(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 683 </span><span class="lineCov"> 22386 : const _Tp& __value)</span> -<span class="lineNum"> 684 </span> : { -<span class="lineNum"> 685 </span><span class="lineCov"> 22386 : for (; __first != __last; ++__first)</span> -<span class="lineNum"> 686 </span><span class="lineNoCov"> 0 : *__first = __value;</span> -<span class="lineNum"> 687 </span><span class="lineCov"> 22386 : }</span> -<span class="lineNum"> 688 </span> : -<span class="lineNum"> 689 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 690 </span> : inline typename -<span class="lineNum"> 691 </span> : __gnu_cxx::__enable_if<__is_scalar<_Tp>::__value, void>::__type -<span class="lineNum"> 692 </span> : __fill_a(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 693 </span> : const _Tp& __value) -<span class="lineNum"> 694 </span> : { -<span class="lineNum"> 695 </span> : const _Tp __tmp = __value; -<span class="lineNum"> 696 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 697 </span> : *__first = __tmp; -<span class="lineNum"> 698 </span> : } -<span class="lineNum"> 699 </span> : -<span class="lineNum"> 700 </span> : // Specialization: for char types we can use memset. -<span class="lineNum"> 701 </span> : template<typename _Tp> -<span class="lineNum"> 702 </span> : inline typename -<span class="lineNum"> 703 </span> : __gnu_cxx::__enable_if<__is_byte<_Tp>::__value, void>::__type -<span class="lineNum"> 704 </span> : __fill_a(_Tp* __first, _Tp* __last, const _Tp& __c) -<span class="lineNum"> 705 </span> : { -<span class="lineNum"> 706 </span> : const _Tp __tmp = __c; -<span class="lineNum"> 707 </span> : __builtin_memset(__first, static_cast<unsigned char>(__tmp), -<span class="lineNum"> 708 </span> : __last - __first); -<span class="lineNum"> 709 </span> : } -<span class="lineNum"> 710 </span> : -<span class="lineNum"> 711 </span> : /** -<span class="lineNum"> 712 </span> : * @brief Fills the range [first,last) with copies of value. -<span class="lineNum"> 713 </span> : * @param first A forward iterator. -<span class="lineNum"> 714 </span> : * @param last A forward iterator. -<span class="lineNum"> 715 </span> : * @param value A reference-to-const of arbitrary type. -<span class="lineNum"> 716 </span> : * @return Nothing. -<span class="lineNum"> 717 </span> : * -<span class="lineNum"> 718 </span> : * This function fills a range with copies of the same value. For char -<span class="lineNum"> 719 </span> : * types filling contiguous areas of memory, this becomes an inline call -<span class="lineNum"> 720 </span> : * to @c memset or @c wmemset. -<span class="lineNum"> 721 </span> : */ -<span class="lineNum"> 722 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 723 </span> : inline void -<span class="lineNum"> 724 </span><span class="lineCov"> 22386 : fill(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __value)</span> -<span class="lineNum"> 725 </span> : { -<span class="lineNum"> 726 </span> : // concept requirements -<span class="lineNum"> 727 </span> : __glibcxx_function_requires(_Mutable_ForwardIteratorConcept< -<span class="lineNum"> 728 </span> : _ForwardIterator>) -<span class="lineNum"> 729 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 730 </span> : -<span class="lineNum"> 731 </span><span class="lineCov"> 22386 : std::__fill_a(std::__niter_base<_ForwardIterator>::__b(__first),</span> -<span class="lineNum"> 732 </span> : std::__niter_base<_ForwardIterator>::__b(__last), __value); -<span class="lineNum"> 733 </span><span class="lineCov"> 22386 : }</span> -<span class="lineNum"> 734 </span> : -<span class="lineNum"> 735 </span> : template<typename _OutputIterator, typename _Size, typename _Tp> -<span class="lineNum"> 736 </span> : inline typename -<span class="lineNum"> 737 </span> : __gnu_cxx::__enable_if<!__is_scalar<_Tp>::__value, _OutputIterator>::__type -<span class="lineNum"> 738 </span> : __fill_n_a(_OutputIterator __first, _Size __n, const _Tp& __value) -<span class="lineNum"> 739 </span> : { -<span class="lineNum"> 740 </span> : for (; __n > 0; --__n, ++__first) -<span class="lineNum"> 741 </span> : *__first = __value; -<span class="lineNum"> 742 </span> : return __first; -<span class="lineNum"> 743 </span> : } -<span class="lineNum"> 744 </span> : -<span class="lineNum"> 745 </span> : template<typename _OutputIterator, typename _Size, typename _Tp> -<span class="lineNum"> 746 </span> : inline typename -<span class="lineNum"> 747 </span> : __gnu_cxx::__enable_if<__is_scalar<_Tp>::__value, _OutputIterator>::__type -<span class="lineNum"> 748 </span><span class="lineCov"> 9 : __fill_n_a(_OutputIterator __first, _Size __n, const _Tp& __value)</span> -<span class="lineNum"> 749 </span> : { -<span class="lineNum"> 750 </span><span class="lineCov"> 9 : const _Tp __tmp = __value;</span> -<span class="lineNum"> 751 </span><span class="lineCov"> 9 : for (; __n > 0; --__n, ++__first)</span> -<span class="lineNum"> 752 </span><span class="lineNoCov"> 0 : *__first = __tmp;</span> -<span class="lineNum"> 753 </span><span class="lineCov"> 9 : return __first;</span> -<span class="lineNum"> 754 </span> : } -<span class="lineNum"> 755 </span> : -<span class="lineNum"> 756 </span> : template<typename _Size, typename _Tp> -<span class="lineNum"> 757 </span> : inline typename -<span class="lineNum"> 758 </span> : __gnu_cxx::__enable_if<__is_byte<_Tp>::__value, _Tp*>::__type -<span class="lineNum"> 759 </span> : __fill_n_a(_Tp* __first, _Size __n, const _Tp& __c) -<span class="lineNum"> 760 </span> : { -<span class="lineNum"> 761 </span> : std::__fill_a(__first, __first + __n, __c); -<span class="lineNum"> 762 </span> : return __first + __n; -<span class="lineNum"> 763 </span> : } -<span class="lineNum"> 764 </span> : -<span class="lineNum"> 765 </span> : /** -<span class="lineNum"> 766 </span> : * @brief Fills the range [first,first+n) with copies of value. -<span class="lineNum"> 767 </span> : * @param first An output iterator. -<span class="lineNum"> 768 </span> : * @param n The count of copies to perform. -<span class="lineNum"> 769 </span> : * @param value A reference-to-const of arbitrary type. -<span class="lineNum"> 770 </span> : * @return The iterator at first+n. -<span class="lineNum"> 771 </span> : * -<span class="lineNum"> 772 </span> : * This function fills a range with copies of the same value. For char -<span class="lineNum"> 773 </span> : * types filling contiguous areas of memory, this becomes an inline call -<span class="lineNum"> 774 </span> : * to @c memset or @ wmemset. -<span class="lineNum"> 775 </span> : */ -<span class="lineNum"> 776 </span> : template<typename _OI, typename _Size, typename _Tp> -<span class="lineNum"> 777 </span> : inline _OI -<span class="lineNum"> 778 </span><span class="lineCov"> 9 : fill_n(_OI __first, _Size __n, const _Tp& __value)</span> -<span class="lineNum"> 779 </span> : { -<span class="lineNum"> 780 </span> : // concept requirements -<span class="lineNum"> 781 </span> : __glibcxx_function_requires(_OutputIteratorConcept<_OI, _Tp>) -<span class="lineNum"> 782 </span> : -<span class="lineNum"> 783 </span> : return _OI(std::__fill_n_a(std::__niter_base<_OI>::__b(__first), -<span class="lineNum"> 784 </span><span class="lineCov"> 9 : __n, __value));</span> -<span class="lineNum"> 785 </span> : } -<span class="lineNum"> 786 </span> : -<span class="lineNum"> 787 </span> : template<bool _BoolType> -<span class="lineNum"> 788 </span> : struct __equal -<span class="lineNum"> 789 </span> : { -<span class="lineNum"> 790 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 791 </span> : static bool -<span class="lineNum"> 792 </span><span class="lineCov"> 4 : equal(_II1 __first1, _II1 __last1, _II2 __first2)</span> -<span class="lineNum"> 793 </span> : { -<span class="lineNum"> 794 </span><span class="lineCov"> 51 : for (; __first1 != __last1; ++__first1, ++__first2)</span> -<span class="lineNum"> 795 </span><span class="lineCov"> 47 : if (!(*__first1 == *__first2))</span> -<span class="lineNum"> 796 </span><span class="lineNoCov"> 0 : return false;</span> -<span class="lineNum"> 797 </span><span class="lineCov"> 4 : return true;</span> -<span class="lineNum"> 798 </span> : } -<span class="lineNum"> 799 </span> : }; -<span class="lineNum"> 800 </span> : -<span class="lineNum"> 801 </span> : template<> -<span class="lineNum"> 802 </span> : struct __equal<true> -<span class="lineNum"> 803 </span> : { -<span class="lineNum"> 804 </span> : template<typename _Tp> -<span class="lineNum"> 805 </span> : static bool -<span class="lineNum"> 806 </span> : equal(const _Tp* __first1, const _Tp* __last1, const _Tp* __first2) -<span class="lineNum"> 807 </span> : { -<span class="lineNum"> 808 </span> : return !__builtin_memcmp(__first1, __first2, sizeof(_Tp) -<span class="lineNum"> 809 </span> : * (__last1 - __first1)); -<span class="lineNum"> 810 </span> : } -<span class="lineNum"> 811 </span> : }; -<span class="lineNum"> 812 </span> : -<span class="lineNum"> 813 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 814 </span> : inline bool -<span class="lineNum"> 815 </span><span class="lineCov"> 4 : __equal_aux(_II1 __first1, _II1 __last1, _II2 __first2)</span> -<span class="lineNum"> 816 </span> : { -<span class="lineNum"> 817 </span> : typedef typename iterator_traits<_II1>::value_type _ValueType1; -<span class="lineNum"> 818 </span> : typedef typename iterator_traits<_II2>::value_type _ValueType2; -<span class="lineNum"> 819 </span> : const bool __simple = (__is_integer<_ValueType1>::__value -<span class="lineNum"> 820 </span> : && __is_pointer<_II1>::__value -<span class="lineNum"> 821 </span> : && __is_pointer<_II2>::__value -<span class="lineNum"> 822 </span><span class="lineCov"> 4 : && __are_same<_ValueType1, _ValueType2>::__value);</span> -<span class="lineNum"> 823 </span> : -<span class="lineNum"> 824 </span><span class="lineCov"> 4 : return std::__equal<__simple>::equal(__first1, __last1, __first2);</span> -<span class="lineNum"> 825 </span> : } -<span class="lineNum"> 826 </span> : -<span class="lineNum"> 827 </span> : -<span class="lineNum"> 828 </span> : template<typename, typename> -<span class="lineNum"> 829 </span> : struct __lc_rai -<span class="lineNum"> 830 </span> : { -<span class="lineNum"> 831 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 832 </span> : static _II1 -<span class="lineNum"> 833 </span> : __newlast1(_II1, _II1 __last1, _II2, _II2) -<span class="lineNum"> 834 </span> : { return __last1; } -<span class="lineNum"> 835 </span> : -<span class="lineNum"> 836 </span> : template<typename _II> -<span class="lineNum"> 837 </span> : static bool -<span class="lineNum"> 838 </span> : __cnd2(_II __first, _II __last) -<span class="lineNum"> 839 </span> : { return __first != __last; } -<span class="lineNum"> 840 </span> : }; -<span class="lineNum"> 841 </span> : -<span class="lineNum"> 842 </span> : template<> -<span class="lineNum"> 843 </span> : struct __lc_rai<random_access_iterator_tag, random_access_iterator_tag> -<span class="lineNum"> 844 </span> : { -<span class="lineNum"> 845 </span> : template<typename _RAI1, typename _RAI2> -<span class="lineNum"> 846 </span> : static _RAI1 -<span class="lineNum"> 847 </span> : __newlast1(_RAI1 __first1, _RAI1 __last1, -<span class="lineNum"> 848 </span> : _RAI2 __first2, _RAI2 __last2) -<span class="lineNum"> 849 </span> : { -<span class="lineNum"> 850 </span> : const typename iterator_traits<_RAI1>::difference_type -<span class="lineNum"> 851 </span> : __diff1 = __last1 - __first1; -<span class="lineNum"> 852 </span> : const typename iterator_traits<_RAI2>::difference_type -<span class="lineNum"> 853 </span> : __diff2 = __last2 - __first2; -<span class="lineNum"> 854 </span> : return __diff2 < __diff1 ? __first1 + __diff2 : __last1; -<span class="lineNum"> 855 </span> : } -<span class="lineNum"> 856 </span> : -<span class="lineNum"> 857 </span> : template<typename _RAI> -<span class="lineNum"> 858 </span> : static bool -<span class="lineNum"> 859 </span> : __cnd2(_RAI, _RAI) -<span class="lineNum"> 860 </span> : { return true; } -<span class="lineNum"> 861 </span> : }; -<span class="lineNum"> 862 </span> : -<span class="lineNum"> 863 </span> : template<bool _BoolType> -<span class="lineNum"> 864 </span> : struct __lexicographical_compare -<span class="lineNum"> 865 </span> : { -<span class="lineNum"> 866 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 867 </span> : static bool __lc(_II1, _II1, _II2, _II2); -<span class="lineNum"> 868 </span> : }; -<span class="lineNum"> 869 </span> : -<span class="lineNum"> 870 </span> : template<bool _BoolType> -<span class="lineNum"> 871 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 872 </span> : bool -<span class="lineNum"> 873 </span> : __lexicographical_compare<_BoolType>:: -<span class="lineNum"> 874 </span> : __lc(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) -<span class="lineNum"> 875 </span> : { -<span class="lineNum"> 876 </span> : typedef typename iterator_traits<_II1>::iterator_category _Category1; -<span class="lineNum"> 877 </span> : typedef typename iterator_traits<_II2>::iterator_category _Category2; -<span class="lineNum"> 878 </span> : typedef std::__lc_rai<_Category1, _Category2> __rai_type; -<span class="lineNum"> 879 </span> : -<span class="lineNum"> 880 </span> : __last1 = __rai_type::__newlast1(__first1, __last1, -<span class="lineNum"> 881 </span> : __first2, __last2); -<span class="lineNum"> 882 </span> : for (; __first1 != __last1 && __rai_type::__cnd2(__first2, __last2); -<span class="lineNum"> 883 </span> : ++__first1, ++__first2) -<span class="lineNum"> 884 </span> : { -<span class="lineNum"> 885 </span> : if (*__first1 < *__first2) -<span class="lineNum"> 886 </span> : return true; -<span class="lineNum"> 887 </span> : if (*__first2 < *__first1) -<span class="lineNum"> 888 </span> : return false; -<span class="lineNum"> 889 </span> : } -<span class="lineNum"> 890 </span> : return __first1 == __last1 && __first2 != __last2; -<span class="lineNum"> 891 </span> : } -<span class="lineNum"> 892 </span> : -<span class="lineNum"> 893 </span> : template<> -<span class="lineNum"> 894 </span> : struct __lexicographical_compare<true> -<span class="lineNum"> 895 </span> : { -<span class="lineNum"> 896 </span> : template<typename _Tp, typename _Up> -<span class="lineNum"> 897 </span> : static bool -<span class="lineNum"> 898 </span> : __lc(const _Tp* __first1, const _Tp* __last1, -<span class="lineNum"> 899 </span> : const _Up* __first2, const _Up* __last2) -<span class="lineNum"> 900 </span> : { -<span class="lineNum"> 901 </span> : const size_t __len1 = __last1 - __first1; -<span class="lineNum"> 902 </span> : const size_t __len2 = __last2 - __first2; -<span class="lineNum"> 903 </span> : const int __result = __builtin_memcmp(__first1, __first2, -<span class="lineNum"> 904 </span> : std::min(__len1, __len2)); -<span class="lineNum"> 905 </span> : return __result != 0 ? __result < 0 : __len1 < __len2; -<span class="lineNum"> 906 </span> : } -<span class="lineNum"> 907 </span> : }; -<span class="lineNum"> 908 </span> : -<span class="lineNum"> 909 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 910 </span> : inline bool -<span class="lineNum"> 911 </span> : __lexicographical_compare_aux(_II1 __first1, _II1 __last1, -<span class="lineNum"> 912 </span> : _II2 __first2, _II2 __last2) -<span class="lineNum"> 913 </span> : { -<span class="lineNum"> 914 </span> : typedef typename iterator_traits<_II1>::value_type _ValueType1; -<span class="lineNum"> 915 </span> : typedef typename iterator_traits<_II2>::value_type _ValueType2; -<span class="lineNum"> 916 </span> : const bool __simple = -<span class="lineNum"> 917 </span> : (__is_byte<_ValueType1>::__value && __is_byte<_ValueType2>::__value -<span class="lineNum"> 918 </span> : && !__gnu_cxx::__numeric_traits<_ValueType1>::__is_signed -<span class="lineNum"> 919 </span> : && !__gnu_cxx::__numeric_traits<_ValueType2>::__is_signed -<span class="lineNum"> 920 </span> : && __is_pointer<_II1>::__value -<span class="lineNum"> 921 </span> : && __is_pointer<_II2>::__value); -<span class="lineNum"> 922 </span> : -<span class="lineNum"> 923 </span> : return std::__lexicographical_compare<__simple>::__lc(__first1, __last1, -<span class="lineNum"> 924 </span> : __first2, __last2); -<span class="lineNum"> 925 </span> : } -<span class="lineNum"> 926 </span> : -<span class="lineNum"> 927 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 928 </span> : -<span class="lineNum"> 929 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_P) -<span class="lineNum"> 930 </span> : -<span class="lineNum"> 931 </span> : /** -<span class="lineNum"> 932 </span> : * @brief Tests a range for element-wise equality. -<span class="lineNum"> 933 </span> : * @param first1 An input iterator. -<span class="lineNum"> 934 </span> : * @param last1 An input iterator. -<span class="lineNum"> 935 </span> : * @param first2 An input iterator. -<span class="lineNum"> 936 </span> : * @return A boolean true or false. -<span class="lineNum"> 937 </span> : * -<span class="lineNum"> 938 </span> : * This compares the elements of two ranges using @c == and returns true or -<span class="lineNum"> 939 </span> : * false depending on whether all of the corresponding elements of the -<span class="lineNum"> 940 </span> : * ranges are equal. -<span class="lineNum"> 941 </span> : */ -<span class="lineNum"> 942 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 943 </span> : inline bool -<span class="lineNum"> 944 </span><span class="lineCov"> 4 : equal(_II1 __first1, _II1 __last1, _II2 __first2)</span> -<span class="lineNum"> 945 </span> : { -<span class="lineNum"> 946 </span> : // concept requirements -<span class="lineNum"> 947 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II1>) -<span class="lineNum"> 948 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II2>) -<span class="lineNum"> 949 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 950 </span> : typename iterator_traits<_II1>::value_type, -<span class="lineNum"> 951 </span> : typename iterator_traits<_II2>::value_type>) -<span class="lineNum"> 952 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 953 </span> : -<span class="lineNum"> 954 </span> : return std::__equal_aux(std::__niter_base<_II1>::__b(__first1), -<span class="lineNum"> 955 </span> : std::__niter_base<_II1>::__b(__last1), -<span class="lineNum"> 956 </span><span class="lineCov"> 4 : std::__niter_base<_II2>::__b(__first2));</span> -<span class="lineNum"> 957 </span> : } -<span class="lineNum"> 958 </span> : -<span class="lineNum"> 959 </span> : /** -<span class="lineNum"> 960 </span> : * @brief Tests a range for element-wise equality. -<span class="lineNum"> 961 </span> : * @param first1 An input iterator. -<span class="lineNum"> 962 </span> : * @param last1 An input iterator. -<span class="lineNum"> 963 </span> : * @param first2 An input iterator. -<span class="lineNum"> 964 </span> : * @param binary_pred A binary predicate @link s20_3_1_base -<span class="lineNum"> 965 </span> : * functor@endlink. -<span class="lineNum"> 966 </span> : * @return A boolean true or false. -<span class="lineNum"> 967 </span> : * -<span class="lineNum"> 968 </span> : * This compares the elements of two ranges using the binary_pred -<span class="lineNum"> 969 </span> : * parameter, and returns true or -<span class="lineNum"> 970 </span> : * false depending on whether all of the corresponding elements of the -<span class="lineNum"> 971 </span> : * ranges are equal. -<span class="lineNum"> 972 </span> : */ -<span class="lineNum"> 973 </span> : template<typename _IIter1, typename _IIter2, typename _BinaryPredicate> -<span class="lineNum"> 974 </span> : inline bool -<span class="lineNum"> 975 </span> : equal(_IIter1 __first1, _IIter1 __last1, -<span class="lineNum"> 976 </span> : _IIter2 __first2, _BinaryPredicate __binary_pred) -<span class="lineNum"> 977 </span> : { -<span class="lineNum"> 978 </span> : // concept requirements -<span class="lineNum"> 979 </span> : __glibcxx_function_requires(_InputIteratorConcept<_IIter1>) -<span class="lineNum"> 980 </span> : __glibcxx_function_requires(_InputIteratorConcept<_IIter2>) -<span class="lineNum"> 981 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 982 </span> : -<span class="lineNum"> 983 </span> : for (; __first1 != __last1; ++__first1, ++__first2) -<span class="lineNum"> 984 </span> : if (!bool(__binary_pred(*__first1, *__first2))) -<span class="lineNum"> 985 </span> : return false; -<span class="lineNum"> 986 </span> : return true; -<span class="lineNum"> 987 </span> : } -<span class="lineNum"> 988 </span> : -<span class="lineNum"> 989 </span> : /** -<span class="lineNum"> 990 </span> : * @brief Performs "dictionary" comparison on ranges. -<span class="lineNum"> 991 </span> : * @param first1 An input iterator. -<span class="lineNum"> 992 </span> : * @param last1 An input iterator. -<span class="lineNum"> 993 </span> : * @param first2 An input iterator. -<span class="lineNum"> 994 </span> : * @param last2 An input iterator. -<span class="lineNum"> 995 </span> : * @return A boolean true or false. -<span class="lineNum"> 996 </span> : * -<span class="lineNum"> 997 </span> : * "Returns true if the sequence of elements defined by the range -<span class="lineNum"> 998 </span> : * [first1,last1) is lexicographically less than the sequence of elements -<span class="lineNum"> 999 </span> : * defined by the range [first2,last2). Returns false otherwise." -<span class="lineNum"> 1000 </span> : * (Quoted from [25.3.8]/1.) If the iterators are all character pointers, -<span class="lineNum"> 1001 </span> : * then this is an inline call to @c memcmp. -<span class="lineNum"> 1002 </span> : */ -<span class="lineNum"> 1003 </span> : template<typename _II1, typename _II2> -<span class="lineNum"> 1004 </span> : inline bool -<span class="lineNum"> 1005 </span> : lexicographical_compare(_II1 __first1, _II1 __last1, -<span class="lineNum"> 1006 </span> : _II2 __first2, _II2 __last2) -<span class="lineNum"> 1007 </span> : { -<span class="lineNum"> 1008 </span> : // concept requirements -<span class="lineNum"> 1009 </span> : typedef typename iterator_traits<_II1>::value_type _ValueType1; -<span class="lineNum"> 1010 </span> : typedef typename iterator_traits<_II2>::value_type _ValueType2; -<span class="lineNum"> 1011 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II1>) -<span class="lineNum"> 1012 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II2>) -<span class="lineNum"> 1013 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType1, _ValueType2>) -<span class="lineNum"> 1014 </span> : __glibcxx_function_requires(_LessThanOpConcept<_ValueType2, _ValueType1>) -<span class="lineNum"> 1015 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 1016 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 1017 </span> : -<span class="lineNum"> 1018 </span> : return std::__lexicographical_compare_aux -<span class="lineNum"> 1019 </span> : (std::__niter_base<_II1>::__b(__first1), -<span class="lineNum"> 1020 </span> : std::__niter_base<_II1>::__b(__last1), -<span class="lineNum"> 1021 </span> : std::__niter_base<_II2>::__b(__first2), -<span class="lineNum"> 1022 </span> : std::__niter_base<_II2>::__b(__last2)); -<span class="lineNum"> 1023 </span> : } -<span class="lineNum"> 1024 </span> : -<span class="lineNum"> 1025 </span> : /** -<span class="lineNum"> 1026 </span> : * @brief Performs "dictionary" comparison on ranges. -<span class="lineNum"> 1027 </span> : * @param first1 An input iterator. -<span class="lineNum"> 1028 </span> : * @param last1 An input iterator. -<span class="lineNum"> 1029 </span> : * @param first2 An input iterator. -<span class="lineNum"> 1030 </span> : * @param last2 An input iterator. -<span class="lineNum"> 1031 </span> : * @param comp A @link s20_3_3_comparisons comparison functor@endlink. -<span class="lineNum"> 1032 </span> : * @return A boolean true or false. -<span class="lineNum"> 1033 </span> : * -<span class="lineNum"> 1034 </span> : * The same as the four-parameter @c lexicographical_compare, but uses the -<span class="lineNum"> 1035 </span> : * comp parameter instead of @c <. -<span class="lineNum"> 1036 </span> : */ -<span class="lineNum"> 1037 </span> : template<typename _II1, typename _II2, typename _Compare> -<span class="lineNum"> 1038 </span> : bool -<span class="lineNum"> 1039 </span> : lexicographical_compare(_II1 __first1, _II1 __last1, -<span class="lineNum"> 1040 </span> : _II2 __first2, _II2 __last2, _Compare __comp) -<span class="lineNum"> 1041 </span> : { -<span class="lineNum"> 1042 </span> : typedef typename iterator_traits<_II1>::iterator_category _Category1; -<span class="lineNum"> 1043 </span> : typedef typename iterator_traits<_II2>::iterator_category _Category2; -<span class="lineNum"> 1044 </span> : typedef std::__lc_rai<_Category1, _Category2> __rai_type; -<span class="lineNum"> 1045 </span> : -<span class="lineNum"> 1046 </span> : // concept requirements -<span class="lineNum"> 1047 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II1>) -<span class="lineNum"> 1048 </span> : __glibcxx_function_requires(_InputIteratorConcept<_II2>) -<span class="lineNum"> 1049 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 1050 </span> : __glibcxx_requires_valid_range(__first2, __last2); -<span class="lineNum"> 1051 </span> : -<span class="lineNum"> 1052 </span> : __last1 = __rai_type::__newlast1(__first1, __last1, __first2, __last2); -<span class="lineNum"> 1053 </span> : for (; __first1 != __last1 && __rai_type::__cnd2(__first2, __last2); -<span class="lineNum"> 1054 </span> : ++__first1, ++__first2) -<span class="lineNum"> 1055 </span> : { -<span class="lineNum"> 1056 </span> : if (__comp(*__first1, *__first2)) -<span class="lineNum"> 1057 </span> : return true; -<span class="lineNum"> 1058 </span> : if (__comp(*__first2, *__first1)) -<span class="lineNum"> 1059 </span> : return false; -<span class="lineNum"> 1060 </span> : } -<span class="lineNum"> 1061 </span> : return __first1 == __last1 && __first2 != __last2; -<span class="lineNum"> 1062 </span> : } -<span class="lineNum"> 1063 </span> : -<span class="lineNum"> 1064 </span> : /** -<span class="lineNum"> 1065 </span> : * @brief Finds the places in ranges which don't match. -<span class="lineNum"> 1066 </span> : * @param first1 An input iterator. -<span class="lineNum"> 1067 </span> : * @param last1 An input iterator. -<span class="lineNum"> 1068 </span> : * @param first2 An input iterator. -<span class="lineNum"> 1069 </span> : * @return A pair of iterators pointing to the first mismatch. -<span class="lineNum"> 1070 </span> : * -<span class="lineNum"> 1071 </span> : * This compares the elements of two ranges using @c == and returns a pair -<span class="lineNum"> 1072 </span> : * of iterators. The first iterator points into the first range, the -<span class="lineNum"> 1073 </span> : * second iterator points into the second range, and the elements pointed -<span class="lineNum"> 1074 </span> : * to by the iterators are not equal. -<span class="lineNum"> 1075 </span> : */ -<span class="lineNum"> 1076 </span> : template<typename _InputIterator1, typename _InputIterator2> -<span class="lineNum"> 1077 </span> : pair<_InputIterator1, _InputIterator2> -<span class="lineNum"> 1078 </span> : mismatch(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 1079 </span> : _InputIterator2 __first2) -<span class="lineNum"> 1080 </span> : { -<span class="lineNum"> 1081 </span> : // concept requirements -<span class="lineNum"> 1082 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 1083 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 1084 </span> : __glibcxx_function_requires(_EqualOpConcept< -<span class="lineNum"> 1085 </span> : typename iterator_traits<_InputIterator1>::value_type, -<span class="lineNum"> 1086 </span> : typename iterator_traits<_InputIterator2>::value_type>) -<span class="lineNum"> 1087 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 1088 </span> : -<span class="lineNum"> 1089 </span> : while (__first1 != __last1 && *__first1 == *__first2) -<span class="lineNum"> 1090 </span> : { -<span class="lineNum"> 1091 </span> : ++__first1; -<span class="lineNum"> 1092 </span> : ++__first2; -<span class="lineNum"> 1093 </span> : } -<span class="lineNum"> 1094 </span> : return pair<_InputIterator1, _InputIterator2>(__first1, __first2); -<span class="lineNum"> 1095 </span> : } -<span class="lineNum"> 1096 </span> : -<span class="lineNum"> 1097 </span> : /** -<span class="lineNum"> 1098 </span> : * @brief Finds the places in ranges which don't match. -<span class="lineNum"> 1099 </span> : * @param first1 An input iterator. -<span class="lineNum"> 1100 </span> : * @param last1 An input iterator. -<span class="lineNum"> 1101 </span> : * @param first2 An input iterator. -<span class="lineNum"> 1102 </span> : * @param binary_pred A binary predicate @link s20_3_1_base -<span class="lineNum"> 1103 </span> : * functor@endlink. -<span class="lineNum"> 1104 </span> : * @return A pair of iterators pointing to the first mismatch. -<span class="lineNum"> 1105 </span> : * -<span class="lineNum"> 1106 </span> : * This compares the elements of two ranges using the binary_pred -<span class="lineNum"> 1107 </span> : * parameter, and returns a pair -<span class="lineNum"> 1108 </span> : * of iterators. The first iterator points into the first range, the -<span class="lineNum"> 1109 </span> : * second iterator points into the second range, and the elements pointed -<span class="lineNum"> 1110 </span> : * to by the iterators are not equal. -<span class="lineNum"> 1111 </span> : */ -<span class="lineNum"> 1112 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 1113 </span> : typename _BinaryPredicate> -<span class="lineNum"> 1114 </span> : pair<_InputIterator1, _InputIterator2> -<span class="lineNum"> 1115 </span> : mismatch(_InputIterator1 __first1, _InputIterator1 __last1, -<span class="lineNum"> 1116 </span> : _InputIterator2 __first2, _BinaryPredicate __binary_pred) -<span class="lineNum"> 1117 </span> : { -<span class="lineNum"> 1118 </span> : // concept requirements -<span class="lineNum"> 1119 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator1>) -<span class="lineNum"> 1120 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator2>) -<span class="lineNum"> 1121 </span> : __glibcxx_requires_valid_range(__first1, __last1); -<span class="lineNum"> 1122 </span> : -<span class="lineNum"> 1123 </span> : while (__first1 != __last1 && bool(__binary_pred(*__first1, *__first2))) -<span class="lineNum"> 1124 </span> : { -<span class="lineNum"> 1125 </span> : ++__first1; -<span class="lineNum"> 1126 </span> : ++__first2; -<span class="lineNum"> 1127 </span> : } -<span class="lineNum"> 1128 </span> : return pair<_InputIterator1, _InputIterator2>(__first1, __first2); -<span class="lineNum"> 1129 </span> : } -<span class="lineNum"> 1130 </span> : -<span class="lineNum"> 1131 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 1132 </span> : -<span class="lineNum"> 1133 </span> : // NB: This file is included within many other C++ includes, as a way -<span class="lineNum"> 1134 </span> : // of getting the base algorithms. So, make sure that parallel bits -<span class="lineNum"> 1135 </span> : // come in too if requested. -<span class="lineNum"> 1136 </span> : #ifdef _GLIBCXX_PARALLEL -<span class="lineNum"> 1137 </span> : # include <parallel/algobase.h> -<span class="lineNum"> 1138 </span> : #endif -<span class="lineNum"> 1139 </span> : -<span class="lineNum"> 1140 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_bvector.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_bvector.h.gcov.html deleted file mode 100644 index 3930b85..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_bvector.h.gcov.html +++ /dev/null @@ -1,1069 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_bvector.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_bvector.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">115</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">70.4 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">81</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // vector<bool> specialization -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996-1999 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_bvector.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_BVECTOR_H -<span class="lineNum"> 63 </span> : #define _STL_BVECTOR_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : typedef unsigned long _Bit_type; -<span class="lineNum"> 68 </span> : enum { _S_word_bit = int(__CHAR_BIT__ * sizeof(_Bit_type)) }; -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : struct _Bit_reference -<span class="lineNum"> 71 </span> : { -<span class="lineNum"> 72 </span> : _Bit_type * _M_p; -<span class="lineNum"> 73 </span> : _Bit_type _M_mask; -<span class="lineNum"> 74 </span> : -<span class="lineNum"> 75 </span><span class="lineCov"> 5 : _Bit_reference(_Bit_type * __x, _Bit_type __y)</span> -<span class="lineNum"> 76 </span><span class="lineCov"> 5 : : _M_p(__x), _M_mask(__y) { }</span> -<span class="lineNum"> 77 </span> : -<span class="lineNum"> 78 </span> : _Bit_reference() : _M_p(0), _M_mask(0) { } -<span class="lineNum"> 79 </span> : -<span class="lineNum"> 80 </span><span class="lineCov"> 3 : operator bool() const</span> -<span class="lineNum"> 81 </span><span class="lineCov"> 3 : { return !!(*_M_p & _M_mask); }</span> -<span class="lineNum"> 82 </span> : -<span class="lineNum"> 83 </span> : _Bit_reference& -<span class="lineNum"> 84 </span><span class="lineCov"> 2 : operator=(bool __x)</span> -<span class="lineNum"> 85 </span> : { -<span class="lineNum"> 86 </span><span class="lineCov"> 2 : if (__x)</span> -<span class="lineNum"> 87 </span><span class="lineCov"> 1 : *_M_p |= _M_mask;</span> -<span class="lineNum"> 88 </span> : else -<span class="lineNum"> 89 </span><span class="lineCov"> 1 : *_M_p &= ~_M_mask;</span> -<span class="lineNum"> 90 </span><span class="lineCov"> 2 : return *this;</span> -<span class="lineNum"> 91 </span> : } -<span class="lineNum"> 92 </span> : -<span class="lineNum"> 93 </span> : _Bit_reference& -<span class="lineNum"> 94 </span><span class="lineNoCov"> 0 : operator=(const _Bit_reference& __x)</span> -<span class="lineNum"> 95 </span><span class="lineNoCov"> 0 : { return *this = bool(__x); }</span> -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : bool -<span class="lineNum"> 98 </span> : operator==(const _Bit_reference& __x) const -<span class="lineNum"> 99 </span> : { return bool(*this) == bool(__x); } -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : bool -<span class="lineNum"> 102 </span> : operator<(const _Bit_reference& __x) const -<span class="lineNum"> 103 </span> : { return !bool(*this) && bool(__x); } -<span class="lineNum"> 104 </span> : -<span class="lineNum"> 105 </span> : void -<span class="lineNum"> 106 </span> : flip() -<span class="lineNum"> 107 </span> : { *_M_p ^= _M_mask; } -<span class="lineNum"> 108 </span> : }; -<span class="lineNum"> 109 </span> : -<span class="lineNum"> 110 </span> : struct _Bit_iterator_base -<span class="lineNum"> 111 </span> : : public std::iterator<std::random_access_iterator_tag, bool> -<span class="lineNum"> 112 </span> : { -<span class="lineNum"> 113 </span> : _Bit_type * _M_p; -<span class="lineNum"> 114 </span> : unsigned int _M_offset; -<span class="lineNum"> 115 </span> : -<span class="lineNum"> 116 </span><span class="lineCov"> 31 : _Bit_iterator_base(_Bit_type * __x, unsigned int __y)</span> -<span class="lineNum"> 117 </span><span class="lineCov"> 31 : : _M_p(__x), _M_offset(__y) { }</span> -<span class="lineNum"> 118 </span> : -<span class="lineNum"> 119 </span> : void -<span class="lineNum"> 120 </span><span class="lineCov"> 2 : _M_bump_up()</span> -<span class="lineNum"> 121 </span> : { -<span class="lineNum"> 122 </span><span class="lineCov"> 2 : if (_M_offset++ == int(_S_word_bit) - 1)</span> -<span class="lineNum"> 123 </span> : { -<span class="lineNum"> 124 </span><span class="lineNoCov"> 0 : _M_offset = 0;</span> -<span class="lineNum"> 125 </span><span class="lineNoCov"> 0 : ++_M_p;</span> -<span class="lineNum"> 126 </span> : } -<span class="lineNum"> 127 </span><span class="lineCov"> 2 : }</span> -<span class="lineNum"> 128 </span> : -<span class="lineNum"> 129 </span> : void -<span class="lineNum"> 130 </span><span class="lineNoCov"> 0 : _M_bump_down()</span> -<span class="lineNum"> 131 </span> : { -<span class="lineNum"> 132 </span><span class="lineNoCov"> 0 : if (_M_offset-- == 0)</span> -<span class="lineNum"> 133 </span> : { -<span class="lineNum"> 134 </span><span class="lineNoCov"> 0 : _M_offset = int(_S_word_bit) - 1;</span> -<span class="lineNum"> 135 </span><span class="lineNoCov"> 0 : --_M_p;</span> -<span class="lineNum"> 136 </span> : } -<span class="lineNum"> 137 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : void -<span class="lineNum"> 140 </span><span class="lineNoCov"> 0 : _M_incr(ptrdiff_t __i)</span> -<span class="lineNum"> 141 </span> : { -<span class="lineNum"> 142 </span><span class="lineNoCov"> 0 : difference_type __n = __i + _M_offset;</span> -<span class="lineNum"> 143 </span><span class="lineNoCov"> 0 : _M_p += __n / int(_S_word_bit);</span> -<span class="lineNum"> 144 </span><span class="lineNoCov"> 0 : __n = __n % int(_S_word_bit);</span> -<span class="lineNum"> 145 </span><span class="lineNoCov"> 0 : if (__n < 0)</span> -<span class="lineNum"> 146 </span> : { -<span class="lineNum"> 147 </span><span class="lineNoCov"> 0 : __n += int(_S_word_bit);</span> -<span class="lineNum"> 148 </span><span class="lineNoCov"> 0 : --_M_p;</span> -<span class="lineNum"> 149 </span> : } -<span class="lineNum"> 150 </span><span class="lineNoCov"> 0 : _M_offset = static_cast<unsigned int>(__n);</span> -<span class="lineNum"> 151 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 152 </span> : -<span class="lineNum"> 153 </span> : bool -<span class="lineNum"> 154 </span><span class="lineCov"> 3 : operator==(const _Bit_iterator_base& __i) const</span> -<span class="lineNum"> 155 </span><span class="lineCov"> 3 : { return _M_p == __i._M_p && _M_offset == __i._M_offset; }</span> -<span class="lineNum"> 156 </span> : -<span class="lineNum"> 157 </span> : bool -<span class="lineNum"> 158 </span> : operator<(const _Bit_iterator_base& __i) const -<span class="lineNum"> 159 </span> : { -<span class="lineNum"> 160 </span> : return _M_p < __i._M_p -<span class="lineNum"> 161 </span> : || (_M_p == __i._M_p && _M_offset < __i._M_offset); -<span class="lineNum"> 162 </span> : } -<span class="lineNum"> 163 </span> : -<span class="lineNum"> 164 </span> : bool -<span class="lineNum"> 165 </span> : operator!=(const _Bit_iterator_base& __i) const -<span class="lineNum"> 166 </span> : { return !(*this == __i); } -<span class="lineNum"> 167 </span> : -<span class="lineNum"> 168 </span> : bool -<span class="lineNum"> 169 </span> : operator>(const _Bit_iterator_base& __i) const -<span class="lineNum"> 170 </span> : { return __i < *this; } -<span class="lineNum"> 171 </span> : -<span class="lineNum"> 172 </span> : bool -<span class="lineNum"> 173 </span> : operator<=(const _Bit_iterator_base& __i) const -<span class="lineNum"> 174 </span> : { return !(__i < *this); } -<span class="lineNum"> 175 </span> : -<span class="lineNum"> 176 </span> : bool -<span class="lineNum"> 177 </span> : operator>=(const _Bit_iterator_base& __i) const -<span class="lineNum"> 178 </span> : { return !(*this < __i); } -<span class="lineNum"> 179 </span> : }; -<span class="lineNum"> 180 </span> : -<span class="lineNum"> 181 </span> : inline ptrdiff_t -<span class="lineNum"> 182 </span><span class="lineCov"> 9 : operator-(const _Bit_iterator_base& __x, const _Bit_iterator_base& __y)</span> -<span class="lineNum"> 183 </span> : { -<span class="lineNum"> 184 </span> : return (int(_S_word_bit) * (__x._M_p - __y._M_p) -<span class="lineNum"> 185 </span><span class="lineCov"> 9 : + __x._M_offset - __y._M_offset);</span> -<span class="lineNum"> 186 </span> : } -<span class="lineNum"> 187 </span> : -<span class="lineNum"> 188 </span> : struct _Bit_iterator : public _Bit_iterator_base -<span class="lineNum"> 189 </span> : { -<span class="lineNum"> 190 </span> : typedef _Bit_reference reference; -<span class="lineNum"> 191 </span> : typedef _Bit_reference* pointer; -<span class="lineNum"> 192 </span> : typedef _Bit_iterator iterator; -<span class="lineNum"> 193 </span> : -<span class="lineNum"> 194 </span><span class="lineCov"> 2 : _Bit_iterator() : _Bit_iterator_base(0, 0) { }</span> -<span class="lineNum"> 195 </span> : -<span class="lineNum"> 196 </span><span class="lineCov"> 3 : _Bit_iterator(_Bit_type * __x, unsigned int __y)</span> -<span class="lineNum"> 197 </span><span class="lineCov"> 3 : : _Bit_iterator_base(__x, __y) { }</span> -<span class="lineNum"> 198 </span> : -<span class="lineNum"> 199 </span> : reference -<span class="lineNum"> 200 </span><span class="lineCov"> 2 : operator*() const</span> -<span class="lineNum"> 201 </span><span class="lineCov"> 2 : { return reference(_M_p, 1UL << _M_offset); }</span> -<span class="lineNum"> 202 </span> : -<span class="lineNum"> 203 </span> : iterator& -<span class="lineNum"> 204 </span><span class="lineNoCov"> 0 : operator++()</span> -<span class="lineNum"> 205 </span> : { -<span class="lineNum"> 206 </span><span class="lineNoCov"> 0 : _M_bump_up();</span> -<span class="lineNum"> 207 </span><span class="lineNoCov"> 0 : return *this;</span> -<span class="lineNum"> 208 </span> : } -<span class="lineNum"> 209 </span> : -<span class="lineNum"> 210 </span> : iterator -<span class="lineNum"> 211 </span><span class="lineCov"> 2 : operator++(int)</span> -<span class="lineNum"> 212 </span> : { -<span class="lineNum"> 213 </span><span class="lineCov"> 2 : iterator __tmp = *this;</span> -<span class="lineNum"> 214 </span><span class="lineCov"> 2 : _M_bump_up();</span> -<span class="lineNum"> 215 </span> : return __tmp; -<span class="lineNum"> 216 </span> : } -<span class="lineNum"> 217 </span> : -<span class="lineNum"> 218 </span> : iterator& -<span class="lineNum"> 219 </span><span class="lineNoCov"> 0 : operator--()</span> -<span class="lineNum"> 220 </span> : { -<span class="lineNum"> 221 </span><span class="lineNoCov"> 0 : _M_bump_down();</span> -<span class="lineNum"> 222 </span><span class="lineNoCov"> 0 : return *this;</span> -<span class="lineNum"> 223 </span> : } -<span class="lineNum"> 224 </span> : -<span class="lineNum"> 225 </span> : iterator -<span class="lineNum"> 226 </span> : operator--(int) -<span class="lineNum"> 227 </span> : { -<span class="lineNum"> 228 </span> : iterator __tmp = *this; -<span class="lineNum"> 229 </span> : _M_bump_down(); -<span class="lineNum"> 230 </span> : return __tmp; -<span class="lineNum"> 231 </span> : } -<span class="lineNum"> 232 </span> : -<span class="lineNum"> 233 </span> : iterator& -<span class="lineNum"> 234 </span><span class="lineNoCov"> 0 : operator+=(difference_type __i)</span> -<span class="lineNum"> 235 </span> : { -<span class="lineNum"> 236 </span><span class="lineNoCov"> 0 : _M_incr(__i);</span> -<span class="lineNum"> 237 </span><span class="lineNoCov"> 0 : return *this;</span> -<span class="lineNum"> 238 </span> : } -<span class="lineNum"> 239 </span> : -<span class="lineNum"> 240 </span> : iterator& -<span class="lineNum"> 241 </span> : operator-=(difference_type __i) -<span class="lineNum"> 242 </span> : { -<span class="lineNum"> 243 </span> : *this += -__i; -<span class="lineNum"> 244 </span> : return *this; -<span class="lineNum"> 245 </span> : } -<span class="lineNum"> 246 </span> : -<span class="lineNum"> 247 </span> : iterator -<span class="lineNum"> 248 </span><span class="lineNoCov"> 0 : operator+(difference_type __i) const</span> -<span class="lineNum"> 249 </span> : { -<span class="lineNum"> 250 </span><span class="lineNoCov"> 0 : iterator __tmp = *this;</span> -<span class="lineNum"> 251 </span><span class="lineNoCov"> 0 : return __tmp += __i;</span> -<span class="lineNum"> 252 </span> : } -<span class="lineNum"> 253 </span> : -<span class="lineNum"> 254 </span> : iterator -<span class="lineNum"> 255 </span> : operator-(difference_type __i) const -<span class="lineNum"> 256 </span> : { -<span class="lineNum"> 257 </span> : iterator __tmp = *this; -<span class="lineNum"> 258 </span> : return __tmp -= __i; -<span class="lineNum"> 259 </span> : } -<span class="lineNum"> 260 </span> : -<span class="lineNum"> 261 </span> : reference -<span class="lineNum"> 262 </span> : operator[](difference_type __i) const -<span class="lineNum"> 263 </span> : { return *(*this + __i); } -<span class="lineNum"> 264 </span> : }; -<span class="lineNum"> 265 </span> : -<span class="lineNum"> 266 </span> : inline _Bit_iterator -<span class="lineNum"> 267 </span> : operator+(ptrdiff_t __n, const _Bit_iterator& __x) -<span class="lineNum"> 268 </span> : { return __x + __n; } -<span class="lineNum"> 269 </span> : -<span class="lineNum"> 270 </span> : struct _Bit_const_iterator : public _Bit_iterator_base -<span class="lineNum"> 271 </span> : { -<span class="lineNum"> 272 </span> : typedef bool reference; -<span class="lineNum"> 273 </span> : typedef bool const_reference; -<span class="lineNum"> 274 </span> : typedef const bool* pointer; -<span class="lineNum"> 275 </span> : typedef _Bit_const_iterator const_iterator; -<span class="lineNum"> 276 </span> : -<span class="lineNum"> 277 </span> : _Bit_const_iterator() : _Bit_iterator_base(0, 0) { } -<span class="lineNum"> 278 </span> : -<span class="lineNum"> 279 </span><span class="lineCov"> 4 : _Bit_const_iterator(_Bit_type * __x, unsigned int __y)</span> -<span class="lineNum"> 280 </span><span class="lineCov"> 4 : : _Bit_iterator_base(__x, __y) { }</span> -<span class="lineNum"> 281 </span> : -<span class="lineNum"> 282 </span><span class="lineCov"> 22 : _Bit_const_iterator(const _Bit_iterator& __x)</span> -<span class="lineNum"> 283 </span><span class="lineCov"> 22 : : _Bit_iterator_base(__x._M_p, __x._M_offset) { }</span> -<span class="lineNum"> 284 </span> : -<span class="lineNum"> 285 </span> : const_reference -<span class="lineNum"> 286 </span><span class="lineCov"> 3 : operator*() const</span> -<span class="lineNum"> 287 </span><span class="lineCov"> 3 : { return _Bit_reference(_M_p, 1UL << _M_offset); }</span> -<span class="lineNum"> 288 </span> : -<span class="lineNum"> 289 </span> : const_iterator& -<span class="lineNum"> 290 </span><span class="lineNoCov"> 0 : operator++()</span> -<span class="lineNum"> 291 </span> : { -<span class="lineNum"> 292 </span><span class="lineNoCov"> 0 : _M_bump_up();</span> -<span class="lineNum"> 293 </span><span class="lineNoCov"> 0 : return *this;</span> -<span class="lineNum"> 294 </span> : } -<span class="lineNum"> 295 </span> : -<span class="lineNum"> 296 </span> : const_iterator -<span class="lineNum"> 297 </span> : operator++(int) -<span class="lineNum"> 298 </span> : { -<span class="lineNum"> 299 </span> : const_iterator __tmp = *this; -<span class="lineNum"> 300 </span> : _M_bump_up(); -<span class="lineNum"> 301 </span> : return __tmp; -<span class="lineNum"> 302 </span> : } -<span class="lineNum"> 303 </span> : -<span class="lineNum"> 304 </span> : const_iterator& -<span class="lineNum"> 305 </span> : operator--() -<span class="lineNum"> 306 </span> : { -<span class="lineNum"> 307 </span> : _M_bump_down(); -<span class="lineNum"> 308 </span> : return *this; -<span class="lineNum"> 309 </span> : } -<span class="lineNum"> 310 </span> : -<span class="lineNum"> 311 </span> : const_iterator -<span class="lineNum"> 312 </span> : operator--(int) -<span class="lineNum"> 313 </span> : { -<span class="lineNum"> 314 </span> : const_iterator __tmp = *this; -<span class="lineNum"> 315 </span> : _M_bump_down(); -<span class="lineNum"> 316 </span> : return __tmp; -<span class="lineNum"> 317 </span> : } -<span class="lineNum"> 318 </span> : -<span class="lineNum"> 319 </span> : const_iterator& -<span class="lineNum"> 320 </span> : operator+=(difference_type __i) -<span class="lineNum"> 321 </span> : { -<span class="lineNum"> 322 </span> : _M_incr(__i); -<span class="lineNum"> 323 </span> : return *this; -<span class="lineNum"> 324 </span> : } -<span class="lineNum"> 325 </span> : -<span class="lineNum"> 326 </span> : const_iterator& -<span class="lineNum"> 327 </span> : operator-=(difference_type __i) -<span class="lineNum"> 328 </span> : { -<span class="lineNum"> 329 </span> : *this += -__i; -<span class="lineNum"> 330 </span> : return *this; -<span class="lineNum"> 331 </span> : } -<span class="lineNum"> 332 </span> : -<span class="lineNum"> 333 </span> : const_iterator -<span class="lineNum"> 334 </span> : operator+(difference_type __i) const -<span class="lineNum"> 335 </span> : { -<span class="lineNum"> 336 </span> : const_iterator __tmp = *this; -<span class="lineNum"> 337 </span> : return __tmp += __i; -<span class="lineNum"> 338 </span> : } -<span class="lineNum"> 339 </span> : -<span class="lineNum"> 340 </span> : const_iterator -<span class="lineNum"> 341 </span> : operator-(difference_type __i) const -<span class="lineNum"> 342 </span> : { -<span class="lineNum"> 343 </span> : const_iterator __tmp = *this; -<span class="lineNum"> 344 </span> : return __tmp -= __i; -<span class="lineNum"> 345 </span> : } -<span class="lineNum"> 346 </span> : -<span class="lineNum"> 347 </span> : const_reference -<span class="lineNum"> 348 </span> : operator[](difference_type __i) const -<span class="lineNum"> 349 </span> : { return *(*this + __i); } -<span class="lineNum"> 350 </span> : }; -<span class="lineNum"> 351 </span> : -<span class="lineNum"> 352 </span> : inline _Bit_const_iterator -<span class="lineNum"> 353 </span> : operator+(ptrdiff_t __n, const _Bit_const_iterator& __x) -<span class="lineNum"> 354 </span> : { return __x + __n; } -<span class="lineNum"> 355 </span> : -<span class="lineNum"> 356 </span> : inline void -<span class="lineNum"> 357 </span> : __fill_bvector(_Bit_iterator __first, _Bit_iterator __last, bool __x) -<span class="lineNum"> 358 </span> : { -<span class="lineNum"> 359 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 360 </span> : *__first = __x; -<span class="lineNum"> 361 </span> : } -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : inline void -<span class="lineNum"> 364 </span> : fill(_Bit_iterator __first, _Bit_iterator __last, const bool& __x) -<span class="lineNum"> 365 </span> : { -<span class="lineNum"> 366 </span> : if (__first._M_p != __last._M_p) -<span class="lineNum"> 367 </span> : { -<span class="lineNum"> 368 </span> : std::fill(__first._M_p + 1, __last._M_p, __x ? ~0 : 0); -<span class="lineNum"> 369 </span> : __fill_bvector(__first, _Bit_iterator(__first._M_p + 1, 0), __x); -<span class="lineNum"> 370 </span> : __fill_bvector(_Bit_iterator(__last._M_p, 0), __last, __x); -<span class="lineNum"> 371 </span> : } -<span class="lineNum"> 372 </span> : else -<span class="lineNum"> 373 </span> : __fill_bvector(__first, __last, __x); -<span class="lineNum"> 374 </span> : } -<span class="lineNum"> 375 </span> : -<span class="lineNum"> 376 </span> : template<typename _Alloc> -<span class="lineNum"> 377 </span> : struct _Bvector_base -<span class="lineNum"> 378 </span> : { -<span class="lineNum"> 379 </span> : typedef typename _Alloc::template rebind<_Bit_type>::other -<span class="lineNum"> 380 </span> : _Bit_alloc_type; -<span class="lineNum"> 381 </span> : -<span class="lineNum"> 382 </span> : struct _Bvector_impl -<span class="lineNum"> 383 </span> : : public _Bit_alloc_type -<span class="lineNum"> 384 </span><span class="lineCov"> 1 : {</span> -<span class="lineNum"> 385 </span> : _Bit_iterator _M_start; -<span class="lineNum"> 386 </span> : _Bit_iterator _M_finish; -<span class="lineNum"> 387 </span> : _Bit_type* _M_end_of_storage; -<span class="lineNum"> 388 </span> : -<span class="lineNum"> 389 </span><span class="lineCov"> 1 : _Bvector_impl()</span> -<span class="lineNum"> 390 </span><span class="lineCov"> 1 : : _Bit_alloc_type(), _M_start(), _M_finish(), _M_end_of_storage(0)</span> -<span class="lineNum"> 391 </span><span class="lineCov"> 1 : { }</span> -<span class="lineNum"> 392 </span> : -<span class="lineNum"> 393 </span> : _Bvector_impl(const _Bit_alloc_type& __a) -<span class="lineNum"> 394 </span> : : _Bit_alloc_type(__a), _M_start(), _M_finish(), _M_end_of_storage(0) -<span class="lineNum"> 395 </span> : { } -<span class="lineNum"> 396 </span> : }; -<span class="lineNum"> 397 </span> : -<span class="lineNum"> 398 </span> : public: -<span class="lineNum"> 399 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 400 </span> : -<span class="lineNum"> 401 </span> : _Bit_alloc_type& -<span class="lineNum"> 402 </span> : _M_get_Bit_allocator() -<span class="lineNum"> 403 </span> : { return *static_cast<_Bit_alloc_type*>(&this->_M_impl); } -<span class="lineNum"> 404 </span> : -<span class="lineNum"> 405 </span> : const _Bit_alloc_type& -<span class="lineNum"> 406 </span><span class="lineCov"> 2 : _M_get_Bit_allocator() const</span> -<span class="lineNum"> 407 </span><span class="lineCov"> 2 : { return *static_cast<const _Bit_alloc_type*>(&this->_M_impl); }</span> -<span class="lineNum"> 408 </span> : -<span class="lineNum"> 409 </span> : allocator_type -<span class="lineNum"> 410 </span> : get_allocator() const -<span class="lineNum"> 411 </span> : { return allocator_type(_M_get_Bit_allocator()); } -<span class="lineNum"> 412 </span> : -<span class="lineNum"> 413 </span><span class="lineCov"> 1 : _Bvector_base()</span> -<span class="lineNum"> 414 </span><span class="lineCov"> 1 : : _M_impl() { }</span> -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span> : _Bvector_base(const allocator_type& __a) -<span class="lineNum"> 417 </span> : : _M_impl(__a) { } -<span class="lineNum"> 418 </span> : -<span class="lineNum"> 419 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 420 </span> : _Bvector_base(_Bvector_base&& __x) -<span class="lineNum"> 421 </span> : : _M_impl(__x._M_get_Bit_allocator()) -<span class="lineNum"> 422 </span> : { -<span class="lineNum"> 423 </span> : this->_M_impl._M_start = __x._M_impl._M_start; -<span class="lineNum"> 424 </span> : this->_M_impl._M_finish = __x._M_impl._M_finish; -<span class="lineNum"> 425 </span> : this->_M_impl._M_end_of_storage = __x._M_impl._M_end_of_storage; -<span class="lineNum"> 426 </span> : __x._M_impl._M_start = _Bit_iterator(); -<span class="lineNum"> 427 </span> : __x._M_impl._M_finish = _Bit_iterator(); -<span class="lineNum"> 428 </span> : __x._M_impl._M_end_of_storage = 0; -<span class="lineNum"> 429 </span> : } -<span class="lineNum"> 430 </span> : #endif -<span class="lineNum"> 431 </span> : -<span class="lineNum"> 432 </span><span class="lineCov"> 1 : ~_Bvector_base()</span> -<span class="lineNum"> 433 </span><span class="lineCov"> 1 : { this->_M_deallocate(); }</span> -<span class="lineNum"> 434 </span> : -<span class="lineNum"> 435 </span> : protected: -<span class="lineNum"> 436 </span> : _Bvector_impl _M_impl; -<span class="lineNum"> 437 </span> : -<span class="lineNum"> 438 </span> : _Bit_type* -<span class="lineNum"> 439 </span><span class="lineCov"> 1 : _M_allocate(size_t __n)</span> -<span class="lineNum"> 440 </span> : { return _M_impl.allocate((__n + int(_S_word_bit) - 1) -<span class="lineNum"> 441 </span><span class="lineCov"> 1 : / int(_S_word_bit)); }</span> -<span class="lineNum"> 442 </span> : -<span class="lineNum"> 443 </span> : void -<span class="lineNum"> 444 </span><span class="lineCov"> 2 : _M_deallocate()</span> -<span class="lineNum"> 445 </span> : { -<span class="lineNum"> 446 </span><span class="lineCov"> 2 : if (_M_impl._M_start._M_p)</span> -<span class="lineNum"> 447 </span><span class="lineCov"> 1 : _M_impl.deallocate(_M_impl._M_start._M_p,</span> -<span class="lineNum"> 448 </span> : _M_impl._M_end_of_storage - _M_impl._M_start._M_p); -<span class="lineNum"> 449 </span><span class="lineCov"> 2 : }</span> -<span class="lineNum"> 450 </span> : }; -<span class="lineNum"> 451 </span> : -<span class="lineNum"> 452 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 453 </span> : -<span class="lineNum"> 454 </span> : // Declare a partial specialization of vector<T, Alloc>. -<span class="lineNum"> 455 </span> : #include <bits/stl_vector.h> -<span class="lineNum"> 456 </span> : -<span class="lineNum"> 457 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 458 </span> : -<span class="lineNum"> 459 </span> : /** -<span class="lineNum"> 460 </span> : * @brief A specialization of vector for booleans which offers fixed time -<span class="lineNum"> 461 </span> : * access to individual elements in any order. -<span class="lineNum"> 462 </span> : * -<span class="lineNum"> 463 </span> : * Note that vector<bool> does not actually meet the requirements for being -<span class="lineNum"> 464 </span> : * a container. This is because the reference and pointer types are not -<span class="lineNum"> 465 </span> : * really references and pointers to bool. See DR96 for details. @see -<span class="lineNum"> 466 </span> : * vector for function documentation. -<span class="lineNum"> 467 </span> : * -<span class="lineNum"> 468 </span> : * @ingroup Containers -<span class="lineNum"> 469 </span> : * @ingroup Sequences -<span class="lineNum"> 470 </span> : * -<span class="lineNum"> 471 </span> : * In some terminology a %vector can be described as a dynamic -<span class="lineNum"> 472 </span> : * C-style array, it offers fast and efficient access to individual -<span class="lineNum"> 473 </span> : * elements in any order and saves the user from worrying about -<span class="lineNum"> 474 </span> : * memory and size allocation. Subscripting ( @c [] ) access is -<span class="lineNum"> 475 </span> : * also provided as with C-style arrays. -<span class="lineNum"> 476 </span> : */ -<span class="lineNum"> 477 </span> : template<typename _Alloc> -<span class="lineNum"> 478 </span> : class vector<bool, _Alloc> : protected _Bvector_base<_Alloc> -<span class="lineNum"> 479 </span> : { -<span class="lineNum"> 480 </span> : typedef _Bvector_base<_Alloc> _Base; -<span class="lineNum"> 481 </span> : -<span class="lineNum"> 482 </span> : public: -<span class="lineNum"> 483 </span> : typedef bool value_type; -<span class="lineNum"> 484 </span> : typedef size_t size_type; -<span class="lineNum"> 485 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 486 </span> : typedef _Bit_reference reference; -<span class="lineNum"> 487 </span> : typedef bool const_reference; -<span class="lineNum"> 488 </span> : typedef _Bit_reference* pointer; -<span class="lineNum"> 489 </span> : typedef const bool* const_pointer; -<span class="lineNum"> 490 </span> : typedef _Bit_iterator iterator; -<span class="lineNum"> 491 </span> : typedef _Bit_const_iterator const_iterator; -<span class="lineNum"> 492 </span> : typedef std::reverse_iterator<const_iterator> const_reverse_iterator; -<span class="lineNum"> 493 </span> : typedef std::reverse_iterator<iterator> reverse_iterator; -<span class="lineNum"> 494 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 495 </span> : -<span class="lineNum"> 496 </span> : allocator_type get_allocator() const -<span class="lineNum"> 497 </span> : { return _Base::get_allocator(); } -<span class="lineNum"> 498 </span> : -<span class="lineNum"> 499 </span> : protected: -<span class="lineNum"> 500 </span> : using _Base::_M_allocate; -<span class="lineNum"> 501 </span> : using _Base::_M_deallocate; -<span class="lineNum"> 502 </span> : using _Base::_M_get_Bit_allocator; -<span class="lineNum"> 503 </span> : -<span class="lineNum"> 504 </span> : public: -<span class="lineNum"> 505 </span><span class="lineCov"> 1 : vector()</span> -<span class="lineNum"> 506 </span><span class="lineCov"> 1 : : _Base() { }</span> -<span class="lineNum"> 507 </span> : -<span class="lineNum"> 508 </span> : explicit -<span class="lineNum"> 509 </span> : vector(const allocator_type& __a) -<span class="lineNum"> 510 </span> : : _Base(__a) { } -<span class="lineNum"> 511 </span> : -<span class="lineNum"> 512 </span> : explicit -<span class="lineNum"> 513 </span> : vector(size_type __n, const bool& __value = bool(), -<span class="lineNum"> 514 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 515 </span> : : _Base(__a) -<span class="lineNum"> 516 </span> : { -<span class="lineNum"> 517 </span> : _M_initialize(__n); -<span class="lineNum"> 518 </span> : std::fill(this->_M_impl._M_start._M_p, this->_M_impl._M_end_of_storage, -<span class="lineNum"> 519 </span> : __value ? ~0 : 0); -<span class="lineNum"> 520 </span> : } -<span class="lineNum"> 521 </span> : -<span class="lineNum"> 522 </span> : vector(const vector& __x) -<span class="lineNum"> 523 </span> : : _Base(__x._M_get_Bit_allocator()) -<span class="lineNum"> 524 </span> : { -<span class="lineNum"> 525 </span> : _M_initialize(__x.size()); -<span class="lineNum"> 526 </span> : _M_copy_aligned(__x.begin(), __x.end(), this->_M_impl._M_start); -<span class="lineNum"> 527 </span> : } -<span class="lineNum"> 528 </span> : -<span class="lineNum"> 529 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 530 </span> : vector(vector&& __x) -<span class="lineNum"> 531 </span> : : _Base(std::forward<_Base>(__x)) { } -<span class="lineNum"> 532 </span> : #endif -<span class="lineNum"> 533 </span> : -<span class="lineNum"> 534 </span> : template<typename _InputIterator> -<span class="lineNum"> 535 </span> : vector(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 536 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 537 </span> : : _Base(__a) -<span class="lineNum"> 538 </span> : { -<span class="lineNum"> 539 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 540 </span> : _M_initialize_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 541 </span> : } -<span class="lineNum"> 542 </span> : -<span class="lineNum"> 543 </span><span class="lineCov"> 1 : ~vector() { }</span> -<span class="lineNum"> 544 </span> : -<span class="lineNum"> 545 </span> : vector& -<span class="lineNum"> 546 </span> : operator=(const vector& __x) -<span class="lineNum"> 547 </span> : { -<span class="lineNum"> 548 </span> : if (&__x == this) -<span class="lineNum"> 549 </span> : return *this; -<span class="lineNum"> 550 </span> : if (__x.size() > capacity()) -<span class="lineNum"> 551 </span> : { -<span class="lineNum"> 552 </span> : this->_M_deallocate(); -<span class="lineNum"> 553 </span> : _M_initialize(__x.size()); -<span class="lineNum"> 554 </span> : } -<span class="lineNum"> 555 </span> : this->_M_impl._M_finish = _M_copy_aligned(__x.begin(), __x.end(), -<span class="lineNum"> 556 </span> : begin()); -<span class="lineNum"> 557 </span> : return *this; -<span class="lineNum"> 558 </span> : } -<span class="lineNum"> 559 </span> : -<span class="lineNum"> 560 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 561 </span> : vector& -<span class="lineNum"> 562 </span> : operator=(vector&& __x) -<span class="lineNum"> 563 </span> : { -<span class="lineNum"> 564 </span> : // NB: DR 675. -<span class="lineNum"> 565 </span> : this->clear(); -<span class="lineNum"> 566 </span> : this->swap(__x); -<span class="lineNum"> 567 </span> : return *this; -<span class="lineNum"> 568 </span> : } -<span class="lineNum"> 569 </span> : #endif -<span class="lineNum"> 570 </span> : -<span class="lineNum"> 571 </span> : // assign(), a generalized assignment member function. Two -<span class="lineNum"> 572 </span> : // versions: one that takes a count, and one that takes a range. -<span class="lineNum"> 573 </span> : // The range version is a member template, so we dispatch on whether -<span class="lineNum"> 574 </span> : // or not the type is an integer. -<span class="lineNum"> 575 </span> : void -<span class="lineNum"> 576 </span> : assign(size_type __n, const bool& __x) -<span class="lineNum"> 577 </span> : { _M_fill_assign(__n, __x); } -<span class="lineNum"> 578 </span> : -<span class="lineNum"> 579 </span> : template<typename _InputIterator> -<span class="lineNum"> 580 </span> : void -<span class="lineNum"> 581 </span> : assign(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 582 </span> : { -<span class="lineNum"> 583 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 584 </span> : _M_assign_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 585 </span> : } -<span class="lineNum"> 586 </span> : -<span class="lineNum"> 587 </span> : iterator -<span class="lineNum"> 588 </span><span class="lineCov"> 1 : begin()</span> -<span class="lineNum"> 589 </span><span class="lineCov"> 1 : { return this->_M_impl._M_start; }</span> -<span class="lineNum"> 590 </span> : -<span class="lineNum"> 591 </span> : const_iterator -<span class="lineNum"> 592 </span><span class="lineCov"> 10 : begin() const</span> -<span class="lineNum"> 593 </span><span class="lineCov"> 10 : { return this->_M_impl._M_start; }</span> -<span class="lineNum"> 594 </span> : -<span class="lineNum"> 595 </span> : iterator -<span class="lineNum"> 596 </span><span class="lineCov"> 2 : end()</span> -<span class="lineNum"> 597 </span><span class="lineCov"> 2 : { return this->_M_impl._M_finish; }</span> -<span class="lineNum"> 598 </span> : -<span class="lineNum"> 599 </span> : const_iterator -<span class="lineNum"> 600 </span><span class="lineCov"> 10 : end() const</span> -<span class="lineNum"> 601 </span><span class="lineCov"> 10 : { return this->_M_impl._M_finish; }</span> -<span class="lineNum"> 602 </span> : -<span class="lineNum"> 603 </span> : reverse_iterator -<span class="lineNum"> 604 </span> : rbegin() -<span class="lineNum"> 605 </span> : { return reverse_iterator(end()); } -<span class="lineNum"> 606 </span> : -<span class="lineNum"> 607 </span> : const_reverse_iterator -<span class="lineNum"> 608 </span> : rbegin() const -<span class="lineNum"> 609 </span> : { return const_reverse_iterator(end()); } -<span class="lineNum"> 610 </span> : -<span class="lineNum"> 611 </span> : reverse_iterator -<span class="lineNum"> 612 </span> : rend() -<span class="lineNum"> 613 </span> : { return reverse_iterator(begin()); } -<span class="lineNum"> 614 </span> : -<span class="lineNum"> 615 </span> : const_reverse_iterator -<span class="lineNum"> 616 </span> : rend() const -<span class="lineNum"> 617 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 618 </span> : -<span class="lineNum"> 619 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 620 </span> : const_iterator -<span class="lineNum"> 621 </span> : cbegin() const -<span class="lineNum"> 622 </span> : { return this->_M_impl._M_start; } -<span class="lineNum"> 623 </span> : -<span class="lineNum"> 624 </span> : const_iterator -<span class="lineNum"> 625 </span> : cend() const -<span class="lineNum"> 626 </span> : { return this->_M_impl._M_finish; } -<span class="lineNum"> 627 </span> : -<span class="lineNum"> 628 </span> : const_reverse_iterator -<span class="lineNum"> 629 </span> : crbegin() const -<span class="lineNum"> 630 </span> : { return const_reverse_iterator(end()); } -<span class="lineNum"> 631 </span> : -<span class="lineNum"> 632 </span> : const_reverse_iterator -<span class="lineNum"> 633 </span> : crend() const -<span class="lineNum"> 634 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 635 </span> : #endif -<span class="lineNum"> 636 </span> : -<span class="lineNum"> 637 </span> : size_type -<span class="lineNum"> 638 </span><span class="lineCov"> 7 : size() const</span> -<span class="lineNum"> 639 </span><span class="lineCov"> 7 : { return size_type(end() - begin()); }</span> -<span class="lineNum"> 640 </span> : -<span class="lineNum"> 641 </span> : size_type -<span class="lineNum"> 642 </span><span class="lineCov"> 2 : max_size() const</span> -<span class="lineNum"> 643 </span> : { -<span class="lineNum"> 644 </span> : const size_type __isize = -<span class="lineNum"> 645 </span> : __gnu_cxx::__numeric_traits<difference_type>::__max -<span class="lineNum"> 646 </span><span class="lineCov"> 2 : - int(_S_word_bit) + 1;</span> -<span class="lineNum"> 647 </span><span class="lineCov"> 2 : const size_type __asize = _M_get_Bit_allocator().max_size();</span> -<span class="lineNum"> 648 </span> : return (__asize <= __isize / int(_S_word_bit) -<span class="lineNum"> 649 </span><span class="lineCov"> 2 : ? __asize * int(_S_word_bit) : __isize);</span> -<span class="lineNum"> 650 </span> : } -<span class="lineNum"> 651 </span> : -<span class="lineNum"> 652 </span> : size_type -<span class="lineNum"> 653 </span> : capacity() const -<span class="lineNum"> 654 </span> : { return size_type(const_iterator(this->_M_impl._M_end_of_storage, 0) -<span class="lineNum"> 655 </span> : - begin()); } -<span class="lineNum"> 656 </span> : -<span class="lineNum"> 657 </span> : bool -<span class="lineNum"> 658 </span><span class="lineCov"> 3 : empty() const</span> -<span class="lineNum"> 659 </span><span class="lineCov"> 3 : { return begin() == end(); }</span> -<span class="lineNum"> 660 </span> : -<span class="lineNum"> 661 </span> : reference -<span class="lineNum"> 662 </span> : operator[](size_type __n) -<span class="lineNum"> 663 </span> : { -<span class="lineNum"> 664 </span> : return *iterator(this->_M_impl._M_start._M_p -<span class="lineNum"> 665 </span> : + __n / int(_S_word_bit), __n % int(_S_word_bit)); -<span class="lineNum"> 666 </span> : } -<span class="lineNum"> 667 </span> : -<span class="lineNum"> 668 </span> : const_reference -<span class="lineNum"> 669 </span><span class="lineCov"> 3 : operator[](size_type __n) const</span> -<span class="lineNum"> 670 </span> : { -<span class="lineNum"> 671 </span> : return *const_iterator(this->_M_impl._M_start._M_p -<span class="lineNum"> 672 </span><span class="lineCov"> 3 : + __n / int(_S_word_bit), __n % int(_S_word_bit));</span> -<span class="lineNum"> 673 </span> : } -<span class="lineNum"> 674 </span> : -<span class="lineNum"> 675 </span> : protected: -<span class="lineNum"> 676 </span> : void -<span class="lineNum"> 677 </span> : _M_range_check(size_type __n) const -<span class="lineNum"> 678 </span> : { -<span class="lineNum"> 679 </span> : if (__n >= this->size()) -<span class="lineNum"> 680 </span> : __throw_out_of_range(__N("vector<bool>::_M_range_check")); -<span class="lineNum"> 681 </span> : } -<span class="lineNum"> 682 </span> : -<span class="lineNum"> 683 </span> : public: -<span class="lineNum"> 684 </span> : reference -<span class="lineNum"> 685 </span> : at(size_type __n) -<span class="lineNum"> 686 </span> : { _M_range_check(__n); return (*this)[__n]; } -<span class="lineNum"> 687 </span> : -<span class="lineNum"> 688 </span> : const_reference -<span class="lineNum"> 689 </span> : at(size_type __n) const -<span class="lineNum"> 690 </span> : { _M_range_check(__n); return (*this)[__n]; } -<span class="lineNum"> 691 </span> : -<span class="lineNum"> 692 </span> : void -<span class="lineNum"> 693 </span> : reserve(size_type __n); -<span class="lineNum"> 694 </span> : -<span class="lineNum"> 695 </span> : reference -<span class="lineNum"> 696 </span> : front() -<span class="lineNum"> 697 </span> : { return *begin(); } -<span class="lineNum"> 698 </span> : -<span class="lineNum"> 699 </span> : const_reference -<span class="lineNum"> 700 </span> : front() const -<span class="lineNum"> 701 </span> : { return *begin(); } -<span class="lineNum"> 702 </span> : -<span class="lineNum"> 703 </span> : reference -<span class="lineNum"> 704 </span> : back() -<span class="lineNum"> 705 </span> : { return *(end() - 1); } -<span class="lineNum"> 706 </span> : -<span class="lineNum"> 707 </span> : const_reference -<span class="lineNum"> 708 </span> : back() const -<span class="lineNum"> 709 </span> : { return *(end() - 1); } -<span class="lineNum"> 710 </span> : -<span class="lineNum"> 711 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 712 </span> : // DR 464. Suggestion for new member functions in standard containers. -<span class="lineNum"> 713 </span> : // N.B. DR 464 says nothing about vector<bool> but we need something -<span class="lineNum"> 714 </span> : // here due to the way we are implementing DR 464 in the debug-mode -<span class="lineNum"> 715 </span> : // vector class. -<span class="lineNum"> 716 </span> : void -<span class="lineNum"> 717 </span> : data() { } -<span class="lineNum"> 718 </span> : -<span class="lineNum"> 719 </span> : void -<span class="lineNum"> 720 </span><span class="lineCov"> 2 : push_back(bool __x)</span> -<span class="lineNum"> 721 </span> : { -<span class="lineNum"> 722 </span><span class="lineCov"> 2 : if (this->_M_impl._M_finish._M_p != this->_M_impl._M_end_of_storage)</span> -<span class="lineNum"> 723 </span><span class="lineCov"> 1 : *this->_M_impl._M_finish++ = __x;</span> -<span class="lineNum"> 724 </span> : else -<span class="lineNum"> 725 </span><span class="lineCov"> 1 : _M_insert_aux(end(), __x);</span> -<span class="lineNum"> 726 </span><span class="lineCov"> 2 : }</span> -<span class="lineNum"> 727 </span> : -<span class="lineNum"> 728 </span> : void -<span class="lineNum"> 729 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 730 </span> : swap(vector&& __x) -<span class="lineNum"> 731 </span> : #else -<span class="lineNum"> 732 </span> : swap(vector& __x) -<span class="lineNum"> 733 </span> : #endif -<span class="lineNum"> 734 </span> : { -<span class="lineNum"> 735 </span> : std::swap(this->_M_impl._M_start, __x._M_impl._M_start); -<span class="lineNum"> 736 </span> : std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); -<span class="lineNum"> 737 </span> : std::swap(this->_M_impl._M_end_of_storage, -<span class="lineNum"> 738 </span> : __x._M_impl._M_end_of_storage); -<span class="lineNum"> 739 </span> : -<span class="lineNum"> 740 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 741 </span> : // 431. Swapping containers with unequal allocators. -<span class="lineNum"> 742 </span> : std::__alloc_swap<typename _Base::_Bit_alloc_type>:: -<span class="lineNum"> 743 </span> : _S_do_it(_M_get_Bit_allocator(), __x._M_get_Bit_allocator()); -<span class="lineNum"> 744 </span> : } -<span class="lineNum"> 745 </span> : -<span class="lineNum"> 746 </span> : // [23.2.5]/1, third-to-last entry in synopsis listing -<span class="lineNum"> 747 </span> : static void -<span class="lineNum"> 748 </span> : swap(reference __x, reference __y) -<span class="lineNum"> 749 </span> : { -<span class="lineNum"> 750 </span> : bool __tmp = __x; -<span class="lineNum"> 751 </span> : __x = __y; -<span class="lineNum"> 752 </span> : __y = __tmp; -<span class="lineNum"> 753 </span> : } -<span class="lineNum"> 754 </span> : -<span class="lineNum"> 755 </span> : iterator -<span class="lineNum"> 756 </span> : insert(iterator __position, const bool& __x = bool()) -<span class="lineNum"> 757 </span> : { -<span class="lineNum"> 758 </span> : const difference_type __n = __position - begin(); -<span class="lineNum"> 759 </span> : if (this->_M_impl._M_finish._M_p != this->_M_impl._M_end_of_storage -<span class="lineNum"> 760 </span> : && __position == end()) -<span class="lineNum"> 761 </span> : *this->_M_impl._M_finish++ = __x; -<span class="lineNum"> 762 </span> : else -<span class="lineNum"> 763 </span> : _M_insert_aux(__position, __x); -<span class="lineNum"> 764 </span> : return begin() + __n; -<span class="lineNum"> 765 </span> : } -<span class="lineNum"> 766 </span> : -<span class="lineNum"> 767 </span> : template<typename _InputIterator> -<span class="lineNum"> 768 </span> : void -<span class="lineNum"> 769 </span> : insert(iterator __position, -<span class="lineNum"> 770 </span> : _InputIterator __first, _InputIterator __last) -<span class="lineNum"> 771 </span> : { -<span class="lineNum"> 772 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 773 </span> : _M_insert_dispatch(__position, __first, __last, _Integral()); -<span class="lineNum"> 774 </span> : } -<span class="lineNum"> 775 </span> : -<span class="lineNum"> 776 </span> : void -<span class="lineNum"> 777 </span> : insert(iterator __position, size_type __n, const bool& __x) -<span class="lineNum"> 778 </span> : { _M_fill_insert(__position, __n, __x); } -<span class="lineNum"> 779 </span> : -<span class="lineNum"> 780 </span> : void -<span class="lineNum"> 781 </span> : pop_back() -<span class="lineNum"> 782 </span> : { --this->_M_impl._M_finish; } -<span class="lineNum"> 783 </span> : -<span class="lineNum"> 784 </span> : iterator -<span class="lineNum"> 785 </span> : erase(iterator __position) -<span class="lineNum"> 786 </span> : { -<span class="lineNum"> 787 </span> : if (__position + 1 != end()) -<span class="lineNum"> 788 </span> : std::copy(__position + 1, end(), __position); -<span class="lineNum"> 789 </span> : --this->_M_impl._M_finish; -<span class="lineNum"> 790 </span> : return __position; -<span class="lineNum"> 791 </span> : } -<span class="lineNum"> 792 </span> : -<span class="lineNum"> 793 </span> : iterator -<span class="lineNum"> 794 </span> : erase(iterator __first, iterator __last) -<span class="lineNum"> 795 </span> : { -<span class="lineNum"> 796 </span> : _M_erase_at_end(std::copy(__last, end(), __first)); -<span class="lineNum"> 797 </span> : return __first; -<span class="lineNum"> 798 </span> : } -<span class="lineNum"> 799 </span> : -<span class="lineNum"> 800 </span> : void -<span class="lineNum"> 801 </span> : resize(size_type __new_size, bool __x = bool()) -<span class="lineNum"> 802 </span> : { -<span class="lineNum"> 803 </span> : if (__new_size < size()) -<span class="lineNum"> 804 </span> : _M_erase_at_end(begin() + difference_type(__new_size)); -<span class="lineNum"> 805 </span> : else -<span class="lineNum"> 806 </span> : insert(end(), __new_size - size(), __x); -<span class="lineNum"> 807 </span> : } -<span class="lineNum"> 808 </span> : -<span class="lineNum"> 809 </span> : void -<span class="lineNum"> 810 </span> : flip() -<span class="lineNum"> 811 </span> : { -<span class="lineNum"> 812 </span> : for (_Bit_type * __p = this->_M_impl._M_start._M_p; -<span class="lineNum"> 813 </span> : __p != this->_M_impl._M_end_of_storage; ++__p) -<span class="lineNum"> 814 </span> : *__p = ~*__p; -<span class="lineNum"> 815 </span> : } -<span class="lineNum"> 816 </span> : -<span class="lineNum"> 817 </span> : void -<span class="lineNum"> 818 </span> : clear() -<span class="lineNum"> 819 </span> : { _M_erase_at_end(begin()); } -<span class="lineNum"> 820 </span> : -<span class="lineNum"> 821 </span> : -<span class="lineNum"> 822 </span> : protected: -<span class="lineNum"> 823 </span> : // Precondition: __first._M_offset == 0 && __result._M_offset == 0. -<span class="lineNum"> 824 </span> : iterator -<span class="lineNum"> 825 </span> : _M_copy_aligned(const_iterator __first, const_iterator __last, -<span class="lineNum"> 826 </span><span class="lineCov"> 1 : iterator __result)</span> -<span class="lineNum"> 827 </span> : { -<span class="lineNum"> 828 </span><span class="lineCov"> 1 : _Bit_type* __q = std::copy(__first._M_p, __last._M_p, __result._M_p);</span> -<span class="lineNum"> 829 </span> : return std::copy(const_iterator(__last._M_p, 0), __last, -<span class="lineNum"> 830 </span><span class="lineCov"> 1 : iterator(__q, 0));</span> -<span class="lineNum"> 831 </span> : } -<span class="lineNum"> 832 </span> : -<span class="lineNum"> 833 </span> : void -<span class="lineNum"> 834 </span> : _M_initialize(size_type __n) -<span class="lineNum"> 835 </span> : { -<span class="lineNum"> 836 </span> : _Bit_type* __q = this->_M_allocate(__n); -<span class="lineNum"> 837 </span> : this->_M_impl._M_end_of_storage = (__q -<span class="lineNum"> 838 </span> : + ((__n + int(_S_word_bit) - 1) -<span class="lineNum"> 839 </span> : / int(_S_word_bit))); -<span class="lineNum"> 840 </span> : this->_M_impl._M_start = iterator(__q, 0); -<span class="lineNum"> 841 </span> : this->_M_impl._M_finish = this->_M_impl._M_start + difference_type(__n); -<span class="lineNum"> 842 </span> : } -<span class="lineNum"> 843 </span> : -<span class="lineNum"> 844 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 845 </span> : -<span class="lineNum"> 846 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 847 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 848 </span> : template<typename _Integer> -<span class="lineNum"> 849 </span> : void -<span class="lineNum"> 850 </span> : _M_initialize_dispatch(_Integer __n, _Integer __x, __true_type) -<span class="lineNum"> 851 </span> : { -<span class="lineNum"> 852 </span> : _M_initialize(static_cast<size_type>(__n)); -<span class="lineNum"> 853 </span> : std::fill(this->_M_impl._M_start._M_p, -<span class="lineNum"> 854 </span> : this->_M_impl._M_end_of_storage, __x ? ~0 : 0); -<span class="lineNum"> 855 </span> : } -<span class="lineNum"> 856 </span> : -<span class="lineNum"> 857 </span> : template<typename _InputIterator> -<span class="lineNum"> 858 </span> : void -<span class="lineNum"> 859 </span> : _M_initialize_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 860 </span> : __false_type) -<span class="lineNum"> 861 </span> : { _M_initialize_range(__first, __last, -<span class="lineNum"> 862 </span> : std::__iterator_category(__first)); } -<span class="lineNum"> 863 </span> : -<span class="lineNum"> 864 </span> : template<typename _InputIterator> -<span class="lineNum"> 865 </span> : void -<span class="lineNum"> 866 </span> : _M_initialize_range(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 867 </span> : std::input_iterator_tag) -<span class="lineNum"> 868 </span> : { -<span class="lineNum"> 869 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 870 </span> : push_back(*__first); -<span class="lineNum"> 871 </span> : } -<span class="lineNum"> 872 </span> : -<span class="lineNum"> 873 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 874 </span> : void -<span class="lineNum"> 875 </span> : _M_initialize_range(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 876 </span> : std::forward_iterator_tag) -<span class="lineNum"> 877 </span> : { -<span class="lineNum"> 878 </span> : const size_type __n = std::distance(__first, __last); -<span class="lineNum"> 879 </span> : _M_initialize(__n); -<span class="lineNum"> 880 </span> : std::copy(__first, __last, this->_M_impl._M_start); -<span class="lineNum"> 881 </span> : } -<span class="lineNum"> 882 </span> : -<span class="lineNum"> 883 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 884 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 885 </span> : template<typename _Integer> -<span class="lineNum"> 886 </span> : void -<span class="lineNum"> 887 </span> : _M_assign_dispatch(_Integer __n, _Integer __val, __true_type) -<span class="lineNum"> 888 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 889 </span> : -<span class="lineNum"> 890 </span> : template<class _InputIterator> -<span class="lineNum"> 891 </span> : void -<span class="lineNum"> 892 </span> : _M_assign_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 893 </span> : __false_type) -<span class="lineNum"> 894 </span> : { _M_assign_aux(__first, __last, std::__iterator_category(__first)); } -<span class="lineNum"> 895 </span> : -<span class="lineNum"> 896 </span> : void -<span class="lineNum"> 897 </span> : _M_fill_assign(size_t __n, bool __x) -<span class="lineNum"> 898 </span> : { -<span class="lineNum"> 899 </span> : if (__n > size()) -<span class="lineNum"> 900 </span> : { -<span class="lineNum"> 901 </span> : std::fill(this->_M_impl._M_start._M_p, -<span class="lineNum"> 902 </span> : this->_M_impl._M_end_of_storage, __x ? ~0 : 0); -<span class="lineNum"> 903 </span> : insert(end(), __n - size(), __x); -<span class="lineNum"> 904 </span> : } -<span class="lineNum"> 905 </span> : else -<span class="lineNum"> 906 </span> : { -<span class="lineNum"> 907 </span> : _M_erase_at_end(begin() + __n); -<span class="lineNum"> 908 </span> : std::fill(this->_M_impl._M_start._M_p, -<span class="lineNum"> 909 </span> : this->_M_impl._M_end_of_storage, __x ? ~0 : 0); -<span class="lineNum"> 910 </span> : } -<span class="lineNum"> 911 </span> : } -<span class="lineNum"> 912 </span> : -<span class="lineNum"> 913 </span> : template<typename _InputIterator> -<span class="lineNum"> 914 </span> : void -<span class="lineNum"> 915 </span> : _M_assign_aux(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 916 </span> : std::input_iterator_tag) -<span class="lineNum"> 917 </span> : { -<span class="lineNum"> 918 </span> : iterator __cur = begin(); -<span class="lineNum"> 919 </span> : for (; __first != __last && __cur != end(); ++__cur, ++__first) -<span class="lineNum"> 920 </span> : *__cur = *__first; -<span class="lineNum"> 921 </span> : if (__first == __last) -<span class="lineNum"> 922 </span> : _M_erase_at_end(__cur); -<span class="lineNum"> 923 </span> : else -<span class="lineNum"> 924 </span> : insert(end(), __first, __last); -<span class="lineNum"> 925 </span> : } -<span class="lineNum"> 926 </span> : -<span class="lineNum"> 927 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 928 </span> : void -<span class="lineNum"> 929 </span> : _M_assign_aux(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 930 </span> : std::forward_iterator_tag) -<span class="lineNum"> 931 </span> : { -<span class="lineNum"> 932 </span> : const size_type __len = std::distance(__first, __last); -<span class="lineNum"> 933 </span> : if (__len < size()) -<span class="lineNum"> 934 </span> : _M_erase_at_end(std::copy(__first, __last, begin())); -<span class="lineNum"> 935 </span> : else -<span class="lineNum"> 936 </span> : { -<span class="lineNum"> 937 </span> : _ForwardIterator __mid = __first; -<span class="lineNum"> 938 </span> : std::advance(__mid, size()); -<span class="lineNum"> 939 </span> : std::copy(__first, __mid, begin()); -<span class="lineNum"> 940 </span> : insert(end(), __mid, __last); -<span class="lineNum"> 941 </span> : } -<span class="lineNum"> 942 </span> : } -<span class="lineNum"> 943 </span> : -<span class="lineNum"> 944 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 945 </span> : -<span class="lineNum"> 946 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 947 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 948 </span> : template<typename _Integer> -<span class="lineNum"> 949 </span> : void -<span class="lineNum"> 950 </span> : _M_insert_dispatch(iterator __pos, _Integer __n, _Integer __x, -<span class="lineNum"> 951 </span> : __true_type) -<span class="lineNum"> 952 </span> : { _M_fill_insert(__pos, __n, __x); } -<span class="lineNum"> 953 </span> : -<span class="lineNum"> 954 </span> : template<typename _InputIterator> -<span class="lineNum"> 955 </span> : void -<span class="lineNum"> 956 </span> : _M_insert_dispatch(iterator __pos, -<span class="lineNum"> 957 </span> : _InputIterator __first, _InputIterator __last, -<span class="lineNum"> 958 </span> : __false_type) -<span class="lineNum"> 959 </span> : { _M_insert_range(__pos, __first, __last, -<span class="lineNum"> 960 </span> : std::__iterator_category(__first)); } -<span class="lineNum"> 961 </span> : -<span class="lineNum"> 962 </span> : void -<span class="lineNum"> 963 </span> : _M_fill_insert(iterator __position, size_type __n, bool __x); -<span class="lineNum"> 964 </span> : -<span class="lineNum"> 965 </span> : template<typename _InputIterator> -<span class="lineNum"> 966 </span> : void -<span class="lineNum"> 967 </span> : _M_insert_range(iterator __pos, _InputIterator __first, -<span class="lineNum"> 968 </span> : _InputIterator __last, std::input_iterator_tag) -<span class="lineNum"> 969 </span> : { -<span class="lineNum"> 970 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 971 </span> : { -<span class="lineNum"> 972 </span> : __pos = insert(__pos, *__first); -<span class="lineNum"> 973 </span> : ++__pos; -<span class="lineNum"> 974 </span> : } -<span class="lineNum"> 975 </span> : } -<span class="lineNum"> 976 </span> : -<span class="lineNum"> 977 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 978 </span> : void -<span class="lineNum"> 979 </span> : _M_insert_range(iterator __position, _ForwardIterator __first, -<span class="lineNum"> 980 </span> : _ForwardIterator __last, std::forward_iterator_tag); -<span class="lineNum"> 981 </span> : -<span class="lineNum"> 982 </span> : void -<span class="lineNum"> 983 </span> : _M_insert_aux(iterator __position, bool __x); -<span class="lineNum"> 984 </span> : -<span class="lineNum"> 985 </span> : size_type -<span class="lineNum"> 986 </span><span class="lineCov"> 1 : _M_check_len(size_type __n, const char* __s) const</span> -<span class="lineNum"> 987 </span> : { -<span class="lineNum"> 988 </span><span class="lineCov"> 1 : if (max_size() - size() < __n)</span> -<span class="lineNum"> 989 </span><span class="lineNoCov"> 0 : __throw_length_error(__N(__s));</span> -<span class="lineNum"> 990 </span> : -<span class="lineNum"> 991 </span><span class="lineCov"> 1 : const size_type __len = size() + std::max(size(), __n);</span> -<span class="lineNum"> 992 </span><span class="lineCov"> 1 : return (__len < size() || __len > max_size()) ? max_size() : __len;</span> -<span class="lineNum"> 993 </span> : } -<span class="lineNum"> 994 </span> : -<span class="lineNum"> 995 </span> : void -<span class="lineNum"> 996 </span> : _M_erase_at_end(iterator __pos) -<span class="lineNum"> 997 </span> : { this->_M_impl._M_finish = __pos; } -<span class="lineNum"> 998 </span> : }; -<span class="lineNum"> 999 </span> : -<span class="lineNum"> 1000 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 1001 </span> : -<span class="lineNum"> 1002 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_construct.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_construct.h.gcov.html deleted file mode 100644 index 82847c7..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_construct.h.gcov.html +++ /dev/null @@ -1,201 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_construct.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_construct.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">12</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">12</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // nonstandard construct and destroy functions -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_construct.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_CONSTRUCT_H -<span class="lineNum"> 63 </span> : #define _STL_CONSTRUCT_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <new> -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : /** -<span class="lineNum"> 70 </span> : * Constructs an object in existing memory by invoking an allocated -<span class="lineNum"> 71 </span> : * object's constructor with an initializer. -<span class="lineNum"> 72 </span> : */ -<span class="lineNum"> 73 </span> : template<typename _T1, typename _T2> -<span class="lineNum"> 74 </span> : inline void -<span class="lineNum"> 75 </span><span class="lineCov"> 23695 : _Construct(_T1* __p, const _T2& __value)</span> -<span class="lineNum"> 76 </span> : { -<span class="lineNum"> 77 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 78 </span> : // 402. wrong new expression in [some_]allocator::construct -<span class="lineNum"> 79 </span><span class="lineCov"> 23695 : ::new(static_cast<void*>(__p)) _T1(__value);</span> -<span class="lineNum"> 80 </span><span class="lineCov"> 23695 : }</span> -<span class="lineNum"> 81 </span> : -<span class="lineNum"> 82 </span> : /** -<span class="lineNum"> 83 </span> : * Destroy the object pointed to by a pointer type. -<span class="lineNum"> 84 </span> : */ -<span class="lineNum"> 85 </span> : template<typename _Tp> -<span class="lineNum"> 86 </span> : inline void -<span class="lineNum"> 87 </span><span class="lineCov"> 82748 : _Destroy(_Tp* __pointer)</span> -<span class="lineNum"> 88 </span><span class="lineCov"> 82748 : { __pointer->~_Tp(); }</span> -<span class="lineNum"> 89 </span> : -<span class="lineNum"> 90 </span> : /** -<span class="lineNum"> 91 </span> : * Destroy a range of objects. If the value_type of the object has -<span class="lineNum"> 92 </span> : * a trivial destructor, the compiler should optimize all of this -<span class="lineNum"> 93 </span> : * away, otherwise the objects' destructors must be invoked. -<span class="lineNum"> 94 </span> : */ -<span class="lineNum"> 95 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 96 </span> : inline void -<span class="lineNum"> 97 </span><span class="lineCov"> 33441 : _Destroy(_ForwardIterator __first, _ForwardIterator __last)</span> -<span class="lineNum"> 98 </span> : { -<span class="lineNum"> 99 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 100 </span> : _Value_type; -<span class="lineNum"> 101 </span><span class="lineCov"> 91960 : if (!__has_trivial_destructor(_Value_type))</span> -<span class="lineNum"> 102 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 103 </span><span class="lineCov"> 82748 : std::_Destroy(&*__first);</span> -<span class="lineNum"> 104 </span><span class="lineCov"> 33441 : }</span> -<span class="lineNum"> 105 </span> : -<span class="lineNum"> 106 </span> : /** -<span class="lineNum"> 107 </span> : * Destroy a range of objects using the supplied allocator. For -<span class="lineNum"> 108 </span> : * nondefault allocators we do not optimize away invocation of -<span class="lineNum"> 109 </span> : * destroy() even if _Tp has a trivial destructor. -<span class="lineNum"> 110 </span> : */ -<span class="lineNum"> 111 </span> : -<span class="lineNum"> 112 </span> : template <typename _Tp> class allocator; -<span class="lineNum"> 113 </span> : -<span class="lineNum"> 114 </span> : template<typename _ForwardIterator, typename _Allocator> -<span class="lineNum"> 115 </span> : void -<span class="lineNum"> 116 </span> : _Destroy(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 117 </span> : _Allocator& __alloc) -<span class="lineNum"> 118 </span> : { -<span class="lineNum"> 119 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 120 </span> : __alloc.destroy(&*__first); -<span class="lineNum"> 121 </span> : } -<span class="lineNum"> 122 </span> : -<span class="lineNum"> 123 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 124 </span> : inline void -<span class="lineNum"> 125 </span> : _Destroy(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 126 </span><span class="lineCov"> 33441 : allocator<_Tp>&)</span> -<span class="lineNum"> 127 </span> : { -<span class="lineNum"> 128 </span><span class="lineCov"> 33441 : _Destroy(__first, __last);</span> -<span class="lineNum"> 129 </span><span class="lineCov"> 33441 : }</span> -<span class="lineNum"> 130 </span> : -<span class="lineNum"> 131 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 132 </span> : -<span class="lineNum"> 133 </span> : #endif /* _STL_CONSTRUCT_H */ -<span class="lineNum"> 134 </span> : -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_deque.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_deque.h.gcov.html deleted file mode 100644 index 6fe09f3..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_deque.h.gcov.html +++ /dev/null @@ -1,1837 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_deque.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_deque.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">189</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">78.3 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">148</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Deque implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_deque.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_DEQUE_H -<span class="lineNum"> 63 </span> : #define _STL_DEQUE_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 66 </span> : #include <bits/stl_iterator_base_types.h> -<span class="lineNum"> 67 </span> : #include <bits/stl_iterator_base_funcs.h> -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 70 </span> : -<span class="lineNum"> 71 </span> : /** -<span class="lineNum"> 72 </span> : * @brief This function controls the size of memory nodes. -<span class="lineNum"> 73 </span> : * @param size The size of an element. -<span class="lineNum"> 74 </span> : * @return The number (not byte size) of elements per node. -<span class="lineNum"> 75 </span> : * -<span class="lineNum"> 76 </span> : * This function started off as a compiler kludge from SGI, but seems to -<span class="lineNum"> 77 </span> : * be a useful wrapper around a repeated constant expression. The '512' is -<span class="lineNum"> 78 </span> : * tunable (and no other code needs to change), but no investigation has -<span class="lineNum"> 79 </span> : * been done since inheriting the SGI code. -<span class="lineNum"> 80 </span> : */ -<span class="lineNum"> 81 </span> : inline size_t -<span class="lineNum"> 82 </span><span class="lineCov"> 7753 : __deque_buf_size(size_t __size)</span> -<span class="lineNum"> 83 </span><span class="lineCov"> 7753 : { return __size < 512 ? size_t(512 / __size) : size_t(1); }</span> -<span class="lineNum"> 84 </span> : -<span class="lineNum"> 85 </span> : -<span class="lineNum"> 86 </span> : /** -<span class="lineNum"> 87 </span> : * @brief A deque::iterator. -<span class="lineNum"> 88 </span> : * -<span class="lineNum"> 89 </span> : * Quite a bit of intelligence here. Much of the functionality of -<span class="lineNum"> 90 </span> : * deque is actually passed off to this class. A deque holds two -<span class="lineNum"> 91 </span> : * of these internally, marking its valid range. Access to -<span class="lineNum"> 92 </span> : * elements is done as offsets of either of those two, relying on -<span class="lineNum"> 93 </span> : * operator overloading in this class. -<span class="lineNum"> 94 </span> : * -<span class="lineNum"> 95 </span> : * All the functions are op overloads except for _M_set_node. -<span class="lineNum"> 96 </span> : */ -<span class="lineNum"> 97 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 98 </span> : struct _Deque_iterator -<span class="lineNum"> 99 </span> : { -<span class="lineNum"> 100 </span> : typedef _Deque_iterator<_Tp, _Tp&, _Tp*> iterator; -<span class="lineNum"> 101 </span> : typedef _Deque_iterator<_Tp, const _Tp&, const _Tp*> const_iterator; -<span class="lineNum"> 102 </span> : -<span class="lineNum"> 103 </span><span class="lineCov"> 7595 : static size_t _S_buffer_size()</span> -<span class="lineNum"> 104 </span><span class="lineCov"> 7595 : { return __deque_buf_size(sizeof(_Tp)); }</span> -<span class="lineNum"> 105 </span> : -<span class="lineNum"> 106 </span> : typedef std::random_access_iterator_tag iterator_category; -<span class="lineNum"> 107 </span> : typedef _Tp value_type; -<span class="lineNum"> 108 </span> : typedef _Ptr pointer; -<span class="lineNum"> 109 </span> : typedef _Ref reference; -<span class="lineNum"> 110 </span> : typedef size_t size_type; -<span class="lineNum"> 111 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 112 </span> : typedef _Tp** _Map_pointer; -<span class="lineNum"> 113 </span> : typedef _Deque_iterator _Self; -<span class="lineNum"> 114 </span> : -<span class="lineNum"> 115 </span> : _Tp* _M_cur; -<span class="lineNum"> 116 </span> : _Tp* _M_first; -<span class="lineNum"> 117 </span> : _Tp* _M_last; -<span class="lineNum"> 118 </span> : _Map_pointer _M_node; -<span class="lineNum"> 119 </span> : -<span class="lineNum"> 120 </span> : _Deque_iterator(_Tp* __x, _Map_pointer __y) -<span class="lineNum"> 121 </span> : : _M_cur(__x), _M_first(*__y), -<span class="lineNum"> 122 </span> : _M_last(*__y + _S_buffer_size()), _M_node(__y) { } -<span class="lineNum"> 123 </span> : -<span class="lineNum"> 124 </span><span class="lineCov"> 68 : _Deque_iterator()</span> -<span class="lineNum"> 125 </span><span class="lineCov"> 68 : : _M_cur(0), _M_first(0), _M_last(0), _M_node(0) { }</span> -<span class="lineNum"> 126 </span> : -<span class="lineNum"> 127 </span><span class="lineCov"> 45179 : _Deque_iterator(const iterator& __x)</span> -<span class="lineNum"> 128 </span> : : _M_cur(__x._M_cur), _M_first(__x._M_first), -<span class="lineNum"> 129 </span><span class="lineCov"> 45179 : _M_last(__x._M_last), _M_node(__x._M_node) { }</span> -<span class="lineNum"> 130 </span> : -<span class="lineNum"> 131 </span> : reference -<span class="lineNum"> 132 </span><span class="lineCov"> 24883 : operator*() const</span> -<span class="lineNum"> 133 </span><span class="lineCov"> 24883 : { return *_M_cur; }</span> -<span class="lineNum"> 134 </span> : -<span class="lineNum"> 135 </span> : pointer -<span class="lineNum"> 136 </span> : operator->() const -<span class="lineNum"> 137 </span> : { return _M_cur; } -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : _Self& -<span class="lineNum"> 140 </span><span class="lineCov"> 24754 : operator++()</span> -<span class="lineNum"> 141 </span> : { -<span class="lineNum"> 142 </span><span class="lineCov"> 24754 : ++_M_cur;</span> -<span class="lineNum"> 143 </span><span class="lineCov"> 24754 : if (_M_cur == _M_last)</span> -<span class="lineNum"> 144 </span> : { -<span class="lineNum"> 145 </span><span class="lineCov"> 29 : _M_set_node(_M_node + 1);</span> -<span class="lineNum"> 146 </span><span class="lineCov"> 29 : _M_cur = _M_first;</span> -<span class="lineNum"> 147 </span> : } -<span class="lineNum"> 148 </span><span class="lineCov"> 24754 : return *this;</span> -<span class="lineNum"> 149 </span> : } -<span class="lineNum"> 150 </span> : -<span class="lineNum"> 151 </span> : _Self -<span class="lineNum"> 152 </span> : operator++(int) -<span class="lineNum"> 153 </span> : { -<span class="lineNum"> 154 </span> : _Self __tmp = *this; -<span class="lineNum"> 155 </span> : ++*this; -<span class="lineNum"> 156 </span> : return __tmp; -<span class="lineNum"> 157 </span> : } -<span class="lineNum"> 158 </span> : -<span class="lineNum"> 159 </span> : _Self& -<span class="lineNum"> 160 </span><span class="lineCov"> 39 : operator--()</span> -<span class="lineNum"> 161 </span> : { -<span class="lineNum"> 162 </span><span class="lineCov"> 39 : if (_M_cur == _M_first)</span> -<span class="lineNum"> 163 </span> : { -<span class="lineNum"> 164 </span><span class="lineNoCov"> 0 : _M_set_node(_M_node - 1);</span> -<span class="lineNum"> 165 </span><span class="lineNoCov"> 0 : _M_cur = _M_last;</span> -<span class="lineNum"> 166 </span> : } -<span class="lineNum"> 167 </span><span class="lineCov"> 39 : --_M_cur;</span> -<span class="lineNum"> 168 </span><span class="lineCov"> 39 : return *this;</span> -<span class="lineNum"> 169 </span> : } -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : _Self -<span class="lineNum"> 172 </span> : operator--(int) -<span class="lineNum"> 173 </span> : { -<span class="lineNum"> 174 </span> : _Self __tmp = *this; -<span class="lineNum"> 175 </span> : --*this; -<span class="lineNum"> 176 </span> : return __tmp; -<span class="lineNum"> 177 </span> : } -<span class="lineNum"> 178 </span> : -<span class="lineNum"> 179 </span> : _Self& -<span class="lineNum"> 180 </span><span class="lineCov"> 180 : operator+=(difference_type __n)</span> -<span class="lineNum"> 181 </span> : { -<span class="lineNum"> 182 </span><span class="lineCov"> 180 : const difference_type __offset = __n + (_M_cur - _M_first);</span> -<span class="lineNum"> 183 </span><span class="lineCov"> 180 : if (__offset >= 0 && __offset < difference_type(_S_buffer_size()))</span> -<span class="lineNum"> 184 </span><span class="lineCov"> 178 : _M_cur += __n;</span> -<span class="lineNum"> 185 </span> : else -<span class="lineNum"> 186 </span> : { -<span class="lineNum"> 187 </span> : const difference_type __node_offset = -<span class="lineNum"> 188 </span> : __offset > 0 ? __offset / difference_type(_S_buffer_size()) -<span class="lineNum"> 189 </span> : : -difference_type((-__offset - 1) -<span class="lineNum"> 190 </span><span class="lineCov"> 2 : / _S_buffer_size()) - 1;</span> -<span class="lineNum"> 191 </span><span class="lineCov"> 2 : _M_set_node(_M_node + __node_offset);</span> -<span class="lineNum"> 192 </span><span class="lineCov"> 2 : _M_cur = _M_first + (__offset - __node_offset</span> -<span class="lineNum"> 193 </span> : * difference_type(_S_buffer_size())); -<span class="lineNum"> 194 </span> : } -<span class="lineNum"> 195 </span><span class="lineCov"> 180 : return *this;</span> -<span class="lineNum"> 196 </span> : } -<span class="lineNum"> 197 </span> : -<span class="lineNum"> 198 </span> : _Self -<span class="lineNum"> 199 </span><span class="lineCov"> 180 : operator+(difference_type __n) const</span> -<span class="lineNum"> 200 </span> : { -<span class="lineNum"> 201 </span><span class="lineCov"> 180 : _Self __tmp = *this;</span> -<span class="lineNum"> 202 </span><span class="lineCov"> 180 : return __tmp += __n;</span> -<span class="lineNum"> 203 </span> : } -<span class="lineNum"> 204 </span> : -<span class="lineNum"> 205 </span> : _Self& -<span class="lineNum"> 206 </span><span class="lineNoCov"> 0 : operator-=(difference_type __n)</span> -<span class="lineNum"> 207 </span><span class="lineNoCov"> 0 : { return *this += -__n; }</span> -<span class="lineNum"> 208 </span> : -<span class="lineNum"> 209 </span> : _Self -<span class="lineNum"> 210 </span><span class="lineNoCov"> 0 : operator-(difference_type __n) const</span> -<span class="lineNum"> 211 </span> : { -<span class="lineNum"> 212 </span><span class="lineNoCov"> 0 : _Self __tmp = *this;</span> -<span class="lineNum"> 213 </span><span class="lineNoCov"> 0 : return __tmp -= __n;</span> -<span class="lineNum"> 214 </span> : } -<span class="lineNum"> 215 </span> : -<span class="lineNum"> 216 </span> : reference -<span class="lineNum"> 217 </span> : operator[](difference_type __n) const -<span class="lineNum"> 218 </span> : { return *(*this + __n); } -<span class="lineNum"> 219 </span> : -<span class="lineNum"> 220 </span> : /** -<span class="lineNum"> 221 </span> : * Prepares to traverse new_node. Sets everything except -<span class="lineNum"> 222 </span> : * _M_cur, which should therefore be set by the caller -<span class="lineNum"> 223 </span> : * immediately afterwards, based on _M_first and _M_last. -<span class="lineNum"> 224 </span> : */ -<span class="lineNum"> 225 </span> : void -<span class="lineNum"> 226 </span><span class="lineCov"> 112 : _M_set_node(_Map_pointer __new_node)</span> -<span class="lineNum"> 227 </span> : { -<span class="lineNum"> 228 </span><span class="lineCov"> 112 : _M_node = __new_node;</span> -<span class="lineNum"> 229 </span><span class="lineCov"> 112 : _M_first = *__new_node;</span> -<span class="lineNum"> 230 </span><span class="lineCov"> 112 : _M_last = _M_first + difference_type(_S_buffer_size());</span> -<span class="lineNum"> 231 </span><span class="lineCov"> 112 : }</span> -<span class="lineNum"> 232 </span> : }; -<span class="lineNum"> 233 </span> : -<span class="lineNum"> 234 </span> : // Note: we also provide overloads whose operands are of the same type in -<span class="lineNum"> 235 </span> : // order to avoid ambiguous overload resolution when std::rel_ops operators -<span class="lineNum"> 236 </span> : // are in scope (for additional details, see libstdc++/3628) -<span class="lineNum"> 237 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 238 </span> : inline bool -<span class="lineNum"> 239 </span> : operator==(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 240 </span><span class="lineCov"> 19443 : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y)</span> -<span class="lineNum"> 241 </span><span class="lineCov"> 19443 : { return __x._M_cur == __y._M_cur; }</span> -<span class="lineNum"> 242 </span> : -<span class="lineNum"> 243 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 244 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 245 </span> : inline bool -<span class="lineNum"> 246 </span> : operator==(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 247 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 248 </span> : { return __x._M_cur == __y._M_cur; } -<span class="lineNum"> 249 </span> : -<span class="lineNum"> 250 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 251 </span> : inline bool -<span class="lineNum"> 252 </span> : operator!=(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 253 </span><span class="lineCov"> 12091 : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y)</span> -<span class="lineNum"> 254 </span><span class="lineCov"> 12091 : { return !(__x == __y); }</span> -<span class="lineNum"> 255 </span> : -<span class="lineNum"> 256 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 257 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 258 </span> : inline bool -<span class="lineNum"> 259 </span> : operator!=(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 260 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 261 </span> : { return !(__x == __y); } -<span class="lineNum"> 262 </span> : -<span class="lineNum"> 263 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 264 </span> : inline bool -<span class="lineNum"> 265 </span> : operator<(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 266 </span> : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y) -<span class="lineNum"> 267 </span> : { return (__x._M_node == __y._M_node) ? (__x._M_cur < __y._M_cur) -<span class="lineNum"> 268 </span> : : (__x._M_node < __y._M_node); } -<span class="lineNum"> 269 </span> : -<span class="lineNum"> 270 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 271 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 272 </span> : inline bool -<span class="lineNum"> 273 </span> : operator<(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 274 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 275 </span> : { return (__x._M_node == __y._M_node) ? (__x._M_cur < __y._M_cur) -<span class="lineNum"> 276 </span> : : (__x._M_node < __y._M_node); } -<span class="lineNum"> 277 </span> : -<span class="lineNum"> 278 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 279 </span> : inline bool -<span class="lineNum"> 280 </span> : operator>(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 281 </span> : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y) -<span class="lineNum"> 282 </span> : { return __y < __x; } -<span class="lineNum"> 283 </span> : -<span class="lineNum"> 284 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 285 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 286 </span> : inline bool -<span class="lineNum"> 287 </span> : operator>(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 288 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 289 </span> : { return __y < __x; } -<span class="lineNum"> 290 </span> : -<span class="lineNum"> 291 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 292 </span> : inline bool -<span class="lineNum"> 293 </span> : operator<=(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 294 </span> : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y) -<span class="lineNum"> 295 </span> : { return !(__y < __x); } -<span class="lineNum"> 296 </span> : -<span class="lineNum"> 297 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 298 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 299 </span> : inline bool -<span class="lineNum"> 300 </span> : operator<=(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 301 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 302 </span> : { return !(__y < __x); } -<span class="lineNum"> 303 </span> : -<span class="lineNum"> 304 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 305 </span> : inline bool -<span class="lineNum"> 306 </span> : operator>=(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 307 </span> : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y) -<span class="lineNum"> 308 </span> : { return !(__x < __y); } -<span class="lineNum"> 309 </span> : -<span class="lineNum"> 310 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 311 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 312 </span> : inline bool -<span class="lineNum"> 313 </span> : operator>=(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 314 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 315 </span> : { return !(__x < __y); } -<span class="lineNum"> 316 </span> : -<span class="lineNum"> 317 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 318 </span> : // According to the resolution of DR179 not only the various comparison -<span class="lineNum"> 319 </span> : // operators but also operator- must accept mixed iterator/const_iterator -<span class="lineNum"> 320 </span> : // parameters. -<span class="lineNum"> 321 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 322 </span> : inline typename _Deque_iterator<_Tp, _Ref, _Ptr>::difference_type -<span class="lineNum"> 323 </span> : operator-(const _Deque_iterator<_Tp, _Ref, _Ptr>& __x, -<span class="lineNum"> 324 </span><span class="lineCov"> 7299 : const _Deque_iterator<_Tp, _Ref, _Ptr>& __y)</span> -<span class="lineNum"> 325 </span> : { -<span class="lineNum"> 326 </span> : return typename _Deque_iterator<_Tp, _Ref, _Ptr>::difference_type -<span class="lineNum"> 327 </span> : (_Deque_iterator<_Tp, _Ref, _Ptr>::_S_buffer_size()) -<span class="lineNum"> 328 </span> : * (__x._M_node - __y._M_node - 1) + (__x._M_cur - __x._M_first) -<span class="lineNum"> 329 </span><span class="lineCov"> 7299 : + (__y._M_last - __y._M_cur);</span> -<span class="lineNum"> 330 </span> : } -<span class="lineNum"> 331 </span> : -<span class="lineNum"> 332 </span> : template<typename _Tp, typename _RefL, typename _PtrL, -<span class="lineNum"> 333 </span> : typename _RefR, typename _PtrR> -<span class="lineNum"> 334 </span> : inline typename _Deque_iterator<_Tp, _RefL, _PtrL>::difference_type -<span class="lineNum"> 335 </span> : operator-(const _Deque_iterator<_Tp, _RefL, _PtrL>& __x, -<span class="lineNum"> 336 </span> : const _Deque_iterator<_Tp, _RefR, _PtrR>& __y) -<span class="lineNum"> 337 </span> : { -<span class="lineNum"> 338 </span> : return typename _Deque_iterator<_Tp, _RefL, _PtrL>::difference_type -<span class="lineNum"> 339 </span> : (_Deque_iterator<_Tp, _RefL, _PtrL>::_S_buffer_size()) -<span class="lineNum"> 340 </span> : * (__x._M_node - __y._M_node - 1) + (__x._M_cur - __x._M_first) -<span class="lineNum"> 341 </span> : + (__y._M_last - __y._M_cur); -<span class="lineNum"> 342 </span> : } -<span class="lineNum"> 343 </span> : -<span class="lineNum"> 344 </span> : template<typename _Tp, typename _Ref, typename _Ptr> -<span class="lineNum"> 345 </span> : inline _Deque_iterator<_Tp, _Ref, _Ptr> -<span class="lineNum"> 346 </span> : operator+(ptrdiff_t __n, const _Deque_iterator<_Tp, _Ref, _Ptr>& __x) -<span class="lineNum"> 347 </span> : { return __x + __n; } -<span class="lineNum"> 348 </span> : -<span class="lineNum"> 349 </span> : template<typename _Tp> -<span class="lineNum"> 350 </span> : void -<span class="lineNum"> 351 </span> : fill(const _Deque_iterator<_Tp, _Tp&, _Tp*>& __first, -<span class="lineNum"> 352 </span> : const _Deque_iterator<_Tp, _Tp&, _Tp*>& __last, const _Tp& __value); -<span class="lineNum"> 353 </span> : -<span class="lineNum"> 354 </span> : /** -<span class="lineNum"> 355 </span> : * Deque base class. This class provides the unified face for %deque's -<span class="lineNum"> 356 </span> : * allocation. This class's constructor and destructor allocate and -<span class="lineNum"> 357 </span> : * deallocate (but do not initialize) storage. This makes %exception -<span class="lineNum"> 358 </span> : * safety easier. -<span class="lineNum"> 359 </span> : * -<span class="lineNum"> 360 </span> : * Nothing in this class ever constructs or destroys an actual Tp element. -<span class="lineNum"> 361 </span> : * (Deque handles that itself.) Only/All memory management is performed -<span class="lineNum"> 362 </span> : * here. -<span class="lineNum"> 363 </span> : */ -<span class="lineNum"> 364 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 365 </span> : class _Deque_base -<span class="lineNum"> 366 </span> : { -<span class="lineNum"> 367 </span> : public: -<span class="lineNum"> 368 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 369 </span> : -<span class="lineNum"> 370 </span> : allocator_type -<span class="lineNum"> 371 </span> : get_allocator() const -<span class="lineNum"> 372 </span> : { return allocator_type(_M_get_Tp_allocator()); } -<span class="lineNum"> 373 </span> : -<span class="lineNum"> 374 </span> : typedef _Deque_iterator<_Tp, _Tp&, _Tp*> iterator; -<span class="lineNum"> 375 </span> : typedef _Deque_iterator<_Tp, const _Tp&, const _Tp*> const_iterator; -<span class="lineNum"> 376 </span> : -<span class="lineNum"> 377 </span><span class="lineCov"> 21 : _Deque_base()</span> -<span class="lineNum"> 378 </span><span class="lineCov"> 21 : : _M_impl()</span> -<span class="lineNum"> 379 </span><span class="lineCov"> 21 : { _M_initialize_map(0); }</span> -<span class="lineNum"> 380 </span> : -<span class="lineNum"> 381 </span><span class="lineCov"> 13 : _Deque_base(const allocator_type& __a, size_t __num_elements)</span> -<span class="lineNum"> 382 </span><span class="lineCov"> 13 : : _M_impl(__a)</span> -<span class="lineNum"> 383 </span><span class="lineCov"> 13 : { _M_initialize_map(__num_elements); }</span> -<span class="lineNum"> 384 </span> : -<span class="lineNum"> 385 </span> : _Deque_base(const allocator_type& __a) -<span class="lineNum"> 386 </span> : : _M_impl(__a) -<span class="lineNum"> 387 </span> : { } -<span class="lineNum"> 388 </span> : -<span class="lineNum"> 389 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 390 </span> : _Deque_base(_Deque_base&& __x) -<span class="lineNum"> 391 </span> : : _M_impl(__x._M_get_Tp_allocator()) -<span class="lineNum"> 392 </span> : { -<span class="lineNum"> 393 </span> : _M_initialize_map(0); -<span class="lineNum"> 394 </span> : if (__x._M_impl._M_map) -<span class="lineNum"> 395 </span> : { -<span class="lineNum"> 396 </span> : std::swap(this->_M_impl._M_start, __x._M_impl._M_start); -<span class="lineNum"> 397 </span> : std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); -<span class="lineNum"> 398 </span> : std::swap(this->_M_impl._M_map, __x._M_impl._M_map); -<span class="lineNum"> 399 </span> : std::swap(this->_M_impl._M_map_size, __x._M_impl._M_map_size); -<span class="lineNum"> 400 </span> : } -<span class="lineNum"> 401 </span> : } -<span class="lineNum"> 402 </span> : #endif -<span class="lineNum"> 403 </span> : -<span class="lineNum"> 404 </span> : ~_Deque_base(); -<span class="lineNum"> 405 </span> : -<span class="lineNum"> 406 </span> : protected: -<span class="lineNum"> 407 </span> : //This struct encapsulates the implementation of the std::deque -<span class="lineNum"> 408 </span> : //standard container and at the same time makes use of the EBO -<span class="lineNum"> 409 </span> : //for empty allocators. -<span class="lineNum"> 410 </span> : typedef typename _Alloc::template rebind<_Tp*>::other _Map_alloc_type; -<span class="lineNum"> 411 </span> : -<span class="lineNum"> 412 </span> : typedef typename _Alloc::template rebind<_Tp>::other _Tp_alloc_type; -<span class="lineNum"> 413 </span> : -<span class="lineNum"> 414 </span> : struct _Deque_impl -<span class="lineNum"> 415 </span> : : public _Tp_alloc_type -<span class="lineNum"> 416 </span><span class="lineCov"> 30 : {</span> -<span class="lineNum"> 417 </span> : _Tp** _M_map; -<span class="lineNum"> 418 </span> : size_t _M_map_size; -<span class="lineNum"> 419 </span> : iterator _M_start; -<span class="lineNum"> 420 </span> : iterator _M_finish; -<span class="lineNum"> 421 </span> : -<span class="lineNum"> 422 </span><span class="lineCov"> 21 : _Deque_impl()</span> -<span class="lineNum"> 423 </span> : : _Tp_alloc_type(), _M_map(0), _M_map_size(0), -<span class="lineNum"> 424 </span><span class="lineCov"> 21 : _M_start(), _M_finish()</span> -<span class="lineNum"> 425 </span><span class="lineCov"> 21 : { }</span> -<span class="lineNum"> 426 </span> : -<span class="lineNum"> 427 </span><span class="lineCov"> 13 : _Deque_impl(const _Tp_alloc_type& __a)</span> -<span class="lineNum"> 428 </span> : : _Tp_alloc_type(__a), _M_map(0), _M_map_size(0), -<span class="lineNum"> 429 </span><span class="lineCov"> 13 : _M_start(), _M_finish()</span> -<span class="lineNum"> 430 </span><span class="lineCov"> 13 : { }</span> -<span class="lineNum"> 431 </span> : }; -<span class="lineNum"> 432 </span> : -<span class="lineNum"> 433 </span> : _Tp_alloc_type& -<span class="lineNum"> 434 </span><span class="lineCov"> 1085 : _M_get_Tp_allocator()</span> -<span class="lineNum"> 435 </span><span class="lineCov"> 1085 : { return *static_cast<_Tp_alloc_type*>(&this->_M_impl); }</span> -<span class="lineNum"> 436 </span> : -<span class="lineNum"> 437 </span> : const _Tp_alloc_type& -<span class="lineNum"> 438 </span><span class="lineCov"> 77 : _M_get_Tp_allocator() const</span> -<span class="lineNum"> 439 </span><span class="lineCov"> 77 : { return *static_cast<const _Tp_alloc_type*>(&this->_M_impl); }</span> -<span class="lineNum"> 440 </span> : -<span class="lineNum"> 441 </span> : _Map_alloc_type -<span class="lineNum"> 442 </span><span class="lineCov"> 64 : _M_get_map_allocator() const</span> -<span class="lineNum"> 443 </span><span class="lineCov"> 64 : { return _Map_alloc_type(_M_get_Tp_allocator()); }</span> -<span class="lineNum"> 444 </span> : -<span class="lineNum"> 445 </span> : _Tp* -<span class="lineNum"> 446 </span><span class="lineCov"> 47 : _M_allocate_node()</span> -<span class="lineNum"> 447 </span> : { -<span class="lineNum"> 448 </span><span class="lineCov"> 47 : return _M_impl._Tp_alloc_type::allocate(__deque_buf_size(sizeof(_Tp)));</span> -<span class="lineNum"> 449 </span> : } -<span class="lineNum"> 450 </span> : -<span class="lineNum"> 451 </span> : void -<span class="lineNum"> 452 </span><span class="lineCov"> 43 : _M_deallocate_node(_Tp* __p)</span> -<span class="lineNum"> 453 </span> : { -<span class="lineNum"> 454 </span><span class="lineCov"> 43 : _M_impl._Tp_alloc_type::deallocate(__p, __deque_buf_size(sizeof(_Tp)));</span> -<span class="lineNum"> 455 </span><span class="lineCov"> 43 : }</span> -<span class="lineNum"> 456 </span> : -<span class="lineNum"> 457 </span> : _Tp** -<span class="lineNum"> 458 </span><span class="lineCov"> 34 : _M_allocate_map(size_t __n)</span> -<span class="lineNum"> 459 </span><span class="lineCov"> 34 : { return _M_get_map_allocator().allocate(__n); }</span> -<span class="lineNum"> 460 </span> : -<span class="lineNum"> 461 </span> : void -<span class="lineNum"> 462 </span><span class="lineCov"> 30 : _M_deallocate_map(_Tp** __p, size_t __n)</span> -<span class="lineNum"> 463 </span><span class="lineCov"> 30 : { _M_get_map_allocator().deallocate(__p, __n); }</span> -<span class="lineNum"> 464 </span> : -<span class="lineNum"> 465 </span> : protected: -<span class="lineNum"> 466 </span> : void _M_initialize_map(size_t); -<span class="lineNum"> 467 </span> : void _M_create_nodes(_Tp** __nstart, _Tp** __nfinish); -<span class="lineNum"> 468 </span> : void _M_destroy_nodes(_Tp** __nstart, _Tp** __nfinish); -<span class="lineNum"> 469 </span> : enum { _S_initial_map_size = 8 }; -<span class="lineNum"> 470 </span> : -<span class="lineNum"> 471 </span> : _Deque_impl _M_impl; -<span class="lineNum"> 472 </span> : }; -<span class="lineNum"> 473 </span> : -<span class="lineNum"> 474 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 475 </span> : _Deque_base<_Tp, _Alloc>:: -<span class="lineNum"> 476 </span><span class="lineCov"> 30 : ~_Deque_base()</span> -<span class="lineNum"> 477 </span> : { -<span class="lineNum"> 478 </span><span class="lineCov"> 30 : if (this->_M_impl._M_map)</span> -<span class="lineNum"> 479 </span> : { -<span class="lineNum"> 480 </span><span class="lineCov"> 30 : _M_destroy_nodes(this->_M_impl._M_start._M_node,</span> -<span class="lineNum"> 481 </span> : this->_M_impl._M_finish._M_node + 1); -<span class="lineNum"> 482 </span><span class="lineCov"> 30 : _M_deallocate_map(this->_M_impl._M_map, this->_M_impl._M_map_size);</span> -<span class="lineNum"> 483 </span> : } -<span class="lineNum"> 484 </span><span class="lineCov"> 30 : }</span> -<span class="lineNum"> 485 </span> : -<span class="lineNum"> 486 </span> : /** -<span class="lineNum"> 487 </span> : * @brief Layout storage. -<span class="lineNum"> 488 </span> : * @param num_elements The count of T's for which to allocate space -<span class="lineNum"> 489 </span> : * at first. -<span class="lineNum"> 490 </span> : * @return Nothing. -<span class="lineNum"> 491 </span> : * -<span class="lineNum"> 492 </span> : * The initial underlying memory layout is a bit complicated... -<span class="lineNum"> 493 </span> : */ -<span class="lineNum"> 494 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 495 </span> : void -<span class="lineNum"> 496 </span> : _Deque_base<_Tp, _Alloc>:: -<span class="lineNum"> 497 </span><span class="lineCov"> 34 : _M_initialize_map(size_t __num_elements)</span> -<span class="lineNum"> 498 </span> : { -<span class="lineNum"> 499 </span> : const size_t __num_nodes = (__num_elements/ __deque_buf_size(sizeof(_Tp)) -<span class="lineNum"> 500 </span><span class="lineCov"> 34 : + 1);</span> -<span class="lineNum"> 501 </span> : -<span class="lineNum"> 502 </span><span class="lineCov"> 34 : this->_M_impl._M_map_size = std::max((size_t) _S_initial_map_size,</span> -<span class="lineNum"> 503 </span> : size_t(__num_nodes + 2)); -<span class="lineNum"> 504 </span><span class="lineCov"> 34 : this->_M_impl._M_map = _M_allocate_map(this->_M_impl._M_map_size);</span> -<span class="lineNum"> 505 </span> : -<span class="lineNum"> 506 </span> : // For "small" maps (needing less than _M_map_size nodes), allocation -<span class="lineNum"> 507 </span> : // starts in the middle elements and grows outwards. So nstart may be -<span class="lineNum"> 508 </span> : // the beginning of _M_map, but for small maps it may be as far in as -<span class="lineNum"> 509 </span> : // _M_map+3. -<span class="lineNum"> 510 </span> : -<span class="lineNum"> 511 </span> : _Tp** __nstart = (this->_M_impl._M_map -<span class="lineNum"> 512 </span><span class="lineCov"> 34 : + (this->_M_impl._M_map_size - __num_nodes) / 2);</span> -<span class="lineNum"> 513 </span><span class="lineCov"> 34 : _Tp** __nfinish = __nstart + __num_nodes;</span> -<span class="lineNum"> 514 </span> : -<span class="lineNum"> 515 </span> : try -<span class="lineNum"> 516 </span><span class="lineCov"> 34 : { _M_create_nodes(__nstart, __nfinish); }</span> -<span class="lineNum"> 517 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 518 </span> : { -<span class="lineNum"> 519 </span><span class="lineNoCov"> 0 : _M_deallocate_map(this->_M_impl._M_map, this->_M_impl._M_map_size);</span> -<span class="lineNum"> 520 </span><span class="lineNoCov"> 0 : this->_M_impl._M_map = 0;</span> -<span class="lineNum"> 521 </span><span class="lineNoCov"> 0 : this->_M_impl._M_map_size = 0;</span> -<span class="lineNum"> 522 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 523 </span> : } -<span class="lineNum"> 524 </span> : -<span class="lineNum"> 525 </span><span class="lineCov"> 34 : this->_M_impl._M_start._M_set_node(__nstart);</span> -<span class="lineNum"> 526 </span><span class="lineCov"> 34 : this->_M_impl._M_finish._M_set_node(__nfinish - 1);</span> -<span class="lineNum"> 527 </span><span class="lineCov"> 34 : this->_M_impl._M_start._M_cur = _M_impl._M_start._M_first;</span> -<span class="lineNum"> 528 </span><span class="lineCov"> 34 : this->_M_impl._M_finish._M_cur = (this->_M_impl._M_finish._M_first</span> -<span class="lineNum"> 529 </span> : + __num_elements -<span class="lineNum"> 530 </span> : % __deque_buf_size(sizeof(_Tp))); -<span class="lineNum"> 531 </span><span class="lineCov"> 34 : }</span> -<span class="lineNum"> 532 </span> : -<span class="lineNum"> 533 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 534 </span> : void -<span class="lineNum"> 535 </span> : _Deque_base<_Tp, _Alloc>:: -<span class="lineNum"> 536 </span><span class="lineCov"> 34 : _M_create_nodes(_Tp** __nstart, _Tp** __nfinish)</span> -<span class="lineNum"> 537 </span> : { -<span class="lineNum"> 538 </span> : _Tp** __cur; -<span class="lineNum"> 539 </span> : try -<span class="lineNum"> 540 </span> : { -<span class="lineNum"> 541 </span><span class="lineCov"> 68 : for (__cur = __nstart; __cur < __nfinish; ++__cur)</span> -<span class="lineNum"> 542 </span><span class="lineCov"> 34 : *__cur = this->_M_allocate_node();</span> -<span class="lineNum"> 543 </span> : } -<span class="lineNum"> 544 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 545 </span> : { -<span class="lineNum"> 546 </span><span class="lineNoCov"> 0 : _M_destroy_nodes(__nstart, __cur);</span> -<span class="lineNum"> 547 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 548 </span> : } -<span class="lineNum"> 549 </span><span class="lineCov"> 34 : }</span> -<span class="lineNum"> 550 </span> : -<span class="lineNum"> 551 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 552 </span> : void -<span class="lineNum"> 553 </span> : _Deque_base<_Tp, _Alloc>:: -<span class="lineNum"> 554 </span><span class="lineCov"> 1046 : _M_destroy_nodes(_Tp** __nstart, _Tp** __nfinish)</span> -<span class="lineNum"> 555 </span> : { -<span class="lineNum"> 556 </span><span class="lineCov"> 1089 : for (_Tp** __n = __nstart; __n < __nfinish; ++__n)</span> -<span class="lineNum"> 557 </span><span class="lineCov"> 43 : _M_deallocate_node(*__n);</span> -<span class="lineNum"> 558 </span><span class="lineCov"> 1046 : }</span> -<span class="lineNum"> 559 </span> : -<span class="lineNum"> 560 </span> : /** -<span class="lineNum"> 561 </span> : * @brief A standard container using fixed-size memory allocation and -<span class="lineNum"> 562 </span> : * constant-time manipulation of elements at either end. -<span class="lineNum"> 563 </span> : * -<span class="lineNum"> 564 </span> : * @ingroup Containers -<span class="lineNum"> 565 </span> : * @ingroup Sequences -<span class="lineNum"> 566 </span> : * -<span class="lineNum"> 567 </span> : * Meets the requirements of a <a href="tables.html#65">container</a>, a -<span class="lineNum"> 568 </span> : * <a href="tables.html#66">reversible container</a>, and a -<span class="lineNum"> 569 </span> : * <a href="tables.html#67">sequence</a>, including the -<span class="lineNum"> 570 </span> : * <a href="tables.html#68">optional sequence requirements</a>. -<span class="lineNum"> 571 </span> : * -<span class="lineNum"> 572 </span> : * In previous HP/SGI versions of deque, there was an extra template -<span class="lineNum"> 573 </span> : * parameter so users could control the node size. This extension turned -<span class="lineNum"> 574 </span> : * out to violate the C++ standard (it can be detected using template -<span class="lineNum"> 575 </span> : * template parameters), and it was removed. -<span class="lineNum"> 576 </span> : * -<span class="lineNum"> 577 </span> : * Here's how a deque<Tp> manages memory. Each deque has 4 members: -<span class="lineNum"> 578 </span> : * -<span class="lineNum"> 579 </span> : * - Tp** _M_map -<span class="lineNum"> 580 </span> : * - size_t _M_map_size -<span class="lineNum"> 581 </span> : * - iterator _M_start, _M_finish -<span class="lineNum"> 582 </span> : * -<span class="lineNum"> 583 </span> : * map_size is at least 8. %map is an array of map_size -<span class="lineNum"> 584 </span> : * pointers-to-"nodes". (The name %map has nothing to do with the -<span class="lineNum"> 585 </span> : * std::map class, and "nodes" should not be confused with -<span class="lineNum"> 586 </span> : * std::list's usage of "node".) -<span class="lineNum"> 587 </span> : * -<span class="lineNum"> 588 </span> : * A "node" has no specific type name as such, but it is referred -<span class="lineNum"> 589 </span> : * to as "node" in this file. It is a simple array-of-Tp. If Tp -<span class="lineNum"> 590 </span> : * is very large, there will be one Tp element per node (i.e., an -<span class="lineNum"> 591 </span> : * "array" of one). For non-huge Tp's, node size is inversely -<span class="lineNum"> 592 </span> : * related to Tp size: the larger the Tp, the fewer Tp's will fit -<span class="lineNum"> 593 </span> : * in a node. The goal here is to keep the total size of a node -<span class="lineNum"> 594 </span> : * relatively small and constant over different Tp's, to improve -<span class="lineNum"> 595 </span> : * allocator efficiency. -<span class="lineNum"> 596 </span> : * -<span class="lineNum"> 597 </span> : * Not every pointer in the %map array will point to a node. If -<span class="lineNum"> 598 </span> : * the initial number of elements in the deque is small, the -<span class="lineNum"> 599 </span> : * /middle/ %map pointers will be valid, and the ones at the edges -<span class="lineNum"> 600 </span> : * will be unused. This same situation will arise as the %map -<span class="lineNum"> 601 </span> : * grows: available %map pointers, if any, will be on the ends. As -<span class="lineNum"> 602 </span> : * new nodes are created, only a subset of the %map's pointers need -<span class="lineNum"> 603 </span> : * to be copied "outward". -<span class="lineNum"> 604 </span> : * -<span class="lineNum"> 605 </span> : * Class invariants: -<span class="lineNum"> 606 </span> : * - For any nonsingular iterator i: -<span class="lineNum"> 607 </span> : * - i.node points to a member of the %map array. (Yes, you read that -<span class="lineNum"> 608 </span> : * correctly: i.node does not actually point to a node.) The member of -<span class="lineNum"> 609 </span> : * the %map array is what actually points to the node. -<span class="lineNum"> 610 </span> : * - i.first == *(i.node) (This points to the node (first Tp element).) -<span class="lineNum"> 611 </span> : * - i.last == i.first + node_size -<span class="lineNum"> 612 </span> : * - i.cur is a pointer in the range [i.first, i.last). NOTE: -<span class="lineNum"> 613 </span> : * the implication of this is that i.cur is always a dereferenceable -<span class="lineNum"> 614 </span> : * pointer, even if i is a past-the-end iterator. -<span class="lineNum"> 615 </span> : * - Start and Finish are always nonsingular iterators. NOTE: this -<span class="lineNum"> 616 </span> : * means that an empty deque must have one node, a deque with <N -<span class="lineNum"> 617 </span> : * elements (where N is the node buffer size) must have one node, a -<span class="lineNum"> 618 </span> : * deque with N through (2N-1) elements must have two nodes, etc. -<span class="lineNum"> 619 </span> : * - For every node other than start.node and finish.node, every -<span class="lineNum"> 620 </span> : * element in the node is an initialized object. If start.node == -<span class="lineNum"> 621 </span> : * finish.node, then [start.cur, finish.cur) are initialized -<span class="lineNum"> 622 </span> : * objects, and the elements outside that range are uninitialized -<span class="lineNum"> 623 </span> : * storage. Otherwise, [start.cur, start.last) and [finish.first, -<span class="lineNum"> 624 </span> : * finish.cur) are initialized objects, and [start.first, start.cur) -<span class="lineNum"> 625 </span> : * and [finish.cur, finish.last) are uninitialized storage. -<span class="lineNum"> 626 </span> : * - [%map, %map + map_size) is a valid, non-empty range. -<span class="lineNum"> 627 </span> : * - [start.node, finish.node] is a valid range contained within -<span class="lineNum"> 628 </span> : * [%map, %map + map_size). -<span class="lineNum"> 629 </span> : * - A pointer in the range [%map, %map + map_size) points to an allocated -<span class="lineNum"> 630 </span> : * node if and only if the pointer is in the range -<span class="lineNum"> 631 </span> : * [start.node, finish.node]. -<span class="lineNum"> 632 </span> : * -<span class="lineNum"> 633 </span> : * Here's the magic: nothing in deque is "aware" of the discontiguous -<span class="lineNum"> 634 </span> : * storage! -<span class="lineNum"> 635 </span> : * -<span class="lineNum"> 636 </span> : * The memory setup and layout occurs in the parent, _Base, and the iterator -<span class="lineNum"> 637 </span> : * class is entirely responsible for "leaping" from one node to the next. -<span class="lineNum"> 638 </span> : * All the implementation routines for deque itself work only through the -<span class="lineNum"> 639 </span> : * start and finish iterators. This keeps the routines simple and sane, -<span class="lineNum"> 640 </span> : * and we can use other standard algorithms as well. -<span class="lineNum"> 641 </span> : */ -<span class="lineNum"> 642 </span> : template<typename _Tp, typename _Alloc = std::allocator<_Tp> > -<span class="lineNum"> 643 </span> : class deque : protected _Deque_base<_Tp, _Alloc> -<span class="lineNum"> 644 </span> : { -<span class="lineNum"> 645 </span> : // concept requirements -<span class="lineNum"> 646 </span> : typedef typename _Alloc::value_type _Alloc_value_type; -<span class="lineNum"> 647 </span> : __glibcxx_class_requires(_Tp, _SGIAssignableConcept) -<span class="lineNum"> 648 </span> : __glibcxx_class_requires2(_Tp, _Alloc_value_type, _SameTypeConcept) -<span class="lineNum"> 649 </span> : -<span class="lineNum"> 650 </span> : typedef _Deque_base<_Tp, _Alloc> _Base; -<span class="lineNum"> 651 </span> : typedef typename _Base::_Tp_alloc_type _Tp_alloc_type; -<span class="lineNum"> 652 </span> : -<span class="lineNum"> 653 </span> : public: -<span class="lineNum"> 654 </span> : typedef _Tp value_type; -<span class="lineNum"> 655 </span> : typedef typename _Tp_alloc_type::pointer pointer; -<span class="lineNum"> 656 </span> : typedef typename _Tp_alloc_type::const_pointer const_pointer; -<span class="lineNum"> 657 </span> : typedef typename _Tp_alloc_type::reference reference; -<span class="lineNum"> 658 </span> : typedef typename _Tp_alloc_type::const_reference const_reference; -<span class="lineNum"> 659 </span> : typedef typename _Base::iterator iterator; -<span class="lineNum"> 660 </span> : typedef typename _Base::const_iterator const_iterator; -<span class="lineNum"> 661 </span> : typedef std::reverse_iterator<const_iterator> const_reverse_iterator; -<span class="lineNum"> 662 </span> : typedef std::reverse_iterator<iterator> reverse_iterator; -<span class="lineNum"> 663 </span> : typedef size_t size_type; -<span class="lineNum"> 664 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 665 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 666 </span> : -<span class="lineNum"> 667 </span> : protected: -<span class="lineNum"> 668 </span> : typedef pointer* _Map_pointer; -<span class="lineNum"> 669 </span> : -<span class="lineNum"> 670 </span><span class="lineNoCov"> 0 : static size_t _S_buffer_size()</span> -<span class="lineNum"> 671 </span><span class="lineNoCov"> 0 : { return __deque_buf_size(sizeof(_Tp)); }</span> -<span class="lineNum"> 672 </span> : -<span class="lineNum"> 673 </span> : // Functions controlling memory layout, and nothing else. -<span class="lineNum"> 674 </span> : using _Base::_M_initialize_map; -<span class="lineNum"> 675 </span> : using _Base::_M_create_nodes; -<span class="lineNum"> 676 </span> : using _Base::_M_destroy_nodes; -<span class="lineNum"> 677 </span> : using _Base::_M_allocate_node; -<span class="lineNum"> 678 </span> : using _Base::_M_deallocate_node; -<span class="lineNum"> 679 </span> : using _Base::_M_allocate_map; -<span class="lineNum"> 680 </span> : using _Base::_M_deallocate_map; -<span class="lineNum"> 681 </span> : using _Base::_M_get_Tp_allocator; -<span class="lineNum"> 682 </span> : -<span class="lineNum"> 683 </span> : /** -<span class="lineNum"> 684 </span> : * A total of four data members accumulated down the hierarchy. -<span class="lineNum"> 685 </span> : * May be accessed via _M_impl.* -<span class="lineNum"> 686 </span> : */ -<span class="lineNum"> 687 </span> : using _Base::_M_impl; -<span class="lineNum"> 688 </span> : -<span class="lineNum"> 689 </span> : public: -<span class="lineNum"> 690 </span> : // [23.2.1.1] construct/copy/destroy -<span class="lineNum"> 691 </span> : // (assign() and get_allocator() are also listed in this section) -<span class="lineNum"> 692 </span> : /** -<span class="lineNum"> 693 </span> : * @brief Default constructor creates no elements. -<span class="lineNum"> 694 </span> : */ -<span class="lineNum"> 695 </span><span class="lineCov"> 21 : deque()</span> -<span class="lineNum"> 696 </span><span class="lineCov"> 21 : : _Base() { }</span> -<span class="lineNum"> 697 </span> : -<span class="lineNum"> 698 </span> : /** -<span class="lineNum"> 699 </span> : * @brief Creates a %deque with no elements. -<span class="lineNum"> 700 </span> : * @param a An allocator object. -<span class="lineNum"> 701 </span> : */ -<span class="lineNum"> 702 </span> : explicit -<span class="lineNum"> 703 </span> : deque(const allocator_type& __a) -<span class="lineNum"> 704 </span> : : _Base(__a, 0) { } -<span class="lineNum"> 705 </span> : -<span class="lineNum"> 706 </span> : /** -<span class="lineNum"> 707 </span> : * @brief Creates a %deque with copies of an exemplar element. -<span class="lineNum"> 708 </span> : * @param n The number of elements to initially create. -<span class="lineNum"> 709 </span> : * @param value An element to copy. -<span class="lineNum"> 710 </span> : * @param a An allocator. -<span class="lineNum"> 711 </span> : * -<span class="lineNum"> 712 </span> : * This constructor fills the %deque with @a n copies of @a value. -<span class="lineNum"> 713 </span> : */ -<span class="lineNum"> 714 </span> : explicit -<span class="lineNum"> 715 </span> : deque(size_type __n, const value_type& __value = value_type(), -<span class="lineNum"> 716 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 717 </span> : : _Base(__a, __n) -<span class="lineNum"> 718 </span> : { _M_fill_initialize(__value); } -<span class="lineNum"> 719 </span> : -<span class="lineNum"> 720 </span> : /** -<span class="lineNum"> 721 </span> : * @brief %Deque copy constructor. -<span class="lineNum"> 722 </span> : * @param x A %deque of identical element and allocator types. -<span class="lineNum"> 723 </span> : * -<span class="lineNum"> 724 </span> : * The newly-created %deque uses a copy of the allocation object used -<span class="lineNum"> 725 </span> : * by @a x. -<span class="lineNum"> 726 </span> : */ -<span class="lineNum"> 727 </span><span class="lineCov"> 13 : deque(const deque& __x)</span> -<span class="lineNum"> 728 </span><span class="lineCov"> 13 : : _Base(__x._M_get_Tp_allocator(), __x.size())</span> -<span class="lineNum"> 729 </span><span class="lineCov"> 13 : { std::__uninitialized_copy_a(__x.begin(), __x.end(), </span> -<span class="lineNum"> 730 </span> : this->_M_impl._M_start, -<span class="lineNum"> 731 </span><span class="lineCov"> 13 : _M_get_Tp_allocator()); }</span> -<span class="lineNum"> 732 </span> : -<span class="lineNum"> 733 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 734 </span> : /** -<span class="lineNum"> 735 </span> : * @brief %Deque move constructor. -<span class="lineNum"> 736 </span> : * @param x A %deque of identical element and allocator types. -<span class="lineNum"> 737 </span> : * -<span class="lineNum"> 738 </span> : * The newly-created %deque contains the exact contents of @a x. -<span class="lineNum"> 739 </span> : * The contents of @a x are a valid, but unspecified %deque. -<span class="lineNum"> 740 </span> : */ -<span class="lineNum"> 741 </span> : deque(deque&& __x) -<span class="lineNum"> 742 </span> : : _Base(std::forward<_Base>(__x)) { } -<span class="lineNum"> 743 </span> : #endif -<span class="lineNum"> 744 </span> : -<span class="lineNum"> 745 </span> : /** -<span class="lineNum"> 746 </span> : * @brief Builds a %deque from a range. -<span class="lineNum"> 747 </span> : * @param first An input iterator. -<span class="lineNum"> 748 </span> : * @param last An input iterator. -<span class="lineNum"> 749 </span> : * @param a An allocator object. -<span class="lineNum"> 750 </span> : * -<span class="lineNum"> 751 </span> : * Create a %deque consisting of copies of the elements from [first, -<span class="lineNum"> 752 </span> : * last). -<span class="lineNum"> 753 </span> : * -<span class="lineNum"> 754 </span> : * If the iterators are forward, bidirectional, or random-access, then -<span class="lineNum"> 755 </span> : * this will call the elements' copy constructor N times (where N is -<span class="lineNum"> 756 </span> : * distance(first,last)) and do no memory reallocation. But if only -<span class="lineNum"> 757 </span> : * input iterators are used, then this will do at most 2N calls to the -<span class="lineNum"> 758 </span> : * copy constructor, and logN memory reallocations. -<span class="lineNum"> 759 </span> : */ -<span class="lineNum"> 760 </span> : template<typename _InputIterator> -<span class="lineNum"> 761 </span> : deque(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 762 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 763 </span> : : _Base(__a) -<span class="lineNum"> 764 </span> : { -<span class="lineNum"> 765 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 766 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 767 </span> : _M_initialize_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 768 </span> : } -<span class="lineNum"> 769 </span> : -<span class="lineNum"> 770 </span> : /** -<span class="lineNum"> 771 </span> : * The dtor only erases the elements, and note that if the elements -<span class="lineNum"> 772 </span> : * themselves are pointers, the pointed-to memory is not touched in any -<span class="lineNum"> 773 </span> : * way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 774 </span> : */ -<span class="lineNum"> 775 </span><span class="lineCov"> 30 : ~deque()</span> -<span class="lineNum"> 776 </span><span class="lineCov"> 30 : { _M_destroy_data(begin(), end(), _M_get_Tp_allocator()); }</span> -<span class="lineNum"> 777 </span> : -<span class="lineNum"> 778 </span> : /** -<span class="lineNum"> 779 </span> : * @brief %Deque assignment operator. -<span class="lineNum"> 780 </span> : * @param x A %deque of identical element and allocator types. -<span class="lineNum"> 781 </span> : * -<span class="lineNum"> 782 </span> : * All the elements of @a x are copied, but unlike the copy constructor, -<span class="lineNum"> 783 </span> : * the allocator object is not copied. -<span class="lineNum"> 784 </span> : */ -<span class="lineNum"> 785 </span> : deque& -<span class="lineNum"> 786 </span> : operator=(const deque& __x); -<span class="lineNum"> 787 </span> : -<span class="lineNum"> 788 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 789 </span> : /** -<span class="lineNum"> 790 </span> : * @brief %Deque move assignment operator. -<span class="lineNum"> 791 </span> : * @param x A %deque of identical element and allocator types. -<span class="lineNum"> 792 </span> : * -<span class="lineNum"> 793 </span> : * The contents of @a x are moved into this deque (without copying). -<span class="lineNum"> 794 </span> : * @a x is a valid, but unspecified %deque. -<span class="lineNum"> 795 </span> : */ -<span class="lineNum"> 796 </span> : deque& -<span class="lineNum"> 797 </span> : operator=(deque&& __x) -<span class="lineNum"> 798 </span> : { -<span class="lineNum"> 799 </span> : // NB: DR 675. -<span class="lineNum"> 800 </span> : this->clear(); -<span class="lineNum"> 801 </span> : this->swap(__x); -<span class="lineNum"> 802 </span> : return *this; -<span class="lineNum"> 803 </span> : } -<span class="lineNum"> 804 </span> : #endif -<span class="lineNum"> 805 </span> : -<span class="lineNum"> 806 </span> : /** -<span class="lineNum"> 807 </span> : * @brief Assigns a given value to a %deque. -<span class="lineNum"> 808 </span> : * @param n Number of elements to be assigned. -<span class="lineNum"> 809 </span> : * @param val Value to be assigned. -<span class="lineNum"> 810 </span> : * -<span class="lineNum"> 811 </span> : * This function fills a %deque with @a n copies of the given -<span class="lineNum"> 812 </span> : * value. Note that the assignment completely changes the -<span class="lineNum"> 813 </span> : * %deque and that the resulting %deque's size is the same as -<span class="lineNum"> 814 </span> : * the number of elements assigned. Old data may be lost. -<span class="lineNum"> 815 </span> : */ -<span class="lineNum"> 816 </span> : void -<span class="lineNum"> 817 </span> : assign(size_type __n, const value_type& __val) -<span class="lineNum"> 818 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 819 </span> : -<span class="lineNum"> 820 </span> : /** -<span class="lineNum"> 821 </span> : * @brief Assigns a range to a %deque. -<span class="lineNum"> 822 </span> : * @param first An input iterator. -<span class="lineNum"> 823 </span> : * @param last An input iterator. -<span class="lineNum"> 824 </span> : * -<span class="lineNum"> 825 </span> : * This function fills a %deque with copies of the elements in the -<span class="lineNum"> 826 </span> : * range [first,last). -<span class="lineNum"> 827 </span> : * -<span class="lineNum"> 828 </span> : * Note that the assignment completely changes the %deque and that the -<span class="lineNum"> 829 </span> : * resulting %deque's size is the same as the number of elements -<span class="lineNum"> 830 </span> : * assigned. Old data may be lost. -<span class="lineNum"> 831 </span> : */ -<span class="lineNum"> 832 </span> : template<typename _InputIterator> -<span class="lineNum"> 833 </span> : void -<span class="lineNum"> 834 </span> : assign(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 835 </span> : { -<span class="lineNum"> 836 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 837 </span> : _M_assign_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 838 </span> : } -<span class="lineNum"> 839 </span> : -<span class="lineNum"> 840 </span> : /// Get a copy of the memory allocation object. -<span class="lineNum"> 841 </span> : allocator_type -<span class="lineNum"> 842 </span> : get_allocator() const -<span class="lineNum"> 843 </span> : { return _Base::get_allocator(); } -<span class="lineNum"> 844 </span> : -<span class="lineNum"> 845 </span> : // iterators -<span class="lineNum"> 846 </span> : /** -<span class="lineNum"> 847 </span> : * Returns a read/write iterator that points to the first element in the -<span class="lineNum"> 848 </span> : * %deque. Iteration is done in ordinary element order. -<span class="lineNum"> 849 </span> : */ -<span class="lineNum"> 850 </span> : iterator -<span class="lineNum"> 851 </span><span class="lineCov"> 7800 : begin()</span> -<span class="lineNum"> 852 </span><span class="lineCov"> 7800 : { return this->_M_impl._M_start; }</span> -<span class="lineNum"> 853 </span> : -<span class="lineNum"> 854 </span> : /** -<span class="lineNum"> 855 </span> : * Returns a read-only (constant) iterator that points to the first -<span class="lineNum"> 856 </span> : * element in the %deque. Iteration is done in ordinary element order. -<span class="lineNum"> 857 </span> : */ -<span class="lineNum"> 858 </span> : const_iterator -<span class="lineNum"> 859 </span><span class="lineCov"> 17 : begin() const</span> -<span class="lineNum"> 860 </span><span class="lineCov"> 17 : { return this->_M_impl._M_start; }</span> -<span class="lineNum"> 861 </span> : -<span class="lineNum"> 862 </span> : /** -<span class="lineNum"> 863 </span> : * Returns a read/write iterator that points one past the last -<span class="lineNum"> 864 </span> : * element in the %deque. Iteration is done in ordinary -<span class="lineNum"> 865 </span> : * element order. -<span class="lineNum"> 866 </span> : */ -<span class="lineNum"> 867 </span> : iterator -<span class="lineNum"> 868 </span><span class="lineCov"> 10575 : end()</span> -<span class="lineNum"> 869 </span><span class="lineCov"> 10575 : { return this->_M_impl._M_finish; }</span> -<span class="lineNum"> 870 </span> : -<span class="lineNum"> 871 </span> : /** -<span class="lineNum"> 872 </span> : * Returns a read-only (constant) iterator that points one past -<span class="lineNum"> 873 </span> : * the last element in the %deque. Iteration is done in -<span class="lineNum"> 874 </span> : * ordinary element order. -<span class="lineNum"> 875 </span> : */ -<span class="lineNum"> 876 </span> : const_iterator -<span class="lineNum"> 877 </span><span class="lineCov"> 17 : end() const</span> -<span class="lineNum"> 878 </span><span class="lineCov"> 17 : { return this->_M_impl._M_finish; }</span> -<span class="lineNum"> 879 </span> : -<span class="lineNum"> 880 </span> : /** -<span class="lineNum"> 881 </span> : * Returns a read/write reverse iterator that points to the -<span class="lineNum"> 882 </span> : * last element in the %deque. Iteration is done in reverse -<span class="lineNum"> 883 </span> : * element order. -<span class="lineNum"> 884 </span> : */ -<span class="lineNum"> 885 </span> : reverse_iterator -<span class="lineNum"> 886 </span> : rbegin() -<span class="lineNum"> 887 </span> : { return reverse_iterator(this->_M_impl._M_finish); } -<span class="lineNum"> 888 </span> : -<span class="lineNum"> 889 </span> : /** -<span class="lineNum"> 890 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 891 </span> : * to the last element in the %deque. Iteration is done in -<span class="lineNum"> 892 </span> : * reverse element order. -<span class="lineNum"> 893 </span> : */ -<span class="lineNum"> 894 </span> : const_reverse_iterator -<span class="lineNum"> 895 </span> : rbegin() const -<span class="lineNum"> 896 </span> : { return const_reverse_iterator(this->_M_impl._M_finish); } -<span class="lineNum"> 897 </span> : -<span class="lineNum"> 898 </span> : /** -<span class="lineNum"> 899 </span> : * Returns a read/write reverse iterator that points to one -<span class="lineNum"> 900 </span> : * before the first element in the %deque. Iteration is done -<span class="lineNum"> 901 </span> : * in reverse element order. -<span class="lineNum"> 902 </span> : */ -<span class="lineNum"> 903 </span> : reverse_iterator -<span class="lineNum"> 904 </span> : rend() -<span class="lineNum"> 905 </span> : { return reverse_iterator(this->_M_impl._M_start); } -<span class="lineNum"> 906 </span> : -<span class="lineNum"> 907 </span> : /** -<span class="lineNum"> 908 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 909 </span> : * to one before the first element in the %deque. Iteration is -<span class="lineNum"> 910 </span> : * done in reverse element order. -<span class="lineNum"> 911 </span> : */ -<span class="lineNum"> 912 </span> : const_reverse_iterator -<span class="lineNum"> 913 </span> : rend() const -<span class="lineNum"> 914 </span> : { return const_reverse_iterator(this->_M_impl._M_start); } -<span class="lineNum"> 915 </span> : -<span class="lineNum"> 916 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 917 </span> : /** -<span class="lineNum"> 918 </span> : * Returns a read-only (constant) iterator that points to the first -<span class="lineNum"> 919 </span> : * element in the %deque. Iteration is done in ordinary element order. -<span class="lineNum"> 920 </span> : */ -<span class="lineNum"> 921 </span> : const_iterator -<span class="lineNum"> 922 </span> : cbegin() const -<span class="lineNum"> 923 </span> : { return this->_M_impl._M_start; } -<span class="lineNum"> 924 </span> : -<span class="lineNum"> 925 </span> : /** -<span class="lineNum"> 926 </span> : * Returns a read-only (constant) iterator that points one past -<span class="lineNum"> 927 </span> : * the last element in the %deque. Iteration is done in -<span class="lineNum"> 928 </span> : * ordinary element order. -<span class="lineNum"> 929 </span> : */ -<span class="lineNum"> 930 </span> : const_iterator -<span class="lineNum"> 931 </span> : cend() const -<span class="lineNum"> 932 </span> : { return this->_M_impl._M_finish; } -<span class="lineNum"> 933 </span> : -<span class="lineNum"> 934 </span> : /** -<span class="lineNum"> 935 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 936 </span> : * to the last element in the %deque. Iteration is done in -<span class="lineNum"> 937 </span> : * reverse element order. -<span class="lineNum"> 938 </span> : */ -<span class="lineNum"> 939 </span> : const_reverse_iterator -<span class="lineNum"> 940 </span> : crbegin() const -<span class="lineNum"> 941 </span> : { return const_reverse_iterator(this->_M_impl._M_finish); } -<span class="lineNum"> 942 </span> : -<span class="lineNum"> 943 </span> : /** -<span class="lineNum"> 944 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 945 </span> : * to one before the first element in the %deque. Iteration is -<span class="lineNum"> 946 </span> : * done in reverse element order. -<span class="lineNum"> 947 </span> : */ -<span class="lineNum"> 948 </span> : const_reverse_iterator -<span class="lineNum"> 949 </span> : crend() const -<span class="lineNum"> 950 </span> : { return const_reverse_iterator(this->_M_impl._M_start); } -<span class="lineNum"> 951 </span> : #endif -<span class="lineNum"> 952 </span> : -<span class="lineNum"> 953 </span> : // [23.2.1.2] capacity -<span class="lineNum"> 954 </span> : /** Returns the number of elements in the %deque. */ -<span class="lineNum"> 955 </span> : size_type -<span class="lineNum"> 956 </span><span class="lineCov"> 111 : size() const</span> -<span class="lineNum"> 957 </span><span class="lineCov"> 111 : { return this->_M_impl._M_finish - this->_M_impl._M_start; }</span> -<span class="lineNum"> 958 </span> : -<span class="lineNum"> 959 </span> : /** Returns the size() of the largest possible %deque. */ -<span class="lineNum"> 960 </span> : size_type -<span class="lineNum"> 961 </span><span class="lineNoCov"> 0 : max_size() const</span> -<span class="lineNum"> 962 </span><span class="lineNoCov"> 0 : { return _M_get_Tp_allocator().max_size(); }</span> -<span class="lineNum"> 963 </span> : -<span class="lineNum"> 964 </span> : /** -<span class="lineNum"> 965 </span> : * @brief Resizes the %deque to the specified number of elements. -<span class="lineNum"> 966 </span> : * @param new_size Number of elements the %deque should contain. -<span class="lineNum"> 967 </span> : * @param x Data with which new elements should be populated. -<span class="lineNum"> 968 </span> : * -<span class="lineNum"> 969 </span> : * This function will %resize the %deque to the specified -<span class="lineNum"> 970 </span> : * number of elements. If the number is smaller than the -<span class="lineNum"> 971 </span> : * %deque's current size the %deque is truncated, otherwise the -<span class="lineNum"> 972 </span> : * %deque is extended and new elements are populated with given -<span class="lineNum"> 973 </span> : * data. -<span class="lineNum"> 974 </span> : */ -<span class="lineNum"> 975 </span> : void -<span class="lineNum"> 976 </span> : resize(size_type __new_size, value_type __x = value_type()) -<span class="lineNum"> 977 </span> : { -<span class="lineNum"> 978 </span> : const size_type __len = size(); -<span class="lineNum"> 979 </span> : if (__new_size < __len) -<span class="lineNum"> 980 </span> : _M_erase_at_end(this->_M_impl._M_start + difference_type(__new_size)); -<span class="lineNum"> 981 </span> : else -<span class="lineNum"> 982 </span> : insert(this->_M_impl._M_finish, __new_size - __len, __x); -<span class="lineNum"> 983 </span> : } -<span class="lineNum"> 984 </span> : -<span class="lineNum"> 985 </span> : /** -<span class="lineNum"> 986 </span> : * Returns true if the %deque is empty. (Thus begin() would -<span class="lineNum"> 987 </span> : * equal end().) -<span class="lineNum"> 988 </span> : */ -<span class="lineNum"> 989 </span> : bool -<span class="lineNum"> 990 </span><span class="lineCov"> 32 : empty() const</span> -<span class="lineNum"> 991 </span><span class="lineCov"> 32 : { return this->_M_impl._M_finish == this->_M_impl._M_start; }</span> -<span class="lineNum"> 992 </span> : -<span class="lineNum"> 993 </span> : // element access -<span class="lineNum"> 994 </span> : /** -<span class="lineNum"> 995 </span> : * @brief Subscript access to the data contained in the %deque. -<span class="lineNum"> 996 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 997 </span> : * accessed. -<span class="lineNum"> 998 </span> : * @return Read/write reference to data. -<span class="lineNum"> 999 </span> : * -<span class="lineNum"> 1000 </span> : * This operator allows for easy, array-style, data access. -<span class="lineNum"> 1001 </span> : * Note that data access with this operator is unchecked and -<span class="lineNum"> 1002 </span> : * out_of_range lookups are not defined. (For checked lookups -<span class="lineNum"> 1003 </span> : * see at().) -<span class="lineNum"> 1004 </span> : */ -<span class="lineNum"> 1005 </span> : reference -<span class="lineNum"> 1006 </span> : operator[](size_type __n) -<span class="lineNum"> 1007 </span> : { return this->_M_impl._M_start[difference_type(__n)]; } -<span class="lineNum"> 1008 </span> : -<span class="lineNum"> 1009 </span> : /** -<span class="lineNum"> 1010 </span> : * @brief Subscript access to the data contained in the %deque. -<span class="lineNum"> 1011 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 1012 </span> : * accessed. -<span class="lineNum"> 1013 </span> : * @return Read-only (constant) reference to data. -<span class="lineNum"> 1014 </span> : * -<span class="lineNum"> 1015 </span> : * This operator allows for easy, array-style, data access. -<span class="lineNum"> 1016 </span> : * Note that data access with this operator is unchecked and -<span class="lineNum"> 1017 </span> : * out_of_range lookups are not defined. (For checked lookups -<span class="lineNum"> 1018 </span> : * see at().) -<span class="lineNum"> 1019 </span> : */ -<span class="lineNum"> 1020 </span> : const_reference -<span class="lineNum"> 1021 </span> : operator[](size_type __n) const -<span class="lineNum"> 1022 </span> : { return this->_M_impl._M_start[difference_type(__n)]; } -<span class="lineNum"> 1023 </span> : -<span class="lineNum"> 1024 </span> : protected: -<span class="lineNum"> 1025 </span> : /// Safety check used only from at(). -<span class="lineNum"> 1026 </span> : void -<span class="lineNum"> 1027 </span> : _M_range_check(size_type __n) const -<span class="lineNum"> 1028 </span> : { -<span class="lineNum"> 1029 </span> : if (__n >= this->size()) -<span class="lineNum"> 1030 </span> : __throw_out_of_range(__N("deque::_M_range_check")); -<span class="lineNum"> 1031 </span> : } -<span class="lineNum"> 1032 </span> : -<span class="lineNum"> 1033 </span> : public: -<span class="lineNum"> 1034 </span> : /** -<span class="lineNum"> 1035 </span> : * @brief Provides access to the data contained in the %deque. -<span class="lineNum"> 1036 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 1037 </span> : * accessed. -<span class="lineNum"> 1038 </span> : * @return Read/write reference to data. -<span class="lineNum"> 1039 </span> : * @throw std::out_of_range If @a n is an invalid index. -<span class="lineNum"> 1040 </span> : * -<span class="lineNum"> 1041 </span> : * This function provides for safer data access. The parameter -<span class="lineNum"> 1042 </span> : * is first checked that it is in the range of the deque. The -<span class="lineNum"> 1043 </span> : * function throws out_of_range if the check fails. -<span class="lineNum"> 1044 </span> : */ -<span class="lineNum"> 1045 </span> : reference -<span class="lineNum"> 1046 </span> : at(size_type __n) -<span class="lineNum"> 1047 </span> : { -<span class="lineNum"> 1048 </span> : _M_range_check(__n); -<span class="lineNum"> 1049 </span> : return (*this)[__n]; -<span class="lineNum"> 1050 </span> : } -<span class="lineNum"> 1051 </span> : -<span class="lineNum"> 1052 </span> : /** -<span class="lineNum"> 1053 </span> : * @brief Provides access to the data contained in the %deque. -<span class="lineNum"> 1054 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 1055 </span> : * accessed. -<span class="lineNum"> 1056 </span> : * @return Read-only (constant) reference to data. -<span class="lineNum"> 1057 </span> : * @throw std::out_of_range If @a n is an invalid index. -<span class="lineNum"> 1058 </span> : * -<span class="lineNum"> 1059 </span> : * This function provides for safer data access. The parameter is first -<span class="lineNum"> 1060 </span> : * checked that it is in the range of the deque. The function throws -<span class="lineNum"> 1061 </span> : * out_of_range if the check fails. -<span class="lineNum"> 1062 </span> : */ -<span class="lineNum"> 1063 </span> : const_reference -<span class="lineNum"> 1064 </span> : at(size_type __n) const -<span class="lineNum"> 1065 </span> : { -<span class="lineNum"> 1066 </span> : _M_range_check(__n); -<span class="lineNum"> 1067 </span> : return (*this)[__n]; -<span class="lineNum"> 1068 </span> : } -<span class="lineNum"> 1069 </span> : -<span class="lineNum"> 1070 </span> : /** -<span class="lineNum"> 1071 </span> : * Returns a read/write reference to the data at the first -<span class="lineNum"> 1072 </span> : * element of the %deque. -<span class="lineNum"> 1073 </span> : */ -<span class="lineNum"> 1074 </span> : reference -<span class="lineNum"> 1075 </span> : front() -<span class="lineNum"> 1076 </span> : { return *begin(); } -<span class="lineNum"> 1077 </span> : -<span class="lineNum"> 1078 </span> : /** -<span class="lineNum"> 1079 </span> : * Returns a read-only (constant) reference to the data at the first -<span class="lineNum"> 1080 </span> : * element of the %deque. -<span class="lineNum"> 1081 </span> : */ -<span class="lineNum"> 1082 </span> : const_reference -<span class="lineNum"> 1083 </span> : front() const -<span class="lineNum"> 1084 </span> : { return *begin(); } -<span class="lineNum"> 1085 </span> : -<span class="lineNum"> 1086 </span> : /** -<span class="lineNum"> 1087 </span> : * Returns a read/write reference to the data at the last element of the -<span class="lineNum"> 1088 </span> : * %deque. -<span class="lineNum"> 1089 </span> : */ -<span class="lineNum"> 1090 </span> : reference -<span class="lineNum"> 1091 </span><span class="lineCov"> 39 : back()</span> -<span class="lineNum"> 1092 </span> : { -<span class="lineNum"> 1093 </span><span class="lineCov"> 39 : iterator __tmp = end();</span> -<span class="lineNum"> 1094 </span><span class="lineCov"> 39 : --__tmp;</span> -<span class="lineNum"> 1095 </span><span class="lineCov"> 39 : return *__tmp;</span> -<span class="lineNum"> 1096 </span> : } -<span class="lineNum"> 1097 </span> : -<span class="lineNum"> 1098 </span> : /** -<span class="lineNum"> 1099 </span> : * Returns a read-only (constant) reference to the data at the last -<span class="lineNum"> 1100 </span> : * element of the %deque. -<span class="lineNum"> 1101 </span> : */ -<span class="lineNum"> 1102 </span> : const_reference -<span class="lineNum"> 1103 </span> : back() const -<span class="lineNum"> 1104 </span> : { -<span class="lineNum"> 1105 </span> : const_iterator __tmp = end(); -<span class="lineNum"> 1106 </span> : --__tmp; -<span class="lineNum"> 1107 </span> : return *__tmp; -<span class="lineNum"> 1108 </span> : } -<span class="lineNum"> 1109 </span> : -<span class="lineNum"> 1110 </span> : // [23.2.1.2] modifiers -<span class="lineNum"> 1111 </span> : /** -<span class="lineNum"> 1112 </span> : * @brief Add data to the front of the %deque. -<span class="lineNum"> 1113 </span> : * @param x Data to be added. -<span class="lineNum"> 1114 </span> : * -<span class="lineNum"> 1115 </span> : * This is a typical stack operation. The function creates an -<span class="lineNum"> 1116 </span> : * element at the front of the %deque and assigns the given -<span class="lineNum"> 1117 </span> : * data to it. Due to the nature of a %deque this operation -<span class="lineNum"> 1118 </span> : * can be done in constant time. -<span class="lineNum"> 1119 </span> : */ -<span class="lineNum"> 1120 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1121 </span> : void -<span class="lineNum"> 1122 </span> : push_front(const value_type& __x) -<span class="lineNum"> 1123 </span> : { -<span class="lineNum"> 1124 </span> : if (this->_M_impl._M_start._M_cur != this->_M_impl._M_start._M_first) -<span class="lineNum"> 1125 </span> : { -<span class="lineNum"> 1126 </span> : this->_M_impl.construct(this->_M_impl._M_start._M_cur - 1, __x); -<span class="lineNum"> 1127 </span> : --this->_M_impl._M_start._M_cur; -<span class="lineNum"> 1128 </span> : } -<span class="lineNum"> 1129 </span> : else -<span class="lineNum"> 1130 </span> : _M_push_front_aux(__x); -<span class="lineNum"> 1131 </span> : } -<span class="lineNum"> 1132 </span> : #else -<span class="lineNum"> 1133 </span> : template<typename... _Args> -<span class="lineNum"> 1134 </span> : void -<span class="lineNum"> 1135 </span> : push_front(_Args&&... __args) -<span class="lineNum"> 1136 </span> : { -<span class="lineNum"> 1137 </span> : if (this->_M_impl._M_start._M_cur != this->_M_impl._M_start._M_first) -<span class="lineNum"> 1138 </span> : { -<span class="lineNum"> 1139 </span> : this->_M_impl.construct(this->_M_impl._M_start._M_cur - 1, -<span class="lineNum"> 1140 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 1141 </span> : --this->_M_impl._M_start._M_cur; -<span class="lineNum"> 1142 </span> : } -<span class="lineNum"> 1143 </span> : else -<span class="lineNum"> 1144 </span> : _M_push_front_aux(std::forward<_Args>(__args)...); -<span class="lineNum"> 1145 </span> : } -<span class="lineNum"> 1146 </span> : #endif -<span class="lineNum"> 1147 </span> : -<span class="lineNum"> 1148 </span> : /** -<span class="lineNum"> 1149 </span> : * @brief Add data to the end of the %deque. -<span class="lineNum"> 1150 </span> : * @param x Data to be added. -<span class="lineNum"> 1151 </span> : * -<span class="lineNum"> 1152 </span> : * This is a typical stack operation. The function creates an -<span class="lineNum"> 1153 </span> : * element at the end of the %deque and assigns the given data -<span class="lineNum"> 1154 </span> : * to it. Due to the nature of a %deque this operation can be -<span class="lineNum"> 1155 </span> : * done in constant time. -<span class="lineNum"> 1156 </span> : */ -<span class="lineNum"> 1157 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1158 </span> : void -<span class="lineNum"> 1159 </span><span class="lineCov"> 12012 : push_back(const value_type& __x)</span> -<span class="lineNum"> 1160 </span> : { -<span class="lineNum"> 1161 </span><span class="lineCov"> 12012 : if (this->_M_impl._M_finish._M_cur</span> -<span class="lineNum"> 1162 </span> : != this->_M_impl._M_finish._M_last - 1) -<span class="lineNum"> 1163 </span> : { -<span class="lineNum"> 1164 </span><span class="lineCov"> 11999 : this->_M_impl.construct(this->_M_impl._M_finish._M_cur, __x);</span> -<span class="lineNum"> 1165 </span><span class="lineCov"> 11999 : ++this->_M_impl._M_finish._M_cur;</span> -<span class="lineNum"> 1166 </span> : } -<span class="lineNum"> 1167 </span> : else -<span class="lineNum"> 1168 </span><span class="lineCov"> 13 : _M_push_back_aux(__x);</span> -<span class="lineNum"> 1169 </span><span class="lineCov"> 12012 : }</span> -<span class="lineNum"> 1170 </span> : #else -<span class="lineNum"> 1171 </span> : template<typename... _Args> -<span class="lineNum"> 1172 </span> : void -<span class="lineNum"> 1173 </span> : push_back(_Args&&... __args) -<span class="lineNum"> 1174 </span> : { -<span class="lineNum"> 1175 </span> : if (this->_M_impl._M_finish._M_cur -<span class="lineNum"> 1176 </span> : != this->_M_impl._M_finish._M_last - 1) -<span class="lineNum"> 1177 </span> : { -<span class="lineNum"> 1178 </span> : this->_M_impl.construct(this->_M_impl._M_finish._M_cur, -<span class="lineNum"> 1179 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 1180 </span> : ++this->_M_impl._M_finish._M_cur; -<span class="lineNum"> 1181 </span> : } -<span class="lineNum"> 1182 </span> : else -<span class="lineNum"> 1183 </span> : _M_push_back_aux(std::forward<_Args>(__args)...); -<span class="lineNum"> 1184 </span> : } -<span class="lineNum"> 1185 </span> : #endif -<span class="lineNum"> 1186 </span> : -<span class="lineNum"> 1187 </span> : /** -<span class="lineNum"> 1188 </span> : * @brief Removes first element. -<span class="lineNum"> 1189 </span> : * -<span class="lineNum"> 1190 </span> : * This is a typical stack operation. It shrinks the %deque by one. -<span class="lineNum"> 1191 </span> : * -<span class="lineNum"> 1192 </span> : * Note that no data is returned, and if the first element's data is -<span class="lineNum"> 1193 </span> : * needed, it should be retrieved before pop_front() is called. -<span class="lineNum"> 1194 </span> : */ -<span class="lineNum"> 1195 </span> : void -<span class="lineNum"> 1196 </span> : pop_front() -<span class="lineNum"> 1197 </span> : { -<span class="lineNum"> 1198 </span> : if (this->_M_impl._M_start._M_cur -<span class="lineNum"> 1199 </span> : != this->_M_impl._M_start._M_last - 1) -<span class="lineNum"> 1200 </span> : { -<span class="lineNum"> 1201 </span> : this->_M_impl.destroy(this->_M_impl._M_start._M_cur); -<span class="lineNum"> 1202 </span> : ++this->_M_impl._M_start._M_cur; -<span class="lineNum"> 1203 </span> : } -<span class="lineNum"> 1204 </span> : else -<span class="lineNum"> 1205 </span> : _M_pop_front_aux(); -<span class="lineNum"> 1206 </span> : } -<span class="lineNum"> 1207 </span> : -<span class="lineNum"> 1208 </span> : /** -<span class="lineNum"> 1209 </span> : * @brief Removes last element. -<span class="lineNum"> 1210 </span> : * -<span class="lineNum"> 1211 </span> : * This is a typical stack operation. It shrinks the %deque by one. -<span class="lineNum"> 1212 </span> : * -<span class="lineNum"> 1213 </span> : * Note that no data is returned, and if the last element's data is -<span class="lineNum"> 1214 </span> : * needed, it should be retrieved before pop_back() is called. -<span class="lineNum"> 1215 </span> : */ -<span class="lineNum"> 1216 </span> : void -<span class="lineNum"> 1217 </span><span class="lineCov"> 24 : pop_back()</span> -<span class="lineNum"> 1218 </span> : { -<span class="lineNum"> 1219 </span><span class="lineCov"> 24 : if (this->_M_impl._M_finish._M_cur</span> -<span class="lineNum"> 1220 </span> : != this->_M_impl._M_finish._M_first) -<span class="lineNum"> 1221 </span> : { -<span class="lineNum"> 1222 </span><span class="lineCov"> 24 : --this->_M_impl._M_finish._M_cur;</span> -<span class="lineNum"> 1223 </span><span class="lineCov"> 24 : this->_M_impl.destroy(this->_M_impl._M_finish._M_cur);</span> -<span class="lineNum"> 1224 </span> : } -<span class="lineNum"> 1225 </span> : else -<span class="lineNum"> 1226 </span><span class="lineNoCov"> 0 : _M_pop_back_aux();</span> -<span class="lineNum"> 1227 </span><span class="lineCov"> 24 : }</span> -<span class="lineNum"> 1228 </span> : -<span class="lineNum"> 1229 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1230 </span> : /** -<span class="lineNum"> 1231 </span> : * @brief Inserts an object in %deque before specified iterator. -<span class="lineNum"> 1232 </span> : * @param position An iterator into the %deque. -<span class="lineNum"> 1233 </span> : * @param args Arguments. -<span class="lineNum"> 1234 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 1235 </span> : * -<span class="lineNum"> 1236 </span> : * This function will insert an object of type T constructed -<span class="lineNum"> 1237 </span> : * with T(std::forward<Args>(args)...) before the specified location. -<span class="lineNum"> 1238 </span> : */ -<span class="lineNum"> 1239 </span> : template<typename... _Args> -<span class="lineNum"> 1240 </span> : iterator -<span class="lineNum"> 1241 </span> : emplace(iterator __position, _Args&&... __args); -<span class="lineNum"> 1242 </span> : #endif -<span class="lineNum"> 1243 </span> : -<span class="lineNum"> 1244 </span> : /** -<span class="lineNum"> 1245 </span> : * @brief Inserts given value into %deque before specified iterator. -<span class="lineNum"> 1246 </span> : * @param position An iterator into the %deque. -<span class="lineNum"> 1247 </span> : * @param x Data to be inserted. -<span class="lineNum"> 1248 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 1249 </span> : * -<span class="lineNum"> 1250 </span> : * This function will insert a copy of the given value before the -<span class="lineNum"> 1251 </span> : * specified location. -<span class="lineNum"> 1252 </span> : */ -<span class="lineNum"> 1253 </span> : iterator -<span class="lineNum"> 1254 </span> : insert(iterator __position, const value_type& __x); -<span class="lineNum"> 1255 </span> : -<span class="lineNum"> 1256 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1257 </span> : /** -<span class="lineNum"> 1258 </span> : * @brief Inserts given rvalue into %deque before specified iterator. -<span class="lineNum"> 1259 </span> : * @param position An iterator into the %deque. -<span class="lineNum"> 1260 </span> : * @param x Data to be inserted. -<span class="lineNum"> 1261 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 1262 </span> : * -<span class="lineNum"> 1263 </span> : * This function will insert a copy of the given rvalue before the -<span class="lineNum"> 1264 </span> : * specified location. -<span class="lineNum"> 1265 </span> : */ -<span class="lineNum"> 1266 </span> : iterator -<span class="lineNum"> 1267 </span> : insert(iterator __position, value_type&& __x) -<span class="lineNum"> 1268 </span> : { return emplace(__position, std::move(__x)); } -<span class="lineNum"> 1269 </span> : #endif -<span class="lineNum"> 1270 </span> : -<span class="lineNum"> 1271 </span> : /** -<span class="lineNum"> 1272 </span> : * @brief Inserts a number of copies of given data into the %deque. -<span class="lineNum"> 1273 </span> : * @param position An iterator into the %deque. -<span class="lineNum"> 1274 </span> : * @param n Number of elements to be inserted. -<span class="lineNum"> 1275 </span> : * @param x Data to be inserted. -<span class="lineNum"> 1276 </span> : * -<span class="lineNum"> 1277 </span> : * This function will insert a specified number of copies of the given -<span class="lineNum"> 1278 </span> : * data before the location specified by @a position. -<span class="lineNum"> 1279 </span> : */ -<span class="lineNum"> 1280 </span> : void -<span class="lineNum"> 1281 </span> : insert(iterator __position, size_type __n, const value_type& __x) -<span class="lineNum"> 1282 </span> : { _M_fill_insert(__position, __n, __x); } -<span class="lineNum"> 1283 </span> : -<span class="lineNum"> 1284 </span> : /** -<span class="lineNum"> 1285 </span> : * @brief Inserts a range into the %deque. -<span class="lineNum"> 1286 </span> : * @param position An iterator into the %deque. -<span class="lineNum"> 1287 </span> : * @param first An input iterator. -<span class="lineNum"> 1288 </span> : * @param last An input iterator. -<span class="lineNum"> 1289 </span> : * -<span class="lineNum"> 1290 </span> : * This function will insert copies of the data in the range -<span class="lineNum"> 1291 </span> : * [first,last) into the %deque before the location specified -<span class="lineNum"> 1292 </span> : * by @a pos. This is known as "range insert." -<span class="lineNum"> 1293 </span> : */ -<span class="lineNum"> 1294 </span> : template<typename _InputIterator> -<span class="lineNum"> 1295 </span> : void -<span class="lineNum"> 1296 </span> : insert(iterator __position, _InputIterator __first, -<span class="lineNum"> 1297 </span><span class="lineNoCov"> 0 : _InputIterator __last)</span> -<span class="lineNum"> 1298 </span> : { -<span class="lineNum"> 1299 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 1300 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 1301 </span><span class="lineNoCov"> 0 : _M_insert_dispatch(__position, __first, __last, _Integral());</span> -<span class="lineNum"> 1302 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1303 </span> : -<span class="lineNum"> 1304 </span> : /** -<span class="lineNum"> 1305 </span> : * @brief Remove element at given position. -<span class="lineNum"> 1306 </span> : * @param position Iterator pointing to element to be erased. -<span class="lineNum"> 1307 </span> : * @return An iterator pointing to the next element (or end()). -<span class="lineNum"> 1308 </span> : * -<span class="lineNum"> 1309 </span> : * This function will erase the element at the given position and thus -<span class="lineNum"> 1310 </span> : * shorten the %deque by one. -<span class="lineNum"> 1311 </span> : * -<span class="lineNum"> 1312 </span> : * The user is cautioned that -<span class="lineNum"> 1313 </span> : * this function only erases the element, and that if the element is -<span class="lineNum"> 1314 </span> : * itself a pointer, the pointed-to memory is not touched in any way. -<span class="lineNum"> 1315 </span> : * Managing the pointer is the user's responsibility. -<span class="lineNum"> 1316 </span> : */ -<span class="lineNum"> 1317 </span> : iterator -<span class="lineNum"> 1318 </span> : erase(iterator __position); -<span class="lineNum"> 1319 </span> : -<span class="lineNum"> 1320 </span> : /** -<span class="lineNum"> 1321 </span> : * @brief Remove a range of elements. -<span class="lineNum"> 1322 </span> : * @param first Iterator pointing to the first element to be erased. -<span class="lineNum"> 1323 </span> : * @param last Iterator pointing to one past the last element to be -<span class="lineNum"> 1324 </span> : * erased. -<span class="lineNum"> 1325 </span> : * @return An iterator pointing to the element pointed to by @a last -<span class="lineNum"> 1326 </span> : * prior to erasing (or end()). -<span class="lineNum"> 1327 </span> : * -<span class="lineNum"> 1328 </span> : * This function will erase the elements in the range [first,last) and -<span class="lineNum"> 1329 </span> : * shorten the %deque accordingly. -<span class="lineNum"> 1330 </span> : * -<span class="lineNum"> 1331 </span> : * The user is cautioned that -<span class="lineNum"> 1332 </span> : * this function only erases the elements, and that if the elements -<span class="lineNum"> 1333 </span> : * themselves are pointers, the pointed-to memory is not touched in any -<span class="lineNum"> 1334 </span> : * way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 1335 </span> : */ -<span class="lineNum"> 1336 </span> : iterator -<span class="lineNum"> 1337 </span> : erase(iterator __first, iterator __last); -<span class="lineNum"> 1338 </span> : -<span class="lineNum"> 1339 </span> : /** -<span class="lineNum"> 1340 </span> : * @brief Swaps data with another %deque. -<span class="lineNum"> 1341 </span> : * @param x A %deque of the same element and allocator types. -<span class="lineNum"> 1342 </span> : * -<span class="lineNum"> 1343 </span> : * This exchanges the elements between two deques in constant time. -<span class="lineNum"> 1344 </span> : * (Four pointers, so it should be quite fast.) -<span class="lineNum"> 1345 </span> : * Note that the global std::swap() function is specialized such that -<span class="lineNum"> 1346 </span> : * std::swap(d1,d2) will feed to this function. -<span class="lineNum"> 1347 </span> : */ -<span class="lineNum"> 1348 </span> : void -<span class="lineNum"> 1349 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1350 </span> : swap(deque&& __x) -<span class="lineNum"> 1351 </span> : #else -<span class="lineNum"> 1352 </span> : swap(deque& __x) -<span class="lineNum"> 1353 </span> : #endif -<span class="lineNum"> 1354 </span> : { -<span class="lineNum"> 1355 </span> : std::swap(this->_M_impl._M_start, __x._M_impl._M_start); -<span class="lineNum"> 1356 </span> : std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); -<span class="lineNum"> 1357 </span> : std::swap(this->_M_impl._M_map, __x._M_impl._M_map); -<span class="lineNum"> 1358 </span> : std::swap(this->_M_impl._M_map_size, __x._M_impl._M_map_size); -<span class="lineNum"> 1359 </span> : -<span class="lineNum"> 1360 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1361 </span> : // 431. Swapping containers with unequal allocators. -<span class="lineNum"> 1362 </span> : std::__alloc_swap<_Tp_alloc_type>::_S_do_it(_M_get_Tp_allocator(), -<span class="lineNum"> 1363 </span> : __x._M_get_Tp_allocator()); -<span class="lineNum"> 1364 </span> : } -<span class="lineNum"> 1365 </span> : -<span class="lineNum"> 1366 </span> : /** -<span class="lineNum"> 1367 </span> : * Erases all the elements. Note that this function only erases the -<span class="lineNum"> 1368 </span> : * elements, and that if the elements themselves are pointers, the -<span class="lineNum"> 1369 </span> : * pointed-to memory is not touched in any way. Managing the pointer is -<span class="lineNum"> 1370 </span> : * the user's responsibility. -<span class="lineNum"> 1371 </span> : */ -<span class="lineNum"> 1372 </span> : void -<span class="lineNum"> 1373 </span><span class="lineCov"> 922 : clear()</span> -<span class="lineNum"> 1374 </span><span class="lineCov"> 922 : { _M_erase_at_end(begin()); }</span> -<span class="lineNum"> 1375 </span> : -<span class="lineNum"> 1376 </span> : protected: -<span class="lineNum"> 1377 </span> : // Internal constructor functions follow. -<span class="lineNum"> 1378 </span> : -<span class="lineNum"> 1379 </span> : // called by the range constructor to implement [23.1.1]/9 -<span class="lineNum"> 1380 </span> : -<span class="lineNum"> 1381 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1382 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1383 </span> : template<typename _Integer> -<span class="lineNum"> 1384 </span> : void -<span class="lineNum"> 1385 </span> : _M_initialize_dispatch(_Integer __n, _Integer __x, __true_type) -<span class="lineNum"> 1386 </span> : { -<span class="lineNum"> 1387 </span> : _M_initialize_map(static_cast<size_type>(__n)); -<span class="lineNum"> 1388 </span> : _M_fill_initialize(__x); -<span class="lineNum"> 1389 </span> : } -<span class="lineNum"> 1390 </span> : -<span class="lineNum"> 1391 </span> : // called by the range constructor to implement [23.1.1]/9 -<span class="lineNum"> 1392 </span> : template<typename _InputIterator> -<span class="lineNum"> 1393 </span> : void -<span class="lineNum"> 1394 </span> : _M_initialize_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1395 </span> : __false_type) -<span class="lineNum"> 1396 </span> : { -<span class="lineNum"> 1397 </span> : typedef typename std::iterator_traits<_InputIterator>:: -<span class="lineNum"> 1398 </span> : iterator_category _IterCategory; -<span class="lineNum"> 1399 </span> : _M_range_initialize(__first, __last, _IterCategory()); -<span class="lineNum"> 1400 </span> : } -<span class="lineNum"> 1401 </span> : -<span class="lineNum"> 1402 </span> : // called by the second initialize_dispatch above -<span class="lineNum"> 1403 </span> : //@{ -<span class="lineNum"> 1404 </span> : /** -<span class="lineNum"> 1405 </span> : * @brief Fills the deque with whatever is in [first,last). -<span class="lineNum"> 1406 </span> : * @param first An input iterator. -<span class="lineNum"> 1407 </span> : * @param last An input iterator. -<span class="lineNum"> 1408 </span> : * @return Nothing. -<span class="lineNum"> 1409 </span> : * -<span class="lineNum"> 1410 </span> : * If the iterators are actually forward iterators (or better), then the -<span class="lineNum"> 1411 </span> : * memory layout can be done all at once. Else we move forward using -<span class="lineNum"> 1412 </span> : * push_back on each value from the iterator. -<span class="lineNum"> 1413 </span> : */ -<span class="lineNum"> 1414 </span> : template<typename _InputIterator> -<span class="lineNum"> 1415 </span> : void -<span class="lineNum"> 1416 </span> : _M_range_initialize(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1417 </span> : std::input_iterator_tag); -<span class="lineNum"> 1418 </span> : -<span class="lineNum"> 1419 </span> : // called by the second initialize_dispatch above -<span class="lineNum"> 1420 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1421 </span> : void -<span class="lineNum"> 1422 </span> : _M_range_initialize(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 1423 </span> : std::forward_iterator_tag); -<span class="lineNum"> 1424 </span> : //@} -<span class="lineNum"> 1425 </span> : -<span class="lineNum"> 1426 </span> : /** -<span class="lineNum"> 1427 </span> : * @brief Fills the %deque with copies of value. -<span class="lineNum"> 1428 </span> : * @param value Initial value. -<span class="lineNum"> 1429 </span> : * @return Nothing. -<span class="lineNum"> 1430 </span> : * @pre _M_start and _M_finish have already been initialized, -<span class="lineNum"> 1431 </span> : * but none of the %deque's elements have yet been constructed. -<span class="lineNum"> 1432 </span> : * -<span class="lineNum"> 1433 </span> : * This function is called only when the user provides an explicit size -<span class="lineNum"> 1434 </span> : * (with or without an explicit exemplar value). -<span class="lineNum"> 1435 </span> : */ -<span class="lineNum"> 1436 </span> : void -<span class="lineNum"> 1437 </span> : _M_fill_initialize(const value_type& __value); -<span class="lineNum"> 1438 </span> : -<span class="lineNum"> 1439 </span> : // Internal assign functions follow. The *_aux functions do the actual -<span class="lineNum"> 1440 </span> : // assignment work for the range versions. -<span class="lineNum"> 1441 </span> : -<span class="lineNum"> 1442 </span> : // called by the range assign to implement [23.1.1]/9 -<span class="lineNum"> 1443 </span> : -<span class="lineNum"> 1444 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1445 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1446 </span> : template<typename _Integer> -<span class="lineNum"> 1447 </span> : void -<span class="lineNum"> 1448 </span> : _M_assign_dispatch(_Integer __n, _Integer __val, __true_type) -<span class="lineNum"> 1449 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 1450 </span> : -<span class="lineNum"> 1451 </span> : // called by the range assign to implement [23.1.1]/9 -<span class="lineNum"> 1452 </span> : template<typename _InputIterator> -<span class="lineNum"> 1453 </span> : void -<span class="lineNum"> 1454 </span> : _M_assign_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1455 </span> : __false_type) -<span class="lineNum"> 1456 </span> : { -<span class="lineNum"> 1457 </span> : typedef typename std::iterator_traits<_InputIterator>:: -<span class="lineNum"> 1458 </span> : iterator_category _IterCategory; -<span class="lineNum"> 1459 </span> : _M_assign_aux(__first, __last, _IterCategory()); -<span class="lineNum"> 1460 </span> : } -<span class="lineNum"> 1461 </span> : -<span class="lineNum"> 1462 </span> : // called by the second assign_dispatch above -<span class="lineNum"> 1463 </span> : template<typename _InputIterator> -<span class="lineNum"> 1464 </span> : void -<span class="lineNum"> 1465 </span> : _M_assign_aux(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1466 </span> : std::input_iterator_tag); -<span class="lineNum"> 1467 </span> : -<span class="lineNum"> 1468 </span> : // called by the second assign_dispatch above -<span class="lineNum"> 1469 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1470 </span> : void -<span class="lineNum"> 1471 </span> : _M_assign_aux(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 1472 </span> : std::forward_iterator_tag) -<span class="lineNum"> 1473 </span> : { -<span class="lineNum"> 1474 </span> : const size_type __len = std::distance(__first, __last); -<span class="lineNum"> 1475 </span> : if (__len > size()) -<span class="lineNum"> 1476 </span> : { -<span class="lineNum"> 1477 </span> : _ForwardIterator __mid = __first; -<span class="lineNum"> 1478 </span> : std::advance(__mid, size()); -<span class="lineNum"> 1479 </span> : std::copy(__first, __mid, begin()); -<span class="lineNum"> 1480 </span> : insert(end(), __mid, __last); -<span class="lineNum"> 1481 </span> : } -<span class="lineNum"> 1482 </span> : else -<span class="lineNum"> 1483 </span> : _M_erase_at_end(std::copy(__first, __last, begin())); -<span class="lineNum"> 1484 </span> : } -<span class="lineNum"> 1485 </span> : -<span class="lineNum"> 1486 </span> : // Called by assign(n,t), and the range assign when it turns out -<span class="lineNum"> 1487 </span> : // to be the same thing. -<span class="lineNum"> 1488 </span> : void -<span class="lineNum"> 1489 </span> : _M_fill_assign(size_type __n, const value_type& __val) -<span class="lineNum"> 1490 </span> : { -<span class="lineNum"> 1491 </span> : if (__n > size()) -<span class="lineNum"> 1492 </span> : { -<span class="lineNum"> 1493 </span> : std::fill(begin(), end(), __val); -<span class="lineNum"> 1494 </span> : insert(end(), __n - size(), __val); -<span class="lineNum"> 1495 </span> : } -<span class="lineNum"> 1496 </span> : else -<span class="lineNum"> 1497 </span> : { -<span class="lineNum"> 1498 </span> : _M_erase_at_end(begin() + difference_type(__n)); -<span class="lineNum"> 1499 </span> : std::fill(begin(), end(), __val); -<span class="lineNum"> 1500 </span> : } -<span class="lineNum"> 1501 </span> : } -<span class="lineNum"> 1502 </span> : -<span class="lineNum"> 1503 </span> : //@{ -<span class="lineNum"> 1504 </span> : /// Helper functions for push_* and pop_*. -<span class="lineNum"> 1505 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1506 </span> : void _M_push_back_aux(const value_type&); -<span class="lineNum"> 1507 </span> : -<span class="lineNum"> 1508 </span> : void _M_push_front_aux(const value_type&); -<span class="lineNum"> 1509 </span> : #else -<span class="lineNum"> 1510 </span> : template<typename... _Args> -<span class="lineNum"> 1511 </span> : void _M_push_back_aux(_Args&&... __args); -<span class="lineNum"> 1512 </span> : -<span class="lineNum"> 1513 </span> : template<typename... _Args> -<span class="lineNum"> 1514 </span> : void _M_push_front_aux(_Args&&... __args); -<span class="lineNum"> 1515 </span> : #endif -<span class="lineNum"> 1516 </span> : -<span class="lineNum"> 1517 </span> : void _M_pop_back_aux(); -<span class="lineNum"> 1518 </span> : -<span class="lineNum"> 1519 </span> : void _M_pop_front_aux(); -<span class="lineNum"> 1520 </span> : //@} -<span class="lineNum"> 1521 </span> : -<span class="lineNum"> 1522 </span> : // Internal insert functions follow. The *_aux functions do the actual -<span class="lineNum"> 1523 </span> : // insertion work when all shortcuts fail. -<span class="lineNum"> 1524 </span> : -<span class="lineNum"> 1525 </span> : // called by the range insert to implement [23.1.1]/9 -<span class="lineNum"> 1526 </span> : -<span class="lineNum"> 1527 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1528 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1529 </span> : template<typename _Integer> -<span class="lineNum"> 1530 </span> : void -<span class="lineNum"> 1531 </span> : _M_insert_dispatch(iterator __pos, -<span class="lineNum"> 1532 </span> : _Integer __n, _Integer __x, __true_type) -<span class="lineNum"> 1533 </span> : { _M_fill_insert(__pos, __n, __x); } -<span class="lineNum"> 1534 </span> : -<span class="lineNum"> 1535 </span> : // called by the range insert to implement [23.1.1]/9 -<span class="lineNum"> 1536 </span> : template<typename _InputIterator> -<span class="lineNum"> 1537 </span> : void -<span class="lineNum"> 1538 </span> : _M_insert_dispatch(iterator __pos, -<span class="lineNum"> 1539 </span> : _InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1540 </span><span class="lineNoCov"> 0 : __false_type)</span> -<span class="lineNum"> 1541 </span> : { -<span class="lineNum"> 1542 </span> : typedef typename std::iterator_traits<_InputIterator>:: -<span class="lineNum"> 1543 </span> : iterator_category _IterCategory; -<span class="lineNum"> 1544 </span><span class="lineNoCov"> 0 : _M_range_insert_aux(__pos, __first, __last, _IterCategory());</span> -<span class="lineNum"> 1545 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1546 </span> : -<span class="lineNum"> 1547 </span> : // called by the second insert_dispatch above -<span class="lineNum"> 1548 </span> : template<typename _InputIterator> -<span class="lineNum"> 1549 </span> : void -<span class="lineNum"> 1550 </span> : _M_range_insert_aux(iterator __pos, _InputIterator __first, -<span class="lineNum"> 1551 </span> : _InputIterator __last, std::input_iterator_tag); -<span class="lineNum"> 1552 </span> : -<span class="lineNum"> 1553 </span> : // called by the second insert_dispatch above -<span class="lineNum"> 1554 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1555 </span> : void -<span class="lineNum"> 1556 </span> : _M_range_insert_aux(iterator __pos, _ForwardIterator __first, -<span class="lineNum"> 1557 </span> : _ForwardIterator __last, std::forward_iterator_tag); -<span class="lineNum"> 1558 </span> : -<span class="lineNum"> 1559 </span> : // Called by insert(p,n,x), and the range insert when it turns out to be -<span class="lineNum"> 1560 </span> : // the same thing. Can use fill functions in optimal situations, -<span class="lineNum"> 1561 </span> : // otherwise passes off to insert_aux(p,n,x). -<span class="lineNum"> 1562 </span> : void -<span class="lineNum"> 1563 </span> : _M_fill_insert(iterator __pos, size_type __n, const value_type& __x); -<span class="lineNum"> 1564 </span> : -<span class="lineNum"> 1565 </span> : // called by insert(p,x) -<span class="lineNum"> 1566 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1567 </span> : iterator -<span class="lineNum"> 1568 </span> : _M_insert_aux(iterator __pos, const value_type& __x); -<span class="lineNum"> 1569 </span> : #else -<span class="lineNum"> 1570 </span> : template<typename... _Args> -<span class="lineNum"> 1571 </span> : iterator -<span class="lineNum"> 1572 </span> : _M_insert_aux(iterator __pos, _Args&&... __args); -<span class="lineNum"> 1573 </span> : #endif -<span class="lineNum"> 1574 </span> : -<span class="lineNum"> 1575 </span> : // called by insert(p,n,x) via fill_insert -<span class="lineNum"> 1576 </span> : void -<span class="lineNum"> 1577 </span> : _M_insert_aux(iterator __pos, size_type __n, const value_type& __x); -<span class="lineNum"> 1578 </span> : -<span class="lineNum"> 1579 </span> : // called by range_insert_aux for forward iterators -<span class="lineNum"> 1580 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1581 </span> : void -<span class="lineNum"> 1582 </span> : _M_insert_aux(iterator __pos, -<span class="lineNum"> 1583 </span> : _ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 1584 </span> : size_type __n); -<span class="lineNum"> 1585 </span> : -<span class="lineNum"> 1586 </span> : -<span class="lineNum"> 1587 </span> : // Internal erase functions follow. -<span class="lineNum"> 1588 </span> : -<span class="lineNum"> 1589 </span> : void -<span class="lineNum"> 1590 </span> : _M_destroy_data_aux(iterator __first, iterator __last); -<span class="lineNum"> 1591 </span> : -<span class="lineNum"> 1592 </span> : // Called by ~deque(). -<span class="lineNum"> 1593 </span> : // NB: Doesn't deallocate the nodes. -<span class="lineNum"> 1594 </span> : template<typename _Alloc1> -<span class="lineNum"> 1595 </span> : void -<span class="lineNum"> 1596 </span> : _M_destroy_data(iterator __first, iterator __last, const _Alloc1&) -<span class="lineNum"> 1597 </span> : { _M_destroy_data_aux(__first, __last); } -<span class="lineNum"> 1598 </span> : -<span class="lineNum"> 1599 </span> : void -<span class="lineNum"> 1600 </span> : _M_destroy_data(iterator __first, iterator __last, -<span class="lineNum"> 1601 </span><span class="lineCov"> 1046 : const std::allocator<_Tp>&)</span> -<span class="lineNum"> 1602 </span> : { -<span class="lineNum"> 1603 </span> : if (!__has_trivial_destructor(value_type)) -<span class="lineNum"> 1604 </span><span class="lineCov"> 26 : _M_destroy_data_aux(__first, __last);</span> -<span class="lineNum"> 1605 </span><span class="lineCov"> 1046 : }</span> -<span class="lineNum"> 1606 </span> : -<span class="lineNum"> 1607 </span> : // Called by erase(q1, q2). -<span class="lineNum"> 1608 </span> : void -<span class="lineNum"> 1609 </span><span class="lineCov"> 90 : _M_erase_at_begin(iterator __pos)</span> -<span class="lineNum"> 1610 </span> : { -<span class="lineNum"> 1611 </span><span class="lineCov"> 90 : _M_destroy_data(begin(), __pos, _M_get_Tp_allocator());</span> -<span class="lineNum"> 1612 </span><span class="lineCov"> 90 : _M_destroy_nodes(this->_M_impl._M_start._M_node, __pos._M_node);</span> -<span class="lineNum"> 1613 </span><span class="lineCov"> 90 : this->_M_impl._M_start = __pos;</span> -<span class="lineNum"> 1614 </span><span class="lineCov"> 90 : }</span> -<span class="lineNum"> 1615 </span> : -<span class="lineNum"> 1616 </span> : // Called by erase(q1, q2), resize(), clear(), _M_assign_aux, -<span class="lineNum"> 1617 </span> : // _M_fill_assign, operator=. -<span class="lineNum"> 1618 </span> : void -<span class="lineNum"> 1619 </span><span class="lineCov"> 926 : _M_erase_at_end(iterator __pos)</span> -<span class="lineNum"> 1620 </span> : { -<span class="lineNum"> 1621 </span><span class="lineCov"> 926 : _M_destroy_data(__pos, end(), _M_get_Tp_allocator());</span> -<span class="lineNum"> 1622 </span><span class="lineCov"> 926 : _M_destroy_nodes(__pos._M_node + 1,</span> -<span class="lineNum"> 1623 </span> : this->_M_impl._M_finish._M_node + 1); -<span class="lineNum"> 1624 </span><span class="lineCov"> 926 : this->_M_impl._M_finish = __pos;</span> -<span class="lineNum"> 1625 </span><span class="lineCov"> 926 : }</span> -<span class="lineNum"> 1626 </span> : -<span class="lineNum"> 1627 </span> : //@{ -<span class="lineNum"> 1628 </span> : /// Memory-handling helpers for the previous internal insert functions. -<span class="lineNum"> 1629 </span> : iterator -<span class="lineNum"> 1630 </span><span class="lineNoCov"> 0 : _M_reserve_elements_at_front(size_type __n)</span> -<span class="lineNum"> 1631 </span> : { -<span class="lineNum"> 1632 </span> : const size_type __vacancies = this->_M_impl._M_start._M_cur -<span class="lineNum"> 1633 </span><span class="lineNoCov"> 0 : - this->_M_impl._M_start._M_first;</span> -<span class="lineNum"> 1634 </span><span class="lineNoCov"> 0 : if (__n > __vacancies)</span> -<span class="lineNum"> 1635 </span><span class="lineNoCov"> 0 : _M_new_elements_at_front(__n - __vacancies);</span> -<span class="lineNum"> 1636 </span><span class="lineNoCov"> 0 : return this->_M_impl._M_start - difference_type(__n);</span> -<span class="lineNum"> 1637 </span> : } -<span class="lineNum"> 1638 </span> : -<span class="lineNum"> 1639 </span> : iterator -<span class="lineNum"> 1640 </span><span class="lineNoCov"> 0 : _M_reserve_elements_at_back(size_type __n)</span> -<span class="lineNum"> 1641 </span> : { -<span class="lineNum"> 1642 </span> : const size_type __vacancies = (this->_M_impl._M_finish._M_last -<span class="lineNum"> 1643 </span><span class="lineNoCov"> 0 : - this->_M_impl._M_finish._M_cur) - 1;</span> -<span class="lineNum"> 1644 </span><span class="lineNoCov"> 0 : if (__n > __vacancies)</span> -<span class="lineNum"> 1645 </span><span class="lineNoCov"> 0 : _M_new_elements_at_back(__n - __vacancies);</span> -<span class="lineNum"> 1646 </span><span class="lineNoCov"> 0 : return this->_M_impl._M_finish + difference_type(__n);</span> -<span class="lineNum"> 1647 </span> : } -<span class="lineNum"> 1648 </span> : -<span class="lineNum"> 1649 </span> : void -<span class="lineNum"> 1650 </span> : _M_new_elements_at_front(size_type __new_elements); -<span class="lineNum"> 1651 </span> : -<span class="lineNum"> 1652 </span> : void -<span class="lineNum"> 1653 </span> : _M_new_elements_at_back(size_type __new_elements); -<span class="lineNum"> 1654 </span> : //@} -<span class="lineNum"> 1655 </span> : -<span class="lineNum"> 1656 </span> : -<span class="lineNum"> 1657 </span> : //@{ -<span class="lineNum"> 1658 </span> : /** -<span class="lineNum"> 1659 </span> : * @brief Memory-handling helpers for the major %map. -<span class="lineNum"> 1660 </span> : * -<span class="lineNum"> 1661 </span> : * Makes sure the _M_map has space for new nodes. Does not -<span class="lineNum"> 1662 </span> : * actually add the nodes. Can invalidate _M_map pointers. -<span class="lineNum"> 1663 </span> : * (And consequently, %deque iterators.) -<span class="lineNum"> 1664 </span> : */ -<span class="lineNum"> 1665 </span> : void -<span class="lineNum"> 1666 </span><span class="lineCov"> 13 : _M_reserve_map_at_back(size_type __nodes_to_add = 1)</span> -<span class="lineNum"> 1667 </span> : { -<span class="lineNum"> 1668 </span><span class="lineCov"> 13 : if (__nodes_to_add + 1 > this->_M_impl._M_map_size</span> -<span class="lineNum"> 1669 </span> : - (this->_M_impl._M_finish._M_node - this->_M_impl._M_map)) -<span class="lineNum"> 1670 </span><span class="lineNoCov"> 0 : _M_reallocate_map(__nodes_to_add, false);</span> -<span class="lineNum"> 1671 </span><span class="lineCov"> 13 : }</span> -<span class="lineNum"> 1672 </span> : -<span class="lineNum"> 1673 </span> : void -<span class="lineNum"> 1674 </span><span class="lineNoCov"> 0 : _M_reserve_map_at_front(size_type __nodes_to_add = 1)</span> -<span class="lineNum"> 1675 </span> : { -<span class="lineNum"> 1676 </span><span class="lineNoCov"> 0 : if (__nodes_to_add > size_type(this->_M_impl._M_start._M_node</span> -<span class="lineNum"> 1677 </span> : - this->_M_impl._M_map)) -<span class="lineNum"> 1678 </span><span class="lineNoCov"> 0 : _M_reallocate_map(__nodes_to_add, true);</span> -<span class="lineNum"> 1679 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1680 </span> : -<span class="lineNum"> 1681 </span> : void -<span class="lineNum"> 1682 </span> : _M_reallocate_map(size_type __nodes_to_add, bool __add_at_front); -<span class="lineNum"> 1683 </span> : //@} -<span class="lineNum"> 1684 </span> : }; -<span class="lineNum"> 1685 </span> : -<span class="lineNum"> 1686 </span> : -<span class="lineNum"> 1687 </span> : /** -<span class="lineNum"> 1688 </span> : * @brief Deque equality comparison. -<span class="lineNum"> 1689 </span> : * @param x A %deque. -<span class="lineNum"> 1690 </span> : * @param y A %deque of the same type as @a x. -<span class="lineNum"> 1691 </span> : * @return True iff the size and elements of the deques are equal. -<span class="lineNum"> 1692 </span> : * -<span class="lineNum"> 1693 </span> : * This is an equivalence relation. It is linear in the size of the -<span class="lineNum"> 1694 </span> : * deques. Deques are considered equivalent if their sizes are equal, -<span class="lineNum"> 1695 </span> : * and if corresponding elements compare equal. -<span class="lineNum"> 1696 </span> : */ -<span class="lineNum"> 1697 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1698 </span> : inline bool -<span class="lineNum"> 1699 </span> : operator==(const deque<_Tp, _Alloc>& __x, -<span class="lineNum"> 1700 </span> : const deque<_Tp, _Alloc>& __y) -<span class="lineNum"> 1701 </span> : { return __x.size() == __y.size() -<span class="lineNum"> 1702 </span> : && std::equal(__x.begin(), __x.end(), __y.begin()); } -<span class="lineNum"> 1703 </span> : -<span class="lineNum"> 1704 </span> : /** -<span class="lineNum"> 1705 </span> : * @brief Deque ordering relation. -<span class="lineNum"> 1706 </span> : * @param x A %deque. -<span class="lineNum"> 1707 </span> : * @param y A %deque of the same type as @a x. -<span class="lineNum"> 1708 </span> : * @return True iff @a x is lexicographically less than @a y. -<span class="lineNum"> 1709 </span> : * -<span class="lineNum"> 1710 </span> : * This is a total ordering relation. It is linear in the size of the -<span class="lineNum"> 1711 </span> : * deques. The elements must be comparable with @c <. -<span class="lineNum"> 1712 </span> : * -<span class="lineNum"> 1713 </span> : * See std::lexicographical_compare() for how the determination is made. -<span class="lineNum"> 1714 </span> : */ -<span class="lineNum"> 1715 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1716 </span> : inline bool -<span class="lineNum"> 1717 </span> : operator<(const deque<_Tp, _Alloc>& __x, -<span class="lineNum"> 1718 </span> : const deque<_Tp, _Alloc>& __y) -<span class="lineNum"> 1719 </span> : { return std::lexicographical_compare(__x.begin(), __x.end(), -<span class="lineNum"> 1720 </span> : __y.begin(), __y.end()); } -<span class="lineNum"> 1721 </span> : -<span class="lineNum"> 1722 </span> : /// Based on operator== -<span class="lineNum"> 1723 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1724 </span> : inline bool -<span class="lineNum"> 1725 </span> : operator!=(const deque<_Tp, _Alloc>& __x, -<span class="lineNum"> 1726 </span> : const deque<_Tp, _Alloc>& __y) -<span class="lineNum"> 1727 </span> : { return !(__x == __y); } -<span class="lineNum"> 1728 </span> : -<span class="lineNum"> 1729 </span> : /// Based on operator< -<span class="lineNum"> 1730 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1731 </span> : inline bool -<span class="lineNum"> 1732 </span> : operator>(const deque<_Tp, _Alloc>& __x, -<span class="lineNum"> 1733 </span> : const deque<_Tp, _Alloc>& __y) -<span class="lineNum"> 1734 </span> : { return __y < __x; } -<span class="lineNum"> 1735 </span> : -<span class="lineNum"> 1736 </span> : /// Based on operator< -<span class="lineNum"> 1737 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1738 </span> : inline bool -<span class="lineNum"> 1739 </span> : operator<=(const deque<_Tp, _Alloc>& __x, -<span class="lineNum"> 1740 </span> : const deque<_Tp, _Alloc>& __y) -<span class="lineNum"> 1741 </span> : { return !(__y < __x); } -<span class="lineNum"> 1742 </span> : -<span class="lineNum"> 1743 </span> : /// Based on operator< -<span class="lineNum"> 1744 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1745 </span> : inline bool -<span class="lineNum"> 1746 </span> : operator>=(const deque<_Tp, _Alloc>& __x, -<span class="lineNum"> 1747 </span> : const deque<_Tp, _Alloc>& __y) -<span class="lineNum"> 1748 </span> : { return !(__x < __y); } -<span class="lineNum"> 1749 </span> : -<span class="lineNum"> 1750 </span> : /// See std::deque::swap(). -<span class="lineNum"> 1751 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1752 </span> : inline void -<span class="lineNum"> 1753 </span> : swap(deque<_Tp,_Alloc>& __x, deque<_Tp,_Alloc>& __y) -<span class="lineNum"> 1754 </span> : { __x.swap(__y); } -<span class="lineNum"> 1755 </span> : -<span class="lineNum"> 1756 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1757 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1758 </span> : inline void -<span class="lineNum"> 1759 </span> : swap(deque<_Tp,_Alloc>&& __x, deque<_Tp,_Alloc>& __y) -<span class="lineNum"> 1760 </span> : { __x.swap(__y); } -<span class="lineNum"> 1761 </span> : -<span class="lineNum"> 1762 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1763 </span> : inline void -<span class="lineNum"> 1764 </span> : swap(deque<_Tp,_Alloc>& __x, deque<_Tp,_Alloc>&& __y) -<span class="lineNum"> 1765 </span> : { __x.swap(__y); } -<span class="lineNum"> 1766 </span> : #endif -<span class="lineNum"> 1767 </span> : -<span class="lineNum"> 1768 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 1769 </span> : -<span class="lineNum"> 1770 </span> : #endif /* _STL_DEQUE_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_function.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_function.h.gcov.html deleted file mode 100644 index 7615b65..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_function.h.gcov.html +++ /dev/null @@ -1,774 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_function.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_function.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">17</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">17</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Functor implementations -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996-1998 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_function.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_FUNCTION_H -<span class="lineNum"> 63 </span> : #define _STL_FUNCTION_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : // 20.3.1 base classes -<span class="lineNum"> 68 </span> : /** @defgroup s20_3_1_base Functor Base Classes -<span class="lineNum"> 69 </span> : * Function objects, or @e functors, are objects with an @c operator() -<span class="lineNum"> 70 </span> : * defined and accessible. They can be passed as arguments to algorithm -<span class="lineNum"> 71 </span> : * templates and used in place of a function pointer. Not only is the -<span class="lineNum"> 72 </span> : * resulting expressiveness of the library increased, but the generated -<span class="lineNum"> 73 </span> : * code can be more efficient than what you might write by hand. When we -<span class="lineNum"> 74 </span> : * refer to "functors," then, generally we include function pointers in -<span class="lineNum"> 75 </span> : * the description as well. -<span class="lineNum"> 76 </span> : * -<span class="lineNum"> 77 </span> : * Often, functors are only created as temporaries passed to algorithm -<span class="lineNum"> 78 </span> : * calls, rather than being created as named variables. -<span class="lineNum"> 79 </span> : * -<span class="lineNum"> 80 </span> : * Two examples taken from the standard itself follow. To perform a -<span class="lineNum"> 81 </span> : * by-element addition of two vectors @c a and @c b containing @c double, -<span class="lineNum"> 82 </span> : * and put the result in @c a, use -<span class="lineNum"> 83 </span> : * \code -<span class="lineNum"> 84 </span> : * transform (a.begin(), a.end(), b.begin(), a.begin(), plus<double>()); -<span class="lineNum"> 85 </span> : * \endcode -<span class="lineNum"> 86 </span> : * To negate every element in @c a, use -<span class="lineNum"> 87 </span> : * \code -<span class="lineNum"> 88 </span> : * transform(a.begin(), a.end(), a.begin(), negate<double>()); -<span class="lineNum"> 89 </span> : * \endcode -<span class="lineNum"> 90 </span> : * The addition and negation functions will be inlined directly. -<span class="lineNum"> 91 </span> : * -<span class="lineNum"> 92 </span> : * The standard functors are derived from structs named @c unary_function -<span class="lineNum"> 93 </span> : * and @c binary_function. These two classes contain nothing but typedefs, -<span class="lineNum"> 94 </span> : * to aid in generic (template) programming. If you write your own -<span class="lineNum"> 95 </span> : * functors, you might consider doing the same. -<span class="lineNum"> 96 </span> : * -<span class="lineNum"> 97 </span> : * @{ -<span class="lineNum"> 98 </span> : */ -<span class="lineNum"> 99 </span> : /** -<span class="lineNum"> 100 </span> : * This is one of the @link s20_3_1_base functor base classes@endlink. -<span class="lineNum"> 101 </span> : */ -<span class="lineNum"> 102 </span> : template<typename _Arg, typename _Result> -<span class="lineNum"> 103 </span> : struct unary_function -<span class="lineNum"> 104 </span><span class="lineCov"> 21 : {</span> -<span class="lineNum"> 105 </span> : typedef _Arg argument_type; ///< @c argument_type is the type of the -<span class="lineNum"> 106 </span> : /// argument (no surprises here) -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : typedef _Result result_type; ///< @c result_type is the return type -<span class="lineNum"> 109 </span> : }; -<span class="lineNum"> 110 </span> : -<span class="lineNum"> 111 </span> : /** -<span class="lineNum"> 112 </span> : * This is one of the @link s20_3_1_base functor base classes@endlink. -<span class="lineNum"> 113 </span> : */ -<span class="lineNum"> 114 </span> : template<typename _Arg1, typename _Arg2, typename _Result> -<span class="lineNum"> 115 </span> : struct binary_function -<span class="lineNum"> 116 </span> : { -<span class="lineNum"> 117 </span> : typedef _Arg1 first_argument_type; ///< the type of the first argument -<span class="lineNum"> 118 </span> : /// (no surprises here) -<span class="lineNum"> 119 </span> : -<span class="lineNum"> 120 </span> : typedef _Arg2 second_argument_type; ///< the type of the second argument -<span class="lineNum"> 121 </span> : typedef _Result result_type; ///< type of the return type -<span class="lineNum"> 122 </span> : }; -<span class="lineNum"> 123 </span> : /** @} */ -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : // 20.3.2 arithmetic -<span class="lineNum"> 126 </span> : /** @defgroup s20_3_2_arithmetic Arithmetic Classes -<span class="lineNum"> 127 </span> : -<span class="lineNum"> 128 </span> : * Because basic math often needs to be done during an algorithm, -<span class="lineNum"> 129 </span> : * the library provides functors for those operations. See the -<span class="lineNum"> 130 </span> : * documentation for @link s20_3_1_base the base classes@endlink -<span class="lineNum"> 131 </span> : * for examples of their use. -<span class="lineNum"> 132 </span> : * -<span class="lineNum"> 133 </span> : * @{ -<span class="lineNum"> 134 </span> : */ -<span class="lineNum"> 135 </span> : /// One of the @link s20_3_2_arithmetic math functors@endlink. -<span class="lineNum"> 136 </span> : template<typename _Tp> -<span class="lineNum"> 137 </span> : struct plus : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 138 </span> : { -<span class="lineNum"> 139 </span> : _Tp -<span class="lineNum"> 140 </span><span class="lineCov"> 4 : operator()(const _Tp& __x, const _Tp& __y) const</span> -<span class="lineNum"> 141 </span><span class="lineCov"> 4 : { return __x + __y; }</span> -<span class="lineNum"> 142 </span> : }; -<span class="lineNum"> 143 </span> : -<span class="lineNum"> 144 </span> : /// One of the @link s20_3_2_arithmetic math functors@endlink. -<span class="lineNum"> 145 </span> : template<typename _Tp> -<span class="lineNum"> 146 </span> : struct minus : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 147 </span> : { -<span class="lineNum"> 148 </span> : _Tp -<span class="lineNum"> 149 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 150 </span> : { return __x - __y; } -<span class="lineNum"> 151 </span> : }; -<span class="lineNum"> 152 </span> : -<span class="lineNum"> 153 </span> : /// One of the @link s20_3_2_arithmetic math functors@endlink. -<span class="lineNum"> 154 </span> : template<typename _Tp> -<span class="lineNum"> 155 </span> : struct multiplies : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 156 </span> : { -<span class="lineNum"> 157 </span> : _Tp -<span class="lineNum"> 158 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 159 </span> : { return __x * __y; } -<span class="lineNum"> 160 </span> : }; -<span class="lineNum"> 161 </span> : -<span class="lineNum"> 162 </span> : /// One of the @link s20_3_2_arithmetic math functors@endlink. -<span class="lineNum"> 163 </span> : template<typename _Tp> -<span class="lineNum"> 164 </span> : struct divides : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 165 </span> : { -<span class="lineNum"> 166 </span> : _Tp -<span class="lineNum"> 167 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 168 </span> : { return __x / __y; } -<span class="lineNum"> 169 </span> : }; -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : /// One of the @link s20_3_2_arithmetic math functors@endlink. -<span class="lineNum"> 172 </span> : template<typename _Tp> -<span class="lineNum"> 173 </span> : struct modulus : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 174 </span> : { -<span class="lineNum"> 175 </span> : _Tp -<span class="lineNum"> 176 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 177 </span> : { return __x % __y; } -<span class="lineNum"> 178 </span> : }; -<span class="lineNum"> 179 </span> : -<span class="lineNum"> 180 </span> : /// One of the @link s20_3_2_arithmetic math functors@endlink. -<span class="lineNum"> 181 </span> : template<typename _Tp> -<span class="lineNum"> 182 </span> : struct negate : public unary_function<_Tp, _Tp> -<span class="lineNum"> 183 </span> : { -<span class="lineNum"> 184 </span> : _Tp -<span class="lineNum"> 185 </span> : operator()(const _Tp& __x) const -<span class="lineNum"> 186 </span> : { return -__x; } -<span class="lineNum"> 187 </span> : }; -<span class="lineNum"> 188 </span> : /** @} */ -<span class="lineNum"> 189 </span> : -<span class="lineNum"> 190 </span> : // 20.3.3 comparisons -<span class="lineNum"> 191 </span> : /** @defgroup s20_3_3_comparisons Comparison Classes -<span class="lineNum"> 192 </span> : * The library provides six wrapper functors for all the basic comparisons -<span class="lineNum"> 193 </span> : * in C++, like @c <. -<span class="lineNum"> 194 </span> : * -<span class="lineNum"> 195 </span> : * @{ -<span class="lineNum"> 196 </span> : */ -<span class="lineNum"> 197 </span> : /// One of the @link s20_3_3_comparisons comparison functors@endlink. -<span class="lineNum"> 198 </span> : template<typename _Tp> -<span class="lineNum"> 199 </span> : struct equal_to : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 200 </span> : { -<span class="lineNum"> 201 </span> : bool -<span class="lineNum"> 202 </span><span class="lineCov"> 66 : operator()(const _Tp& __x, const _Tp& __y) const</span> -<span class="lineNum"> 203 </span><span class="lineCov"> 66 : { return __x == __y; }</span> -<span class="lineNum"> 204 </span> : }; -<span class="lineNum"> 205 </span> : -<span class="lineNum"> 206 </span> : /// One of the @link s20_3_3_comparisons comparison functors@endlink. -<span class="lineNum"> 207 </span> : template<typename _Tp> -<span class="lineNum"> 208 </span> : struct not_equal_to : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 209 </span> : { -<span class="lineNum"> 210 </span> : bool -<span class="lineNum"> 211 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 212 </span> : { return __x != __y; } -<span class="lineNum"> 213 </span> : }; -<span class="lineNum"> 214 </span> : -<span class="lineNum"> 215 </span> : /// One of the @link s20_3_3_comparisons comparison functors@endlink. -<span class="lineNum"> 216 </span> : template<typename _Tp> -<span class="lineNum"> 217 </span> : struct greater : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 218 </span> : { -<span class="lineNum"> 219 </span> : bool -<span class="lineNum"> 220 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 221 </span> : { return __x > __y; } -<span class="lineNum"> 222 </span> : }; -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : /// One of the @link s20_3_3_comparisons comparison functors@endlink. -<span class="lineNum"> 225 </span> : template<typename _Tp> -<span class="lineNum"> 226 </span> : struct less : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 227 </span> : { -<span class="lineNum"> 228 </span> : bool -<span class="lineNum"> 229 </span><span class="lineCov"> 10727242 : operator()(const _Tp& __x, const _Tp& __y) const</span> -<span class="lineNum"> 230 </span><span class="lineCov"> 10727242 : { return __x < __y; }</span> -<span class="lineNum"> 231 </span> : }; -<span class="lineNum"> 232 </span> : -<span class="lineNum"> 233 </span> : /// One of the @link s20_3_3_comparisons comparison functors@endlink. -<span class="lineNum"> 234 </span> : template<typename _Tp> -<span class="lineNum"> 235 </span> : struct greater_equal : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 236 </span> : { -<span class="lineNum"> 237 </span> : bool -<span class="lineNum"> 238 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 239 </span> : { return __x >= __y; } -<span class="lineNum"> 240 </span> : }; -<span class="lineNum"> 241 </span> : -<span class="lineNum"> 242 </span> : /// One of the @link s20_3_3_comparisons comparison functors@endlink. -<span class="lineNum"> 243 </span> : template<typename _Tp> -<span class="lineNum"> 244 </span> : struct less_equal : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 245 </span> : { -<span class="lineNum"> 246 </span> : bool -<span class="lineNum"> 247 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 248 </span> : { return __x <= __y; } -<span class="lineNum"> 249 </span> : }; -<span class="lineNum"> 250 </span> : /** @} */ -<span class="lineNum"> 251 </span> : -<span class="lineNum"> 252 </span> : // 20.3.4 logical operations -<span class="lineNum"> 253 </span> : /** @defgroup s20_3_4_logical Boolean Operations Classes -<span class="lineNum"> 254 </span> : * Here are wrapper functors for Boolean operations: @c &&, @c ||, -<span class="lineNum"> 255 </span> : * and @c !. -<span class="lineNum"> 256 </span> : * -<span class="lineNum"> 257 </span> : * @{ -<span class="lineNum"> 258 </span> : */ -<span class="lineNum"> 259 </span> : /// One of the @link s20_3_4_logical Boolean operations functors@endlink. -<span class="lineNum"> 260 </span> : template<typename _Tp> -<span class="lineNum"> 261 </span> : struct logical_and : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 262 </span> : { -<span class="lineNum"> 263 </span> : bool -<span class="lineNum"> 264 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 265 </span> : { return __x && __y; } -<span class="lineNum"> 266 </span> : }; -<span class="lineNum"> 267 </span> : -<span class="lineNum"> 268 </span> : /// One of the @link s20_3_4_logical Boolean operations functors@endlink. -<span class="lineNum"> 269 </span> : template<typename _Tp> -<span class="lineNum"> 270 </span> : struct logical_or : public binary_function<_Tp, _Tp, bool> -<span class="lineNum"> 271 </span> : { -<span class="lineNum"> 272 </span> : bool -<span class="lineNum"> 273 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 274 </span> : { return __x || __y; } -<span class="lineNum"> 275 </span> : }; -<span class="lineNum"> 276 </span> : -<span class="lineNum"> 277 </span> : /// One of the @link s20_3_4_logical Boolean operations functors@endlink. -<span class="lineNum"> 278 </span> : template<typename _Tp> -<span class="lineNum"> 279 </span> : struct logical_not : public unary_function<_Tp, bool> -<span class="lineNum"> 280 </span> : { -<span class="lineNum"> 281 </span> : bool -<span class="lineNum"> 282 </span> : operator()(const _Tp& __x) const -<span class="lineNum"> 283 </span> : { return !__x; } -<span class="lineNum"> 284 </span> : }; -<span class="lineNum"> 285 </span> : /** @} */ -<span class="lineNum"> 286 </span> : -<span class="lineNum"> 287 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 288 </span> : // DR 660. Missing Bitwise Operations. -<span class="lineNum"> 289 </span> : template<typename _Tp> -<span class="lineNum"> 290 </span> : struct bit_and : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 291 </span> : { -<span class="lineNum"> 292 </span> : _Tp -<span class="lineNum"> 293 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 294 </span> : { return __x & __y; } -<span class="lineNum"> 295 </span> : }; -<span class="lineNum"> 296 </span> : -<span class="lineNum"> 297 </span> : template<typename _Tp> -<span class="lineNum"> 298 </span> : struct bit_or : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 299 </span> : { -<span class="lineNum"> 300 </span> : _Tp -<span class="lineNum"> 301 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 302 </span> : { return __x | __y; } -<span class="lineNum"> 303 </span> : }; -<span class="lineNum"> 304 </span> : -<span class="lineNum"> 305 </span> : template<typename _Tp> -<span class="lineNum"> 306 </span> : struct bit_xor : public binary_function<_Tp, _Tp, _Tp> -<span class="lineNum"> 307 </span> : { -<span class="lineNum"> 308 </span> : _Tp -<span class="lineNum"> 309 </span> : operator()(const _Tp& __x, const _Tp& __y) const -<span class="lineNum"> 310 </span> : { return __x ^ __y; } -<span class="lineNum"> 311 </span> : }; -<span class="lineNum"> 312 </span> : -<span class="lineNum"> 313 </span> : // 20.3.5 negators -<span class="lineNum"> 314 </span> : /** @defgroup s20_3_5_negators Negators -<span class="lineNum"> 315 </span> : * The functions @c not1 and @c not2 each take a predicate functor -<span class="lineNum"> 316 </span> : * and return an instance of @c unary_negate or -<span class="lineNum"> 317 </span> : * @c binary_negate, respectively. These classes are functors whose -<span class="lineNum"> 318 </span> : * @c operator() performs the stored predicate function and then returns -<span class="lineNum"> 319 </span> : * the negation of the result. -<span class="lineNum"> 320 </span> : * -<span class="lineNum"> 321 </span> : * For example, given a vector of integers and a trivial predicate, -<span class="lineNum"> 322 </span> : * \code -<span class="lineNum"> 323 </span> : * struct IntGreaterThanThree -<span class="lineNum"> 324 </span> : * : public std::unary_function<int, bool> -<span class="lineNum"> 325 </span> : * { -<span class="lineNum"> 326 </span> : * bool operator() (int x) { return x > 3; } -<span class="lineNum"> 327 </span> : * }; -<span class="lineNum"> 328 </span> : * -<span class="lineNum"> 329 </span> : * std::find_if (v.begin(), v.end(), not1(IntGreaterThanThree())); -<span class="lineNum"> 330 </span> : * \endcode -<span class="lineNum"> 331 </span> : * The call to @c find_if will locate the first index (i) of @c v for which -<span class="lineNum"> 332 </span> : * "!(v[i] > 3)" is true. -<span class="lineNum"> 333 </span> : * -<span class="lineNum"> 334 </span> : * The not1/unary_negate combination works on predicates taking a single -<span class="lineNum"> 335 </span> : * argument. The not2/binary_negate combination works on predicates which -<span class="lineNum"> 336 </span> : * take two arguments. -<span class="lineNum"> 337 </span> : * -<span class="lineNum"> 338 </span> : * @{ -<span class="lineNum"> 339 </span> : */ -<span class="lineNum"> 340 </span> : /// One of the @link s20_3_5_negators negation functors@endlink. -<span class="lineNum"> 341 </span> : template<typename _Predicate> -<span class="lineNum"> 342 </span> : class unary_negate -<span class="lineNum"> 343 </span> : : public unary_function<typename _Predicate::argument_type, bool> -<span class="lineNum"> 344 </span> : { -<span class="lineNum"> 345 </span> : protected: -<span class="lineNum"> 346 </span> : _Predicate _M_pred; -<span class="lineNum"> 347 </span> : -<span class="lineNum"> 348 </span> : public: -<span class="lineNum"> 349 </span> : explicit -<span class="lineNum"> 350 </span> : unary_negate(const _Predicate& __x) : _M_pred(__x) { } -<span class="lineNum"> 351 </span> : -<span class="lineNum"> 352 </span> : bool -<span class="lineNum"> 353 </span> : operator()(const typename _Predicate::argument_type& __x) const -<span class="lineNum"> 354 </span> : { return !_M_pred(__x); } -<span class="lineNum"> 355 </span> : }; -<span class="lineNum"> 356 </span> : -<span class="lineNum"> 357 </span> : /// One of the @link s20_3_5_negators negation functors@endlink. -<span class="lineNum"> 358 </span> : template<typename _Predicate> -<span class="lineNum"> 359 </span> : inline unary_negate<_Predicate> -<span class="lineNum"> 360 </span> : not1(const _Predicate& __pred) -<span class="lineNum"> 361 </span> : { return unary_negate<_Predicate>(__pred); } -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : /// One of the @link s20_3_5_negators negation functors@endlink. -<span class="lineNum"> 364 </span> : template<typename _Predicate> -<span class="lineNum"> 365 </span> : class binary_negate -<span class="lineNum"> 366 </span> : : public binary_function<typename _Predicate::first_argument_type, -<span class="lineNum"> 367 </span> : typename _Predicate::second_argument_type, bool> -<span class="lineNum"> 368 </span> : { -<span class="lineNum"> 369 </span> : protected: -<span class="lineNum"> 370 </span> : _Predicate _M_pred; -<span class="lineNum"> 371 </span> : -<span class="lineNum"> 372 </span> : public: -<span class="lineNum"> 373 </span> : explicit -<span class="lineNum"> 374 </span> : binary_negate(const _Predicate& __x) : _M_pred(__x) { } -<span class="lineNum"> 375 </span> : -<span class="lineNum"> 376 </span> : bool -<span class="lineNum"> 377 </span> : operator()(const typename _Predicate::first_argument_type& __x, -<span class="lineNum"> 378 </span> : const typename _Predicate::second_argument_type& __y) const -<span class="lineNum"> 379 </span> : { return !_M_pred(__x, __y); } -<span class="lineNum"> 380 </span> : }; -<span class="lineNum"> 381 </span> : -<span class="lineNum"> 382 </span> : /// One of the @link s20_3_5_negators negation functors@endlink. -<span class="lineNum"> 383 </span> : template<typename _Predicate> -<span class="lineNum"> 384 </span> : inline binary_negate<_Predicate> -<span class="lineNum"> 385 </span> : not2(const _Predicate& __pred) -<span class="lineNum"> 386 </span> : { return binary_negate<_Predicate>(__pred); } -<span class="lineNum"> 387 </span> : /** @} */ -<span class="lineNum"> 388 </span> : -<span class="lineNum"> 389 </span> : // 20.3.7 adaptors pointers functions -<span class="lineNum"> 390 </span> : /** @defgroup s20_3_7_adaptors Adaptors for pointers to functions -<span class="lineNum"> 391 </span> : * The advantage of function objects over pointers to functions is that -<span class="lineNum"> 392 </span> : * the objects in the standard library declare nested typedefs describing -<span class="lineNum"> 393 </span> : * their argument and result types with uniform names (e.g., @c result_type -<span class="lineNum"> 394 </span> : * from the base classes @c unary_function and @c binary_function). -<span class="lineNum"> 395 </span> : * Sometimes those typedefs are required, not just optional. -<span class="lineNum"> 396 </span> : * -<span class="lineNum"> 397 </span> : * Adaptors are provided to turn pointers to unary (single-argument) and -<span class="lineNum"> 398 </span> : * binary (double-argument) functions into function objects. The -<span class="lineNum"> 399 </span> : * long-winded functor @c pointer_to_unary_function is constructed with a -<span class="lineNum"> 400 </span> : * function pointer @c f, and its @c operator() called with argument @c x -<span class="lineNum"> 401 </span> : * returns @c f(x). The functor @c pointer_to_binary_function does the same -<span class="lineNum"> 402 </span> : * thing, but with a double-argument @c f and @c operator(). -<span class="lineNum"> 403 </span> : * -<span class="lineNum"> 404 </span> : * The function @c ptr_fun takes a pointer-to-function @c f and constructs -<span class="lineNum"> 405 </span> : * an instance of the appropriate functor. -<span class="lineNum"> 406 </span> : * -<span class="lineNum"> 407 </span> : * @{ -<span class="lineNum"> 408 </span> : */ -<span class="lineNum"> 409 </span> : /// One of the @link s20_3_7_adaptors adaptors for function pointers@endlink. -<span class="lineNum"> 410 </span> : template<typename _Arg, typename _Result> -<span class="lineNum"> 411 </span> : class pointer_to_unary_function : public unary_function<_Arg, _Result> -<span class="lineNum"> 412 </span> : { -<span class="lineNum"> 413 </span> : protected: -<span class="lineNum"> 414 </span> : _Result (*_M_ptr)(_Arg); -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span> : public: -<span class="lineNum"> 417 </span> : pointer_to_unary_function() { } -<span class="lineNum"> 418 </span> : -<span class="lineNum"> 419 </span> : explicit -<span class="lineNum"> 420 </span><span class="lineCov"> 2 : pointer_to_unary_function(_Result (*__x)(_Arg))</span> -<span class="lineNum"> 421 </span><span class="lineCov"> 2 : : _M_ptr(__x) { }</span> -<span class="lineNum"> 422 </span> : -<span class="lineNum"> 423 </span> : _Result -<span class="lineNum"> 424 </span><span class="lineCov"> 516 : operator()(_Arg __x) const</span> -<span class="lineNum"> 425 </span><span class="lineCov"> 516 : { return _M_ptr(__x); }</span> -<span class="lineNum"> 426 </span> : }; -<span class="lineNum"> 427 </span> : -<span class="lineNum"> 428 </span> : /// One of the @link s20_3_7_adaptors adaptors for function pointers@endlink. -<span class="lineNum"> 429 </span> : template<typename _Arg, typename _Result> -<span class="lineNum"> 430 </span> : inline pointer_to_unary_function<_Arg, _Result> -<span class="lineNum"> 431 </span><span class="lineCov"> 2 : ptr_fun(_Result (*__x)(_Arg))</span> -<span class="lineNum"> 432 </span><span class="lineCov"> 2 : { return pointer_to_unary_function<_Arg, _Result>(__x); }</span> -<span class="lineNum"> 433 </span> : -<span class="lineNum"> 434 </span> : /// One of the @link s20_3_7_adaptors adaptors for function pointers@endlink. -<span class="lineNum"> 435 </span> : template<typename _Arg1, typename _Arg2, typename _Result> -<span class="lineNum"> 436 </span> : class pointer_to_binary_function -<span class="lineNum"> 437 </span> : : public binary_function<_Arg1, _Arg2, _Result> -<span class="lineNum"> 438 </span> : { -<span class="lineNum"> 439 </span> : protected: -<span class="lineNum"> 440 </span> : _Result (*_M_ptr)(_Arg1, _Arg2); -<span class="lineNum"> 441 </span> : -<span class="lineNum"> 442 </span> : public: -<span class="lineNum"> 443 </span> : pointer_to_binary_function() { } -<span class="lineNum"> 444 </span> : -<span class="lineNum"> 445 </span> : explicit -<span class="lineNum"> 446 </span> : pointer_to_binary_function(_Result (*__x)(_Arg1, _Arg2)) -<span class="lineNum"> 447 </span> : : _M_ptr(__x) { } -<span class="lineNum"> 448 </span> : -<span class="lineNum"> 449 </span> : _Result -<span class="lineNum"> 450 </span> : operator()(_Arg1 __x, _Arg2 __y) const -<span class="lineNum"> 451 </span> : { return _M_ptr(__x, __y); } -<span class="lineNum"> 452 </span> : }; -<span class="lineNum"> 453 </span> : -<span class="lineNum"> 454 </span> : /// One of the @link s20_3_7_adaptors adaptors for function pointers@endlink. -<span class="lineNum"> 455 </span> : template<typename _Arg1, typename _Arg2, typename _Result> -<span class="lineNum"> 456 </span> : inline pointer_to_binary_function<_Arg1, _Arg2, _Result> -<span class="lineNum"> 457 </span> : ptr_fun(_Result (*__x)(_Arg1, _Arg2)) -<span class="lineNum"> 458 </span> : { return pointer_to_binary_function<_Arg1, _Arg2, _Result>(__x); } -<span class="lineNum"> 459 </span> : /** @} */ -<span class="lineNum"> 460 </span> : -<span class="lineNum"> 461 </span> : template<typename _Tp> -<span class="lineNum"> 462 </span> : struct _Identity : public unary_function<_Tp,_Tp> -<span class="lineNum"> 463 </span> : { -<span class="lineNum"> 464 </span> : _Tp& -<span class="lineNum"> 465 </span> : operator()(_Tp& __x) const -<span class="lineNum"> 466 </span> : { return __x; } -<span class="lineNum"> 467 </span> : -<span class="lineNum"> 468 </span> : const _Tp& -<span class="lineNum"> 469 </span><span class="lineCov"> 16055496 : operator()(const _Tp& __x) const</span> -<span class="lineNum"> 470 </span><span class="lineCov"> 16055496 : { return __x; }</span> -<span class="lineNum"> 471 </span> : }; -<span class="lineNum"> 472 </span> : -<span class="lineNum"> 473 </span> : template<typename _Pair> -<span class="lineNum"> 474 </span> : struct _Select1st : public unary_function<_Pair, -<span class="lineNum"> 475 </span> : typename _Pair::first_type> -<span class="lineNum"> 476 </span> : { -<span class="lineNum"> 477 </span> : typename _Pair::first_type& -<span class="lineNum"> 478 </span> : operator()(_Pair& __x) const -<span class="lineNum"> 479 </span> : { return __x.first; } -<span class="lineNum"> 480 </span> : -<span class="lineNum"> 481 </span> : const typename _Pair::first_type& -<span class="lineNum"> 482 </span><span class="lineCov"> 4509167 : operator()(const _Pair& __x) const</span> -<span class="lineNum"> 483 </span><span class="lineCov"> 4509167 : { return __x.first; }</span> -<span class="lineNum"> 484 </span> : }; -<span class="lineNum"> 485 </span> : -<span class="lineNum"> 486 </span> : template<typename _Pair> -<span class="lineNum"> 487 </span> : struct _Select2nd : public unary_function<_Pair, -<span class="lineNum"> 488 </span> : typename _Pair::second_type> -<span class="lineNum"> 489 </span> : { -<span class="lineNum"> 490 </span> : typename _Pair::second_type& -<span class="lineNum"> 491 </span> : operator()(_Pair& __x) const -<span class="lineNum"> 492 </span> : { return __x.second; } -<span class="lineNum"> 493 </span> : -<span class="lineNum"> 494 </span> : const typename _Pair::second_type& -<span class="lineNum"> 495 </span> : operator()(const _Pair& __x) const -<span class="lineNum"> 496 </span> : { return __x.second; } -<span class="lineNum"> 497 </span> : }; -<span class="lineNum"> 498 </span> : -<span class="lineNum"> 499 </span> : // 20.3.8 adaptors pointers members -<span class="lineNum"> 500 </span> : /** @defgroup s20_3_8_memadaptors Adaptors for pointers to members -<span class="lineNum"> 501 </span> : * There are a total of 8 = 2^3 function objects in this family. -<span class="lineNum"> 502 </span> : * (1) Member functions taking no arguments vs member functions taking -<span class="lineNum"> 503 </span> : * one argument. -<span class="lineNum"> 504 </span> : * (2) Call through pointer vs call through reference. -<span class="lineNum"> 505 </span> : * (3) Const vs non-const member function. -<span class="lineNum"> 506 </span> : * -<span class="lineNum"> 507 </span> : * All of this complexity is in the function objects themselves. You can -<span class="lineNum"> 508 </span> : * ignore it by using the helper function mem_fun and mem_fun_ref, -<span class="lineNum"> 509 </span> : * which create whichever type of adaptor is appropriate. -<span class="lineNum"> 510 </span> : * -<span class="lineNum"> 511 </span> : * @{ -<span class="lineNum"> 512 </span> : */ -<span class="lineNum"> 513 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 514 </span> : /// pointers@endlink. -<span class="lineNum"> 515 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 516 </span> : class mem_fun_t : public unary_function<_Tp*, _Ret> -<span class="lineNum"> 517 </span> : { -<span class="lineNum"> 518 </span> : public: -<span class="lineNum"> 519 </span> : explicit -<span class="lineNum"> 520 </span> : mem_fun_t(_Ret (_Tp::*__pf)()) -<span class="lineNum"> 521 </span> : : _M_f(__pf) { } -<span class="lineNum"> 522 </span> : -<span class="lineNum"> 523 </span> : _Ret -<span class="lineNum"> 524 </span> : operator()(_Tp* __p) const -<span class="lineNum"> 525 </span> : { return (__p->*_M_f)(); } -<span class="lineNum"> 526 </span> : -<span class="lineNum"> 527 </span> : private: -<span class="lineNum"> 528 </span> : _Ret (_Tp::*_M_f)(); -<span class="lineNum"> 529 </span> : }; -<span class="lineNum"> 530 </span> : -<span class="lineNum"> 531 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 532 </span> : /// pointers@endlink. -<span class="lineNum"> 533 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 534 </span> : class const_mem_fun_t : public unary_function<const _Tp*, _Ret> -<span class="lineNum"> 535 </span> : { -<span class="lineNum"> 536 </span> : public: -<span class="lineNum"> 537 </span> : explicit -<span class="lineNum"> 538 </span> : const_mem_fun_t(_Ret (_Tp::*__pf)() const) -<span class="lineNum"> 539 </span> : : _M_f(__pf) { } -<span class="lineNum"> 540 </span> : -<span class="lineNum"> 541 </span> : _Ret -<span class="lineNum"> 542 </span> : operator()(const _Tp* __p) const -<span class="lineNum"> 543 </span> : { return (__p->*_M_f)(); } -<span class="lineNum"> 544 </span> : -<span class="lineNum"> 545 </span> : private: -<span class="lineNum"> 546 </span> : _Ret (_Tp::*_M_f)() const; -<span class="lineNum"> 547 </span> : }; -<span class="lineNum"> 548 </span> : -<span class="lineNum"> 549 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 550 </span> : /// pointers@endlink. -<span class="lineNum"> 551 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 552 </span> : class mem_fun_ref_t : public unary_function<_Tp, _Ret> -<span class="lineNum"> 553 </span> : { -<span class="lineNum"> 554 </span> : public: -<span class="lineNum"> 555 </span> : explicit -<span class="lineNum"> 556 </span> : mem_fun_ref_t(_Ret (_Tp::*__pf)()) -<span class="lineNum"> 557 </span> : : _M_f(__pf) { } -<span class="lineNum"> 558 </span> : -<span class="lineNum"> 559 </span> : _Ret -<span class="lineNum"> 560 </span> : operator()(_Tp& __r) const -<span class="lineNum"> 561 </span> : { return (__r.*_M_f)(); } -<span class="lineNum"> 562 </span> : -<span class="lineNum"> 563 </span> : private: -<span class="lineNum"> 564 </span> : _Ret (_Tp::*_M_f)(); -<span class="lineNum"> 565 </span> : }; -<span class="lineNum"> 566 </span> : -<span class="lineNum"> 567 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 568 </span> : /// pointers@endlink. -<span class="lineNum"> 569 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 570 </span> : class const_mem_fun_ref_t : public unary_function<_Tp, _Ret> -<span class="lineNum"> 571 </span> : { -<span class="lineNum"> 572 </span> : public: -<span class="lineNum"> 573 </span> : explicit -<span class="lineNum"> 574 </span> : const_mem_fun_ref_t(_Ret (_Tp::*__pf)() const) -<span class="lineNum"> 575 </span> : : _M_f(__pf) { } -<span class="lineNum"> 576 </span> : -<span class="lineNum"> 577 </span> : _Ret -<span class="lineNum"> 578 </span> : operator()(const _Tp& __r) const -<span class="lineNum"> 579 </span> : { return (__r.*_M_f)(); } -<span class="lineNum"> 580 </span> : -<span class="lineNum"> 581 </span> : private: -<span class="lineNum"> 582 </span> : _Ret (_Tp::*_M_f)() const; -<span class="lineNum"> 583 </span> : }; -<span class="lineNum"> 584 </span> : -<span class="lineNum"> 585 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 586 </span> : /// pointers@endlink. -<span class="lineNum"> 587 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 588 </span> : class mem_fun1_t : public binary_function<_Tp*, _Arg, _Ret> -<span class="lineNum"> 589 </span> : { -<span class="lineNum"> 590 </span> : public: -<span class="lineNum"> 591 </span> : explicit -<span class="lineNum"> 592 </span> : mem_fun1_t(_Ret (_Tp::*__pf)(_Arg)) -<span class="lineNum"> 593 </span> : : _M_f(__pf) { } -<span class="lineNum"> 594 </span> : -<span class="lineNum"> 595 </span> : _Ret -<span class="lineNum"> 596 </span> : operator()(_Tp* __p, _Arg __x) const -<span class="lineNum"> 597 </span> : { return (__p->*_M_f)(__x); } -<span class="lineNum"> 598 </span> : -<span class="lineNum"> 599 </span> : private: -<span class="lineNum"> 600 </span> : _Ret (_Tp::*_M_f)(_Arg); -<span class="lineNum"> 601 </span> : }; -<span class="lineNum"> 602 </span> : -<span class="lineNum"> 603 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 604 </span> : /// pointers@endlink. -<span class="lineNum"> 605 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 606 </span> : class const_mem_fun1_t : public binary_function<const _Tp*, _Arg, _Ret> -<span class="lineNum"> 607 </span> : { -<span class="lineNum"> 608 </span> : public: -<span class="lineNum"> 609 </span> : explicit -<span class="lineNum"> 610 </span> : const_mem_fun1_t(_Ret (_Tp::*__pf)(_Arg) const) -<span class="lineNum"> 611 </span> : : _M_f(__pf) { } -<span class="lineNum"> 612 </span> : -<span class="lineNum"> 613 </span> : _Ret -<span class="lineNum"> 614 </span> : operator()(const _Tp* __p, _Arg __x) const -<span class="lineNum"> 615 </span> : { return (__p->*_M_f)(__x); } -<span class="lineNum"> 616 </span> : -<span class="lineNum"> 617 </span> : private: -<span class="lineNum"> 618 </span> : _Ret (_Tp::*_M_f)(_Arg) const; -<span class="lineNum"> 619 </span> : }; -<span class="lineNum"> 620 </span> : -<span class="lineNum"> 621 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 622 </span> : /// pointers@endlink. -<span class="lineNum"> 623 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 624 </span> : class mem_fun1_ref_t : public binary_function<_Tp, _Arg, _Ret> -<span class="lineNum"> 625 </span> : { -<span class="lineNum"> 626 </span> : public: -<span class="lineNum"> 627 </span> : explicit -<span class="lineNum"> 628 </span> : mem_fun1_ref_t(_Ret (_Tp::*__pf)(_Arg)) -<span class="lineNum"> 629 </span> : : _M_f(__pf) { } -<span class="lineNum"> 630 </span> : -<span class="lineNum"> 631 </span> : _Ret -<span class="lineNum"> 632 </span> : operator()(_Tp& __r, _Arg __x) const -<span class="lineNum"> 633 </span> : { return (__r.*_M_f)(__x); } -<span class="lineNum"> 634 </span> : -<span class="lineNum"> 635 </span> : private: -<span class="lineNum"> 636 </span> : _Ret (_Tp::*_M_f)(_Arg); -<span class="lineNum"> 637 </span> : }; -<span class="lineNum"> 638 </span> : -<span class="lineNum"> 639 </span> : /// One of the @link s20_3_8_memadaptors adaptors for member -<span class="lineNum"> 640 </span> : /// pointers@endlink. -<span class="lineNum"> 641 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 642 </span> : class const_mem_fun1_ref_t : public binary_function<_Tp, _Arg, _Ret> -<span class="lineNum"> 643 </span> : { -<span class="lineNum"> 644 </span> : public: -<span class="lineNum"> 645 </span> : explicit -<span class="lineNum"> 646 </span> : const_mem_fun1_ref_t(_Ret (_Tp::*__pf)(_Arg) const) -<span class="lineNum"> 647 </span> : : _M_f(__pf) { } -<span class="lineNum"> 648 </span> : -<span class="lineNum"> 649 </span> : _Ret -<span class="lineNum"> 650 </span> : operator()(const _Tp& __r, _Arg __x) const -<span class="lineNum"> 651 </span> : { return (__r.*_M_f)(__x); } -<span class="lineNum"> 652 </span> : -<span class="lineNum"> 653 </span> : private: -<span class="lineNum"> 654 </span> : _Ret (_Tp::*_M_f)(_Arg) const; -<span class="lineNum"> 655 </span> : }; -<span class="lineNum"> 656 </span> : -<span class="lineNum"> 657 </span> : // Mem_fun adaptor helper functions. There are only two: -<span class="lineNum"> 658 </span> : // mem_fun and mem_fun_ref. -<span class="lineNum"> 659 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 660 </span> : inline mem_fun_t<_Ret, _Tp> -<span class="lineNum"> 661 </span> : mem_fun(_Ret (_Tp::*__f)()) -<span class="lineNum"> 662 </span> : { return mem_fun_t<_Ret, _Tp>(__f); } -<span class="lineNum"> 663 </span> : -<span class="lineNum"> 664 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 665 </span> : inline const_mem_fun_t<_Ret, _Tp> -<span class="lineNum"> 666 </span> : mem_fun(_Ret (_Tp::*__f)() const) -<span class="lineNum"> 667 </span> : { return const_mem_fun_t<_Ret, _Tp>(__f); } -<span class="lineNum"> 668 </span> : -<span class="lineNum"> 669 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 670 </span> : inline mem_fun_ref_t<_Ret, _Tp> -<span class="lineNum"> 671 </span> : mem_fun_ref(_Ret (_Tp::*__f)()) -<span class="lineNum"> 672 </span> : { return mem_fun_ref_t<_Ret, _Tp>(__f); } -<span class="lineNum"> 673 </span> : -<span class="lineNum"> 674 </span> : template<typename _Ret, typename _Tp> -<span class="lineNum"> 675 </span> : inline const_mem_fun_ref_t<_Ret, _Tp> -<span class="lineNum"> 676 </span> : mem_fun_ref(_Ret (_Tp::*__f)() const) -<span class="lineNum"> 677 </span> : { return const_mem_fun_ref_t<_Ret, _Tp>(__f); } -<span class="lineNum"> 678 </span> : -<span class="lineNum"> 679 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 680 </span> : inline mem_fun1_t<_Ret, _Tp, _Arg> -<span class="lineNum"> 681 </span> : mem_fun(_Ret (_Tp::*__f)(_Arg)) -<span class="lineNum"> 682 </span> : { return mem_fun1_t<_Ret, _Tp, _Arg>(__f); } -<span class="lineNum"> 683 </span> : -<span class="lineNum"> 684 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 685 </span> : inline const_mem_fun1_t<_Ret, _Tp, _Arg> -<span class="lineNum"> 686 </span> : mem_fun(_Ret (_Tp::*__f)(_Arg) const) -<span class="lineNum"> 687 </span> : { return const_mem_fun1_t<_Ret, _Tp, _Arg>(__f); } -<span class="lineNum"> 688 </span> : -<span class="lineNum"> 689 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 690 </span> : inline mem_fun1_ref_t<_Ret, _Tp, _Arg> -<span class="lineNum"> 691 </span> : mem_fun_ref(_Ret (_Tp::*__f)(_Arg)) -<span class="lineNum"> 692 </span> : { return mem_fun1_ref_t<_Ret, _Tp, _Arg>(__f); } -<span class="lineNum"> 693 </span> : -<span class="lineNum"> 694 </span> : template<typename _Ret, typename _Tp, typename _Arg> -<span class="lineNum"> 695 </span> : inline const_mem_fun1_ref_t<_Ret, _Tp, _Arg> -<span class="lineNum"> 696 </span> : mem_fun_ref(_Ret (_Tp::*__f)(_Arg) const) -<span class="lineNum"> 697 </span> : { return const_mem_fun1_ref_t<_Ret, _Tp, _Arg>(__f); } -<span class="lineNum"> 698 </span> : -<span class="lineNum"> 699 </span> : /** @} */ -<span class="lineNum"> 700 </span> : -<span class="lineNum"> 701 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 702 </span> : -<span class="lineNum"> 703 </span> : #if !defined(__GXX_EXPERIMENTAL_CXX0X__) || _GLIBCXX_DEPRECATED -<span class="lineNum"> 704 </span> : # include <backward/binders.h> -<span class="lineNum"> 705 </span> : #endif -<span class="lineNum"> 706 </span> : -<span class="lineNum"> 707 </span> : #endif /* _STL_FUNCTION_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_heap.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_heap.h.gcov.html deleted file mode 100644 index c9d582a..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_heap.h.gcov.html +++ /dev/null @@ -1,637 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_heap.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_heap.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">92</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">0.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">0</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Heap implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * Copyright (c) 1997 -<span class="lineNum"> 45 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 46 </span> : * -<span class="lineNum"> 47 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 48 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 49 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 50 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 51 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 52 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 53 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 54 </span> : */ -<span class="lineNum"> 55 </span> : -<span class="lineNum"> 56 </span> : /** @file stl_heap.h -<span class="lineNum"> 57 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 58 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 59 </span> : */ -<span class="lineNum"> 60 </span> : -<span class="lineNum"> 61 </span> : #ifndef _STL_HEAP_H -<span class="lineNum"> 62 </span> : #define _STL_HEAP_H 1 -<span class="lineNum"> 63 </span> : -<span class="lineNum"> 64 </span> : #include <debug/debug.h> -<span class="lineNum"> 65 </span> : #include <bits/stl_move.h> -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : template<typename _RandomAccessIterator, typename _Distance> -<span class="lineNum"> 70 </span> : _Distance -<span class="lineNum"> 71 </span> : __is_heap_until(_RandomAccessIterator __first, _Distance __n) -<span class="lineNum"> 72 </span> : { -<span class="lineNum"> 73 </span> : _Distance __parent = 0; -<span class="lineNum"> 74 </span> : for (_Distance __child = 1; __child < __n; ++__child) -<span class="lineNum"> 75 </span> : { -<span class="lineNum"> 76 </span> : if (__first[__parent] < __first[__child]) -<span class="lineNum"> 77 </span> : return __child; -<span class="lineNum"> 78 </span> : if ((__child & 1) == 0) -<span class="lineNum"> 79 </span> : ++__parent; -<span class="lineNum"> 80 </span> : } -<span class="lineNum"> 81 </span> : return __n; -<span class="lineNum"> 82 </span> : } -<span class="lineNum"> 83 </span> : -<span class="lineNum"> 84 </span> : template<typename _RandomAccessIterator, typename _Distance, -<span class="lineNum"> 85 </span> : typename _Compare> -<span class="lineNum"> 86 </span> : _Distance -<span class="lineNum"> 87 </span> : __is_heap_until(_RandomAccessIterator __first, _Distance __n, -<span class="lineNum"> 88 </span> : _Compare __comp) -<span class="lineNum"> 89 </span> : { -<span class="lineNum"> 90 </span> : _Distance __parent = 0; -<span class="lineNum"> 91 </span> : for (_Distance __child = 1; __child < __n; ++__child) -<span class="lineNum"> 92 </span> : { -<span class="lineNum"> 93 </span> : if (__comp(__first[__parent], __first[__child])) -<span class="lineNum"> 94 </span> : return __child; -<span class="lineNum"> 95 </span> : if ((__child & 1) == 0) -<span class="lineNum"> 96 </span> : ++__parent; -<span class="lineNum"> 97 </span> : } -<span class="lineNum"> 98 </span> : return __n; -<span class="lineNum"> 99 </span> : } -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : // __is_heap, a predicate testing whether or not a range is a heap. -<span class="lineNum"> 102 </span> : // This function is an extension, not part of the C++ standard. -<span class="lineNum"> 103 </span> : template<typename _RandomAccessIterator, typename _Distance> -<span class="lineNum"> 104 </span> : inline bool -<span class="lineNum"> 105 </span> : __is_heap(_RandomAccessIterator __first, _Distance __n) -<span class="lineNum"> 106 </span> : { return std::__is_heap_until(__first, __n) == __n; } -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : template<typename _RandomAccessIterator, typename _Compare, -<span class="lineNum"> 109 </span> : typename _Distance> -<span class="lineNum"> 110 </span> : inline bool -<span class="lineNum"> 111 </span> : __is_heap(_RandomAccessIterator __first, _Compare __comp, _Distance __n) -<span class="lineNum"> 112 </span> : { return std::__is_heap_until(__first, __n, __comp) == __n; } -<span class="lineNum"> 113 </span> : -<span class="lineNum"> 114 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 115 </span> : inline bool -<span class="lineNum"> 116 </span> : __is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last) -<span class="lineNum"> 117 </span> : { return std::__is_heap(__first, std::distance(__first, __last)); } -<span class="lineNum"> 118 </span> : -<span class="lineNum"> 119 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 120 </span> : inline bool -<span class="lineNum"> 121 </span> : __is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 122 </span> : _Compare __comp) -<span class="lineNum"> 123 </span> : { return std::__is_heap(__first, __comp, std::distance(__first, __last)); } -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : // Heap-manipulation functions: push_heap, pop_heap, make_heap, sort_heap, -<span class="lineNum"> 126 </span> : // + is_heap and is_heap_until in C++0x. -<span class="lineNum"> 127 </span> : -<span class="lineNum"> 128 </span> : template<typename _RandomAccessIterator, typename _Distance, typename _Tp> -<span class="lineNum"> 129 </span> : void -<span class="lineNum"> 130 </span> : __push_heap(_RandomAccessIterator __first, -<span class="lineNum"> 131 </span><span class="lineNoCov"> 0 : _Distance __holeIndex, _Distance __topIndex, _Tp __value)</span> -<span class="lineNum"> 132 </span> : { -<span class="lineNum"> 133 </span><span class="lineNoCov"> 0 : _Distance __parent = (__holeIndex - 1) / 2;</span> -<span class="lineNum"> 134 </span><span class="lineNoCov"> 0 : while (__holeIndex > __topIndex && *(__first + __parent) < __value)</span> -<span class="lineNum"> 135 </span> : { -<span class="lineNum"> 136 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(*(__first + __parent));</span> -<span class="lineNum"> 137 </span><span class="lineNoCov"> 0 : __holeIndex = __parent;</span> -<span class="lineNum"> 138 </span><span class="lineNoCov"> 0 : __parent = (__holeIndex - 1) / 2;</span> -<span class="lineNum"> 139 </span> : } -<span class="lineNum"> 140 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(__value);</span> -<span class="lineNum"> 141 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 142 </span> : -<span class="lineNum"> 143 </span> : /** -<span class="lineNum"> 144 </span> : * @brief Push an element onto a heap. -<span class="lineNum"> 145 </span> : * @param first Start of heap. -<span class="lineNum"> 146 </span> : * @param last End of heap + element. -<span class="lineNum"> 147 </span> : * @ingroup heap -<span class="lineNum"> 148 </span> : * -<span class="lineNum"> 149 </span> : * This operation pushes the element at last-1 onto the valid heap over the -<span class="lineNum"> 150 </span> : * range [first,last-1). After completion, [first,last) is a valid heap. -<span class="lineNum"> 151 </span> : */ -<span class="lineNum"> 152 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 153 </span> : inline void -<span class="lineNum"> 154 </span> : push_heap(_RandomAccessIterator __first, _RandomAccessIterator __last) -<span class="lineNum"> 155 </span> : { -<span class="lineNum"> 156 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 157 </span> : _ValueType; -<span class="lineNum"> 158 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 159 </span> : _DistanceType; -<span class="lineNum"> 160 </span> : -<span class="lineNum"> 161 </span> : // concept requirements -<span class="lineNum"> 162 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 163 </span> : _RandomAccessIterator>) -<span class="lineNum"> 164 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 165 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 166 </span> : __glibcxx_requires_heap(__first, __last - 1); -<span class="lineNum"> 167 </span> : -<span class="lineNum"> 168 </span> : _ValueType __value = _GLIBCXX_MOVE(*(__last - 1)); -<span class="lineNum"> 169 </span> : std::__push_heap(__first, _DistanceType((__last - __first) - 1), -<span class="lineNum"> 170 </span> : _DistanceType(0), _GLIBCXX_MOVE(__value)); -<span class="lineNum"> 171 </span> : } -<span class="lineNum"> 172 </span> : -<span class="lineNum"> 173 </span> : template<typename _RandomAccessIterator, typename _Distance, typename _Tp, -<span class="lineNum"> 174 </span> : typename _Compare> -<span class="lineNum"> 175 </span> : void -<span class="lineNum"> 176 </span> : __push_heap(_RandomAccessIterator __first, _Distance __holeIndex, -<span class="lineNum"> 177 </span><span class="lineNoCov"> 0 : _Distance __topIndex, _Tp __value, _Compare __comp)</span> -<span class="lineNum"> 178 </span> : { -<span class="lineNum"> 179 </span><span class="lineNoCov"> 0 : _Distance __parent = (__holeIndex - 1) / 2;</span> -<span class="lineNum"> 180 </span><span class="lineNoCov"> 0 : while (__holeIndex > __topIndex</span> -<span class="lineNum"> 181 </span> : && __comp(*(__first + __parent), __value)) -<span class="lineNum"> 182 </span> : { -<span class="lineNum"> 183 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(*(__first + __parent));</span> -<span class="lineNum"> 184 </span><span class="lineNoCov"> 0 : __holeIndex = __parent;</span> -<span class="lineNum"> 185 </span><span class="lineNoCov"> 0 : __parent = (__holeIndex - 1) / 2;</span> -<span class="lineNum"> 186 </span> : } -<span class="lineNum"> 187 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(__value);</span> -<span class="lineNum"> 188 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 189 </span> : -<span class="lineNum"> 190 </span> : /** -<span class="lineNum"> 191 </span> : * @brief Push an element onto a heap using comparison functor. -<span class="lineNum"> 192 </span> : * @param first Start of heap. -<span class="lineNum"> 193 </span> : * @param last End of heap + element. -<span class="lineNum"> 194 </span> : * @param comp Comparison functor. -<span class="lineNum"> 195 </span> : * @ingroup heap -<span class="lineNum"> 196 </span> : * -<span class="lineNum"> 197 </span> : * This operation pushes the element at last-1 onto the valid heap over the -<span class="lineNum"> 198 </span> : * range [first,last-1). After completion, [first,last) is a valid heap. -<span class="lineNum"> 199 </span> : * Compare operations are performed using comp. -<span class="lineNum"> 200 </span> : */ -<span class="lineNum"> 201 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 202 </span> : inline void -<span class="lineNum"> 203 </span> : push_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 204 </span> : _Compare __comp) -<span class="lineNum"> 205 </span> : { -<span class="lineNum"> 206 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 207 </span> : _ValueType; -<span class="lineNum"> 208 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 209 </span> : _DistanceType; -<span class="lineNum"> 210 </span> : -<span class="lineNum"> 211 </span> : // concept requirements -<span class="lineNum"> 212 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 213 </span> : _RandomAccessIterator>) -<span class="lineNum"> 214 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 215 </span> : __glibcxx_requires_heap_pred(__first, __last - 1, __comp); -<span class="lineNum"> 216 </span> : -<span class="lineNum"> 217 </span> : _ValueType __value = _GLIBCXX_MOVE(*(__last - 1)); -<span class="lineNum"> 218 </span> : std::__push_heap(__first, _DistanceType((__last - __first) - 1), -<span class="lineNum"> 219 </span> : _DistanceType(0), _GLIBCXX_MOVE(__value), __comp); -<span class="lineNum"> 220 </span> : } -<span class="lineNum"> 221 </span> : -<span class="lineNum"> 222 </span> : template<typename _RandomAccessIterator, typename _Distance, typename _Tp> -<span class="lineNum"> 223 </span> : void -<span class="lineNum"> 224 </span> : __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, -<span class="lineNum"> 225 </span><span class="lineNoCov"> 0 : _Distance __len, _Tp __value)</span> -<span class="lineNum"> 226 </span> : { -<span class="lineNum"> 227 </span><span class="lineNoCov"> 0 : const _Distance __topIndex = __holeIndex;</span> -<span class="lineNum"> 228 </span><span class="lineNoCov"> 0 : _Distance __secondChild = __holeIndex;</span> -<span class="lineNum"> 229 </span><span class="lineNoCov"> 0 : while (__secondChild < (__len - 1) / 2)</span> -<span class="lineNum"> 230 </span> : { -<span class="lineNum"> 231 </span><span class="lineNoCov"> 0 : __secondChild = 2 * (__secondChild + 1);</span> -<span class="lineNum"> 232 </span><span class="lineNoCov"> 0 : if (*(__first + __secondChild) < *(__first + (__secondChild - 1)))</span> -<span class="lineNum"> 233 </span><span class="lineNoCov"> 0 : __secondChild--;</span> -<span class="lineNum"> 234 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(*(__first + __secondChild));</span> -<span class="lineNum"> 235 </span><span class="lineNoCov"> 0 : __holeIndex = __secondChild;</span> -<span class="lineNum"> 236 </span> : } -<span class="lineNum"> 237 </span><span class="lineNoCov"> 0 : if ((__len & 1) == 0 && __secondChild == (__len - 2) / 2)</span> -<span class="lineNum"> 238 </span> : { -<span class="lineNum"> 239 </span><span class="lineNoCov"> 0 : __secondChild = 2 * (__secondChild + 1);</span> -<span class="lineNum"> 240 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(*(__first</span> -<span class="lineNum"> 241 </span> : + (__secondChild - 1))); -<span class="lineNum"> 242 </span><span class="lineNoCov"> 0 : __holeIndex = __secondChild - 1;</span> -<span class="lineNum"> 243 </span> : } -<span class="lineNum"> 244 </span><span class="lineNoCov"> 0 : std::__push_heap(__first, __holeIndex, __topIndex,</span> -<span class="lineNum"> 245 </span> : _GLIBCXX_MOVE(__value)); -<span class="lineNum"> 246 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 247 </span> : -<span class="lineNum"> 248 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 249 </span> : inline void -<span class="lineNum"> 250 </span> : __pop_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 251 </span><span class="lineNoCov"> 0 : _RandomAccessIterator __result)</span> -<span class="lineNum"> 252 </span> : { -<span class="lineNum"> 253 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 254 </span> : _ValueType; -<span class="lineNum"> 255 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 256 </span> : _DistanceType; -<span class="lineNum"> 257 </span> : -<span class="lineNum"> 258 </span><span class="lineNoCov"> 0 : _ValueType __value = _GLIBCXX_MOVE(*__result);</span> -<span class="lineNum"> 259 </span><span class="lineNoCov"> 0 : *__result = _GLIBCXX_MOVE(*__first);</span> -<span class="lineNum"> 260 </span><span class="lineNoCov"> 0 : std::__adjust_heap(__first, _DistanceType(0),</span> -<span class="lineNum"> 261 </span> : _DistanceType(__last - __first), -<span class="lineNum"> 262 </span> : _GLIBCXX_MOVE(__value)); -<span class="lineNum"> 263 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 264 </span> : -<span class="lineNum"> 265 </span> : /** -<span class="lineNum"> 266 </span> : * @brief Pop an element off a heap. -<span class="lineNum"> 267 </span> : * @param first Start of heap. -<span class="lineNum"> 268 </span> : * @param last End of heap. -<span class="lineNum"> 269 </span> : * @ingroup heap -<span class="lineNum"> 270 </span> : * -<span class="lineNum"> 271 </span> : * This operation pops the top of the heap. The elements first and last-1 -<span class="lineNum"> 272 </span> : * are swapped and [first,last-1) is made into a heap. -<span class="lineNum"> 273 </span> : */ -<span class="lineNum"> 274 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 275 </span> : inline void -<span class="lineNum"> 276 </span><span class="lineNoCov"> 0 : pop_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)</span> -<span class="lineNum"> 277 </span> : { -<span class="lineNum"> 278 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 279 </span> : _ValueType; -<span class="lineNum"> 280 </span> : -<span class="lineNum"> 281 </span> : // concept requirements -<span class="lineNum"> 282 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 283 </span> : _RandomAccessIterator>) -<span class="lineNum"> 284 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 285 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 286 </span> : __glibcxx_requires_heap(__first, __last); -<span class="lineNum"> 287 </span> : -<span class="lineNum"> 288 </span><span class="lineNoCov"> 0 : std::__pop_heap(__first, __last - 1, __last - 1);</span> -<span class="lineNum"> 289 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 290 </span> : -<span class="lineNum"> 291 </span> : template<typename _RandomAccessIterator, typename _Distance, -<span class="lineNum"> 292 </span> : typename _Tp, typename _Compare> -<span class="lineNum"> 293 </span> : void -<span class="lineNum"> 294 </span> : __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, -<span class="lineNum"> 295 </span><span class="lineNoCov"> 0 : _Distance __len, _Tp __value, _Compare __comp)</span> -<span class="lineNum"> 296 </span> : { -<span class="lineNum"> 297 </span><span class="lineNoCov"> 0 : const _Distance __topIndex = __holeIndex;</span> -<span class="lineNum"> 298 </span><span class="lineNoCov"> 0 : _Distance __secondChild = __holeIndex;</span> -<span class="lineNum"> 299 </span><span class="lineNoCov"> 0 : while (__secondChild < (__len - 1) / 2)</span> -<span class="lineNum"> 300 </span> : { -<span class="lineNum"> 301 </span><span class="lineNoCov"> 0 : __secondChild = 2 * (__secondChild + 1);</span> -<span class="lineNum"> 302 </span><span class="lineNoCov"> 0 : if (__comp(*(__first + __secondChild),</span> -<span class="lineNum"> 303 </span> : *(__first + (__secondChild - 1)))) -<span class="lineNum"> 304 </span><span class="lineNoCov"> 0 : __secondChild--;</span> -<span class="lineNum"> 305 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(*(__first + __secondChild));</span> -<span class="lineNum"> 306 </span><span class="lineNoCov"> 0 : __holeIndex = __secondChild;</span> -<span class="lineNum"> 307 </span> : } -<span class="lineNum"> 308 </span><span class="lineNoCov"> 0 : if ((__len & 1) == 0 && __secondChild == (__len - 2) / 2)</span> -<span class="lineNum"> 309 </span> : { -<span class="lineNum"> 310 </span><span class="lineNoCov"> 0 : __secondChild = 2 * (__secondChild + 1);</span> -<span class="lineNum"> 311 </span><span class="lineNoCov"> 0 : *(__first + __holeIndex) = _GLIBCXX_MOVE(*(__first</span> -<span class="lineNum"> 312 </span> : + (__secondChild - 1))); -<span class="lineNum"> 313 </span><span class="lineNoCov"> 0 : __holeIndex = __secondChild - 1;</span> -<span class="lineNum"> 314 </span> : } -<span class="lineNum"> 315 </span><span class="lineNoCov"> 0 : std::__push_heap(__first, __holeIndex, __topIndex, </span> -<span class="lineNum"> 316 </span> : _GLIBCXX_MOVE(__value), __comp); -<span class="lineNum"> 317 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 318 </span> : -<span class="lineNum"> 319 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 320 </span> : inline void -<span class="lineNum"> 321 </span> : __pop_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 322 </span><span class="lineNoCov"> 0 : _RandomAccessIterator __result, _Compare __comp)</span> -<span class="lineNum"> 323 </span> : { -<span class="lineNum"> 324 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 325 </span> : _ValueType; -<span class="lineNum"> 326 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 327 </span> : _DistanceType; -<span class="lineNum"> 328 </span> : -<span class="lineNum"> 329 </span><span class="lineNoCov"> 0 : _ValueType __value = _GLIBCXX_MOVE(*__result);</span> -<span class="lineNum"> 330 </span><span class="lineNoCov"> 0 : *__result = _GLIBCXX_MOVE(*__first);</span> -<span class="lineNum"> 331 </span><span class="lineNoCov"> 0 : std::__adjust_heap(__first, _DistanceType(0),</span> -<span class="lineNum"> 332 </span> : _DistanceType(__last - __first), -<span class="lineNum"> 333 </span> : _GLIBCXX_MOVE(__value), __comp); -<span class="lineNum"> 334 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 335 </span> : -<span class="lineNum"> 336 </span> : /** -<span class="lineNum"> 337 </span> : * @brief Pop an element off a heap using comparison functor. -<span class="lineNum"> 338 </span> : * @param first Start of heap. -<span class="lineNum"> 339 </span> : * @param last End of heap. -<span class="lineNum"> 340 </span> : * @param comp Comparison functor to use. -<span class="lineNum"> 341 </span> : * @ingroup heap -<span class="lineNum"> 342 </span> : * -<span class="lineNum"> 343 </span> : * This operation pops the top of the heap. The elements first and last-1 -<span class="lineNum"> 344 </span> : * are swapped and [first,last-1) is made into a heap. Comparisons are -<span class="lineNum"> 345 </span> : * made using comp. -<span class="lineNum"> 346 </span> : */ -<span class="lineNum"> 347 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 348 </span> : inline void -<span class="lineNum"> 349 </span> : pop_heap(_RandomAccessIterator __first, -<span class="lineNum"> 350 </span><span class="lineNoCov"> 0 : _RandomAccessIterator __last, _Compare __comp)</span> -<span class="lineNum"> 351 </span> : { -<span class="lineNum"> 352 </span> : // concept requirements -<span class="lineNum"> 353 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 354 </span> : _RandomAccessIterator>) -<span class="lineNum"> 355 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 356 </span> : __glibcxx_requires_heap_pred(__first, __last, __comp); -<span class="lineNum"> 357 </span> : -<span class="lineNum"> 358 </span><span class="lineNoCov"> 0 : std::__pop_heap(__first, __last - 1, __last - 1, __comp);</span> -<span class="lineNum"> 359 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 360 </span> : -<span class="lineNum"> 361 </span> : /** -<span class="lineNum"> 362 </span> : * @brief Construct a heap over a range. -<span class="lineNum"> 363 </span> : * @param first Start of heap. -<span class="lineNum"> 364 </span> : * @param last End of heap. -<span class="lineNum"> 365 </span> : * @ingroup heap -<span class="lineNum"> 366 </span> : * -<span class="lineNum"> 367 </span> : * This operation makes the elements in [first,last) into a heap. -<span class="lineNum"> 368 </span> : */ -<span class="lineNum"> 369 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 370 </span> : void -<span class="lineNum"> 371 </span><span class="lineNoCov"> 0 : make_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)</span> -<span class="lineNum"> 372 </span> : { -<span class="lineNum"> 373 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 374 </span> : _ValueType; -<span class="lineNum"> 375 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 376 </span> : _DistanceType; -<span class="lineNum"> 377 </span> : -<span class="lineNum"> 378 </span> : // concept requirements -<span class="lineNum"> 379 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 380 </span> : _RandomAccessIterator>) -<span class="lineNum"> 381 </span> : __glibcxx_function_requires(_LessThanComparableConcept<_ValueType>) -<span class="lineNum"> 382 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 383 </span> : -<span class="lineNum"> 384 </span><span class="lineNoCov"> 0 : if (__last - __first < 2)</span> -<span class="lineNum"> 385 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 386 </span> : -<span class="lineNum"> 387 </span><span class="lineNoCov"> 0 : const _DistanceType __len = __last - __first;</span> -<span class="lineNum"> 388 </span><span class="lineNoCov"> 0 : _DistanceType __parent = (__len - 2) / 2;</span> -<span class="lineNum"> 389 </span><span class="lineNoCov"> 0 : while (true)</span> -<span class="lineNum"> 390 </span> : { -<span class="lineNum"> 391 </span><span class="lineNoCov"> 0 : _ValueType __value = _GLIBCXX_MOVE(*(__first + __parent));</span> -<span class="lineNum"> 392 </span><span class="lineNoCov"> 0 : std::__adjust_heap(__first, __parent, __len, _GLIBCXX_MOVE(__value));</span> -<span class="lineNum"> 393 </span><span class="lineNoCov"> 0 : if (__parent == 0)</span> -<span class="lineNum"> 394 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 395 </span><span class="lineNoCov"> 0 : __parent--;</span> -<span class="lineNum"> 396 </span> : } -<span class="lineNum"> 397 </span> : } -<span class="lineNum"> 398 </span> : -<span class="lineNum"> 399 </span> : /** -<span class="lineNum"> 400 </span> : * @brief Construct a heap over a range using comparison functor. -<span class="lineNum"> 401 </span> : * @param first Start of heap. -<span class="lineNum"> 402 </span> : * @param last End of heap. -<span class="lineNum"> 403 </span> : * @param comp Comparison functor to use. -<span class="lineNum"> 404 </span> : * @ingroup heap -<span class="lineNum"> 405 </span> : * -<span class="lineNum"> 406 </span> : * This operation makes the elements in [first,last) into a heap. -<span class="lineNum"> 407 </span> : * Comparisons are made using comp. -<span class="lineNum"> 408 </span> : */ -<span class="lineNum"> 409 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 410 </span> : void -<span class="lineNum"> 411 </span> : make_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 412 </span><span class="lineNoCov"> 0 : _Compare __comp)</span> -<span class="lineNum"> 413 </span> : { -<span class="lineNum"> 414 </span> : typedef typename iterator_traits<_RandomAccessIterator>::value_type -<span class="lineNum"> 415 </span> : _ValueType; -<span class="lineNum"> 416 </span> : typedef typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 417 </span> : _DistanceType; -<span class="lineNum"> 418 </span> : -<span class="lineNum"> 419 </span> : // concept requirements -<span class="lineNum"> 420 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 421 </span> : _RandomAccessIterator>) -<span class="lineNum"> 422 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 423 </span> : -<span class="lineNum"> 424 </span><span class="lineNoCov"> 0 : if (__last - __first < 2)</span> -<span class="lineNum"> 425 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 426 </span> : -<span class="lineNum"> 427 </span><span class="lineNoCov"> 0 : const _DistanceType __len = __last - __first;</span> -<span class="lineNum"> 428 </span><span class="lineNoCov"> 0 : _DistanceType __parent = (__len - 2) / 2;</span> -<span class="lineNum"> 429 </span><span class="lineNoCov"> 0 : while (true)</span> -<span class="lineNum"> 430 </span> : { -<span class="lineNum"> 431 </span><span class="lineNoCov"> 0 : _ValueType __value = _GLIBCXX_MOVE(*(__first + __parent));</span> -<span class="lineNum"> 432 </span><span class="lineNoCov"> 0 : std::__adjust_heap(__first, __parent, __len, _GLIBCXX_MOVE(__value),</span> -<span class="lineNum"> 433 </span> : __comp); -<span class="lineNum"> 434 </span><span class="lineNoCov"> 0 : if (__parent == 0)</span> -<span class="lineNum"> 435 </span><span class="lineNoCov"> 0 : return;</span> -<span class="lineNum"> 436 </span><span class="lineNoCov"> 0 : __parent--;</span> -<span class="lineNum"> 437 </span> : } -<span class="lineNum"> 438 </span> : } -<span class="lineNum"> 439 </span> : -<span class="lineNum"> 440 </span> : /** -<span class="lineNum"> 441 </span> : * @brief Sort a heap. -<span class="lineNum"> 442 </span> : * @param first Start of heap. -<span class="lineNum"> 443 </span> : * @param last End of heap. -<span class="lineNum"> 444 </span> : * @ingroup heap -<span class="lineNum"> 445 </span> : * -<span class="lineNum"> 446 </span> : * This operation sorts the valid heap in the range [first,last). -<span class="lineNum"> 447 </span> : */ -<span class="lineNum"> 448 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 449 </span> : void -<span class="lineNum"> 450 </span><span class="lineNoCov"> 0 : sort_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)</span> -<span class="lineNum"> 451 </span> : { -<span class="lineNum"> 452 </span> : // concept requirements -<span class="lineNum"> 453 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 454 </span> : _RandomAccessIterator>) -<span class="lineNum"> 455 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 456 </span> : typename iterator_traits<_RandomAccessIterator>::value_type>) -<span class="lineNum"> 457 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 458 </span> : __glibcxx_requires_heap(__first, __last); -<span class="lineNum"> 459 </span> : -<span class="lineNum"> 460 </span><span class="lineNoCov"> 0 : while (__last - __first > 1)</span> -<span class="lineNum"> 461 </span><span class="lineNoCov"> 0 : std::pop_heap(__first, _RandomAccessIterator(__last--));</span> -<span class="lineNum"> 462 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 463 </span> : -<span class="lineNum"> 464 </span> : /** -<span class="lineNum"> 465 </span> : * @brief Sort a heap using comparison functor. -<span class="lineNum"> 466 </span> : * @param first Start of heap. -<span class="lineNum"> 467 </span> : * @param last End of heap. -<span class="lineNum"> 468 </span> : * @param comp Comparison functor to use. -<span class="lineNum"> 469 </span> : * @ingroup heap -<span class="lineNum"> 470 </span> : * -<span class="lineNum"> 471 </span> : * This operation sorts the valid heap in the range [first,last). -<span class="lineNum"> 472 </span> : * Comparisons are made using comp. -<span class="lineNum"> 473 </span> : */ -<span class="lineNum"> 474 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 475 </span> : void -<span class="lineNum"> 476 </span> : sort_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 477 </span><span class="lineNoCov"> 0 : _Compare __comp)</span> -<span class="lineNum"> 478 </span> : { -<span class="lineNum"> 479 </span> : // concept requirements -<span class="lineNum"> 480 </span> : __glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept< -<span class="lineNum"> 481 </span> : _RandomAccessIterator>) -<span class="lineNum"> 482 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 483 </span> : __glibcxx_requires_heap_pred(__first, __last, __comp); -<span class="lineNum"> 484 </span> : -<span class="lineNum"> 485 </span><span class="lineNoCov"> 0 : while (__last - __first > 1)</span> -<span class="lineNum"> 486 </span><span class="lineNoCov"> 0 : std::pop_heap(__first, _RandomAccessIterator(__last--), __comp);</span> -<span class="lineNum"> 487 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 488 </span> : -<span class="lineNum"> 489 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 490 </span> : /** -<span class="lineNum"> 491 </span> : * @brief Search the end of a heap. -<span class="lineNum"> 492 </span> : * @param first Start of range. -<span class="lineNum"> 493 </span> : * @param last End of range. -<span class="lineNum"> 494 </span> : * @return An iterator pointing to the first element not in the heap. -<span class="lineNum"> 495 </span> : * @ingroup heap -<span class="lineNum"> 496 </span> : * -<span class="lineNum"> 497 </span> : * This operation returns the last iterator i in [first, last) for which -<span class="lineNum"> 498 </span> : * the range [first, i) is a heap. -<span class="lineNum"> 499 </span> : */ -<span class="lineNum"> 500 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 501 </span> : inline _RandomAccessIterator -<span class="lineNum"> 502 </span> : is_heap_until(_RandomAccessIterator __first, _RandomAccessIterator __last) -<span class="lineNum"> 503 </span> : { -<span class="lineNum"> 504 </span> : // concept requirements -<span class="lineNum"> 505 </span> : __glibcxx_function_requires(_RandomAccessIteratorConcept< -<span class="lineNum"> 506 </span> : _RandomAccessIterator>) -<span class="lineNum"> 507 </span> : __glibcxx_function_requires(_LessThanComparableConcept< -<span class="lineNum"> 508 </span> : typename iterator_traits<_RandomAccessIterator>::value_type>) -<span class="lineNum"> 509 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 510 </span> : -<span class="lineNum"> 511 </span> : return __first + std::__is_heap_until(__first, std::distance(__first, -<span class="lineNum"> 512 </span> : __last)); -<span class="lineNum"> 513 </span> : } -<span class="lineNum"> 514 </span> : -<span class="lineNum"> 515 </span> : /** -<span class="lineNum"> 516 </span> : * @brief Search the end of a heap using comparison functor. -<span class="lineNum"> 517 </span> : * @param first Start of range. -<span class="lineNum"> 518 </span> : * @param last End of range. -<span class="lineNum"> 519 </span> : * @param comp Comparison functor to use. -<span class="lineNum"> 520 </span> : * @return An iterator pointing to the first element not in the heap. -<span class="lineNum"> 521 </span> : * @ingroup heap -<span class="lineNum"> 522 </span> : * -<span class="lineNum"> 523 </span> : * This operation returns the last iterator i in [first, last) for which -<span class="lineNum"> 524 </span> : * the range [first, i) is a heap. Comparisons are made using comp. -<span class="lineNum"> 525 </span> : */ -<span class="lineNum"> 526 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 527 </span> : inline _RandomAccessIterator -<span class="lineNum"> 528 </span> : is_heap_until(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 529 </span> : _Compare __comp) -<span class="lineNum"> 530 </span> : { -<span class="lineNum"> 531 </span> : // concept requirements -<span class="lineNum"> 532 </span> : __glibcxx_function_requires(_RandomAccessIteratorConcept< -<span class="lineNum"> 533 </span> : _RandomAccessIterator>) -<span class="lineNum"> 534 </span> : __glibcxx_requires_valid_range(__first, __last); -<span class="lineNum"> 535 </span> : -<span class="lineNum"> 536 </span> : return __first + std::__is_heap_until(__first, std::distance(__first, -<span class="lineNum"> 537 </span> : __last), -<span class="lineNum"> 538 </span> : __comp); -<span class="lineNum"> 539 </span> : } -<span class="lineNum"> 540 </span> : -<span class="lineNum"> 541 </span> : /** -<span class="lineNum"> 542 </span> : * @brief Determines whether a range is a heap. -<span class="lineNum"> 543 </span> : * @param first Start of range. -<span class="lineNum"> 544 </span> : * @param last End of range. -<span class="lineNum"> 545 </span> : * @return True if range is a heap, false otherwise. -<span class="lineNum"> 546 </span> : * @ingroup heap -<span class="lineNum"> 547 </span> : */ -<span class="lineNum"> 548 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 549 </span> : inline bool -<span class="lineNum"> 550 </span> : is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last) -<span class="lineNum"> 551 </span> : { return std::is_heap_until(__first, __last) == __last; } -<span class="lineNum"> 552 </span> : -<span class="lineNum"> 553 </span> : /** -<span class="lineNum"> 554 </span> : * @brief Determines whether a range is a heap using comparison functor. -<span class="lineNum"> 555 </span> : * @param first Start of range. -<span class="lineNum"> 556 </span> : * @param last End of range. -<span class="lineNum"> 557 </span> : * @param comp Comparison functor to use. -<span class="lineNum"> 558 </span> : * @return True if range is a heap, false otherwise. -<span class="lineNum"> 559 </span> : * @ingroup heap -<span class="lineNum"> 560 </span> : */ -<span class="lineNum"> 561 </span> : template<typename _RandomAccessIterator, typename _Compare> -<span class="lineNum"> 562 </span> : inline bool -<span class="lineNum"> 563 </span> : is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 564 </span> : _Compare __comp) -<span class="lineNum"> 565 </span> : { return std::is_heap_until(__first, __last, __comp) == __last; } -<span class="lineNum"> 566 </span> : #endif -<span class="lineNum"> 567 </span> : -<span class="lineNum"> 568 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 569 </span> : -<span class="lineNum"> 570 </span> : #endif /* _STL_HEAP_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_iterator.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_iterator.h.gcov.html deleted file mode 100644 index 20e1312..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_iterator.h.gcov.html +++ /dev/null @@ -1,1095 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_iterator.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_iterator.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">66</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">93.9 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">62</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Iterators -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996-1998 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_iterator.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : * -<span class="lineNum"> 61 </span> : * This file implements reverse_iterator, back_insert_iterator, -<span class="lineNum"> 62 </span> : * front_insert_iterator, insert_iterator, __normal_iterator, and their -<span class="lineNum"> 63 </span> : * supporting functions and overloaded operators. -<span class="lineNum"> 64 </span> : */ -<span class="lineNum"> 65 </span> : -<span class="lineNum"> 66 </span> : #ifndef _STL_ITERATOR_H -<span class="lineNum"> 67 </span> : #define _STL_ITERATOR_H 1 -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : #include <bits/cpp_type_traits.h> -<span class="lineNum"> 70 </span> : #include <ext/type_traits.h> -<span class="lineNum"> 71 </span> : #include <bits/stl_move.h> -<span class="lineNum"> 72 </span> : -<span class="lineNum"> 73 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 74 </span> : -<span class="lineNum"> 75 </span> : // 24.4.1 Reverse iterators -<span class="lineNum"> 76 </span> : /** -<span class="lineNum"> 77 </span> : * "Bidirectional and random access iterators have corresponding reverse -<span class="lineNum"> 78 </span> : * %iterator adaptors that iterate through the data structure in the -<span class="lineNum"> 79 </span> : * opposite direction. They have the same signatures as the corresponding -<span class="lineNum"> 80 </span> : * iterators. The fundamental relation between a reverse %iterator and its -<span class="lineNum"> 81 </span> : * corresponding %iterator @c i is established by the identity: -<span class="lineNum"> 82 </span> : * @code -<span class="lineNum"> 83 </span> : * &*(reverse_iterator(i)) == &*(i - 1) -<span class="lineNum"> 84 </span> : * @endcode -<span class="lineNum"> 85 </span> : * -<span class="lineNum"> 86 </span> : * This mapping is dictated by the fact that while there is always a -<span class="lineNum"> 87 </span> : * pointer past the end of an array, there might not be a valid pointer -<span class="lineNum"> 88 </span> : * before the beginning of an array." [24.4.1]/1,2 -<span class="lineNum"> 89 </span> : * -<span class="lineNum"> 90 </span> : * Reverse iterators can be tricky and surprising at first. Their -<span class="lineNum"> 91 </span> : * semantics make sense, however, and the trickiness is a side effect of -<span class="lineNum"> 92 </span> : * the requirement that the iterators must be safe. -<span class="lineNum"> 93 </span> : */ -<span class="lineNum"> 94 </span> : template<typename _Iterator> -<span class="lineNum"> 95 </span> : class reverse_iterator -<span class="lineNum"> 96 </span> : : public iterator<typename iterator_traits<_Iterator>::iterator_category, -<span class="lineNum"> 97 </span> : typename iterator_traits<_Iterator>::value_type, -<span class="lineNum"> 98 </span> : typename iterator_traits<_Iterator>::difference_type, -<span class="lineNum"> 99 </span> : typename iterator_traits<_Iterator>::pointer, -<span class="lineNum"> 100 </span> : typename iterator_traits<_Iterator>::reference> -<span class="lineNum"> 101 </span> : { -<span class="lineNum"> 102 </span> : protected: -<span class="lineNum"> 103 </span> : _Iterator current; -<span class="lineNum"> 104 </span> : -<span class="lineNum"> 105 </span> : public: -<span class="lineNum"> 106 </span> : typedef _Iterator iterator_type; -<span class="lineNum"> 107 </span> : typedef typename iterator_traits<_Iterator>::difference_type -<span class="lineNum"> 108 </span> : difference_type; -<span class="lineNum"> 109 </span> : typedef typename iterator_traits<_Iterator>::reference reference; -<span class="lineNum"> 110 </span> : typedef typename iterator_traits<_Iterator>::pointer pointer; -<span class="lineNum"> 111 </span> : -<span class="lineNum"> 112 </span> : public: -<span class="lineNum"> 113 </span> : /** -<span class="lineNum"> 114 </span> : * The default constructor default-initializes member @p current. -<span class="lineNum"> 115 </span> : * If it is a pointer, that means it is zero-initialized. -<span class="lineNum"> 116 </span> : */ -<span class="lineNum"> 117 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 118 </span> : // 235 No specification of default ctor for reverse_iterator -<span class="lineNum"> 119 </span> : reverse_iterator() : current() { } -<span class="lineNum"> 120 </span> : -<span class="lineNum"> 121 </span> : /** -<span class="lineNum"> 122 </span> : * This %iterator will move in the opposite direction that @p x does. -<span class="lineNum"> 123 </span> : */ -<span class="lineNum"> 124 </span> : explicit -<span class="lineNum"> 125 </span><span class="lineCov"> 34 : reverse_iterator(iterator_type __x) : current(__x) { }</span> -<span class="lineNum"> 126 </span> : -<span class="lineNum"> 127 </span> : /** -<span class="lineNum"> 128 </span> : * The copy constructor is normal. -<span class="lineNum"> 129 </span> : */ -<span class="lineNum"> 130 </span> : reverse_iterator(const reverse_iterator& __x) -<span class="lineNum"> 131 </span> : : current(__x.current) { } -<span class="lineNum"> 132 </span> : -<span class="lineNum"> 133 </span> : /** -<span class="lineNum"> 134 </span> : * A reverse_iterator across other types can be copied in the normal -<span class="lineNum"> 135 </span> : * fashion. -<span class="lineNum"> 136 </span> : */ -<span class="lineNum"> 137 </span> : template<typename _Iter> -<span class="lineNum"> 138 </span> : reverse_iterator(const reverse_iterator<_Iter>& __x) -<span class="lineNum"> 139 </span> : : current(__x.base()) { } -<span class="lineNum"> 140 </span> : -<span class="lineNum"> 141 </span> : /** -<span class="lineNum"> 142 </span> : * @return @c current, the %iterator used for underlying work. -<span class="lineNum"> 143 </span> : */ -<span class="lineNum"> 144 </span> : iterator_type -<span class="lineNum"> 145 </span> : base() const -<span class="lineNum"> 146 </span> : { return current; } -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : /** -<span class="lineNum"> 149 </span> : * @return TODO -<span class="lineNum"> 150 </span> : * -<span class="lineNum"> 151 </span> : * @doctodo -<span class="lineNum"> 152 </span> : */ -<span class="lineNum"> 153 </span> : reference -<span class="lineNum"> 154 </span><span class="lineCov"> 34 : operator*() const</span> -<span class="lineNum"> 155 </span> : { -<span class="lineNum"> 156 </span><span class="lineCov"> 34 : _Iterator __tmp = current;</span> -<span class="lineNum"> 157 </span><span class="lineCov"> 34 : return *--__tmp;</span> -<span class="lineNum"> 158 </span> : } -<span class="lineNum"> 159 </span> : -<span class="lineNum"> 160 </span> : /** -<span class="lineNum"> 161 </span> : * @return TODO -<span class="lineNum"> 162 </span> : * -<span class="lineNum"> 163 </span> : * @doctodo -<span class="lineNum"> 164 </span> : */ -<span class="lineNum"> 165 </span> : pointer -<span class="lineNum"> 166 </span><span class="lineCov"> 32 : operator->() const</span> -<span class="lineNum"> 167 </span><span class="lineCov"> 32 : { return &(operator*()); }</span> -<span class="lineNum"> 168 </span> : -<span class="lineNum"> 169 </span> : /** -<span class="lineNum"> 170 </span> : * @return TODO -<span class="lineNum"> 171 </span> : * -<span class="lineNum"> 172 </span> : * @doctodo -<span class="lineNum"> 173 </span> : */ -<span class="lineNum"> 174 </span> : reverse_iterator& -<span class="lineNum"> 175 </span> : operator++() -<span class="lineNum"> 176 </span> : { -<span class="lineNum"> 177 </span> : --current; -<span class="lineNum"> 178 </span> : return *this; -<span class="lineNum"> 179 </span> : } -<span class="lineNum"> 180 </span> : -<span class="lineNum"> 181 </span> : /** -<span class="lineNum"> 182 </span> : * @return TODO -<span class="lineNum"> 183 </span> : * -<span class="lineNum"> 184 </span> : * @doctodo -<span class="lineNum"> 185 </span> : */ -<span class="lineNum"> 186 </span> : reverse_iterator -<span class="lineNum"> 187 </span> : operator++(int) -<span class="lineNum"> 188 </span> : { -<span class="lineNum"> 189 </span> : reverse_iterator __tmp = *this; -<span class="lineNum"> 190 </span> : --current; -<span class="lineNum"> 191 </span> : return __tmp; -<span class="lineNum"> 192 </span> : } -<span class="lineNum"> 193 </span> : -<span class="lineNum"> 194 </span> : /** -<span class="lineNum"> 195 </span> : * @return TODO -<span class="lineNum"> 196 </span> : * -<span class="lineNum"> 197 </span> : * @doctodo -<span class="lineNum"> 198 </span> : */ -<span class="lineNum"> 199 </span> : reverse_iterator& -<span class="lineNum"> 200 </span> : operator--() -<span class="lineNum"> 201 </span> : { -<span class="lineNum"> 202 </span> : ++current; -<span class="lineNum"> 203 </span> : return *this; -<span class="lineNum"> 204 </span> : } -<span class="lineNum"> 205 </span> : -<span class="lineNum"> 206 </span> : /** -<span class="lineNum"> 207 </span> : * @return TODO -<span class="lineNum"> 208 </span> : * -<span class="lineNum"> 209 </span> : * @doctodo -<span class="lineNum"> 210 </span> : */ -<span class="lineNum"> 211 </span> : reverse_iterator -<span class="lineNum"> 212 </span> : operator--(int) -<span class="lineNum"> 213 </span> : { -<span class="lineNum"> 214 </span> : reverse_iterator __tmp = *this; -<span class="lineNum"> 215 </span> : ++current; -<span class="lineNum"> 216 </span> : return __tmp; -<span class="lineNum"> 217 </span> : } -<span class="lineNum"> 218 </span> : -<span class="lineNum"> 219 </span> : /** -<span class="lineNum"> 220 </span> : * @return TODO -<span class="lineNum"> 221 </span> : * -<span class="lineNum"> 222 </span> : * @doctodo -<span class="lineNum"> 223 </span> : */ -<span class="lineNum"> 224 </span> : reverse_iterator -<span class="lineNum"> 225 </span> : operator+(difference_type __n) const -<span class="lineNum"> 226 </span> : { return reverse_iterator(current - __n); } -<span class="lineNum"> 227 </span> : -<span class="lineNum"> 228 </span> : /** -<span class="lineNum"> 229 </span> : * @return TODO -<span class="lineNum"> 230 </span> : * -<span class="lineNum"> 231 </span> : * @doctodo -<span class="lineNum"> 232 </span> : */ -<span class="lineNum"> 233 </span> : reverse_iterator& -<span class="lineNum"> 234 </span> : operator+=(difference_type __n) -<span class="lineNum"> 235 </span> : { -<span class="lineNum"> 236 </span> : current -= __n; -<span class="lineNum"> 237 </span> : return *this; -<span class="lineNum"> 238 </span> : } -<span class="lineNum"> 239 </span> : -<span class="lineNum"> 240 </span> : /** -<span class="lineNum"> 241 </span> : * @return TODO -<span class="lineNum"> 242 </span> : * -<span class="lineNum"> 243 </span> : * @doctodo -<span class="lineNum"> 244 </span> : */ -<span class="lineNum"> 245 </span> : reverse_iterator -<span class="lineNum"> 246 </span> : operator-(difference_type __n) const -<span class="lineNum"> 247 </span> : { return reverse_iterator(current + __n); } -<span class="lineNum"> 248 </span> : -<span class="lineNum"> 249 </span> : /** -<span class="lineNum"> 250 </span> : * @return TODO -<span class="lineNum"> 251 </span> : * -<span class="lineNum"> 252 </span> : * @doctodo -<span class="lineNum"> 253 </span> : */ -<span class="lineNum"> 254 </span> : reverse_iterator& -<span class="lineNum"> 255 </span> : operator-=(difference_type __n) -<span class="lineNum"> 256 </span> : { -<span class="lineNum"> 257 </span> : current += __n; -<span class="lineNum"> 258 </span> : return *this; -<span class="lineNum"> 259 </span> : } -<span class="lineNum"> 260 </span> : -<span class="lineNum"> 261 </span> : /** -<span class="lineNum"> 262 </span> : * @return TODO -<span class="lineNum"> 263 </span> : * -<span class="lineNum"> 264 </span> : * @doctodo -<span class="lineNum"> 265 </span> : */ -<span class="lineNum"> 266 </span> : reference -<span class="lineNum"> 267 </span> : operator[](difference_type __n) const -<span class="lineNum"> 268 </span> : { return *(*this + __n); } -<span class="lineNum"> 269 </span> : }; -<span class="lineNum"> 270 </span> : -<span class="lineNum"> 271 </span> : //@{ -<span class="lineNum"> 272 </span> : /** -<span class="lineNum"> 273 </span> : * @param x A %reverse_iterator. -<span class="lineNum"> 274 </span> : * @param y A %reverse_iterator. -<span class="lineNum"> 275 </span> : * @return A simple bool. -<span class="lineNum"> 276 </span> : * -<span class="lineNum"> 277 </span> : * Reverse iterators forward many operations to their underlying base() -<span class="lineNum"> 278 </span> : * iterators. Others are implemented in terms of one another. -<span class="lineNum"> 279 </span> : * -<span class="lineNum"> 280 </span> : */ -<span class="lineNum"> 281 </span> : template<typename _Iterator> -<span class="lineNum"> 282 </span> : inline bool -<span class="lineNum"> 283 </span> : operator==(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 284 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 285 </span> : { return __x.base() == __y.base(); } -<span class="lineNum"> 286 </span> : -<span class="lineNum"> 287 </span> : template<typename _Iterator> -<span class="lineNum"> 288 </span> : inline bool -<span class="lineNum"> 289 </span> : operator<(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 290 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 291 </span> : { return __y.base() < __x.base(); } -<span class="lineNum"> 292 </span> : -<span class="lineNum"> 293 </span> : template<typename _Iterator> -<span class="lineNum"> 294 </span> : inline bool -<span class="lineNum"> 295 </span> : operator!=(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 296 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 297 </span> : { return !(__x == __y); } -<span class="lineNum"> 298 </span> : -<span class="lineNum"> 299 </span> : template<typename _Iterator> -<span class="lineNum"> 300 </span> : inline bool -<span class="lineNum"> 301 </span> : operator>(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 302 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 303 </span> : { return __y < __x; } -<span class="lineNum"> 304 </span> : -<span class="lineNum"> 305 </span> : template<typename _Iterator> -<span class="lineNum"> 306 </span> : inline bool -<span class="lineNum"> 307 </span> : operator<=(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 308 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 309 </span> : { return !(__y < __x); } -<span class="lineNum"> 310 </span> : -<span class="lineNum"> 311 </span> : template<typename _Iterator> -<span class="lineNum"> 312 </span> : inline bool -<span class="lineNum"> 313 </span> : operator>=(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 314 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 315 </span> : { return !(__x < __y); } -<span class="lineNum"> 316 </span> : -<span class="lineNum"> 317 </span> : template<typename _Iterator> -<span class="lineNum"> 318 </span> : inline typename reverse_iterator<_Iterator>::difference_type -<span class="lineNum"> 319 </span> : operator-(const reverse_iterator<_Iterator>& __x, -<span class="lineNum"> 320 </span> : const reverse_iterator<_Iterator>& __y) -<span class="lineNum"> 321 </span> : { return __y.base() - __x.base(); } -<span class="lineNum"> 322 </span> : -<span class="lineNum"> 323 </span> : template<typename _Iterator> -<span class="lineNum"> 324 </span> : inline reverse_iterator<_Iterator> -<span class="lineNum"> 325 </span> : operator+(typename reverse_iterator<_Iterator>::difference_type __n, -<span class="lineNum"> 326 </span> : const reverse_iterator<_Iterator>& __x) -<span class="lineNum"> 327 </span> : { return reverse_iterator<_Iterator>(__x.base() - __n); } -<span class="lineNum"> 328 </span> : -<span class="lineNum"> 329 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 330 </span> : // DR 280. Comparison of reverse_iterator to const reverse_iterator. -<span class="lineNum"> 331 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 332 </span> : inline bool -<span class="lineNum"> 333 </span> : operator==(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 334 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 335 </span> : { return __x.base() == __y.base(); } -<span class="lineNum"> 336 </span> : -<span class="lineNum"> 337 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 338 </span> : inline bool -<span class="lineNum"> 339 </span> : operator<(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 340 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 341 </span> : { return __y.base() < __x.base(); } -<span class="lineNum"> 342 </span> : -<span class="lineNum"> 343 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 344 </span> : inline bool -<span class="lineNum"> 345 </span> : operator!=(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 346 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 347 </span> : { return !(__x == __y); } -<span class="lineNum"> 348 </span> : -<span class="lineNum"> 349 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 350 </span> : inline bool -<span class="lineNum"> 351 </span> : operator>(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 352 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 353 </span> : { return __y < __x; } -<span class="lineNum"> 354 </span> : -<span class="lineNum"> 355 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 356 </span> : inline bool -<span class="lineNum"> 357 </span> : operator<=(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 358 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 359 </span> : { return !(__y < __x); } -<span class="lineNum"> 360 </span> : -<span class="lineNum"> 361 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 362 </span> : inline bool -<span class="lineNum"> 363 </span> : operator>=(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 364 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 365 </span> : { return !(__x < __y); } -<span class="lineNum"> 366 </span> : -<span class="lineNum"> 367 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 368 </span> : inline typename reverse_iterator<_IteratorL>::difference_type -<span class="lineNum"> 369 </span> : operator-(const reverse_iterator<_IteratorL>& __x, -<span class="lineNum"> 370 </span> : const reverse_iterator<_IteratorR>& __y) -<span class="lineNum"> 371 </span> : { return __y.base() - __x.base(); } -<span class="lineNum"> 372 </span> : //@} -<span class="lineNum"> 373 </span> : -<span class="lineNum"> 374 </span> : // 24.4.2.2.1 back_insert_iterator -<span class="lineNum"> 375 </span> : /** -<span class="lineNum"> 376 </span> : * @brief Turns assignment into insertion. -<span class="lineNum"> 377 </span> : * -<span class="lineNum"> 378 </span> : * These are output iterators, constructed from a container-of-T. -<span class="lineNum"> 379 </span> : * Assigning a T to the iterator appends it to the container using -<span class="lineNum"> 380 </span> : * push_back. -<span class="lineNum"> 381 </span> : * -<span class="lineNum"> 382 </span> : * Tip: Using the back_inserter function to create these iterators can -<span class="lineNum"> 383 </span> : * save typing. -<span class="lineNum"> 384 </span> : */ -<span class="lineNum"> 385 </span> : template<typename _Container> -<span class="lineNum"> 386 </span> : class back_insert_iterator -<span class="lineNum"> 387 </span> : : public iterator<output_iterator_tag, void, void, void, void> -<span class="lineNum"> 388 </span> : { -<span class="lineNum"> 389 </span> : protected: -<span class="lineNum"> 390 </span> : _Container* container; -<span class="lineNum"> 391 </span> : -<span class="lineNum"> 392 </span> : public: -<span class="lineNum"> 393 </span> : /// A nested typedef for the type of whatever container you used. -<span class="lineNum"> 394 </span> : typedef _Container container_type; -<span class="lineNum"> 395 </span> : -<span class="lineNum"> 396 </span> : /// The only way to create this %iterator is with a container. -<span class="lineNum"> 397 </span> : explicit -<span class="lineNum"> 398 </span><span class="lineCov"> 946 : back_insert_iterator(_Container& __x) : container(&__x) { }</span> -<span class="lineNum"> 399 </span> : -<span class="lineNum"> 400 </span> : /** -<span class="lineNum"> 401 </span> : * @param value An instance of whatever type -<span class="lineNum"> 402 </span> : * container_type::const_reference is; presumably a -<span class="lineNum"> 403 </span> : * reference-to-const T for container<T>. -<span class="lineNum"> 404 </span> : * @return This %iterator, for chained operations. -<span class="lineNum"> 405 </span> : * -<span class="lineNum"> 406 </span> : * This kind of %iterator doesn't really have a "position" in the -<span class="lineNum"> 407 </span> : * container (you can think of the position as being permanently at -<span class="lineNum"> 408 </span> : * the end, if you like). Assigning a value to the %iterator will -<span class="lineNum"> 409 </span> : * always append the value to the end of the container. -<span class="lineNum"> 410 </span> : */ -<span class="lineNum"> 411 </span> : back_insert_iterator& -<span class="lineNum"> 412 </span><span class="lineCov"> 17415 : operator=(typename _Container::const_reference __value)</span> -<span class="lineNum"> 413 </span> : { -<span class="lineNum"> 414 </span><span class="lineCov"> 17415 : container->push_back(__value);</span> -<span class="lineNum"> 415 </span><span class="lineCov"> 17415 : return *this;</span> -<span class="lineNum"> 416 </span> : } -<span class="lineNum"> 417 </span> : -<span class="lineNum"> 418 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 419 </span> : back_insert_iterator& -<span class="lineNum"> 420 </span> : operator=(typename _Container::value_type&& __value) -<span class="lineNum"> 421 </span> : { -<span class="lineNum"> 422 </span> : container->push_back(std::move(__value)); -<span class="lineNum"> 423 </span> : return *this; -<span class="lineNum"> 424 </span> : } -<span class="lineNum"> 425 </span> : #endif -<span class="lineNum"> 426 </span> : -<span class="lineNum"> 427 </span> : /// Simply returns *this. -<span class="lineNum"> 428 </span> : back_insert_iterator& -<span class="lineNum"> 429 </span><span class="lineCov"> 17419 : operator*()</span> -<span class="lineNum"> 430 </span><span class="lineCov"> 17419 : { return *this; }</span> -<span class="lineNum"> 431 </span> : -<span class="lineNum"> 432 </span> : /// Simply returns *this. (This %iterator does not "move".) -<span class="lineNum"> 433 </span> : back_insert_iterator& -<span class="lineNum"> 434 </span><span class="lineCov"> 17405 : operator++()</span> -<span class="lineNum"> 435 </span><span class="lineCov"> 17405 : { return *this; }</span> -<span class="lineNum"> 436 </span> : -<span class="lineNum"> 437 </span> : /// Simply returns *this. (This %iterator does not "move".) -<span class="lineNum"> 438 </span> : back_insert_iterator -<span class="lineNum"> 439 </span><span class="lineCov"> 10 : operator++(int)</span> -<span class="lineNum"> 440 </span><span class="lineCov"> 10 : { return *this; }</span> -<span class="lineNum"> 441 </span> : }; -<span class="lineNum"> 442 </span> : -<span class="lineNum"> 443 </span> : /** -<span class="lineNum"> 444 </span> : * @param x A container of arbitrary type. -<span class="lineNum"> 445 </span> : * @return An instance of back_insert_iterator working on @p x. -<span class="lineNum"> 446 </span> : * -<span class="lineNum"> 447 </span> : * This wrapper function helps in creating back_insert_iterator instances. -<span class="lineNum"> 448 </span> : * Typing the name of the %iterator requires knowing the precise full -<span class="lineNum"> 449 </span> : * type of the container, which can be tedious and impedes generic -<span class="lineNum"> 450 </span> : * programming. Using this function lets you take advantage of automatic -<span class="lineNum"> 451 </span> : * template parameter deduction, making the compiler match the correct -<span class="lineNum"> 452 </span> : * types for you. -<span class="lineNum"> 453 </span> : */ -<span class="lineNum"> 454 </span> : template<typename _Container> -<span class="lineNum"> 455 </span> : inline back_insert_iterator<_Container> -<span class="lineNum"> 456 </span><span class="lineCov"> 946 : back_inserter(_Container& __x)</span> -<span class="lineNum"> 457 </span><span class="lineCov"> 946 : { return back_insert_iterator<_Container>(__x); }</span> -<span class="lineNum"> 458 </span> : -<span class="lineNum"> 459 </span> : /** -<span class="lineNum"> 460 </span> : * @brief Turns assignment into insertion. -<span class="lineNum"> 461 </span> : * -<span class="lineNum"> 462 </span> : * These are output iterators, constructed from a container-of-T. -<span class="lineNum"> 463 </span> : * Assigning a T to the iterator prepends it to the container using -<span class="lineNum"> 464 </span> : * push_front. -<span class="lineNum"> 465 </span> : * -<span class="lineNum"> 466 </span> : * Tip: Using the front_inserter function to create these iterators can -<span class="lineNum"> 467 </span> : * save typing. -<span class="lineNum"> 468 </span> : */ -<span class="lineNum"> 469 </span> : template<typename _Container> -<span class="lineNum"> 470 </span> : class front_insert_iterator -<span class="lineNum"> 471 </span> : : public iterator<output_iterator_tag, void, void, void, void> -<span class="lineNum"> 472 </span> : { -<span class="lineNum"> 473 </span> : protected: -<span class="lineNum"> 474 </span> : _Container* container; -<span class="lineNum"> 475 </span> : -<span class="lineNum"> 476 </span> : public: -<span class="lineNum"> 477 </span> : /// A nested typedef for the type of whatever container you used. -<span class="lineNum"> 478 </span> : typedef _Container container_type; -<span class="lineNum"> 479 </span> : -<span class="lineNum"> 480 </span> : /// The only way to create this %iterator is with a container. -<span class="lineNum"> 481 </span> : explicit front_insert_iterator(_Container& __x) : container(&__x) { } -<span class="lineNum"> 482 </span> : -<span class="lineNum"> 483 </span> : /** -<span class="lineNum"> 484 </span> : * @param value An instance of whatever type -<span class="lineNum"> 485 </span> : * container_type::const_reference is; presumably a -<span class="lineNum"> 486 </span> : * reference-to-const T for container<T>. -<span class="lineNum"> 487 </span> : * @return This %iterator, for chained operations. -<span class="lineNum"> 488 </span> : * -<span class="lineNum"> 489 </span> : * This kind of %iterator doesn't really have a "position" in the -<span class="lineNum"> 490 </span> : * container (you can think of the position as being permanently at -<span class="lineNum"> 491 </span> : * the front, if you like). Assigning a value to the %iterator will -<span class="lineNum"> 492 </span> : * always prepend the value to the front of the container. -<span class="lineNum"> 493 </span> : */ -<span class="lineNum"> 494 </span> : front_insert_iterator& -<span class="lineNum"> 495 </span> : operator=(typename _Container::const_reference __value) -<span class="lineNum"> 496 </span> : { -<span class="lineNum"> 497 </span> : container->push_front(__value); -<span class="lineNum"> 498 </span> : return *this; -<span class="lineNum"> 499 </span> : } -<span class="lineNum"> 500 </span> : -<span class="lineNum"> 501 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 502 </span> : front_insert_iterator& -<span class="lineNum"> 503 </span> : operator=(typename _Container::value_type&& __value) -<span class="lineNum"> 504 </span> : { -<span class="lineNum"> 505 </span> : container->push_front(std::move(__value)); -<span class="lineNum"> 506 </span> : return *this; -<span class="lineNum"> 507 </span> : } -<span class="lineNum"> 508 </span> : #endif -<span class="lineNum"> 509 </span> : -<span class="lineNum"> 510 </span> : /// Simply returns *this. -<span class="lineNum"> 511 </span> : front_insert_iterator& -<span class="lineNum"> 512 </span> : operator*() -<span class="lineNum"> 513 </span> : { return *this; } -<span class="lineNum"> 514 </span> : -<span class="lineNum"> 515 </span> : /// Simply returns *this. (This %iterator does not "move".) -<span class="lineNum"> 516 </span> : front_insert_iterator& -<span class="lineNum"> 517 </span> : operator++() -<span class="lineNum"> 518 </span> : { return *this; } -<span class="lineNum"> 519 </span> : -<span class="lineNum"> 520 </span> : /// Simply returns *this. (This %iterator does not "move".) -<span class="lineNum"> 521 </span> : front_insert_iterator -<span class="lineNum"> 522 </span> : operator++(int) -<span class="lineNum"> 523 </span> : { return *this; } -<span class="lineNum"> 524 </span> : }; -<span class="lineNum"> 525 </span> : -<span class="lineNum"> 526 </span> : /** -<span class="lineNum"> 527 </span> : * @param x A container of arbitrary type. -<span class="lineNum"> 528 </span> : * @return An instance of front_insert_iterator working on @p x. -<span class="lineNum"> 529 </span> : * -<span class="lineNum"> 530 </span> : * This wrapper function helps in creating front_insert_iterator instances. -<span class="lineNum"> 531 </span> : * Typing the name of the %iterator requires knowing the precise full -<span class="lineNum"> 532 </span> : * type of the container, which can be tedious and impedes generic -<span class="lineNum"> 533 </span> : * programming. Using this function lets you take advantage of automatic -<span class="lineNum"> 534 </span> : * template parameter deduction, making the compiler match the correct -<span class="lineNum"> 535 </span> : * types for you. -<span class="lineNum"> 536 </span> : */ -<span class="lineNum"> 537 </span> : template<typename _Container> -<span class="lineNum"> 538 </span> : inline front_insert_iterator<_Container> -<span class="lineNum"> 539 </span> : front_inserter(_Container& __x) -<span class="lineNum"> 540 </span> : { return front_insert_iterator<_Container>(__x); } -<span class="lineNum"> 541 </span> : -<span class="lineNum"> 542 </span> : /** -<span class="lineNum"> 543 </span> : * @brief Turns assignment into insertion. -<span class="lineNum"> 544 </span> : * -<span class="lineNum"> 545 </span> : * These are output iterators, constructed from a container-of-T. -<span class="lineNum"> 546 </span> : * Assigning a T to the iterator inserts it in the container at the -<span class="lineNum"> 547 </span> : * %iterator's position, rather than overwriting the value at that -<span class="lineNum"> 548 </span> : * position. -<span class="lineNum"> 549 </span> : * -<span class="lineNum"> 550 </span> : * (Sequences will actually insert a @e copy of the value before the -<span class="lineNum"> 551 </span> : * %iterator's position.) -<span class="lineNum"> 552 </span> : * -<span class="lineNum"> 553 </span> : * Tip: Using the inserter function to create these iterators can -<span class="lineNum"> 554 </span> : * save typing. -<span class="lineNum"> 555 </span> : */ -<span class="lineNum"> 556 </span> : template<typename _Container> -<span class="lineNum"> 557 </span> : class insert_iterator -<span class="lineNum"> 558 </span> : : public iterator<output_iterator_tag, void, void, void, void> -<span class="lineNum"> 559 </span> : { -<span class="lineNum"> 560 </span> : protected: -<span class="lineNum"> 561 </span> : _Container* container; -<span class="lineNum"> 562 </span> : typename _Container::iterator iter; -<span class="lineNum"> 563 </span> : -<span class="lineNum"> 564 </span> : public: -<span class="lineNum"> 565 </span> : /// A nested typedef for the type of whatever container you used. -<span class="lineNum"> 566 </span> : typedef _Container container_type; -<span class="lineNum"> 567 </span> : -<span class="lineNum"> 568 </span> : /** -<span class="lineNum"> 569 </span> : * The only way to create this %iterator is with a container and an -<span class="lineNum"> 570 </span> : * initial position (a normal %iterator into the container). -<span class="lineNum"> 571 </span> : */ -<span class="lineNum"> 572 </span><span class="lineCov"> 21203 : insert_iterator(_Container& __x, typename _Container::iterator __i)</span> -<span class="lineNum"> 573 </span><span class="lineCov"> 21203 : : container(&__x), iter(__i) {}</span> -<span class="lineNum"> 574 </span> : -<span class="lineNum"> 575 </span> : /** -<span class="lineNum"> 576 </span> : * @param value An instance of whatever type -<span class="lineNum"> 577 </span> : * container_type::const_reference is; presumably a -<span class="lineNum"> 578 </span> : * reference-to-const T for container<T>. -<span class="lineNum"> 579 </span> : * @return This %iterator, for chained operations. -<span class="lineNum"> 580 </span> : * -<span class="lineNum"> 581 </span> : * This kind of %iterator maintains its own position in the -<span class="lineNum"> 582 </span> : * container. Assigning a value to the %iterator will insert the -<span class="lineNum"> 583 </span> : * value into the container at the place before the %iterator. -<span class="lineNum"> 584 </span> : * -<span class="lineNum"> 585 </span> : * The position is maintained such that subsequent assignments will -<span class="lineNum"> 586 </span> : * insert values immediately after one another. For example, -<span class="lineNum"> 587 </span> : * @code -<span class="lineNum"> 588 </span> : * // vector v contains A and Z -<span class="lineNum"> 589 </span> : * -<span class="lineNum"> 590 </span> : * insert_iterator i (v, ++v.begin()); -<span class="lineNum"> 591 </span> : * i = 1; -<span class="lineNum"> 592 </span> : * i = 2; -<span class="lineNum"> 593 </span> : * i = 3; -<span class="lineNum"> 594 </span> : * -<span class="lineNum"> 595 </span> : * // vector v contains A, 1, 2, 3, and Z -<span class="lineNum"> 596 </span> : * @endcode -<span class="lineNum"> 597 </span> : */ -<span class="lineNum"> 598 </span> : insert_iterator& -<span class="lineNum"> 599 </span><span class="lineCov"> 107622 : operator=(typename _Container::const_reference __value)</span> -<span class="lineNum"> 600 </span> : { -<span class="lineNum"> 601 </span><span class="lineCov"> 107622 : iter = container->insert(iter, __value);</span> -<span class="lineNum"> 602 </span><span class="lineCov"> 107622 : ++iter;</span> -<span class="lineNum"> 603 </span><span class="lineCov"> 107622 : return *this;</span> -<span class="lineNum"> 604 </span> : } -<span class="lineNum"> 605 </span> : -<span class="lineNum"> 606 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 607 </span> : insert_iterator& -<span class="lineNum"> 608 </span> : operator=(typename _Container::value_type&& __value) -<span class="lineNum"> 609 </span> : { -<span class="lineNum"> 610 </span> : iter = container->insert(iter, std::move(__value)); -<span class="lineNum"> 611 </span> : ++iter; -<span class="lineNum"> 612 </span> : return *this; -<span class="lineNum"> 613 </span> : } -<span class="lineNum"> 614 </span> : #endif -<span class="lineNum"> 615 </span> : -<span class="lineNum"> 616 </span> : /// Simply returns *this. -<span class="lineNum"> 617 </span> : insert_iterator& -<span class="lineNum"> 618 </span><span class="lineCov"> 107650 : operator*()</span> -<span class="lineNum"> 619 </span><span class="lineCov"> 107650 : { return *this; }</span> -<span class="lineNum"> 620 </span> : -<span class="lineNum"> 621 </span> : /// Simply returns *this. (This %iterator does not "move".) -<span class="lineNum"> 622 </span> : insert_iterator& -<span class="lineNum"> 623 </span><span class="lineCov"> 107622 : operator++()</span> -<span class="lineNum"> 624 </span><span class="lineCov"> 107622 : { return *this; }</span> -<span class="lineNum"> 625 </span> : -<span class="lineNum"> 626 </span> : /// Simply returns *this. (This %iterator does not "move".) -<span class="lineNum"> 627 </span> : insert_iterator& -<span class="lineNum"> 628 </span><span class="lineNoCov"> 0 : operator++(int)</span> -<span class="lineNum"> 629 </span><span class="lineNoCov"> 0 : { return *this; }</span> -<span class="lineNum"> 630 </span> : }; -<span class="lineNum"> 631 </span> : -<span class="lineNum"> 632 </span> : /** -<span class="lineNum"> 633 </span> : * @param x A container of arbitrary type. -<span class="lineNum"> 634 </span> : * @return An instance of insert_iterator working on @p x. -<span class="lineNum"> 635 </span> : * -<span class="lineNum"> 636 </span> : * This wrapper function helps in creating insert_iterator instances. -<span class="lineNum"> 637 </span> : * Typing the name of the %iterator requires knowing the precise full -<span class="lineNum"> 638 </span> : * type of the container, which can be tedious and impedes generic -<span class="lineNum"> 639 </span> : * programming. Using this function lets you take advantage of automatic -<span class="lineNum"> 640 </span> : * template parameter deduction, making the compiler match the correct -<span class="lineNum"> 641 </span> : * types for you. -<span class="lineNum"> 642 </span> : */ -<span class="lineNum"> 643 </span> : template<typename _Container, typename _Iterator> -<span class="lineNum"> 644 </span> : inline insert_iterator<_Container> -<span class="lineNum"> 645 </span><span class="lineCov"> 21203 : inserter(_Container& __x, _Iterator __i)</span> -<span class="lineNum"> 646 </span> : { -<span class="lineNum"> 647 </span> : return insert_iterator<_Container>(__x, -<span class="lineNum"> 648 </span><span class="lineCov"> 21203 : typename _Container::iterator(__i));</span> -<span class="lineNum"> 649 </span> : } -<span class="lineNum"> 650 </span> : -<span class="lineNum"> 651 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 652 </span> : -<span class="lineNum"> 653 </span> : _GLIBCXX_BEGIN_NAMESPACE(__gnu_cxx) -<span class="lineNum"> 654 </span> : -<span class="lineNum"> 655 </span> : // This iterator adapter is 'normal' in the sense that it does not -<span class="lineNum"> 656 </span> : // change the semantics of any of the operators of its iterator -<span class="lineNum"> 657 </span> : // parameter. Its primary purpose is to convert an iterator that is -<span class="lineNum"> 658 </span> : // not a class, e.g. a pointer, into an iterator that is a class. -<span class="lineNum"> 659 </span> : // The _Container parameter exists solely so that different containers -<span class="lineNum"> 660 </span> : // using this template can instantiate different types, even if the -<span class="lineNum"> 661 </span> : // _Iterator parameter is the same. -<span class="lineNum"> 662 </span> : using std::iterator_traits; -<span class="lineNum"> 663 </span> : using std::iterator; -<span class="lineNum"> 664 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 665 </span> : class __normal_iterator -<span class="lineNum"> 666 </span> : { -<span class="lineNum"> 667 </span> : protected: -<span class="lineNum"> 668 </span> : _Iterator _M_current; -<span class="lineNum"> 669 </span> : -<span class="lineNum"> 670 </span> : public: -<span class="lineNum"> 671 </span> : typedef _Iterator iterator_type; -<span class="lineNum"> 672 </span> : typedef typename iterator_traits<_Iterator>::iterator_category -<span class="lineNum"> 673 </span> : iterator_category; -<span class="lineNum"> 674 </span> : typedef typename iterator_traits<_Iterator>::value_type value_type; -<span class="lineNum"> 675 </span> : typedef typename iterator_traits<_Iterator>::difference_type -<span class="lineNum"> 676 </span> : difference_type; -<span class="lineNum"> 677 </span> : typedef typename iterator_traits<_Iterator>::reference reference; -<span class="lineNum"> 678 </span> : typedef typename iterator_traits<_Iterator>::pointer pointer; -<span class="lineNum"> 679 </span> : -<span class="lineNum"> 680 </span><span class="lineCov"> 3 : __normal_iterator() : _M_current(_Iterator()) { }</span> -<span class="lineNum"> 681 </span> : -<span class="lineNum"> 682 </span> : explicit -<span class="lineNum"> 683 </span><span class="lineCov"> 150393 : __normal_iterator(const _Iterator& __i) : _M_current(__i) { }</span> -<span class="lineNum"> 684 </span> : -<span class="lineNum"> 685 </span> : // Allow iterator to const_iterator conversion -<span class="lineNum"> 686 </span> : template<typename _Iter> -<span class="lineNum"> 687 </span> : __normal_iterator(const __normal_iterator<_Iter, -<span class="lineNum"> 688 </span> : typename __enable_if< -<span class="lineNum"> 689 </span> : (std::__are_same<_Iter, typename _Container::pointer>::__value), -<span class="lineNum"> 690 </span><span class="lineCov"> 28 : _Container>::__type>& __i)</span> -<span class="lineNum"> 691 </span><span class="lineCov"> 28 : : _M_current(__i.base()) { }</span> -<span class="lineNum"> 692 </span> : -<span class="lineNum"> 693 </span> : // Forward iterator requirements -<span class="lineNum"> 694 </span> : reference -<span class="lineNum"> 695 </span><span class="lineCov"> 925025 : operator*() const</span> -<span class="lineNum"> 696 </span><span class="lineCov"> 925025 : { return *_M_current; }</span> -<span class="lineNum"> 697 </span> : -<span class="lineNum"> 698 </span> : pointer -<span class="lineNum"> 699 </span><span class="lineCov"> 3 : operator->() const</span> -<span class="lineNum"> 700 </span><span class="lineCov"> 3 : { return _M_current; }</span> -<span class="lineNum"> 701 </span> : -<span class="lineNum"> 702 </span> : __normal_iterator& -<span class="lineNum"> 703 </span><span class="lineCov"> 81617 : operator++()</span> -<span class="lineNum"> 704 </span> : { -<span class="lineNum"> 705 </span><span class="lineCov"> 81617 : ++_M_current;</span> -<span class="lineNum"> 706 </span><span class="lineCov"> 81617 : return *this;</span> -<span class="lineNum"> 707 </span> : } -<span class="lineNum"> 708 </span> : -<span class="lineNum"> 709 </span> : __normal_iterator -<span class="lineNum"> 710 </span><span class="lineCov"> 54836 : operator++(int)</span> -<span class="lineNum"> 711 </span><span class="lineCov"> 54836 : { return __normal_iterator(_M_current++); }</span> -<span class="lineNum"> 712 </span> : -<span class="lineNum"> 713 </span> : // Bidirectional iterator requirements -<span class="lineNum"> 714 </span> : __normal_iterator& -<span class="lineNum"> 715 </span><span class="lineCov"> 249605 : operator--()</span> -<span class="lineNum"> 716 </span> : { -<span class="lineNum"> 717 </span><span class="lineCov"> 249605 : --_M_current;</span> -<span class="lineNum"> 718 </span><span class="lineCov"> 249605 : return *this;</span> -<span class="lineNum"> 719 </span> : } -<span class="lineNum"> 720 </span> : -<span class="lineNum"> 721 </span> : __normal_iterator -<span class="lineNum"> 722 </span><span class="lineNoCov"> 0 : operator--(int)</span> -<span class="lineNum"> 723 </span><span class="lineNoCov"> 0 : { return __normal_iterator(_M_current--); }</span> -<span class="lineNum"> 724 </span> : -<span class="lineNum"> 725 </span> : // Random access iterator requirements -<span class="lineNum"> 726 </span> : reference -<span class="lineNum"> 727 </span> : operator[](const difference_type& __n) const -<span class="lineNum"> 728 </span> : { return _M_current[__n]; } -<span class="lineNum"> 729 </span> : -<span class="lineNum"> 730 </span> : __normal_iterator& -<span class="lineNum"> 731 </span> : operator+=(const difference_type& __n) -<span class="lineNum"> 732 </span> : { _M_current += __n; return *this; } -<span class="lineNum"> 733 </span> : -<span class="lineNum"> 734 </span> : __normal_iterator -<span class="lineNum"> 735 </span><span class="lineCov"> 13455 : operator+(const difference_type& __n) const</span> -<span class="lineNum"> 736 </span><span class="lineCov"> 13455 : { return __normal_iterator(_M_current + __n); }</span> -<span class="lineNum"> 737 </span> : -<span class="lineNum"> 738 </span> : __normal_iterator& -<span class="lineNum"> 739 </span> : operator-=(const difference_type& __n) -<span class="lineNum"> 740 </span> : { _M_current -= __n; return *this; } -<span class="lineNum"> 741 </span> : -<span class="lineNum"> 742 </span> : __normal_iterator -<span class="lineNum"> 743 </span><span class="lineCov"> 846 : operator-(const difference_type& __n) const</span> -<span class="lineNum"> 744 </span><span class="lineCov"> 846 : { return __normal_iterator(_M_current - __n); }</span> -<span class="lineNum"> 745 </span> : -<span class="lineNum"> 746 </span> : const _Iterator& -<span class="lineNum"> 747 </span><span class="lineCov"> 455202 : base() const</span> -<span class="lineNum"> 748 </span><span class="lineCov"> 455202 : { return _M_current; }</span> -<span class="lineNum"> 749 </span> : }; -<span class="lineNum"> 750 </span> : -<span class="lineNum"> 751 </span> : // Note: In what follows, the left- and right-hand-side iterators are -<span class="lineNum"> 752 </span> : // allowed to vary in types (conceptually in cv-qualification) so that -<span class="lineNum"> 753 </span> : // comparison between cv-qualified and non-cv-qualified iterators be -<span class="lineNum"> 754 </span> : // valid. However, the greedy and unfriendly operators in std::rel_ops -<span class="lineNum"> 755 </span> : // will make overload resolution ambiguous (when in scope) if we don't -<span class="lineNum"> 756 </span> : // provide overloads whose operands are of the same type. Can someone -<span class="lineNum"> 757 </span> : // remind me what generic programming is about? -- Gaby -<span class="lineNum"> 758 </span> : -<span class="lineNum"> 759 </span> : // Forward iterator requirements -<span class="lineNum"> 760 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 761 </span> : inline bool -<span class="lineNum"> 762 </span> : operator==(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 763 </span> : const __normal_iterator<_IteratorR, _Container>& __rhs) -<span class="lineNum"> 764 </span> : { return __lhs.base() == __rhs.base(); } -<span class="lineNum"> 765 </span> : -<span class="lineNum"> 766 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 767 </span> : inline bool -<span class="lineNum"> 768 </span> : operator==(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 769 </span><span class="lineCov"> 4368 : const __normal_iterator<_Iterator, _Container>& __rhs)</span> -<span class="lineNum"> 770 </span><span class="lineCov"> 4368 : { return __lhs.base() == __rhs.base(); }</span> -<span class="lineNum"> 771 </span> : -<span class="lineNum"> 772 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 773 </span> : inline bool -<span class="lineNum"> 774 </span> : operator!=(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 775 </span><span class="lineCov"> 38 : const __normal_iterator<_IteratorR, _Container>& __rhs)</span> -<span class="lineNum"> 776 </span><span class="lineCov"> 38 : { return __lhs.base() != __rhs.base(); }</span> -<span class="lineNum"> 777 </span> : -<span class="lineNum"> 778 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 779 </span> : inline bool -<span class="lineNum"> 780 </span> : operator!=(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 781 </span><span class="lineCov"> 123290 : const __normal_iterator<_Iterator, _Container>& __rhs)</span> -<span class="lineNum"> 782 </span><span class="lineCov"> 123290 : { return __lhs.base() != __rhs.base(); }</span> -<span class="lineNum"> 783 </span> : -<span class="lineNum"> 784 </span> : // Random access iterator requirements -<span class="lineNum"> 785 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 786 </span> : inline bool -<span class="lineNum"> 787 </span> : operator<(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 788 </span> : const __normal_iterator<_IteratorR, _Container>& __rhs) -<span class="lineNum"> 789 </span> : { return __lhs.base() < __rhs.base(); } -<span class="lineNum"> 790 </span> : -<span class="lineNum"> 791 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 792 </span> : inline bool -<span class="lineNum"> 793 </span> : operator<(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 794 </span><span class="lineCov"> 7923 : const __normal_iterator<_Iterator, _Container>& __rhs)</span> -<span class="lineNum"> 795 </span><span class="lineCov"> 7923 : { return __lhs.base() < __rhs.base(); }</span> -<span class="lineNum"> 796 </span> : -<span class="lineNum"> 797 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 798 </span> : inline bool -<span class="lineNum"> 799 </span> : operator>(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 800 </span> : const __normal_iterator<_IteratorR, _Container>& __rhs) -<span class="lineNum"> 801 </span> : { return __lhs.base() > __rhs.base(); } -<span class="lineNum"> 802 </span> : -<span class="lineNum"> 803 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 804 </span> : inline bool -<span class="lineNum"> 805 </span> : operator>(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 806 </span> : const __normal_iterator<_Iterator, _Container>& __rhs) -<span class="lineNum"> 807 </span> : { return __lhs.base() > __rhs.base(); } -<span class="lineNum"> 808 </span> : -<span class="lineNum"> 809 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 810 </span> : inline bool -<span class="lineNum"> 811 </span> : operator<=(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 812 </span> : const __normal_iterator<_IteratorR, _Container>& __rhs) -<span class="lineNum"> 813 </span> : { return __lhs.base() <= __rhs.base(); } -<span class="lineNum"> 814 </span> : -<span class="lineNum"> 815 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 816 </span> : inline bool -<span class="lineNum"> 817 </span> : operator<=(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 818 </span> : const __normal_iterator<_Iterator, _Container>& __rhs) -<span class="lineNum"> 819 </span> : { return __lhs.base() <= __rhs.base(); } -<span class="lineNum"> 820 </span> : -<span class="lineNum"> 821 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 822 </span> : inline bool -<span class="lineNum"> 823 </span> : operator>=(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 824 </span> : const __normal_iterator<_IteratorR, _Container>& __rhs) -<span class="lineNum"> 825 </span> : { return __lhs.base() >= __rhs.base(); } -<span class="lineNum"> 826 </span> : -<span class="lineNum"> 827 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 828 </span> : inline bool -<span class="lineNum"> 829 </span> : operator>=(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 830 </span> : const __normal_iterator<_Iterator, _Container>& __rhs) -<span class="lineNum"> 831 </span> : { return __lhs.base() >= __rhs.base(); } -<span class="lineNum"> 832 </span> : -<span class="lineNum"> 833 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 834 </span> : // According to the resolution of DR179 not only the various comparison -<span class="lineNum"> 835 </span> : // operators but also operator- must accept mixed iterator/const_iterator -<span class="lineNum"> 836 </span> : // parameters. -<span class="lineNum"> 837 </span> : template<typename _IteratorL, typename _IteratorR, typename _Container> -<span class="lineNum"> 838 </span> : inline typename __normal_iterator<_IteratorL, _Container>::difference_type -<span class="lineNum"> 839 </span> : operator-(const __normal_iterator<_IteratorL, _Container>& __lhs, -<span class="lineNum"> 840 </span> : const __normal_iterator<_IteratorR, _Container>& __rhs) -<span class="lineNum"> 841 </span> : { return __lhs.base() - __rhs.base(); } -<span class="lineNum"> 842 </span> : -<span class="lineNum"> 843 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 844 </span> : inline typename __normal_iterator<_Iterator, _Container>::difference_type -<span class="lineNum"> 845 </span> : operator-(const __normal_iterator<_Iterator, _Container>& __lhs, -<span class="lineNum"> 846 </span><span class="lineCov"> 37193 : const __normal_iterator<_Iterator, _Container>& __rhs)</span> -<span class="lineNum"> 847 </span><span class="lineCov"> 37193 : { return __lhs.base() - __rhs.base(); }</span> -<span class="lineNum"> 848 </span> : -<span class="lineNum"> 849 </span> : template<typename _Iterator, typename _Container> -<span class="lineNum"> 850 </span> : inline __normal_iterator<_Iterator, _Container> -<span class="lineNum"> 851 </span> : operator+(typename __normal_iterator<_Iterator, _Container>::difference_type -<span class="lineNum"> 852 </span> : __n, const __normal_iterator<_Iterator, _Container>& __i) -<span class="lineNum"> 853 </span> : { return __normal_iterator<_Iterator, _Container>(__i.base() + __n); } -<span class="lineNum"> 854 </span> : -<span class="lineNum"> 855 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 856 </span> : -<span class="lineNum"> 857 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 858 </span> : -<span class="lineNum"> 859 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 860 </span> : -<span class="lineNum"> 861 </span> : // 24.4.3 Move iterators -<span class="lineNum"> 862 </span> : /** -<span class="lineNum"> 863 </span> : * Class template move_iterator is an iterator adapter with the same -<span class="lineNum"> 864 </span> : * behavior as the underlying iterator except that its dereference -<span class="lineNum"> 865 </span> : * operator implicitly converts the value returned by the underlying -<span class="lineNum"> 866 </span> : * iterator's dereference operator to an rvalue reference. Some -<span class="lineNum"> 867 </span> : * generic algorithms can be called with move iterators to replace -<span class="lineNum"> 868 </span> : * copying with moving. -<span class="lineNum"> 869 </span> : */ -<span class="lineNum"> 870 </span> : template<typename _Iterator> -<span class="lineNum"> 871 </span> : class move_iterator -<span class="lineNum"> 872 </span> : { -<span class="lineNum"> 873 </span> : protected: -<span class="lineNum"> 874 </span> : _Iterator _M_current; -<span class="lineNum"> 875 </span> : -<span class="lineNum"> 876 </span> : public: -<span class="lineNum"> 877 </span> : typedef _Iterator iterator_type; -<span class="lineNum"> 878 </span> : typedef typename iterator_traits<_Iterator>::difference_type -<span class="lineNum"> 879 </span> : difference_type; -<span class="lineNum"> 880 </span> : // NB: DR 680. -<span class="lineNum"> 881 </span> : typedef _Iterator pointer; -<span class="lineNum"> 882 </span> : typedef typename iterator_traits<_Iterator>::value_type value_type; -<span class="lineNum"> 883 </span> : typedef typename iterator_traits<_Iterator>::iterator_category -<span class="lineNum"> 884 </span> : iterator_category; -<span class="lineNum"> 885 </span> : typedef value_type&& reference; -<span class="lineNum"> 886 </span> : -<span class="lineNum"> 887 </span> : public: -<span class="lineNum"> 888 </span> : move_iterator() -<span class="lineNum"> 889 </span> : : _M_current() { } -<span class="lineNum"> 890 </span> : -<span class="lineNum"> 891 </span> : explicit -<span class="lineNum"> 892 </span> : move_iterator(iterator_type __i) -<span class="lineNum"> 893 </span> : : _M_current(__i) { } -<span class="lineNum"> 894 </span> : -<span class="lineNum"> 895 </span> : template<typename _Iter> -<span class="lineNum"> 896 </span> : move_iterator(const move_iterator<_Iter>& __i) -<span class="lineNum"> 897 </span> : : _M_current(__i.base()) { } -<span class="lineNum"> 898 </span> : -<span class="lineNum"> 899 </span> : iterator_type -<span class="lineNum"> 900 </span> : base() const -<span class="lineNum"> 901 </span> : { return _M_current; } -<span class="lineNum"> 902 </span> : -<span class="lineNum"> 903 </span> : reference -<span class="lineNum"> 904 </span> : operator*() const -<span class="lineNum"> 905 </span> : { return *_M_current; } -<span class="lineNum"> 906 </span> : -<span class="lineNum"> 907 </span> : pointer -<span class="lineNum"> 908 </span> : operator->() const -<span class="lineNum"> 909 </span> : { return _M_current; } -<span class="lineNum"> 910 </span> : -<span class="lineNum"> 911 </span> : move_iterator& -<span class="lineNum"> 912 </span> : operator++() -<span class="lineNum"> 913 </span> : { -<span class="lineNum"> 914 </span> : ++_M_current; -<span class="lineNum"> 915 </span> : return *this; -<span class="lineNum"> 916 </span> : } -<span class="lineNum"> 917 </span> : -<span class="lineNum"> 918 </span> : move_iterator -<span class="lineNum"> 919 </span> : operator++(int) -<span class="lineNum"> 920 </span> : { -<span class="lineNum"> 921 </span> : move_iterator __tmp = *this; -<span class="lineNum"> 922 </span> : ++_M_current; -<span class="lineNum"> 923 </span> : return __tmp; -<span class="lineNum"> 924 </span> : } -<span class="lineNum"> 925 </span> : -<span class="lineNum"> 926 </span> : move_iterator& -<span class="lineNum"> 927 </span> : operator--() -<span class="lineNum"> 928 </span> : { -<span class="lineNum"> 929 </span> : --_M_current; -<span class="lineNum"> 930 </span> : return *this; -<span class="lineNum"> 931 </span> : } -<span class="lineNum"> 932 </span> : -<span class="lineNum"> 933 </span> : move_iterator -<span class="lineNum"> 934 </span> : operator--(int) -<span class="lineNum"> 935 </span> : { -<span class="lineNum"> 936 </span> : move_iterator __tmp = *this; -<span class="lineNum"> 937 </span> : --_M_current; -<span class="lineNum"> 938 </span> : return __tmp; -<span class="lineNum"> 939 </span> : } -<span class="lineNum"> 940 </span> : -<span class="lineNum"> 941 </span> : move_iterator -<span class="lineNum"> 942 </span> : operator+(difference_type __n) const -<span class="lineNum"> 943 </span> : { return move_iterator(_M_current + __n); } -<span class="lineNum"> 944 </span> : -<span class="lineNum"> 945 </span> : move_iterator& -<span class="lineNum"> 946 </span> : operator+=(difference_type __n) -<span class="lineNum"> 947 </span> : { -<span class="lineNum"> 948 </span> : _M_current += __n; -<span class="lineNum"> 949 </span> : return *this; -<span class="lineNum"> 950 </span> : } -<span class="lineNum"> 951 </span> : -<span class="lineNum"> 952 </span> : move_iterator -<span class="lineNum"> 953 </span> : operator-(difference_type __n) const -<span class="lineNum"> 954 </span> : { return move_iterator(_M_current - __n); } -<span class="lineNum"> 955 </span> : -<span class="lineNum"> 956 </span> : move_iterator& -<span class="lineNum"> 957 </span> : operator-=(difference_type __n) -<span class="lineNum"> 958 </span> : { -<span class="lineNum"> 959 </span> : _M_current -= __n; -<span class="lineNum"> 960 </span> : return *this; -<span class="lineNum"> 961 </span> : } -<span class="lineNum"> 962 </span> : -<span class="lineNum"> 963 </span> : reference -<span class="lineNum"> 964 </span> : operator[](difference_type __n) const -<span class="lineNum"> 965 </span> : { return _M_current[__n]; } -<span class="lineNum"> 966 </span> : }; -<span class="lineNum"> 967 </span> : -<span class="lineNum"> 968 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 969 </span> : inline bool -<span class="lineNum"> 970 </span> : operator==(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 971 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 972 </span> : { return __x.base() == __y.base(); } -<span class="lineNum"> 973 </span> : -<span class="lineNum"> 974 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 975 </span> : inline bool -<span class="lineNum"> 976 </span> : operator!=(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 977 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 978 </span> : { return !(__x == __y); } -<span class="lineNum"> 979 </span> : -<span class="lineNum"> 980 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 981 </span> : inline bool -<span class="lineNum"> 982 </span> : operator<(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 983 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 984 </span> : { return __x.base() < __y.base(); } -<span class="lineNum"> 985 </span> : -<span class="lineNum"> 986 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 987 </span> : inline bool -<span class="lineNum"> 988 </span> : operator<=(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 989 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 990 </span> : { return !(__y < __x); } -<span class="lineNum"> 991 </span> : -<span class="lineNum"> 992 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 993 </span> : inline bool -<span class="lineNum"> 994 </span> : operator>(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 995 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 996 </span> : { return __y < __x; } -<span class="lineNum"> 997 </span> : -<span class="lineNum"> 998 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 999 </span> : inline bool -<span class="lineNum"> 1000 </span> : operator>=(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 1001 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 1002 </span> : { return !(__x < __y); } -<span class="lineNum"> 1003 </span> : -<span class="lineNum"> 1004 </span> : template<typename _IteratorL, typename _IteratorR> -<span class="lineNum"> 1005 </span> : inline typename move_iterator<_IteratorL>::difference_type -<span class="lineNum"> 1006 </span> : operator-(const move_iterator<_IteratorL>& __x, -<span class="lineNum"> 1007 </span> : const move_iterator<_IteratorR>& __y) -<span class="lineNum"> 1008 </span> : { return __x.base() - __y.base(); } -<span class="lineNum"> 1009 </span> : -<span class="lineNum"> 1010 </span> : template<typename _Iterator> -<span class="lineNum"> 1011 </span> : inline move_iterator<_Iterator> -<span class="lineNum"> 1012 </span> : operator+(typename move_iterator<_Iterator>::difference_type __n, -<span class="lineNum"> 1013 </span> : const move_iterator<_Iterator>& __x) -<span class="lineNum"> 1014 </span> : { return __x + __n; } -<span class="lineNum"> 1015 </span> : -<span class="lineNum"> 1016 </span> : template<typename _Iterator> -<span class="lineNum"> 1017 </span> : inline move_iterator<_Iterator> -<span class="lineNum"> 1018 </span> : make_move_iterator(const _Iterator& __i) -<span class="lineNum"> 1019 </span> : { return move_iterator<_Iterator>(__i); } -<span class="lineNum"> 1020 </span> : -<span class="lineNum"> 1021 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 1022 </span> : -<span class="lineNum"> 1023 </span> : #define _GLIBCXX_MAKE_MOVE_ITERATOR(_Iter) std::make_move_iterator(_Iter) -<span class="lineNum"> 1024 </span> : #else -<span class="lineNum"> 1025 </span> : #define _GLIBCXX_MAKE_MOVE_ITERATOR(_Iter) (_Iter) -<span class="lineNum"> 1026 </span> : #endif // __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1027 </span> : -<span class="lineNum"> 1028 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_iterator_base_funcs.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_iterator_base_funcs.h.gcov.html deleted file mode 100644 index 8486f49..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_iterator_base_funcs.h.gcov.html +++ /dev/null @@ -1,249 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_iterator_base_funcs.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_iterator_base_funcs.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">28</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">82.1 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">23</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Functions used by iterators -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996-1998 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_iterator_base_funcs.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : * -<span class="lineNum"> 61 </span> : * This file contains all of the general iterator-related utility -<span class="lineNum"> 62 </span> : * functions, such as distance() and advance(). -<span class="lineNum"> 63 </span> : */ -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #ifndef _STL_ITERATOR_BASE_FUNCS_H -<span class="lineNum"> 66 </span> : #define _STL_ITERATOR_BASE_FUNCS_H 1 -<span class="lineNum"> 67 </span> : -<span class="lineNum"> 68 </span> : #pragma GCC system_header -<span class="lineNum"> 69 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 70 </span> : -<span class="lineNum"> 71 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 72 </span> : -<span class="lineNum"> 73 </span> : template<typename _InputIterator> -<span class="lineNum"> 74 </span> : inline typename iterator_traits<_InputIterator>::difference_type -<span class="lineNum"> 75 </span> : __distance(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 76 </span><span class="lineCov"> 13 : input_iterator_tag)</span> -<span class="lineNum"> 77 </span> : { -<span class="lineNum"> 78 </span> : // concept requirements -<span class="lineNum"> 79 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 80 </span> : -<span class="lineNum"> 81 </span><span class="lineCov"> 13 : typename iterator_traits<_InputIterator>::difference_type __n = 0;</span> -<span class="lineNum"> 82 </span><span class="lineCov"> 37 : while (__first != __last)</span> -<span class="lineNum"> 83 </span> : { -<span class="lineNum"> 84 </span><span class="lineCov"> 11 : ++__first;</span> -<span class="lineNum"> 85 </span><span class="lineCov"> 11 : ++__n;</span> -<span class="lineNum"> 86 </span> : } -<span class="lineNum"> 87 </span><span class="lineCov"> 13 : return __n;</span> -<span class="lineNum"> 88 </span> : } -<span class="lineNum"> 89 </span> : -<span class="lineNum"> 90 </span> : template<typename _RandomAccessIterator> -<span class="lineNum"> 91 </span> : inline typename iterator_traits<_RandomAccessIterator>::difference_type -<span class="lineNum"> 92 </span> : __distance(_RandomAccessIterator __first, _RandomAccessIterator __last, -<span class="lineNum"> 93 </span><span class="lineCov"> 1287 : random_access_iterator_tag)</span> -<span class="lineNum"> 94 </span> : { -<span class="lineNum"> 95 </span> : // concept requirements -<span class="lineNum"> 96 </span> : __glibcxx_function_requires(_RandomAccessIteratorConcept< -<span class="lineNum"> 97 </span> : _RandomAccessIterator>) -<span class="lineNum"> 98 </span><span class="lineCov"> 1287 : return __last - __first;</span> -<span class="lineNum"> 99 </span> : } -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : /** -<span class="lineNum"> 102 </span> : * @brief A generalization of pointer arithmetic. -<span class="lineNum"> 103 </span> : * @param first An input iterator. -<span class="lineNum"> 104 </span> : * @param last An input iterator. -<span class="lineNum"> 105 </span> : * @return The distance between them. -<span class="lineNum"> 106 </span> : * -<span class="lineNum"> 107 </span> : * Returns @c n such that first + n == last. This requires that @p last -<span class="lineNum"> 108 </span> : * must be reachable from @p first. Note that @c n may be negative. -<span class="lineNum"> 109 </span> : * -<span class="lineNum"> 110 </span> : * For random access iterators, this uses their @c + and @c - operations -<span class="lineNum"> 111 </span> : * and are constant time. For other %iterator classes they are linear time. -<span class="lineNum"> 112 </span> : */ -<span class="lineNum"> 113 </span> : template<typename _InputIterator> -<span class="lineNum"> 114 </span> : inline typename iterator_traits<_InputIterator>::difference_type -<span class="lineNum"> 115 </span><span class="lineCov"> 1300 : distance(_InputIterator __first, _InputIterator __last)</span> -<span class="lineNum"> 116 </span> : { -<span class="lineNum"> 117 </span> : // concept requirements -- taken care of in __distance -<span class="lineNum"> 118 </span> : return std::__distance(__first, __last, -<span class="lineNum"> 119 </span><span class="lineCov"> 1300 : std::__iterator_category(__first));</span> -<span class="lineNum"> 120 </span> : } -<span class="lineNum"> 121 </span> : -<span class="lineNum"> 122 </span> : template<typename _InputIterator, typename _Distance> -<span class="lineNum"> 123 </span> : inline void -<span class="lineNum"> 124 </span><span class="lineCov"> 10 : __advance(_InputIterator& __i, _Distance __n, input_iterator_tag)</span> -<span class="lineNum"> 125 </span> : { -<span class="lineNum"> 126 </span> : // concept requirements -<span class="lineNum"> 127 </span> : __glibcxx_function_requires(_InputIteratorConcept<_InputIterator>) -<span class="lineNum"> 128 </span><span class="lineCov"> 41 : while (__n--)</span> -<span class="lineNum"> 129 </span><span class="lineCov"> 21 : ++__i;</span> -<span class="lineNum"> 130 </span><span class="lineCov"> 10 : }</span> -<span class="lineNum"> 131 </span> : -<span class="lineNum"> 132 </span> : template<typename _BidirectionalIterator, typename _Distance> -<span class="lineNum"> 133 </span> : inline void -<span class="lineNum"> 134 </span> : __advance(_BidirectionalIterator& __i, _Distance __n, -<span class="lineNum"> 135 </span><span class="lineCov"> 55 : bidirectional_iterator_tag)</span> -<span class="lineNum"> 136 </span> : { -<span class="lineNum"> 137 </span> : // concept requirements -<span class="lineNum"> 138 </span> : __glibcxx_function_requires(_BidirectionalIteratorConcept< -<span class="lineNum"> 139 </span> : _BidirectionalIterator>) -<span class="lineNum"> 140 </span><span class="lineCov"> 55 : if (__n > 0)</span> -<span class="lineNum"> 141 </span><span class="lineCov"> 165 : while (__n--)</span> -<span class="lineNum"> 142 </span><span class="lineCov"> 55 : ++__i;</span> -<span class="lineNum"> 143 </span> : else -<span class="lineNum"> 144 </span><span class="lineNoCov"> 0 : while (__n++)</span> -<span class="lineNum"> 145 </span><span class="lineNoCov"> 0 : --__i;</span> -<span class="lineNum"> 146 </span><span class="lineCov"> 55 : }</span> -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : template<typename _RandomAccessIterator, typename _Distance> -<span class="lineNum"> 149 </span> : inline void -<span class="lineNum"> 150 </span> : __advance(_RandomAccessIterator& __i, _Distance __n, -<span class="lineNum"> 151 </span><span class="lineNoCov"> 0 : random_access_iterator_tag)</span> -<span class="lineNum"> 152 </span> : { -<span class="lineNum"> 153 </span> : // concept requirements -<span class="lineNum"> 154 </span> : __glibcxx_function_requires(_RandomAccessIteratorConcept< -<span class="lineNum"> 155 </span> : _RandomAccessIterator>) -<span class="lineNum"> 156 </span><span class="lineNoCov"> 0 : __i += __n;</span> -<span class="lineNum"> 157 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 158 </span> : -<span class="lineNum"> 159 </span> : /** -<span class="lineNum"> 160 </span> : * @brief A generalization of pointer arithmetic. -<span class="lineNum"> 161 </span> : * @param i An input iterator. -<span class="lineNum"> 162 </span> : * @param n The "delta" by which to change @p i. -<span class="lineNum"> 163 </span> : * @return Nothing. -<span class="lineNum"> 164 </span> : * -<span class="lineNum"> 165 </span> : * This increments @p i by @p n. For bidirectional and random access -<span class="lineNum"> 166 </span> : * iterators, @p n may be negative, in which case @p i is decremented. -<span class="lineNum"> 167 </span> : * -<span class="lineNum"> 168 </span> : * For random access iterators, this uses their @c + and @c - operations -<span class="lineNum"> 169 </span> : * and are constant time. For other %iterator classes they are linear time. -<span class="lineNum"> 170 </span> : */ -<span class="lineNum"> 171 </span> : template<typename _InputIterator, typename _Distance> -<span class="lineNum"> 172 </span> : inline void -<span class="lineNum"> 173 </span><span class="lineCov"> 65 : advance(_InputIterator& __i, _Distance __n)</span> -<span class="lineNum"> 174 </span> : { -<span class="lineNum"> 175 </span> : // concept requirements -- taken care of in __advance -<span class="lineNum"> 176 </span><span class="lineCov"> 65 : typename iterator_traits<_InputIterator>::difference_type __d = __n;</span> -<span class="lineNum"> 177 </span><span class="lineCov"> 65 : std::__advance(__i, __d, std::__iterator_category(__i));</span> -<span class="lineNum"> 178 </span><span class="lineCov"> 65 : }</span> -<span class="lineNum"> 179 </span> : -<span class="lineNum"> 180 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 181 </span> : -<span class="lineNum"> 182 </span> : #endif /* _STL_ITERATOR_BASE_FUNCS_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_iterator_base_types.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_iterator_base_types.h.gcov.html deleted file mode 100644 index fc03082..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_iterator_base_types.h.gcov.html +++ /dev/null @@ -1,239 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_iterator_base_types.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_iterator_base_types.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">3</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">3</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Types used in iterator implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996-1998 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_iterator_base_types.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : * -<span class="lineNum"> 61 </span> : * This file contains all of the general iterator-related utility types, -<span class="lineNum"> 62 </span> : * such as iterator_traits and struct iterator. -<span class="lineNum"> 63 </span> : */ -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #ifndef _STL_ITERATOR_BASE_TYPES_H -<span class="lineNum"> 66 </span> : #define _STL_ITERATOR_BASE_TYPES_H 1 -<span class="lineNum"> 67 </span> : -<span class="lineNum"> 68 </span> : #pragma GCC system_header -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : #include <bits/c++config.h> -<span class="lineNum"> 71 </span> : #include <cstddef> -<span class="lineNum"> 72 </span> : -<span class="lineNum"> 73 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 74 </span> : -<span class="lineNum"> 75 </span> : //@{ -<span class="lineNum"> 76 </span> : /** -<span class="lineNum"> 77 </span> : * @defgroup iterator_tags Iterator Tags -<span class="lineNum"> 78 </span> : * These are empty types, used to distinguish different iterators. The -<span class="lineNum"> 79 </span> : * distinction is not made by what they contain, but simply by what they -<span class="lineNum"> 80 </span> : * are. Different underlying algorithms can then be used based on the -<span class="lineNum"> 81 </span> : * different operations supported by different iterator types. -<span class="lineNum"> 82 </span> : */ -<span class="lineNum"> 83 </span> : /// Marking input iterators. -<span class="lineNum"> 84 </span> : struct input_iterator_tag {}; -<span class="lineNum"> 85 </span> : /// Marking output iterators. -<span class="lineNum"> 86 </span> : struct output_iterator_tag {}; -<span class="lineNum"> 87 </span> : /// Forward iterators support a superset of input iterator operations. -<span class="lineNum"> 88 </span> : struct forward_iterator_tag : public input_iterator_tag {}; -<span class="lineNum"> 89 </span> : /// Bidirectional iterators support a superset of forward iterator -<span class="lineNum"> 90 </span> : /// operations. -<span class="lineNum"> 91 </span> : struct bidirectional_iterator_tag : public forward_iterator_tag {}; -<span class="lineNum"> 92 </span> : /// Random-access iterators support a superset of bidirectional iterator -<span class="lineNum"> 93 </span> : /// operations. -<span class="lineNum"> 94 </span> : struct random_access_iterator_tag : public bidirectional_iterator_tag {}; -<span class="lineNum"> 95 </span> : //@} -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : -<span class="lineNum"> 98 </span> : /** -<span class="lineNum"> 99 </span> : * @brief Common %iterator class. -<span class="lineNum"> 100 </span> : * -<span class="lineNum"> 101 </span> : * This class does nothing but define nested typedefs. %Iterator classes -<span class="lineNum"> 102 </span> : * can inherit from this class to save some work. The typedefs are then -<span class="lineNum"> 103 </span> : * used in specializations and overloading. -<span class="lineNum"> 104 </span> : * -<span class="lineNum"> 105 </span> : * In particular, there are no default implementations of requirements -<span class="lineNum"> 106 </span> : * such as @c operator++ and the like. (How could there be?) -<span class="lineNum"> 107 </span> : */ -<span class="lineNum"> 108 </span> : template<typename _Category, typename _Tp, typename _Distance = ptrdiff_t, -<span class="lineNum"> 109 </span> : typename _Pointer = _Tp*, typename _Reference = _Tp&> -<span class="lineNum"> 110 </span> : struct iterator -<span class="lineNum"> 111 </span><span class="lineCov"> 304336 : {</span> -<span class="lineNum"> 112 </span> : /// One of the @link iterator_tags tag types@endlink. -<span class="lineNum"> 113 </span> : typedef _Category iterator_category; -<span class="lineNum"> 114 </span> : /// The type "pointed to" by the iterator. -<span class="lineNum"> 115 </span> : typedef _Tp value_type; -<span class="lineNum"> 116 </span> : /// Distance between iterators is represented as this type. -<span class="lineNum"> 117 </span> : typedef _Distance difference_type; -<span class="lineNum"> 118 </span> : /// This type represents a pointer-to-value_type. -<span class="lineNum"> 119 </span> : typedef _Pointer pointer; -<span class="lineNum"> 120 </span> : /// This type represents a reference-to-value_type. -<span class="lineNum"> 121 </span> : typedef _Reference reference; -<span class="lineNum"> 122 </span> : }; -<span class="lineNum"> 123 </span> : -<span class="lineNum"> 124 </span> : /** -<span class="lineNum"> 125 </span> : * This class does nothing but define nested typedefs. The general -<span class="lineNum"> 126 </span> : * version simply "forwards" the nested typedefs from the Iterator -<span class="lineNum"> 127 </span> : * argument. Specialized versions for pointers and pointers-to-const -<span class="lineNum"> 128 </span> : * provide tighter, more correct semantics. -<span class="lineNum"> 129 </span> : */ -<span class="lineNum"> 130 </span> : template<typename _Iterator> -<span class="lineNum"> 131 </span> : struct iterator_traits -<span class="lineNum"> 132 </span> : { -<span class="lineNum"> 133 </span> : typedef typename _Iterator::iterator_category iterator_category; -<span class="lineNum"> 134 </span> : typedef typename _Iterator::value_type value_type; -<span class="lineNum"> 135 </span> : typedef typename _Iterator::difference_type difference_type; -<span class="lineNum"> 136 </span> : typedef typename _Iterator::pointer pointer; -<span class="lineNum"> 137 </span> : typedef typename _Iterator::reference reference; -<span class="lineNum"> 138 </span> : }; -<span class="lineNum"> 139 </span> : -<span class="lineNum"> 140 </span> : template<typename _Tp> -<span class="lineNum"> 141 </span> : struct iterator_traits<_Tp*> -<span class="lineNum"> 142 </span> : { -<span class="lineNum"> 143 </span> : typedef random_access_iterator_tag iterator_category; -<span class="lineNum"> 144 </span> : typedef _Tp value_type; -<span class="lineNum"> 145 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 146 </span> : typedef _Tp* pointer; -<span class="lineNum"> 147 </span> : typedef _Tp& reference; -<span class="lineNum"> 148 </span> : }; -<span class="lineNum"> 149 </span> : -<span class="lineNum"> 150 </span> : template<typename _Tp> -<span class="lineNum"> 151 </span> : struct iterator_traits<const _Tp*> -<span class="lineNum"> 152 </span> : { -<span class="lineNum"> 153 </span> : typedef random_access_iterator_tag iterator_category; -<span class="lineNum"> 154 </span> : typedef _Tp value_type; -<span class="lineNum"> 155 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 156 </span> : typedef const _Tp* pointer; -<span class="lineNum"> 157 </span> : typedef const _Tp& reference; -<span class="lineNum"> 158 </span> : }; -<span class="lineNum"> 159 </span> : -<span class="lineNum"> 160 </span> : /** -<span class="lineNum"> 161 </span> : * This function is not a part of the C++ standard but is syntactic -<span class="lineNum"> 162 </span> : * sugar for internal library use only. -<span class="lineNum"> 163 </span> : */ -<span class="lineNum"> 164 </span> : template<typename _Iter> -<span class="lineNum"> 165 </span> : inline typename iterator_traits<_Iter>::iterator_category -<span class="lineNum"> 166 </span><span class="lineCov"> 4730 : __iterator_category(const _Iter&)</span> -<span class="lineNum"> 167 </span><span class="lineCov"> 4730 : { return typename iterator_traits<_Iter>::iterator_category(); }</span> -<span class="lineNum"> 168 </span> : -<span class="lineNum"> 169 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : #endif /* _STL_ITERATOR_BASE_TYPES_H */ -<span class="lineNum"> 172 </span> : -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_list.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_list.h.gcov.html deleted file mode 100644 index 9abdf8e..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_list.h.gcov.html +++ /dev/null @@ -1,1530 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_list.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_list.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">94</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">93.6 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">88</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // List implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_list.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_LIST_H -<span class="lineNum"> 63 </span> : #define _STL_LIST_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : // Supporting structures are split into common and templated types; the -<span class="lineNum"> 70 </span> : // latter publicly inherits from the former in an effort to reduce code -<span class="lineNum"> 71 </span> : // duplication. This results in some "needless" static_cast'ing later on, -<span class="lineNum"> 72 </span> : // but it's all safe downcasting. -<span class="lineNum"> 73 </span> : -<span class="lineNum"> 74 </span> : /// Common part of a node in the %list. -<span class="lineNum"> 75 </span> : struct _List_node_base -<span class="lineNum"> 76 </span> : { -<span class="lineNum"> 77 </span> : _List_node_base* _M_next; -<span class="lineNum"> 78 </span> : _List_node_base* _M_prev; -<span class="lineNum"> 79 </span> : -<span class="lineNum"> 80 </span> : static void -<span class="lineNum"> 81 </span> : swap(_List_node_base& __x, _List_node_base& __y); -<span class="lineNum"> 82 </span> : -<span class="lineNum"> 83 </span> : void -<span class="lineNum"> 84 </span> : transfer(_List_node_base * const __first, -<span class="lineNum"> 85 </span> : _List_node_base * const __last); -<span class="lineNum"> 86 </span> : -<span class="lineNum"> 87 </span> : void -<span class="lineNum"> 88 </span> : reverse(); -<span class="lineNum"> 89 </span> : -<span class="lineNum"> 90 </span> : void -<span class="lineNum"> 91 </span> : hook(_List_node_base * const __position); -<span class="lineNum"> 92 </span> : -<span class="lineNum"> 93 </span> : void -<span class="lineNum"> 94 </span> : unhook(); -<span class="lineNum"> 95 </span> : }; -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : /// An actual node in the %list. -<span class="lineNum"> 98 </span> : template<typename _Tp> -<span class="lineNum"> 99 </span> : struct _List_node : public _List_node_base -<span class="lineNum"> 100 </span> : { -<span class="lineNum"> 101 </span> : ///< User's data. -<span class="lineNum"> 102 </span> : _Tp _M_data; -<span class="lineNum"> 103 </span> : }; -<span class="lineNum"> 104 </span> : -<span class="lineNum"> 105 </span> : /** -<span class="lineNum"> 106 </span> : * @brief A list::iterator. -<span class="lineNum"> 107 </span> : * -<span class="lineNum"> 108 </span> : * All the functions are op overloads. -<span class="lineNum"> 109 </span> : */ -<span class="lineNum"> 110 </span> : template<typename _Tp> -<span class="lineNum"> 111 </span> : struct _List_iterator -<span class="lineNum"> 112 </span> : { -<span class="lineNum"> 113 </span> : typedef _List_iterator<_Tp> _Self; -<span class="lineNum"> 114 </span> : typedef _List_node<_Tp> _Node; -<span class="lineNum"> 115 </span> : -<span class="lineNum"> 116 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 117 </span> : typedef std::bidirectional_iterator_tag iterator_category; -<span class="lineNum"> 118 </span> : typedef _Tp value_type; -<span class="lineNum"> 119 </span> : typedef _Tp* pointer; -<span class="lineNum"> 120 </span> : typedef _Tp& reference; -<span class="lineNum"> 121 </span> : -<span class="lineNum"> 122 </span> : _List_iterator() -<span class="lineNum"> 123 </span> : : _M_node() { } -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : explicit -<span class="lineNum"> 126 </span><span class="lineCov"> 206 : _List_iterator(_List_node_base* __x)</span> -<span class="lineNum"> 127 </span><span class="lineCov"> 206 : : _M_node(__x) { }</span> -<span class="lineNum"> 128 </span> : -<span class="lineNum"> 129 </span> : // Must downcast from List_node_base to _List_node to get to _M_data. -<span class="lineNum"> 130 </span> : reference -<span class="lineNum"> 131 </span><span class="lineCov"> 99 : operator*() const</span> -<span class="lineNum"> 132 </span><span class="lineCov"> 99 : { return static_cast<_Node*>(_M_node)->_M_data; }</span> -<span class="lineNum"> 133 </span> : -<span class="lineNum"> 134 </span> : pointer -<span class="lineNum"> 135 </span> : operator->() const -<span class="lineNum"> 136 </span> : { return &static_cast<_Node*>(_M_node)->_M_data; } -<span class="lineNum"> 137 </span> : -<span class="lineNum"> 138 </span> : _Self& -<span class="lineNum"> 139 </span><span class="lineCov"> 63 : operator++()</span> -<span class="lineNum"> 140 </span> : { -<span class="lineNum"> 141 </span><span class="lineCov"> 63 : _M_node = _M_node->_M_next;</span> -<span class="lineNum"> 142 </span><span class="lineCov"> 63 : return *this;</span> -<span class="lineNum"> 143 </span> : } -<span class="lineNum"> 144 </span> : -<span class="lineNum"> 145 </span> : _Self -<span class="lineNum"> 146 </span><span class="lineNoCov"> 0 : operator++(int)</span> -<span class="lineNum"> 147 </span> : { -<span class="lineNum"> 148 </span><span class="lineNoCov"> 0 : _Self __tmp = *this;</span> -<span class="lineNum"> 149 </span><span class="lineNoCov"> 0 : _M_node = _M_node->_M_next;</span> -<span class="lineNum"> 150 </span> : return __tmp; -<span class="lineNum"> 151 </span> : } -<span class="lineNum"> 152 </span> : -<span class="lineNum"> 153 </span> : _Self& -<span class="lineNum"> 154 </span><span class="lineCov"> 1 : operator--()</span> -<span class="lineNum"> 155 </span> : { -<span class="lineNum"> 156 </span><span class="lineCov"> 1 : _M_node = _M_node->_M_prev;</span> -<span class="lineNum"> 157 </span><span class="lineCov"> 1 : return *this;</span> -<span class="lineNum"> 158 </span> : } -<span class="lineNum"> 159 </span> : -<span class="lineNum"> 160 </span> : _Self -<span class="lineNum"> 161 </span> : operator--(int) -<span class="lineNum"> 162 </span> : { -<span class="lineNum"> 163 </span> : _Self __tmp = *this; -<span class="lineNum"> 164 </span> : _M_node = _M_node->_M_prev; -<span class="lineNum"> 165 </span> : return __tmp; -<span class="lineNum"> 166 </span> : } -<span class="lineNum"> 167 </span> : -<span class="lineNum"> 168 </span> : bool -<span class="lineNum"> 169 </span><span class="lineCov"> 108 : operator==(const _Self& __x) const</span> -<span class="lineNum"> 170 </span><span class="lineCov"> 108 : { return _M_node == __x._M_node; }</span> -<span class="lineNum"> 171 </span> : -<span class="lineNum"> 172 </span> : bool -<span class="lineNum"> 173 </span><span class="lineCov"> 42 : operator!=(const _Self& __x) const</span> -<span class="lineNum"> 174 </span><span class="lineCov"> 42 : { return _M_node != __x._M_node; }</span> -<span class="lineNum"> 175 </span> : -<span class="lineNum"> 176 </span> : // The only member points to the %list element. -<span class="lineNum"> 177 </span> : _List_node_base* _M_node; -<span class="lineNum"> 178 </span> : }; -<span class="lineNum"> 179 </span> : -<span class="lineNum"> 180 </span> : /** -<span class="lineNum"> 181 </span> : * @brief A list::const_iterator. -<span class="lineNum"> 182 </span> : * -<span class="lineNum"> 183 </span> : * All the functions are op overloads. -<span class="lineNum"> 184 </span> : */ -<span class="lineNum"> 185 </span> : template<typename _Tp> -<span class="lineNum"> 186 </span> : struct _List_const_iterator -<span class="lineNum"> 187 </span> : { -<span class="lineNum"> 188 </span> : typedef _List_const_iterator<_Tp> _Self; -<span class="lineNum"> 189 </span> : typedef const _List_node<_Tp> _Node; -<span class="lineNum"> 190 </span> : typedef _List_iterator<_Tp> iterator; -<span class="lineNum"> 191 </span> : -<span class="lineNum"> 192 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 193 </span> : typedef std::bidirectional_iterator_tag iterator_category; -<span class="lineNum"> 194 </span> : typedef _Tp value_type; -<span class="lineNum"> 195 </span> : typedef const _Tp* pointer; -<span class="lineNum"> 196 </span> : typedef const _Tp& reference; -<span class="lineNum"> 197 </span> : -<span class="lineNum"> 198 </span> : _List_const_iterator() -<span class="lineNum"> 199 </span> : : _M_node() { } -<span class="lineNum"> 200 </span> : -<span class="lineNum"> 201 </span> : explicit -<span class="lineNum"> 202 </span><span class="lineCov"> 42 : _List_const_iterator(const _List_node_base* __x)</span> -<span class="lineNum"> 203 </span><span class="lineCov"> 42 : : _M_node(__x) { }</span> -<span class="lineNum"> 204 </span> : -<span class="lineNum"> 205 </span> : _List_const_iterator(const iterator& __x) -<span class="lineNum"> 206 </span> : : _M_node(__x._M_node) { } -<span class="lineNum"> 207 </span> : -<span class="lineNum"> 208 </span> : // Must downcast from List_node_base to _List_node to get to -<span class="lineNum"> 209 </span> : // _M_data. -<span class="lineNum"> 210 </span> : reference -<span class="lineNum"> 211 </span><span class="lineCov"> 8 : operator*() const</span> -<span class="lineNum"> 212 </span><span class="lineCov"> 8 : { return static_cast<_Node*>(_M_node)->_M_data; }</span> -<span class="lineNum"> 213 </span> : -<span class="lineNum"> 214 </span> : pointer -<span class="lineNum"> 215 </span> : operator->() const -<span class="lineNum"> 216 </span> : { return &static_cast<_Node*>(_M_node)->_M_data; } -<span class="lineNum"> 217 </span> : -<span class="lineNum"> 218 </span> : _Self& -<span class="lineNum"> 219 </span><span class="lineCov"> 19 : operator++()</span> -<span class="lineNum"> 220 </span> : { -<span class="lineNum"> 221 </span><span class="lineCov"> 19 : _M_node = _M_node->_M_next;</span> -<span class="lineNum"> 222 </span><span class="lineCov"> 19 : return *this;</span> -<span class="lineNum"> 223 </span> : } -<span class="lineNum"> 224 </span> : -<span class="lineNum"> 225 </span> : _Self -<span class="lineNum"> 226 </span> : operator++(int) -<span class="lineNum"> 227 </span> : { -<span class="lineNum"> 228 </span> : _Self __tmp = *this; -<span class="lineNum"> 229 </span> : _M_node = _M_node->_M_next; -<span class="lineNum"> 230 </span> : return __tmp; -<span class="lineNum"> 231 </span> : } -<span class="lineNum"> 232 </span> : -<span class="lineNum"> 233 </span> : _Self& -<span class="lineNum"> 234 </span> : operator--() -<span class="lineNum"> 235 </span> : { -<span class="lineNum"> 236 </span> : _M_node = _M_node->_M_prev; -<span class="lineNum"> 237 </span> : return *this; -<span class="lineNum"> 238 </span> : } -<span class="lineNum"> 239 </span> : -<span class="lineNum"> 240 </span> : _Self -<span class="lineNum"> 241 </span> : operator--(int) -<span class="lineNum"> 242 </span> : { -<span class="lineNum"> 243 </span> : _Self __tmp = *this; -<span class="lineNum"> 244 </span> : _M_node = _M_node->_M_prev; -<span class="lineNum"> 245 </span> : return __tmp; -<span class="lineNum"> 246 </span> : } -<span class="lineNum"> 247 </span> : -<span class="lineNum"> 248 </span> : bool -<span class="lineNum"> 249 </span><span class="lineCov"> 6 : operator==(const _Self& __x) const</span> -<span class="lineNum"> 250 </span><span class="lineCov"> 6 : { return _M_node == __x._M_node; }</span> -<span class="lineNum"> 251 </span> : -<span class="lineNum"> 252 </span> : bool -<span class="lineNum"> 253 </span><span class="lineCov"> 38 : operator!=(const _Self& __x) const</span> -<span class="lineNum"> 254 </span><span class="lineCov"> 38 : { return _M_node != __x._M_node; }</span> -<span class="lineNum"> 255 </span> : -<span class="lineNum"> 256 </span> : // The only member points to the %list element. -<span class="lineNum"> 257 </span> : const _List_node_base* _M_node; -<span class="lineNum"> 258 </span> : }; -<span class="lineNum"> 259 </span> : -<span class="lineNum"> 260 </span> : template<typename _Val> -<span class="lineNum"> 261 </span> : inline bool -<span class="lineNum"> 262 </span> : operator==(const _List_iterator<_Val>& __x, -<span class="lineNum"> 263 </span> : const _List_const_iterator<_Val>& __y) -<span class="lineNum"> 264 </span> : { return __x._M_node == __y._M_node; } -<span class="lineNum"> 265 </span> : -<span class="lineNum"> 266 </span> : template<typename _Val> -<span class="lineNum"> 267 </span> : inline bool -<span class="lineNum"> 268 </span> : operator!=(const _List_iterator<_Val>& __x, -<span class="lineNum"> 269 </span> : const _List_const_iterator<_Val>& __y) -<span class="lineNum"> 270 </span> : { return __x._M_node != __y._M_node; } -<span class="lineNum"> 271 </span> : -<span class="lineNum"> 272 </span> : -<span class="lineNum"> 273 </span> : /// See bits/stl_deque.h's _Deque_base for an explanation. -<span class="lineNum"> 274 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 275 </span> : class _List_base -<span class="lineNum"> 276 </span> : { -<span class="lineNum"> 277 </span> : protected: -<span class="lineNum"> 278 </span> : // NOTA BENE -<span class="lineNum"> 279 </span> : // The stored instance is not actually of "allocator_type"'s -<span class="lineNum"> 280 </span> : // type. Instead we rebind the type to -<span class="lineNum"> 281 </span> : // Allocator<List_node<Tp>>, which according to [20.1.5]/4 -<span class="lineNum"> 282 </span> : // should probably be the same. List_node<Tp> is not the same -<span class="lineNum"> 283 </span> : // size as Tp (it's two pointers larger), and specializations on -<span class="lineNum"> 284 </span> : // Tp may go unused because List_node<Tp> is being bound -<span class="lineNum"> 285 </span> : // instead. -<span class="lineNum"> 286 </span> : // -<span class="lineNum"> 287 </span> : // We put this to the test in the constructors and in -<span class="lineNum"> 288 </span> : // get_allocator, where we use conversions between -<span class="lineNum"> 289 </span> : // allocator_type and _Node_alloc_type. The conversion is -<span class="lineNum"> 290 </span> : // required by table 32 in [20.1.5]. -<span class="lineNum"> 291 </span> : typedef typename _Alloc::template rebind<_List_node<_Tp> >::other -<span class="lineNum"> 292 </span> : _Node_alloc_type; -<span class="lineNum"> 293 </span> : -<span class="lineNum"> 294 </span> : typedef typename _Alloc::template rebind<_Tp>::other _Tp_alloc_type; -<span class="lineNum"> 295 </span> : -<span class="lineNum"> 296 </span> : struct _List_impl -<span class="lineNum"> 297 </span> : : public _Node_alloc_type -<span class="lineNum"> 298 </span><span class="lineCov"> 19 : {</span> -<span class="lineNum"> 299 </span> : _List_node_base _M_node; -<span class="lineNum"> 300 </span> : -<span class="lineNum"> 301 </span><span class="lineCov"> 19 : _List_impl()</span> -<span class="lineNum"> 302 </span><span class="lineCov"> 19 : : _Node_alloc_type(), _M_node()</span> -<span class="lineNum"> 303 </span><span class="lineCov"> 19 : { }</span> -<span class="lineNum"> 304 </span> : -<span class="lineNum"> 305 </span> : _List_impl(const _Node_alloc_type& __a) -<span class="lineNum"> 306 </span> : : _Node_alloc_type(__a), _M_node() -<span class="lineNum"> 307 </span> : { } -<span class="lineNum"> 308 </span> : }; -<span class="lineNum"> 309 </span> : -<span class="lineNum"> 310 </span> : _List_impl _M_impl; -<span class="lineNum"> 311 </span> : -<span class="lineNum"> 312 </span> : _List_node<_Tp>* -<span class="lineNum"> 313 </span><span class="lineCov"> 47 : _M_get_node()</span> -<span class="lineNum"> 314 </span><span class="lineCov"> 47 : { return _M_impl._Node_alloc_type::allocate(1); }</span> -<span class="lineNum"> 315 </span> : -<span class="lineNum"> 316 </span> : void -<span class="lineNum"> 317 </span><span class="lineCov"> 47 : _M_put_node(_List_node<_Tp>* __p)</span> -<span class="lineNum"> 318 </span><span class="lineCov"> 47 : { _M_impl._Node_alloc_type::deallocate(__p, 1); }</span> -<span class="lineNum"> 319 </span> : -<span class="lineNum"> 320 </span> : public: -<span class="lineNum"> 321 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 322 </span> : -<span class="lineNum"> 323 </span> : _Node_alloc_type& -<span class="lineNum"> 324 </span> : _M_get_Node_allocator() -<span class="lineNum"> 325 </span> : { return *static_cast<_Node_alloc_type*>(&this->_M_impl); } -<span class="lineNum"> 326 </span> : -<span class="lineNum"> 327 </span> : const _Node_alloc_type& -<span class="lineNum"> 328 </span><span class="lineCov"> 94 : _M_get_Node_allocator() const</span> -<span class="lineNum"> 329 </span><span class="lineCov"> 94 : { return *static_cast<const _Node_alloc_type*>(&this->_M_impl); }</span> -<span class="lineNum"> 330 </span> : -<span class="lineNum"> 331 </span> : _Tp_alloc_type -<span class="lineNum"> 332 </span><span class="lineCov"> 94 : _M_get_Tp_allocator() const</span> -<span class="lineNum"> 333 </span><span class="lineCov"> 94 : { return _Tp_alloc_type(_M_get_Node_allocator()); }</span> -<span class="lineNum"> 334 </span> : -<span class="lineNum"> 335 </span> : allocator_type -<span class="lineNum"> 336 </span> : get_allocator() const -<span class="lineNum"> 337 </span> : { return allocator_type(_M_get_Node_allocator()); } -<span class="lineNum"> 338 </span> : -<span class="lineNum"> 339 </span><span class="lineCov"> 19 : _List_base()</span> -<span class="lineNum"> 340 </span><span class="lineCov"> 19 : : _M_impl()</span> -<span class="lineNum"> 341 </span><span class="lineCov"> 19 : { _M_init(); }</span> -<span class="lineNum"> 342 </span> : -<span class="lineNum"> 343 </span> : _List_base(const allocator_type& __a) -<span class="lineNum"> 344 </span> : : _M_impl(__a) -<span class="lineNum"> 345 </span> : { _M_init(); } -<span class="lineNum"> 346 </span> : -<span class="lineNum"> 347 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 348 </span> : _List_base(_List_base&& __x) -<span class="lineNum"> 349 </span> : : _M_impl(__x._M_get_Node_allocator()) -<span class="lineNum"> 350 </span> : { -<span class="lineNum"> 351 </span> : _M_init(); -<span class="lineNum"> 352 </span> : _List_node_base::swap(this->_M_impl._M_node, __x._M_impl._M_node); -<span class="lineNum"> 353 </span> : } -<span class="lineNum"> 354 </span> : #endif -<span class="lineNum"> 355 </span> : -<span class="lineNum"> 356 </span> : // This is what actually destroys the list. -<span class="lineNum"> 357 </span><span class="lineCov"> 19 : ~_List_base()</span> -<span class="lineNum"> 358 </span><span class="lineCov"> 19 : { _M_clear(); }</span> -<span class="lineNum"> 359 </span> : -<span class="lineNum"> 360 </span> : void -<span class="lineNum"> 361 </span> : _M_clear(); -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : void -<span class="lineNum"> 364 </span><span class="lineCov"> 19 : _M_init()</span> -<span class="lineNum"> 365 </span> : { -<span class="lineNum"> 366 </span><span class="lineCov"> 19 : this->_M_impl._M_node._M_next = &this->_M_impl._M_node;</span> -<span class="lineNum"> 367 </span><span class="lineCov"> 19 : this->_M_impl._M_node._M_prev = &this->_M_impl._M_node;</span> -<span class="lineNum"> 368 </span><span class="lineCov"> 19 : }</span> -<span class="lineNum"> 369 </span> : }; -<span class="lineNum"> 370 </span> : -<span class="lineNum"> 371 </span> : /** -<span class="lineNum"> 372 </span> : * @brief A standard container with linear time access to elements, -<span class="lineNum"> 373 </span> : * and fixed time insertion/deletion at any point in the sequence. -<span class="lineNum"> 374 </span> : * -<span class="lineNum"> 375 </span> : * @ingroup Containers -<span class="lineNum"> 376 </span> : * @ingroup Sequences -<span class="lineNum"> 377 </span> : * -<span class="lineNum"> 378 </span> : * Meets the requirements of a <a href="tables.html#65">container</a>, a -<span class="lineNum"> 379 </span> : * <a href="tables.html#66">reversible container</a>, and a -<span class="lineNum"> 380 </span> : * <a href="tables.html#67">sequence</a>, including the -<span class="lineNum"> 381 </span> : * <a href="tables.html#68">optional sequence requirements</a> with the -<span class="lineNum"> 382 </span> : * %exception of @c at and @c operator[]. -<span class="lineNum"> 383 </span> : * -<span class="lineNum"> 384 </span> : * This is a @e doubly @e linked %list. Traversal up and down the -<span class="lineNum"> 385 </span> : * %list requires linear time, but adding and removing elements (or -<span class="lineNum"> 386 </span> : * @e nodes) is done in constant time, regardless of where the -<span class="lineNum"> 387 </span> : * change takes place. Unlike std::vector and std::deque, -<span class="lineNum"> 388 </span> : * random-access iterators are not provided, so subscripting ( @c -<span class="lineNum"> 389 </span> : * [] ) access is not allowed. For algorithms which only need -<span class="lineNum"> 390 </span> : * sequential access, this lack makes no difference. -<span class="lineNum"> 391 </span> : * -<span class="lineNum"> 392 </span> : * Also unlike the other standard containers, std::list provides -<span class="lineNum"> 393 </span> : * specialized algorithms %unique to linked lists, such as -<span class="lineNum"> 394 </span> : * splicing, sorting, and in-place reversal. -<span class="lineNum"> 395 </span> : * -<span class="lineNum"> 396 </span> : * A couple points on memory allocation for list<Tp>: -<span class="lineNum"> 397 </span> : * -<span class="lineNum"> 398 </span> : * First, we never actually allocate a Tp, we allocate -<span class="lineNum"> 399 </span> : * List_node<Tp>'s and trust [20.1.5]/4 to DTRT. This is to ensure -<span class="lineNum"> 400 </span> : * that after elements from %list<X,Alloc1> are spliced into -<span class="lineNum"> 401 </span> : * %list<X,Alloc2>, destroying the memory of the second %list is a -<span class="lineNum"> 402 </span> : * valid operation, i.e., Alloc1 giveth and Alloc2 taketh away. -<span class="lineNum"> 403 </span> : * -<span class="lineNum"> 404 </span> : * Second, a %list conceptually represented as -<span class="lineNum"> 405 </span> : * @code -<span class="lineNum"> 406 </span> : * A <---> B <---> C <---> D -<span class="lineNum"> 407 </span> : * @endcode -<span class="lineNum"> 408 </span> : * is actually circular; a link exists between A and D. The %list -<span class="lineNum"> 409 </span> : * class holds (as its only data member) a private list::iterator -<span class="lineNum"> 410 </span> : * pointing to @e D, not to @e A! To get to the head of the %list, -<span class="lineNum"> 411 </span> : * we start at the tail and move forward by one. When this member -<span class="lineNum"> 412 </span> : * iterator's next/previous pointers refer to itself, the %list is -<span class="lineNum"> 413 </span> : * %empty. -<span class="lineNum"> 414 </span> : */ -<span class="lineNum"> 415 </span> : template<typename _Tp, typename _Alloc = std::allocator<_Tp> > -<span class="lineNum"> 416 </span> : class list : protected _List_base<_Tp, _Alloc> -<span class="lineNum"> 417 </span><span class="lineCov"> 19 : {</span> -<span class="lineNum"> 418 </span> : // concept requirements -<span class="lineNum"> 419 </span> : typedef typename _Alloc::value_type _Alloc_value_type; -<span class="lineNum"> 420 </span> : __glibcxx_class_requires(_Tp, _SGIAssignableConcept) -<span class="lineNum"> 421 </span> : __glibcxx_class_requires2(_Tp, _Alloc_value_type, _SameTypeConcept) -<span class="lineNum"> 422 </span> : -<span class="lineNum"> 423 </span> : typedef _List_base<_Tp, _Alloc> _Base; -<span class="lineNum"> 424 </span> : typedef typename _Base::_Tp_alloc_type _Tp_alloc_type; -<span class="lineNum"> 425 </span> : -<span class="lineNum"> 426 </span> : public: -<span class="lineNum"> 427 </span> : typedef _Tp value_type; -<span class="lineNum"> 428 </span> : typedef typename _Tp_alloc_type::pointer pointer; -<span class="lineNum"> 429 </span> : typedef typename _Tp_alloc_type::const_pointer const_pointer; -<span class="lineNum"> 430 </span> : typedef typename _Tp_alloc_type::reference reference; -<span class="lineNum"> 431 </span> : typedef typename _Tp_alloc_type::const_reference const_reference; -<span class="lineNum"> 432 </span> : typedef _List_iterator<_Tp> iterator; -<span class="lineNum"> 433 </span> : typedef _List_const_iterator<_Tp> const_iterator; -<span class="lineNum"> 434 </span> : typedef std::reverse_iterator<const_iterator> const_reverse_iterator; -<span class="lineNum"> 435 </span> : typedef std::reverse_iterator<iterator> reverse_iterator; -<span class="lineNum"> 436 </span> : typedef size_t size_type; -<span class="lineNum"> 437 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 438 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 439 </span> : -<span class="lineNum"> 440 </span> : protected: -<span class="lineNum"> 441 </span> : // Note that pointers-to-_Node's can be ctor-converted to -<span class="lineNum"> 442 </span> : // iterator types. -<span class="lineNum"> 443 </span> : typedef _List_node<_Tp> _Node; -<span class="lineNum"> 444 </span> : -<span class="lineNum"> 445 </span> : using _Base::_M_impl; -<span class="lineNum"> 446 </span> : using _Base::_M_put_node; -<span class="lineNum"> 447 </span> : using _Base::_M_get_node; -<span class="lineNum"> 448 </span> : using _Base::_M_get_Tp_allocator; -<span class="lineNum"> 449 </span> : using _Base::_M_get_Node_allocator; -<span class="lineNum"> 450 </span> : -<span class="lineNum"> 451 </span> : /** -<span class="lineNum"> 452 </span> : * @param x An instance of user data. -<span class="lineNum"> 453 </span> : * -<span class="lineNum"> 454 </span> : * Allocates space for a new node and constructs a copy of @a x in it. -<span class="lineNum"> 455 </span> : */ -<span class="lineNum"> 456 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 457 </span> : _Node* -<span class="lineNum"> 458 </span><span class="lineCov"> 47 : _M_create_node(const value_type& __x)</span> -<span class="lineNum"> 459 </span> : { -<span class="lineNum"> 460 </span><span class="lineCov"> 47 : _Node* __p = this->_M_get_node();</span> -<span class="lineNum"> 461 </span> : try -<span class="lineNum"> 462 </span> : { -<span class="lineNum"> 463 </span><span class="lineCov"> 47 : _M_get_Tp_allocator().construct(&__p->_M_data, __x);</span> -<span class="lineNum"> 464 </span> : } -<span class="lineNum"> 465 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 466 </span> : { -<span class="lineNum"> 467 </span><span class="lineNoCov"> 0 : _M_put_node(__p);</span> -<span class="lineNum"> 468 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 469 </span> : } -<span class="lineNum"> 470 </span><span class="lineCov"> 47 : return __p;</span> -<span class="lineNum"> 471 </span> : } -<span class="lineNum"> 472 </span> : #else -<span class="lineNum"> 473 </span> : template<typename... _Args> -<span class="lineNum"> 474 </span> : _Node* -<span class="lineNum"> 475 </span> : _M_create_node(_Args&&... __args) -<span class="lineNum"> 476 </span> : { -<span class="lineNum"> 477 </span> : _Node* __p = this->_M_get_node(); -<span class="lineNum"> 478 </span> : try -<span class="lineNum"> 479 </span> : { -<span class="lineNum"> 480 </span> : _M_get_Tp_allocator().construct(&__p->_M_data, -<span class="lineNum"> 481 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 482 </span> : } -<span class="lineNum"> 483 </span> : catch(...) -<span class="lineNum"> 484 </span> : { -<span class="lineNum"> 485 </span> : _M_put_node(__p); -<span class="lineNum"> 486 </span> : __throw_exception_again; -<span class="lineNum"> 487 </span> : } -<span class="lineNum"> 488 </span> : return __p; -<span class="lineNum"> 489 </span> : } -<span class="lineNum"> 490 </span> : #endif -<span class="lineNum"> 491 </span> : -<span class="lineNum"> 492 </span> : public: -<span class="lineNum"> 493 </span> : // [23.2.2.1] construct/copy/destroy -<span class="lineNum"> 494 </span> : // (assign() and get_allocator() are also listed in this section) -<span class="lineNum"> 495 </span> : /** -<span class="lineNum"> 496 </span> : * @brief Default constructor creates no elements. -<span class="lineNum"> 497 </span> : */ -<span class="lineNum"> 498 </span><span class="lineCov"> 19 : list()</span> -<span class="lineNum"> 499 </span><span class="lineCov"> 19 : : _Base() { }</span> -<span class="lineNum"> 500 </span> : -<span class="lineNum"> 501 </span> : /** -<span class="lineNum"> 502 </span> : * @brief Creates a %list with no elements. -<span class="lineNum"> 503 </span> : * @param a An allocator object. -<span class="lineNum"> 504 </span> : */ -<span class="lineNum"> 505 </span> : explicit -<span class="lineNum"> 506 </span> : list(const allocator_type& __a) -<span class="lineNum"> 507 </span> : : _Base(__a) { } -<span class="lineNum"> 508 </span> : -<span class="lineNum"> 509 </span> : /** -<span class="lineNum"> 510 </span> : * @brief Creates a %list with copies of an exemplar element. -<span class="lineNum"> 511 </span> : * @param n The number of elements to initially create. -<span class="lineNum"> 512 </span> : * @param value An element to copy. -<span class="lineNum"> 513 </span> : * @param a An allocator object. -<span class="lineNum"> 514 </span> : * -<span class="lineNum"> 515 </span> : * This constructor fills the %list with @a n copies of @a value. -<span class="lineNum"> 516 </span> : */ -<span class="lineNum"> 517 </span> : explicit -<span class="lineNum"> 518 </span> : list(size_type __n, const value_type& __value = value_type(), -<span class="lineNum"> 519 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 520 </span> : : _Base(__a) -<span class="lineNum"> 521 </span> : { _M_fill_initialize(__n, __value); } -<span class="lineNum"> 522 </span> : -<span class="lineNum"> 523 </span> : /** -<span class="lineNum"> 524 </span> : * @brief %List copy constructor. -<span class="lineNum"> 525 </span> : * @param x A %list of identical element and allocator types. -<span class="lineNum"> 526 </span> : * -<span class="lineNum"> 527 </span> : * The newly-created %list uses a copy of the allocation object used -<span class="lineNum"> 528 </span> : * by @a x. -<span class="lineNum"> 529 </span> : */ -<span class="lineNum"> 530 </span> : list(const list& __x) -<span class="lineNum"> 531 </span> : : _Base(__x._M_get_Node_allocator()) -<span class="lineNum"> 532 </span> : { _M_initialize_dispatch(__x.begin(), __x.end(), __false_type()); } -<span class="lineNum"> 533 </span> : -<span class="lineNum"> 534 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 535 </span> : /** -<span class="lineNum"> 536 </span> : * @brief %List move constructor. -<span class="lineNum"> 537 </span> : * @param x A %list of identical element and allocator types. -<span class="lineNum"> 538 </span> : * -<span class="lineNum"> 539 </span> : * The newly-created %list contains the exact contents of @a x. -<span class="lineNum"> 540 </span> : * The contents of @a x are a valid, but unspecified %list. -<span class="lineNum"> 541 </span> : */ -<span class="lineNum"> 542 </span> : list(list&& __x) -<span class="lineNum"> 543 </span> : : _Base(std::forward<_Base>(__x)) { } -<span class="lineNum"> 544 </span> : #endif -<span class="lineNum"> 545 </span> : -<span class="lineNum"> 546 </span> : /** -<span class="lineNum"> 547 </span> : * @brief Builds a %list from a range. -<span class="lineNum"> 548 </span> : * @param first An input iterator. -<span class="lineNum"> 549 </span> : * @param last An input iterator. -<span class="lineNum"> 550 </span> : * @param a An allocator object. -<span class="lineNum"> 551 </span> : * -<span class="lineNum"> 552 </span> : * Create a %list consisting of copies of the elements from -<span class="lineNum"> 553 </span> : * [@a first,@a last). This is linear in N (where N is -<span class="lineNum"> 554 </span> : * distance(@a first,@a last)). -<span class="lineNum"> 555 </span> : */ -<span class="lineNum"> 556 </span> : template<typename _InputIterator> -<span class="lineNum"> 557 </span> : list(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 558 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 559 </span> : : _Base(__a) -<span class="lineNum"> 560 </span> : { -<span class="lineNum"> 561 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 562 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 563 </span> : _M_initialize_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 564 </span> : } -<span class="lineNum"> 565 </span> : -<span class="lineNum"> 566 </span> : /** -<span class="lineNum"> 567 </span> : * No explicit dtor needed as the _Base dtor takes care of -<span class="lineNum"> 568 </span> : * things. The _Base dtor only erases the elements, and note -<span class="lineNum"> 569 </span> : * that if the elements themselves are pointers, the pointed-to -<span class="lineNum"> 570 </span> : * memory is not touched in any way. Managing the pointer is -<span class="lineNum"> 571 </span> : * the user's responsibility. -<span class="lineNum"> 572 </span> : */ -<span class="lineNum"> 573 </span> : -<span class="lineNum"> 574 </span> : /** -<span class="lineNum"> 575 </span> : * @brief %List assignment operator. -<span class="lineNum"> 576 </span> : * @param x A %list of identical element and allocator types. -<span class="lineNum"> 577 </span> : * -<span class="lineNum"> 578 </span> : * All the elements of @a x are copied, but unlike the copy -<span class="lineNum"> 579 </span> : * constructor, the allocator object is not copied. -<span class="lineNum"> 580 </span> : */ -<span class="lineNum"> 581 </span> : list& -<span class="lineNum"> 582 </span> : operator=(const list& __x); -<span class="lineNum"> 583 </span> : -<span class="lineNum"> 584 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 585 </span> : /** -<span class="lineNum"> 586 </span> : * @brief %List move assignment operator. -<span class="lineNum"> 587 </span> : * @param x A %list of identical element and allocator types. -<span class="lineNum"> 588 </span> : * -<span class="lineNum"> 589 </span> : * The contents of @a x are moved into this %list (without copying). -<span class="lineNum"> 590 </span> : * @a x is a valid, but unspecified %list -<span class="lineNum"> 591 </span> : */ -<span class="lineNum"> 592 </span> : list& -<span class="lineNum"> 593 </span> : operator=(list&& __x) -<span class="lineNum"> 594 </span> : { -<span class="lineNum"> 595 </span> : // NB: DR 675. -<span class="lineNum"> 596 </span> : this->clear(); -<span class="lineNum"> 597 </span> : this->swap(__x); -<span class="lineNum"> 598 </span> : return *this; -<span class="lineNum"> 599 </span> : } -<span class="lineNum"> 600 </span> : #endif -<span class="lineNum"> 601 </span> : -<span class="lineNum"> 602 </span> : /** -<span class="lineNum"> 603 </span> : * @brief Assigns a given value to a %list. -<span class="lineNum"> 604 </span> : * @param n Number of elements to be assigned. -<span class="lineNum"> 605 </span> : * @param val Value to be assigned. -<span class="lineNum"> 606 </span> : * -<span class="lineNum"> 607 </span> : * This function fills a %list with @a n copies of the given -<span class="lineNum"> 608 </span> : * value. Note that the assignment completely changes the %list -<span class="lineNum"> 609 </span> : * and that the resulting %list's size is the same as the number -<span class="lineNum"> 610 </span> : * of elements assigned. Old data may be lost. -<span class="lineNum"> 611 </span> : */ -<span class="lineNum"> 612 </span> : void -<span class="lineNum"> 613 </span> : assign(size_type __n, const value_type& __val) -<span class="lineNum"> 614 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 615 </span> : -<span class="lineNum"> 616 </span> : /** -<span class="lineNum"> 617 </span> : * @brief Assigns a range to a %list. -<span class="lineNum"> 618 </span> : * @param first An input iterator. -<span class="lineNum"> 619 </span> : * @param last An input iterator. -<span class="lineNum"> 620 </span> : * -<span class="lineNum"> 621 </span> : * This function fills a %list with copies of the elements in the -<span class="lineNum"> 622 </span> : * range [@a first,@a last). -<span class="lineNum"> 623 </span> : * -<span class="lineNum"> 624 </span> : * Note that the assignment completely changes the %list and -<span class="lineNum"> 625 </span> : * that the resulting %list's size is the same as the number of -<span class="lineNum"> 626 </span> : * elements assigned. Old data may be lost. -<span class="lineNum"> 627 </span> : */ -<span class="lineNum"> 628 </span> : template<typename _InputIterator> -<span class="lineNum"> 629 </span> : void -<span class="lineNum"> 630 </span> : assign(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 631 </span> : { -<span class="lineNum"> 632 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 633 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 634 </span> : _M_assign_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 635 </span> : } -<span class="lineNum"> 636 </span> : -<span class="lineNum"> 637 </span> : /// Get a copy of the memory allocation object. -<span class="lineNum"> 638 </span> : allocator_type -<span class="lineNum"> 639 </span> : get_allocator() const -<span class="lineNum"> 640 </span> : { return _Base::get_allocator(); } -<span class="lineNum"> 641 </span> : -<span class="lineNum"> 642 </span> : // iterators -<span class="lineNum"> 643 </span> : /** -<span class="lineNum"> 644 </span> : * Returns a read/write iterator that points to the first element in the -<span class="lineNum"> 645 </span> : * %list. Iteration is done in ordinary element order. -<span class="lineNum"> 646 </span> : */ -<span class="lineNum"> 647 </span> : iterator -<span class="lineNum"> 648 </span><span class="lineCov"> 27 : begin()</span> -<span class="lineNum"> 649 </span><span class="lineCov"> 27 : { return iterator(this->_M_impl._M_node._M_next); }</span> -<span class="lineNum"> 650 </span> : -<span class="lineNum"> 651 </span> : /** -<span class="lineNum"> 652 </span> : * Returns a read-only (constant) iterator that points to the -<span class="lineNum"> 653 </span> : * first element in the %list. Iteration is done in ordinary -<span class="lineNum"> 654 </span> : * element order. -<span class="lineNum"> 655 </span> : */ -<span class="lineNum"> 656 </span> : const_iterator -<span class="lineNum"> 657 </span><span class="lineCov"> 21 : begin() const</span> -<span class="lineNum"> 658 </span><span class="lineCov"> 21 : { return const_iterator(this->_M_impl._M_node._M_next); }</span> -<span class="lineNum"> 659 </span> : -<span class="lineNum"> 660 </span> : /** -<span class="lineNum"> 661 </span> : * Returns a read/write iterator that points one past the last -<span class="lineNum"> 662 </span> : * element in the %list. Iteration is done in ordinary element -<span class="lineNum"> 663 </span> : * order. -<span class="lineNum"> 664 </span> : */ -<span class="lineNum"> 665 </span> : iterator -<span class="lineNum"> 666 </span><span class="lineCov"> 154 : end()</span> -<span class="lineNum"> 667 </span><span class="lineCov"> 154 : { return iterator(&this->_M_impl._M_node); }</span> -<span class="lineNum"> 668 </span> : -<span class="lineNum"> 669 </span> : /** -<span class="lineNum"> 670 </span> : * Returns a read-only (constant) iterator that points one past -<span class="lineNum"> 671 </span> : * the last element in the %list. Iteration is done in ordinary -<span class="lineNum"> 672 </span> : * element order. -<span class="lineNum"> 673 </span> : */ -<span class="lineNum"> 674 </span> : const_iterator -<span class="lineNum"> 675 </span><span class="lineCov"> 21 : end() const</span> -<span class="lineNum"> 676 </span><span class="lineCov"> 21 : { return const_iterator(&this->_M_impl._M_node); }</span> -<span class="lineNum"> 677 </span> : -<span class="lineNum"> 678 </span> : /** -<span class="lineNum"> 679 </span> : * Returns a read/write reverse iterator that points to the last -<span class="lineNum"> 680 </span> : * element in the %list. Iteration is done in reverse element -<span class="lineNum"> 681 </span> : * order. -<span class="lineNum"> 682 </span> : */ -<span class="lineNum"> 683 </span> : reverse_iterator -<span class="lineNum"> 684 </span><span class="lineCov"> 1 : rbegin()</span> -<span class="lineNum"> 685 </span><span class="lineCov"> 1 : { return reverse_iterator(end()); }</span> -<span class="lineNum"> 686 </span> : -<span class="lineNum"> 687 </span> : /** -<span class="lineNum"> 688 </span> : * Returns a read-only (constant) reverse iterator that points to -<span class="lineNum"> 689 </span> : * the last element in the %list. Iteration is done in reverse -<span class="lineNum"> 690 </span> : * element order. -<span class="lineNum"> 691 </span> : */ -<span class="lineNum"> 692 </span> : const_reverse_iterator -<span class="lineNum"> 693 </span> : rbegin() const -<span class="lineNum"> 694 </span> : { return const_reverse_iterator(end()); } -<span class="lineNum"> 695 </span> : -<span class="lineNum"> 696 </span> : /** -<span class="lineNum"> 697 </span> : * Returns a read/write reverse iterator that points to one -<span class="lineNum"> 698 </span> : * before the first element in the %list. Iteration is done in -<span class="lineNum"> 699 </span> : * reverse element order. -<span class="lineNum"> 700 </span> : */ -<span class="lineNum"> 701 </span> : reverse_iterator -<span class="lineNum"> 702 </span> : rend() -<span class="lineNum"> 703 </span> : { return reverse_iterator(begin()); } -<span class="lineNum"> 704 </span> : -<span class="lineNum"> 705 </span> : /** -<span class="lineNum"> 706 </span> : * Returns a read-only (constant) reverse iterator that points to one -<span class="lineNum"> 707 </span> : * before the first element in the %list. Iteration is done in reverse -<span class="lineNum"> 708 </span> : * element order. -<span class="lineNum"> 709 </span> : */ -<span class="lineNum"> 710 </span> : const_reverse_iterator -<span class="lineNum"> 711 </span> : rend() const -<span class="lineNum"> 712 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 713 </span> : -<span class="lineNum"> 714 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 715 </span> : /** -<span class="lineNum"> 716 </span> : * Returns a read-only (constant) iterator that points to the -<span class="lineNum"> 717 </span> : * first element in the %list. Iteration is done in ordinary -<span class="lineNum"> 718 </span> : * element order. -<span class="lineNum"> 719 </span> : */ -<span class="lineNum"> 720 </span> : const_iterator -<span class="lineNum"> 721 </span> : cbegin() const -<span class="lineNum"> 722 </span> : { return const_iterator(this->_M_impl._M_node._M_next); } -<span class="lineNum"> 723 </span> : -<span class="lineNum"> 724 </span> : /** -<span class="lineNum"> 725 </span> : * Returns a read-only (constant) iterator that points one past -<span class="lineNum"> 726 </span> : * the last element in the %list. Iteration is done in ordinary -<span class="lineNum"> 727 </span> : * element order. -<span class="lineNum"> 728 </span> : */ -<span class="lineNum"> 729 </span> : const_iterator -<span class="lineNum"> 730 </span> : cend() const -<span class="lineNum"> 731 </span> : { return const_iterator(&this->_M_impl._M_node); } -<span class="lineNum"> 732 </span> : -<span class="lineNum"> 733 </span> : /** -<span class="lineNum"> 734 </span> : * Returns a read-only (constant) reverse iterator that points to -<span class="lineNum"> 735 </span> : * the last element in the %list. Iteration is done in reverse -<span class="lineNum"> 736 </span> : * element order. -<span class="lineNum"> 737 </span> : */ -<span class="lineNum"> 738 </span> : const_reverse_iterator -<span class="lineNum"> 739 </span> : crbegin() const -<span class="lineNum"> 740 </span> : { return const_reverse_iterator(end()); } -<span class="lineNum"> 741 </span> : -<span class="lineNum"> 742 </span> : /** -<span class="lineNum"> 743 </span> : * Returns a read-only (constant) reverse iterator that points to one -<span class="lineNum"> 744 </span> : * before the first element in the %list. Iteration is done in reverse -<span class="lineNum"> 745 </span> : * element order. -<span class="lineNum"> 746 </span> : */ -<span class="lineNum"> 747 </span> : const_reverse_iterator -<span class="lineNum"> 748 </span> : crend() const -<span class="lineNum"> 749 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 750 </span> : #endif -<span class="lineNum"> 751 </span> : -<span class="lineNum"> 752 </span> : // [23.2.2.2] capacity -<span class="lineNum"> 753 </span> : /** -<span class="lineNum"> 754 </span> : * Returns true if the %list is empty. (Thus begin() would equal -<span class="lineNum"> 755 </span> : * end().) -<span class="lineNum"> 756 </span> : */ -<span class="lineNum"> 757 </span> : bool -<span class="lineNum"> 758 </span> : empty() const -<span class="lineNum"> 759 </span> : { return this->_M_impl._M_node._M_next == &this->_M_impl._M_node; } -<span class="lineNum"> 760 </span> : -<span class="lineNum"> 761 </span> : /** Returns the number of elements in the %list. */ -<span class="lineNum"> 762 </span> : size_type -<span class="lineNum"> 763 </span><span class="lineCov"> 13 : size() const</span> -<span class="lineNum"> 764 </span><span class="lineCov"> 13 : { return std::distance(begin(), end()); }</span> -<span class="lineNum"> 765 </span> : -<span class="lineNum"> 766 </span> : /** Returns the size() of the largest possible %list. */ -<span class="lineNum"> 767 </span> : size_type -<span class="lineNum"> 768 </span> : max_size() const -<span class="lineNum"> 769 </span> : { return _M_get_Tp_allocator().max_size(); } -<span class="lineNum"> 770 </span> : -<span class="lineNum"> 771 </span> : /** -<span class="lineNum"> 772 </span> : * @brief Resizes the %list to the specified number of elements. -<span class="lineNum"> 773 </span> : * @param new_size Number of elements the %list should contain. -<span class="lineNum"> 774 </span> : * @param x Data with which new elements should be populated. -<span class="lineNum"> 775 </span> : * -<span class="lineNum"> 776 </span> : * This function will %resize the %list to the specified number -<span class="lineNum"> 777 </span> : * of elements. If the number is smaller than the %list's -<span class="lineNum"> 778 </span> : * current size the %list is truncated, otherwise the %list is -<span class="lineNum"> 779 </span> : * extended and new elements are populated with given data. -<span class="lineNum"> 780 </span> : */ -<span class="lineNum"> 781 </span> : void -<span class="lineNum"> 782 </span> : resize(size_type __new_size, value_type __x = value_type()); -<span class="lineNum"> 783 </span> : -<span class="lineNum"> 784 </span> : // element access -<span class="lineNum"> 785 </span> : /** -<span class="lineNum"> 786 </span> : * Returns a read/write reference to the data at the first -<span class="lineNum"> 787 </span> : * element of the %list. -<span class="lineNum"> 788 </span> : */ -<span class="lineNum"> 789 </span> : reference -<span class="lineNum"> 790 </span> : front() -<span class="lineNum"> 791 </span> : { return *begin(); } -<span class="lineNum"> 792 </span> : -<span class="lineNum"> 793 </span> : /** -<span class="lineNum"> 794 </span> : * Returns a read-only (constant) reference to the data at the first -<span class="lineNum"> 795 </span> : * element of the %list. -<span class="lineNum"> 796 </span> : */ -<span class="lineNum"> 797 </span> : const_reference -<span class="lineNum"> 798 </span> : front() const -<span class="lineNum"> 799 </span> : { return *begin(); } -<span class="lineNum"> 800 </span> : -<span class="lineNum"> 801 </span> : /** -<span class="lineNum"> 802 </span> : * Returns a read/write reference to the data at the last element -<span class="lineNum"> 803 </span> : * of the %list. -<span class="lineNum"> 804 </span> : */ -<span class="lineNum"> 805 </span> : reference -<span class="lineNum"> 806 </span> : back() -<span class="lineNum"> 807 </span> : { -<span class="lineNum"> 808 </span> : iterator __tmp = end(); -<span class="lineNum"> 809 </span> : --__tmp; -<span class="lineNum"> 810 </span> : return *__tmp; -<span class="lineNum"> 811 </span> : } -<span class="lineNum"> 812 </span> : -<span class="lineNum"> 813 </span> : /** -<span class="lineNum"> 814 </span> : * Returns a read-only (constant) reference to the data at the last -<span class="lineNum"> 815 </span> : * element of the %list. -<span class="lineNum"> 816 </span> : */ -<span class="lineNum"> 817 </span> : const_reference -<span class="lineNum"> 818 </span> : back() const -<span class="lineNum"> 819 </span> : { -<span class="lineNum"> 820 </span> : const_iterator __tmp = end(); -<span class="lineNum"> 821 </span> : --__tmp; -<span class="lineNum"> 822 </span> : return *__tmp; -<span class="lineNum"> 823 </span> : } -<span class="lineNum"> 824 </span> : -<span class="lineNum"> 825 </span> : // [23.2.2.3] modifiers -<span class="lineNum"> 826 </span> : /** -<span class="lineNum"> 827 </span> : * @brief Add data to the front of the %list. -<span class="lineNum"> 828 </span> : * @param x Data to be added. -<span class="lineNum"> 829 </span> : * -<span class="lineNum"> 830 </span> : * This is a typical stack operation. The function creates an -<span class="lineNum"> 831 </span> : * element at the front of the %list and assigns the given data -<span class="lineNum"> 832 </span> : * to it. Due to the nature of a %list this operation can be -<span class="lineNum"> 833 </span> : * done in constant time, and does not invalidate iterators and -<span class="lineNum"> 834 </span> : * references. -<span class="lineNum"> 835 </span> : */ -<span class="lineNum"> 836 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 837 </span> : void -<span class="lineNum"> 838 </span> : push_front(const value_type& __x) -<span class="lineNum"> 839 </span> : { this->_M_insert(begin(), __x); } -<span class="lineNum"> 840 </span> : #else -<span class="lineNum"> 841 </span> : template<typename... _Args> -<span class="lineNum"> 842 </span> : void -<span class="lineNum"> 843 </span> : push_front(_Args&&... __args) -<span class="lineNum"> 844 </span> : { this->_M_insert(begin(), std::forward<_Args>(__args)...); } -<span class="lineNum"> 845 </span> : #endif -<span class="lineNum"> 846 </span> : -<span class="lineNum"> 847 </span> : /** -<span class="lineNum"> 848 </span> : * @brief Removes first element. -<span class="lineNum"> 849 </span> : * -<span class="lineNum"> 850 </span> : * This is a typical stack operation. It shrinks the %list by -<span class="lineNum"> 851 </span> : * one. Due to the nature of a %list this operation can be done -<span class="lineNum"> 852 </span> : * in constant time, and only invalidates iterators/references to -<span class="lineNum"> 853 </span> : * the element being removed. -<span class="lineNum"> 854 </span> : * -<span class="lineNum"> 855 </span> : * Note that no data is returned, and if the first element's data -<span class="lineNum"> 856 </span> : * is needed, it should be retrieved before pop_front() is -<span class="lineNum"> 857 </span> : * called. -<span class="lineNum"> 858 </span> : */ -<span class="lineNum"> 859 </span> : void -<span class="lineNum"> 860 </span> : pop_front() -<span class="lineNum"> 861 </span> : { this->_M_erase(begin()); } -<span class="lineNum"> 862 </span> : -<span class="lineNum"> 863 </span> : /** -<span class="lineNum"> 864 </span> : * @brief Add data to the end of the %list. -<span class="lineNum"> 865 </span> : * @param x Data to be added. -<span class="lineNum"> 866 </span> : * -<span class="lineNum"> 867 </span> : * This is a typical stack operation. The function creates an -<span class="lineNum"> 868 </span> : * element at the end of the %list and assigns the given data to -<span class="lineNum"> 869 </span> : * it. Due to the nature of a %list this operation can be done -<span class="lineNum"> 870 </span> : * in constant time, and does not invalidate iterators and -<span class="lineNum"> 871 </span> : * references. -<span class="lineNum"> 872 </span> : */ -<span class="lineNum"> 873 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 874 </span> : void -<span class="lineNum"> 875 </span><span class="lineCov"> 47 : push_back(const value_type& __x)</span> -<span class="lineNum"> 876 </span><span class="lineCov"> 47 : { this->_M_insert(end(), __x); }</span> -<span class="lineNum"> 877 </span> : #else -<span class="lineNum"> 878 </span> : template<typename... _Args> -<span class="lineNum"> 879 </span> : void -<span class="lineNum"> 880 </span> : push_back(_Args&&... __args) -<span class="lineNum"> 881 </span> : { this->_M_insert(end(), std::forward<_Args>(__args)...); } -<span class="lineNum"> 882 </span> : #endif -<span class="lineNum"> 883 </span> : -<span class="lineNum"> 884 </span> : /** -<span class="lineNum"> 885 </span> : * @brief Removes last element. -<span class="lineNum"> 886 </span> : * -<span class="lineNum"> 887 </span> : * This is a typical stack operation. It shrinks the %list by -<span class="lineNum"> 888 </span> : * one. Due to the nature of a %list this operation can be done -<span class="lineNum"> 889 </span> : * in constant time, and only invalidates iterators/references to -<span class="lineNum"> 890 </span> : * the element being removed. -<span class="lineNum"> 891 </span> : * -<span class="lineNum"> 892 </span> : * Note that no data is returned, and if the last element's data -<span class="lineNum"> 893 </span> : * is needed, it should be retrieved before pop_back() is called. -<span class="lineNum"> 894 </span> : */ -<span class="lineNum"> 895 </span> : void -<span class="lineNum"> 896 </span> : pop_back() -<span class="lineNum"> 897 </span> : { this->_M_erase(iterator(this->_M_impl._M_node._M_prev)); } -<span class="lineNum"> 898 </span> : -<span class="lineNum"> 899 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 900 </span> : /** -<span class="lineNum"> 901 </span> : * @brief Constructs object in %list before specified iterator. -<span class="lineNum"> 902 </span> : * @param position A const_iterator into the %list. -<span class="lineNum"> 903 </span> : * @param args Arguments. -<span class="lineNum"> 904 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 905 </span> : * -<span class="lineNum"> 906 </span> : * This function will insert an object of type T constructed -<span class="lineNum"> 907 </span> : * with T(std::forward<Args>(args)...) before the specified -<span class="lineNum"> 908 </span> : * location. Due to the nature of a %list this operation can -<span class="lineNum"> 909 </span> : * be done in constant time, and does not invalidate iterators -<span class="lineNum"> 910 </span> : * and references. -<span class="lineNum"> 911 </span> : */ -<span class="lineNum"> 912 </span> : template<typename... _Args> -<span class="lineNum"> 913 </span> : iterator -<span class="lineNum"> 914 </span> : emplace(iterator __position, _Args&&... __args); -<span class="lineNum"> 915 </span> : #endif -<span class="lineNum"> 916 </span> : -<span class="lineNum"> 917 </span> : /** -<span class="lineNum"> 918 </span> : * @brief Inserts given value into %list before specified iterator. -<span class="lineNum"> 919 </span> : * @param position An iterator into the %list. -<span class="lineNum"> 920 </span> : * @param x Data to be inserted. -<span class="lineNum"> 921 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 922 </span> : * -<span class="lineNum"> 923 </span> : * This function will insert a copy of the given value before -<span class="lineNum"> 924 </span> : * the specified location. Due to the nature of a %list this -<span class="lineNum"> 925 </span> : * operation can be done in constant time, and does not -<span class="lineNum"> 926 </span> : * invalidate iterators and references. -<span class="lineNum"> 927 </span> : */ -<span class="lineNum"> 928 </span> : iterator -<span class="lineNum"> 929 </span> : insert(iterator __position, const value_type& __x); -<span class="lineNum"> 930 </span> : -<span class="lineNum"> 931 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 932 </span> : /** -<span class="lineNum"> 933 </span> : * @brief Inserts given rvalue into %list before specified iterator. -<span class="lineNum"> 934 </span> : * @param position An iterator into the %list. -<span class="lineNum"> 935 </span> : * @param x Data to be inserted. -<span class="lineNum"> 936 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 937 </span> : * -<span class="lineNum"> 938 </span> : * This function will insert a copy of the given rvalue before -<span class="lineNum"> 939 </span> : * the specified location. Due to the nature of a %list this -<span class="lineNum"> 940 </span> : * operation can be done in constant time, and does not -<span class="lineNum"> 941 </span> : * invalidate iterators and references. -<span class="lineNum"> 942 </span> : */ -<span class="lineNum"> 943 </span> : iterator -<span class="lineNum"> 944 </span> : insert(iterator __position, value_type&& __x) -<span class="lineNum"> 945 </span> : { return emplace(__position, std::move(__x)); } -<span class="lineNum"> 946 </span> : #endif -<span class="lineNum"> 947 </span> : -<span class="lineNum"> 948 </span> : /** -<span class="lineNum"> 949 </span> : * @brief Inserts a number of copies of given data into the %list. -<span class="lineNum"> 950 </span> : * @param position An iterator into the %list. -<span class="lineNum"> 951 </span> : * @param n Number of elements to be inserted. -<span class="lineNum"> 952 </span> : * @param x Data to be inserted. -<span class="lineNum"> 953 </span> : * -<span class="lineNum"> 954 </span> : * This function will insert a specified number of copies of the -<span class="lineNum"> 955 </span> : * given data before the location specified by @a position. -<span class="lineNum"> 956 </span> : * -<span class="lineNum"> 957 </span> : * This operation is linear in the number of elements inserted and -<span class="lineNum"> 958 </span> : * does not invalidate iterators and references. -<span class="lineNum"> 959 </span> : */ -<span class="lineNum"> 960 </span> : void -<span class="lineNum"> 961 </span> : insert(iterator __position, size_type __n, const value_type& __x) -<span class="lineNum"> 962 </span> : { -<span class="lineNum"> 963 </span> : list __tmp(__n, __x, _M_get_Node_allocator()); -<span class="lineNum"> 964 </span> : splice(__position, __tmp); -<span class="lineNum"> 965 </span> : } -<span class="lineNum"> 966 </span> : -<span class="lineNum"> 967 </span> : /** -<span class="lineNum"> 968 </span> : * @brief Inserts a range into the %list. -<span class="lineNum"> 969 </span> : * @param position An iterator into the %list. -<span class="lineNum"> 970 </span> : * @param first An input iterator. -<span class="lineNum"> 971 </span> : * @param last An input iterator. -<span class="lineNum"> 972 </span> : * -<span class="lineNum"> 973 </span> : * This function will insert copies of the data in the range [@a -<span class="lineNum"> 974 </span> : * first,@a last) into the %list before the location specified by -<span class="lineNum"> 975 </span> : * @a position. -<span class="lineNum"> 976 </span> : * -<span class="lineNum"> 977 </span> : * This operation is linear in the number of elements inserted and -<span class="lineNum"> 978 </span> : * does not invalidate iterators and references. -<span class="lineNum"> 979 </span> : */ -<span class="lineNum"> 980 </span> : template<typename _InputIterator> -<span class="lineNum"> 981 </span> : void -<span class="lineNum"> 982 </span> : insert(iterator __position, _InputIterator __first, -<span class="lineNum"> 983 </span> : _InputIterator __last) -<span class="lineNum"> 984 </span> : { -<span class="lineNum"> 985 </span> : list __tmp(__first, __last, _M_get_Node_allocator()); -<span class="lineNum"> 986 </span> : splice(__position, __tmp); -<span class="lineNum"> 987 </span> : } -<span class="lineNum"> 988 </span> : -<span class="lineNum"> 989 </span> : /** -<span class="lineNum"> 990 </span> : * @brief Remove element at given position. -<span class="lineNum"> 991 </span> : * @param position Iterator pointing to element to be erased. -<span class="lineNum"> 992 </span> : * @return An iterator pointing to the next element (or end()). -<span class="lineNum"> 993 </span> : * -<span class="lineNum"> 994 </span> : * This function will erase the element at the given position and thus -<span class="lineNum"> 995 </span> : * shorten the %list by one. -<span class="lineNum"> 996 </span> : * -<span class="lineNum"> 997 </span> : * Due to the nature of a %list this operation can be done in -<span class="lineNum"> 998 </span> : * constant time, and only invalidates iterators/references to -<span class="lineNum"> 999 </span> : * the element being removed. The user is also cautioned that -<span class="lineNum"> 1000 </span> : * this function only erases the element, and that if the element -<span class="lineNum"> 1001 </span> : * is itself a pointer, the pointed-to memory is not touched in -<span class="lineNum"> 1002 </span> : * any way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 1003 </span> : */ -<span class="lineNum"> 1004 </span> : iterator -<span class="lineNum"> 1005 </span> : erase(iterator __position); -<span class="lineNum"> 1006 </span> : -<span class="lineNum"> 1007 </span> : /** -<span class="lineNum"> 1008 </span> : * @brief Remove a range of elements. -<span class="lineNum"> 1009 </span> : * @param first Iterator pointing to the first element to be erased. -<span class="lineNum"> 1010 </span> : * @param last Iterator pointing to one past the last element to be -<span class="lineNum"> 1011 </span> : * erased. -<span class="lineNum"> 1012 </span> : * @return An iterator pointing to the element pointed to by @a last -<span class="lineNum"> 1013 </span> : * prior to erasing (or end()). -<span class="lineNum"> 1014 </span> : * -<span class="lineNum"> 1015 </span> : * This function will erase the elements in the range @a -<span class="lineNum"> 1016 </span> : * [first,last) and shorten the %list accordingly. -<span class="lineNum"> 1017 </span> : * -<span class="lineNum"> 1018 </span> : * This operation is linear time in the size of the range and only -<span class="lineNum"> 1019 </span> : * invalidates iterators/references to the element being removed. -<span class="lineNum"> 1020 </span> : * The user is also cautioned that this function only erases the -<span class="lineNum"> 1021 </span> : * elements, and that if the elements themselves are pointers, the -<span class="lineNum"> 1022 </span> : * pointed-to memory is not touched in any way. Managing the pointer -<span class="lineNum"> 1023 </span> : * is the user's responsibility. -<span class="lineNum"> 1024 </span> : */ -<span class="lineNum"> 1025 </span> : iterator -<span class="lineNum"> 1026 </span> : erase(iterator __first, iterator __last) -<span class="lineNum"> 1027 </span> : { -<span class="lineNum"> 1028 </span> : while (__first != __last) -<span class="lineNum"> 1029 </span> : __first = erase(__first); -<span class="lineNum"> 1030 </span> : return __last; -<span class="lineNum"> 1031 </span> : } -<span class="lineNum"> 1032 </span> : -<span class="lineNum"> 1033 </span> : /** -<span class="lineNum"> 1034 </span> : * @brief Swaps data with another %list. -<span class="lineNum"> 1035 </span> : * @param x A %list of the same element and allocator types. -<span class="lineNum"> 1036 </span> : * -<span class="lineNum"> 1037 </span> : * This exchanges the elements between two lists in constant -<span class="lineNum"> 1038 </span> : * time. Note that the global std::swap() function is -<span class="lineNum"> 1039 </span> : * specialized such that std::swap(l1,l2) will feed to this -<span class="lineNum"> 1040 </span> : * function. -<span class="lineNum"> 1041 </span> : */ -<span class="lineNum"> 1042 </span> : void -<span class="lineNum"> 1043 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1044 </span> : swap(list&& __x) -<span class="lineNum"> 1045 </span> : #else -<span class="lineNum"> 1046 </span> : swap(list& __x) -<span class="lineNum"> 1047 </span> : #endif -<span class="lineNum"> 1048 </span> : { -<span class="lineNum"> 1049 </span> : _List_node_base::swap(this->_M_impl._M_node, __x._M_impl._M_node); -<span class="lineNum"> 1050 </span> : -<span class="lineNum"> 1051 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1052 </span> : // 431. Swapping containers with unequal allocators. -<span class="lineNum"> 1053 </span> : std::__alloc_swap<typename _Base::_Node_alloc_type>:: -<span class="lineNum"> 1054 </span> : _S_do_it(_M_get_Node_allocator(), __x._M_get_Node_allocator()); -<span class="lineNum"> 1055 </span> : } -<span class="lineNum"> 1056 </span> : -<span class="lineNum"> 1057 </span> : /** -<span class="lineNum"> 1058 </span> : * Erases all the elements. Note that this function only erases -<span class="lineNum"> 1059 </span> : * the elements, and that if the elements themselves are -<span class="lineNum"> 1060 </span> : * pointers, the pointed-to memory is not touched in any way. -<span class="lineNum"> 1061 </span> : * Managing the pointer is the user's responsibility. -<span class="lineNum"> 1062 </span> : */ -<span class="lineNum"> 1063 </span> : void -<span class="lineNum"> 1064 </span> : clear() -<span class="lineNum"> 1065 </span> : { -<span class="lineNum"> 1066 </span> : _Base::_M_clear(); -<span class="lineNum"> 1067 </span> : _Base::_M_init(); -<span class="lineNum"> 1068 </span> : } -<span class="lineNum"> 1069 </span> : -<span class="lineNum"> 1070 </span> : // [23.2.2.4] list operations -<span class="lineNum"> 1071 </span> : /** -<span class="lineNum"> 1072 </span> : * @brief Insert contents of another %list. -<span class="lineNum"> 1073 </span> : * @param position Iterator referencing the element to insert before. -<span class="lineNum"> 1074 </span> : * @param x Source list. -<span class="lineNum"> 1075 </span> : * -<span class="lineNum"> 1076 </span> : * The elements of @a x are inserted in constant time in front of -<span class="lineNum"> 1077 </span> : * the element referenced by @a position. @a x becomes an empty -<span class="lineNum"> 1078 </span> : * list. -<span class="lineNum"> 1079 </span> : * -<span class="lineNum"> 1080 </span> : * Requires this != @a x. -<span class="lineNum"> 1081 </span> : */ -<span class="lineNum"> 1082 </span> : void -<span class="lineNum"> 1083 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1084 </span> : splice(iterator __position, list&& __x) -<span class="lineNum"> 1085 </span> : #else -<span class="lineNum"> 1086 </span> : splice(iterator __position, list& __x) -<span class="lineNum"> 1087 </span> : #endif -<span class="lineNum"> 1088 </span> : { -<span class="lineNum"> 1089 </span> : if (!__x.empty()) -<span class="lineNum"> 1090 </span> : { -<span class="lineNum"> 1091 </span> : _M_check_equal_allocators(__x); -<span class="lineNum"> 1092 </span> : -<span class="lineNum"> 1093 </span> : this->_M_transfer(__position, __x.begin(), __x.end()); -<span class="lineNum"> 1094 </span> : } -<span class="lineNum"> 1095 </span> : } -<span class="lineNum"> 1096 </span> : -<span class="lineNum"> 1097 </span> : /** -<span class="lineNum"> 1098 </span> : * @brief Insert element from another %list. -<span class="lineNum"> 1099 </span> : * @param position Iterator referencing the element to insert before. -<span class="lineNum"> 1100 </span> : * @param x Source list. -<span class="lineNum"> 1101 </span> : * @param i Iterator referencing the element to move. -<span class="lineNum"> 1102 </span> : * -<span class="lineNum"> 1103 </span> : * Removes the element in list @a x referenced by @a i and -<span class="lineNum"> 1104 </span> : * inserts it into the current list before @a position. -<span class="lineNum"> 1105 </span> : */ -<span class="lineNum"> 1106 </span> : void -<span class="lineNum"> 1107 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1108 </span> : splice(iterator __position, list&& __x, iterator __i) -<span class="lineNum"> 1109 </span> : #else -<span class="lineNum"> 1110 </span> : splice(iterator __position, list& __x, iterator __i) -<span class="lineNum"> 1111 </span> : #endif -<span class="lineNum"> 1112 </span> : { -<span class="lineNum"> 1113 </span> : iterator __j = __i; -<span class="lineNum"> 1114 </span> : ++__j; -<span class="lineNum"> 1115 </span> : if (__position == __i || __position == __j) -<span class="lineNum"> 1116 </span> : return; -<span class="lineNum"> 1117 </span> : -<span class="lineNum"> 1118 </span> : if (this != &__x) -<span class="lineNum"> 1119 </span> : _M_check_equal_allocators(__x); -<span class="lineNum"> 1120 </span> : -<span class="lineNum"> 1121 </span> : this->_M_transfer(__position, __i, __j); -<span class="lineNum"> 1122 </span> : } -<span class="lineNum"> 1123 </span> : -<span class="lineNum"> 1124 </span> : /** -<span class="lineNum"> 1125 </span> : * @brief Insert range from another %list. -<span class="lineNum"> 1126 </span> : * @param position Iterator referencing the element to insert before. -<span class="lineNum"> 1127 </span> : * @param x Source list. -<span class="lineNum"> 1128 </span> : * @param first Iterator referencing the start of range in x. -<span class="lineNum"> 1129 </span> : * @param last Iterator referencing the end of range in x. -<span class="lineNum"> 1130 </span> : * -<span class="lineNum"> 1131 </span> : * Removes elements in the range [first,last) and inserts them -<span class="lineNum"> 1132 </span> : * before @a position in constant time. -<span class="lineNum"> 1133 </span> : * -<span class="lineNum"> 1134 </span> : * Undefined if @a position is in [first,last). -<span class="lineNum"> 1135 </span> : */ -<span class="lineNum"> 1136 </span> : void -<span class="lineNum"> 1137 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1138 </span> : splice(iterator __position, list&& __x, iterator __first, -<span class="lineNum"> 1139 </span> : iterator __last) -<span class="lineNum"> 1140 </span> : #else -<span class="lineNum"> 1141 </span> : splice(iterator __position, list& __x, iterator __first, -<span class="lineNum"> 1142 </span> : iterator __last) -<span class="lineNum"> 1143 </span> : #endif -<span class="lineNum"> 1144 </span> : { -<span class="lineNum"> 1145 </span> : if (__first != __last) -<span class="lineNum"> 1146 </span> : { -<span class="lineNum"> 1147 </span> : if (this != &__x) -<span class="lineNum"> 1148 </span> : _M_check_equal_allocators(__x); -<span class="lineNum"> 1149 </span> : -<span class="lineNum"> 1150 </span> : this->_M_transfer(__position, __first, __last); -<span class="lineNum"> 1151 </span> : } -<span class="lineNum"> 1152 </span> : } -<span class="lineNum"> 1153 </span> : -<span class="lineNum"> 1154 </span> : /** -<span class="lineNum"> 1155 </span> : * @brief Remove all elements equal to value. -<span class="lineNum"> 1156 </span> : * @param value The value to remove. -<span class="lineNum"> 1157 </span> : * -<span class="lineNum"> 1158 </span> : * Removes every element in the list equal to @a value. -<span class="lineNum"> 1159 </span> : * Remaining elements stay in list order. Note that this -<span class="lineNum"> 1160 </span> : * function only erases the elements, and that if the elements -<span class="lineNum"> 1161 </span> : * themselves are pointers, the pointed-to memory is not -<span class="lineNum"> 1162 </span> : * touched in any way. Managing the pointer is the user's -<span class="lineNum"> 1163 </span> : * responsibility. -<span class="lineNum"> 1164 </span> : */ -<span class="lineNum"> 1165 </span> : void -<span class="lineNum"> 1166 </span> : remove(const _Tp& __value); -<span class="lineNum"> 1167 </span> : -<span class="lineNum"> 1168 </span> : /** -<span class="lineNum"> 1169 </span> : * @brief Remove all elements satisfying a predicate. -<span class="lineNum"> 1170 </span> : * @param Predicate Unary predicate function or object. -<span class="lineNum"> 1171 </span> : * -<span class="lineNum"> 1172 </span> : * Removes every element in the list for which the predicate -<span class="lineNum"> 1173 </span> : * returns true. Remaining elements stay in list order. Note -<span class="lineNum"> 1174 </span> : * that this function only erases the elements, and that if the -<span class="lineNum"> 1175 </span> : * elements themselves are pointers, the pointed-to memory is -<span class="lineNum"> 1176 </span> : * not touched in any way. Managing the pointer is the user's -<span class="lineNum"> 1177 </span> : * responsibility. -<span class="lineNum"> 1178 </span> : */ -<span class="lineNum"> 1179 </span> : template<typename _Predicate> -<span class="lineNum"> 1180 </span> : void -<span class="lineNum"> 1181 </span> : remove_if(_Predicate); -<span class="lineNum"> 1182 </span> : -<span class="lineNum"> 1183 </span> : /** -<span class="lineNum"> 1184 </span> : * @brief Remove consecutive duplicate elements. -<span class="lineNum"> 1185 </span> : * -<span class="lineNum"> 1186 </span> : * For each consecutive set of elements with the same value, -<span class="lineNum"> 1187 </span> : * remove all but the first one. Remaining elements stay in -<span class="lineNum"> 1188 </span> : * list order. Note that this function only erases the -<span class="lineNum"> 1189 </span> : * elements, and that if the elements themselves are pointers, -<span class="lineNum"> 1190 </span> : * the pointed-to memory is not touched in any way. Managing -<span class="lineNum"> 1191 </span> : * the pointer is the user's responsibility. -<span class="lineNum"> 1192 </span> : */ -<span class="lineNum"> 1193 </span> : void -<span class="lineNum"> 1194 </span> : unique(); -<span class="lineNum"> 1195 </span> : -<span class="lineNum"> 1196 </span> : /** -<span class="lineNum"> 1197 </span> : * @brief Remove consecutive elements satisfying a predicate. -<span class="lineNum"> 1198 </span> : * @param BinaryPredicate Binary predicate function or object. -<span class="lineNum"> 1199 </span> : * -<span class="lineNum"> 1200 </span> : * For each consecutive set of elements [first,last) that -<span class="lineNum"> 1201 </span> : * satisfy predicate(first,i) where i is an iterator in -<span class="lineNum"> 1202 </span> : * [first,last), remove all but the first one. Remaining -<span class="lineNum"> 1203 </span> : * elements stay in list order. Note that this function only -<span class="lineNum"> 1204 </span> : * erases the elements, and that if the elements themselves are -<span class="lineNum"> 1205 </span> : * pointers, the pointed-to memory is not touched in any way. -<span class="lineNum"> 1206 </span> : * Managing the pointer is the user's responsibility. -<span class="lineNum"> 1207 </span> : */ -<span class="lineNum"> 1208 </span> : template<typename _BinaryPredicate> -<span class="lineNum"> 1209 </span> : void -<span class="lineNum"> 1210 </span> : unique(_BinaryPredicate); -<span class="lineNum"> 1211 </span> : -<span class="lineNum"> 1212 </span> : /** -<span class="lineNum"> 1213 </span> : * @brief Merge sorted lists. -<span class="lineNum"> 1214 </span> : * @param x Sorted list to merge. -<span class="lineNum"> 1215 </span> : * -<span class="lineNum"> 1216 </span> : * Assumes that both @a x and this list are sorted according to -<span class="lineNum"> 1217 </span> : * operator<(). Merges elements of @a x into this list in -<span class="lineNum"> 1218 </span> : * sorted order, leaving @a x empty when complete. Elements in -<span class="lineNum"> 1219 </span> : * this list precede elements in @a x that are equal. -<span class="lineNum"> 1220 </span> : */ -<span class="lineNum"> 1221 </span> : void -<span class="lineNum"> 1222 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1223 </span> : merge(list&& __x); -<span class="lineNum"> 1224 </span> : #else -<span class="lineNum"> 1225 </span> : merge(list& __x); -<span class="lineNum"> 1226 </span> : #endif -<span class="lineNum"> 1227 </span> : -<span class="lineNum"> 1228 </span> : /** -<span class="lineNum"> 1229 </span> : * @brief Merge sorted lists according to comparison function. -<span class="lineNum"> 1230 </span> : * @param x Sorted list to merge. -<span class="lineNum"> 1231 </span> : * @param StrictWeakOrdering Comparison function defining -<span class="lineNum"> 1232 </span> : * sort order. -<span class="lineNum"> 1233 </span> : * -<span class="lineNum"> 1234 </span> : * Assumes that both @a x and this list are sorted according to -<span class="lineNum"> 1235 </span> : * StrictWeakOrdering. Merges elements of @a x into this list -<span class="lineNum"> 1236 </span> : * in sorted order, leaving @a x empty when complete. Elements -<span class="lineNum"> 1237 </span> : * in this list precede elements in @a x that are equivalent -<span class="lineNum"> 1238 </span> : * according to StrictWeakOrdering(). -<span class="lineNum"> 1239 </span> : */ -<span class="lineNum"> 1240 </span> : template<typename _StrictWeakOrdering> -<span class="lineNum"> 1241 </span> : void -<span class="lineNum"> 1242 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1243 </span> : merge(list&&, _StrictWeakOrdering); -<span class="lineNum"> 1244 </span> : #else -<span class="lineNum"> 1245 </span> : merge(list&, _StrictWeakOrdering); -<span class="lineNum"> 1246 </span> : #endif -<span class="lineNum"> 1247 </span> : -<span class="lineNum"> 1248 </span> : /** -<span class="lineNum"> 1249 </span> : * @brief Reverse the elements in list. -<span class="lineNum"> 1250 </span> : * -<span class="lineNum"> 1251 </span> : * Reverse the order of elements in the list in linear time. -<span class="lineNum"> 1252 </span> : */ -<span class="lineNum"> 1253 </span> : void -<span class="lineNum"> 1254 </span> : reverse() -<span class="lineNum"> 1255 </span> : { this->_M_impl._M_node.reverse(); } -<span class="lineNum"> 1256 </span> : -<span class="lineNum"> 1257 </span> : /** -<span class="lineNum"> 1258 </span> : * @brief Sort the elements. -<span class="lineNum"> 1259 </span> : * -<span class="lineNum"> 1260 </span> : * Sorts the elements of this list in NlogN time. Equivalent -<span class="lineNum"> 1261 </span> : * elements remain in list order. -<span class="lineNum"> 1262 </span> : */ -<span class="lineNum"> 1263 </span> : void -<span class="lineNum"> 1264 </span> : sort(); -<span class="lineNum"> 1265 </span> : -<span class="lineNum"> 1266 </span> : /** -<span class="lineNum"> 1267 </span> : * @brief Sort the elements according to comparison function. -<span class="lineNum"> 1268 </span> : * -<span class="lineNum"> 1269 </span> : * Sorts the elements of this list in NlogN time. Equivalent -<span class="lineNum"> 1270 </span> : * elements remain in list order. -<span class="lineNum"> 1271 </span> : */ -<span class="lineNum"> 1272 </span> : template<typename _StrictWeakOrdering> -<span class="lineNum"> 1273 </span> : void -<span class="lineNum"> 1274 </span> : sort(_StrictWeakOrdering); -<span class="lineNum"> 1275 </span> : -<span class="lineNum"> 1276 </span> : protected: -<span class="lineNum"> 1277 </span> : // Internal constructor functions follow. -<span class="lineNum"> 1278 </span> : -<span class="lineNum"> 1279 </span> : // Called by the range constructor to implement [23.1.1]/9 -<span class="lineNum"> 1280 </span> : -<span class="lineNum"> 1281 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1282 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1283 </span> : template<typename _Integer> -<span class="lineNum"> 1284 </span> : void -<span class="lineNum"> 1285 </span> : _M_initialize_dispatch(_Integer __n, _Integer __x, __true_type) -<span class="lineNum"> 1286 </span> : { _M_fill_initialize(static_cast<size_type>(__n), __x); } -<span class="lineNum"> 1287 </span> : -<span class="lineNum"> 1288 </span> : // Called by the range constructor to implement [23.1.1]/9 -<span class="lineNum"> 1289 </span> : template<typename _InputIterator> -<span class="lineNum"> 1290 </span> : void -<span class="lineNum"> 1291 </span> : _M_initialize_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1292 </span> : __false_type) -<span class="lineNum"> 1293 </span> : { -<span class="lineNum"> 1294 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 1295 </span> : push_back(*__first); -<span class="lineNum"> 1296 </span> : } -<span class="lineNum"> 1297 </span> : -<span class="lineNum"> 1298 </span> : // Called by list(n,v,a), and the range constructor when it turns out -<span class="lineNum"> 1299 </span> : // to be the same thing. -<span class="lineNum"> 1300 </span> : void -<span class="lineNum"> 1301 </span> : _M_fill_initialize(size_type __n, const value_type& __x) -<span class="lineNum"> 1302 </span> : { -<span class="lineNum"> 1303 </span> : for (; __n > 0; --__n) -<span class="lineNum"> 1304 </span> : push_back(__x); -<span class="lineNum"> 1305 </span> : } -<span class="lineNum"> 1306 </span> : -<span class="lineNum"> 1307 </span> : -<span class="lineNum"> 1308 </span> : // Internal assign functions follow. -<span class="lineNum"> 1309 </span> : -<span class="lineNum"> 1310 </span> : // Called by the range assign to implement [23.1.1]/9 -<span class="lineNum"> 1311 </span> : -<span class="lineNum"> 1312 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1313 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1314 </span> : template<typename _Integer> -<span class="lineNum"> 1315 </span> : void -<span class="lineNum"> 1316 </span> : _M_assign_dispatch(_Integer __n, _Integer __val, __true_type) -<span class="lineNum"> 1317 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 1318 </span> : -<span class="lineNum"> 1319 </span> : // Called by the range assign to implement [23.1.1]/9 -<span class="lineNum"> 1320 </span> : template<typename _InputIterator> -<span class="lineNum"> 1321 </span> : void -<span class="lineNum"> 1322 </span> : _M_assign_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1323 </span> : __false_type); -<span class="lineNum"> 1324 </span> : -<span class="lineNum"> 1325 </span> : // Called by assign(n,t), and the range assign when it turns out -<span class="lineNum"> 1326 </span> : // to be the same thing. -<span class="lineNum"> 1327 </span> : void -<span class="lineNum"> 1328 </span> : _M_fill_assign(size_type __n, const value_type& __val); -<span class="lineNum"> 1329 </span> : -<span class="lineNum"> 1330 </span> : -<span class="lineNum"> 1331 </span> : // Moves the elements from [first,last) before position. -<span class="lineNum"> 1332 </span> : void -<span class="lineNum"> 1333 </span> : _M_transfer(iterator __position, iterator __first, iterator __last) -<span class="lineNum"> 1334 </span> : { __position._M_node->transfer(__first._M_node, __last._M_node); } -<span class="lineNum"> 1335 </span> : -<span class="lineNum"> 1336 </span> : // Inserts new element at position given and with value given. -<span class="lineNum"> 1337 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1338 </span> : void -<span class="lineNum"> 1339 </span><span class="lineCov"> 47 : _M_insert(iterator __position, const value_type& __x)</span> -<span class="lineNum"> 1340 </span> : { -<span class="lineNum"> 1341 </span><span class="lineCov"> 47 : _Node* __tmp = _M_create_node(__x);</span> -<span class="lineNum"> 1342 </span><span class="lineCov"> 47 : __tmp->hook(__position._M_node);</span> -<span class="lineNum"> 1343 </span><span class="lineCov"> 47 : }</span> -<span class="lineNum"> 1344 </span> : #else -<span class="lineNum"> 1345 </span> : template<typename... _Args> -<span class="lineNum"> 1346 </span> : void -<span class="lineNum"> 1347 </span> : _M_insert(iterator __position, _Args&&... __args) -<span class="lineNum"> 1348 </span> : { -<span class="lineNum"> 1349 </span> : _Node* __tmp = _M_create_node(std::forward<_Args>(__args)...); -<span class="lineNum"> 1350 </span> : __tmp->hook(__position._M_node); -<span class="lineNum"> 1351 </span> : } -<span class="lineNum"> 1352 </span> : #endif -<span class="lineNum"> 1353 </span> : -<span class="lineNum"> 1354 </span> : // Erases element at position given. -<span class="lineNum"> 1355 </span> : void -<span class="lineNum"> 1356 </span><span class="lineCov"> 25 : _M_erase(iterator __position)</span> -<span class="lineNum"> 1357 </span> : { -<span class="lineNum"> 1358 </span><span class="lineCov"> 25 : __position._M_node->unhook();</span> -<span class="lineNum"> 1359 </span><span class="lineCov"> 25 : _Node* __n = static_cast<_Node*>(__position._M_node);</span> -<span class="lineNum"> 1360 </span><span class="lineCov"> 25 : _M_get_Tp_allocator().destroy(&__n->_M_data);</span> -<span class="lineNum"> 1361 </span><span class="lineCov"> 25 : _M_put_node(__n);</span> -<span class="lineNum"> 1362 </span><span class="lineCov"> 25 : }</span> -<span class="lineNum"> 1363 </span> : -<span class="lineNum"> 1364 </span> : // To implement the splice (and merge) bits of N1599. -<span class="lineNum"> 1365 </span> : void -<span class="lineNum"> 1366 </span> : _M_check_equal_allocators(list& __x) -<span class="lineNum"> 1367 </span> : { -<span class="lineNum"> 1368 </span> : if (std::__alloc_neq<typename _Base::_Node_alloc_type>:: -<span class="lineNum"> 1369 </span> : _S_do_it(_M_get_Node_allocator(), __x._M_get_Node_allocator())) -<span class="lineNum"> 1370 </span> : __throw_runtime_error(__N("list::_M_check_equal_allocators")); -<span class="lineNum"> 1371 </span> : } -<span class="lineNum"> 1372 </span> : }; -<span class="lineNum"> 1373 </span> : -<span class="lineNum"> 1374 </span> : /** -<span class="lineNum"> 1375 </span> : * @brief List equality comparison. -<span class="lineNum"> 1376 </span> : * @param x A %list. -<span class="lineNum"> 1377 </span> : * @param y A %list of the same type as @a x. -<span class="lineNum"> 1378 </span> : * @return True iff the size and elements of the lists are equal. -<span class="lineNum"> 1379 </span> : * -<span class="lineNum"> 1380 </span> : * This is an equivalence relation. It is linear in the size of -<span class="lineNum"> 1381 </span> : * the lists. Lists are considered equivalent if their sizes are -<span class="lineNum"> 1382 </span> : * equal, and if corresponding elements compare equal. -<span class="lineNum"> 1383 </span> : */ -<span class="lineNum"> 1384 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1385 </span> : inline bool -<span class="lineNum"> 1386 </span><span class="lineCov"> 4 : operator==(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y)</span> -<span class="lineNum"> 1387 </span> : { -<span class="lineNum"> 1388 </span> : typedef typename list<_Tp, _Alloc>::const_iterator const_iterator; -<span class="lineNum"> 1389 </span><span class="lineCov"> 4 : const_iterator __end1 = __x.end();</span> -<span class="lineNum"> 1390 </span><span class="lineCov"> 4 : const_iterator __end2 = __y.end();</span> -<span class="lineNum"> 1391 </span> : -<span class="lineNum"> 1392 </span><span class="lineCov"> 4 : const_iterator __i1 = __x.begin();</span> -<span class="lineNum"> 1393 </span><span class="lineCov"> 4 : const_iterator __i2 = __y.begin();</span> -<span class="lineNum"> 1394 </span><span class="lineCov"> 12 : while (__i1 != __end1 && __i2 != __end2 && *__i1 == *__i2)</span> -<span class="lineNum"> 1395 </span> : { -<span class="lineNum"> 1396 </span><span class="lineCov"> 4 : ++__i1;</span> -<span class="lineNum"> 1397 </span><span class="lineCov"> 4 : ++__i2;</span> -<span class="lineNum"> 1398 </span> : } -<span class="lineNum"> 1399 </span><span class="lineCov"> 4 : return __i1 == __end1 && __i2 == __end2;</span> -<span class="lineNum"> 1400 </span> : } -<span class="lineNum"> 1401 </span> : -<span class="lineNum"> 1402 </span> : /** -<span class="lineNum"> 1403 </span> : * @brief List ordering relation. -<span class="lineNum"> 1404 </span> : * @param x A %list. -<span class="lineNum"> 1405 </span> : * @param y A %list of the same type as @a x. -<span class="lineNum"> 1406 </span> : * @return True iff @a x is lexicographically less than @a y. -<span class="lineNum"> 1407 </span> : * -<span class="lineNum"> 1408 </span> : * This is a total ordering relation. It is linear in the size of the -<span class="lineNum"> 1409 </span> : * lists. The elements must be comparable with @c <. -<span class="lineNum"> 1410 </span> : * -<span class="lineNum"> 1411 </span> : * See std::lexicographical_compare() for how the determination is made. -<span class="lineNum"> 1412 </span> : */ -<span class="lineNum"> 1413 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1414 </span> : inline bool -<span class="lineNum"> 1415 </span> : operator<(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) -<span class="lineNum"> 1416 </span> : { return std::lexicographical_compare(__x.begin(), __x.end(), -<span class="lineNum"> 1417 </span> : __y.begin(), __y.end()); } -<span class="lineNum"> 1418 </span> : -<span class="lineNum"> 1419 </span> : /// Based on operator== -<span class="lineNum"> 1420 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1421 </span> : inline bool -<span class="lineNum"> 1422 </span><span class="lineCov"> 2 : operator!=(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y)</span> -<span class="lineNum"> 1423 </span><span class="lineCov"> 2 : { return !(__x == __y); }</span> -<span class="lineNum"> 1424 </span> : -<span class="lineNum"> 1425 </span> : /// Based on operator< -<span class="lineNum"> 1426 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1427 </span> : inline bool -<span class="lineNum"> 1428 </span> : operator>(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) -<span class="lineNum"> 1429 </span> : { return __y < __x; } -<span class="lineNum"> 1430 </span> : -<span class="lineNum"> 1431 </span> : /// Based on operator< -<span class="lineNum"> 1432 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1433 </span> : inline bool -<span class="lineNum"> 1434 </span> : operator<=(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) -<span class="lineNum"> 1435 </span> : { return !(__y < __x); } -<span class="lineNum"> 1436 </span> : -<span class="lineNum"> 1437 </span> : /// Based on operator< -<span class="lineNum"> 1438 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1439 </span> : inline bool -<span class="lineNum"> 1440 </span> : operator>=(const list<_Tp, _Alloc>& __x, const list<_Tp, _Alloc>& __y) -<span class="lineNum"> 1441 </span> : { return !(__x < __y); } -<span class="lineNum"> 1442 </span> : -<span class="lineNum"> 1443 </span> : /// See std::list::swap(). -<span class="lineNum"> 1444 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1445 </span> : inline void -<span class="lineNum"> 1446 </span> : swap(list<_Tp, _Alloc>& __x, list<_Tp, _Alloc>& __y) -<span class="lineNum"> 1447 </span> : { __x.swap(__y); } -<span class="lineNum"> 1448 </span> : -<span class="lineNum"> 1449 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1450 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1451 </span> : inline void -<span class="lineNum"> 1452 </span> : swap(list<_Tp, _Alloc>&& __x, list<_Tp, _Alloc>& __y) -<span class="lineNum"> 1453 </span> : { __x.swap(__y); } -<span class="lineNum"> 1454 </span> : -<span class="lineNum"> 1455 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1456 </span> : inline void -<span class="lineNum"> 1457 </span> : swap(list<_Tp, _Alloc>& __x, list<_Tp, _Alloc>&& __y) -<span class="lineNum"> 1458 </span> : { __x.swap(__y); } -<span class="lineNum"> 1459 </span> : #endif -<span class="lineNum"> 1460 </span> : -<span class="lineNum"> 1461 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 1462 </span> : -<span class="lineNum"> 1463 </span> : #endif /* _STL_LIST_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_map.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_map.h.gcov.html deleted file mode 100644 index 6a8cb4e..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_map.h.gcov.html +++ /dev/null @@ -1,894 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_map.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_map.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">41</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">41</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Map implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_map.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_MAP_H -<span class="lineNum"> 63 </span> : #define _STL_MAP_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/functexcept.h> -<span class="lineNum"> 66 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 67 </span> : -<span class="lineNum"> 68 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : /** -<span class="lineNum"> 71 </span> : * @brief A standard container made up of (key,value) pairs, which can be -<span class="lineNum"> 72 </span> : * retrieved based on a key, in logarithmic time. -<span class="lineNum"> 73 </span> : * -<span class="lineNum"> 74 </span> : * @ingroup Containers -<span class="lineNum"> 75 </span> : * @ingroup Assoc_containers -<span class="lineNum"> 76 </span> : * -<span class="lineNum"> 77 </span> : * Meets the requirements of a <a href="tables.html#65">container</a>, a -<span class="lineNum"> 78 </span> : * <a href="tables.html#66">reversible container</a>, and an -<span class="lineNum"> 79 </span> : * <a href="tables.html#69">associative container</a> (using unique keys). -<span class="lineNum"> 80 </span> : * For a @c map<Key,T> the key_type is Key, the mapped_type is T, and the -<span class="lineNum"> 81 </span> : * value_type is std::pair<const Key,T>. -<span class="lineNum"> 82 </span> : * -<span class="lineNum"> 83 </span> : * Maps support bidirectional iterators. -<span class="lineNum"> 84 </span> : * -<span class="lineNum"> 85 </span> : * The private tree data is declared exactly the same way for map and -<span class="lineNum"> 86 </span> : * multimap; the distinction is made entirely in how the tree functions are -<span class="lineNum"> 87 </span> : * called (*_unique versus *_equal, same as the standard). -<span class="lineNum"> 88 </span> : */ -<span class="lineNum"> 89 </span> : template <typename _Key, typename _Tp, typename _Compare = std::less<_Key>, -<span class="lineNum"> 90 </span> : typename _Alloc = std::allocator<std::pair<const _Key, _Tp> > > -<span class="lineNum"> 91 </span> : class map -<span class="lineNum"> 92 </span><span class="lineCov"> 12304 : {</span> -<span class="lineNum"> 93 </span> : public: -<span class="lineNum"> 94 </span> : typedef _Key key_type; -<span class="lineNum"> 95 </span> : typedef _Tp mapped_type; -<span class="lineNum"> 96 </span> : typedef std::pair<const _Key, _Tp> value_type; -<span class="lineNum"> 97 </span> : typedef _Compare key_compare; -<span class="lineNum"> 98 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 99 </span> : -<span class="lineNum"> 100 </span> : private: -<span class="lineNum"> 101 </span> : // concept requirements -<span class="lineNum"> 102 </span> : typedef typename _Alloc::value_type _Alloc_value_type; -<span class="lineNum"> 103 </span> : __glibcxx_class_requires(_Tp, _SGIAssignableConcept) -<span class="lineNum"> 104 </span> : __glibcxx_class_requires4(_Compare, bool, _Key, _Key, -<span class="lineNum"> 105 </span> : _BinaryFunctionConcept) -<span class="lineNum"> 106 </span> : __glibcxx_class_requires2(value_type, _Alloc_value_type, _SameTypeConcept) -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : public: -<span class="lineNum"> 109 </span> : class value_compare -<span class="lineNum"> 110 </span> : : public std::binary_function<value_type, value_type, bool> -<span class="lineNum"> 111 </span> : { -<span class="lineNum"> 112 </span> : friend class map<_Key, _Tp, _Compare, _Alloc>; -<span class="lineNum"> 113 </span> : protected: -<span class="lineNum"> 114 </span> : _Compare comp; -<span class="lineNum"> 115 </span> : -<span class="lineNum"> 116 </span> : value_compare(_Compare __c) -<span class="lineNum"> 117 </span> : : comp(__c) { } -<span class="lineNum"> 118 </span> : -<span class="lineNum"> 119 </span> : public: -<span class="lineNum"> 120 </span> : bool operator()(const value_type& __x, const value_type& __y) const -<span class="lineNum"> 121 </span> : { return comp(__x.first, __y.first); } -<span class="lineNum"> 122 </span> : }; -<span class="lineNum"> 123 </span> : -<span class="lineNum"> 124 </span> : private: -<span class="lineNum"> 125 </span> : /// This turns a red-black tree into a [multi]map. -<span class="lineNum"> 126 </span> : typedef typename _Alloc::template rebind<value_type>::other -<span class="lineNum"> 127 </span> : _Pair_alloc_type; -<span class="lineNum"> 128 </span> : -<span class="lineNum"> 129 </span> : typedef _Rb_tree<key_type, value_type, _Select1st<value_type>, -<span class="lineNum"> 130 </span> : key_compare, _Pair_alloc_type> _Rep_type; -<span class="lineNum"> 131 </span> : -<span class="lineNum"> 132 </span> : /// The actual tree structure. -<span class="lineNum"> 133 </span> : _Rep_type _M_t; -<span class="lineNum"> 134 </span> : -<span class="lineNum"> 135 </span> : public: -<span class="lineNum"> 136 </span> : // many of these are specified differently in ISO, but the following are -<span class="lineNum"> 137 </span> : // "functionally equivalent" -<span class="lineNum"> 138 </span> : typedef typename _Pair_alloc_type::pointer pointer; -<span class="lineNum"> 139 </span> : typedef typename _Pair_alloc_type::const_pointer const_pointer; -<span class="lineNum"> 140 </span> : typedef typename _Pair_alloc_type::reference reference; -<span class="lineNum"> 141 </span> : typedef typename _Pair_alloc_type::const_reference const_reference; -<span class="lineNum"> 142 </span> : typedef typename _Rep_type::iterator iterator; -<span class="lineNum"> 143 </span> : typedef typename _Rep_type::const_iterator const_iterator; -<span class="lineNum"> 144 </span> : typedef typename _Rep_type::size_type size_type; -<span class="lineNum"> 145 </span> : typedef typename _Rep_type::difference_type difference_type; -<span class="lineNum"> 146 </span> : typedef typename _Rep_type::reverse_iterator reverse_iterator; -<span class="lineNum"> 147 </span> : typedef typename _Rep_type::const_reverse_iterator const_reverse_iterator; -<span class="lineNum"> 148 </span> : -<span class="lineNum"> 149 </span> : // [23.3.1.1] construct/copy/destroy -<span class="lineNum"> 150 </span> : // (get_allocator() is normally listed in this section, but seems to have -<span class="lineNum"> 151 </span> : // been accidentally omitted in the printed standard) -<span class="lineNum"> 152 </span> : /** -<span class="lineNum"> 153 </span> : * @brief Default constructor creates no elements. -<span class="lineNum"> 154 </span> : */ -<span class="lineNum"> 155 </span><span class="lineCov"> 2859 : map()</span> -<span class="lineNum"> 156 </span><span class="lineCov"> 2859 : : _M_t() { }</span> -<span class="lineNum"> 157 </span> : -<span class="lineNum"> 158 </span> : /** -<span class="lineNum"> 159 </span> : * @brief Creates a %map with no elements. -<span class="lineNum"> 160 </span> : * @param comp A comparison object. -<span class="lineNum"> 161 </span> : * @param a An allocator object. -<span class="lineNum"> 162 </span> : */ -<span class="lineNum"> 163 </span> : explicit -<span class="lineNum"> 164 </span> : map(const _Compare& __comp, -<span class="lineNum"> 165 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 166 </span> : : _M_t(__comp, __a) { } -<span class="lineNum"> 167 </span> : -<span class="lineNum"> 168 </span> : /** -<span class="lineNum"> 169 </span> : * @brief %Map copy constructor. -<span class="lineNum"> 170 </span> : * @param x A %map of identical element and allocator types. -<span class="lineNum"> 171 </span> : * -<span class="lineNum"> 172 </span> : * The newly-created %map uses a copy of the allocation object -<span class="lineNum"> 173 </span> : * used by @a x. -<span class="lineNum"> 174 </span> : */ -<span class="lineNum"> 175 </span><span class="lineCov"> 9445 : map(const map& __x)</span> -<span class="lineNum"> 176 </span><span class="lineCov"> 9445 : : _M_t(__x._M_t) { }</span> -<span class="lineNum"> 177 </span> : -<span class="lineNum"> 178 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 179 </span> : /** -<span class="lineNum"> 180 </span> : * @brief %Map move constructor. -<span class="lineNum"> 181 </span> : * @param x A %map of identical element and allocator types. -<span class="lineNum"> 182 </span> : * -<span class="lineNum"> 183 </span> : * The newly-created %map contains the exact contents of @a x. -<span class="lineNum"> 184 </span> : * The contents of @a x are a valid, but unspecified %map. -<span class="lineNum"> 185 </span> : */ -<span class="lineNum"> 186 </span> : map(map&& __x) -<span class="lineNum"> 187 </span> : : _M_t(std::forward<_Rep_type>(__x._M_t)) { } -<span class="lineNum"> 188 </span> : #endif -<span class="lineNum"> 189 </span> : -<span class="lineNum"> 190 </span> : /** -<span class="lineNum"> 191 </span> : * @brief Builds a %map from a range. -<span class="lineNum"> 192 </span> : * @param first An input iterator. -<span class="lineNum"> 193 </span> : * @param last An input iterator. -<span class="lineNum"> 194 </span> : * -<span class="lineNum"> 195 </span> : * Create a %map consisting of copies of the elements from [first,last). -<span class="lineNum"> 196 </span> : * This is linear in N if the range is already sorted, and NlogN -<span class="lineNum"> 197 </span> : * otherwise (where N is distance(first,last)). -<span class="lineNum"> 198 </span> : */ -<span class="lineNum"> 199 </span> : template<typename _InputIterator> -<span class="lineNum"> 200 </span> : map(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 201 </span> : : _M_t() -<span class="lineNum"> 202 </span> : { _M_t._M_insert_unique(__first, __last); } -<span class="lineNum"> 203 </span> : -<span class="lineNum"> 204 </span> : /** -<span class="lineNum"> 205 </span> : * @brief Builds a %map from a range. -<span class="lineNum"> 206 </span> : * @param first An input iterator. -<span class="lineNum"> 207 </span> : * @param last An input iterator. -<span class="lineNum"> 208 </span> : * @param comp A comparison functor. -<span class="lineNum"> 209 </span> : * @param a An allocator object. -<span class="lineNum"> 210 </span> : * -<span class="lineNum"> 211 </span> : * Create a %map consisting of copies of the elements from [first,last). -<span class="lineNum"> 212 </span> : * This is linear in N if the range is already sorted, and NlogN -<span class="lineNum"> 213 </span> : * otherwise (where N is distance(first,last)). -<span class="lineNum"> 214 </span> : */ -<span class="lineNum"> 215 </span> : template<typename _InputIterator> -<span class="lineNum"> 216 </span> : map(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 217 </span> : const _Compare& __comp, -<span class="lineNum"> 218 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 219 </span> : : _M_t(__comp, __a) -<span class="lineNum"> 220 </span> : { _M_t._M_insert_unique(__first, __last); } -<span class="lineNum"> 221 </span> : -<span class="lineNum"> 222 </span> : // FIXME There is no dtor declared, but we should have something -<span class="lineNum"> 223 </span> : // generated by Doxygen. I don't know what tags to add to this -<span class="lineNum"> 224 </span> : // paragraph to make that happen: -<span class="lineNum"> 225 </span> : /** -<span class="lineNum"> 226 </span> : * The dtor only erases the elements, and note that if the elements -<span class="lineNum"> 227 </span> : * themselves are pointers, the pointed-to memory is not touched in any -<span class="lineNum"> 228 </span> : * way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 229 </span> : */ -<span class="lineNum"> 230 </span> : -<span class="lineNum"> 231 </span> : /** -<span class="lineNum"> 232 </span> : * @brief %Map assignment operator. -<span class="lineNum"> 233 </span> : * @param x A %map of identical element and allocator types. -<span class="lineNum"> 234 </span> : * -<span class="lineNum"> 235 </span> : * All the elements of @a x are copied, but unlike the copy constructor, -<span class="lineNum"> 236 </span> : * the allocator object is not copied. -<span class="lineNum"> 237 </span> : */ -<span class="lineNum"> 238 </span> : map& -<span class="lineNum"> 239 </span><span class="lineCov"> 17 : operator=(const map& __x)</span> -<span class="lineNum"> 240 </span> : { -<span class="lineNum"> 241 </span><span class="lineCov"> 17 : _M_t = __x._M_t;</span> -<span class="lineNum"> 242 </span><span class="lineCov"> 17 : return *this;</span> -<span class="lineNum"> 243 </span> : } -<span class="lineNum"> 244 </span> : -<span class="lineNum"> 245 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 246 </span> : /** -<span class="lineNum"> 247 </span> : * @brief %Map move assignment operator. -<span class="lineNum"> 248 </span> : * @param x A %map of identical element and allocator types. -<span class="lineNum"> 249 </span> : * -<span class="lineNum"> 250 </span> : * The contents of @a x are moved into this map (without copying). -<span class="lineNum"> 251 </span> : * @a x is a valid, but unspecified %map. -<span class="lineNum"> 252 </span> : */ -<span class="lineNum"> 253 </span> : map& -<span class="lineNum"> 254 </span> : operator=(map&& __x) -<span class="lineNum"> 255 </span> : { -<span class="lineNum"> 256 </span> : // NB: DR 675. -<span class="lineNum"> 257 </span> : this->clear(); -<span class="lineNum"> 258 </span> : this->swap(__x); -<span class="lineNum"> 259 </span> : return *this; -<span class="lineNum"> 260 </span> : } -<span class="lineNum"> 261 </span> : #endif -<span class="lineNum"> 262 </span> : -<span class="lineNum"> 263 </span> : /// Get a copy of the memory allocation object. -<span class="lineNum"> 264 </span> : allocator_type -<span class="lineNum"> 265 </span> : get_allocator() const -<span class="lineNum"> 266 </span> : { return _M_t.get_allocator(); } -<span class="lineNum"> 267 </span> : -<span class="lineNum"> 268 </span> : // iterators -<span class="lineNum"> 269 </span> : /** -<span class="lineNum"> 270 </span> : * Returns a read/write iterator that points to the first pair in the -<span class="lineNum"> 271 </span> : * %map. -<span class="lineNum"> 272 </span> : * Iteration is done in ascending order according to the keys. -<span class="lineNum"> 273 </span> : */ -<span class="lineNum"> 274 </span> : iterator -<span class="lineNum"> 275 </span><span class="lineCov"> 2681 : begin()</span> -<span class="lineNum"> 276 </span><span class="lineCov"> 2681 : { return _M_t.begin(); }</span> -<span class="lineNum"> 277 </span> : -<span class="lineNum"> 278 </span> : /** -<span class="lineNum"> 279 </span> : * Returns a read-only (constant) iterator that points to the first pair -<span class="lineNum"> 280 </span> : * in the %map. Iteration is done in ascending order according to the -<span class="lineNum"> 281 </span> : * keys. -<span class="lineNum"> 282 </span> : */ -<span class="lineNum"> 283 </span> : const_iterator -<span class="lineNum"> 284 </span><span class="lineCov"> 154 : begin() const</span> -<span class="lineNum"> 285 </span><span class="lineCov"> 154 : { return _M_t.begin(); }</span> -<span class="lineNum"> 286 </span> : -<span class="lineNum"> 287 </span> : /** -<span class="lineNum"> 288 </span> : * Returns a read/write iterator that points one past the last -<span class="lineNum"> 289 </span> : * pair in the %map. Iteration is done in ascending order -<span class="lineNum"> 290 </span> : * according to the keys. -<span class="lineNum"> 291 </span> : */ -<span class="lineNum"> 292 </span> : iterator -<span class="lineNum"> 293 </span><span class="lineCov"> 155879 : end()</span> -<span class="lineNum"> 294 </span><span class="lineCov"> 155879 : { return _M_t.end(); }</span> -<span class="lineNum"> 295 </span> : -<span class="lineNum"> 296 </span> : /** -<span class="lineNum"> 297 </span> : * Returns a read-only (constant) iterator that points one past the last -<span class="lineNum"> 298 </span> : * pair in the %map. Iteration is done in ascending order according to -<span class="lineNum"> 299 </span> : * the keys. -<span class="lineNum"> 300 </span> : */ -<span class="lineNum"> 301 </span> : const_iterator -<span class="lineNum"> 302 </span><span class="lineCov"> 441802 : end() const</span> -<span class="lineNum"> 303 </span><span class="lineCov"> 441802 : { return _M_t.end(); }</span> -<span class="lineNum"> 304 </span> : -<span class="lineNum"> 305 </span> : /** -<span class="lineNum"> 306 </span> : * Returns a read/write reverse iterator that points to the last pair in -<span class="lineNum"> 307 </span> : * the %map. Iteration is done in descending order according to the -<span class="lineNum"> 308 </span> : * keys. -<span class="lineNum"> 309 </span> : */ -<span class="lineNum"> 310 </span> : reverse_iterator -<span class="lineNum"> 311 </span> : rbegin() -<span class="lineNum"> 312 </span> : { return _M_t.rbegin(); } -<span class="lineNum"> 313 </span> : -<span class="lineNum"> 314 </span> : /** -<span class="lineNum"> 315 </span> : * Returns a read-only (constant) reverse iterator that points to the -<span class="lineNum"> 316 </span> : * last pair in the %map. Iteration is done in descending order -<span class="lineNum"> 317 </span> : * according to the keys. -<span class="lineNum"> 318 </span> : */ -<span class="lineNum"> 319 </span> : const_reverse_iterator -<span class="lineNum"> 320 </span><span class="lineCov"> 32 : rbegin() const</span> -<span class="lineNum"> 321 </span><span class="lineCov"> 32 : { return _M_t.rbegin(); }</span> -<span class="lineNum"> 322 </span> : -<span class="lineNum"> 323 </span> : /** -<span class="lineNum"> 324 </span> : * Returns a read/write reverse iterator that points to one before the -<span class="lineNum"> 325 </span> : * first pair in the %map. Iteration is done in descending order -<span class="lineNum"> 326 </span> : * according to the keys. -<span class="lineNum"> 327 </span> : */ -<span class="lineNum"> 328 </span> : reverse_iterator -<span class="lineNum"> 329 </span> : rend() -<span class="lineNum"> 330 </span> : { return _M_t.rend(); } -<span class="lineNum"> 331 </span> : -<span class="lineNum"> 332 </span> : /** -<span class="lineNum"> 333 </span> : * Returns a read-only (constant) reverse iterator that points to one -<span class="lineNum"> 334 </span> : * before the first pair in the %map. Iteration is done in descending -<span class="lineNum"> 335 </span> : * order according to the keys. -<span class="lineNum"> 336 </span> : */ -<span class="lineNum"> 337 </span> : const_reverse_iterator -<span class="lineNum"> 338 </span> : rend() const -<span class="lineNum"> 339 </span> : { return _M_t.rend(); } -<span class="lineNum"> 340 </span> : -<span class="lineNum"> 341 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 342 </span> : /** -<span class="lineNum"> 343 </span> : * Returns a read-only (constant) iterator that points to the first pair -<span class="lineNum"> 344 </span> : * in the %map. Iteration is done in ascending order according to the -<span class="lineNum"> 345 </span> : * keys. -<span class="lineNum"> 346 </span> : */ -<span class="lineNum"> 347 </span> : const_iterator -<span class="lineNum"> 348 </span> : cbegin() const -<span class="lineNum"> 349 </span> : { return _M_t.begin(); } -<span class="lineNum"> 350 </span> : -<span class="lineNum"> 351 </span> : /** -<span class="lineNum"> 352 </span> : * Returns a read-only (constant) iterator that points one past the last -<span class="lineNum"> 353 </span> : * pair in the %map. Iteration is done in ascending order according to -<span class="lineNum"> 354 </span> : * the keys. -<span class="lineNum"> 355 </span> : */ -<span class="lineNum"> 356 </span> : const_iterator -<span class="lineNum"> 357 </span> : cend() const -<span class="lineNum"> 358 </span> : { return _M_t.end(); } -<span class="lineNum"> 359 </span> : -<span class="lineNum"> 360 </span> : /** -<span class="lineNum"> 361 </span> : * Returns a read-only (constant) reverse iterator that points to the -<span class="lineNum"> 362 </span> : * last pair in the %map. Iteration is done in descending order -<span class="lineNum"> 363 </span> : * according to the keys. -<span class="lineNum"> 364 </span> : */ -<span class="lineNum"> 365 </span> : const_reverse_iterator -<span class="lineNum"> 366 </span> : crbegin() const -<span class="lineNum"> 367 </span> : { return _M_t.rbegin(); } -<span class="lineNum"> 368 </span> : -<span class="lineNum"> 369 </span> : /** -<span class="lineNum"> 370 </span> : * Returns a read-only (constant) reverse iterator that points to one -<span class="lineNum"> 371 </span> : * before the first pair in the %map. Iteration is done in descending -<span class="lineNum"> 372 </span> : * order according to the keys. -<span class="lineNum"> 373 </span> : */ -<span class="lineNum"> 374 </span> : const_reverse_iterator -<span class="lineNum"> 375 </span> : crend() const -<span class="lineNum"> 376 </span> : { return _M_t.rend(); } -<span class="lineNum"> 377 </span> : #endif -<span class="lineNum"> 378 </span> : -<span class="lineNum"> 379 </span> : // capacity -<span class="lineNum"> 380 </span> : /** Returns true if the %map is empty. (Thus begin() would equal -<span class="lineNum"> 381 </span> : * end().) -<span class="lineNum"> 382 </span> : */ -<span class="lineNum"> 383 </span> : bool -<span class="lineNum"> 384 </span><span class="lineCov"> 3939 : empty() const</span> -<span class="lineNum"> 385 </span><span class="lineCov"> 3939 : { return _M_t.empty(); }</span> -<span class="lineNum"> 386 </span> : -<span class="lineNum"> 387 </span> : /** Returns the size of the %map. */ -<span class="lineNum"> 388 </span> : size_type -<span class="lineNum"> 389 </span><span class="lineCov"> 20 : size() const</span> -<span class="lineNum"> 390 </span><span class="lineCov"> 20 : { return _M_t.size(); }</span> -<span class="lineNum"> 391 </span> : -<span class="lineNum"> 392 </span> : /** Returns the maximum size of the %map. */ -<span class="lineNum"> 393 </span> : size_type -<span class="lineNum"> 394 </span> : max_size() const -<span class="lineNum"> 395 </span> : { return _M_t.max_size(); } -<span class="lineNum"> 396 </span> : -<span class="lineNum"> 397 </span> : // [23.3.1.2] element access -<span class="lineNum"> 398 </span> : /** -<span class="lineNum"> 399 </span> : * @brief Subscript ( @c [] ) access to %map data. -<span class="lineNum"> 400 </span> : * @param k The key for which data should be retrieved. -<span class="lineNum"> 401 </span> : * @return A reference to the data of the (key,data) %pair. -<span class="lineNum"> 402 </span> : * -<span class="lineNum"> 403 </span> : * Allows for easy lookup with the subscript ( @c [] ) -<span class="lineNum"> 404 </span> : * operator. Returns data associated with the key specified in -<span class="lineNum"> 405 </span> : * subscript. If the key does not exist, a pair with that key -<span class="lineNum"> 406 </span> : * is created using default values, which is then returned. -<span class="lineNum"> 407 </span> : * -<span class="lineNum"> 408 </span> : * Lookup requires logarithmic time. -<span class="lineNum"> 409 </span> : */ -<span class="lineNum"> 410 </span> : mapped_type& -<span class="lineNum"> 411 </span><span class="lineCov"> 6297 : operator[](const key_type& __k)</span> -<span class="lineNum"> 412 </span> : { -<span class="lineNum"> 413 </span> : // concept requirements -<span class="lineNum"> 414 </span> : __glibcxx_function_requires(_DefaultConstructibleConcept<mapped_type>) -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span><span class="lineCov"> 6297 : iterator __i = lower_bound(__k);</span> -<span class="lineNum"> 417 </span> : // __i->first is greater than or equivalent to __k. -<span class="lineNum"> 418 </span><span class="lineCov"> 6297 : if (__i == end() || key_comp()(__k, (*__i).first))</span> -<span class="lineNum"> 419 </span><span class="lineCov"> 4149 : __i = insert(__i, value_type(__k, mapped_type()));</span> -<span class="lineNum"> 420 </span><span class="lineCov"> 6297 : return (*__i).second;</span> -<span class="lineNum"> 421 </span> : } -<span class="lineNum"> 422 </span> : -<span class="lineNum"> 423 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 424 </span> : // DR 464. Suggestion for new member functions in standard containers. -<span class="lineNum"> 425 </span> : /** -<span class="lineNum"> 426 </span> : * @brief Access to %map data. -<span class="lineNum"> 427 </span> : * @param k The key for which data should be retrieved. -<span class="lineNum"> 428 </span> : * @return A reference to the data whose key is equivalent to @a k, if -<span class="lineNum"> 429 </span> : * such a data is present in the %map. -<span class="lineNum"> 430 </span> : * @throw std::out_of_range If no such data is present. -<span class="lineNum"> 431 </span> : */ -<span class="lineNum"> 432 </span> : mapped_type& -<span class="lineNum"> 433 </span> : at(const key_type& __k) -<span class="lineNum"> 434 </span> : { -<span class="lineNum"> 435 </span> : iterator __i = lower_bound(__k); -<span class="lineNum"> 436 </span> : if (__i == end() || key_comp()(__k, (*__i).first)) -<span class="lineNum"> 437 </span> : __throw_out_of_range(__N("map::at")); -<span class="lineNum"> 438 </span> : return (*__i).second; -<span class="lineNum"> 439 </span> : } -<span class="lineNum"> 440 </span> : -<span class="lineNum"> 441 </span> : const mapped_type& -<span class="lineNum"> 442 </span> : at(const key_type& __k) const -<span class="lineNum"> 443 </span> : { -<span class="lineNum"> 444 </span> : const_iterator __i = lower_bound(__k); -<span class="lineNum"> 445 </span> : if (__i == end() || key_comp()(__k, (*__i).first)) -<span class="lineNum"> 446 </span> : __throw_out_of_range(__N("map::at")); -<span class="lineNum"> 447 </span> : return (*__i).second; -<span class="lineNum"> 448 </span> : } -<span class="lineNum"> 449 </span> : -<span class="lineNum"> 450 </span> : // modifiers -<span class="lineNum"> 451 </span> : /** -<span class="lineNum"> 452 </span> : * @brief Attempts to insert a std::pair into the %map. -<span class="lineNum"> 453 </span> : -<span class="lineNum"> 454 </span> : * @param x Pair to be inserted (see std::make_pair for easy creation -<span class="lineNum"> 455 </span> : * of pairs). -<span class="lineNum"> 456 </span> : -<span class="lineNum"> 457 </span> : * @return A pair, of which the first element is an iterator that -<span class="lineNum"> 458 </span> : * points to the possibly inserted pair, and the second is -<span class="lineNum"> 459 </span> : * a bool that is true if the pair was actually inserted. -<span class="lineNum"> 460 </span> : * -<span class="lineNum"> 461 </span> : * This function attempts to insert a (key, value) %pair into the %map. -<span class="lineNum"> 462 </span> : * A %map relies on unique keys and thus a %pair is only inserted if its -<span class="lineNum"> 463 </span> : * first element (the key) is not already present in the %map. -<span class="lineNum"> 464 </span> : * -<span class="lineNum"> 465 </span> : * Insertion requires logarithmic time. -<span class="lineNum"> 466 </span> : */ -<span class="lineNum"> 467 </span> : std::pair<iterator, bool> -<span class="lineNum"> 468 </span><span class="lineCov"> 101375 : insert(const value_type& __x)</span> -<span class="lineNum"> 469 </span><span class="lineCov"> 101375 : { return _M_t._M_insert_unique(__x); }</span> -<span class="lineNum"> 470 </span> : -<span class="lineNum"> 471 </span> : /** -<span class="lineNum"> 472 </span> : * @brief Attempts to insert a std::pair into the %map. -<span class="lineNum"> 473 </span> : * @param position An iterator that serves as a hint as to where the -<span class="lineNum"> 474 </span> : * pair should be inserted. -<span class="lineNum"> 475 </span> : * @param x Pair to be inserted (see std::make_pair for easy creation -<span class="lineNum"> 476 </span> : * of pairs). -<span class="lineNum"> 477 </span> : * @return An iterator that points to the element with key of @a x (may -<span class="lineNum"> 478 </span> : * or may not be the %pair passed in). -<span class="lineNum"> 479 </span> : * -<span class="lineNum"> 480 </span> : -<span class="lineNum"> 481 </span> : * This function is not concerned about whether the insertion -<span class="lineNum"> 482 </span> : * took place, and thus does not return a boolean like the -<span class="lineNum"> 483 </span> : * single-argument insert() does. Note that the first -<span class="lineNum"> 484 </span> : * parameter is only a hint and can potentially improve the -<span class="lineNum"> 485 </span> : * performance of the insertion process. A bad hint would -<span class="lineNum"> 486 </span> : * cause no gains in efficiency. -<span class="lineNum"> 487 </span> : * -<span class="lineNum"> 488 </span> : * See -<span class="lineNum"> 489 </span> : * http://gcc.gnu.org/onlinedocs/libstdc++/23_containers/howto.html#4 -<span class="lineNum"> 490 </span> : * for more on "hinting". -<span class="lineNum"> 491 </span> : * -<span class="lineNum"> 492 </span> : * Insertion requires logarithmic time (if the hint is not taken). -<span class="lineNum"> 493 </span> : */ -<span class="lineNum"> 494 </span> : iterator -<span class="lineNum"> 495 </span><span class="lineCov"> 4149 : insert(iterator __position, const value_type& __x)</span> -<span class="lineNum"> 496 </span><span class="lineCov"> 4149 : { return _M_t._M_insert_unique_(__position, __x); }</span> -<span class="lineNum"> 497 </span> : -<span class="lineNum"> 498 </span> : /** -<span class="lineNum"> 499 </span> : * @brief Template function that attempts to insert a range of elements. -<span class="lineNum"> 500 </span> : * @param first Iterator pointing to the start of the range to be -<span class="lineNum"> 501 </span> : * inserted. -<span class="lineNum"> 502 </span> : * @param last Iterator pointing to the end of the range. -<span class="lineNum"> 503 </span> : * -<span class="lineNum"> 504 </span> : * Complexity similar to that of the range constructor. -<span class="lineNum"> 505 </span> : */ -<span class="lineNum"> 506 </span> : template<typename _InputIterator> -<span class="lineNum"> 507 </span> : void -<span class="lineNum"> 508 </span> : insert(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 509 </span> : { _M_t._M_insert_unique(__first, __last); } -<span class="lineNum"> 510 </span> : -<span class="lineNum"> 511 </span> : /** -<span class="lineNum"> 512 </span> : * @brief Erases an element from a %map. -<span class="lineNum"> 513 </span> : * @param position An iterator pointing to the element to be erased. -<span class="lineNum"> 514 </span> : * -<span class="lineNum"> 515 </span> : * This function erases an element, pointed to by the given -<span class="lineNum"> 516 </span> : * iterator, from a %map. Note that this function only erases -<span class="lineNum"> 517 </span> : * the element, and that if the element is itself a pointer, -<span class="lineNum"> 518 </span> : * the pointed-to memory is not touched in any way. Managing -<span class="lineNum"> 519 </span> : * the pointer is the user's responsibility. -<span class="lineNum"> 520 </span> : */ -<span class="lineNum"> 521 </span> : void -<span class="lineNum"> 522 </span> : erase(iterator __position) -<span class="lineNum"> 523 </span> : { _M_t.erase(__position); } -<span class="lineNum"> 524 </span> : -<span class="lineNum"> 525 </span> : /** -<span class="lineNum"> 526 </span> : * @brief Erases elements according to the provided key. -<span class="lineNum"> 527 </span> : * @param x Key of element to be erased. -<span class="lineNum"> 528 </span> : * @return The number of elements erased. -<span class="lineNum"> 529 </span> : * -<span class="lineNum"> 530 </span> : * This function erases all the elements located by the given key from -<span class="lineNum"> 531 </span> : * a %map. -<span class="lineNum"> 532 </span> : * Note that this function only erases the element, and that if -<span class="lineNum"> 533 </span> : * the element is itself a pointer, the pointed-to memory is not touched -<span class="lineNum"> 534 </span> : * in any way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 535 </span> : */ -<span class="lineNum"> 536 </span> : size_type -<span class="lineNum"> 537 </span> : erase(const key_type& __x) -<span class="lineNum"> 538 </span> : { return _M_t.erase(__x); } -<span class="lineNum"> 539 </span> : -<span class="lineNum"> 540 </span> : /** -<span class="lineNum"> 541 </span> : * @brief Erases a [first,last) range of elements from a %map. -<span class="lineNum"> 542 </span> : * @param first Iterator pointing to the start of the range to be -<span class="lineNum"> 543 </span> : * erased. -<span class="lineNum"> 544 </span> : * @param last Iterator pointing to the end of the range to be erased. -<span class="lineNum"> 545 </span> : * -<span class="lineNum"> 546 </span> : * This function erases a sequence of elements from a %map. -<span class="lineNum"> 547 </span> : * Note that this function only erases the element, and that if -<span class="lineNum"> 548 </span> : * the element is itself a pointer, the pointed-to memory is not touched -<span class="lineNum"> 549 </span> : * in any way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 550 </span> : */ -<span class="lineNum"> 551 </span> : void -<span class="lineNum"> 552 </span> : erase(iterator __first, iterator __last) -<span class="lineNum"> 553 </span> : { _M_t.erase(__first, __last); } -<span class="lineNum"> 554 </span> : -<span class="lineNum"> 555 </span> : /** -<span class="lineNum"> 556 </span> : * @brief Swaps data with another %map. -<span class="lineNum"> 557 </span> : * @param x A %map of the same element and allocator types. -<span class="lineNum"> 558 </span> : * -<span class="lineNum"> 559 </span> : * This exchanges the elements between two maps in constant -<span class="lineNum"> 560 </span> : * time. (It is only swapping a pointer, an integer, and an -<span class="lineNum"> 561 </span> : * instance of the @c Compare type (which itself is often -<span class="lineNum"> 562 </span> : * stateless and empty), so it should be quite fast.) Note -<span class="lineNum"> 563 </span> : * that the global std::swap() function is specialized such -<span class="lineNum"> 564 </span> : * that std::swap(m1,m2) will feed to this function. -<span class="lineNum"> 565 </span> : */ -<span class="lineNum"> 566 </span> : void -<span class="lineNum"> 567 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 568 </span> : swap(map&& __x) -<span class="lineNum"> 569 </span> : #else -<span class="lineNum"> 570 </span> : swap(map& __x) -<span class="lineNum"> 571 </span> : #endif -<span class="lineNum"> 572 </span> : { _M_t.swap(__x._M_t); } -<span class="lineNum"> 573 </span> : -<span class="lineNum"> 574 </span> : /** -<span class="lineNum"> 575 </span> : * Erases all elements in a %map. Note that this function only -<span class="lineNum"> 576 </span> : * erases the elements, and that if the elements themselves are -<span class="lineNum"> 577 </span> : * pointers, the pointed-to memory is not touched in any way. -<span class="lineNum"> 578 </span> : * Managing the pointer is the user's responsibility. -<span class="lineNum"> 579 </span> : */ -<span class="lineNum"> 580 </span> : void -<span class="lineNum"> 581 </span><span class="lineCov"> 3288 : clear()</span> -<span class="lineNum"> 582 </span><span class="lineCov"> 3288 : { _M_t.clear(); }</span> -<span class="lineNum"> 583 </span> : -<span class="lineNum"> 584 </span> : // observers -<span class="lineNum"> 585 </span> : /** -<span class="lineNum"> 586 </span> : * Returns the key comparison object out of which the %map was -<span class="lineNum"> 587 </span> : * constructed. -<span class="lineNum"> 588 </span> : */ -<span class="lineNum"> 589 </span> : key_compare -<span class="lineNum"> 590 </span><span class="lineCov"> 3296 : key_comp() const</span> -<span class="lineNum"> 591 </span><span class="lineCov"> 3296 : { return _M_t.key_comp(); }</span> -<span class="lineNum"> 592 </span> : -<span class="lineNum"> 593 </span> : /** -<span class="lineNum"> 594 </span> : * Returns a value comparison object, built from the key comparison -<span class="lineNum"> 595 </span> : * object out of which the %map was constructed. -<span class="lineNum"> 596 </span> : */ -<span class="lineNum"> 597 </span> : value_compare -<span class="lineNum"> 598 </span> : value_comp() const -<span class="lineNum"> 599 </span> : { return value_compare(_M_t.key_comp()); } -<span class="lineNum"> 600 </span> : -<span class="lineNum"> 601 </span> : // [23.3.1.3] map operations -<span class="lineNum"> 602 </span> : /** -<span class="lineNum"> 603 </span> : * @brief Tries to locate an element in a %map. -<span class="lineNum"> 604 </span> : * @param x Key of (key, value) %pair to be located. -<span class="lineNum"> 605 </span> : * @return Iterator pointing to sought-after element, or end() if not -<span class="lineNum"> 606 </span> : * found. -<span class="lineNum"> 607 </span> : * -<span class="lineNum"> 608 </span> : * This function takes a key and tries to locate the element with which -<span class="lineNum"> 609 </span> : * the key matches. If successful the function returns an iterator -<span class="lineNum"> 610 </span> : * pointing to the sought after %pair. If unsuccessful it returns the -<span class="lineNum"> 611 </span> : * past-the-end ( @c end() ) iterator. -<span class="lineNum"> 612 </span> : */ -<span class="lineNum"> 613 </span> : iterator -<span class="lineNum"> 614 </span><span class="lineCov"> 50117 : find(const key_type& __x)</span> -<span class="lineNum"> 615 </span><span class="lineCov"> 50117 : { return _M_t.find(__x); }</span> -<span class="lineNum"> 616 </span> : -<span class="lineNum"> 617 </span> : /** -<span class="lineNum"> 618 </span> : * @brief Tries to locate an element in a %map. -<span class="lineNum"> 619 </span> : * @param x Key of (key, value) %pair to be located. -<span class="lineNum"> 620 </span> : * @return Read-only (constant) iterator pointing to sought-after -<span class="lineNum"> 621 </span> : * element, or end() if not found. -<span class="lineNum"> 622 </span> : * -<span class="lineNum"> 623 </span> : * This function takes a key and tries to locate the element with which -<span class="lineNum"> 624 </span> : * the key matches. If successful the function returns a constant -<span class="lineNum"> 625 </span> : * iterator pointing to the sought after %pair. If unsuccessful it -<span class="lineNum"> 626 </span> : * returns the past-the-end ( @c end() ) iterator. -<span class="lineNum"> 627 </span> : */ -<span class="lineNum"> 628 </span> : const_iterator -<span class="lineNum"> 629 </span><span class="lineCov"> 3916 : find(const key_type& __x) const</span> -<span class="lineNum"> 630 </span><span class="lineCov"> 3916 : { return _M_t.find(__x); }</span> -<span class="lineNum"> 631 </span> : -<span class="lineNum"> 632 </span> : /** -<span class="lineNum"> 633 </span> : * @brief Finds the number of elements with given key. -<span class="lineNum"> 634 </span> : * @param x Key of (key, value) pairs to be located. -<span class="lineNum"> 635 </span> : * @return Number of elements with specified key. -<span class="lineNum"> 636 </span> : * -<span class="lineNum"> 637 </span> : * This function only makes sense for multimaps; for map the result will -<span class="lineNum"> 638 </span> : * either be 0 (not present) or 1 (present). -<span class="lineNum"> 639 </span> : */ -<span class="lineNum"> 640 </span> : size_type -<span class="lineNum"> 641 </span> : count(const key_type& __x) const -<span class="lineNum"> 642 </span> : { return _M_t.find(__x) == _M_t.end() ? 0 : 1; } -<span class="lineNum"> 643 </span> : -<span class="lineNum"> 644 </span> : /** -<span class="lineNum"> 645 </span> : * @brief Finds the beginning of a subsequence matching given key. -<span class="lineNum"> 646 </span> : * @param x Key of (key, value) pair to be located. -<span class="lineNum"> 647 </span> : * @return Iterator pointing to first element equal to or greater -<span class="lineNum"> 648 </span> : * than key, or end(). -<span class="lineNum"> 649 </span> : * -<span class="lineNum"> 650 </span> : * This function returns the first element of a subsequence of elements -<span class="lineNum"> 651 </span> : * that matches the given key. If unsuccessful it returns an iterator -<span class="lineNum"> 652 </span> : * pointing to the first element that has a greater value than given key -<span class="lineNum"> 653 </span> : * or end() if no such element exists. -<span class="lineNum"> 654 </span> : */ -<span class="lineNum"> 655 </span> : iterator -<span class="lineNum"> 656 </span><span class="lineCov"> 6297 : lower_bound(const key_type& __x)</span> -<span class="lineNum"> 657 </span><span class="lineCov"> 6297 : { return _M_t.lower_bound(__x); }</span> -<span class="lineNum"> 658 </span> : -<span class="lineNum"> 659 </span> : /** -<span class="lineNum"> 660 </span> : * @brief Finds the beginning of a subsequence matching given key. -<span class="lineNum"> 661 </span> : * @param x Key of (key, value) pair to be located. -<span class="lineNum"> 662 </span> : * @return Read-only (constant) iterator pointing to first element -<span class="lineNum"> 663 </span> : * equal to or greater than key, or end(). -<span class="lineNum"> 664 </span> : * -<span class="lineNum"> 665 </span> : * This function returns the first element of a subsequence of elements -<span class="lineNum"> 666 </span> : * that matches the given key. If unsuccessful it returns an iterator -<span class="lineNum"> 667 </span> : * pointing to the first element that has a greater value than given key -<span class="lineNum"> 668 </span> : * or end() if no such element exists. -<span class="lineNum"> 669 </span> : */ -<span class="lineNum"> 670 </span> : const_iterator -<span class="lineNum"> 671 </span> : lower_bound(const key_type& __x) const -<span class="lineNum"> 672 </span> : { return _M_t.lower_bound(__x); } -<span class="lineNum"> 673 </span> : -<span class="lineNum"> 674 </span> : /** -<span class="lineNum"> 675 </span> : * @brief Finds the end of a subsequence matching given key. -<span class="lineNum"> 676 </span> : * @param x Key of (key, value) pair to be located. -<span class="lineNum"> 677 </span> : * @return Iterator pointing to the first element -<span class="lineNum"> 678 </span> : * greater than key, or end(). -<span class="lineNum"> 679 </span> : */ -<span class="lineNum"> 680 </span> : iterator -<span class="lineNum"> 681 </span> : upper_bound(const key_type& __x) -<span class="lineNum"> 682 </span> : { return _M_t.upper_bound(__x); } -<span class="lineNum"> 683 </span> : -<span class="lineNum"> 684 </span> : /** -<span class="lineNum"> 685 </span> : * @brief Finds the end of a subsequence matching given key. -<span class="lineNum"> 686 </span> : * @param x Key of (key, value) pair to be located. -<span class="lineNum"> 687 </span> : * @return Read-only (constant) iterator pointing to first iterator -<span class="lineNum"> 688 </span> : * greater than key, or end(). -<span class="lineNum"> 689 </span> : */ -<span class="lineNum"> 690 </span> : const_iterator -<span class="lineNum"> 691 </span> : upper_bound(const key_type& __x) const -<span class="lineNum"> 692 </span> : { return _M_t.upper_bound(__x); } -<span class="lineNum"> 693 </span> : -<span class="lineNum"> 694 </span> : /** -<span class="lineNum"> 695 </span> : * @brief Finds a subsequence matching given key. -<span class="lineNum"> 696 </span> : * @param x Key of (key, value) pairs to be located. -<span class="lineNum"> 697 </span> : * @return Pair of iterators that possibly points to the subsequence -<span class="lineNum"> 698 </span> : * matching given key. -<span class="lineNum"> 699 </span> : * -<span class="lineNum"> 700 </span> : * This function is equivalent to -<span class="lineNum"> 701 </span> : * @code -<span class="lineNum"> 702 </span> : * std::make_pair(c.lower_bound(val), -<span class="lineNum"> 703 </span> : * c.upper_bound(val)) -<span class="lineNum"> 704 </span> : * @endcode -<span class="lineNum"> 705 </span> : * (but is faster than making the calls separately). -<span class="lineNum"> 706 </span> : * -<span class="lineNum"> 707 </span> : * This function probably only makes sense for multimaps. -<span class="lineNum"> 708 </span> : */ -<span class="lineNum"> 709 </span> : std::pair<iterator, iterator> -<span class="lineNum"> 710 </span> : equal_range(const key_type& __x) -<span class="lineNum"> 711 </span> : { return _M_t.equal_range(__x); } -<span class="lineNum"> 712 </span> : -<span class="lineNum"> 713 </span> : /** -<span class="lineNum"> 714 </span> : * @brief Finds a subsequence matching given key. -<span class="lineNum"> 715 </span> : * @param x Key of (key, value) pairs to be located. -<span class="lineNum"> 716 </span> : * @return Pair of read-only (constant) iterators that possibly points -<span class="lineNum"> 717 </span> : * to the subsequence matching given key. -<span class="lineNum"> 718 </span> : * -<span class="lineNum"> 719 </span> : * This function is equivalent to -<span class="lineNum"> 720 </span> : * @code -<span class="lineNum"> 721 </span> : * std::make_pair(c.lower_bound(val), -<span class="lineNum"> 722 </span> : * c.upper_bound(val)) -<span class="lineNum"> 723 </span> : * @endcode -<span class="lineNum"> 724 </span> : * (but is faster than making the calls separately). -<span class="lineNum"> 725 </span> : * -<span class="lineNum"> 726 </span> : * This function probably only makes sense for multimaps. -<span class="lineNum"> 727 </span> : */ -<span class="lineNum"> 728 </span> : std::pair<const_iterator, const_iterator> -<span class="lineNum"> 729 </span> : equal_range(const key_type& __x) const -<span class="lineNum"> 730 </span> : { return _M_t.equal_range(__x); } -<span class="lineNum"> 731 </span> : -<span class="lineNum"> 732 </span> : template<typename _K1, typename _T1, typename _C1, typename _A1> -<span class="lineNum"> 733 </span> : friend bool -<span class="lineNum"> 734 </span> : operator==(const map<_K1, _T1, _C1, _A1>&, -<span class="lineNum"> 735 </span> : const map<_K1, _T1, _C1, _A1>&); -<span class="lineNum"> 736 </span> : -<span class="lineNum"> 737 </span> : template<typename _K1, typename _T1, typename _C1, typename _A1> -<span class="lineNum"> 738 </span> : friend bool -<span class="lineNum"> 739 </span> : operator<(const map<_K1, _T1, _C1, _A1>&, -<span class="lineNum"> 740 </span> : const map<_K1, _T1, _C1, _A1>&); -<span class="lineNum"> 741 </span> : }; -<span class="lineNum"> 742 </span> : -<span class="lineNum"> 743 </span> : /** -<span class="lineNum"> 744 </span> : * @brief Map equality comparison. -<span class="lineNum"> 745 </span> : * @param x A %map. -<span class="lineNum"> 746 </span> : * @param y A %map of the same type as @a x. -<span class="lineNum"> 747 </span> : * @return True iff the size and elements of the maps are equal. -<span class="lineNum"> 748 </span> : * -<span class="lineNum"> 749 </span> : * This is an equivalence relation. It is linear in the size of the -<span class="lineNum"> 750 </span> : * maps. Maps are considered equivalent if their sizes are equal, -<span class="lineNum"> 751 </span> : * and if corresponding elements compare equal. -<span class="lineNum"> 752 </span> : */ -<span class="lineNum"> 753 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 754 </span> : inline bool -<span class="lineNum"> 755 </span> : operator==(const map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 756 </span> : const map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 757 </span> : { return __x._M_t == __y._M_t; } -<span class="lineNum"> 758 </span> : -<span class="lineNum"> 759 </span> : /** -<span class="lineNum"> 760 </span> : * @brief Map ordering relation. -<span class="lineNum"> 761 </span> : * @param x A %map. -<span class="lineNum"> 762 </span> : * @param y A %map of the same type as @a x. -<span class="lineNum"> 763 </span> : * @return True iff @a x is lexicographically less than @a y. -<span class="lineNum"> 764 </span> : * -<span class="lineNum"> 765 </span> : * This is a total ordering relation. It is linear in the size of the -<span class="lineNum"> 766 </span> : * maps. The elements must be comparable with @c <. -<span class="lineNum"> 767 </span> : * -<span class="lineNum"> 768 </span> : * See std::lexicographical_compare() for how the determination is made. -<span class="lineNum"> 769 </span> : */ -<span class="lineNum"> 770 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 771 </span> : inline bool -<span class="lineNum"> 772 </span> : operator<(const map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 773 </span> : const map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 774 </span> : { return __x._M_t < __y._M_t; } -<span class="lineNum"> 775 </span> : -<span class="lineNum"> 776 </span> : /// Based on operator== -<span class="lineNum"> 777 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 778 </span> : inline bool -<span class="lineNum"> 779 </span> : operator!=(const map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 780 </span> : const map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 781 </span> : { return !(__x == __y); } -<span class="lineNum"> 782 </span> : -<span class="lineNum"> 783 </span> : /// Based on operator< -<span class="lineNum"> 784 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 785 </span> : inline bool -<span class="lineNum"> 786 </span> : operator>(const map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 787 </span> : const map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 788 </span> : { return __y < __x; } -<span class="lineNum"> 789 </span> : -<span class="lineNum"> 790 </span> : /// Based on operator< -<span class="lineNum"> 791 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 792 </span> : inline bool -<span class="lineNum"> 793 </span> : operator<=(const map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 794 </span> : const map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 795 </span> : { return !(__y < __x); } -<span class="lineNum"> 796 </span> : -<span class="lineNum"> 797 </span> : /// Based on operator< -<span class="lineNum"> 798 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 799 </span> : inline bool -<span class="lineNum"> 800 </span> : operator>=(const map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 801 </span> : const map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 802 </span> : { return !(__x < __y); } -<span class="lineNum"> 803 </span> : -<span class="lineNum"> 804 </span> : /// See std::map::swap(). -<span class="lineNum"> 805 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 806 </span> : inline void -<span class="lineNum"> 807 </span> : swap(map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 808 </span> : map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 809 </span> : { __x.swap(__y); } -<span class="lineNum"> 810 </span> : -<span class="lineNum"> 811 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 812 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 813 </span> : inline void -<span class="lineNum"> 814 </span> : swap(map<_Key, _Tp, _Compare, _Alloc>&& __x, -<span class="lineNum"> 815 </span> : map<_Key, _Tp, _Compare, _Alloc>& __y) -<span class="lineNum"> 816 </span> : { __x.swap(__y); } -<span class="lineNum"> 817 </span> : -<span class="lineNum"> 818 </span> : template<typename _Key, typename _Tp, typename _Compare, typename _Alloc> -<span class="lineNum"> 819 </span> : inline void -<span class="lineNum"> 820 </span> : swap(map<_Key, _Tp, _Compare, _Alloc>& __x, -<span class="lineNum"> 821 </span> : map<_Key, _Tp, _Compare, _Alloc>&& __y) -<span class="lineNum"> 822 </span> : { __x.swap(__y); } -<span class="lineNum"> 823 </span> : #endif -<span class="lineNum"> 824 </span> : -<span class="lineNum"> 825 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 826 </span> : -<span class="lineNum"> 827 </span> : #endif /* _STL_MAP_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_move.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_move.h.gcov.html deleted file mode 100644 index 93e7633..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_move.h.gcov.html +++ /dev/null @@ -1,159 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_move.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_move.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">5</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">5</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Move, forward and identity for C++0x + swap -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2007 Free Software Foundation, Inc. -<span class="lineNum"> 4 </span> : // -<span class="lineNum"> 5 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 6 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 7 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 8 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 9 </span> : // any later version. -<span class="lineNum"> 10 </span> : -<span class="lineNum"> 11 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 12 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 13 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 14 </span> : // GNU General Public License for more details. -<span class="lineNum"> 15 </span> : -<span class="lineNum"> 16 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 17 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 18 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 19 </span> : // USA. -<span class="lineNum"> 20 </span> : -<span class="lineNum"> 21 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 22 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 23 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 24 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 25 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 26 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 27 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. -<span class="lineNum"> 29 </span> : -<span class="lineNum"> 30 </span> : /** @file stl_move.h -<span class="lineNum"> 31 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 32 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 33 </span> : */ -<span class="lineNum"> 34 </span> : -<span class="lineNum"> 35 </span> : #ifndef _STL_MOVE_H -<span class="lineNum"> 36 </span> : #define _STL_MOVE_H 1 -<span class="lineNum"> 37 </span> : -<span class="lineNum"> 38 </span> : #include <bits/c++config.h> -<span class="lineNum"> 39 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 40 </span> : -<span class="lineNum"> 41 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 42 </span> : #include <type_traits> -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 45 </span> : -<span class="lineNum"> 46 </span> : // 20.2.2, forward/move -<span class="lineNum"> 47 </span> : template<typename _Tp> -<span class="lineNum"> 48 </span> : struct identity -<span class="lineNum"> 49 </span> : { -<span class="lineNum"> 50 </span> : typedef _Tp type; -<span class="lineNum"> 51 </span> : }; -<span class="lineNum"> 52 </span> : -<span class="lineNum"> 53 </span> : template<typename _Tp> -<span class="lineNum"> 54 </span> : inline _Tp&& -<span class="lineNum"> 55 </span> : forward(typename std::identity<_Tp>::type&& __t) -<span class="lineNum"> 56 </span> : { return __t; } -<span class="lineNum"> 57 </span> : -<span class="lineNum"> 58 </span> : template<typename _Tp> -<span class="lineNum"> 59 </span> : inline typename std::remove_reference<_Tp>::type&& -<span class="lineNum"> 60 </span> : move(_Tp&& __t) -<span class="lineNum"> 61 </span> : { return __t; } -<span class="lineNum"> 62 </span> : -<span class="lineNum"> 63 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #define _GLIBCXX_MOVE(_Tp) std::move(_Tp) -<span class="lineNum"> 66 </span> : #else -<span class="lineNum"> 67 </span> : #define _GLIBCXX_MOVE(_Tp) (_Tp) -<span class="lineNum"> 68 </span> : #endif -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 71 </span> : -<span class="lineNum"> 72 </span> : /** -<span class="lineNum"> 73 </span> : * @brief Swaps two values. -<span class="lineNum"> 74 </span> : * @param a A thing of arbitrary type. -<span class="lineNum"> 75 </span> : * @param b Another thing of arbitrary type. -<span class="lineNum"> 76 </span> : * @return Nothing. -<span class="lineNum"> 77 </span> : */ -<span class="lineNum"> 78 </span> : template<typename _Tp> -<span class="lineNum"> 79 </span> : inline void -<span class="lineNum"> 80 </span><span class="lineCov"> 7080 : swap(_Tp& __a, _Tp& __b)</span> -<span class="lineNum"> 81 </span> : { -<span class="lineNum"> 82 </span> : // concept requirements -<span class="lineNum"> 83 </span> : __glibcxx_function_requires(_SGIAssignableConcept<_Tp>) -<span class="lineNum"> 84 </span> : -<span class="lineNum"> 85 </span><span class="lineCov"> 7080 : _Tp __tmp = _GLIBCXX_MOVE(__a);</span> -<span class="lineNum"> 86 </span><span class="lineCov"> 7080 : __a = _GLIBCXX_MOVE(__b);</span> -<span class="lineNum"> 87 </span><span class="lineCov"> 7080 : __b = _GLIBCXX_MOVE(__tmp);</span> -<span class="lineNum"> 88 </span><span class="lineCov"> 7080 : }</span> -<span class="lineNum"> 89 </span> : -<span class="lineNum"> 90 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 91 </span> : -<span class="lineNum"> 92 </span> : #endif /* _STL_MOVE_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_pair.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_pair.h.gcov.html deleted file mode 100644 index 455afe5..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_pair.h.gcov.html +++ /dev/null @@ -1,331 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_pair.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_pair.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">9</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">9</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Pair implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_pair.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_PAIR_H -<span class="lineNum"> 63 </span> : #define _STL_PAIR_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/stl_move.h> // for std::move / std::forward, std::decay, and -<span class="lineNum"> 66 </span> : // std::swap -<span class="lineNum"> 67 </span> : -<span class="lineNum"> 68 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : /// pair holds two objects of arbitrary type. -<span class="lineNum"> 71 </span> : template<class _T1, class _T2> -<span class="lineNum"> 72 </span> : struct pair -<span class="lineNum"> 73 </span><span class="lineCov"> 814163 : {</span> -<span class="lineNum"> 74 </span> : typedef _T1 first_type; ///< @c first_type is the first bound type -<span class="lineNum"> 75 </span> : typedef _T2 second_type; ///< @c second_type is the second bound type -<span class="lineNum"> 76 </span> : -<span class="lineNum"> 77 </span> : _T1 first; ///< @c first is a copy of the first object -<span class="lineNum"> 78 </span> : _T2 second; ///< @c second is a copy of the second object -<span class="lineNum"> 79 </span> : -<span class="lineNum"> 80 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 81 </span> : // 265. std::pair::pair() effects overly restrictive -<span class="lineNum"> 82 </span> : /** The default constructor creates @c first and @c second using their -<span class="lineNum"> 83 </span> : * respective default constructors. */ -<span class="lineNum"> 84 </span><span class="lineCov"> 19 : pair()</span> -<span class="lineNum"> 85 </span><span class="lineCov"> 19 : : first(), second() { }</span> -<span class="lineNum"> 86 </span> : -<span class="lineNum"> 87 </span> : /** Two objects may be passed to a @c pair constructor to be copied. */ -<span class="lineNum"> 88 </span><span class="lineCov"> 3562241 : pair(const _T1& __a, const _T2& __b)</span> -<span class="lineNum"> 89 </span><span class="lineCov"> 3562241 : : first(__a), second(__b) { }</span> -<span class="lineNum"> 90 </span> : -<span class="lineNum"> 91 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 92 </span> : template<class _U1, class _U2> -<span class="lineNum"> 93 </span> : pair(_U1&& __x, _U2&& __y) -<span class="lineNum"> 94 </span> : : first(std::forward<_U1>(__x)), -<span class="lineNum"> 95 </span> : second(std::forward<_U2>(__y)) { } -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : pair(pair&& __p) -<span class="lineNum"> 98 </span> : : first(std::move(__p.first)), -<span class="lineNum"> 99 </span> : second(std::move(__p.second)) { } -<span class="lineNum"> 100 </span> : #endif -<span class="lineNum"> 101 </span> : -<span class="lineNum"> 102 </span> : /** There is also a templated copy ctor for the @c pair class itself. */ -<span class="lineNum"> 103 </span> : template<class _U1, class _U2> -<span class="lineNum"> 104 </span><span class="lineCov"> 101375 : pair(const pair<_U1, _U2>& __p)</span> -<span class="lineNum"> 105 </span> : : first(__p.first), -<span class="lineNum"> 106 </span><span class="lineCov"> 101375 : second(__p.second) { }</span> -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 109 </span> : template<class _U1, class _U2> -<span class="lineNum"> 110 </span> : pair(pair<_U1, _U2>&& __p) -<span class="lineNum"> 111 </span> : : first(std::move(__p.first)), -<span class="lineNum"> 112 </span> : second(std::move(__p.second)) { } -<span class="lineNum"> 113 </span> : -<span class="lineNum"> 114 </span> : // http://gcc.gnu.org/ml/libstdc++/2007-08/msg00052.html -<span class="lineNum"> 115 </span> : template<class _U1, class _Arg0, class... _Args> -<span class="lineNum"> 116 </span> : pair(_U1&& __x, _Arg0&& __arg0, _Args&&... __args) -<span class="lineNum"> 117 </span> : : first(std::forward<_U1>(__x)), -<span class="lineNum"> 118 </span> : second(std::forward<_Arg0>(__arg0), -<span class="lineNum"> 119 </span> : std::forward<_Args>(__args)...) { } -<span class="lineNum"> 120 </span> : -<span class="lineNum"> 121 </span> : pair& -<span class="lineNum"> 122 </span> : operator=(pair&& __p) -<span class="lineNum"> 123 </span> : { -<span class="lineNum"> 124 </span> : first = std::move(__p.first); -<span class="lineNum"> 125 </span> : second = std::move(__p.second); -<span class="lineNum"> 126 </span> : return *this; -<span class="lineNum"> 127 </span> : } -<span class="lineNum"> 128 </span> : -<span class="lineNum"> 129 </span> : template<class _U1, class _U2> -<span class="lineNum"> 130 </span> : pair& -<span class="lineNum"> 131 </span> : operator=(pair<_U1, _U2>&& __p) -<span class="lineNum"> 132 </span> : { -<span class="lineNum"> 133 </span> : first = std::move(__p.first); -<span class="lineNum"> 134 </span> : second = std::move(__p.second); -<span class="lineNum"> 135 </span> : return *this; -<span class="lineNum"> 136 </span> : } -<span class="lineNum"> 137 </span> : -<span class="lineNum"> 138 </span> : void -<span class="lineNum"> 139 </span> : swap(pair&& __p) -<span class="lineNum"> 140 </span> : { -<span class="lineNum"> 141 </span> : using std::swap; -<span class="lineNum"> 142 </span> : swap(first, __p.first); -<span class="lineNum"> 143 </span> : swap(second, __p.second); -<span class="lineNum"> 144 </span> : } -<span class="lineNum"> 145 </span> : #endif -<span class="lineNum"> 146 </span> : }; -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : /// Two pairs of the same type are equal iff their members are equal. -<span class="lineNum"> 149 </span> : template<class _T1, class _T2> -<span class="lineNum"> 150 </span> : inline bool -<span class="lineNum"> 151 </span> : operator==(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) -<span class="lineNum"> 152 </span> : { return __x.first == __y.first && __x.second == __y.second; } -<span class="lineNum"> 153 </span> : -<span class="lineNum"> 154 </span> : /// <http://gcc.gnu.org/onlinedocs/libstdc++/20_util/howto.html#pairlt> -<span class="lineNum"> 155 </span> : template<class _T1, class _T2> -<span class="lineNum"> 156 </span> : inline bool -<span class="lineNum"> 157 </span> : operator<(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) -<span class="lineNum"> 158 </span> : { return __x.first < __y.first -<span class="lineNum"> 159 </span> : || (!(__y.first < __x.first) && __x.second < __y.second); } -<span class="lineNum"> 160 </span> : -<span class="lineNum"> 161 </span> : /// Uses @c operator== to find the result. -<span class="lineNum"> 162 </span> : template<class _T1, class _T2> -<span class="lineNum"> 163 </span> : inline bool -<span class="lineNum"> 164 </span> : operator!=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) -<span class="lineNum"> 165 </span> : { return !(__x == __y); } -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : /// Uses @c operator< to find the result. -<span class="lineNum"> 168 </span> : template<class _T1, class _T2> -<span class="lineNum"> 169 </span> : inline bool -<span class="lineNum"> 170 </span> : operator>(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) -<span class="lineNum"> 171 </span> : { return __y < __x; } -<span class="lineNum"> 172 </span> : -<span class="lineNum"> 173 </span> : /// Uses @c operator< to find the result. -<span class="lineNum"> 174 </span> : template<class _T1, class _T2> -<span class="lineNum"> 175 </span> : inline bool -<span class="lineNum"> 176 </span> : operator<=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) -<span class="lineNum"> 177 </span> : { return !(__y < __x); } -<span class="lineNum"> 178 </span> : -<span class="lineNum"> 179 </span> : /// Uses @c operator< to find the result. -<span class="lineNum"> 180 </span> : template<class _T1, class _T2> -<span class="lineNum"> 181 </span> : inline bool -<span class="lineNum"> 182 </span> : operator>=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) -<span class="lineNum"> 183 </span> : { return !(__x < __y); } -<span class="lineNum"> 184 </span> : -<span class="lineNum"> 185 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 186 </span> : /// See std::pair::swap(). -<span class="lineNum"> 187 </span> : template<class _T1, class _T2> -<span class="lineNum"> 188 </span> : inline void -<span class="lineNum"> 189 </span> : swap(pair<_T1, _T2>& __x, pair<_T1, _T2>& __y) -<span class="lineNum"> 190 </span> : { __x.swap(__y); } -<span class="lineNum"> 191 </span> : -<span class="lineNum"> 192 </span> : template<class _T1, class _T2> -<span class="lineNum"> 193 </span> : inline void -<span class="lineNum"> 194 </span> : swap(pair<_T1, _T2>&& __x, pair<_T1, _T2>& __y) -<span class="lineNum"> 195 </span> : { __x.swap(__y); } -<span class="lineNum"> 196 </span> : -<span class="lineNum"> 197 </span> : template<class _T1, class _T2> -<span class="lineNum"> 198 </span> : inline void -<span class="lineNum"> 199 </span> : swap(pair<_T1, _T2>& __x, pair<_T1, _T2>&& __y) -<span class="lineNum"> 200 </span> : { __x.swap(__y); } -<span class="lineNum"> 201 </span> : #endif -<span class="lineNum"> 202 </span> : -<span class="lineNum"> 203 </span> : /** -<span class="lineNum"> 204 </span> : * @brief A convenience wrapper for creating a pair from two objects. -<span class="lineNum"> 205 </span> : * @param x The first object. -<span class="lineNum"> 206 </span> : * @param y The second object. -<span class="lineNum"> 207 </span> : * @return A newly-constructed pair<> object of the appropriate type. -<span class="lineNum"> 208 </span> : * -<span class="lineNum"> 209 </span> : * The standard requires that the objects be passed by reference-to-const, -<span class="lineNum"> 210 </span> : * but LWG issue #181 says they should be passed by const value. We follow -<span class="lineNum"> 211 </span> : * the LWG by default. -<span class="lineNum"> 212 </span> : */ -<span class="lineNum"> 213 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 214 </span> : // 181. make_pair() unintended behavior -<span class="lineNum"> 215 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 216 </span> : template<class _T1, class _T2> -<span class="lineNum"> 217 </span> : inline pair<_T1, _T2> -<span class="lineNum"> 218 </span><span class="lineCov"> 474889 : make_pair(_T1 __x, _T2 __y)</span> -<span class="lineNum"> 219 </span><span class="lineCov"> 474889 : { return pair<_T1, _T2>(__x, __y); }</span> -<span class="lineNum"> 220 </span> : #else -<span class="lineNum"> 221 </span> : template<typename _Tp> -<span class="lineNum"> 222 </span> : class reference_wrapper; -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : // Helper which adds a reference to a type when given a reference_wrapper -<span class="lineNum"> 225 </span> : template<typename _Tp> -<span class="lineNum"> 226 </span> : struct __strip_reference_wrapper -<span class="lineNum"> 227 </span> : { -<span class="lineNum"> 228 </span> : typedef _Tp __type; -<span class="lineNum"> 229 </span> : }; -<span class="lineNum"> 230 </span> : -<span class="lineNum"> 231 </span> : template<typename _Tp> -<span class="lineNum"> 232 </span> : struct __strip_reference_wrapper<reference_wrapper<_Tp> > -<span class="lineNum"> 233 </span> : { -<span class="lineNum"> 234 </span> : typedef _Tp& __type; -<span class="lineNum"> 235 </span> : }; -<span class="lineNum"> 236 </span> : -<span class="lineNum"> 237 </span> : template<typename _Tp> -<span class="lineNum"> 238 </span> : struct __strip_reference_wrapper<const reference_wrapper<_Tp> > -<span class="lineNum"> 239 </span> : { -<span class="lineNum"> 240 </span> : typedef _Tp& __type; -<span class="lineNum"> 241 </span> : }; -<span class="lineNum"> 242 </span> : -<span class="lineNum"> 243 </span> : template<typename _Tp> -<span class="lineNum"> 244 </span> : struct __decay_and_strip -<span class="lineNum"> 245 </span> : { -<span class="lineNum"> 246 </span> : typedef typename __strip_reference_wrapper< -<span class="lineNum"> 247 </span> : typename decay<_Tp>::type>::__type __type; -<span class="lineNum"> 248 </span> : }; -<span class="lineNum"> 249 </span> : -<span class="lineNum"> 250 </span> : // NB: DR 706. -<span class="lineNum"> 251 </span> : template<class _T1, class _T2> -<span class="lineNum"> 252 </span> : inline pair<typename __decay_and_strip<_T1>::__type, -<span class="lineNum"> 253 </span> : typename __decay_and_strip<_T2>::__type> -<span class="lineNum"> 254 </span> : make_pair(_T1&& __x, _T2&& __y) -<span class="lineNum"> 255 </span> : { -<span class="lineNum"> 256 </span> : return pair<typename __decay_and_strip<_T1>::__type, -<span class="lineNum"> 257 </span> : typename __decay_and_strip<_T2>::__type> -<span class="lineNum"> 258 </span> : (std::forward<_T1>(__x), std::forward<_T2>(__y)); -<span class="lineNum"> 259 </span> : } -<span class="lineNum"> 260 </span> : #endif -<span class="lineNum"> 261 </span> : -<span class="lineNum"> 262 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 263 </span> : -<span class="lineNum"> 264 </span> : #endif /* _STL_PAIR_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_set.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_set.h.gcov.html deleted file mode 100644 index 3398416..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_set.h.gcov.html +++ /dev/null @@ -1,731 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_set.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_set.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">33</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">33</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Set implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_set.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_SET_H -<span class="lineNum"> 63 </span> : #define _STL_SET_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : /** -<span class="lineNum"> 70 </span> : * @brief A standard container made up of unique keys, which can be -<span class="lineNum"> 71 </span> : * retrieved in logarithmic time. -<span class="lineNum"> 72 </span> : * -<span class="lineNum"> 73 </span> : * @ingroup Containers -<span class="lineNum"> 74 </span> : * @ingroup Assoc_containers -<span class="lineNum"> 75 </span> : * -<span class="lineNum"> 76 </span> : * Meets the requirements of a <a href="tables.html#65">container</a>, a -<span class="lineNum"> 77 </span> : * <a href="tables.html#66">reversible container</a>, and an -<span class="lineNum"> 78 </span> : * <a href="tables.html#69">associative container</a> (using unique keys). -<span class="lineNum"> 79 </span> : * -<span class="lineNum"> 80 </span> : * Sets support bidirectional iterators. -<span class="lineNum"> 81 </span> : * -<span class="lineNum"> 82 </span> : * @param Key Type of key objects. -<span class="lineNum"> 83 </span> : * @param Compare Comparison function object type, defaults to less<Key>. -<span class="lineNum"> 84 </span> : * @param Alloc Allocator type, defaults to allocator<Key>. -<span class="lineNum"> 85 </span> : * -<span class="lineNum"> 86 </span> : * The private tree data is declared exactly the same way for set and -<span class="lineNum"> 87 </span> : * multiset; the distinction is made entirely in how the tree functions are -<span class="lineNum"> 88 </span> : * called (*_unique versus *_equal, same as the standard). -<span class="lineNum"> 89 </span> : */ -<span class="lineNum"> 90 </span> : template<typename _Key, typename _Compare = std::less<_Key>, -<span class="lineNum"> 91 </span> : typename _Alloc = std::allocator<_Key> > -<span class="lineNum"> 92 </span> : class set -<span class="lineNum"> 93 </span><span class="lineCov"> 1308625 : {</span> -<span class="lineNum"> 94 </span> : // concept requirements -<span class="lineNum"> 95 </span> : typedef typename _Alloc::value_type _Alloc_value_type; -<span class="lineNum"> 96 </span> : __glibcxx_class_requires(_Key, _SGIAssignableConcept) -<span class="lineNum"> 97 </span> : __glibcxx_class_requires4(_Compare, bool, _Key, _Key, -<span class="lineNum"> 98 </span> : _BinaryFunctionConcept) -<span class="lineNum"> 99 </span> : __glibcxx_class_requires2(_Key, _Alloc_value_type, _SameTypeConcept) -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : public: -<span class="lineNum"> 102 </span> : // typedefs: -<span class="lineNum"> 103 </span> : //@{ -<span class="lineNum"> 104 </span> : /// Public typedefs. -<span class="lineNum"> 105 </span> : typedef _Key key_type; -<span class="lineNum"> 106 </span> : typedef _Key value_type; -<span class="lineNum"> 107 </span> : typedef _Compare key_compare; -<span class="lineNum"> 108 </span> : typedef _Compare value_compare; -<span class="lineNum"> 109 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 110 </span> : //@} -<span class="lineNum"> 111 </span> : -<span class="lineNum"> 112 </span> : private: -<span class="lineNum"> 113 </span> : typedef typename _Alloc::template rebind<_Key>::other _Key_alloc_type; -<span class="lineNum"> 114 </span> : -<span class="lineNum"> 115 </span> : typedef _Rb_tree<key_type, value_type, _Identity<value_type>, -<span class="lineNum"> 116 </span> : key_compare, _Key_alloc_type> _Rep_type; -<span class="lineNum"> 117 </span> : _Rep_type _M_t; // Red-black tree representing set. -<span class="lineNum"> 118 </span> : -<span class="lineNum"> 119 </span> : public: -<span class="lineNum"> 120 </span> : //@{ -<span class="lineNum"> 121 </span> : /// Iterator-related typedefs. -<span class="lineNum"> 122 </span> : typedef typename _Key_alloc_type::pointer pointer; -<span class="lineNum"> 123 </span> : typedef typename _Key_alloc_type::const_pointer const_pointer; -<span class="lineNum"> 124 </span> : typedef typename _Key_alloc_type::reference reference; -<span class="lineNum"> 125 </span> : typedef typename _Key_alloc_type::const_reference const_reference; -<span class="lineNum"> 126 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 127 </span> : // DR 103. set::iterator is required to be modifiable, -<span class="lineNum"> 128 </span> : // but this allows modification of keys. -<span class="lineNum"> 129 </span> : typedef typename _Rep_type::const_iterator iterator; -<span class="lineNum"> 130 </span> : typedef typename _Rep_type::const_iterator const_iterator; -<span class="lineNum"> 131 </span> : typedef typename _Rep_type::const_reverse_iterator reverse_iterator; -<span class="lineNum"> 132 </span> : typedef typename _Rep_type::const_reverse_iterator const_reverse_iterator; -<span class="lineNum"> 133 </span> : typedef typename _Rep_type::size_type size_type; -<span class="lineNum"> 134 </span> : typedef typename _Rep_type::difference_type difference_type; -<span class="lineNum"> 135 </span> : //@} -<span class="lineNum"> 136 </span> : -<span class="lineNum"> 137 </span> : // allocation/deallocation -<span class="lineNum"> 138 </span> : /** -<span class="lineNum"> 139 </span> : * @brief Default constructor creates no elements. -<span class="lineNum"> 140 </span> : */ -<span class="lineNum"> 141 </span><span class="lineCov"> 277740 : set()</span> -<span class="lineNum"> 142 </span><span class="lineCov"> 277740 : : _M_t() { }</span> -<span class="lineNum"> 143 </span> : -<span class="lineNum"> 144 </span> : /** -<span class="lineNum"> 145 </span> : * @brief Creates a %set with no elements. -<span class="lineNum"> 146 </span> : * @param comp Comparator to use. -<span class="lineNum"> 147 </span> : * @param a An allocator object. -<span class="lineNum"> 148 </span> : */ -<span class="lineNum"> 149 </span> : explicit -<span class="lineNum"> 150 </span> : set(const _Compare& __comp, -<span class="lineNum"> 151 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 152 </span> : : _M_t(__comp, __a) { } -<span class="lineNum"> 153 </span> : -<span class="lineNum"> 154 </span> : /** -<span class="lineNum"> 155 </span> : * @brief Builds a %set from a range. -<span class="lineNum"> 156 </span> : * @param first An input iterator. -<span class="lineNum"> 157 </span> : * @param last An input iterator. -<span class="lineNum"> 158 </span> : * -<span class="lineNum"> 159 </span> : * Create a %set consisting of copies of the elements from [first,last). -<span class="lineNum"> 160 </span> : * This is linear in N if the range is already sorted, and NlogN -<span class="lineNum"> 161 </span> : * otherwise (where N is distance(first,last)). -<span class="lineNum"> 162 </span> : */ -<span class="lineNum"> 163 </span> : template<typename _InputIterator> -<span class="lineNum"> 164 </span> : set(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 165 </span> : : _M_t() -<span class="lineNum"> 166 </span> : { _M_t._M_insert_unique(__first, __last); } -<span class="lineNum"> 167 </span> : -<span class="lineNum"> 168 </span> : /** -<span class="lineNum"> 169 </span> : * @brief Builds a %set from a range. -<span class="lineNum"> 170 </span> : * @param first An input iterator. -<span class="lineNum"> 171 </span> : * @param last An input iterator. -<span class="lineNum"> 172 </span> : * @param comp A comparison functor. -<span class="lineNum"> 173 </span> : * @param a An allocator object. -<span class="lineNum"> 174 </span> : * -<span class="lineNum"> 175 </span> : * Create a %set consisting of copies of the elements from [first,last). -<span class="lineNum"> 176 </span> : * This is linear in N if the range is already sorted, and NlogN -<span class="lineNum"> 177 </span> : * otherwise (where N is distance(first,last)). -<span class="lineNum"> 178 </span> : */ -<span class="lineNum"> 179 </span> : template<typename _InputIterator> -<span class="lineNum"> 180 </span> : set(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 181 </span> : const _Compare& __comp, -<span class="lineNum"> 182 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 183 </span> : : _M_t(__comp, __a) -<span class="lineNum"> 184 </span> : { _M_t._M_insert_unique(__first, __last); } -<span class="lineNum"> 185 </span> : -<span class="lineNum"> 186 </span> : /** -<span class="lineNum"> 187 </span> : * @brief %Set copy constructor. -<span class="lineNum"> 188 </span> : * @param x A %set of identical element and allocator types. -<span class="lineNum"> 189 </span> : * -<span class="lineNum"> 190 </span> : * The newly-created %set uses a copy of the allocation object used -<span class="lineNum"> 191 </span> : * by @a x. -<span class="lineNum"> 192 </span> : */ -<span class="lineNum"> 193 </span><span class="lineCov"> 925151 : set(const set& __x)</span> -<span class="lineNum"> 194 </span><span class="lineCov"> 925151 : : _M_t(__x._M_t) { }</span> -<span class="lineNum"> 195 </span> : -<span class="lineNum"> 196 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 197 </span> : /** -<span class="lineNum"> 198 </span> : * @brief %Set move constructor -<span class="lineNum"> 199 </span> : * @param x A %set of identical element and allocator types. -<span class="lineNum"> 200 </span> : * -<span class="lineNum"> 201 </span> : * The newly-created %set contains the exact contents of @a x. -<span class="lineNum"> 202 </span> : * The contents of @a x are a valid, but unspecified %set. -<span class="lineNum"> 203 </span> : */ -<span class="lineNum"> 204 </span> : set(set&& __x) -<span class="lineNum"> 205 </span> : : _M_t(std::forward<_Rep_type>(__x._M_t)) { } -<span class="lineNum"> 206 </span> : #endif -<span class="lineNum"> 207 </span> : -<span class="lineNum"> 208 </span> : /** -<span class="lineNum"> 209 </span> : * @brief %Set assignment operator. -<span class="lineNum"> 210 </span> : * @param x A %set of identical element and allocator types. -<span class="lineNum"> 211 </span> : * -<span class="lineNum"> 212 </span> : * All the elements of @a x are copied, but unlike the copy constructor, -<span class="lineNum"> 213 </span> : * the allocator object is not copied. -<span class="lineNum"> 214 </span> : */ -<span class="lineNum"> 215 </span> : set& -<span class="lineNum"> 216 </span><span class="lineCov"> 80 : operator=(const set& __x)</span> -<span class="lineNum"> 217 </span> : { -<span class="lineNum"> 218 </span><span class="lineCov"> 80 : _M_t = __x._M_t;</span> -<span class="lineNum"> 219 </span><span class="lineCov"> 80 : return *this;</span> -<span class="lineNum"> 220 </span> : } -<span class="lineNum"> 221 </span> : -<span class="lineNum"> 222 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 223 </span> : /** -<span class="lineNum"> 224 </span> : * @brief %Set move assignment operator. -<span class="lineNum"> 225 </span> : * @param x A %set of identical element and allocator types. -<span class="lineNum"> 226 </span> : * -<span class="lineNum"> 227 </span> : * The contents of @a x are moved into this %set (without copying). -<span class="lineNum"> 228 </span> : * @a x is a valid, but unspecified %set. -<span class="lineNum"> 229 </span> : */ -<span class="lineNum"> 230 </span> : set& -<span class="lineNum"> 231 </span> : operator=(set&& __x) -<span class="lineNum"> 232 </span> : { -<span class="lineNum"> 233 </span> : // NB: DR 675. -<span class="lineNum"> 234 </span> : this->clear(); -<span class="lineNum"> 235 </span> : this->swap(__x); -<span class="lineNum"> 236 </span> : return *this; -<span class="lineNum"> 237 </span> : } -<span class="lineNum"> 238 </span> : #endif -<span class="lineNum"> 239 </span> : -<span class="lineNum"> 240 </span> : // accessors: -<span class="lineNum"> 241 </span> : -<span class="lineNum"> 242 </span> : /// Returns the comparison object with which the %set was constructed. -<span class="lineNum"> 243 </span> : key_compare -<span class="lineNum"> 244 </span> : key_comp() const -<span class="lineNum"> 245 </span> : { return _M_t.key_comp(); } -<span class="lineNum"> 246 </span> : /// Returns the comparison object with which the %set was constructed. -<span class="lineNum"> 247 </span> : value_compare -<span class="lineNum"> 248 </span> : value_comp() const -<span class="lineNum"> 249 </span> : { return _M_t.key_comp(); } -<span class="lineNum"> 250 </span> : /// Returns the allocator object with which the %set was constructed. -<span class="lineNum"> 251 </span> : allocator_type -<span class="lineNum"> 252 </span> : get_allocator() const -<span class="lineNum"> 253 </span> : { return _M_t.get_allocator(); } -<span class="lineNum"> 254 </span> : -<span class="lineNum"> 255 </span> : /** -<span class="lineNum"> 256 </span> : * Returns a read-only (constant) iterator that points to the first -<span class="lineNum"> 257 </span> : * element in the %set. Iteration is done in ascending order according -<span class="lineNum"> 258 </span> : * to the keys. -<span class="lineNum"> 259 </span> : */ -<span class="lineNum"> 260 </span> : iterator -<span class="lineNum"> 261 </span><span class="lineCov"> 468023 : begin() const</span> -<span class="lineNum"> 262 </span><span class="lineCov"> 468023 : { return _M_t.begin(); }</span> -<span class="lineNum"> 263 </span> : -<span class="lineNum"> 264 </span> : /** -<span class="lineNum"> 265 </span> : * Returns a read-only (constant) iterator that points one past the last -<span class="lineNum"> 266 </span> : * element in the %set. Iteration is done in ascending order according -<span class="lineNum"> 267 </span> : * to the keys. -<span class="lineNum"> 268 </span> : */ -<span class="lineNum"> 269 </span> : iterator -<span class="lineNum"> 270 </span><span class="lineCov"> 1576796 : end() const</span> -<span class="lineNum"> 271 </span><span class="lineCov"> 1576796 : { return _M_t.end(); }</span> -<span class="lineNum"> 272 </span> : -<span class="lineNum"> 273 </span> : /** -<span class="lineNum"> 274 </span> : * Returns a read-only (constant) iterator that points to the last -<span class="lineNum"> 275 </span> : * element in the %set. Iteration is done in descending order according -<span class="lineNum"> 276 </span> : * to the keys. -<span class="lineNum"> 277 </span> : */ -<span class="lineNum"> 278 </span> : reverse_iterator -<span class="lineNum"> 279 </span> : rbegin() const -<span class="lineNum"> 280 </span> : { return _M_t.rbegin(); } -<span class="lineNum"> 281 </span> : -<span class="lineNum"> 282 </span> : /** -<span class="lineNum"> 283 </span> : * Returns a read-only (constant) reverse iterator that points to the -<span class="lineNum"> 284 </span> : * last pair in the %set. Iteration is done in descending order -<span class="lineNum"> 285 </span> : * according to the keys. -<span class="lineNum"> 286 </span> : */ -<span class="lineNum"> 287 </span> : reverse_iterator -<span class="lineNum"> 288 </span> : rend() const -<span class="lineNum"> 289 </span> : { return _M_t.rend(); } -<span class="lineNum"> 290 </span> : -<span class="lineNum"> 291 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 292 </span> : /** -<span class="lineNum"> 293 </span> : * Returns a read-only (constant) iterator that points to the first -<span class="lineNum"> 294 </span> : * element in the %set. Iteration is done in ascending order according -<span class="lineNum"> 295 </span> : * to the keys. -<span class="lineNum"> 296 </span> : */ -<span class="lineNum"> 297 </span> : iterator -<span class="lineNum"> 298 </span> : cbegin() const -<span class="lineNum"> 299 </span> : { return _M_t.begin(); } -<span class="lineNum"> 300 </span> : -<span class="lineNum"> 301 </span> : /** -<span class="lineNum"> 302 </span> : * Returns a read-only (constant) iterator that points one past the last -<span class="lineNum"> 303 </span> : * element in the %set. Iteration is done in ascending order according -<span class="lineNum"> 304 </span> : * to the keys. -<span class="lineNum"> 305 </span> : */ -<span class="lineNum"> 306 </span> : iterator -<span class="lineNum"> 307 </span> : cend() const -<span class="lineNum"> 308 </span> : { return _M_t.end(); } -<span class="lineNum"> 309 </span> : -<span class="lineNum"> 310 </span> : /** -<span class="lineNum"> 311 </span> : * Returns a read-only (constant) iterator that points to the last -<span class="lineNum"> 312 </span> : * element in the %set. Iteration is done in descending order according -<span class="lineNum"> 313 </span> : * to the keys. -<span class="lineNum"> 314 </span> : */ -<span class="lineNum"> 315 </span> : reverse_iterator -<span class="lineNum"> 316 </span> : crbegin() const -<span class="lineNum"> 317 </span> : { return _M_t.rbegin(); } -<span class="lineNum"> 318 </span> : -<span class="lineNum"> 319 </span> : /** -<span class="lineNum"> 320 </span> : * Returns a read-only (constant) reverse iterator that points to the -<span class="lineNum"> 321 </span> : * last pair in the %set. Iteration is done in descending order -<span class="lineNum"> 322 </span> : * according to the keys. -<span class="lineNum"> 323 </span> : */ -<span class="lineNum"> 324 </span> : reverse_iterator -<span class="lineNum"> 325 </span> : crend() const -<span class="lineNum"> 326 </span> : { return _M_t.rend(); } -<span class="lineNum"> 327 </span> : #endif -<span class="lineNum"> 328 </span> : -<span class="lineNum"> 329 </span> : /// Returns true if the %set is empty. -<span class="lineNum"> 330 </span> : bool -<span class="lineNum"> 331 </span><span class="lineCov"> 338386 : empty() const</span> -<span class="lineNum"> 332 </span><span class="lineCov"> 338386 : { return _M_t.empty(); }</span> -<span class="lineNum"> 333 </span> : -<span class="lineNum"> 334 </span> : /// Returns the size of the %set. -<span class="lineNum"> 335 </span> : size_type -<span class="lineNum"> 336 </span><span class="lineCov"> 84631 : size() const</span> -<span class="lineNum"> 337 </span><span class="lineCov"> 84631 : { return _M_t.size(); }</span> -<span class="lineNum"> 338 </span> : -<span class="lineNum"> 339 </span> : /// Returns the maximum size of the %set. -<span class="lineNum"> 340 </span> : size_type -<span class="lineNum"> 341 </span> : max_size() const -<span class="lineNum"> 342 </span> : { return _M_t.max_size(); } -<span class="lineNum"> 343 </span> : -<span class="lineNum"> 344 </span> : /** -<span class="lineNum"> 345 </span> : * @brief Swaps data with another %set. -<span class="lineNum"> 346 </span> : * @param x A %set of the same element and allocator types. -<span class="lineNum"> 347 </span> : * -<span class="lineNum"> 348 </span> : * This exchanges the elements between two sets in constant time. -<span class="lineNum"> 349 </span> : * (It is only swapping a pointer, an integer, and an instance of -<span class="lineNum"> 350 </span> : * the @c Compare type (which itself is often stateless and empty), so it -<span class="lineNum"> 351 </span> : * should be quite fast.) -<span class="lineNum"> 352 </span> : * Note that the global std::swap() function is specialized such that -<span class="lineNum"> 353 </span> : * std::swap(s1,s2) will feed to this function. -<span class="lineNum"> 354 </span> : */ -<span class="lineNum"> 355 </span> : void -<span class="lineNum"> 356 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 357 </span> : swap(set&& __x) -<span class="lineNum"> 358 </span> : #else -<span class="lineNum"> 359 </span> : swap(set& __x) -<span class="lineNum"> 360 </span> : #endif -<span class="lineNum"> 361 </span> : { _M_t.swap(__x._M_t); } -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : // insert/erase -<span class="lineNum"> 364 </span> : /** -<span class="lineNum"> 365 </span> : * @brief Attempts to insert an element into the %set. -<span class="lineNum"> 366 </span> : * @param x Element to be inserted. -<span class="lineNum"> 367 </span> : * @return A pair, of which the first element is an iterator that points -<span class="lineNum"> 368 </span> : * to the possibly inserted element, and the second is a bool -<span class="lineNum"> 369 </span> : * that is true if the element was actually inserted. -<span class="lineNum"> 370 </span> : * -<span class="lineNum"> 371 </span> : * This function attempts to insert an element into the %set. A %set -<span class="lineNum"> 372 </span> : * relies on unique keys and thus an element is only inserted if it is -<span class="lineNum"> 373 </span> : * not already present in the %set. -<span class="lineNum"> 374 </span> : * -<span class="lineNum"> 375 </span> : * Insertion requires logarithmic time. -<span class="lineNum"> 376 </span> : */ -<span class="lineNum"> 377 </span> : std::pair<iterator, bool> -<span class="lineNum"> 378 </span><span class="lineCov"> 1422360 : insert(const value_type& __x)</span> -<span class="lineNum"> 379 </span> : { -<span class="lineNum"> 380 </span> : std::pair<typename _Rep_type::iterator, bool> __p = -<span class="lineNum"> 381 </span><span class="lineCov"> 1422360 : _M_t._M_insert_unique(__x);</span> -<span class="lineNum"> 382 </span><span class="lineCov"> 1422360 : return std::pair<iterator, bool>(__p.first, __p.second);</span> -<span class="lineNum"> 383 </span> : } -<span class="lineNum"> 384 </span> : -<span class="lineNum"> 385 </span> : /** -<span class="lineNum"> 386 </span> : * @brief Attempts to insert an element into the %set. -<span class="lineNum"> 387 </span> : * @param position An iterator that serves as a hint as to where the -<span class="lineNum"> 388 </span> : * element should be inserted. -<span class="lineNum"> 389 </span> : * @param x Element to be inserted. -<span class="lineNum"> 390 </span> : * @return An iterator that points to the element with key of @a x (may -<span class="lineNum"> 391 </span> : * or may not be the element passed in). -<span class="lineNum"> 392 </span> : * -<span class="lineNum"> 393 </span> : * This function is not concerned about whether the insertion took place, -<span class="lineNum"> 394 </span> : * and thus does not return a boolean like the single-argument insert() -<span class="lineNum"> 395 </span> : * does. Note that the first parameter is only a hint and can -<span class="lineNum"> 396 </span> : * potentially improve the performance of the insertion process. A bad -<span class="lineNum"> 397 </span> : * hint would cause no gains in efficiency. -<span class="lineNum"> 398 </span> : * -<span class="lineNum"> 399 </span> : * See http://gcc.gnu.org/onlinedocs/libstdc++/23_containers/howto.html#4 -<span class="lineNum"> 400 </span> : * for more on "hinting". -<span class="lineNum"> 401 </span> : * -<span class="lineNum"> 402 </span> : * Insertion requires logarithmic time (if the hint is not taken). -<span class="lineNum"> 403 </span> : */ -<span class="lineNum"> 404 </span> : iterator -<span class="lineNum"> 405 </span><span class="lineCov"> 107613 : insert(iterator __position, const value_type& __x)</span> -<span class="lineNum"> 406 </span><span class="lineCov"> 107613 : { return _M_t._M_insert_unique_(__position, __x); }</span> -<span class="lineNum"> 407 </span> : -<span class="lineNum"> 408 </span> : /** -<span class="lineNum"> 409 </span> : * @brief A template function that attempts to insert a range of elements. -<span class="lineNum"> 410 </span> : * @param first Iterator pointing to the start of the range to be -<span class="lineNum"> 411 </span> : * inserted. -<span class="lineNum"> 412 </span> : * @param last Iterator pointing to the end of the range. -<span class="lineNum"> 413 </span> : * -<span class="lineNum"> 414 </span> : * Complexity similar to that of the range constructor. -<span class="lineNum"> 415 </span> : */ -<span class="lineNum"> 416 </span> : template<typename _InputIterator> -<span class="lineNum"> 417 </span> : void -<span class="lineNum"> 418 </span> : insert(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 419 </span> : { _M_t._M_insert_unique(__first, __last); } -<span class="lineNum"> 420 </span> : -<span class="lineNum"> 421 </span> : /** -<span class="lineNum"> 422 </span> : * @brief Erases an element from a %set. -<span class="lineNum"> 423 </span> : * @param position An iterator pointing to the element to be erased. -<span class="lineNum"> 424 </span> : * -<span class="lineNum"> 425 </span> : * This function erases an element, pointed to by the given iterator, -<span class="lineNum"> 426 </span> : * from a %set. Note that this function only erases the element, and -<span class="lineNum"> 427 </span> : * that if the element is itself a pointer, the pointed-to memory is not -<span class="lineNum"> 428 </span> : * touched in any way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 429 </span> : */ -<span class="lineNum"> 430 </span> : void -<span class="lineNum"> 431 </span><span class="lineCov"> 129 : erase(iterator __position)</span> -<span class="lineNum"> 432 </span><span class="lineCov"> 129 : { _M_t.erase(__position); }</span> -<span class="lineNum"> 433 </span> : -<span class="lineNum"> 434 </span> : /** -<span class="lineNum"> 435 </span> : * @brief Erases elements according to the provided key. -<span class="lineNum"> 436 </span> : * @param x Key of element to be erased. -<span class="lineNum"> 437 </span> : * @return The number of elements erased. -<span class="lineNum"> 438 </span> : * -<span class="lineNum"> 439 </span> : * This function erases all the elements located by the given key from -<span class="lineNum"> 440 </span> : * a %set. -<span class="lineNum"> 441 </span> : * Note that this function only erases the element, and that if -<span class="lineNum"> 442 </span> : * the element is itself a pointer, the pointed-to memory is not touched -<span class="lineNum"> 443 </span> : * in any way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 444 </span> : */ -<span class="lineNum"> 445 </span> : size_type -<span class="lineNum"> 446 </span><span class="lineCov"> 9 : erase(const key_type& __x)</span> -<span class="lineNum"> 447 </span><span class="lineCov"> 9 : { return _M_t.erase(__x); }</span> -<span class="lineNum"> 448 </span> : -<span class="lineNum"> 449 </span> : /** -<span class="lineNum"> 450 </span> : * @brief Erases a [first,last) range of elements from a %set. -<span class="lineNum"> 451 </span> : * @param first Iterator pointing to the start of the range to be -<span class="lineNum"> 452 </span> : * erased. -<span class="lineNum"> 453 </span> : * @param last Iterator pointing to the end of the range to be erased. -<span class="lineNum"> 454 </span> : * -<span class="lineNum"> 455 </span> : * This function erases a sequence of elements from a %set. -<span class="lineNum"> 456 </span> : * Note that this function only erases the element, and that if -<span class="lineNum"> 457 </span> : * the element is itself a pointer, the pointed-to memory is not touched -<span class="lineNum"> 458 </span> : * in any way. Managing the pointer is the user's responsibility. -<span class="lineNum"> 459 </span> : */ -<span class="lineNum"> 460 </span> : void -<span class="lineNum"> 461 </span> : erase(iterator __first, iterator __last) -<span class="lineNum"> 462 </span> : { _M_t.erase(__first, __last); } -<span class="lineNum"> 463 </span> : -<span class="lineNum"> 464 </span> : /** -<span class="lineNum"> 465 </span> : * Erases all elements in a %set. Note that this function only erases -<span class="lineNum"> 466 </span> : * the elements, and that if the elements themselves are pointers, the -<span class="lineNum"> 467 </span> : * pointed-to memory is not touched in any way. Managing the pointer is -<span class="lineNum"> 468 </span> : * the user's responsibility. -<span class="lineNum"> 469 </span> : */ -<span class="lineNum"> 470 </span> : void -<span class="lineNum"> 471 </span><span class="lineCov"> 84600 : clear()</span> -<span class="lineNum"> 472 </span><span class="lineCov"> 84600 : { _M_t.clear(); }</span> -<span class="lineNum"> 473 </span> : -<span class="lineNum"> 474 </span> : // set operations: -<span class="lineNum"> 475 </span> : -<span class="lineNum"> 476 </span> : /** -<span class="lineNum"> 477 </span> : * @brief Finds the number of elements. -<span class="lineNum"> 478 </span> : * @param x Element to located. -<span class="lineNum"> 479 </span> : * @return Number of elements with specified key. -<span class="lineNum"> 480 </span> : * -<span class="lineNum"> 481 </span> : * This function only makes sense for multisets; for set the result will -<span class="lineNum"> 482 </span> : * either be 0 (not present) or 1 (present). -<span class="lineNum"> 483 </span> : */ -<span class="lineNum"> 484 </span> : size_type -<span class="lineNum"> 485 </span> : count(const key_type& __x) const -<span class="lineNum"> 486 </span> : { return _M_t.find(__x) == _M_t.end() ? 0 : 1; } -<span class="lineNum"> 487 </span> : -<span class="lineNum"> 488 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 489 </span> : // 214. set::find() missing const overload -<span class="lineNum"> 490 </span> : //@{ -<span class="lineNum"> 491 </span> : /** -<span class="lineNum"> 492 </span> : * @brief Tries to locate an element in a %set. -<span class="lineNum"> 493 </span> : * @param x Element to be located. -<span class="lineNum"> 494 </span> : * @return Iterator pointing to sought-after element, or end() if not -<span class="lineNum"> 495 </span> : * found. -<span class="lineNum"> 496 </span> : * -<span class="lineNum"> 497 </span> : * This function takes a key and tries to locate the element with which -<span class="lineNum"> 498 </span> : * the key matches. If successful the function returns an iterator -<span class="lineNum"> 499 </span> : * pointing to the sought after element. If unsuccessful it returns the -<span class="lineNum"> 500 </span> : * past-the-end ( @c end() ) iterator. -<span class="lineNum"> 501 </span> : */ -<span class="lineNum"> 502 </span> : iterator -<span class="lineNum"> 503 </span><span class="lineCov"> 39 : find(const key_type& __x)</span> -<span class="lineNum"> 504 </span><span class="lineCov"> 39 : { return _M_t.find(__x); }</span> -<span class="lineNum"> 505 </span> : -<span class="lineNum"> 506 </span> : const_iterator -<span class="lineNum"> 507 </span><span class="lineCov"> 16 : find(const key_type& __x) const</span> -<span class="lineNum"> 508 </span><span class="lineCov"> 16 : { return _M_t.find(__x); }</span> -<span class="lineNum"> 509 </span> : //@} -<span class="lineNum"> 510 </span> : -<span class="lineNum"> 511 </span> : //@{ -<span class="lineNum"> 512 </span> : /** -<span class="lineNum"> 513 </span> : * @brief Finds the beginning of a subsequence matching given key. -<span class="lineNum"> 514 </span> : * @param x Key to be located. -<span class="lineNum"> 515 </span> : * @return Iterator pointing to first element equal to or greater -<span class="lineNum"> 516 </span> : * than key, or end(). -<span class="lineNum"> 517 </span> : * -<span class="lineNum"> 518 </span> : * This function returns the first element of a subsequence of elements -<span class="lineNum"> 519 </span> : * that matches the given key. If unsuccessful it returns an iterator -<span class="lineNum"> 520 </span> : * pointing to the first element that has a greater value than given key -<span class="lineNum"> 521 </span> : * or end() if no such element exists. -<span class="lineNum"> 522 </span> : */ -<span class="lineNum"> 523 </span> : iterator -<span class="lineNum"> 524 </span> : lower_bound(const key_type& __x) -<span class="lineNum"> 525 </span> : { return _M_t.lower_bound(__x); } -<span class="lineNum"> 526 </span> : -<span class="lineNum"> 527 </span> : const_iterator -<span class="lineNum"> 528 </span> : lower_bound(const key_type& __x) const -<span class="lineNum"> 529 </span> : { return _M_t.lower_bound(__x); } -<span class="lineNum"> 530 </span> : //@} -<span class="lineNum"> 531 </span> : -<span class="lineNum"> 532 </span> : //@{ -<span class="lineNum"> 533 </span> : /** -<span class="lineNum"> 534 </span> : * @brief Finds the end of a subsequence matching given key. -<span class="lineNum"> 535 </span> : * @param x Key to be located. -<span class="lineNum"> 536 </span> : * @return Iterator pointing to the first element -<span class="lineNum"> 537 </span> : * greater than key, or end(). -<span class="lineNum"> 538 </span> : */ -<span class="lineNum"> 539 </span> : iterator -<span class="lineNum"> 540 </span> : upper_bound(const key_type& __x) -<span class="lineNum"> 541 </span> : { return _M_t.upper_bound(__x); } -<span class="lineNum"> 542 </span> : -<span class="lineNum"> 543 </span> : const_iterator -<span class="lineNum"> 544 </span> : upper_bound(const key_type& __x) const -<span class="lineNum"> 545 </span> : { return _M_t.upper_bound(__x); } -<span class="lineNum"> 546 </span> : //@} -<span class="lineNum"> 547 </span> : -<span class="lineNum"> 548 </span> : //@{ -<span class="lineNum"> 549 </span> : /** -<span class="lineNum"> 550 </span> : * @brief Finds a subsequence matching given key. -<span class="lineNum"> 551 </span> : * @param x Key to be located. -<span class="lineNum"> 552 </span> : * @return Pair of iterators that possibly points to the subsequence -<span class="lineNum"> 553 </span> : * matching given key. -<span class="lineNum"> 554 </span> : * -<span class="lineNum"> 555 </span> : * This function is equivalent to -<span class="lineNum"> 556 </span> : * @code -<span class="lineNum"> 557 </span> : * std::make_pair(c.lower_bound(val), -<span class="lineNum"> 558 </span> : * c.upper_bound(val)) -<span class="lineNum"> 559 </span> : * @endcode -<span class="lineNum"> 560 </span> : * (but is faster than making the calls separately). -<span class="lineNum"> 561 </span> : * -<span class="lineNum"> 562 </span> : * This function probably only makes sense for multisets. -<span class="lineNum"> 563 </span> : */ -<span class="lineNum"> 564 </span> : std::pair<iterator, iterator> -<span class="lineNum"> 565 </span> : equal_range(const key_type& __x) -<span class="lineNum"> 566 </span> : { return _M_t.equal_range(__x); } -<span class="lineNum"> 567 </span> : -<span class="lineNum"> 568 </span> : std::pair<const_iterator, const_iterator> -<span class="lineNum"> 569 </span> : equal_range(const key_type& __x) const -<span class="lineNum"> 570 </span> : { return _M_t.equal_range(__x); } -<span class="lineNum"> 571 </span> : //@} -<span class="lineNum"> 572 </span> : -<span class="lineNum"> 573 </span> : template<typename _K1, typename _C1, typename _A1> -<span class="lineNum"> 574 </span> : friend bool -<span class="lineNum"> 575 </span> : operator==(const set<_K1, _C1, _A1>&, const set<_K1, _C1, _A1>&); -<span class="lineNum"> 576 </span> : -<span class="lineNum"> 577 </span> : template<typename _K1, typename _C1, typename _A1> -<span class="lineNum"> 578 </span> : friend bool -<span class="lineNum"> 579 </span> : operator<(const set<_K1, _C1, _A1>&, const set<_K1, _C1, _A1>&); -<span class="lineNum"> 580 </span> : }; -<span class="lineNum"> 581 </span> : -<span class="lineNum"> 582 </span> : -<span class="lineNum"> 583 </span> : /** -<span class="lineNum"> 584 </span> : * @brief Set equality comparison. -<span class="lineNum"> 585 </span> : * @param x A %set. -<span class="lineNum"> 586 </span> : * @param y A %set of the same type as @a x. -<span class="lineNum"> 587 </span> : * @return True iff the size and elements of the sets are equal. -<span class="lineNum"> 588 </span> : * -<span class="lineNum"> 589 </span> : * This is an equivalence relation. It is linear in the size of the sets. -<span class="lineNum"> 590 </span> : * Sets are considered equivalent if their sizes are equal, and if -<span class="lineNum"> 591 </span> : * corresponding elements compare equal. -<span class="lineNum"> 592 </span> : */ -<span class="lineNum"> 593 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 594 </span> : inline bool -<span class="lineNum"> 595 </span> : operator==(const set<_Key, _Compare, _Alloc>& __x, -<span class="lineNum"> 596 </span><span class="lineCov"> 4 : const set<_Key, _Compare, _Alloc>& __y)</span> -<span class="lineNum"> 597 </span><span class="lineCov"> 4 : { return __x._M_t == __y._M_t; }</span> -<span class="lineNum"> 598 </span> : -<span class="lineNum"> 599 </span> : /** -<span class="lineNum"> 600 </span> : * @brief Set ordering relation. -<span class="lineNum"> 601 </span> : * @param x A %set. -<span class="lineNum"> 602 </span> : * @param y A %set of the same type as @a x. -<span class="lineNum"> 603 </span> : * @return True iff @a x is lexicographically less than @a y. -<span class="lineNum"> 604 </span> : * -<span class="lineNum"> 605 </span> : * This is a total ordering relation. It is linear in the size of the -<span class="lineNum"> 606 </span> : * maps. The elements must be comparable with @c <. -<span class="lineNum"> 607 </span> : * -<span class="lineNum"> 608 </span> : * See std::lexicographical_compare() for how the determination is made. -<span class="lineNum"> 609 </span> : */ -<span class="lineNum"> 610 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 611 </span> : inline bool -<span class="lineNum"> 612 </span> : operator<(const set<_Key, _Compare, _Alloc>& __x, -<span class="lineNum"> 613 </span> : const set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 614 </span> : { return __x._M_t < __y._M_t; } -<span class="lineNum"> 615 </span> : -<span class="lineNum"> 616 </span> : /// Returns !(x == y). -<span class="lineNum"> 617 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 618 </span> : inline bool -<span class="lineNum"> 619 </span> : operator!=(const set<_Key, _Compare, _Alloc>& __x, -<span class="lineNum"> 620 </span> : const set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 621 </span> : { return !(__x == __y); } -<span class="lineNum"> 622 </span> : -<span class="lineNum"> 623 </span> : /// Returns y < x. -<span class="lineNum"> 624 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 625 </span> : inline bool -<span class="lineNum"> 626 </span> : operator>(const set<_Key, _Compare, _Alloc>& __x, -<span class="lineNum"> 627 </span> : const set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 628 </span> : { return __y < __x; } -<span class="lineNum"> 629 </span> : -<span class="lineNum"> 630 </span> : /// Returns !(y < x) -<span class="lineNum"> 631 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 632 </span> : inline bool -<span class="lineNum"> 633 </span> : operator<=(const set<_Key, _Compare, _Alloc>& __x, -<span class="lineNum"> 634 </span> : const set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 635 </span> : { return !(__y < __x); } -<span class="lineNum"> 636 </span> : -<span class="lineNum"> 637 </span> : /// Returns !(x < y) -<span class="lineNum"> 638 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 639 </span> : inline bool -<span class="lineNum"> 640 </span> : operator>=(const set<_Key, _Compare, _Alloc>& __x, -<span class="lineNum"> 641 </span> : const set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 642 </span> : { return !(__x < __y); } -<span class="lineNum"> 643 </span> : -<span class="lineNum"> 644 </span> : /// See std::set::swap(). -<span class="lineNum"> 645 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 646 </span> : inline void -<span class="lineNum"> 647 </span> : swap(set<_Key, _Compare, _Alloc>& __x, set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 648 </span> : { __x.swap(__y); } -<span class="lineNum"> 649 </span> : -<span class="lineNum"> 650 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 651 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 652 </span> : inline void -<span class="lineNum"> 653 </span> : swap(set<_Key, _Compare, _Alloc>&& __x, set<_Key, _Compare, _Alloc>& __y) -<span class="lineNum"> 654 </span> : { __x.swap(__y); } -<span class="lineNum"> 655 </span> : -<span class="lineNum"> 656 </span> : template<typename _Key, typename _Compare, typename _Alloc> -<span class="lineNum"> 657 </span> : inline void -<span class="lineNum"> 658 </span> : swap(set<_Key, _Compare, _Alloc>& __x, set<_Key, _Compare, _Alloc>&& __y) -<span class="lineNum"> 659 </span> : { __x.swap(__y); } -<span class="lineNum"> 660 </span> : #endif -<span class="lineNum"> 661 </span> : -<span class="lineNum"> 662 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 663 </span> : -<span class="lineNum"> 664 </span> : #endif /* _STL_SET_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_stack.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_stack.h.gcov.html deleted file mode 100644 index d033bc3..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_stack.h.gcov.html +++ /dev/null @@ -1,369 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_stack.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_stack.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">12</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">12</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Stack implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_stack.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_STACK_H -<span class="lineNum"> 63 </span> : #define _STL_STACK_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 66 </span> : #include <debug/debug.h> -<span class="lineNum"> 67 </span> : -<span class="lineNum"> 68 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : /** -<span class="lineNum"> 71 </span> : * @brief A standard container giving FILO behavior. -<span class="lineNum"> 72 </span> : * -<span class="lineNum"> 73 </span> : * @ingroup Containers -<span class="lineNum"> 74 </span> : * @ingroup Sequences -<span class="lineNum"> 75 </span> : * -<span class="lineNum"> 76 </span> : * Meets many of the requirements of a -<span class="lineNum"> 77 </span> : * <a href="tables.html#65">container</a>, -<span class="lineNum"> 78 </span> : * but does not define anything to do with iterators. Very few of the -<span class="lineNum"> 79 </span> : * other standard container interfaces are defined. -<span class="lineNum"> 80 </span> : * -<span class="lineNum"> 81 </span> : * This is not a true container, but an @e adaptor. It holds -<span class="lineNum"> 82 </span> : * another container, and provides a wrapper interface to that -<span class="lineNum"> 83 </span> : * container. The wrapper is what enforces strict -<span class="lineNum"> 84 </span> : * first-in-last-out %stack behavior. -<span class="lineNum"> 85 </span> : * -<span class="lineNum"> 86 </span> : * The second template parameter defines the type of the underlying -<span class="lineNum"> 87 </span> : * sequence/container. It defaults to std::deque, but it can be -<span class="lineNum"> 88 </span> : * any type that supports @c back, @c push_back, and @c pop_front, -<span class="lineNum"> 89 </span> : * such as std::list, std::vector, or an appropriate user-defined -<span class="lineNum"> 90 </span> : * type. -<span class="lineNum"> 91 </span> : * -<span class="lineNum"> 92 </span> : * Members not found in "normal" containers are @c container_type, -<span class="lineNum"> 93 </span> : * which is a typedef for the second Sequence parameter, and @c -<span class="lineNum"> 94 </span> : * push, @c pop, and @c top, which are standard %stack/FILO -<span class="lineNum"> 95 </span> : * operations. -<span class="lineNum"> 96 </span> : */ -<span class="lineNum"> 97 </span> : template<typename _Tp, typename _Sequence = deque<_Tp> > -<span class="lineNum"> 98 </span> : class stack -<span class="lineNum"> 99 </span><span class="lineCov"> 13 : {</span> -<span class="lineNum"> 100 </span> : // concept requirements -<span class="lineNum"> 101 </span> : typedef typename _Sequence::value_type _Sequence_value_type; -<span class="lineNum"> 102 </span> : __glibcxx_class_requires(_Tp, _SGIAssignableConcept) -<span class="lineNum"> 103 </span> : __glibcxx_class_requires(_Sequence, _BackInsertionSequenceConcept) -<span class="lineNum"> 104 </span> : __glibcxx_class_requires2(_Tp, _Sequence_value_type, _SameTypeConcept) -<span class="lineNum"> 105 </span> : -<span class="lineNum"> 106 </span> : template<typename _Tp1, typename _Seq1> -<span class="lineNum"> 107 </span> : friend bool -<span class="lineNum"> 108 </span> : operator==(const stack<_Tp1, _Seq1>&, const stack<_Tp1, _Seq1>&); -<span class="lineNum"> 109 </span> : -<span class="lineNum"> 110 </span> : template<typename _Tp1, typename _Seq1> -<span class="lineNum"> 111 </span> : friend bool -<span class="lineNum"> 112 </span> : operator<(const stack<_Tp1, _Seq1>&, const stack<_Tp1, _Seq1>&); -<span class="lineNum"> 113 </span> : -<span class="lineNum"> 114 </span> : public: -<span class="lineNum"> 115 </span> : typedef typename _Sequence::value_type value_type; -<span class="lineNum"> 116 </span> : typedef typename _Sequence::reference reference; -<span class="lineNum"> 117 </span> : typedef typename _Sequence::const_reference const_reference; -<span class="lineNum"> 118 </span> : typedef typename _Sequence::size_type size_type; -<span class="lineNum"> 119 </span> : typedef _Sequence container_type; -<span class="lineNum"> 120 </span> : -<span class="lineNum"> 121 </span> : protected: -<span class="lineNum"> 122 </span> : // See queue::c for notes on this name. -<span class="lineNum"> 123 </span> : _Sequence c; -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : public: -<span class="lineNum"> 126 </span> : // XXX removed old def ctor, added def arg to this one to match 14882 -<span class="lineNum"> 127 </span> : /** -<span class="lineNum"> 128 </span> : * @brief Default constructor creates no elements. -<span class="lineNum"> 129 </span> : */ -<span class="lineNum"> 130 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 131 </span> : explicit -<span class="lineNum"> 132 </span><span class="lineCov"> 13 : stack(const _Sequence& __c = _Sequence())</span> -<span class="lineNum"> 133 </span><span class="lineCov"> 13 : : c(__c) { }</span> -<span class="lineNum"> 134 </span> : #else -<span class="lineNum"> 135 </span> : explicit -<span class="lineNum"> 136 </span> : stack(const _Sequence& __c) -<span class="lineNum"> 137 </span> : : c(__c) { } -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : explicit -<span class="lineNum"> 140 </span> : stack(_Sequence&& __c = _Sequence()) -<span class="lineNum"> 141 </span> : : c(std::move(__c)) { } -<span class="lineNum"> 142 </span> : #endif -<span class="lineNum"> 143 </span> : -<span class="lineNum"> 144 </span> : /** -<span class="lineNum"> 145 </span> : * Returns true if the %stack is empty. -<span class="lineNum"> 146 </span> : */ -<span class="lineNum"> 147 </span> : bool -<span class="lineNum"> 148 </span><span class="lineCov"> 32 : empty() const</span> -<span class="lineNum"> 149 </span><span class="lineCov"> 32 : { return c.empty(); }</span> -<span class="lineNum"> 150 </span> : -<span class="lineNum"> 151 </span> : /** Returns the number of elements in the %stack. */ -<span class="lineNum"> 152 </span> : size_type -<span class="lineNum"> 153 </span> : size() const -<span class="lineNum"> 154 </span> : { return c.size(); } -<span class="lineNum"> 155 </span> : -<span class="lineNum"> 156 </span> : /** -<span class="lineNum"> 157 </span> : * Returns a read/write reference to the data at the first -<span class="lineNum"> 158 </span> : * element of the %stack. -<span class="lineNum"> 159 </span> : */ -<span class="lineNum"> 160 </span> : reference -<span class="lineNum"> 161 </span><span class="lineCov"> 39 : top()</span> -<span class="lineNum"> 162 </span> : { -<span class="lineNum"> 163 </span> : __glibcxx_requires_nonempty(); -<span class="lineNum"> 164 </span><span class="lineCov"> 39 : return c.back();</span> -<span class="lineNum"> 165 </span> : } -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : /** -<span class="lineNum"> 168 </span> : * Returns a read-only (constant) reference to the data at the first -<span class="lineNum"> 169 </span> : * element of the %stack. -<span class="lineNum"> 170 </span> : */ -<span class="lineNum"> 171 </span> : const_reference -<span class="lineNum"> 172 </span> : top() const -<span class="lineNum"> 173 </span> : { -<span class="lineNum"> 174 </span> : __glibcxx_requires_nonempty(); -<span class="lineNum"> 175 </span> : return c.back(); -<span class="lineNum"> 176 </span> : } -<span class="lineNum"> 177 </span> : -<span class="lineNum"> 178 </span> : /** -<span class="lineNum"> 179 </span> : * @brief Add data to the top of the %stack. -<span class="lineNum"> 180 </span> : * @param x Data to be added. -<span class="lineNum"> 181 </span> : * -<span class="lineNum"> 182 </span> : * This is a typical %stack operation. The function creates an -<span class="lineNum"> 183 </span> : * element at the top of the %stack and assigns the given data -<span class="lineNum"> 184 </span> : * to it. The time complexity of the operation depends on the -<span class="lineNum"> 185 </span> : * underlying sequence. -<span class="lineNum"> 186 </span> : */ -<span class="lineNum"> 187 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 188 </span> : void -<span class="lineNum"> 189 </span><span class="lineCov"> 24 : push(const value_type& __x)</span> -<span class="lineNum"> 190 </span><span class="lineCov"> 24 : { c.push_back(__x); }</span> -<span class="lineNum"> 191 </span> : #else -<span class="lineNum"> 192 </span> : // NB: DR 756. -<span class="lineNum"> 193 </span> : template<typename... _Args> -<span class="lineNum"> 194 </span> : void -<span class="lineNum"> 195 </span> : push(_Args&&... __args) -<span class="lineNum"> 196 </span> : { c.push_back(std::forward<_Args>(__args)...); } -<span class="lineNum"> 197 </span> : #endif -<span class="lineNum"> 198 </span> : -<span class="lineNum"> 199 </span> : /** -<span class="lineNum"> 200 </span> : * @brief Removes first element. -<span class="lineNum"> 201 </span> : * -<span class="lineNum"> 202 </span> : * This is a typical %stack operation. It shrinks the %stack -<span class="lineNum"> 203 </span> : * by one. The time complexity of the operation depends on the -<span class="lineNum"> 204 </span> : * underlying sequence. -<span class="lineNum"> 205 </span> : * -<span class="lineNum"> 206 </span> : * Note that no data is returned, and if the first element's -<span class="lineNum"> 207 </span> : * data is needed, it should be retrieved before pop() is -<span class="lineNum"> 208 </span> : * called. -<span class="lineNum"> 209 </span> : */ -<span class="lineNum"> 210 </span> : void -<span class="lineNum"> 211 </span><span class="lineCov"> 24 : pop()</span> -<span class="lineNum"> 212 </span> : { -<span class="lineNum"> 213 </span> : __glibcxx_requires_nonempty(); -<span class="lineNum"> 214 </span><span class="lineCov"> 24 : c.pop_back();</span> -<span class="lineNum"> 215 </span><span class="lineCov"> 24 : }</span> -<span class="lineNum"> 216 </span> : -<span class="lineNum"> 217 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 218 </span> : void -<span class="lineNum"> 219 </span> : swap(stack&& __s) -<span class="lineNum"> 220 </span> : { c.swap(__s.c); } -<span class="lineNum"> 221 </span> : #endif -<span class="lineNum"> 222 </span> : }; -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : /** -<span class="lineNum"> 225 </span> : * @brief Stack equality comparison. -<span class="lineNum"> 226 </span> : * @param x A %stack. -<span class="lineNum"> 227 </span> : * @param y A %stack of the same type as @a x. -<span class="lineNum"> 228 </span> : * @return True iff the size and elements of the stacks are equal. -<span class="lineNum"> 229 </span> : * -<span class="lineNum"> 230 </span> : * This is an equivalence relation. Complexity and semantics -<span class="lineNum"> 231 </span> : * depend on the underlying sequence type, but the expected rules -<span class="lineNum"> 232 </span> : * are: this relation is linear in the size of the sequences, and -<span class="lineNum"> 233 </span> : * stacks are considered equivalent if their sequences compare -<span class="lineNum"> 234 </span> : * equal. -<span class="lineNum"> 235 </span> : */ -<span class="lineNum"> 236 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 237 </span> : inline bool -<span class="lineNum"> 238 </span> : operator==(const stack<_Tp, _Seq>& __x, const stack<_Tp, _Seq>& __y) -<span class="lineNum"> 239 </span> : { return __x.c == __y.c; } -<span class="lineNum"> 240 </span> : -<span class="lineNum"> 241 </span> : /** -<span class="lineNum"> 242 </span> : * @brief Stack ordering relation. -<span class="lineNum"> 243 </span> : * @param x A %stack. -<span class="lineNum"> 244 </span> : * @param y A %stack of the same type as @a x. -<span class="lineNum"> 245 </span> : * @return True iff @a x is lexicographically less than @a y. -<span class="lineNum"> 246 </span> : * -<span class="lineNum"> 247 </span> : * This is an total ordering relation. Complexity and semantics -<span class="lineNum"> 248 </span> : * depend on the underlying sequence type, but the expected rules -<span class="lineNum"> 249 </span> : * are: this relation is linear in the size of the sequences, the -<span class="lineNum"> 250 </span> : * elements must be comparable with @c <, and -<span class="lineNum"> 251 </span> : * std::lexicographical_compare() is usually used to make the -<span class="lineNum"> 252 </span> : * determination. -<span class="lineNum"> 253 </span> : */ -<span class="lineNum"> 254 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 255 </span> : inline bool -<span class="lineNum"> 256 </span> : operator<(const stack<_Tp, _Seq>& __x, const stack<_Tp, _Seq>& __y) -<span class="lineNum"> 257 </span> : { return __x.c < __y.c; } -<span class="lineNum"> 258 </span> : -<span class="lineNum"> 259 </span> : /// Based on operator== -<span class="lineNum"> 260 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 261 </span> : inline bool -<span class="lineNum"> 262 </span> : operator!=(const stack<_Tp, _Seq>& __x, const stack<_Tp, _Seq>& __y) -<span class="lineNum"> 263 </span> : { return !(__x == __y); } -<span class="lineNum"> 264 </span> : -<span class="lineNum"> 265 </span> : /// Based on operator< -<span class="lineNum"> 266 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 267 </span> : inline bool -<span class="lineNum"> 268 </span> : operator>(const stack<_Tp, _Seq>& __x, const stack<_Tp, _Seq>& __y) -<span class="lineNum"> 269 </span> : { return __y < __x; } -<span class="lineNum"> 270 </span> : -<span class="lineNum"> 271 </span> : /// Based on operator< -<span class="lineNum"> 272 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 273 </span> : inline bool -<span class="lineNum"> 274 </span> : operator<=(const stack<_Tp, _Seq>& __x, const stack<_Tp, _Seq>& __y) -<span class="lineNum"> 275 </span> : { return !(__y < __x); } -<span class="lineNum"> 276 </span> : -<span class="lineNum"> 277 </span> : /// Based on operator< -<span class="lineNum"> 278 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 279 </span> : inline bool -<span class="lineNum"> 280 </span> : operator>=(const stack<_Tp, _Seq>& __x, const stack<_Tp, _Seq>& __y) -<span class="lineNum"> 281 </span> : { return !(__x < __y); } -<span class="lineNum"> 282 </span> : -<span class="lineNum"> 283 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 284 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 285 </span> : inline void -<span class="lineNum"> 286 </span> : swap(stack<_Tp, _Seq>& __x, stack<_Tp, _Seq>& __y) -<span class="lineNum"> 287 </span> : { __x.swap(__y); } -<span class="lineNum"> 288 </span> : -<span class="lineNum"> 289 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 290 </span> : inline void -<span class="lineNum"> 291 </span> : swap(stack<_Tp, _Seq>&& __x, stack<_Tp, _Seq>& __y) -<span class="lineNum"> 292 </span> : { __x.swap(__y); } -<span class="lineNum"> 293 </span> : -<span class="lineNum"> 294 </span> : template<typename _Tp, typename _Seq> -<span class="lineNum"> 295 </span> : inline void -<span class="lineNum"> 296 </span> : swap(stack<_Tp, _Seq>& __x, stack<_Tp, _Seq>&& __y) -<span class="lineNum"> 297 </span> : { __x.swap(__y); } -<span class="lineNum"> 298 </span> : #endif -<span class="lineNum"> 299 </span> : -<span class="lineNum"> 300 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 301 </span> : -<span class="lineNum"> 302 </span> : #endif /* _STL_STACK_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_tree.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_tree.h.gcov.html deleted file mode 100644 index 9827a27..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_tree.h.gcov.html +++ /dev/null @@ -1,1533 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_tree.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_tree.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">295</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">94.2 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">278</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // RB tree implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 34 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1994 -<span class="lineNum"> 46 </span> : * Hewlett-Packard Company -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : * -<span class="lineNum"> 56 </span> : * -<span class="lineNum"> 57 </span> : */ -<span class="lineNum"> 58 </span> : -<span class="lineNum"> 59 </span> : /** @file stl_tree.h -<span class="lineNum"> 60 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 61 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 62 </span> : */ -<span class="lineNum"> 63 </span> : -<span class="lineNum"> 64 </span> : #ifndef _STL_TREE_H -<span class="lineNum"> 65 </span> : #define _STL_TREE_H 1 -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : #include <bits/stl_algobase.h> -<span class="lineNum"> 68 </span> : #include <bits/allocator.h> -<span class="lineNum"> 69 </span> : #include <bits/stl_function.h> -<span class="lineNum"> 70 </span> : #include <bits/cpp_type_traits.h> -<span class="lineNum"> 71 </span> : -<span class="lineNum"> 72 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 73 </span> : -<span class="lineNum"> 74 </span> : // Red-black tree class, designed for use in implementing STL -<span class="lineNum"> 75 </span> : // associative containers (set, multiset, map, and multimap). The -<span class="lineNum"> 76 </span> : // insertion and deletion algorithms are based on those in Cormen, -<span class="lineNum"> 77 </span> : // Leiserson, and Rivest, Introduction to Algorithms (MIT Press, -<span class="lineNum"> 78 </span> : // 1990), except that -<span class="lineNum"> 79 </span> : // -<span class="lineNum"> 80 </span> : // (1) the header cell is maintained with links not only to the root -<span class="lineNum"> 81 </span> : // but also to the leftmost node of the tree, to enable constant -<span class="lineNum"> 82 </span> : // time begin(), and to the rightmost node of the tree, to enable -<span class="lineNum"> 83 </span> : // linear time performance when used with the generic set algorithms -<span class="lineNum"> 84 </span> : // (set_union, etc.) -<span class="lineNum"> 85 </span> : // -<span class="lineNum"> 86 </span> : // (2) when a node being deleted has two children its successor node -<span class="lineNum"> 87 </span> : // is relinked into its place, rather than copied, so that the only -<span class="lineNum"> 88 </span> : // iterators invalidated are those referring to the deleted node. -<span class="lineNum"> 89 </span> : -<span class="lineNum"> 90 </span> : enum _Rb_tree_color { _S_red = false, _S_black = true }; -<span class="lineNum"> 91 </span> : -<span class="lineNum"> 92 </span> : struct _Rb_tree_node_base -<span class="lineNum"> 93 </span> : { -<span class="lineNum"> 94 </span> : typedef _Rb_tree_node_base* _Base_ptr; -<span class="lineNum"> 95 </span> : typedef const _Rb_tree_node_base* _Const_Base_ptr; -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : _Rb_tree_color _M_color; -<span class="lineNum"> 98 </span> : _Base_ptr _M_parent; -<span class="lineNum"> 99 </span> : _Base_ptr _M_left; -<span class="lineNum"> 100 </span> : _Base_ptr _M_right; -<span class="lineNum"> 101 </span> : -<span class="lineNum"> 102 </span> : static _Base_ptr -<span class="lineNum"> 103 </span><span class="lineCov"> 880633 : _S_minimum(_Base_ptr __x)</span> -<span class="lineNum"> 104 </span> : { -<span class="lineNum"> 105 </span><span class="lineCov"> 880633 : while (__x->_M_left != 0) __x = __x->_M_left;</span> -<span class="lineNum"> 106 </span><span class="lineCov"> 880633 : return __x;</span> -<span class="lineNum"> 107 </span> : } -<span class="lineNum"> 108 </span> : -<span class="lineNum"> 109 </span> : static _Const_Base_ptr -<span class="lineNum"> 110 </span> : _S_minimum(_Const_Base_ptr __x) -<span class="lineNum"> 111 </span> : { -<span class="lineNum"> 112 </span> : while (__x->_M_left != 0) __x = __x->_M_left; -<span class="lineNum"> 113 </span> : return __x; -<span class="lineNum"> 114 </span> : } -<span class="lineNum"> 115 </span> : -<span class="lineNum"> 116 </span> : static _Base_ptr -<span class="lineNum"> 117 </span><span class="lineCov"> 880633 : _S_maximum(_Base_ptr __x)</span> -<span class="lineNum"> 118 </span> : { -<span class="lineNum"> 119 </span><span class="lineCov"> 880633 : while (__x->_M_right != 0) __x = __x->_M_right;</span> -<span class="lineNum"> 120 </span><span class="lineCov"> 880633 : return __x;</span> -<span class="lineNum"> 121 </span> : } -<span class="lineNum"> 122 </span> : -<span class="lineNum"> 123 </span> : static _Const_Base_ptr -<span class="lineNum"> 124 </span> : _S_maximum(_Const_Base_ptr __x) -<span class="lineNum"> 125 </span> : { -<span class="lineNum"> 126 </span> : while (__x->_M_right != 0) __x = __x->_M_right; -<span class="lineNum"> 127 </span> : return __x; -<span class="lineNum"> 128 </span> : } -<span class="lineNum"> 129 </span> : }; -<span class="lineNum"> 130 </span> : -<span class="lineNum"> 131 </span> : template<typename _Val> -<span class="lineNum"> 132 </span> : struct _Rb_tree_node : public _Rb_tree_node_base -<span class="lineNum"> 133 </span> : { -<span class="lineNum"> 134 </span> : typedef _Rb_tree_node<_Val>* _Link_type; -<span class="lineNum"> 135 </span> : _Val _M_value_field; -<span class="lineNum"> 136 </span> : }; -<span class="lineNum"> 137 </span> : -<span class="lineNum"> 138 </span> : _Rb_tree_node_base* -<span class="lineNum"> 139 </span> : _Rb_tree_increment(_Rb_tree_node_base* __x); -<span class="lineNum"> 140 </span> : -<span class="lineNum"> 141 </span> : const _Rb_tree_node_base* -<span class="lineNum"> 142 </span> : _Rb_tree_increment(const _Rb_tree_node_base* __x); -<span class="lineNum"> 143 </span> : -<span class="lineNum"> 144 </span> : _Rb_tree_node_base* -<span class="lineNum"> 145 </span> : _Rb_tree_decrement(_Rb_tree_node_base* __x); -<span class="lineNum"> 146 </span> : -<span class="lineNum"> 147 </span> : const _Rb_tree_node_base* -<span class="lineNum"> 148 </span> : _Rb_tree_decrement(const _Rb_tree_node_base* __x); -<span class="lineNum"> 149 </span> : -<span class="lineNum"> 150 </span> : template<typename _Tp> -<span class="lineNum"> 151 </span> : struct _Rb_tree_iterator -<span class="lineNum"> 152 </span> : { -<span class="lineNum"> 153 </span> : typedef _Tp value_type; -<span class="lineNum"> 154 </span> : typedef _Tp& reference; -<span class="lineNum"> 155 </span> : typedef _Tp* pointer; -<span class="lineNum"> 156 </span> : -<span class="lineNum"> 157 </span> : typedef bidirectional_iterator_tag iterator_category; -<span class="lineNum"> 158 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 159 </span> : -<span class="lineNum"> 160 </span> : typedef _Rb_tree_iterator<_Tp> _Self; -<span class="lineNum"> 161 </span> : typedef _Rb_tree_node_base::_Base_ptr _Base_ptr; -<span class="lineNum"> 162 </span> : typedef _Rb_tree_node<_Tp>* _Link_type; -<span class="lineNum"> 163 </span> : -<span class="lineNum"> 164 </span> : _Rb_tree_iterator() -<span class="lineNum"> 165 </span> : : _M_node() { } -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : explicit -<span class="lineNum"> 168 </span><span class="lineCov"> 4550329 : _Rb_tree_iterator(_Link_type __x)</span> -<span class="lineNum"> 169 </span><span class="lineCov"> 4550329 : : _M_node(__x) { }</span> -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : reference -<span class="lineNum"> 172 </span><span class="lineCov"> 9593 : operator*() const</span> -<span class="lineNum"> 173 </span><span class="lineCov"> 9593 : { return static_cast<_Link_type>(_M_node)->_M_value_field; }</span> -<span class="lineNum"> 174 </span> : -<span class="lineNum"> 175 </span> : pointer -<span class="lineNum"> 176 </span><span class="lineCov"> 32985 : operator->() const</span> -<span class="lineNum"> 177 </span><span class="lineCov"> 32985 : { return &static_cast<_Link_type>(_M_node)->_M_value_field; }</span> -<span class="lineNum"> 178 </span> : -<span class="lineNum"> 179 </span> : _Self& -<span class="lineNum"> 180 </span> : operator++() -<span class="lineNum"> 181 </span> : { -<span class="lineNum"> 182 </span> : _M_node = _Rb_tree_increment(_M_node); -<span class="lineNum"> 183 </span> : return *this; -<span class="lineNum"> 184 </span> : } -<span class="lineNum"> 185 </span> : -<span class="lineNum"> 186 </span> : _Self -<span class="lineNum"> 187 </span><span class="lineCov"> 658 : operator++(int)</span> -<span class="lineNum"> 188 </span> : { -<span class="lineNum"> 189 </span><span class="lineCov"> 658 : _Self __tmp = *this;</span> -<span class="lineNum"> 190 </span><span class="lineCov"> 658 : _M_node = _Rb_tree_increment(_M_node);</span> -<span class="lineNum"> 191 </span> : return __tmp; -<span class="lineNum"> 192 </span> : } -<span class="lineNum"> 193 </span> : -<span class="lineNum"> 194 </span> : _Self& -<span class="lineNum"> 195 </span><span class="lineCov"> 83333 : operator--()</span> -<span class="lineNum"> 196 </span> : { -<span class="lineNum"> 197 </span><span class="lineCov"> 83333 : _M_node = _Rb_tree_decrement(_M_node);</span> -<span class="lineNum"> 198 </span><span class="lineCov"> 83333 : return *this;</span> -<span class="lineNum"> 199 </span> : } -<span class="lineNum"> 200 </span> : -<span class="lineNum"> 201 </span> : _Self -<span class="lineNum"> 202 </span> : operator--(int) -<span class="lineNum"> 203 </span> : { -<span class="lineNum"> 204 </span> : _Self __tmp = *this; -<span class="lineNum"> 205 </span> : _M_node = _Rb_tree_decrement(_M_node); -<span class="lineNum"> 206 </span> : return __tmp; -<span class="lineNum"> 207 </span> : } -<span class="lineNum"> 208 </span> : -<span class="lineNum"> 209 </span> : bool -<span class="lineNum"> 210 </span><span class="lineCov"> 638793 : operator==(const _Self& __x) const</span> -<span class="lineNum"> 211 </span><span class="lineCov"> 638793 : { return _M_node == __x._M_node; }</span> -<span class="lineNum"> 212 </span> : -<span class="lineNum"> 213 </span> : bool -<span class="lineNum"> 214 </span><span class="lineCov"> 749 : operator!=(const _Self& __x) const</span> -<span class="lineNum"> 215 </span><span class="lineCov"> 749 : { return _M_node != __x._M_node; }</span> -<span class="lineNum"> 216 </span> : -<span class="lineNum"> 217 </span> : _Base_ptr _M_node; -<span class="lineNum"> 218 </span> : }; -<span class="lineNum"> 219 </span> : -<span class="lineNum"> 220 </span> : template<typename _Tp> -<span class="lineNum"> 221 </span> : struct _Rb_tree_const_iterator -<span class="lineNum"> 222 </span> : { -<span class="lineNum"> 223 </span> : typedef _Tp value_type; -<span class="lineNum"> 224 </span> : typedef const _Tp& reference; -<span class="lineNum"> 225 </span> : typedef const _Tp* pointer; -<span class="lineNum"> 226 </span> : -<span class="lineNum"> 227 </span> : typedef _Rb_tree_iterator<_Tp> iterator; -<span class="lineNum"> 228 </span> : -<span class="lineNum"> 229 </span> : typedef bidirectional_iterator_tag iterator_category; -<span class="lineNum"> 230 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 231 </span> : -<span class="lineNum"> 232 </span> : typedef _Rb_tree_const_iterator<_Tp> _Self; -<span class="lineNum"> 233 </span> : typedef _Rb_tree_node_base::_Const_Base_ptr _Base_ptr; -<span class="lineNum"> 234 </span> : typedef const _Rb_tree_node<_Tp>* _Link_type; -<span class="lineNum"> 235 </span> : -<span class="lineNum"> 236 </span> : _Rb_tree_const_iterator() -<span class="lineNum"> 237 </span> : : _M_node() { } -<span class="lineNum"> 238 </span> : -<span class="lineNum"> 239 </span> : explicit -<span class="lineNum"> 240 </span><span class="lineCov"> 2494703 : _Rb_tree_const_iterator(_Link_type __x)</span> -<span class="lineNum"> 241 </span><span class="lineCov"> 2494703 : : _M_node(__x) { }</span> -<span class="lineNum"> 242 </span> : -<span class="lineNum"> 243 </span><span class="lineCov"> 1643427 : _Rb_tree_const_iterator(const iterator& __it)</span> -<span class="lineNum"> 244 </span><span class="lineCov"> 1643427 : : _M_node(__it._M_node) { }</span> -<span class="lineNum"> 245 </span> : -<span class="lineNum"> 246 </span> : reference -<span class="lineNum"> 247 </span><span class="lineCov"> 1553025 : operator*() const</span> -<span class="lineNum"> 248 </span><span class="lineCov"> 1553025 : { return static_cast<_Link_type>(_M_node)->_M_value_field; }</span> -<span class="lineNum"> 249 </span> : -<span class="lineNum"> 250 </span> : pointer -<span class="lineNum"> 251 </span><span class="lineCov"> 817027 : operator->() const</span> -<span class="lineNum"> 252 </span><span class="lineCov"> 817027 : { return &static_cast<_Link_type>(_M_node)->_M_value_field; }</span> -<span class="lineNum"> 253 </span> : -<span class="lineNum"> 254 </span> : _Self& -<span class="lineNum"> 255 </span><span class="lineCov"> 1717591 : operator++()</span> -<span class="lineNum"> 256 </span> : { -<span class="lineNum"> 257 </span><span class="lineCov"> 1717591 : _M_node = _Rb_tree_increment(_M_node);</span> -<span class="lineNum"> 258 </span><span class="lineCov"> 1717591 : return *this;</span> -<span class="lineNum"> 259 </span> : } -<span class="lineNum"> 260 </span> : -<span class="lineNum"> 261 </span> : _Self -<span class="lineNum"> 262 </span><span class="lineCov"> 9048 : operator++(int)</span> -<span class="lineNum"> 263 </span> : { -<span class="lineNum"> 264 </span><span class="lineCov"> 9048 : _Self __tmp = *this;</span> -<span class="lineNum"> 265 </span><span class="lineCov"> 9048 : _M_node = _Rb_tree_increment(_M_node);</span> -<span class="lineNum"> 266 </span> : return __tmp; -<span class="lineNum"> 267 </span> : } -<span class="lineNum"> 268 </span> : -<span class="lineNum"> 269 </span> : _Self& -<span class="lineNum"> 270 </span><span class="lineCov"> 2000 : operator--()</span> -<span class="lineNum"> 271 </span> : { -<span class="lineNum"> 272 </span><span class="lineCov"> 2000 : _M_node = _Rb_tree_decrement(_M_node);</span> -<span class="lineNum"> 273 </span><span class="lineCov"> 2000 : return *this;</span> -<span class="lineNum"> 274 </span> : } -<span class="lineNum"> 275 </span> : -<span class="lineNum"> 276 </span> : _Self -<span class="lineNum"> 277 </span> : operator--(int) -<span class="lineNum"> 278 </span> : { -<span class="lineNum"> 279 </span> : _Self __tmp = *this; -<span class="lineNum"> 280 </span> : _M_node = _Rb_tree_decrement(_M_node); -<span class="lineNum"> 281 </span> : return __tmp; -<span class="lineNum"> 282 </span> : } -<span class="lineNum"> 283 </span> : -<span class="lineNum"> 284 </span> : bool -<span class="lineNum"> 285 </span><span class="lineCov"> 177758 : operator==(const _Self& __x) const</span> -<span class="lineNum"> 286 </span><span class="lineCov"> 177758 : { return _M_node == __x._M_node; }</span> -<span class="lineNum"> 287 </span> : -<span class="lineNum"> 288 </span> : bool -<span class="lineNum"> 289 </span><span class="lineCov"> 2095612 : operator!=(const _Self& __x) const</span> -<span class="lineNum"> 290 </span><span class="lineCov"> 2095612 : { return _M_node != __x._M_node; }</span> -<span class="lineNum"> 291 </span> : -<span class="lineNum"> 292 </span> : _Base_ptr _M_node; -<span class="lineNum"> 293 </span> : }; -<span class="lineNum"> 294 </span> : -<span class="lineNum"> 295 </span> : template<typename _Val> -<span class="lineNum"> 296 </span> : inline bool -<span class="lineNum"> 297 </span> : operator==(const _Rb_tree_iterator<_Val>& __x, -<span class="lineNum"> 298 </span> : const _Rb_tree_const_iterator<_Val>& __y) -<span class="lineNum"> 299 </span> : { return __x._M_node == __y._M_node; } -<span class="lineNum"> 300 </span> : -<span class="lineNum"> 301 </span> : template<typename _Val> -<span class="lineNum"> 302 </span> : inline bool -<span class="lineNum"> 303 </span> : operator!=(const _Rb_tree_iterator<_Val>& __x, -<span class="lineNum"> 304 </span> : const _Rb_tree_const_iterator<_Val>& __y) -<span class="lineNum"> 305 </span> : { return __x._M_node != __y._M_node; } -<span class="lineNum"> 306 </span> : -<span class="lineNum"> 307 </span> : void -<span class="lineNum"> 308 </span> : _Rb_tree_insert_and_rebalance(const bool __insert_left, -<span class="lineNum"> 309 </span> : _Rb_tree_node_base* __x, -<span class="lineNum"> 310 </span> : _Rb_tree_node_base* __p, -<span class="lineNum"> 311 </span> : _Rb_tree_node_base& __header); -<span class="lineNum"> 312 </span> : -<span class="lineNum"> 313 </span> : _Rb_tree_node_base* -<span class="lineNum"> 314 </span> : _Rb_tree_rebalance_for_erase(_Rb_tree_node_base* const __z, -<span class="lineNum"> 315 </span> : _Rb_tree_node_base& __header); -<span class="lineNum"> 316 </span> : -<span class="lineNum"> 317 </span> : -<span class="lineNum"> 318 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 319 </span> : typename _Compare, typename _Alloc = allocator<_Val> > -<span class="lineNum"> 320 </span> : class _Rb_tree -<span class="lineNum"> 321 </span> : { -<span class="lineNum"> 322 </span> : typedef typename _Alloc::template rebind<_Rb_tree_node<_Val> >::other -<span class="lineNum"> 323 </span> : _Node_allocator; -<span class="lineNum"> 324 </span> : -<span class="lineNum"> 325 </span> : protected: -<span class="lineNum"> 326 </span> : typedef _Rb_tree_node_base* _Base_ptr; -<span class="lineNum"> 327 </span> : typedef const _Rb_tree_node_base* _Const_Base_ptr; -<span class="lineNum"> 328 </span> : -<span class="lineNum"> 329 </span> : public: -<span class="lineNum"> 330 </span> : typedef _Key key_type; -<span class="lineNum"> 331 </span> : typedef _Val value_type; -<span class="lineNum"> 332 </span> : typedef value_type* pointer; -<span class="lineNum"> 333 </span> : typedef const value_type* const_pointer; -<span class="lineNum"> 334 </span> : typedef value_type& reference; -<span class="lineNum"> 335 </span> : typedef const value_type& const_reference; -<span class="lineNum"> 336 </span> : typedef _Rb_tree_node<_Val>* _Link_type; -<span class="lineNum"> 337 </span> : typedef const _Rb_tree_node<_Val>* _Const_Link_type; -<span class="lineNum"> 338 </span> : typedef size_t size_type; -<span class="lineNum"> 339 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 340 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 341 </span> : -<span class="lineNum"> 342 </span> : _Node_allocator& -<span class="lineNum"> 343 </span> : _M_get_Node_allocator() -<span class="lineNum"> 344 </span> : { return *static_cast<_Node_allocator*>(&this->_M_impl); } -<span class="lineNum"> 345 </span> : -<span class="lineNum"> 346 </span> : const _Node_allocator& -<span class="lineNum"> 347 </span><span class="lineCov"> 12223942 : _M_get_Node_allocator() const</span> -<span class="lineNum"> 348 </span><span class="lineCov"> 12223942 : { return *static_cast<const _Node_allocator*>(&this->_M_impl); }</span> -<span class="lineNum"> 349 </span> : -<span class="lineNum"> 350 </span> : allocator_type -<span class="lineNum"> 351 </span><span class="lineCov"> 11289346 : get_allocator() const</span> -<span class="lineNum"> 352 </span><span class="lineCov"> 11289346 : { return allocator_type(_M_get_Node_allocator()); }</span> -<span class="lineNum"> 353 </span> : -<span class="lineNum"> 354 </span> : protected: -<span class="lineNum"> 355 </span> : _Link_type -<span class="lineNum"> 356 </span><span class="lineCov"> 5644688 : _M_get_node()</span> -<span class="lineNum"> 357 </span><span class="lineCov"> 5644688 : { return _M_impl._Node_allocator::allocate(1); }</span> -<span class="lineNum"> 358 </span> : -<span class="lineNum"> 359 </span> : void -<span class="lineNum"> 360 </span><span class="lineCov"> 5644658 : _M_put_node(_Link_type __p)</span> -<span class="lineNum"> 361 </span><span class="lineCov"> 5644658 : { _M_impl._Node_allocator::deallocate(__p, 1); }</span> -<span class="lineNum"> 362 </span> : -<span class="lineNum"> 363 </span> : _Link_type -<span class="lineNum"> 364 </span><span class="lineCov"> 5644688 : _M_create_node(const value_type& __x)</span> -<span class="lineNum"> 365 </span> : { -<span class="lineNum"> 366 </span><span class="lineCov"> 5644688 : _Link_type __tmp = _M_get_node();</span> -<span class="lineNum"> 367 </span> : try -<span class="lineNum"> 368 </span><span class="lineCov"> 5644688 : { get_allocator().construct(&__tmp->_M_value_field, __x); }</span> -<span class="lineNum"> 369 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 370 </span> : { -<span class="lineNum"> 371 </span><span class="lineNoCov"> 0 : _M_put_node(__tmp);</span> -<span class="lineNum"> 372 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 373 </span> : } -<span class="lineNum"> 374 </span><span class="lineCov"> 5644688 : return __tmp;</span> -<span class="lineNum"> 375 </span> : } -<span class="lineNum"> 376 </span> : -<span class="lineNum"> 377 </span> : _Link_type -<span class="lineNum"> 378 </span><span class="lineCov"> 3573982 : _M_clone_node(_Const_Link_type __x)</span> -<span class="lineNum"> 379 </span> : { -<span class="lineNum"> 380 </span><span class="lineCov"> 3573982 : _Link_type __tmp = _M_create_node(__x->_M_value_field);</span> -<span class="lineNum"> 381 </span><span class="lineCov"> 3573982 : __tmp->_M_color = __x->_M_color;</span> -<span class="lineNum"> 382 </span><span class="lineCov"> 3573982 : __tmp->_M_left = 0;</span> -<span class="lineNum"> 383 </span><span class="lineCov"> 3573982 : __tmp->_M_right = 0;</span> -<span class="lineNum"> 384 </span><span class="lineCov"> 3573982 : return __tmp;</span> -<span class="lineNum"> 385 </span> : } -<span class="lineNum"> 386 </span> : -<span class="lineNum"> 387 </span> : void -<span class="lineNum"> 388 </span><span class="lineCov"> 5644658 : _M_destroy_node(_Link_type __p)</span> -<span class="lineNum"> 389 </span> : { -<span class="lineNum"> 390 </span><span class="lineCov"> 5644658 : get_allocator().destroy(&__p->_M_value_field);</span> -<span class="lineNum"> 391 </span><span class="lineCov"> 5644658 : _M_put_node(__p);</span> -<span class="lineNum"> 392 </span><span class="lineCov"> 5644658 : }</span> -<span class="lineNum"> 393 </span> : -<span class="lineNum"> 394 </span> : protected: -<span class="lineNum"> 395 </span> : template<typename _Key_compare, -<span class="lineNum"> 396 </span> : bool _Is_pod_comparator = __is_pod(_Key_compare)> -<span class="lineNum"> 397 </span> : struct _Rb_tree_impl : public _Node_allocator -<span class="lineNum"> 398 </span><span class="lineCov"> 1320929 : {</span> -<span class="lineNum"> 399 </span> : _Key_compare _M_key_compare; -<span class="lineNum"> 400 </span> : _Rb_tree_node_base _M_header; -<span class="lineNum"> 401 </span> : size_type _M_node_count; // Keeps track of size of tree. -<span class="lineNum"> 402 </span> : -<span class="lineNum"> 403 </span><span class="lineCov"> 280599 : _Rb_tree_impl()</span> -<span class="lineNum"> 404 </span> : : _Node_allocator(), _M_key_compare(), _M_header(), -<span class="lineNum"> 405 </span><span class="lineCov"> 280599 : _M_node_count(0)</span> -<span class="lineNum"> 406 </span><span class="lineCov"> 280599 : { _M_initialize(); }</span> -<span class="lineNum"> 407 </span> : -<span class="lineNum"> 408 </span><span class="lineCov"> 934596 : _Rb_tree_impl(const _Key_compare& __comp, const _Node_allocator& __a)</span> -<span class="lineNum"> 409 </span> : : _Node_allocator(__a), _M_key_compare(__comp), _M_header(), -<span class="lineNum"> 410 </span><span class="lineCov"> 934596 : _M_node_count(0)</span> -<span class="lineNum"> 411 </span><span class="lineCov"> 934596 : { _M_initialize(); }</span> -<span class="lineNum"> 412 </span> : -<span class="lineNum"> 413 </span> : private: -<span class="lineNum"> 414 </span> : void -<span class="lineNum"> 415 </span><span class="lineCov"> 1215195 : _M_initialize()</span> -<span class="lineNum"> 416 </span> : { -<span class="lineNum"> 417 </span><span class="lineCov"> 1215195 : this->_M_header._M_color = _S_red;</span> -<span class="lineNum"> 418 </span><span class="lineCov"> 1215195 : this->_M_header._M_parent = 0;</span> -<span class="lineNum"> 419 </span><span class="lineCov"> 1215195 : this->_M_header._M_left = &this->_M_header;</span> -<span class="lineNum"> 420 </span><span class="lineCov"> 1215195 : this->_M_header._M_right = &this->_M_header;</span> -<span class="lineNum"> 421 </span><span class="lineCov"> 1215195 : } </span> -<span class="lineNum"> 422 </span> : }; -<span class="lineNum"> 423 </span> : -<span class="lineNum"> 424 </span> : _Rb_tree_impl<_Compare> _M_impl; -<span class="lineNum"> 425 </span> : -<span class="lineNum"> 426 </span> : protected: -<span class="lineNum"> 427 </span> : _Base_ptr& -<span class="lineNum"> 428 </span><span class="lineCov"> 2729891 : _M_root()</span> -<span class="lineNum"> 429 </span><span class="lineCov"> 2729891 : { return this->_M_impl._M_header._M_parent; }</span> -<span class="lineNum"> 430 </span> : -<span class="lineNum"> 431 </span> : _Const_Base_ptr -<span class="lineNum"> 432 </span><span class="lineCov"> 934693 : _M_root() const</span> -<span class="lineNum"> 433 </span><span class="lineCov"> 934693 : { return this->_M_impl._M_header._M_parent; }</span> -<span class="lineNum"> 434 </span> : -<span class="lineNum"> 435 </span> : _Base_ptr& -<span class="lineNum"> 436 </span><span class="lineCov"> 970809 : _M_leftmost()</span> -<span class="lineNum"> 437 </span><span class="lineCov"> 970809 : { return this->_M_impl._M_header._M_left; }</span> -<span class="lineNum"> 438 </span> : -<span class="lineNum"> 439 </span> : _Const_Base_ptr -<span class="lineNum"> 440 </span> : _M_leftmost() const -<span class="lineNum"> 441 </span> : { return this->_M_impl._M_header._M_left; } -<span class="lineNum"> 442 </span> : -<span class="lineNum"> 443 </span> : _Base_ptr& -<span class="lineNum"> 444 </span><span class="lineCov"> 2012568 : _M_rightmost()</span> -<span class="lineNum"> 445 </span><span class="lineCov"> 2012568 : { return this->_M_impl._M_header._M_right; }</span> -<span class="lineNum"> 446 </span> : -<span class="lineNum"> 447 </span> : _Const_Base_ptr -<span class="lineNum"> 448 </span> : _M_rightmost() const -<span class="lineNum"> 449 </span> : { return this->_M_impl._M_header._M_right; } -<span class="lineNum"> 450 </span> : -<span class="lineNum"> 451 </span> : _Link_type -<span class="lineNum"> 452 </span><span class="lineCov"> 3119123 : _M_begin()</span> -<span class="lineNum"> 453 </span><span class="lineCov"> 3119123 : { return static_cast<_Link_type>(this->_M_impl._M_header._M_parent); }</span> -<span class="lineNum"> 454 </span> : -<span class="lineNum"> 455 </span> : _Const_Link_type -<span class="lineNum"> 456 </span><span class="lineCov"> 884565 : _M_begin() const</span> -<span class="lineNum"> 457 </span> : { -<span class="lineNum"> 458 </span> : return static_cast<_Const_Link_type> -<span class="lineNum"> 459 </span><span class="lineCov"> 884565 : (this->_M_impl._M_header._M_parent);</span> -<span class="lineNum"> 460 </span> : } -<span class="lineNum"> 461 </span> : -<span class="lineNum"> 462 </span> : _Link_type -<span class="lineNum"> 463 </span><span class="lineCov"> 5489610 : _M_end()</span> -<span class="lineNum"> 464 </span><span class="lineCov"> 5489610 : { return static_cast<_Link_type>(&this->_M_impl._M_header); }</span> -<span class="lineNum"> 465 </span> : -<span class="lineNum"> 466 </span> : _Const_Link_type -<span class="lineNum"> 467 </span><span class="lineCov"> 3932 : _M_end() const</span> -<span class="lineNum"> 468 </span><span class="lineCov"> 3932 : { return static_cast<_Const_Link_type>(&this->_M_impl._M_header); }</span> -<span class="lineNum"> 469 </span> : -<span class="lineNum"> 470 </span> : static const_reference -<span class="lineNum"> 471 </span><span class="lineCov"> 7342455 : _S_value(_Const_Link_type __x)</span> -<span class="lineNum"> 472 </span><span class="lineCov"> 7342455 : { return __x->_M_value_field; }</span> -<span class="lineNum"> 473 </span> : -<span class="lineNum"> 474 </span> : static const _Key& -<span class="lineNum"> 475 </span><span class="lineCov"> 7342455 : _S_key(_Const_Link_type __x)</span> -<span class="lineNum"> 476 </span><span class="lineCov"> 7342455 : { return _KeyOfValue()(_S_value(__x)); }</span> -<span class="lineNum"> 477 </span> : -<span class="lineNum"> 478 </span> : static _Link_type -<span class="lineNum"> 479 </span><span class="lineCov"> 6468290 : _S_left(_Base_ptr __x)</span> -<span class="lineNum"> 480 </span><span class="lineCov"> 6468290 : { return static_cast<_Link_type>(__x->_M_left); }</span> -<span class="lineNum"> 481 </span> : -<span class="lineNum"> 482 </span> : static _Const_Link_type -<span class="lineNum"> 483 </span><span class="lineCov"> 3579867 : _S_left(_Const_Base_ptr __x)</span> -<span class="lineNum"> 484 </span><span class="lineCov"> 3579867 : { return static_cast<_Const_Link_type>(__x->_M_left); }</span> -<span class="lineNum"> 485 </span> : -<span class="lineNum"> 486 </span> : static _Link_type -<span class="lineNum"> 487 </span><span class="lineCov"> 12155056 : _S_right(_Base_ptr __x)</span> -<span class="lineNum"> 488 </span><span class="lineCov"> 12155056 : { return static_cast<_Link_type>(__x->_M_right); }</span> -<span class="lineNum"> 489 </span> : -<span class="lineNum"> 490 </span> : static _Const_Link_type -<span class="lineNum"> 491 </span><span class="lineCov"> 1503831 : _S_right(_Const_Base_ptr __x)</span> -<span class="lineNum"> 492 </span><span class="lineCov"> 1503831 : { return static_cast<_Const_Link_type>(__x->_M_right); }</span> -<span class="lineNum"> 493 </span> : -<span class="lineNum"> 494 </span> : static const_reference -<span class="lineNum"> 495 </span><span class="lineCov"> 3381491 : _S_value(_Const_Base_ptr __x)</span> -<span class="lineNum"> 496 </span><span class="lineCov"> 3381491 : { return static_cast<_Const_Link_type>(__x)->_M_value_field; }</span> -<span class="lineNum"> 497 </span> : -<span class="lineNum"> 498 </span> : static const _Key& -<span class="lineNum"> 499 </span><span class="lineCov"> 3381491 : _S_key(_Const_Base_ptr __x)</span> -<span class="lineNum"> 500 </span><span class="lineCov"> 3381491 : { return _KeyOfValue()(_S_value(__x)); }</span> -<span class="lineNum"> 501 </span> : -<span class="lineNum"> 502 </span> : static _Base_ptr -<span class="lineNum"> 503 </span><span class="lineCov"> 880633 : _S_minimum(_Base_ptr __x)</span> -<span class="lineNum"> 504 </span><span class="lineCov"> 880633 : { return _Rb_tree_node_base::_S_minimum(__x); }</span> -<span class="lineNum"> 505 </span> : -<span class="lineNum"> 506 </span> : static _Const_Base_ptr -<span class="lineNum"> 507 </span> : _S_minimum(_Const_Base_ptr __x) -<span class="lineNum"> 508 </span> : { return _Rb_tree_node_base::_S_minimum(__x); } -<span class="lineNum"> 509 </span> : -<span class="lineNum"> 510 </span> : static _Base_ptr -<span class="lineNum"> 511 </span><span class="lineCov"> 880633 : _S_maximum(_Base_ptr __x)</span> -<span class="lineNum"> 512 </span><span class="lineCov"> 880633 : { return _Rb_tree_node_base::_S_maximum(__x); }</span> -<span class="lineNum"> 513 </span> : -<span class="lineNum"> 514 </span> : static _Const_Base_ptr -<span class="lineNum"> 515 </span> : _S_maximum(_Const_Base_ptr __x) -<span class="lineNum"> 516 </span> : { return _Rb_tree_node_base::_S_maximum(__x); } -<span class="lineNum"> 517 </span> : -<span class="lineNum"> 518 </span> : public: -<span class="lineNum"> 519 </span> : typedef _Rb_tree_iterator<value_type> iterator; -<span class="lineNum"> 520 </span> : typedef _Rb_tree_const_iterator<value_type> const_iterator; -<span class="lineNum"> 521 </span> : -<span class="lineNum"> 522 </span> : typedef std::reverse_iterator<iterator> reverse_iterator; -<span class="lineNum"> 523 </span> : typedef std::reverse_iterator<const_iterator> const_reverse_iterator; -<span class="lineNum"> 524 </span> : -<span class="lineNum"> 525 </span> : private: -<span class="lineNum"> 526 </span> : iterator -<span class="lineNum"> 527 </span> : _M_insert_(_Const_Base_ptr __x, _Const_Base_ptr __y, -<span class="lineNum"> 528 </span> : const value_type& __v); -<span class="lineNum"> 529 </span> : -<span class="lineNum"> 530 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 531 </span> : // 233. Insertion hints in associative containers. -<span class="lineNum"> 532 </span> : iterator -<span class="lineNum"> 533 </span> : _M_insert_lower(_Base_ptr __x, _Base_ptr __y, const value_type& __v); -<span class="lineNum"> 534 </span> : -<span class="lineNum"> 535 </span> : iterator -<span class="lineNum"> 536 </span> : _M_insert_equal_lower(const value_type& __x); -<span class="lineNum"> 537 </span> : -<span class="lineNum"> 538 </span> : _Link_type -<span class="lineNum"> 539 </span> : _M_copy(_Const_Link_type __x, _Link_type __p); -<span class="lineNum"> 540 </span> : -<span class="lineNum"> 541 </span> : void -<span class="lineNum"> 542 </span> : _M_erase(_Link_type __x); -<span class="lineNum"> 543 </span> : -<span class="lineNum"> 544 </span> : iterator -<span class="lineNum"> 545 </span> : _M_lower_bound(_Link_type __x, _Link_type __y, -<span class="lineNum"> 546 </span> : const _Key& __k); -<span class="lineNum"> 547 </span> : -<span class="lineNum"> 548 </span> : const_iterator -<span class="lineNum"> 549 </span> : _M_lower_bound(_Const_Link_type __x, _Const_Link_type __y, -<span class="lineNum"> 550 </span> : const _Key& __k) const; -<span class="lineNum"> 551 </span> : -<span class="lineNum"> 552 </span> : iterator -<span class="lineNum"> 553 </span> : _M_upper_bound(_Link_type __x, _Link_type __y, -<span class="lineNum"> 554 </span> : const _Key& __k); -<span class="lineNum"> 555 </span> : -<span class="lineNum"> 556 </span> : const_iterator -<span class="lineNum"> 557 </span> : _M_upper_bound(_Const_Link_type __x, _Const_Link_type __y, -<span class="lineNum"> 558 </span> : const _Key& __k) const; -<span class="lineNum"> 559 </span> : -<span class="lineNum"> 560 </span> : public: -<span class="lineNum"> 561 </span> : // allocation/deallocation -<span class="lineNum"> 562 </span><span class="lineCov"> 280599 : _Rb_tree() { }</span> -<span class="lineNum"> 563 </span> : -<span class="lineNum"> 564 </span> : _Rb_tree(const _Compare& __comp, -<span class="lineNum"> 565 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 566 </span> : : _M_impl(__comp, __a) { } -<span class="lineNum"> 567 </span> : -<span class="lineNum"> 568 </span><span class="lineCov"> 934596 : _Rb_tree(const _Rb_tree& __x)</span> -<span class="lineNum"> 569 </span><span class="lineCov"> 934596 : : _M_impl(__x._M_impl._M_key_compare, __x._M_get_Node_allocator())</span> -<span class="lineNum"> 570 </span> : { -<span class="lineNum"> 571 </span><span class="lineCov"> 934596 : if (__x._M_root() != 0)</span> -<span class="lineNum"> 572 </span> : { -<span class="lineNum"> 573 </span><span class="lineCov"> 880580 : _M_root() = _M_copy(__x._M_begin(), _M_end());</span> -<span class="lineNum"> 574 </span><span class="lineCov"> 880580 : _M_leftmost() = _S_minimum(_M_root());</span> -<span class="lineNum"> 575 </span><span class="lineCov"> 880580 : _M_rightmost() = _S_maximum(_M_root());</span> -<span class="lineNum"> 576 </span><span class="lineCov"> 880580 : _M_impl._M_node_count = __x._M_impl._M_node_count;</span> -<span class="lineNum"> 577 </span> : } -<span class="lineNum"> 578 </span><span class="lineCov"> 934596 : }</span> -<span class="lineNum"> 579 </span> : -<span class="lineNum"> 580 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 581 </span> : _Rb_tree(_Rb_tree&& __x); -<span class="lineNum"> 582 </span> : #endif -<span class="lineNum"> 583 </span> : -<span class="lineNum"> 584 </span><span class="lineCov"> 1320929 : ~_Rb_tree()</span> -<span class="lineNum"> 585 </span><span class="lineCov"> 1320929 : { _M_erase(_M_begin()); }</span> -<span class="lineNum"> 586 </span> : -<span class="lineNum"> 587 </span> : _Rb_tree& -<span class="lineNum"> 588 </span> : operator=(const _Rb_tree& __x); -<span class="lineNum"> 589 </span> : -<span class="lineNum"> 590 </span> : // Accessors. -<span class="lineNum"> 591 </span> : _Compare -<span class="lineNum"> 592 </span><span class="lineCov"> 3296 : key_comp() const</span> -<span class="lineNum"> 593 </span><span class="lineCov"> 3296 : { return _M_impl._M_key_compare; }</span> -<span class="lineNum"> 594 </span> : -<span class="lineNum"> 595 </span> : iterator -<span class="lineNum"> 596 </span><span class="lineCov"> 538878 : begin()</span> -<span class="lineNum"> 597 </span> : { -<span class="lineNum"> 598 </span> : return iterator(static_cast<_Link_type> -<span class="lineNum"> 599 </span><span class="lineCov"> 538878 : (this->_M_impl._M_header._M_left));</span> -<span class="lineNum"> 600 </span> : } -<span class="lineNum"> 601 </span> : -<span class="lineNum"> 602 </span> : const_iterator -<span class="lineNum"> 603 </span><span class="lineCov"> 468185 : begin() const</span> -<span class="lineNum"> 604 </span> : { -<span class="lineNum"> 605 </span> : return const_iterator(static_cast<_Const_Link_type> -<span class="lineNum"> 606 </span><span class="lineCov"> 468185 : (this->_M_impl._M_header._M_left));</span> -<span class="lineNum"> 607 </span> : } -<span class="lineNum"> 608 </span> : -<span class="lineNum"> 609 </span> : iterator -<span class="lineNum"> 610 </span><span class="lineCov"> 230534 : end()</span> -<span class="lineNum"> 611 </span><span class="lineCov"> 230534 : { return iterator(static_cast<_Link_type>(&this->_M_impl._M_header)); }</span> -<span class="lineNum"> 612 </span> : -<span class="lineNum"> 613 </span> : const_iterator -<span class="lineNum"> 614 </span><span class="lineCov"> 2022586 : end() const</span> -<span class="lineNum"> 615 </span> : { -<span class="lineNum"> 616 </span> : return const_iterator(static_cast<_Const_Link_type> -<span class="lineNum"> 617 </span><span class="lineCov"> 2022586 : (&this->_M_impl._M_header));</span> -<span class="lineNum"> 618 </span> : } -<span class="lineNum"> 619 </span> : -<span class="lineNum"> 620 </span> : reverse_iterator -<span class="lineNum"> 621 </span> : rbegin() -<span class="lineNum"> 622 </span> : { return reverse_iterator(end()); } -<span class="lineNum"> 623 </span> : -<span class="lineNum"> 624 </span> : const_reverse_iterator -<span class="lineNum"> 625 </span><span class="lineCov"> 32 : rbegin() const</span> -<span class="lineNum"> 626 </span><span class="lineCov"> 32 : { return const_reverse_iterator(end()); }</span> -<span class="lineNum"> 627 </span> : -<span class="lineNum"> 628 </span> : reverse_iterator -<span class="lineNum"> 629 </span> : rend() -<span class="lineNum"> 630 </span> : { return reverse_iterator(begin()); } -<span class="lineNum"> 631 </span> : -<span class="lineNum"> 632 </span> : const_reverse_iterator -<span class="lineNum"> 633 </span> : rend() const -<span class="lineNum"> 634 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 635 </span> : -<span class="lineNum"> 636 </span> : bool -<span class="lineNum"> 637 </span><span class="lineCov"> 342325 : empty() const</span> -<span class="lineNum"> 638 </span><span class="lineCov"> 342325 : { return _M_impl._M_node_count == 0; }</span> -<span class="lineNum"> 639 </span> : -<span class="lineNum"> 640 </span> : size_type -<span class="lineNum"> 641 </span><span class="lineCov"> 734435 : size() const</span> -<span class="lineNum"> 642 </span><span class="lineCov"> 734435 : { return _M_impl._M_node_count; }</span> -<span class="lineNum"> 643 </span> : -<span class="lineNum"> 644 </span> : size_type -<span class="lineNum"> 645 </span> : max_size() const -<span class="lineNum"> 646 </span> : { return get_allocator().max_size(); } -<span class="lineNum"> 647 </span> : -<span class="lineNum"> 648 </span> : void -<span class="lineNum"> 649 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 650 </span> : swap(_Rb_tree&& __t); -<span class="lineNum"> 651 </span> : #else -<span class="lineNum"> 652 </span> : swap(_Rb_tree& __t); -<span class="lineNum"> 653 </span> : #endif -<span class="lineNum"> 654 </span> : -<span class="lineNum"> 655 </span> : // Insert/erase. -<span class="lineNum"> 656 </span> : pair<iterator, bool> -<span class="lineNum"> 657 </span> : _M_insert_unique(const value_type& __x); -<span class="lineNum"> 658 </span> : -<span class="lineNum"> 659 </span> : iterator -<span class="lineNum"> 660 </span> : _M_insert_equal(const value_type& __x); -<span class="lineNum"> 661 </span> : -<span class="lineNum"> 662 </span> : iterator -<span class="lineNum"> 663 </span> : _M_insert_unique_(const_iterator __position, const value_type& __x); -<span class="lineNum"> 664 </span> : -<span class="lineNum"> 665 </span> : iterator -<span class="lineNum"> 666 </span> : _M_insert_equal_(const_iterator __position, const value_type& __x); -<span class="lineNum"> 667 </span> : -<span class="lineNum"> 668 </span> : template<typename _InputIterator> -<span class="lineNum"> 669 </span> : void -<span class="lineNum"> 670 </span> : _M_insert_unique(_InputIterator __first, _InputIterator __last); -<span class="lineNum"> 671 </span> : -<span class="lineNum"> 672 </span> : template<typename _InputIterator> -<span class="lineNum"> 673 </span> : void -<span class="lineNum"> 674 </span> : _M_insert_equal(_InputIterator __first, _InputIterator __last); -<span class="lineNum"> 675 </span> : -<span class="lineNum"> 676 </span> : void -<span class="lineNum"> 677 </span> : erase(iterator __position); -<span class="lineNum"> 678 </span> : -<span class="lineNum"> 679 </span> : void -<span class="lineNum"> 680 </span> : erase(const_iterator __position); -<span class="lineNum"> 681 </span> : -<span class="lineNum"> 682 </span> : size_type -<span class="lineNum"> 683 </span> : erase(const key_type& __x); -<span class="lineNum"> 684 </span> : -<span class="lineNum"> 685 </span> : void -<span class="lineNum"> 686 </span> : erase(iterator __first, iterator __last); -<span class="lineNum"> 687 </span> : -<span class="lineNum"> 688 </span> : void -<span class="lineNum"> 689 </span> : erase(const_iterator __first, const_iterator __last); -<span class="lineNum"> 690 </span> : -<span class="lineNum"> 691 </span> : void -<span class="lineNum"> 692 </span> : erase(const key_type* __first, const key_type* __last); -<span class="lineNum"> 693 </span> : -<span class="lineNum"> 694 </span> : void -<span class="lineNum"> 695 </span><span class="lineCov"> 87992 : clear()</span> -<span class="lineNum"> 696 </span> : { -<span class="lineNum"> 697 </span><span class="lineCov"> 87992 : _M_erase(_M_begin());</span> -<span class="lineNum"> 698 </span><span class="lineCov"> 87992 : _M_leftmost() = _M_end();</span> -<span class="lineNum"> 699 </span><span class="lineCov"> 87992 : _M_root() = 0;</span> -<span class="lineNum"> 700 </span><span class="lineCov"> 87992 : _M_rightmost() = _M_end();</span> -<span class="lineNum"> 701 </span><span class="lineCov"> 87992 : _M_impl._M_node_count = 0;</span> -<span class="lineNum"> 702 </span><span class="lineCov"> 87992 : }</span> -<span class="lineNum"> 703 </span> : -<span class="lineNum"> 704 </span> : // Set operations. -<span class="lineNum"> 705 </span> : iterator -<span class="lineNum"> 706 </span> : find(const key_type& __k); -<span class="lineNum"> 707 </span> : -<span class="lineNum"> 708 </span> : const_iterator -<span class="lineNum"> 709 </span> : find(const key_type& __k) const; -<span class="lineNum"> 710 </span> : -<span class="lineNum"> 711 </span> : size_type -<span class="lineNum"> 712 </span> : count(const key_type& __k) const; -<span class="lineNum"> 713 </span> : -<span class="lineNum"> 714 </span> : iterator -<span class="lineNum"> 715 </span><span class="lineCov"> 6297 : lower_bound(const key_type& __k)</span> -<span class="lineNum"> 716 </span><span class="lineCov"> 6297 : { return _M_lower_bound(_M_begin(), _M_end(), __k); }</span> -<span class="lineNum"> 717 </span> : -<span class="lineNum"> 718 </span> : const_iterator -<span class="lineNum"> 719 </span> : lower_bound(const key_type& __k) const -<span class="lineNum"> 720 </span> : { return _M_lower_bound(_M_begin(), _M_end(), __k); } -<span class="lineNum"> 721 </span> : -<span class="lineNum"> 722 </span> : iterator -<span class="lineNum"> 723 </span> : upper_bound(const key_type& __k) -<span class="lineNum"> 724 </span> : { return _M_upper_bound(_M_begin(), _M_end(), __k); } -<span class="lineNum"> 725 </span> : -<span class="lineNum"> 726 </span> : const_iterator -<span class="lineNum"> 727 </span> : upper_bound(const key_type& __k) const -<span class="lineNum"> 728 </span> : { return _M_upper_bound(_M_begin(), _M_end(), __k); } -<span class="lineNum"> 729 </span> : -<span class="lineNum"> 730 </span> : pair<iterator, iterator> -<span class="lineNum"> 731 </span> : equal_range(const key_type& __k); -<span class="lineNum"> 732 </span> : -<span class="lineNum"> 733 </span> : pair<const_iterator, const_iterator> -<span class="lineNum"> 734 </span> : equal_range(const key_type& __k) const; -<span class="lineNum"> 735 </span> : -<span class="lineNum"> 736 </span> : // Debugging. -<span class="lineNum"> 737 </span> : bool -<span class="lineNum"> 738 </span> : __rb_verify() const; -<span class="lineNum"> 739 </span> : }; -<span class="lineNum"> 740 </span> : -<span class="lineNum"> 741 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 742 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 743 </span> : inline bool -<span class="lineNum"> 744 </span> : operator==(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 745 </span><span class="lineCov"> 4 : const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y)</span> -<span class="lineNum"> 746 </span> : { -<span class="lineNum"> 747 </span> : return __x.size() == __y.size() -<span class="lineNum"> 748 </span><span class="lineCov"> 4 : && std::equal(__x.begin(), __x.end(), __y.begin());</span> -<span class="lineNum"> 749 </span> : } -<span class="lineNum"> 750 </span> : -<span class="lineNum"> 751 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 752 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 753 </span> : inline bool -<span class="lineNum"> 754 </span> : operator<(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 755 </span> : const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y) -<span class="lineNum"> 756 </span> : { -<span class="lineNum"> 757 </span> : return std::lexicographical_compare(__x.begin(), __x.end(), -<span class="lineNum"> 758 </span> : __y.begin(), __y.end()); -<span class="lineNum"> 759 </span> : } -<span class="lineNum"> 760 </span> : -<span class="lineNum"> 761 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 762 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 763 </span> : inline bool -<span class="lineNum"> 764 </span> : operator!=(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 765 </span> : const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y) -<span class="lineNum"> 766 </span> : { return !(__x == __y); } -<span class="lineNum"> 767 </span> : -<span class="lineNum"> 768 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 769 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 770 </span> : inline bool -<span class="lineNum"> 771 </span> : operator>(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 772 </span> : const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y) -<span class="lineNum"> 773 </span> : { return __y < __x; } -<span class="lineNum"> 774 </span> : -<span class="lineNum"> 775 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 776 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 777 </span> : inline bool -<span class="lineNum"> 778 </span> : operator<=(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 779 </span> : const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y) -<span class="lineNum"> 780 </span> : { return !(__y < __x); } -<span class="lineNum"> 781 </span> : -<span class="lineNum"> 782 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 783 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 784 </span> : inline bool -<span class="lineNum"> 785 </span> : operator>=(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 786 </span> : const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y) -<span class="lineNum"> 787 </span> : { return !(__x < __y); } -<span class="lineNum"> 788 </span> : -<span class="lineNum"> 789 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 790 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 791 </span> : inline void -<span class="lineNum"> 792 </span> : swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x, -<span class="lineNum"> 793 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y) -<span class="lineNum"> 794 </span> : { __x.swap(__y); } -<span class="lineNum"> 795 </span> : -<span class="lineNum"> 796 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 797 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 798 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 799 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 800 </span> : _Rb_tree(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&& __x) -<span class="lineNum"> 801 </span> : : _M_impl(__x._M_impl._M_key_compare, __x._M_get_Node_allocator()) -<span class="lineNum"> 802 </span> : { -<span class="lineNum"> 803 </span> : if (__x._M_root() != 0) -<span class="lineNum"> 804 </span> : { -<span class="lineNum"> 805 </span> : _M_root() = __x._M_root(); -<span class="lineNum"> 806 </span> : _M_leftmost() = __x._M_leftmost(); -<span class="lineNum"> 807 </span> : _M_rightmost() = __x._M_rightmost(); -<span class="lineNum"> 808 </span> : _M_root()->_M_parent = _M_end(); -<span class="lineNum"> 809 </span> : -<span class="lineNum"> 810 </span> : __x._M_root() = 0; -<span class="lineNum"> 811 </span> : __x._M_leftmost() = __x._M_end(); -<span class="lineNum"> 812 </span> : __x._M_rightmost() = __x._M_end(); -<span class="lineNum"> 813 </span> : -<span class="lineNum"> 814 </span> : this->_M_impl._M_node_count = __x._M_impl._M_node_count; -<span class="lineNum"> 815 </span> : __x._M_impl._M_node_count = 0; -<span class="lineNum"> 816 </span> : } -<span class="lineNum"> 817 </span> : } -<span class="lineNum"> 818 </span> : #endif -<span class="lineNum"> 819 </span> : -<span class="lineNum"> 820 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 821 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 822 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& -<span class="lineNum"> 823 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 824 </span><span class="lineCov"> 97 : operator=(const _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x)</span> -<span class="lineNum"> 825 </span> : { -<span class="lineNum"> 826 </span><span class="lineCov"> 97 : if (this != &__x)</span> -<span class="lineNum"> 827 </span> : { -<span class="lineNum"> 828 </span> : // Note that _Key may be a constant type. -<span class="lineNum"> 829 </span><span class="lineCov"> 97 : clear();</span> -<span class="lineNum"> 830 </span><span class="lineCov"> 97 : _M_impl._M_key_compare = __x._M_impl._M_key_compare;</span> -<span class="lineNum"> 831 </span><span class="lineCov"> 97 : if (__x._M_root() != 0)</span> -<span class="lineNum"> 832 </span> : { -<span class="lineNum"> 833 </span><span class="lineCov"> 53 : _M_root() = _M_copy(__x._M_begin(), _M_end());</span> -<span class="lineNum"> 834 </span><span class="lineCov"> 53 : _M_leftmost() = _S_minimum(_M_root());</span> -<span class="lineNum"> 835 </span><span class="lineCov"> 53 : _M_rightmost() = _S_maximum(_M_root());</span> -<span class="lineNum"> 836 </span><span class="lineCov"> 53 : _M_impl._M_node_count = __x._M_impl._M_node_count;</span> -<span class="lineNum"> 837 </span> : } -<span class="lineNum"> 838 </span> : } -<span class="lineNum"> 839 </span><span class="lineCov"> 97 : return *this;</span> -<span class="lineNum"> 840 </span> : } -<span class="lineNum"> 841 </span> : -<span class="lineNum"> 842 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 843 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 844 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator -<span class="lineNum"> 845 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 846 </span><span class="lineCov"> 2070706 : _M_insert_(_Const_Base_ptr __x, _Const_Base_ptr __p, const _Val& __v)</span> -<span class="lineNum"> 847 </span> : { -<span class="lineNum"> 848 </span> : bool __insert_left = (__x != 0 || __p == _M_end() -<span class="lineNum"> 849 </span> : || _M_impl._M_key_compare(_KeyOfValue()(__v), -<span class="lineNum"> 850 </span><span class="lineCov"> 2070706 : _S_key(__p)));</span> -<span class="lineNum"> 851 </span> : -<span class="lineNum"> 852 </span><span class="lineCov"> 2070706 : _Link_type __z = _M_create_node(__v);</span> -<span class="lineNum"> 853 </span> : -<span class="lineNum"> 854 </span><span class="lineCov"> 2070706 : _Rb_tree_insert_and_rebalance(__insert_left, __z,</span> -<span class="lineNum"> 855 </span> : const_cast<_Base_ptr>(__p), -<span class="lineNum"> 856 </span> : this->_M_impl._M_header); -<span class="lineNum"> 857 </span><span class="lineCov"> 2070706 : ++_M_impl._M_node_count;</span> -<span class="lineNum"> 858 </span><span class="lineCov"> 2070706 : return iterator(__z);</span> -<span class="lineNum"> 859 </span> : } -<span class="lineNum"> 860 </span> : -<span class="lineNum"> 861 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 862 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 863 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator -<span class="lineNum"> 864 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 865 </span> : _M_insert_lower(_Base_ptr __x, _Base_ptr __p, const _Val& __v) -<span class="lineNum"> 866 </span> : { -<span class="lineNum"> 867 </span> : bool __insert_left = (__x != 0 || __p == _M_end() -<span class="lineNum"> 868 </span> : || !_M_impl._M_key_compare(_S_key(__p), -<span class="lineNum"> 869 </span> : _KeyOfValue()(__v))); -<span class="lineNum"> 870 </span> : -<span class="lineNum"> 871 </span> : _Link_type __z = _M_create_node(__v); -<span class="lineNum"> 872 </span> : -<span class="lineNum"> 873 </span> : _Rb_tree_insert_and_rebalance(__insert_left, __z, __p, -<span class="lineNum"> 874 </span> : this->_M_impl._M_header); -<span class="lineNum"> 875 </span> : ++_M_impl._M_node_count; -<span class="lineNum"> 876 </span> : return iterator(__z); -<span class="lineNum"> 877 </span> : } -<span class="lineNum"> 878 </span> : -<span class="lineNum"> 879 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 880 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 881 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator -<span class="lineNum"> 882 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 883 </span> : _M_insert_equal_lower(const _Val& __v) -<span class="lineNum"> 884 </span> : { -<span class="lineNum"> 885 </span> : _Link_type __x = _M_begin(); -<span class="lineNum"> 886 </span> : _Link_type __y = _M_end(); -<span class="lineNum"> 887 </span> : while (__x != 0) -<span class="lineNum"> 888 </span> : { -<span class="lineNum"> 889 </span> : __y = __x; -<span class="lineNum"> 890 </span> : __x = !_M_impl._M_key_compare(_S_key(__x), _KeyOfValue()(__v)) ? -<span class="lineNum"> 891 </span> : _S_left(__x) : _S_right(__x); -<span class="lineNum"> 892 </span> : } -<span class="lineNum"> 893 </span> : return _M_insert_lower(__x, __y, __v); -<span class="lineNum"> 894 </span> : } -<span class="lineNum"> 895 </span> : -<span class="lineNum"> 896 </span> : template<typename _Key, typename _Val, typename _KoV, -<span class="lineNum"> 897 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 898 </span> : typename _Rb_tree<_Key, _Val, _KoV, _Compare, _Alloc>::_Link_type -<span class="lineNum"> 899 </span> : _Rb_tree<_Key, _Val, _KoV, _Compare, _Alloc>:: -<span class="lineNum"> 900 </span><span class="lineCov"> 2381075 : _M_copy(_Const_Link_type __x, _Link_type __p)</span> -<span class="lineNum"> 901 </span> : { -<span class="lineNum"> 902 </span> : // Structural copy. __x and __p must be non-null. -<span class="lineNum"> 903 </span><span class="lineCov"> 2381075 : _Link_type __top = _M_clone_node(__x);</span> -<span class="lineNum"> 904 </span><span class="lineCov"> 2381075 : __top->_M_parent = __p;</span> -<span class="lineNum"> 905 </span> : -<span class="lineNum"> 906 </span> : try -<span class="lineNum"> 907 </span> : { -<span class="lineNum"> 908 </span><span class="lineCov"> 2381075 : if (__x->_M_right)</span> -<span class="lineNum"> 909 </span><span class="lineCov"> 1355924 : __top->_M_right = _M_copy(_S_right(__x), __top);</span> -<span class="lineNum"> 910 </span><span class="lineCov"> 2381075 : __p = __top;</span> -<span class="lineNum"> 911 </span><span class="lineCov"> 2381075 : __x = _S_left(__x);</span> -<span class="lineNum"> 912 </span> : -<span class="lineNum"> 913 </span><span class="lineCov"> 5955057 : while (__x != 0)</span> -<span class="lineNum"> 914 </span> : { -<span class="lineNum"> 915 </span><span class="lineCov"> 1192907 : _Link_type __y = _M_clone_node(__x);</span> -<span class="lineNum"> 916 </span><span class="lineCov"> 1192907 : __p->_M_left = __y;</span> -<span class="lineNum"> 917 </span><span class="lineCov"> 1192907 : __y->_M_parent = __p;</span> -<span class="lineNum"> 918 </span><span class="lineCov"> 1192907 : if (__x->_M_right)</span> -<span class="lineNum"> 919 </span><span class="lineCov"> 144518 : __y->_M_right = _M_copy(_S_right(__x), __y);</span> -<span class="lineNum"> 920 </span><span class="lineCov"> 1192907 : __p = __y;</span> -<span class="lineNum"> 921 </span><span class="lineCov"> 1192907 : __x = _S_left(__x);</span> -<span class="lineNum"> 922 </span> : } -<span class="lineNum"> 923 </span> : } -<span class="lineNum"> 924 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 925 </span> : { -<span class="lineNum"> 926 </span><span class="lineNoCov"> 0 : _M_erase(__top);</span> -<span class="lineNum"> 927 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 928 </span> : } -<span class="lineNum"> 929 </span><span class="lineCov"> 2381075 : return __top;</span> -<span class="lineNum"> 930 </span> : } -<span class="lineNum"> 931 </span> : -<span class="lineNum"> 932 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 933 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 934 </span> : void -<span class="lineNum"> 935 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 936 </span><span class="lineCov"> 7053477 : _M_erase(_Link_type __x)</span> -<span class="lineNum"> 937 </span> : { -<span class="lineNum"> 938 </span> : // Erase without rebalancing. -<span class="lineNum"> 939 </span><span class="lineCov"> 19751483 : while (__x != 0)</span> -<span class="lineNum"> 940 </span> : { -<span class="lineNum"> 941 </span><span class="lineCov"> 5644529 : _M_erase(_S_right(__x));</span> -<span class="lineNum"> 942 </span><span class="lineCov"> 5644529 : _Link_type __y = _S_left(__x);</span> -<span class="lineNum"> 943 </span><span class="lineCov"> 5644529 : _M_destroy_node(__x);</span> -<span class="lineNum"> 944 </span><span class="lineCov"> 5644529 : __x = __y;</span> -<span class="lineNum"> 945 </span> : } -<span class="lineNum"> 946 </span><span class="lineCov"> 7053477 : }</span> -<span class="lineNum"> 947 </span> : -<span class="lineNum"> 948 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 949 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 950 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 951 </span> : _Compare, _Alloc>::iterator -<span class="lineNum"> 952 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 953 </span> : _M_lower_bound(_Link_type __x, _Link_type __y, -<span class="lineNum"> 954 </span><span class="lineCov"> 56455 : const _Key& __k)</span> -<span class="lineNum"> 955 </span> : { -<span class="lineNum"> 956 </span><span class="lineCov"> 956283 : while (__x != 0)</span> -<span class="lineNum"> 957 </span><span class="lineCov"> 843373 : if (!_M_impl._M_key_compare(_S_key(__x), __k))</span> -<span class="lineNum"> 958 </span><span class="lineCov"> 159236 : __y = __x, __x = _S_left(__x);</span> -<span class="lineNum"> 959 </span> : else -<span class="lineNum"> 960 </span><span class="lineCov"> 684137 : __x = _S_right(__x);</span> -<span class="lineNum"> 961 </span><span class="lineCov"> 56455 : return iterator(__y);</span> -<span class="lineNum"> 962 </span> : } -<span class="lineNum"> 963 </span> : -<span class="lineNum"> 964 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 965 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 966 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 967 </span> : _Compare, _Alloc>::const_iterator -<span class="lineNum"> 968 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 969 </span> : _M_lower_bound(_Const_Link_type __x, _Const_Link_type __y, -<span class="lineNum"> 970 </span><span class="lineCov"> 3932 : const _Key& __k) const</span> -<span class="lineNum"> 971 </span> : { -<span class="lineNum"> 972 </span><span class="lineCov"> 16029 : while (__x != 0)</span> -<span class="lineNum"> 973 </span><span class="lineCov"> 8165 : if (!_M_impl._M_key_compare(_S_key(__x), __k))</span> -<span class="lineNum"> 974 </span><span class="lineCov"> 5885 : __y = __x, __x = _S_left(__x);</span> -<span class="lineNum"> 975 </span> : else -<span class="lineNum"> 976 </span><span class="lineCov"> 2280 : __x = _S_right(__x);</span> -<span class="lineNum"> 977 </span><span class="lineCov"> 3932 : return const_iterator(__y);</span> -<span class="lineNum"> 978 </span> : } -<span class="lineNum"> 979 </span> : -<span class="lineNum"> 980 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 981 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 982 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 983 </span> : _Compare, _Alloc>::iterator -<span class="lineNum"> 984 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 985 </span> : _M_upper_bound(_Link_type __x, _Link_type __y, -<span class="lineNum"> 986 </span><span class="lineCov"> 2 : const _Key& __k)</span> -<span class="lineNum"> 987 </span> : { -<span class="lineNum"> 988 </span><span class="lineCov"> 4 : while (__x != 0)</span> -<span class="lineNum"> 989 </span><span class="lineNoCov"> 0 : if (_M_impl._M_key_compare(__k, _S_key(__x)))</span> -<span class="lineNum"> 990 </span><span class="lineNoCov"> 0 : __y = __x, __x = _S_left(__x);</span> -<span class="lineNum"> 991 </span> : else -<span class="lineNum"> 992 </span><span class="lineNoCov"> 0 : __x = _S_right(__x);</span> -<span class="lineNum"> 993 </span><span class="lineCov"> 2 : return iterator(__y);</span> -<span class="lineNum"> 994 </span> : } -<span class="lineNum"> 995 </span> : -<span class="lineNum"> 996 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 997 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 998 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 999 </span> : _Compare, _Alloc>::const_iterator -<span class="lineNum"> 1000 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1001 </span> : _M_upper_bound(_Const_Link_type __x, _Const_Link_type __y, -<span class="lineNum"> 1002 </span> : const _Key& __k) const -<span class="lineNum"> 1003 </span> : { -<span class="lineNum"> 1004 </span> : while (__x != 0) -<span class="lineNum"> 1005 </span> : if (_M_impl._M_key_compare(__k, _S_key(__x))) -<span class="lineNum"> 1006 </span> : __y = __x, __x = _S_left(__x); -<span class="lineNum"> 1007 </span> : else -<span class="lineNum"> 1008 </span> : __x = _S_right(__x); -<span class="lineNum"> 1009 </span> : return const_iterator(__y); -<span class="lineNum"> 1010 </span> : } -<span class="lineNum"> 1011 </span> : -<span class="lineNum"> 1012 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1013 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1014 </span> : pair<typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1015 </span> : _Compare, _Alloc>::iterator, -<span class="lineNum"> 1016 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1017 </span> : _Compare, _Alloc>::iterator> -<span class="lineNum"> 1018 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1019 </span><span class="lineCov"> 9 : equal_range(const _Key& __k)</span> -<span class="lineNum"> 1020 </span> : { -<span class="lineNum"> 1021 </span><span class="lineCov"> 9 : _Link_type __x = _M_begin();</span> -<span class="lineNum"> 1022 </span><span class="lineCov"> 9 : _Link_type __y = _M_end();</span> -<span class="lineNum"> 1023 </span><span class="lineCov"> 20 : while (__x != 0)</span> -<span class="lineNum"> 1024 </span> : { -<span class="lineNum"> 1025 </span><span class="lineCov"> 4 : if (_M_impl._M_key_compare(_S_key(__x), __k))</span> -<span class="lineNum"> 1026 </span><span class="lineNoCov"> 0 : __x = _S_right(__x);</span> -<span class="lineNum"> 1027 </span><span class="lineCov"> 4 : else if (_M_impl._M_key_compare(__k, _S_key(__x)))</span> -<span class="lineNum"> 1028 </span><span class="lineCov"> 2 : __y = __x, __x = _S_left(__x);</span> -<span class="lineNum"> 1029 </span> : else -<span class="lineNum"> 1030 </span> : { -<span class="lineNum"> 1031 </span><span class="lineCov"> 2 : _Link_type __xu(__x), __yu(__y);</span> -<span class="lineNum"> 1032 </span><span class="lineCov"> 2 : __y = __x, __x = _S_left(__x);</span> -<span class="lineNum"> 1033 </span><span class="lineCov"> 2 : __xu = _S_right(__xu);</span> -<span class="lineNum"> 1034 </span> : return pair<iterator, -<span class="lineNum"> 1035 </span> : iterator>(_M_lower_bound(__x, __y, __k), -<span class="lineNum"> 1036 </span><span class="lineCov"> 2 : _M_upper_bound(__xu, __yu, __k));</span> -<span class="lineNum"> 1037 </span> : } -<span class="lineNum"> 1038 </span> : } -<span class="lineNum"> 1039 </span> : return pair<iterator, iterator>(iterator(__y), -<span class="lineNum"> 1040 </span><span class="lineCov"> 7 : iterator(__y));</span> -<span class="lineNum"> 1041 </span> : } -<span class="lineNum"> 1042 </span> : -<span class="lineNum"> 1043 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1044 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1045 </span> : pair<typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1046 </span> : _Compare, _Alloc>::const_iterator, -<span class="lineNum"> 1047 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1048 </span> : _Compare, _Alloc>::const_iterator> -<span class="lineNum"> 1049 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1050 </span> : equal_range(const _Key& __k) const -<span class="lineNum"> 1051 </span> : { -<span class="lineNum"> 1052 </span> : _Const_Link_type __x = _M_begin(); -<span class="lineNum"> 1053 </span> : _Const_Link_type __y = _M_end(); -<span class="lineNum"> 1054 </span> : while (__x != 0) -<span class="lineNum"> 1055 </span> : { -<span class="lineNum"> 1056 </span> : if (_M_impl._M_key_compare(_S_key(__x), __k)) -<span class="lineNum"> 1057 </span> : __x = _S_right(__x); -<span class="lineNum"> 1058 </span> : else if (_M_impl._M_key_compare(__k, _S_key(__x))) -<span class="lineNum"> 1059 </span> : __y = __x, __x = _S_left(__x); -<span class="lineNum"> 1060 </span> : else -<span class="lineNum"> 1061 </span> : { -<span class="lineNum"> 1062 </span> : _Const_Link_type __xu(__x), __yu(__y); -<span class="lineNum"> 1063 </span> : __y = __x, __x = _S_left(__x); -<span class="lineNum"> 1064 </span> : __xu = _S_right(__xu); -<span class="lineNum"> 1065 </span> : return pair<const_iterator, -<span class="lineNum"> 1066 </span> : const_iterator>(_M_lower_bound(__x, __y, __k), -<span class="lineNum"> 1067 </span> : _M_upper_bound(__xu, __yu, __k)); -<span class="lineNum"> 1068 </span> : } -<span class="lineNum"> 1069 </span> : } -<span class="lineNum"> 1070 </span> : return pair<const_iterator, const_iterator>(const_iterator(__y), -<span class="lineNum"> 1071 </span> : const_iterator(__y)); -<span class="lineNum"> 1072 </span> : } -<span class="lineNum"> 1073 </span> : -<span class="lineNum"> 1074 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1075 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1076 </span> : void -<span class="lineNum"> 1077 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1078 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1079 </span> : swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&& __t) -<span class="lineNum"> 1080 </span> : #else -<span class="lineNum"> 1081 </span> : swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __t) -<span class="lineNum"> 1082 </span> : #endif -<span class="lineNum"> 1083 </span> : { -<span class="lineNum"> 1084 </span> : if (_M_root() == 0) -<span class="lineNum"> 1085 </span> : { -<span class="lineNum"> 1086 </span> : if (__t._M_root() != 0) -<span class="lineNum"> 1087 </span> : { -<span class="lineNum"> 1088 </span> : _M_root() = __t._M_root(); -<span class="lineNum"> 1089 </span> : _M_leftmost() = __t._M_leftmost(); -<span class="lineNum"> 1090 </span> : _M_rightmost() = __t._M_rightmost(); -<span class="lineNum"> 1091 </span> : _M_root()->_M_parent = _M_end(); -<span class="lineNum"> 1092 </span> : -<span class="lineNum"> 1093 </span> : __t._M_root() = 0; -<span class="lineNum"> 1094 </span> : __t._M_leftmost() = __t._M_end(); -<span class="lineNum"> 1095 </span> : __t._M_rightmost() = __t._M_end(); -<span class="lineNum"> 1096 </span> : } -<span class="lineNum"> 1097 </span> : } -<span class="lineNum"> 1098 </span> : else if (__t._M_root() == 0) -<span class="lineNum"> 1099 </span> : { -<span class="lineNum"> 1100 </span> : __t._M_root() = _M_root(); -<span class="lineNum"> 1101 </span> : __t._M_leftmost() = _M_leftmost(); -<span class="lineNum"> 1102 </span> : __t._M_rightmost() = _M_rightmost(); -<span class="lineNum"> 1103 </span> : __t._M_root()->_M_parent = __t._M_end(); -<span class="lineNum"> 1104 </span> : -<span class="lineNum"> 1105 </span> : _M_root() = 0; -<span class="lineNum"> 1106 </span> : _M_leftmost() = _M_end(); -<span class="lineNum"> 1107 </span> : _M_rightmost() = _M_end(); -<span class="lineNum"> 1108 </span> : } -<span class="lineNum"> 1109 </span> : else -<span class="lineNum"> 1110 </span> : { -<span class="lineNum"> 1111 </span> : std::swap(_M_root(),__t._M_root()); -<span class="lineNum"> 1112 </span> : std::swap(_M_leftmost(),__t._M_leftmost()); -<span class="lineNum"> 1113 </span> : std::swap(_M_rightmost(),__t._M_rightmost()); -<span class="lineNum"> 1114 </span> : -<span class="lineNum"> 1115 </span> : _M_root()->_M_parent = _M_end(); -<span class="lineNum"> 1116 </span> : __t._M_root()->_M_parent = __t._M_end(); -<span class="lineNum"> 1117 </span> : } -<span class="lineNum"> 1118 </span> : // No need to swap header's color as it does not change. -<span class="lineNum"> 1119 </span> : std::swap(this->_M_impl._M_node_count, __t._M_impl._M_node_count); -<span class="lineNum"> 1120 </span> : std::swap(this->_M_impl._M_key_compare, __t._M_impl._M_key_compare); -<span class="lineNum"> 1121 </span> : -<span class="lineNum"> 1122 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1123 </span> : // 431. Swapping containers with unequal allocators. -<span class="lineNum"> 1124 </span> : std::__alloc_swap<_Node_allocator>:: -<span class="lineNum"> 1125 </span> : _S_do_it(_M_get_Node_allocator(), __t._M_get_Node_allocator()); -<span class="lineNum"> 1126 </span> : } -<span class="lineNum"> 1127 </span> : -<span class="lineNum"> 1128 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1129 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1130 </span> : pair<typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1131 </span> : _Compare, _Alloc>::iterator, bool> -<span class="lineNum"> 1132 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1133 </span><span class="lineCov"> 1653740 : _M_insert_unique(const _Val& __v)</span> -<span class="lineNum"> 1134 </span> : { -<span class="lineNum"> 1135 </span><span class="lineCov"> 1653740 : _Link_type __x = _M_begin();</span> -<span class="lineNum"> 1136 </span><span class="lineCov"> 1653740 : _Link_type __y = _M_end();</span> -<span class="lineNum"> 1137 </span><span class="lineCov"> 1653740 : bool __comp = true;</span> -<span class="lineNum"> 1138 </span><span class="lineCov"> 9798389 : while (__x != 0)</span> -<span class="lineNum"> 1139 </span> : { -<span class="lineNum"> 1140 </span><span class="lineCov"> 6490909 : __y = __x;</span> -<span class="lineNum"> 1141 </span><span class="lineCov"> 6490909 : __comp = _M_impl._M_key_compare(_KeyOfValue()(__v), _S_key(__x));</span> -<span class="lineNum"> 1142 </span><span class="lineCov"> 6490909 : __x = __comp ? _S_left(__x) : _S_right(__x);</span> -<span class="lineNum"> 1143 </span> : } -<span class="lineNum"> 1144 </span><span class="lineCov"> 1653740 : iterator __j = iterator(__y);</span> -<span class="lineNum"> 1145 </span><span class="lineCov"> 1653740 : if (__comp)</span> -<span class="lineNum"> 1146 </span> : { -<span class="lineNum"> 1147 </span><span class="lineCov"> 536188 : if (__j == begin())</span> -<span class="lineNum"> 1148 </span><span class="lineCov"> 452855 : return pair<iterator, bool>(_M_insert_(__x, __y, __v), true);</span> -<span class="lineNum"> 1149 </span> : else -<span class="lineNum"> 1150 </span><span class="lineCov"> 83333 : --__j;</span> -<span class="lineNum"> 1151 </span> : } -<span class="lineNum"> 1152 </span><span class="lineCov"> 1200885 : if (_M_impl._M_key_compare(_S_key(__j._M_node), _KeyOfValue()(__v)))</span> -<span class="lineNum"> 1153 </span><span class="lineCov"> 1095156 : return pair<iterator, bool>(_M_insert_(__x, __y, __v), true);</span> -<span class="lineNum"> 1154 </span><span class="lineCov"> 105729 : return pair<iterator, bool>(__j, false);</span> -<span class="lineNum"> 1155 </span> : } -<span class="lineNum"> 1156 </span> : -<span class="lineNum"> 1157 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1158 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1159 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator -<span class="lineNum"> 1160 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1161 </span> : _M_insert_equal(const _Val& __v) -<span class="lineNum"> 1162 </span> : { -<span class="lineNum"> 1163 </span> : _Link_type __x = _M_begin(); -<span class="lineNum"> 1164 </span> : _Link_type __y = _M_end(); -<span class="lineNum"> 1165 </span> : while (__x != 0) -<span class="lineNum"> 1166 </span> : { -<span class="lineNum"> 1167 </span> : __y = __x; -<span class="lineNum"> 1168 </span> : __x = _M_impl._M_key_compare(_KeyOfValue()(__v), _S_key(__x)) ? -<span class="lineNum"> 1169 </span> : _S_left(__x) : _S_right(__x); -<span class="lineNum"> 1170 </span> : } -<span class="lineNum"> 1171 </span> : return _M_insert_(__x, __y, __v); -<span class="lineNum"> 1172 </span> : } -<span class="lineNum"> 1173 </span> : -<span class="lineNum"> 1174 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1175 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1176 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator -<span class="lineNum"> 1177 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1178 </span><span class="lineCov"> 652700 : _M_insert_unique_(const_iterator __position, const _Val& __v)</span> -<span class="lineNum"> 1179 </span> : { -<span class="lineNum"> 1180 </span> : // end() -<span class="lineNum"> 1181 </span><span class="lineCov"> 652700 : if (__position._M_node == _M_end())</span> -<span class="lineNum"> 1182 </span> : { -<span class="lineNum"> 1183 </span><span class="lineCov"> 649758 : if (size() > 0</span> -<span class="lineNum"> 1184 </span> : && _M_impl._M_key_compare(_S_key(_M_rightmost()), -<span class="lineNum"> 1185 </span> : _KeyOfValue()(__v))) -<span class="lineNum"> 1186 </span><span class="lineCov"> 521501 : return _M_insert_(0, _M_rightmost(), __v);</span> -<span class="lineNum"> 1187 </span> : else -<span class="lineNum"> 1188 </span><span class="lineCov"> 128257 : return _M_insert_unique(__v).first;</span> -<span class="lineNum"> 1189 </span> : } -<span class="lineNum"> 1190 </span><span class="lineCov"> 2942 : else if (_M_impl._M_key_compare(_KeyOfValue()(__v),</span> -<span class="lineNum"> 1191 </span> : _S_key(__position._M_node))) -<span class="lineNum"> 1192 </span> : { -<span class="lineNum"> 1193 </span> : // First, try before... -<span class="lineNum"> 1194 </span><span class="lineCov"> 2040 : const_iterator __before = __position;</span> -<span class="lineNum"> 1195 </span><span class="lineCov"> 2040 : if (__position._M_node == _M_leftmost()) // begin()</span> -<span class="lineNum"> 1196 </span><span class="lineCov"> 72 : return _M_insert_(_M_leftmost(), _M_leftmost(), __v);</span> -<span class="lineNum"> 1197 </span><span class="lineCov"> 1968 : else if (_M_impl._M_key_compare(_S_key((--__before)._M_node), </span> -<span class="lineNum"> 1198 </span> : _KeyOfValue()(__v))) -<span class="lineNum"> 1199 </span> : { -<span class="lineNum"> 1200 </span><span class="lineCov"> 1101 : if (_S_right(__before._M_node) == 0)</span> -<span class="lineNum"> 1201 </span><span class="lineCov"> 562 : return _M_insert_(0, __before._M_node, __v);</span> -<span class="lineNum"> 1202 </span> : else -<span class="lineNum"> 1203 </span> : return _M_insert_(__position._M_node, -<span class="lineNum"> 1204 </span><span class="lineCov"> 539 : __position._M_node, __v);</span> -<span class="lineNum"> 1205 </span> : } -<span class="lineNum"> 1206 </span> : else -<span class="lineNum"> 1207 </span><span class="lineCov"> 867 : return _M_insert_unique(__v).first;</span> -<span class="lineNum"> 1208 </span> : } -<span class="lineNum"> 1209 </span><span class="lineCov"> 902 : else if (_M_impl._M_key_compare(_S_key(__position._M_node),</span> -<span class="lineNum"> 1210 </span> : _KeyOfValue()(__v))) -<span class="lineNum"> 1211 </span> : { -<span class="lineNum"> 1212 </span> : // ... then try after. -<span class="lineNum"> 1213 </span><span class="lineCov"> 902 : const_iterator __after = __position;</span> -<span class="lineNum"> 1214 </span><span class="lineCov"> 902 : if (__position._M_node == _M_rightmost())</span> -<span class="lineNum"> 1215 </span><span class="lineCov"> 13 : return _M_insert_(0, _M_rightmost(), __v);</span> -<span class="lineNum"> 1216 </span><span class="lineCov"> 889 : else if (_M_impl._M_key_compare(_KeyOfValue()(__v),</span> -<span class="lineNum"> 1217 </span> : _S_key((++__after)._M_node))) -<span class="lineNum"> 1218 </span> : { -<span class="lineNum"> 1219 </span><span class="lineCov"> 8 : if (_S_right(__position._M_node) == 0)</span> -<span class="lineNum"> 1220 </span><span class="lineCov"> 4 : return _M_insert_(0, __position._M_node, __v);</span> -<span class="lineNum"> 1221 </span> : else -<span class="lineNum"> 1222 </span><span class="lineCov"> 4 : return _M_insert_(__after._M_node, __after._M_node, __v);</span> -<span class="lineNum"> 1223 </span> : } -<span class="lineNum"> 1224 </span> : else -<span class="lineNum"> 1225 </span><span class="lineCov"> 881 : return _M_insert_unique(__v).first;</span> -<span class="lineNum"> 1226 </span> : } -<span class="lineNum"> 1227 </span> : else -<span class="lineNum"> 1228 </span> : // Equivalent keys. -<span class="lineNum"> 1229 </span> : return iterator(static_cast<_Link_type> -<span class="lineNum"> 1230 </span><span class="lineNoCov"> 0 : (const_cast<_Base_ptr>(__position._M_node)));</span> -<span class="lineNum"> 1231 </span> : } -<span class="lineNum"> 1232 </span> : -<span class="lineNum"> 1233 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1234 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1235 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator -<span class="lineNum"> 1236 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1237 </span> : _M_insert_equal_(const_iterator __position, const _Val& __v) -<span class="lineNum"> 1238 </span> : { -<span class="lineNum"> 1239 </span> : // end() -<span class="lineNum"> 1240 </span> : if (__position._M_node == _M_end()) -<span class="lineNum"> 1241 </span> : { -<span class="lineNum"> 1242 </span> : if (size() > 0 -<span class="lineNum"> 1243 </span> : && !_M_impl._M_key_compare(_KeyOfValue()(__v), -<span class="lineNum"> 1244 </span> : _S_key(_M_rightmost()))) -<span class="lineNum"> 1245 </span> : return _M_insert_(0, _M_rightmost(), __v); -<span class="lineNum"> 1246 </span> : else -<span class="lineNum"> 1247 </span> : return _M_insert_equal(__v); -<span class="lineNum"> 1248 </span> : } -<span class="lineNum"> 1249 </span> : else if (!_M_impl._M_key_compare(_S_key(__position._M_node), -<span class="lineNum"> 1250 </span> : _KeyOfValue()(__v))) -<span class="lineNum"> 1251 </span> : { -<span class="lineNum"> 1252 </span> : // First, try before... -<span class="lineNum"> 1253 </span> : const_iterator __before = __position; -<span class="lineNum"> 1254 </span> : if (__position._M_node == _M_leftmost()) // begin() -<span class="lineNum"> 1255 </span> : return _M_insert_(_M_leftmost(), _M_leftmost(), __v); -<span class="lineNum"> 1256 </span> : else if (!_M_impl._M_key_compare(_KeyOfValue()(__v), -<span class="lineNum"> 1257 </span> : _S_key((--__before)._M_node))) -<span class="lineNum"> 1258 </span> : { -<span class="lineNum"> 1259 </span> : if (_S_right(__before._M_node) == 0) -<span class="lineNum"> 1260 </span> : return _M_insert_(0, __before._M_node, __v); -<span class="lineNum"> 1261 </span> : else -<span class="lineNum"> 1262 </span> : return _M_insert_(__position._M_node, -<span class="lineNum"> 1263 </span> : __position._M_node, __v); -<span class="lineNum"> 1264 </span> : } -<span class="lineNum"> 1265 </span> : else -<span class="lineNum"> 1266 </span> : return _M_insert_equal(__v); -<span class="lineNum"> 1267 </span> : } -<span class="lineNum"> 1268 </span> : else -<span class="lineNum"> 1269 </span> : { -<span class="lineNum"> 1270 </span> : // ... then try after. -<span class="lineNum"> 1271 </span> : const_iterator __after = __position; -<span class="lineNum"> 1272 </span> : if (__position._M_node == _M_rightmost()) -<span class="lineNum"> 1273 </span> : return _M_insert_(0, _M_rightmost(), __v); -<span class="lineNum"> 1274 </span> : else if (!_M_impl._M_key_compare(_S_key((++__after)._M_node), -<span class="lineNum"> 1275 </span> : _KeyOfValue()(__v))) -<span class="lineNum"> 1276 </span> : { -<span class="lineNum"> 1277 </span> : if (_S_right(__position._M_node) == 0) -<span class="lineNum"> 1278 </span> : return _M_insert_(0, __position._M_node, __v); -<span class="lineNum"> 1279 </span> : else -<span class="lineNum"> 1280 </span> : return _M_insert_(__after._M_node, __after._M_node, __v); -<span class="lineNum"> 1281 </span> : } -<span class="lineNum"> 1282 </span> : else -<span class="lineNum"> 1283 </span> : return _M_insert_equal_lower(__v); -<span class="lineNum"> 1284 </span> : } -<span class="lineNum"> 1285 </span> : } -<span class="lineNum"> 1286 </span> : -<span class="lineNum"> 1287 </span> : template<typename _Key, typename _Val, typename _KoV, -<span class="lineNum"> 1288 </span> : typename _Cmp, typename _Alloc> -<span class="lineNum"> 1289 </span> : template<class _II> -<span class="lineNum"> 1290 </span> : void -<span class="lineNum"> 1291 </span> : _Rb_tree<_Key, _Val, _KoV, _Cmp, _Alloc>:: -<span class="lineNum"> 1292 </span> : _M_insert_unique(_II __first, _II __last) -<span class="lineNum"> 1293 </span> : { -<span class="lineNum"> 1294 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 1295 </span> : _M_insert_unique_(end(), *__first); -<span class="lineNum"> 1296 </span> : } -<span class="lineNum"> 1297 </span> : -<span class="lineNum"> 1298 </span> : template<typename _Key, typename _Val, typename _KoV, -<span class="lineNum"> 1299 </span> : typename _Cmp, typename _Alloc> -<span class="lineNum"> 1300 </span> : template<class _II> -<span class="lineNum"> 1301 </span> : void -<span class="lineNum"> 1302 </span> : _Rb_tree<_Key, _Val, _KoV, _Cmp, _Alloc>:: -<span class="lineNum"> 1303 </span> : _M_insert_equal(_II __first, _II __last) -<span class="lineNum"> 1304 </span> : { -<span class="lineNum"> 1305 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 1306 </span> : _M_insert_equal_(end(), *__first); -<span class="lineNum"> 1307 </span> : } -<span class="lineNum"> 1308 </span> : -<span class="lineNum"> 1309 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1310 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1311 </span> : inline void -<span class="lineNum"> 1312 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1313 </span><span class="lineNoCov"> 0 : erase(iterator __position)</span> -<span class="lineNum"> 1314 </span> : { -<span class="lineNum"> 1315 </span> : _Link_type __y = -<span class="lineNum"> 1316 </span> : static_cast<_Link_type>(_Rb_tree_rebalance_for_erase -<span class="lineNum"> 1317 </span> : (__position._M_node, -<span class="lineNum"> 1318 </span><span class="lineNoCov"> 0 : this->_M_impl._M_header));</span> -<span class="lineNum"> 1319 </span><span class="lineNoCov"> 0 : _M_destroy_node(__y);</span> -<span class="lineNum"> 1320 </span><span class="lineNoCov"> 0 : --_M_impl._M_node_count;</span> -<span class="lineNum"> 1321 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 1322 </span> : -<span class="lineNum"> 1323 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1324 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1325 </span> : inline void -<span class="lineNum"> 1326 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1327 </span><span class="lineCov"> 129 : erase(const_iterator __position)</span> -<span class="lineNum"> 1328 </span> : { -<span class="lineNum"> 1329 </span> : _Link_type __y = -<span class="lineNum"> 1330 </span> : static_cast<_Link_type>(_Rb_tree_rebalance_for_erase -<span class="lineNum"> 1331 </span> : (const_cast<_Base_ptr>(__position._M_node), -<span class="lineNum"> 1332 </span><span class="lineCov"> 129 : this->_M_impl._M_header));</span> -<span class="lineNum"> 1333 </span><span class="lineCov"> 129 : _M_destroy_node(__y);</span> -<span class="lineNum"> 1334 </span><span class="lineCov"> 129 : --_M_impl._M_node_count;</span> -<span class="lineNum"> 1335 </span><span class="lineCov"> 129 : }</span> -<span class="lineNum"> 1336 </span> : -<span class="lineNum"> 1337 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1338 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1339 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type -<span class="lineNum"> 1340 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1341 </span><span class="lineCov"> 9 : erase(const _Key& __x)</span> -<span class="lineNum"> 1342 </span> : { -<span class="lineNum"> 1343 </span><span class="lineCov"> 9 : pair<iterator, iterator> __p = equal_range(__x);</span> -<span class="lineNum"> 1344 </span><span class="lineCov"> 9 : const size_type __old_size = size();</span> -<span class="lineNum"> 1345 </span><span class="lineCov"> 9 : erase(__p.first, __p.second);</span> -<span class="lineNum"> 1346 </span><span class="lineCov"> 9 : return __old_size - size();</span> -<span class="lineNum"> 1347 </span> : } -<span class="lineNum"> 1348 </span> : -<span class="lineNum"> 1349 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1350 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1351 </span> : void -<span class="lineNum"> 1352 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1353 </span><span class="lineCov"> 9 : erase(iterator __first, iterator __last)</span> -<span class="lineNum"> 1354 </span> : { -<span class="lineNum"> 1355 </span><span class="lineCov"> 9 : if (__first == begin() && __last == end())</span> -<span class="lineNum"> 1356 </span><span class="lineCov"> 7 : clear();</span> -<span class="lineNum"> 1357 </span> : else -<span class="lineNum"> 1358 </span><span class="lineCov"> 4 : while (__first != __last)</span> -<span class="lineNum"> 1359 </span><span class="lineNoCov"> 0 : erase(__first++);</span> -<span class="lineNum"> 1360 </span><span class="lineCov"> 9 : }</span> -<span class="lineNum"> 1361 </span> : -<span class="lineNum"> 1362 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1363 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1364 </span> : void -<span class="lineNum"> 1365 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1366 </span> : erase(const_iterator __first, const_iterator __last) -<span class="lineNum"> 1367 </span> : { -<span class="lineNum"> 1368 </span> : if (__first == begin() && __last == end()) -<span class="lineNum"> 1369 </span> : clear(); -<span class="lineNum"> 1370 </span> : else -<span class="lineNum"> 1371 </span> : while (__first != __last) -<span class="lineNum"> 1372 </span> : erase(__first++); -<span class="lineNum"> 1373 </span> : } -<span class="lineNum"> 1374 </span> : -<span class="lineNum"> 1375 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1376 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1377 </span> : void -<span class="lineNum"> 1378 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1379 </span> : erase(const _Key* __first, const _Key* __last) -<span class="lineNum"> 1380 </span> : { -<span class="lineNum"> 1381 </span> : while (__first != __last) -<span class="lineNum"> 1382 </span> : erase(*__first++); -<span class="lineNum"> 1383 </span> : } -<span class="lineNum"> 1384 </span> : -<span class="lineNum"> 1385 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1386 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1387 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1388 </span> : _Compare, _Alloc>::iterator -<span class="lineNum"> 1389 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1390 </span><span class="lineCov"> 50156 : find(const _Key& __k)</span> -<span class="lineNum"> 1391 </span> : { -<span class="lineNum"> 1392 </span><span class="lineCov"> 50156 : iterator __j = _M_lower_bound(_M_begin(), _M_end(), __k);</span> -<span class="lineNum"> 1393 </span> : return (__j == end() -<span class="lineNum"> 1394 </span> : || _M_impl._M_key_compare(__k, -<span class="lineNum"> 1395 </span><span class="lineCov"> 50156 : _S_key(__j._M_node))) ? end() : __j;</span> -<span class="lineNum"> 1396 </span> : } -<span class="lineNum"> 1397 </span> : -<span class="lineNum"> 1398 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1399 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1400 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, -<span class="lineNum"> 1401 </span> : _Compare, _Alloc>::const_iterator -<span class="lineNum"> 1402 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1403 </span><span class="lineCov"> 3932 : find(const _Key& __k) const</span> -<span class="lineNum"> 1404 </span> : { -<span class="lineNum"> 1405 </span><span class="lineCov"> 3932 : const_iterator __j = _M_lower_bound(_M_begin(), _M_end(), __k);</span> -<span class="lineNum"> 1406 </span> : return (__j == end() -<span class="lineNum"> 1407 </span> : || _M_impl._M_key_compare(__k, -<span class="lineNum"> 1408 </span><span class="lineCov"> 3932 : _S_key(__j._M_node))) ? end() : __j;</span> -<span class="lineNum"> 1409 </span> : } -<span class="lineNum"> 1410 </span> : -<span class="lineNum"> 1411 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1412 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1413 </span> : typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type -<span class="lineNum"> 1414 </span> : _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>:: -<span class="lineNum"> 1415 </span> : count(const _Key& __k) const -<span class="lineNum"> 1416 </span> : { -<span class="lineNum"> 1417 </span> : pair<const_iterator, const_iterator> __p = equal_range(__k); -<span class="lineNum"> 1418 </span> : const size_type __n = std::distance(__p.first, __p.second); -<span class="lineNum"> 1419 </span> : return __n; -<span class="lineNum"> 1420 </span> : } -<span class="lineNum"> 1421 </span> : -<span class="lineNum"> 1422 </span> : unsigned int -<span class="lineNum"> 1423 </span> : _Rb_tree_black_count(const _Rb_tree_node_base* __node, -<span class="lineNum"> 1424 </span> : const _Rb_tree_node_base* __root); -<span class="lineNum"> 1425 </span> : -<span class="lineNum"> 1426 </span> : template<typename _Key, typename _Val, typename _KeyOfValue, -<span class="lineNum"> 1427 </span> : typename _Compare, typename _Alloc> -<span class="lineNum"> 1428 </span> : bool -<span class="lineNum"> 1429 </span> : _Rb_tree<_Key,_Val,_KeyOfValue,_Compare,_Alloc>::__rb_verify() const -<span class="lineNum"> 1430 </span> : { -<span class="lineNum"> 1431 </span> : if (_M_impl._M_node_count == 0 || begin() == end()) -<span class="lineNum"> 1432 </span> : return _M_impl._M_node_count == 0 && begin() == end() -<span class="lineNum"> 1433 </span> : && this->_M_impl._M_header._M_left == _M_end() -<span class="lineNum"> 1434 </span> : && this->_M_impl._M_header._M_right == _M_end(); -<span class="lineNum"> 1435 </span> : -<span class="lineNum"> 1436 </span> : unsigned int __len = _Rb_tree_black_count(_M_leftmost(), _M_root()); -<span class="lineNum"> 1437 </span> : for (const_iterator __it = begin(); __it != end(); ++__it) -<span class="lineNum"> 1438 </span> : { -<span class="lineNum"> 1439 </span> : _Const_Link_type __x = static_cast<_Const_Link_type>(__it._M_node); -<span class="lineNum"> 1440 </span> : _Const_Link_type __L = _S_left(__x); -<span class="lineNum"> 1441 </span> : _Const_Link_type __R = _S_right(__x); -<span class="lineNum"> 1442 </span> : -<span class="lineNum"> 1443 </span> : if (__x->_M_color == _S_red) -<span class="lineNum"> 1444 </span> : if ((__L && __L->_M_color == _S_red) -<span class="lineNum"> 1445 </span> : || (__R && __R->_M_color == _S_red)) -<span class="lineNum"> 1446 </span> : return false; -<span class="lineNum"> 1447 </span> : -<span class="lineNum"> 1448 </span> : if (__L && _M_impl._M_key_compare(_S_key(__x), _S_key(__L))) -<span class="lineNum"> 1449 </span> : return false; -<span class="lineNum"> 1450 </span> : if (__R && _M_impl._M_key_compare(_S_key(__R), _S_key(__x))) -<span class="lineNum"> 1451 </span> : return false; -<span class="lineNum"> 1452 </span> : -<span class="lineNum"> 1453 </span> : if (!__L && !__R && _Rb_tree_black_count(__x, _M_root()) != __len) -<span class="lineNum"> 1454 </span> : return false; -<span class="lineNum"> 1455 </span> : } -<span class="lineNum"> 1456 </span> : -<span class="lineNum"> 1457 </span> : if (_M_leftmost() != _Rb_tree_node_base::_S_minimum(_M_root())) -<span class="lineNum"> 1458 </span> : return false; -<span class="lineNum"> 1459 </span> : if (_M_rightmost() != _Rb_tree_node_base::_S_maximum(_M_root())) -<span class="lineNum"> 1460 </span> : return false; -<span class="lineNum"> 1461 </span> : return true; -<span class="lineNum"> 1462 </span> : } -<span class="lineNum"> 1463 </span> : -<span class="lineNum"> 1464 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 1465 </span> : -<span class="lineNum"> 1466 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_uninitialized.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_uninitialized.h.gcov.html deleted file mode 100644 index 08dd2e7..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_uninitialized.h.gcov.html +++ /dev/null @@ -1,503 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_uninitialized.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_uninitialized.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">43</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">58.1 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">25</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Raw memory manipulators -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996,1997 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_uninitialized.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_UNINITIALIZED_H -<span class="lineNum"> 63 </span> : #define _STL_UNINITIALIZED_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : template<bool> -<span class="lineNum"> 68 </span> : struct __uninitialized_copy -<span class="lineNum"> 69 </span> : { -<span class="lineNum"> 70 </span> : template<typename _InputIterator, typename _ForwardIterator> -<span class="lineNum"> 71 </span> : static _ForwardIterator -<span class="lineNum"> 72 </span> : uninitialized_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 73 </span><span class="lineCov"> 36673 : _ForwardIterator __result)</span> -<span class="lineNum"> 74 </span> : { -<span class="lineNum"> 75 </span><span class="lineCov"> 36673 : _ForwardIterator __cur = __result;</span> -<span class="lineNum"> 76 </span> : try -<span class="lineNum"> 77 </span> : { -<span class="lineNum"> 78 </span><span class="lineCov"> 84888 : for (; __first != __last; ++__first, ++__cur)</span> -<span class="lineNum"> 79 </span><span class="lineCov"> 48215 : ::new(static_cast<void*>(&*__cur)) typename</span> -<span class="lineNum"> 80 </span> : iterator_traits<_ForwardIterator>::value_type(*__first); -<span class="lineNum"> 81 </span><span class="lineCov"> 36660 : return __cur;</span> -<span class="lineNum"> 82 </span> : } -<span class="lineNum"> 83 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 84 </span> : { -<span class="lineNum"> 85 </span><span class="lineNoCov"> 0 : std::_Destroy(__result, __cur);</span> -<span class="lineNum"> 86 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 87 </span> : } -<span class="lineNum"> 88 </span> : } -<span class="lineNum"> 89 </span> : }; -<span class="lineNum"> 90 </span> : -<span class="lineNum"> 91 </span> : template<> -<span class="lineNum"> 92 </span> : struct __uninitialized_copy<true> -<span class="lineNum"> 93 </span> : { -<span class="lineNum"> 94 </span> : template<typename _InputIterator, typename _ForwardIterator> -<span class="lineNum"> 95 </span> : static _ForwardIterator -<span class="lineNum"> 96 </span> : uninitialized_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 97 </span><span class="lineCov"> 27152 : _ForwardIterator __result)</span> -<span class="lineNum"> 98 </span><span class="lineCov"> 27152 : { return std::copy(__first, __last, __result); }</span> -<span class="lineNum"> 99 </span> : }; -<span class="lineNum"> 100 </span> : -<span class="lineNum"> 101 </span> : /** -<span class="lineNum"> 102 </span> : * @brief Copies the range [first,last) into result. -<span class="lineNum"> 103 </span> : * @param first An input iterator. -<span class="lineNum"> 104 </span> : * @param last An input iterator. -<span class="lineNum"> 105 </span> : * @param result An output iterator. -<span class="lineNum"> 106 </span> : * @return result + (first - last) -<span class="lineNum"> 107 </span> : * -<span class="lineNum"> 108 </span> : * Like copy(), but does not require an initialized output range. -<span class="lineNum"> 109 </span> : */ -<span class="lineNum"> 110 </span> : template<typename _InputIterator, typename _ForwardIterator> -<span class="lineNum"> 111 </span> : inline _ForwardIterator -<span class="lineNum"> 112 </span> : uninitialized_copy(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 113 </span><span class="lineCov"> 63825 : _ForwardIterator __result)</span> -<span class="lineNum"> 114 </span> : { -<span class="lineNum"> 115 </span> : typedef typename iterator_traits<_InputIterator>::value_type -<span class="lineNum"> 116 </span> : _ValueType1; -<span class="lineNum"> 117 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 118 </span> : _ValueType2; -<span class="lineNum"> 119 </span> : -<span class="lineNum"> 120 </span> : return std::__uninitialized_copy<(__is_pod(_ValueType1) -<span class="lineNum"> 121 </span> : && __is_pod(_ValueType2))>:: -<span class="lineNum"> 122 </span><span class="lineCov"> 63825 : uninitialized_copy(__first, __last, __result);</span> -<span class="lineNum"> 123 </span> : } -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : -<span class="lineNum"> 126 </span> : template<bool> -<span class="lineNum"> 127 </span> : struct __uninitialized_fill -<span class="lineNum"> 128 </span> : { -<span class="lineNum"> 129 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 130 </span> : static void -<span class="lineNum"> 131 </span> : uninitialized_fill(_ForwardIterator __first, -<span class="lineNum"> 132 </span> : _ForwardIterator __last, const _Tp& __x) -<span class="lineNum"> 133 </span> : { -<span class="lineNum"> 134 </span> : _ForwardIterator __cur = __first; -<span class="lineNum"> 135 </span> : try -<span class="lineNum"> 136 </span> : { -<span class="lineNum"> 137 </span> : for (; __cur != __last; ++__cur) -<span class="lineNum"> 138 </span> : std::_Construct(&*__cur, __x); -<span class="lineNum"> 139 </span> : } -<span class="lineNum"> 140 </span> : catch(...) -<span class="lineNum"> 141 </span> : { -<span class="lineNum"> 142 </span> : std::_Destroy(__first, __cur); -<span class="lineNum"> 143 </span> : __throw_exception_again; -<span class="lineNum"> 144 </span> : } -<span class="lineNum"> 145 </span> : } -<span class="lineNum"> 146 </span> : }; -<span class="lineNum"> 147 </span> : -<span class="lineNum"> 148 </span> : template<> -<span class="lineNum"> 149 </span> : struct __uninitialized_fill<true> -<span class="lineNum"> 150 </span> : { -<span class="lineNum"> 151 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 152 </span> : static void -<span class="lineNum"> 153 </span> : uninitialized_fill(_ForwardIterator __first, -<span class="lineNum"> 154 </span> : _ForwardIterator __last, const _Tp& __x) -<span class="lineNum"> 155 </span> : { std::fill(__first, __last, __x); } -<span class="lineNum"> 156 </span> : }; -<span class="lineNum"> 157 </span> : -<span class="lineNum"> 158 </span> : /** -<span class="lineNum"> 159 </span> : * @brief Copies the value x into the range [first,last). -<span class="lineNum"> 160 </span> : * @param first An input iterator. -<span class="lineNum"> 161 </span> : * @param last An input iterator. -<span class="lineNum"> 162 </span> : * @param x The source value. -<span class="lineNum"> 163 </span> : * @return Nothing. -<span class="lineNum"> 164 </span> : * -<span class="lineNum"> 165 </span> : * Like fill(), but does not require an initialized output range. -<span class="lineNum"> 166 </span> : */ -<span class="lineNum"> 167 </span> : template<typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 168 </span> : inline void -<span class="lineNum"> 169 </span> : uninitialized_fill(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 170 </span> : const _Tp& __x) -<span class="lineNum"> 171 </span> : { -<span class="lineNum"> 172 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 173 </span> : _ValueType; -<span class="lineNum"> 174 </span> : -<span class="lineNum"> 175 </span> : std::__uninitialized_fill<__is_pod(_ValueType)>:: -<span class="lineNum"> 176 </span> : uninitialized_fill(__first, __last, __x); -<span class="lineNum"> 177 </span> : } -<span class="lineNum"> 178 </span> : -<span class="lineNum"> 179 </span> : -<span class="lineNum"> 180 </span> : template<bool> -<span class="lineNum"> 181 </span> : struct __uninitialized_fill_n -<span class="lineNum"> 182 </span> : { -<span class="lineNum"> 183 </span> : template<typename _ForwardIterator, typename _Size, typename _Tp> -<span class="lineNum"> 184 </span> : static void -<span class="lineNum"> 185 </span> : uninitialized_fill_n(_ForwardIterator __first, _Size __n, -<span class="lineNum"> 186 </span><span class="lineCov"> 22443 : const _Tp& __x)</span> -<span class="lineNum"> 187 </span> : { -<span class="lineNum"> 188 </span><span class="lineCov"> 22443 : _ForwardIterator __cur = __first;</span> -<span class="lineNum"> 189 </span> : try -<span class="lineNum"> 190 </span> : { -<span class="lineNum"> 191 </span><span class="lineCov"> 46138 : for (; __n > 0; --__n, ++__cur)</span> -<span class="lineNum"> 192 </span><span class="lineCov"> 23695 : std::_Construct(&*__cur, __x);</span> -<span class="lineNum"> 193 </span> : } -<span class="lineNum"> 194 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 195 </span> : { -<span class="lineNum"> 196 </span><span class="lineNoCov"> 0 : std::_Destroy(__first, __cur);</span> -<span class="lineNum"> 197 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 198 </span> : } -<span class="lineNum"> 199 </span><span class="lineCov"> 22443 : }</span> -<span class="lineNum"> 200 </span> : }; -<span class="lineNum"> 201 </span> : -<span class="lineNum"> 202 </span> : template<> -<span class="lineNum"> 203 </span> : struct __uninitialized_fill_n<true> -<span class="lineNum"> 204 </span> : { -<span class="lineNum"> 205 </span> : template<typename _ForwardIterator, typename _Size, typename _Tp> -<span class="lineNum"> 206 </span> : static void -<span class="lineNum"> 207 </span> : uninitialized_fill_n(_ForwardIterator __first, _Size __n, -<span class="lineNum"> 208 </span><span class="lineCov"> 9 : const _Tp& __x)</span> -<span class="lineNum"> 209 </span><span class="lineCov"> 9 : { std::fill_n(__first, __n, __x); }</span> -<span class="lineNum"> 210 </span> : }; -<span class="lineNum"> 211 </span> : -<span class="lineNum"> 212 </span> : /** -<span class="lineNum"> 213 </span> : * @brief Copies the value x into the range [first,first+n). -<span class="lineNum"> 214 </span> : * @param first An input iterator. -<span class="lineNum"> 215 </span> : * @param n The number of copies to make. -<span class="lineNum"> 216 </span> : * @param x The source value. -<span class="lineNum"> 217 </span> : * @return Nothing. -<span class="lineNum"> 218 </span> : * -<span class="lineNum"> 219 </span> : * Like fill_n(), but does not require an initialized output range. -<span class="lineNum"> 220 </span> : */ -<span class="lineNum"> 221 </span> : template<typename _ForwardIterator, typename _Size, typename _Tp> -<span class="lineNum"> 222 </span> : inline void -<span class="lineNum"> 223 </span><span class="lineCov"> 22452 : uninitialized_fill_n(_ForwardIterator __first, _Size __n, const _Tp& __x)</span> -<span class="lineNum"> 224 </span> : { -<span class="lineNum"> 225 </span> : typedef typename iterator_traits<_ForwardIterator>::value_type -<span class="lineNum"> 226 </span> : _ValueType; -<span class="lineNum"> 227 </span> : -<span class="lineNum"> 228 </span><span class="lineCov"> 22452 : std::__uninitialized_fill_n<__is_pod(_ValueType)>::</span> -<span class="lineNum"> 229 </span> : uninitialized_fill_n(__first, __n, __x); -<span class="lineNum"> 230 </span><span class="lineCov"> 22452 : }</span> -<span class="lineNum"> 231 </span> : -<span class="lineNum"> 232 </span> : // Extensions: versions of uninitialized_copy, uninitialized_fill, -<span class="lineNum"> 233 </span> : // and uninitialized_fill_n that take an allocator parameter. -<span class="lineNum"> 234 </span> : // We dispatch back to the standard versions when we're given the -<span class="lineNum"> 235 </span> : // default allocator. For nondefault allocators we do not use -<span class="lineNum"> 236 </span> : // any of the POD optimizations. -<span class="lineNum"> 237 </span> : -<span class="lineNum"> 238 </span> : template<typename _InputIterator, typename _ForwardIterator, -<span class="lineNum"> 239 </span> : typename _Allocator> -<span class="lineNum"> 240 </span> : _ForwardIterator -<span class="lineNum"> 241 </span> : __uninitialized_copy_a(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 242 </span> : _ForwardIterator __result, _Allocator& __alloc) -<span class="lineNum"> 243 </span> : { -<span class="lineNum"> 244 </span> : _ForwardIterator __cur = __result; -<span class="lineNum"> 245 </span> : try -<span class="lineNum"> 246 </span> : { -<span class="lineNum"> 247 </span> : for (; __first != __last; ++__first, ++__cur) -<span class="lineNum"> 248 </span> : __alloc.construct(&*__cur, *__first); -<span class="lineNum"> 249 </span> : return __cur; -<span class="lineNum"> 250 </span> : } -<span class="lineNum"> 251 </span> : catch(...) -<span class="lineNum"> 252 </span> : { -<span class="lineNum"> 253 </span> : std::_Destroy(__result, __cur, __alloc); -<span class="lineNum"> 254 </span> : __throw_exception_again; -<span class="lineNum"> 255 </span> : } -<span class="lineNum"> 256 </span> : } -<span class="lineNum"> 257 </span> : -<span class="lineNum"> 258 </span> : template<typename _InputIterator, typename _ForwardIterator, typename _Tp> -<span class="lineNum"> 259 </span> : inline _ForwardIterator -<span class="lineNum"> 260 </span> : __uninitialized_copy_a(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 261 </span><span class="lineCov"> 63825 : _ForwardIterator __result, allocator<_Tp>&)</span> -<span class="lineNum"> 262 </span><span class="lineCov"> 63825 : { return std::uninitialized_copy(__first, __last, __result); }</span> -<span class="lineNum"> 263 </span> : -<span class="lineNum"> 264 </span> : template<typename _InputIterator, typename _ForwardIterator, -<span class="lineNum"> 265 </span> : typename _Allocator> -<span class="lineNum"> 266 </span> : inline _ForwardIterator -<span class="lineNum"> 267 </span> : __uninitialized_move_a(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 268 </span><span class="lineCov"> 63802 : _ForwardIterator __result, _Allocator& __alloc)</span> -<span class="lineNum"> 269 </span> : { -<span class="lineNum"> 270 </span> : return std::__uninitialized_copy_a(_GLIBCXX_MAKE_MOVE_ITERATOR(__first), -<span class="lineNum"> 271 </span> : _GLIBCXX_MAKE_MOVE_ITERATOR(__last), -<span class="lineNum"> 272 </span><span class="lineCov"> 63802 : __result, __alloc);</span> -<span class="lineNum"> 273 </span> : } -<span class="lineNum"> 274 </span> : -<span class="lineNum"> 275 </span> : template<typename _ForwardIterator, typename _Tp, typename _Allocator> -<span class="lineNum"> 276 </span> : void -<span class="lineNum"> 277 </span> : __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 278 </span> : const _Tp& __x, _Allocator& __alloc) -<span class="lineNum"> 279 </span> : { -<span class="lineNum"> 280 </span> : _ForwardIterator __cur = __first; -<span class="lineNum"> 281 </span> : try -<span class="lineNum"> 282 </span> : { -<span class="lineNum"> 283 </span> : for (; __cur != __last; ++__cur) -<span class="lineNum"> 284 </span> : __alloc.construct(&*__cur, __x); -<span class="lineNum"> 285 </span> : } -<span class="lineNum"> 286 </span> : catch(...) -<span class="lineNum"> 287 </span> : { -<span class="lineNum"> 288 </span> : std::_Destroy(__first, __cur, __alloc); -<span class="lineNum"> 289 </span> : __throw_exception_again; -<span class="lineNum"> 290 </span> : } -<span class="lineNum"> 291 </span> : } -<span class="lineNum"> 292 </span> : -<span class="lineNum"> 293 </span> : template<typename _ForwardIterator, typename _Tp, typename _Tp2> -<span class="lineNum"> 294 </span> : inline void -<span class="lineNum"> 295 </span> : __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 296 </span> : const _Tp& __x, allocator<_Tp2>&) -<span class="lineNum"> 297 </span> : { std::uninitialized_fill(__first, __last, __x); } -<span class="lineNum"> 298 </span> : -<span class="lineNum"> 299 </span> : template<typename _ForwardIterator, typename _Size, typename _Tp, -<span class="lineNum"> 300 </span> : typename _Allocator> -<span class="lineNum"> 301 </span> : void -<span class="lineNum"> 302 </span> : __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n, -<span class="lineNum"> 303 </span> : const _Tp& __x, _Allocator& __alloc) -<span class="lineNum"> 304 </span> : { -<span class="lineNum"> 305 </span> : _ForwardIterator __cur = __first; -<span class="lineNum"> 306 </span> : try -<span class="lineNum"> 307 </span> : { -<span class="lineNum"> 308 </span> : for (; __n > 0; --__n, ++__cur) -<span class="lineNum"> 309 </span> : __alloc.construct(&*__cur, __x); -<span class="lineNum"> 310 </span> : } -<span class="lineNum"> 311 </span> : catch(...) -<span class="lineNum"> 312 </span> : { -<span class="lineNum"> 313 </span> : std::_Destroy(__first, __cur, __alloc); -<span class="lineNum"> 314 </span> : __throw_exception_again; -<span class="lineNum"> 315 </span> : } -<span class="lineNum"> 316 </span> : } -<span class="lineNum"> 317 </span> : -<span class="lineNum"> 318 </span> : template<typename _ForwardIterator, typename _Size, typename _Tp, -<span class="lineNum"> 319 </span> : typename _Tp2> -<span class="lineNum"> 320 </span> : inline void -<span class="lineNum"> 321 </span> : __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n, -<span class="lineNum"> 322 </span><span class="lineCov"> 22452 : const _Tp& __x, allocator<_Tp2>&)</span> -<span class="lineNum"> 323 </span><span class="lineCov"> 22452 : { std::uninitialized_fill_n(__first, __n, __x); }</span> -<span class="lineNum"> 324 </span> : -<span class="lineNum"> 325 </span> : -<span class="lineNum"> 326 </span> : // Extensions: __uninitialized_copy_move, __uninitialized_move_copy, -<span class="lineNum"> 327 </span> : // __uninitialized_fill_move, __uninitialized_move_fill. -<span class="lineNum"> 328 </span> : // All of these algorithms take a user-supplied allocator, which is used -<span class="lineNum"> 329 </span> : // for construction and destruction. -<span class="lineNum"> 330 </span> : -<span class="lineNum"> 331 </span> : // __uninitialized_copy_move -<span class="lineNum"> 332 </span> : // Copies [first1, last1) into [result, result + (last1 - first1)), and -<span class="lineNum"> 333 </span> : // move [first2, last2) into -<span class="lineNum"> 334 </span> : // [result, result + (last1 - first1) + (last2 - first2)). -<span class="lineNum"> 335 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 336 </span> : typename _ForwardIterator, typename _Allocator> -<span class="lineNum"> 337 </span> : inline _ForwardIterator -<span class="lineNum"> 338 </span> : __uninitialized_copy_move(_InputIterator1 __first1, -<span class="lineNum"> 339 </span> : _InputIterator1 __last1, -<span class="lineNum"> 340 </span> : _InputIterator2 __first2, -<span class="lineNum"> 341 </span> : _InputIterator2 __last2, -<span class="lineNum"> 342 </span> : _ForwardIterator __result, -<span class="lineNum"> 343 </span><span class="lineNoCov"> 0 : _Allocator& __alloc)</span> -<span class="lineNum"> 344 </span> : { -<span class="lineNum"> 345 </span> : _ForwardIterator __mid = std::__uninitialized_copy_a(__first1, __last1, -<span class="lineNum"> 346 </span> : __result, -<span class="lineNum"> 347 </span><span class="lineNoCov"> 0 : __alloc);</span> -<span class="lineNum"> 348 </span> : try -<span class="lineNum"> 349 </span> : { -<span class="lineNum"> 350 </span><span class="lineNoCov"> 0 : return std::__uninitialized_move_a(__first2, __last2, __mid, __alloc);</span> -<span class="lineNum"> 351 </span> : } -<span class="lineNum"> 352 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 353 </span> : { -<span class="lineNum"> 354 </span><span class="lineNoCov"> 0 : std::_Destroy(__result, __mid, __alloc);</span> -<span class="lineNum"> 355 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 356 </span> : } -<span class="lineNum"> 357 </span> : } -<span class="lineNum"> 358 </span> : -<span class="lineNum"> 359 </span> : // __uninitialized_move_copy -<span class="lineNum"> 360 </span> : // Moves [first1, last1) into [result, result + (last1 - first1)), and -<span class="lineNum"> 361 </span> : // copies [first2, last2) into -<span class="lineNum"> 362 </span> : // [result, result + (last1 - first1) + (last2 - first2)). -<span class="lineNum"> 363 </span> : template<typename _InputIterator1, typename _InputIterator2, -<span class="lineNum"> 364 </span> : typename _ForwardIterator, typename _Allocator> -<span class="lineNum"> 365 </span> : inline _ForwardIterator -<span class="lineNum"> 366 </span> : __uninitialized_move_copy(_InputIterator1 __first1, -<span class="lineNum"> 367 </span> : _InputIterator1 __last1, -<span class="lineNum"> 368 </span> : _InputIterator2 __first2, -<span class="lineNum"> 369 </span> : _InputIterator2 __last2, -<span class="lineNum"> 370 </span> : _ForwardIterator __result, -<span class="lineNum"> 371 </span><span class="lineNoCov"> 0 : _Allocator& __alloc)</span> -<span class="lineNum"> 372 </span> : { -<span class="lineNum"> 373 </span> : _ForwardIterator __mid = std::__uninitialized_move_a(__first1, __last1, -<span class="lineNum"> 374 </span> : __result, -<span class="lineNum"> 375 </span><span class="lineNoCov"> 0 : __alloc);</span> -<span class="lineNum"> 376 </span> : try -<span class="lineNum"> 377 </span> : { -<span class="lineNum"> 378 </span><span class="lineNoCov"> 0 : return std::__uninitialized_copy_a(__first2, __last2, __mid, __alloc);</span> -<span class="lineNum"> 379 </span> : } -<span class="lineNum"> 380 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 381 </span> : { -<span class="lineNum"> 382 </span><span class="lineNoCov"> 0 : std::_Destroy(__result, __mid, __alloc);</span> -<span class="lineNum"> 383 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 384 </span> : } -<span class="lineNum"> 385 </span> : } -<span class="lineNum"> 386 </span> : -<span class="lineNum"> 387 </span> : // __uninitialized_fill_move -<span class="lineNum"> 388 </span> : // Fills [result, mid) with x, and moves [first, last) into -<span class="lineNum"> 389 </span> : // [mid, mid + (last - first)). -<span class="lineNum"> 390 </span> : template<typename _ForwardIterator, typename _Tp, typename _InputIterator, -<span class="lineNum"> 391 </span> : typename _Allocator> -<span class="lineNum"> 392 </span> : inline _ForwardIterator -<span class="lineNum"> 393 </span> : __uninitialized_fill_move(_ForwardIterator __result, _ForwardIterator __mid, -<span class="lineNum"> 394 </span> : const _Tp& __x, _InputIterator __first, -<span class="lineNum"> 395 </span> : _InputIterator __last, _Allocator& __alloc) -<span class="lineNum"> 396 </span> : { -<span class="lineNum"> 397 </span> : std::__uninitialized_fill_a(__result, __mid, __x, __alloc); -<span class="lineNum"> 398 </span> : try -<span class="lineNum"> 399 </span> : { -<span class="lineNum"> 400 </span> : return std::__uninitialized_move_a(__first, __last, __mid, __alloc); -<span class="lineNum"> 401 </span> : } -<span class="lineNum"> 402 </span> : catch(...) -<span class="lineNum"> 403 </span> : { -<span class="lineNum"> 404 </span> : std::_Destroy(__result, __mid, __alloc); -<span class="lineNum"> 405 </span> : __throw_exception_again; -<span class="lineNum"> 406 </span> : } -<span class="lineNum"> 407 </span> : } -<span class="lineNum"> 408 </span> : -<span class="lineNum"> 409 </span> : // __uninitialized_move_fill -<span class="lineNum"> 410 </span> : // Moves [first1, last1) into [first2, first2 + (last1 - first1)), and -<span class="lineNum"> 411 </span> : // fills [first2 + (last1 - first1), last2) with x. -<span class="lineNum"> 412 </span> : template<typename _InputIterator, typename _ForwardIterator, typename _Tp, -<span class="lineNum"> 413 </span> : typename _Allocator> -<span class="lineNum"> 414 </span> : inline void -<span class="lineNum"> 415 </span> : __uninitialized_move_fill(_InputIterator __first1, _InputIterator __last1, -<span class="lineNum"> 416 </span> : _ForwardIterator __first2, -<span class="lineNum"> 417 </span> : _ForwardIterator __last2, const _Tp& __x, -<span class="lineNum"> 418 </span> : _Allocator& __alloc) -<span class="lineNum"> 419 </span> : { -<span class="lineNum"> 420 </span> : _ForwardIterator __mid2 = std::__uninitialized_move_a(__first1, __last1, -<span class="lineNum"> 421 </span> : __first2, -<span class="lineNum"> 422 </span> : __alloc); -<span class="lineNum"> 423 </span> : try -<span class="lineNum"> 424 </span> : { -<span class="lineNum"> 425 </span> : std::__uninitialized_fill_a(__mid2, __last2, __x, __alloc); -<span class="lineNum"> 426 </span> : } -<span class="lineNum"> 427 </span> : catch(...) -<span class="lineNum"> 428 </span> : { -<span class="lineNum"> 429 </span> : std::_Destroy(__first2, __mid2, __alloc); -<span class="lineNum"> 430 </span> : __throw_exception_again; -<span class="lineNum"> 431 </span> : } -<span class="lineNum"> 432 </span> : } -<span class="lineNum"> 433 </span> : -<span class="lineNum"> 434 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 435 </span> : -<span class="lineNum"> 436 </span> : #endif /* _STL_UNINITIALIZED_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stl_vector.h.gcov.html b/rep/usr/include/c++/4.3/bits/stl_vector.h.gcov.html deleted file mode 100644 index 847af95..0000000 --- a/rep/usr/include/c++/4.3/bits/stl_vector.h.gcov.html +++ /dev/null @@ -1,1241 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stl_vector.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stl_vector.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">103</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">91.3 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">94</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Vector implementation -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file stl_vector.h -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _STL_VECTOR_H -<span class="lineNum"> 63 </span> : #define _STL_VECTOR_H 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : #include <bits/stl_iterator_base_funcs.h> -<span class="lineNum"> 66 </span> : #include <bits/functexcept.h> -<span class="lineNum"> 67 </span> : #include <bits/concept_check.h> -<span class="lineNum"> 68 </span> : -<span class="lineNum"> 69 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 70 </span> : -<span class="lineNum"> 71 </span> : /// See bits/stl_deque.h's _Deque_base for an explanation. -<span class="lineNum"> 72 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 73 </span> : struct _Vector_base -<span class="lineNum"> 74 </span> : { -<span class="lineNum"> 75 </span> : typedef typename _Alloc::template rebind<_Tp>::other _Tp_alloc_type; -<span class="lineNum"> 76 </span> : -<span class="lineNum"> 77 </span> : struct _Vector_impl -<span class="lineNum"> 78 </span> : : public _Tp_alloc_type -<span class="lineNum"> 79 </span><span class="lineCov"> 4841 : {</span> -<span class="lineNum"> 80 </span> : _Tp* _M_start; -<span class="lineNum"> 81 </span> : _Tp* _M_finish; -<span class="lineNum"> 82 </span> : _Tp* _M_end_of_storage; -<span class="lineNum"> 83 </span> : -<span class="lineNum"> 84 </span><span class="lineCov"> 4840 : _Vector_impl()</span> -<span class="lineNum"> 85 </span><span class="lineCov"> 4840 : : _Tp_alloc_type(), _M_start(0), _M_finish(0), _M_end_of_storage(0)</span> -<span class="lineNum"> 86 </span><span class="lineCov"> 4840 : { }</span> -<span class="lineNum"> 87 </span> : -<span class="lineNum"> 88 </span><span class="lineCov"> 9 : _Vector_impl(_Tp_alloc_type const& __a)</span> -<span class="lineNum"> 89 </span><span class="lineCov"> 9 : : _Tp_alloc_type(__a), _M_start(0), _M_finish(0), _M_end_of_storage(0)</span> -<span class="lineNum"> 90 </span><span class="lineCov"> 9 : { }</span> -<span class="lineNum"> 91 </span> : }; -<span class="lineNum"> 92 </span> : -<span class="lineNum"> 93 </span> : public: -<span class="lineNum"> 94 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 95 </span> : -<span class="lineNum"> 96 </span> : _Tp_alloc_type& -<span class="lineNum"> 97 </span><span class="lineCov"> 119679 : _M_get_Tp_allocator()</span> -<span class="lineNum"> 98 </span><span class="lineCov"> 119679 : { return *static_cast<_Tp_alloc_type*>(&this->_M_impl); }</span> -<span class="lineNum"> 99 </span> : -<span class="lineNum"> 100 </span> : const _Tp_alloc_type& -<span class="lineNum"> 101 </span><span class="lineCov"> 41426 : _M_get_Tp_allocator() const</span> -<span class="lineNum"> 102 </span><span class="lineCov"> 41426 : { return *static_cast<const _Tp_alloc_type*>(&this->_M_impl); }</span> -<span class="lineNum"> 103 </span> : -<span class="lineNum"> 104 </span> : allocator_type -<span class="lineNum"> 105 </span> : get_allocator() const -<span class="lineNum"> 106 </span> : { return allocator_type(_M_get_Tp_allocator()); } -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span><span class="lineCov"> 4840 : _Vector_base()</span> -<span class="lineNum"> 109 </span><span class="lineCov"> 4840 : : _M_impl() { }</span> -<span class="lineNum"> 110 </span> : -<span class="lineNum"> 111 </span> : _Vector_base(const allocator_type& __a) -<span class="lineNum"> 112 </span> : : _M_impl(__a) { } -<span class="lineNum"> 113 </span> : -<span class="lineNum"> 114 </span><span class="lineCov"> 9 : _Vector_base(size_t __n, const allocator_type& __a)</span> -<span class="lineNum"> 115 </span><span class="lineCov"> 9 : : _M_impl(__a)</span> -<span class="lineNum"> 116 </span> : { -<span class="lineNum"> 117 </span><span class="lineCov"> 9 : this->_M_impl._M_start = this->_M_allocate(__n);</span> -<span class="lineNum"> 118 </span><span class="lineCov"> 9 : this->_M_impl._M_finish = this->_M_impl._M_start;</span> -<span class="lineNum"> 119 </span><span class="lineCov"> 9 : this->_M_impl._M_end_of_storage = this->_M_impl._M_start + __n;</span> -<span class="lineNum"> 120 </span><span class="lineCov"> 9 : }</span> -<span class="lineNum"> 121 </span> : -<span class="lineNum"> 122 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 123 </span> : _Vector_base(_Vector_base&& __x) -<span class="lineNum"> 124 </span> : : _M_impl(__x._M_get_Tp_allocator()) -<span class="lineNum"> 125 </span> : { -<span class="lineNum"> 126 </span> : this->_M_impl._M_start = __x._M_impl._M_start; -<span class="lineNum"> 127 </span> : this->_M_impl._M_finish = __x._M_impl._M_finish; -<span class="lineNum"> 128 </span> : this->_M_impl._M_end_of_storage = __x._M_impl._M_end_of_storage; -<span class="lineNum"> 129 </span> : __x._M_impl._M_start = 0; -<span class="lineNum"> 130 </span> : __x._M_impl._M_finish = 0; -<span class="lineNum"> 131 </span> : __x._M_impl._M_end_of_storage = 0; -<span class="lineNum"> 132 </span> : } -<span class="lineNum"> 133 </span> : #endif -<span class="lineNum"> 134 </span> : -<span class="lineNum"> 135 </span><span class="lineCov"> 4841 : ~_Vector_base()</span> -<span class="lineNum"> 136 </span><span class="lineCov"> 4841 : { _M_deallocate(this->_M_impl._M_start, this->_M_impl._M_end_of_storage</span> -<span class="lineNum"> 137 </span><span class="lineCov"> 4841 : - this->_M_impl._M_start); }</span> -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : public: -<span class="lineNum"> 140 </span> : _Vector_impl _M_impl; -<span class="lineNum"> 141 </span> : -<span class="lineNum"> 142 </span> : _Tp* -<span class="lineNum"> 143 </span><span class="lineCov"> 20727 : _M_allocate(size_t __n)</span> -<span class="lineNum"> 144 </span><span class="lineCov"> 20727 : { return __n != 0 ? _M_impl.allocate(__n) : 0; }</span> -<span class="lineNum"> 145 </span> : -<span class="lineNum"> 146 </span> : void -<span class="lineNum"> 147 </span><span class="lineCov"> 25559 : _M_deallocate(_Tp* __p, size_t __n)</span> -<span class="lineNum"> 148 </span> : { -<span class="lineNum"> 149 </span><span class="lineCov"> 25559 : if (__p)</span> -<span class="lineNum"> 150 </span><span class="lineCov"> 20616 : _M_impl.deallocate(__p, __n);</span> -<span class="lineNum"> 151 </span><span class="lineCov"> 25559 : }</span> -<span class="lineNum"> 152 </span> : }; -<span class="lineNum"> 153 </span> : -<span class="lineNum"> 154 </span> : -<span class="lineNum"> 155 </span> : /** -<span class="lineNum"> 156 </span> : * @brief A standard container which offers fixed time access to -<span class="lineNum"> 157 </span> : * individual elements in any order. -<span class="lineNum"> 158 </span> : * -<span class="lineNum"> 159 </span> : * @ingroup Containers -<span class="lineNum"> 160 </span> : * @ingroup Sequences -<span class="lineNum"> 161 </span> : * -<span class="lineNum"> 162 </span> : * Meets the requirements of a <a href="tables.html#65">container</a>, a -<span class="lineNum"> 163 </span> : * <a href="tables.html#66">reversible container</a>, and a -<span class="lineNum"> 164 </span> : * <a href="tables.html#67">sequence</a>, including the -<span class="lineNum"> 165 </span> : * <a href="tables.html#68">optional sequence requirements</a> with the -<span class="lineNum"> 166 </span> : * %exception of @c push_front and @c pop_front. -<span class="lineNum"> 167 </span> : * -<span class="lineNum"> 168 </span> : * In some terminology a %vector can be described as a dynamic -<span class="lineNum"> 169 </span> : * C-style array, it offers fast and efficient access to individual -<span class="lineNum"> 170 </span> : * elements in any order and saves the user from worrying about -<span class="lineNum"> 171 </span> : * memory and size allocation. Subscripting ( @c [] ) access is -<span class="lineNum"> 172 </span> : * also provided as with C-style arrays. -<span class="lineNum"> 173 </span> : */ -<span class="lineNum"> 174 </span> : template<typename _Tp, typename _Alloc = std::allocator<_Tp> > -<span class="lineNum"> 175 </span> : class vector : protected _Vector_base<_Tp, _Alloc> -<span class="lineNum"> 176 </span> : { -<span class="lineNum"> 177 </span> : // Concept requirements. -<span class="lineNum"> 178 </span> : typedef typename _Alloc::value_type _Alloc_value_type; -<span class="lineNum"> 179 </span> : __glibcxx_class_requires(_Tp, _SGIAssignableConcept) -<span class="lineNum"> 180 </span> : __glibcxx_class_requires2(_Tp, _Alloc_value_type, _SameTypeConcept) -<span class="lineNum"> 181 </span> : -<span class="lineNum"> 182 </span> : typedef _Vector_base<_Tp, _Alloc> _Base; -<span class="lineNum"> 183 </span> : typedef vector<_Tp, _Alloc> vector_type; -<span class="lineNum"> 184 </span> : typedef typename _Base::_Tp_alloc_type _Tp_alloc_type; -<span class="lineNum"> 185 </span> : -<span class="lineNum"> 186 </span> : public: -<span class="lineNum"> 187 </span> : typedef _Tp value_type; -<span class="lineNum"> 188 </span> : typedef typename _Tp_alloc_type::pointer pointer; -<span class="lineNum"> 189 </span> : typedef typename _Tp_alloc_type::const_pointer const_pointer; -<span class="lineNum"> 190 </span> : typedef typename _Tp_alloc_type::reference reference; -<span class="lineNum"> 191 </span> : typedef typename _Tp_alloc_type::const_reference const_reference; -<span class="lineNum"> 192 </span> : typedef __gnu_cxx::__normal_iterator<pointer, vector_type> iterator; -<span class="lineNum"> 193 </span> : typedef __gnu_cxx::__normal_iterator<const_pointer, vector_type> -<span class="lineNum"> 194 </span> : const_iterator; -<span class="lineNum"> 195 </span> : typedef std::reverse_iterator<const_iterator> const_reverse_iterator; -<span class="lineNum"> 196 </span> : typedef std::reverse_iterator<iterator> reverse_iterator; -<span class="lineNum"> 197 </span> : typedef size_t size_type; -<span class="lineNum"> 198 </span> : typedef ptrdiff_t difference_type; -<span class="lineNum"> 199 </span> : typedef _Alloc allocator_type; -<span class="lineNum"> 200 </span> : -<span class="lineNum"> 201 </span> : protected: -<span class="lineNum"> 202 </span> : using _Base::_M_allocate; -<span class="lineNum"> 203 </span> : using _Base::_M_deallocate; -<span class="lineNum"> 204 </span> : using _Base::_M_impl; -<span class="lineNum"> 205 </span> : using _Base::_M_get_Tp_allocator; -<span class="lineNum"> 206 </span> : -<span class="lineNum"> 207 </span> : public: -<span class="lineNum"> 208 </span> : // [23.2.4.1] construct/copy/destroy -<span class="lineNum"> 209 </span> : // (assign() and get_allocator() are also listed in this section) -<span class="lineNum"> 210 </span> : /** -<span class="lineNum"> 211 </span> : * @brief Default constructor creates no elements. -<span class="lineNum"> 212 </span> : */ -<span class="lineNum"> 213 </span><span class="lineCov"> 4840 : vector()</span> -<span class="lineNum"> 214 </span><span class="lineCov"> 4840 : : _Base() { }</span> -<span class="lineNum"> 215 </span> : -<span class="lineNum"> 216 </span> : /** -<span class="lineNum"> 217 </span> : * @brief Creates a %vector with no elements. -<span class="lineNum"> 218 </span> : * @param a An allocator object. -<span class="lineNum"> 219 </span> : */ -<span class="lineNum"> 220 </span> : explicit -<span class="lineNum"> 221 </span> : vector(const allocator_type& __a) -<span class="lineNum"> 222 </span> : : _Base(__a) { } -<span class="lineNum"> 223 </span> : -<span class="lineNum"> 224 </span> : /** -<span class="lineNum"> 225 </span> : * @brief Creates a %vector with copies of an exemplar element. -<span class="lineNum"> 226 </span> : * @param n The number of elements to initially create. -<span class="lineNum"> 227 </span> : * @param value An element to copy. -<span class="lineNum"> 228 </span> : * @param a An allocator. -<span class="lineNum"> 229 </span> : * -<span class="lineNum"> 230 </span> : * This constructor fills the %vector with @a n copies of @a value. -<span class="lineNum"> 231 </span> : */ -<span class="lineNum"> 232 </span> : explicit -<span class="lineNum"> 233 </span> : vector(size_type __n, const value_type& __value = value_type(), -<span class="lineNum"> 234 </span><span class="lineCov"> 9 : const allocator_type& __a = allocator_type())</span> -<span class="lineNum"> 235 </span><span class="lineCov"> 9 : : _Base(__n, __a)</span> -<span class="lineNum"> 236 </span><span class="lineCov"> 9 : { _M_fill_initialize(__n, __value); }</span> -<span class="lineNum"> 237 </span> : -<span class="lineNum"> 238 </span> : /** -<span class="lineNum"> 239 </span> : * @brief %Vector copy constructor. -<span class="lineNum"> 240 </span> : * @param x A %vector of identical element and allocator types. -<span class="lineNum"> 241 </span> : * -<span class="lineNum"> 242 </span> : * The newly-created %vector uses a copy of the allocation -<span class="lineNum"> 243 </span> : * object used by @a x. All the elements of @a x are copied, -<span class="lineNum"> 244 </span> : * but any extra memory in -<span class="lineNum"> 245 </span> : * @a x (for fast expansion) will not be copied. -<span class="lineNum"> 246 </span> : */ -<span class="lineNum"> 247 </span><span class="lineNoCov"> 0 : vector(const vector& __x)</span> -<span class="lineNum"> 248 </span><span class="lineNoCov"> 0 : : _Base(__x.size(), __x._M_get_Tp_allocator())</span> -<span class="lineNum"> 249 </span><span class="lineNoCov"> 0 : { this->_M_impl._M_finish =</span> -<span class="lineNum"> 250 </span> : std::__uninitialized_copy_a(__x.begin(), __x.end(), -<span class="lineNum"> 251 </span> : this->_M_impl._M_start, -<span class="lineNum"> 252 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 253 </span><span class="lineNoCov"> 0 : }</span> -<span class="lineNum"> 254 </span> : -<span class="lineNum"> 255 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 256 </span> : /** -<span class="lineNum"> 257 </span> : * @brief %Vector move constructor. -<span class="lineNum"> 258 </span> : * @param x A %vector of identical element and allocator types. -<span class="lineNum"> 259 </span> : * -<span class="lineNum"> 260 </span> : * The newly-created %vector contains the exact contents of @a x. -<span class="lineNum"> 261 </span> : * The contents of @a x are a valid, but unspecified %vector. -<span class="lineNum"> 262 </span> : */ -<span class="lineNum"> 263 </span> : vector(vector&& __x) -<span class="lineNum"> 264 </span> : : _Base(std::forward<_Base>(__x)) { } -<span class="lineNum"> 265 </span> : #endif -<span class="lineNum"> 266 </span> : -<span class="lineNum"> 267 </span> : /** -<span class="lineNum"> 268 </span> : * @brief Builds a %vector from a range. -<span class="lineNum"> 269 </span> : * @param first An input iterator. -<span class="lineNum"> 270 </span> : * @param last An input iterator. -<span class="lineNum"> 271 </span> : * @param a An allocator. -<span class="lineNum"> 272 </span> : * -<span class="lineNum"> 273 </span> : * Create a %vector consisting of copies of the elements from -<span class="lineNum"> 274 </span> : * [first,last). -<span class="lineNum"> 275 </span> : * -<span class="lineNum"> 276 </span> : * If the iterators are forward, bidirectional, or -<span class="lineNum"> 277 </span> : * random-access, then this will call the elements' copy -<span class="lineNum"> 278 </span> : * constructor N times (where N is distance(first,last)) and do -<span class="lineNum"> 279 </span> : * no memory reallocation. But if only input iterators are -<span class="lineNum"> 280 </span> : * used, then this will do at most 2N calls to the copy -<span class="lineNum"> 281 </span> : * constructor, and logN memory reallocations. -<span class="lineNum"> 282 </span> : */ -<span class="lineNum"> 283 </span> : template<typename _InputIterator> -<span class="lineNum"> 284 </span> : vector(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 285 </span> : const allocator_type& __a = allocator_type()) -<span class="lineNum"> 286 </span> : : _Base(__a) -<span class="lineNum"> 287 </span> : { -<span class="lineNum"> 288 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 289 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 290 </span> : _M_initialize_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 291 </span> : } -<span class="lineNum"> 292 </span> : -<span class="lineNum"> 293 </span> : /** -<span class="lineNum"> 294 </span> : * The dtor only erases the elements, and note that if the -<span class="lineNum"> 295 </span> : * elements themselves are pointers, the pointed-to memory is -<span class="lineNum"> 296 </span> : * not touched in any way. Managing the pointer is the user's -<span class="lineNum"> 297 </span> : * responsibility. -<span class="lineNum"> 298 </span> : */ -<span class="lineNum"> 299 </span><span class="lineCov"> 4841 : ~vector()</span> -<span class="lineNum"> 300 </span><span class="lineCov"> 4841 : { std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish,</span> -<span class="lineNum"> 301 </span><span class="lineCov"> 4841 : _M_get_Tp_allocator()); }</span> -<span class="lineNum"> 302 </span> : -<span class="lineNum"> 303 </span> : /** -<span class="lineNum"> 304 </span> : * @brief %Vector assignment operator. -<span class="lineNum"> 305 </span> : * @param x A %vector of identical element and allocator types. -<span class="lineNum"> 306 </span> : * -<span class="lineNum"> 307 </span> : * All the elements of @a x are copied, but any extra memory in -<span class="lineNum"> 308 </span> : * @a x (for fast expansion) will not be copied. Unlike the -<span class="lineNum"> 309 </span> : * copy constructor, the allocator object is not copied. -<span class="lineNum"> 310 </span> : */ -<span class="lineNum"> 311 </span> : vector& -<span class="lineNum"> 312 </span> : operator=(const vector& __x); -<span class="lineNum"> 313 </span> : -<span class="lineNum"> 314 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 315 </span> : /** -<span class="lineNum"> 316 </span> : * @brief %Vector move assignment operator. -<span class="lineNum"> 317 </span> : * @param x A %vector of identical element and allocator types. -<span class="lineNum"> 318 </span> : * -<span class="lineNum"> 319 </span> : * The contents of @a x are moved into this %vector (without copying). -<span class="lineNum"> 320 </span> : * @a x is a valid, but unspecified %vector. -<span class="lineNum"> 321 </span> : */ -<span class="lineNum"> 322 </span> : vector& -<span class="lineNum"> 323 </span> : operator=(vector&& __x) -<span class="lineNum"> 324 </span> : { -<span class="lineNum"> 325 </span> : // NB: DR 675. -<span class="lineNum"> 326 </span> : this->clear(); -<span class="lineNum"> 327 </span> : this->swap(__x); -<span class="lineNum"> 328 </span> : return *this; -<span class="lineNum"> 329 </span> : } -<span class="lineNum"> 330 </span> : #endif -<span class="lineNum"> 331 </span> : -<span class="lineNum"> 332 </span> : /** -<span class="lineNum"> 333 </span> : * @brief Assigns a given value to a %vector. -<span class="lineNum"> 334 </span> : * @param n Number of elements to be assigned. -<span class="lineNum"> 335 </span> : * @param val Value to be assigned. -<span class="lineNum"> 336 </span> : * -<span class="lineNum"> 337 </span> : * This function fills a %vector with @a n copies of the given -<span class="lineNum"> 338 </span> : * value. Note that the assignment completely changes the -<span class="lineNum"> 339 </span> : * %vector and that the resulting %vector's size is the same as -<span class="lineNum"> 340 </span> : * the number of elements assigned. Old data may be lost. -<span class="lineNum"> 341 </span> : */ -<span class="lineNum"> 342 </span> : void -<span class="lineNum"> 343 </span> : assign(size_type __n, const value_type& __val) -<span class="lineNum"> 344 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 345 </span> : -<span class="lineNum"> 346 </span> : /** -<span class="lineNum"> 347 </span> : * @brief Assigns a range to a %vector. -<span class="lineNum"> 348 </span> : * @param first An input iterator. -<span class="lineNum"> 349 </span> : * @param last An input iterator. -<span class="lineNum"> 350 </span> : * -<span class="lineNum"> 351 </span> : * This function fills a %vector with copies of the elements in the -<span class="lineNum"> 352 </span> : * range [first,last). -<span class="lineNum"> 353 </span> : * -<span class="lineNum"> 354 </span> : * Note that the assignment completely changes the %vector and -<span class="lineNum"> 355 </span> : * that the resulting %vector's size is the same as the number -<span class="lineNum"> 356 </span> : * of elements assigned. Old data may be lost. -<span class="lineNum"> 357 </span> : */ -<span class="lineNum"> 358 </span> : template<typename _InputIterator> -<span class="lineNum"> 359 </span> : void -<span class="lineNum"> 360 </span> : assign(_InputIterator __first, _InputIterator __last) -<span class="lineNum"> 361 </span> : { -<span class="lineNum"> 362 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 363 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 364 </span> : _M_assign_dispatch(__first, __last, _Integral()); -<span class="lineNum"> 365 </span> : } -<span class="lineNum"> 366 </span> : -<span class="lineNum"> 367 </span> : /// Get a copy of the memory allocation object. -<span class="lineNum"> 368 </span> : using _Base::get_allocator; -<span class="lineNum"> 369 </span> : -<span class="lineNum"> 370 </span> : // iterators -<span class="lineNum"> 371 </span> : /** -<span class="lineNum"> 372 </span> : * Returns a read/write iterator that points to the first -<span class="lineNum"> 373 </span> : * element in the %vector. Iteration is done in ordinary -<span class="lineNum"> 374 </span> : * element order. -<span class="lineNum"> 375 </span> : */ -<span class="lineNum"> 376 </span> : iterator -<span class="lineNum"> 377 </span><span class="lineCov"> 4034 : begin()</span> -<span class="lineNum"> 378 </span><span class="lineCov"> 4034 : { return iterator(this->_M_impl._M_start); }</span> -<span class="lineNum"> 379 </span> : -<span class="lineNum"> 380 </span> : /** -<span class="lineNum"> 381 </span> : * Returns a read-only (constant) iterator that points to the -<span class="lineNum"> 382 </span> : * first element in the %vector. Iteration is done in ordinary -<span class="lineNum"> 383 </span> : * element order. -<span class="lineNum"> 384 </span> : */ -<span class="lineNum"> 385 </span> : const_iterator -<span class="lineNum"> 386 </span><span class="lineCov"> 91 : begin() const</span> -<span class="lineNum"> 387 </span><span class="lineCov"> 91 : { return const_iterator(this->_M_impl._M_start); }</span> -<span class="lineNum"> 388 </span> : -<span class="lineNum"> 389 </span> : /** -<span class="lineNum"> 390 </span> : * Returns a read/write iterator that points one past the last -<span class="lineNum"> 391 </span> : * element in the %vector. Iteration is done in ordinary -<span class="lineNum"> 392 </span> : * element order. -<span class="lineNum"> 393 </span> : */ -<span class="lineNum"> 394 </span> : iterator -<span class="lineNum"> 395 </span><span class="lineCov"> 69161 : end()</span> -<span class="lineNum"> 396 </span><span class="lineCov"> 69161 : { return iterator(this->_M_impl._M_finish); }</span> -<span class="lineNum"> 397 </span> : -<span class="lineNum"> 398 </span> : /** -<span class="lineNum"> 399 </span> : * Returns a read-only (constant) iterator that points one past -<span class="lineNum"> 400 </span> : * the last element in the %vector. Iteration is done in -<span class="lineNum"> 401 </span> : * ordinary element order. -<span class="lineNum"> 402 </span> : */ -<span class="lineNum"> 403 </span> : const_iterator -<span class="lineNum"> 404 </span><span class="lineCov"> 175 : end() const</span> -<span class="lineNum"> 405 </span><span class="lineCov"> 175 : { return const_iterator(this->_M_impl._M_finish); }</span> -<span class="lineNum"> 406 </span> : -<span class="lineNum"> 407 </span> : /** -<span class="lineNum"> 408 </span> : * Returns a read/write reverse iterator that points to the -<span class="lineNum"> 409 </span> : * last element in the %vector. Iteration is done in reverse -<span class="lineNum"> 410 </span> : * element order. -<span class="lineNum"> 411 </span> : */ -<span class="lineNum"> 412 </span> : reverse_iterator -<span class="lineNum"> 413 </span><span class="lineCov"> 1 : rbegin()</span> -<span class="lineNum"> 414 </span><span class="lineCov"> 1 : { return reverse_iterator(end()); }</span> -<span class="lineNum"> 415 </span> : -<span class="lineNum"> 416 </span> : /** -<span class="lineNum"> 417 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 418 </span> : * to the last element in the %vector. Iteration is done in -<span class="lineNum"> 419 </span> : * reverse element order. -<span class="lineNum"> 420 </span> : */ -<span class="lineNum"> 421 </span> : const_reverse_iterator -<span class="lineNum"> 422 </span> : rbegin() const -<span class="lineNum"> 423 </span> : { return const_reverse_iterator(end()); } -<span class="lineNum"> 424 </span> : -<span class="lineNum"> 425 </span> : /** -<span class="lineNum"> 426 </span> : * Returns a read/write reverse iterator that points to one -<span class="lineNum"> 427 </span> : * before the first element in the %vector. Iteration is done -<span class="lineNum"> 428 </span> : * in reverse element order. -<span class="lineNum"> 429 </span> : */ -<span class="lineNum"> 430 </span> : reverse_iterator -<span class="lineNum"> 431 </span> : rend() -<span class="lineNum"> 432 </span> : { return reverse_iterator(begin()); } -<span class="lineNum"> 433 </span> : -<span class="lineNum"> 434 </span> : /** -<span class="lineNum"> 435 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 436 </span> : * to one before the first element in the %vector. Iteration -<span class="lineNum"> 437 </span> : * is done in reverse element order. -<span class="lineNum"> 438 </span> : */ -<span class="lineNum"> 439 </span> : const_reverse_iterator -<span class="lineNum"> 440 </span> : rend() const -<span class="lineNum"> 441 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 442 </span> : -<span class="lineNum"> 443 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 444 </span> : /** -<span class="lineNum"> 445 </span> : * Returns a read-only (constant) iterator that points to the -<span class="lineNum"> 446 </span> : * first element in the %vector. Iteration is done in ordinary -<span class="lineNum"> 447 </span> : * element order. -<span class="lineNum"> 448 </span> : */ -<span class="lineNum"> 449 </span> : const_iterator -<span class="lineNum"> 450 </span> : cbegin() const -<span class="lineNum"> 451 </span> : { return const_iterator(this->_M_impl._M_start); } -<span class="lineNum"> 452 </span> : -<span class="lineNum"> 453 </span> : /** -<span class="lineNum"> 454 </span> : * Returns a read-only (constant) iterator that points one past -<span class="lineNum"> 455 </span> : * the last element in the %vector. Iteration is done in -<span class="lineNum"> 456 </span> : * ordinary element order. -<span class="lineNum"> 457 </span> : */ -<span class="lineNum"> 458 </span> : const_iterator -<span class="lineNum"> 459 </span> : cend() const -<span class="lineNum"> 460 </span> : { return const_iterator(this->_M_impl._M_finish); } -<span class="lineNum"> 461 </span> : -<span class="lineNum"> 462 </span> : /** -<span class="lineNum"> 463 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 464 </span> : * to the last element in the %vector. Iteration is done in -<span class="lineNum"> 465 </span> : * reverse element order. -<span class="lineNum"> 466 </span> : */ -<span class="lineNum"> 467 </span> : const_reverse_iterator -<span class="lineNum"> 468 </span> : crbegin() const -<span class="lineNum"> 469 </span> : { return const_reverse_iterator(end()); } -<span class="lineNum"> 470 </span> : -<span class="lineNum"> 471 </span> : /** -<span class="lineNum"> 472 </span> : * Returns a read-only (constant) reverse iterator that points -<span class="lineNum"> 473 </span> : * to one before the first element in the %vector. Iteration -<span class="lineNum"> 474 </span> : * is done in reverse element order. -<span class="lineNum"> 475 </span> : */ -<span class="lineNum"> 476 </span> : const_reverse_iterator -<span class="lineNum"> 477 </span> : crend() const -<span class="lineNum"> 478 </span> : { return const_reverse_iterator(begin()); } -<span class="lineNum"> 479 </span> : #endif -<span class="lineNum"> 480 </span> : -<span class="lineNum"> 481 </span> : // [23.2.4.2] capacity -<span class="lineNum"> 482 </span> : /** Returns the number of elements in the %vector. */ -<span class="lineNum"> 483 </span> : size_type -<span class="lineNum"> 484 </span><span class="lineCov"> 1028954 : size() const</span> -<span class="lineNum"> 485 </span><span class="lineCov"> 1028954 : { return size_type(this->_M_impl._M_finish - this->_M_impl._M_start); }</span> -<span class="lineNum"> 486 </span> : -<span class="lineNum"> 487 </span> : /** Returns the size() of the largest possible %vector. */ -<span class="lineNum"> 488 </span> : size_type -<span class="lineNum"> 489 </span><span class="lineCov"> 41426 : max_size() const</span> -<span class="lineNum"> 490 </span><span class="lineCov"> 41426 : { return _M_get_Tp_allocator().max_size(); }</span> -<span class="lineNum"> 491 </span> : -<span class="lineNum"> 492 </span> : /** -<span class="lineNum"> 493 </span> : * @brief Resizes the %vector to the specified number of elements. -<span class="lineNum"> 494 </span> : * @param new_size Number of elements the %vector should contain. -<span class="lineNum"> 495 </span> : * @param x Data with which new elements should be populated. -<span class="lineNum"> 496 </span> : * -<span class="lineNum"> 497 </span> : * This function will %resize the %vector to the specified -<span class="lineNum"> 498 </span> : * number of elements. If the number is smaller than the -<span class="lineNum"> 499 </span> : * %vector's current size the %vector is truncated, otherwise -<span class="lineNum"> 500 </span> : * the %vector is extended and new elements are populated with -<span class="lineNum"> 501 </span> : * given data. -<span class="lineNum"> 502 </span> : */ -<span class="lineNum"> 503 </span> : void -<span class="lineNum"> 504 </span><span class="lineCov"> 22443 : resize(size_type __new_size, value_type __x = value_type())</span> -<span class="lineNum"> 505 </span> : { -<span class="lineNum"> 506 </span><span class="lineCov"> 22443 : if (__new_size < size())</span> -<span class="lineNum"> 507 </span><span class="lineNoCov"> 0 : _M_erase_at_end(this->_M_impl._M_start + __new_size);</span> -<span class="lineNum"> 508 </span> : else -<span class="lineNum"> 509 </span><span class="lineCov"> 22443 : insert(end(), __new_size - size(), __x);</span> -<span class="lineNum"> 510 </span><span class="lineCov"> 22443 : }</span> -<span class="lineNum"> 511 </span> : -<span class="lineNum"> 512 </span> : /** -<span class="lineNum"> 513 </span> : * Returns the total number of elements that the %vector can -<span class="lineNum"> 514 </span> : * hold before needing to allocate more memory. -<span class="lineNum"> 515 </span> : */ -<span class="lineNum"> 516 </span> : size_type -<span class="lineNum"> 517 </span><span class="lineCov"> 10 : capacity() const</span> -<span class="lineNum"> 518 </span> : { return size_type(this->_M_impl._M_end_of_storage -<span class="lineNum"> 519 </span><span class="lineCov"> 10 : - this->_M_impl._M_start); }</span> -<span class="lineNum"> 520 </span> : -<span class="lineNum"> 521 </span> : /** -<span class="lineNum"> 522 </span> : * Returns true if the %vector is empty. (Thus begin() would -<span class="lineNum"> 523 </span> : * equal end().) -<span class="lineNum"> 524 </span> : */ -<span class="lineNum"> 525 </span> : bool -<span class="lineNum"> 526 </span><span class="lineCov"> 25 : empty() const</span> -<span class="lineNum"> 527 </span><span class="lineCov"> 25 : { return begin() == end(); }</span> -<span class="lineNum"> 528 </span> : -<span class="lineNum"> 529 </span> : /** -<span class="lineNum"> 530 </span> : * @brief Attempt to preallocate enough memory for specified number of -<span class="lineNum"> 531 </span> : * elements. -<span class="lineNum"> 532 </span> : * @param n Number of elements required. -<span class="lineNum"> 533 </span> : * @throw std::length_error If @a n exceeds @c max_size(). -<span class="lineNum"> 534 </span> : * -<span class="lineNum"> 535 </span> : * This function attempts to reserve enough memory for the -<span class="lineNum"> 536 </span> : * %vector to hold the specified number of elements. If the -<span class="lineNum"> 537 </span> : * number requested is more than max_size(), length_error is -<span class="lineNum"> 538 </span> : * thrown. -<span class="lineNum"> 539 </span> : * -<span class="lineNum"> 540 </span> : * The advantage of this function is that if optimal code is a -<span class="lineNum"> 541 </span> : * necessity and the user can determine the number of elements -<span class="lineNum"> 542 </span> : * that will be required, the user can reserve the memory in -<span class="lineNum"> 543 </span> : * %advance, and thus prevent a possible reallocation of memory -<span class="lineNum"> 544 </span> : * and copying of %vector data. -<span class="lineNum"> 545 </span> : */ -<span class="lineNum"> 546 </span> : void -<span class="lineNum"> 547 </span> : reserve(size_type __n); -<span class="lineNum"> 548 </span> : -<span class="lineNum"> 549 </span> : // element access -<span class="lineNum"> 550 </span> : /** -<span class="lineNum"> 551 </span> : * @brief Subscript access to the data contained in the %vector. -<span class="lineNum"> 552 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 553 </span> : * accessed. -<span class="lineNum"> 554 </span> : * @return Read/write reference to data. -<span class="lineNum"> 555 </span> : * -<span class="lineNum"> 556 </span> : * This operator allows for easy, array-style, data access. -<span class="lineNum"> 557 </span> : * Note that data access with this operator is unchecked and -<span class="lineNum"> 558 </span> : * out_of_range lookups are not defined. (For checked lookups -<span class="lineNum"> 559 </span> : * see at().) -<span class="lineNum"> 560 </span> : */ -<span class="lineNum"> 561 </span> : reference -<span class="lineNum"> 562 </span><span class="lineCov"> 256895 : operator[](size_type __n)</span> -<span class="lineNum"> 563 </span><span class="lineCov"> 256895 : { return *(this->_M_impl._M_start + __n); }</span> -<span class="lineNum"> 564 </span> : -<span class="lineNum"> 565 </span> : /** -<span class="lineNum"> 566 </span> : * @brief Subscript access to the data contained in the %vector. -<span class="lineNum"> 567 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 568 </span> : * accessed. -<span class="lineNum"> 569 </span> : * @return Read-only (constant) reference to data. -<span class="lineNum"> 570 </span> : * -<span class="lineNum"> 571 </span> : * This operator allows for easy, array-style, data access. -<span class="lineNum"> 572 </span> : * Note that data access with this operator is unchecked and -<span class="lineNum"> 573 </span> : * out_of_range lookups are not defined. (For checked lookups -<span class="lineNum"> 574 </span> : * see at().) -<span class="lineNum"> 575 </span> : */ -<span class="lineNum"> 576 </span> : const_reference -<span class="lineNum"> 577 </span><span class="lineCov"> 1925198 : operator[](size_type __n) const</span> -<span class="lineNum"> 578 </span><span class="lineCov"> 1925198 : { return *(this->_M_impl._M_start + __n); }</span> -<span class="lineNum"> 579 </span> : -<span class="lineNum"> 580 </span> : protected: -<span class="lineNum"> 581 </span> : /// Safety check used only from at(). -<span class="lineNum"> 582 </span> : void -<span class="lineNum"> 583 </span> : _M_range_check(size_type __n) const -<span class="lineNum"> 584 </span> : { -<span class="lineNum"> 585 </span> : if (__n >= this->size()) -<span class="lineNum"> 586 </span> : __throw_out_of_range(__N("vector::_M_range_check")); -<span class="lineNum"> 587 </span> : } -<span class="lineNum"> 588 </span> : -<span class="lineNum"> 589 </span> : public: -<span class="lineNum"> 590 </span> : /** -<span class="lineNum"> 591 </span> : * @brief Provides access to the data contained in the %vector. -<span class="lineNum"> 592 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 593 </span> : * accessed. -<span class="lineNum"> 594 </span> : * @return Read/write reference to data. -<span class="lineNum"> 595 </span> : * @throw std::out_of_range If @a n is an invalid index. -<span class="lineNum"> 596 </span> : * -<span class="lineNum"> 597 </span> : * This function provides for safer data access. The parameter -<span class="lineNum"> 598 </span> : * is first checked that it is in the range of the vector. The -<span class="lineNum"> 599 </span> : * function throws out_of_range if the check fails. -<span class="lineNum"> 600 </span> : */ -<span class="lineNum"> 601 </span> : reference -<span class="lineNum"> 602 </span> : at(size_type __n) -<span class="lineNum"> 603 </span> : { -<span class="lineNum"> 604 </span> : _M_range_check(__n); -<span class="lineNum"> 605 </span> : return (*this)[__n]; -<span class="lineNum"> 606 </span> : } -<span class="lineNum"> 607 </span> : -<span class="lineNum"> 608 </span> : /** -<span class="lineNum"> 609 </span> : * @brief Provides access to the data contained in the %vector. -<span class="lineNum"> 610 </span> : * @param n The index of the element for which data should be -<span class="lineNum"> 611 </span> : * accessed. -<span class="lineNum"> 612 </span> : * @return Read-only (constant) reference to data. -<span class="lineNum"> 613 </span> : * @throw std::out_of_range If @a n is an invalid index. -<span class="lineNum"> 614 </span> : * -<span class="lineNum"> 615 </span> : * This function provides for safer data access. The parameter -<span class="lineNum"> 616 </span> : * is first checked that it is in the range of the vector. The -<span class="lineNum"> 617 </span> : * function throws out_of_range if the check fails. -<span class="lineNum"> 618 </span> : */ -<span class="lineNum"> 619 </span> : const_reference -<span class="lineNum"> 620 </span> : at(size_type __n) const -<span class="lineNum"> 621 </span> : { -<span class="lineNum"> 622 </span> : _M_range_check(__n); -<span class="lineNum"> 623 </span> : return (*this)[__n]; -<span class="lineNum"> 624 </span> : } -<span class="lineNum"> 625 </span> : -<span class="lineNum"> 626 </span> : /** -<span class="lineNum"> 627 </span> : * Returns a read/write reference to the data at the first -<span class="lineNum"> 628 </span> : * element of the %vector. -<span class="lineNum"> 629 </span> : */ -<span class="lineNum"> 630 </span> : reference -<span class="lineNum"> 631 </span> : front() -<span class="lineNum"> 632 </span> : { return *begin(); } -<span class="lineNum"> 633 </span> : -<span class="lineNum"> 634 </span> : /** -<span class="lineNum"> 635 </span> : * Returns a read-only (constant) reference to the data at the first -<span class="lineNum"> 636 </span> : * element of the %vector. -<span class="lineNum"> 637 </span> : */ -<span class="lineNum"> 638 </span> : const_reference -<span class="lineNum"> 639 </span> : front() const -<span class="lineNum"> 640 </span> : { return *begin(); } -<span class="lineNum"> 641 </span> : -<span class="lineNum"> 642 </span> : /** -<span class="lineNum"> 643 </span> : * Returns a read/write reference to the data at the last -<span class="lineNum"> 644 </span> : * element of the %vector. -<span class="lineNum"> 645 </span> : */ -<span class="lineNum"> 646 </span> : reference -<span class="lineNum"> 647 </span><span class="lineCov"> 3 : back()</span> -<span class="lineNum"> 648 </span><span class="lineCov"> 3 : { return *(end() - 1); }</span> -<span class="lineNum"> 649 </span> : -<span class="lineNum"> 650 </span> : /** -<span class="lineNum"> 651 </span> : * Returns a read-only (constant) reference to the data at the -<span class="lineNum"> 652 </span> : * last element of the %vector. -<span class="lineNum"> 653 </span> : */ -<span class="lineNum"> 654 </span> : const_reference -<span class="lineNum"> 655 </span> : back() const -<span class="lineNum"> 656 </span> : { return *(end() - 1); } -<span class="lineNum"> 657 </span> : -<span class="lineNum"> 658 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 659 </span> : // DR 464. Suggestion for new member functions in standard containers. -<span class="lineNum"> 660 </span> : // data access -<span class="lineNum"> 661 </span> : /** -<span class="lineNum"> 662 </span> : * Returns a pointer such that [data(), data() + size()) is a valid -<span class="lineNum"> 663 </span> : * range. For a non-empty %vector, data() == &front(). -<span class="lineNum"> 664 </span> : */ -<span class="lineNum"> 665 </span> : pointer -<span class="lineNum"> 666 </span> : data() -<span class="lineNum"> 667 </span> : { return pointer(this->_M_impl._M_start); } -<span class="lineNum"> 668 </span> : -<span class="lineNum"> 669 </span> : const_pointer -<span class="lineNum"> 670 </span> : data() const -<span class="lineNum"> 671 </span> : { return const_pointer(this->_M_impl._M_start); } -<span class="lineNum"> 672 </span> : -<span class="lineNum"> 673 </span> : // [23.2.4.3] modifiers -<span class="lineNum"> 674 </span> : /** -<span class="lineNum"> 675 </span> : * @brief Add data to the end of the %vector. -<span class="lineNum"> 676 </span> : * @param x Data to be added. -<span class="lineNum"> 677 </span> : * -<span class="lineNum"> 678 </span> : * This is a typical stack operation. The function creates an -<span class="lineNum"> 679 </span> : * element at the end of the %vector and assigns the given data -<span class="lineNum"> 680 </span> : * to it. Due to the nature of a %vector this operation can be -<span class="lineNum"> 681 </span> : * done in constant time if the %vector has preallocated space -<span class="lineNum"> 682 </span> : * available. -<span class="lineNum"> 683 </span> : */ -<span class="lineNum"> 684 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 685 </span> : void -<span class="lineNum"> 686 </span><span class="lineCov"> 129213 : push_back(const value_type& __x)</span> -<span class="lineNum"> 687 </span> : { -<span class="lineNum"> 688 </span><span class="lineCov"> 129213 : if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage)</span> -<span class="lineNum"> 689 </span> : { -<span class="lineNum"> 690 </span><span class="lineCov"> 108914 : this->_M_impl.construct(this->_M_impl._M_finish, __x);</span> -<span class="lineNum"> 691 </span><span class="lineCov"> 108914 : ++this->_M_impl._M_finish;</span> -<span class="lineNum"> 692 </span> : } -<span class="lineNum"> 693 </span> : else -<span class="lineNum"> 694 </span><span class="lineCov"> 20299 : _M_insert_aux(end(), __x);</span> -<span class="lineNum"> 695 </span><span class="lineCov"> 129213 : }</span> -<span class="lineNum"> 696 </span> : #else -<span class="lineNum"> 697 </span> : template<typename... _Args> -<span class="lineNum"> 698 </span> : void -<span class="lineNum"> 699 </span> : push_back(_Args&&... __args) -<span class="lineNum"> 700 </span> : { -<span class="lineNum"> 701 </span> : if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage) -<span class="lineNum"> 702 </span> : { -<span class="lineNum"> 703 </span> : this->_M_impl.construct(this->_M_impl._M_finish, -<span class="lineNum"> 704 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 705 </span> : ++this->_M_impl._M_finish; -<span class="lineNum"> 706 </span> : } -<span class="lineNum"> 707 </span> : else -<span class="lineNum"> 708 </span> : _M_insert_aux(end(), std::forward<_Args>(__args)...); -<span class="lineNum"> 709 </span> : } -<span class="lineNum"> 710 </span> : #endif -<span class="lineNum"> 711 </span> : -<span class="lineNum"> 712 </span> : /** -<span class="lineNum"> 713 </span> : * @brief Removes last element. -<span class="lineNum"> 714 </span> : * -<span class="lineNum"> 715 </span> : * This is a typical stack operation. It shrinks the %vector by one. -<span class="lineNum"> 716 </span> : * -<span class="lineNum"> 717 </span> : * Note that no data is returned, and if the last element's -<span class="lineNum"> 718 </span> : * data is needed, it should be retrieved before pop_back() is -<span class="lineNum"> 719 </span> : * called. -<span class="lineNum"> 720 </span> : */ -<span class="lineNum"> 721 </span> : void -<span class="lineNum"> 722 </span><span class="lineCov"> 3 : pop_back()</span> -<span class="lineNum"> 723 </span> : { -<span class="lineNum"> 724 </span><span class="lineCov"> 3 : --this->_M_impl._M_finish;</span> -<span class="lineNum"> 725 </span><span class="lineCov"> 3 : this->_M_impl.destroy(this->_M_impl._M_finish);</span> -<span class="lineNum"> 726 </span><span class="lineCov"> 3 : }</span> -<span class="lineNum"> 727 </span> : -<span class="lineNum"> 728 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 729 </span> : /** -<span class="lineNum"> 730 </span> : * @brief Inserts an object in %vector before specified iterator. -<span class="lineNum"> 731 </span> : * @param position An iterator into the %vector. -<span class="lineNum"> 732 </span> : * @param args Arguments. -<span class="lineNum"> 733 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 734 </span> : * -<span class="lineNum"> 735 </span> : * This function will insert an object of type T constructed -<span class="lineNum"> 736 </span> : * with T(std::forward<Args>(args)...) before the specified location. -<span class="lineNum"> 737 </span> : * Note that this kind of operation could be expensive for a %vector -<span class="lineNum"> 738 </span> : * and if it is frequently used the user should consider using -<span class="lineNum"> 739 </span> : * std::list. -<span class="lineNum"> 740 </span> : */ -<span class="lineNum"> 741 </span> : template<typename... _Args> -<span class="lineNum"> 742 </span> : iterator -<span class="lineNum"> 743 </span> : emplace(iterator __position, _Args&&... __args); -<span class="lineNum"> 744 </span> : #endif -<span class="lineNum"> 745 </span> : -<span class="lineNum"> 746 </span> : /** -<span class="lineNum"> 747 </span> : * @brief Inserts given value into %vector before specified iterator. -<span class="lineNum"> 748 </span> : * @param position An iterator into the %vector. -<span class="lineNum"> 749 </span> : * @param x Data to be inserted. -<span class="lineNum"> 750 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 751 </span> : * -<span class="lineNum"> 752 </span> : * This function will insert a copy of the given value before -<span class="lineNum"> 753 </span> : * the specified location. Note that this kind of operation -<span class="lineNum"> 754 </span> : * could be expensive for a %vector and if it is frequently -<span class="lineNum"> 755 </span> : * used the user should consider using std::list. -<span class="lineNum"> 756 </span> : */ -<span class="lineNum"> 757 </span> : iterator -<span class="lineNum"> 758 </span> : insert(iterator __position, const value_type& __x); -<span class="lineNum"> 759 </span> : -<span class="lineNum"> 760 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 761 </span> : /** -<span class="lineNum"> 762 </span> : * @brief Inserts given rvalue into %vector before specified iterator. -<span class="lineNum"> 763 </span> : * @param position An iterator into the %vector. -<span class="lineNum"> 764 </span> : * @param x Data to be inserted. -<span class="lineNum"> 765 </span> : * @return An iterator that points to the inserted data. -<span class="lineNum"> 766 </span> : * -<span class="lineNum"> 767 </span> : * This function will insert a copy of the given rvalue before -<span class="lineNum"> 768 </span> : * the specified location. Note that this kind of operation -<span class="lineNum"> 769 </span> : * could be expensive for a %vector and if it is frequently -<span class="lineNum"> 770 </span> : * used the user should consider using std::list. -<span class="lineNum"> 771 </span> : */ -<span class="lineNum"> 772 </span> : iterator -<span class="lineNum"> 773 </span> : insert(iterator __position, value_type&& __x) -<span class="lineNum"> 774 </span> : { return emplace(__position, std::move(__x)); } -<span class="lineNum"> 775 </span> : #endif -<span class="lineNum"> 776 </span> : -<span class="lineNum"> 777 </span> : /** -<span class="lineNum"> 778 </span> : * @brief Inserts a number of copies of given data into the %vector. -<span class="lineNum"> 779 </span> : * @param position An iterator into the %vector. -<span class="lineNum"> 780 </span> : * @param n Number of elements to be inserted. -<span class="lineNum"> 781 </span> : * @param x Data to be inserted. -<span class="lineNum"> 782 </span> : * -<span class="lineNum"> 783 </span> : * This function will insert a specified number of copies of -<span class="lineNum"> 784 </span> : * the given data before the location specified by @a position. -<span class="lineNum"> 785 </span> : * -<span class="lineNum"> 786 </span> : * Note that this kind of operation could be expensive for a -<span class="lineNum"> 787 </span> : * %vector and if it is frequently used the user should -<span class="lineNum"> 788 </span> : * consider using std::list. -<span class="lineNum"> 789 </span> : */ -<span class="lineNum"> 790 </span> : void -<span class="lineNum"> 791 </span><span class="lineCov"> 22443 : insert(iterator __position, size_type __n, const value_type& __x)</span> -<span class="lineNum"> 792 </span><span class="lineCov"> 22443 : { _M_fill_insert(__position, __n, __x); }</span> -<span class="lineNum"> 793 </span> : -<span class="lineNum"> 794 </span> : /** -<span class="lineNum"> 795 </span> : * @brief Inserts a range into the %vector. -<span class="lineNum"> 796 </span> : * @param position An iterator into the %vector. -<span class="lineNum"> 797 </span> : * @param first An input iterator. -<span class="lineNum"> 798 </span> : * @param last An input iterator. -<span class="lineNum"> 799 </span> : * -<span class="lineNum"> 800 </span> : * This function will insert copies of the data in the range -<span class="lineNum"> 801 </span> : * [first,last) into the %vector before the location specified -<span class="lineNum"> 802 </span> : * by @a pos. -<span class="lineNum"> 803 </span> : * -<span class="lineNum"> 804 </span> : * Note that this kind of operation could be expensive for a -<span class="lineNum"> 805 </span> : * %vector and if it is frequently used the user should -<span class="lineNum"> 806 </span> : * consider using std::list. -<span class="lineNum"> 807 </span> : */ -<span class="lineNum"> 808 </span> : template<typename _InputIterator> -<span class="lineNum"> 809 </span> : void -<span class="lineNum"> 810 </span> : insert(iterator __position, _InputIterator __first, -<span class="lineNum"> 811 </span> : _InputIterator __last) -<span class="lineNum"> 812 </span> : { -<span class="lineNum"> 813 </span> : // Check whether it's an integral type. If so, it's not an iterator. -<span class="lineNum"> 814 </span> : typedef typename std::__is_integer<_InputIterator>::__type _Integral; -<span class="lineNum"> 815 </span> : _M_insert_dispatch(__position, __first, __last, _Integral()); -<span class="lineNum"> 816 </span> : } -<span class="lineNum"> 817 </span> : -<span class="lineNum"> 818 </span> : /** -<span class="lineNum"> 819 </span> : * @brief Remove element at given position. -<span class="lineNum"> 820 </span> : * @param position Iterator pointing to element to be erased. -<span class="lineNum"> 821 </span> : * @return An iterator pointing to the next element (or end()). -<span class="lineNum"> 822 </span> : * -<span class="lineNum"> 823 </span> : * This function will erase the element at the given position and thus -<span class="lineNum"> 824 </span> : * shorten the %vector by one. -<span class="lineNum"> 825 </span> : * -<span class="lineNum"> 826 </span> : * Note This operation could be expensive and if it is -<span class="lineNum"> 827 </span> : * frequently used the user should consider using std::list. -<span class="lineNum"> 828 </span> : * The user is also cautioned that this function only erases -<span class="lineNum"> 829 </span> : * the element, and that if the element is itself a pointer, -<span class="lineNum"> 830 </span> : * the pointed-to memory is not touched in any way. Managing -<span class="lineNum"> 831 </span> : * the pointer is the user's responsibility. -<span class="lineNum"> 832 </span> : */ -<span class="lineNum"> 833 </span> : iterator -<span class="lineNum"> 834 </span> : erase(iterator __position); -<span class="lineNum"> 835 </span> : -<span class="lineNum"> 836 </span> : /** -<span class="lineNum"> 837 </span> : * @brief Remove a range of elements. -<span class="lineNum"> 838 </span> : * @param first Iterator pointing to the first element to be erased. -<span class="lineNum"> 839 </span> : * @param last Iterator pointing to one past the last element to be -<span class="lineNum"> 840 </span> : * erased. -<span class="lineNum"> 841 </span> : * @return An iterator pointing to the element pointed to by @a last -<span class="lineNum"> 842 </span> : * prior to erasing (or end()). -<span class="lineNum"> 843 </span> : * -<span class="lineNum"> 844 </span> : * This function will erase the elements in the range [first,last) and -<span class="lineNum"> 845 </span> : * shorten the %vector accordingly. -<span class="lineNum"> 846 </span> : * -<span class="lineNum"> 847 </span> : * Note This operation could be expensive and if it is -<span class="lineNum"> 848 </span> : * frequently used the user should consider using std::list. -<span class="lineNum"> 849 </span> : * The user is also cautioned that this function only erases -<span class="lineNum"> 850 </span> : * the elements, and that if the elements themselves are -<span class="lineNum"> 851 </span> : * pointers, the pointed-to memory is not touched in any way. -<span class="lineNum"> 852 </span> : * Managing the pointer is the user's responsibility. -<span class="lineNum"> 853 </span> : */ -<span class="lineNum"> 854 </span> : iterator -<span class="lineNum"> 855 </span> : erase(iterator __first, iterator __last); -<span class="lineNum"> 856 </span> : -<span class="lineNum"> 857 </span> : /** -<span class="lineNum"> 858 </span> : * @brief Swaps data with another %vector. -<span class="lineNum"> 859 </span> : * @param x A %vector of the same element and allocator types. -<span class="lineNum"> 860 </span> : * -<span class="lineNum"> 861 </span> : * This exchanges the elements between two vectors in constant time. -<span class="lineNum"> 862 </span> : * (Three pointers, so it should be quite fast.) -<span class="lineNum"> 863 </span> : * Note that the global std::swap() function is specialized such that -<span class="lineNum"> 864 </span> : * std::swap(v1,v2) will feed to this function. -<span class="lineNum"> 865 </span> : */ -<span class="lineNum"> 866 </span> : void -<span class="lineNum"> 867 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 868 </span> : swap(vector&& __x) -<span class="lineNum"> 869 </span> : #else -<span class="lineNum"> 870 </span> : swap(vector& __x) -<span class="lineNum"> 871 </span> : #endif -<span class="lineNum"> 872 </span> : { -<span class="lineNum"> 873 </span> : std::swap(this->_M_impl._M_start, __x._M_impl._M_start); -<span class="lineNum"> 874 </span> : std::swap(this->_M_impl._M_finish, __x._M_impl._M_finish); -<span class="lineNum"> 875 </span> : std::swap(this->_M_impl._M_end_of_storage, -<span class="lineNum"> 876 </span> : __x._M_impl._M_end_of_storage); -<span class="lineNum"> 877 </span> : -<span class="lineNum"> 878 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 879 </span> : // 431. Swapping containers with unequal allocators. -<span class="lineNum"> 880 </span> : std::__alloc_swap<_Tp_alloc_type>::_S_do_it(_M_get_Tp_allocator(), -<span class="lineNum"> 881 </span> : __x._M_get_Tp_allocator()); -<span class="lineNum"> 882 </span> : } -<span class="lineNum"> 883 </span> : -<span class="lineNum"> 884 </span> : /** -<span class="lineNum"> 885 </span> : * Erases all the elements. Note that this function only erases the -<span class="lineNum"> 886 </span> : * elements, and that if the elements themselves are pointers, the -<span class="lineNum"> 887 </span> : * pointed-to memory is not touched in any way. Managing the pointer is -<span class="lineNum"> 888 </span> : * the user's responsibility. -<span class="lineNum"> 889 </span> : */ -<span class="lineNum"> 890 </span> : void -<span class="lineNum"> 891 </span><span class="lineCov"> 7856 : clear()</span> -<span class="lineNum"> 892 </span><span class="lineCov"> 7856 : { _M_erase_at_end(this->_M_impl._M_start); }</span> -<span class="lineNum"> 893 </span> : -<span class="lineNum"> 894 </span> : protected: -<span class="lineNum"> 895 </span> : /** -<span class="lineNum"> 896 </span> : * Memory expansion handler. Uses the member allocation function to -<span class="lineNum"> 897 </span> : * obtain @a n bytes of memory, and then copies [first,last) into it. -<span class="lineNum"> 898 </span> : */ -<span class="lineNum"> 899 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 900 </span> : pointer -<span class="lineNum"> 901 </span> : _M_allocate_and_copy(size_type __n, -<span class="lineNum"> 902 </span><span class="lineCov"> 10 : _ForwardIterator __first, _ForwardIterator __last)</span> -<span class="lineNum"> 903 </span> : { -<span class="lineNum"> 904 </span><span class="lineCov"> 10 : pointer __result = this->_M_allocate(__n);</span> -<span class="lineNum"> 905 </span> : try -<span class="lineNum"> 906 </span> : { -<span class="lineNum"> 907 </span><span class="lineCov"> 10 : std::__uninitialized_copy_a(__first, __last, __result,</span> -<span class="lineNum"> 908 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 909 </span><span class="lineCov"> 10 : return __result;</span> -<span class="lineNum"> 910 </span> : } -<span class="lineNum"> 911 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 912 </span> : { -<span class="lineNum"> 913 </span><span class="lineNoCov"> 0 : _M_deallocate(__result, __n);</span> -<span class="lineNum"> 914 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 915 </span> : } -<span class="lineNum"> 916 </span> : } -<span class="lineNum"> 917 </span> : -<span class="lineNum"> 918 </span> : -<span class="lineNum"> 919 </span> : // Internal constructor functions follow. -<span class="lineNum"> 920 </span> : -<span class="lineNum"> 921 </span> : // Called by the range constructor to implement [23.1.1]/9 -<span class="lineNum"> 922 </span> : -<span class="lineNum"> 923 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 924 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 925 </span> : template<typename _Integer> -<span class="lineNum"> 926 </span> : void -<span class="lineNum"> 927 </span> : _M_initialize_dispatch(_Integer __n, _Integer __value, __true_type) -<span class="lineNum"> 928 </span> : { -<span class="lineNum"> 929 </span> : this->_M_impl._M_start = _M_allocate(static_cast<size_type>(__n)); -<span class="lineNum"> 930 </span> : this->_M_impl._M_end_of_storage = -<span class="lineNum"> 931 </span> : this->_M_impl._M_start + static_cast<size_type>(__n); -<span class="lineNum"> 932 </span> : _M_fill_initialize(static_cast<size_type>(__n), __value); -<span class="lineNum"> 933 </span> : } -<span class="lineNum"> 934 </span> : -<span class="lineNum"> 935 </span> : // Called by the range constructor to implement [23.1.1]/9 -<span class="lineNum"> 936 </span> : template<typename _InputIterator> -<span class="lineNum"> 937 </span> : void -<span class="lineNum"> 938 </span> : _M_initialize_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 939 </span> : __false_type) -<span class="lineNum"> 940 </span> : { -<span class="lineNum"> 941 </span> : typedef typename std::iterator_traits<_InputIterator>:: -<span class="lineNum"> 942 </span> : iterator_category _IterCategory; -<span class="lineNum"> 943 </span> : _M_range_initialize(__first, __last, _IterCategory()); -<span class="lineNum"> 944 </span> : } -<span class="lineNum"> 945 </span> : -<span class="lineNum"> 946 </span> : // Called by the second initialize_dispatch above -<span class="lineNum"> 947 </span> : template<typename _InputIterator> -<span class="lineNum"> 948 </span> : void -<span class="lineNum"> 949 </span> : _M_range_initialize(_InputIterator __first, -<span class="lineNum"> 950 </span> : _InputIterator __last, std::input_iterator_tag) -<span class="lineNum"> 951 </span> : { -<span class="lineNum"> 952 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 953 </span> : push_back(*__first); -<span class="lineNum"> 954 </span> : } -<span class="lineNum"> 955 </span> : -<span class="lineNum"> 956 </span> : // Called by the second initialize_dispatch above -<span class="lineNum"> 957 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 958 </span> : void -<span class="lineNum"> 959 </span> : _M_range_initialize(_ForwardIterator __first, -<span class="lineNum"> 960 </span> : _ForwardIterator __last, std::forward_iterator_tag) -<span class="lineNum"> 961 </span> : { -<span class="lineNum"> 962 </span> : const size_type __n = std::distance(__first, __last); -<span class="lineNum"> 963 </span> : this->_M_impl._M_start = this->_M_allocate(__n); -<span class="lineNum"> 964 </span> : this->_M_impl._M_end_of_storage = this->_M_impl._M_start + __n; -<span class="lineNum"> 965 </span> : this->_M_impl._M_finish = -<span class="lineNum"> 966 </span> : std::__uninitialized_copy_a(__first, __last, -<span class="lineNum"> 967 </span> : this->_M_impl._M_start, -<span class="lineNum"> 968 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 969 </span> : } -<span class="lineNum"> 970 </span> : -<span class="lineNum"> 971 </span> : // Called by the first initialize_dispatch above and by the -<span class="lineNum"> 972 </span> : // vector(n,value,a) constructor. -<span class="lineNum"> 973 </span> : void -<span class="lineNum"> 974 </span><span class="lineCov"> 9 : _M_fill_initialize(size_type __n, const value_type& __value)</span> -<span class="lineNum"> 975 </span> : { -<span class="lineNum"> 976 </span><span class="lineCov"> 9 : std::__uninitialized_fill_n_a(this->_M_impl._M_start, __n, __value, </span> -<span class="lineNum"> 977 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 978 </span><span class="lineCov"> 9 : this->_M_impl._M_finish = this->_M_impl._M_end_of_storage;</span> -<span class="lineNum"> 979 </span><span class="lineCov"> 9 : }</span> -<span class="lineNum"> 980 </span> : -<span class="lineNum"> 981 </span> : -<span class="lineNum"> 982 </span> : // Internal assign functions follow. The *_aux functions do the actual -<span class="lineNum"> 983 </span> : // assignment work for the range versions. -<span class="lineNum"> 984 </span> : -<span class="lineNum"> 985 </span> : // Called by the range assign to implement [23.1.1]/9 -<span class="lineNum"> 986 </span> : -<span class="lineNum"> 987 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 988 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 989 </span> : template<typename _Integer> -<span class="lineNum"> 990 </span> : void -<span class="lineNum"> 991 </span> : _M_assign_dispatch(_Integer __n, _Integer __val, __true_type) -<span class="lineNum"> 992 </span> : { _M_fill_assign(__n, __val); } -<span class="lineNum"> 993 </span> : -<span class="lineNum"> 994 </span> : // Called by the range assign to implement [23.1.1]/9 -<span class="lineNum"> 995 </span> : template<typename _InputIterator> -<span class="lineNum"> 996 </span> : void -<span class="lineNum"> 997 </span> : _M_assign_dispatch(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 998 </span> : __false_type) -<span class="lineNum"> 999 </span> : { -<span class="lineNum"> 1000 </span> : typedef typename std::iterator_traits<_InputIterator>:: -<span class="lineNum"> 1001 </span> : iterator_category _IterCategory; -<span class="lineNum"> 1002 </span> : _M_assign_aux(__first, __last, _IterCategory()); -<span class="lineNum"> 1003 </span> : } -<span class="lineNum"> 1004 </span> : -<span class="lineNum"> 1005 </span> : // Called by the second assign_dispatch above -<span class="lineNum"> 1006 </span> : template<typename _InputIterator> -<span class="lineNum"> 1007 </span> : void -<span class="lineNum"> 1008 </span> : _M_assign_aux(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 1009 </span> : std::input_iterator_tag); -<span class="lineNum"> 1010 </span> : -<span class="lineNum"> 1011 </span> : // Called by the second assign_dispatch above -<span class="lineNum"> 1012 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1013 </span> : void -<span class="lineNum"> 1014 </span> : _M_assign_aux(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 1015 </span> : std::forward_iterator_tag); -<span class="lineNum"> 1016 </span> : -<span class="lineNum"> 1017 </span> : // Called by assign(n,t), and the range assign when it turns out -<span class="lineNum"> 1018 </span> : // to be the same thing. -<span class="lineNum"> 1019 </span> : void -<span class="lineNum"> 1020 </span> : _M_fill_assign(size_type __n, const value_type& __val); -<span class="lineNum"> 1021 </span> : -<span class="lineNum"> 1022 </span> : -<span class="lineNum"> 1023 </span> : // Internal insert functions follow. -<span class="lineNum"> 1024 </span> : -<span class="lineNum"> 1025 </span> : // Called by the range insert to implement [23.1.1]/9 -<span class="lineNum"> 1026 </span> : -<span class="lineNum"> 1027 </span> : // _GLIBCXX_RESOLVE_LIB_DEFECTS -<span class="lineNum"> 1028 </span> : // 438. Ambiguity in the "do the right thing" clause -<span class="lineNum"> 1029 </span> : template<typename _Integer> -<span class="lineNum"> 1030 </span> : void -<span class="lineNum"> 1031 </span> : _M_insert_dispatch(iterator __pos, _Integer __n, _Integer __val, -<span class="lineNum"> 1032 </span> : __true_type) -<span class="lineNum"> 1033 </span> : { _M_fill_insert(__pos, __n, __val); } -<span class="lineNum"> 1034 </span> : -<span class="lineNum"> 1035 </span> : // Called by the range insert to implement [23.1.1]/9 -<span class="lineNum"> 1036 </span> : template<typename _InputIterator> -<span class="lineNum"> 1037 </span> : void -<span class="lineNum"> 1038 </span> : _M_insert_dispatch(iterator __pos, _InputIterator __first, -<span class="lineNum"> 1039 </span> : _InputIterator __last, __false_type) -<span class="lineNum"> 1040 </span> : { -<span class="lineNum"> 1041 </span> : typedef typename std::iterator_traits<_InputIterator>:: -<span class="lineNum"> 1042 </span> : iterator_category _IterCategory; -<span class="lineNum"> 1043 </span> : _M_range_insert(__pos, __first, __last, _IterCategory()); -<span class="lineNum"> 1044 </span> : } -<span class="lineNum"> 1045 </span> : -<span class="lineNum"> 1046 </span> : // Called by the second insert_dispatch above -<span class="lineNum"> 1047 </span> : template<typename _InputIterator> -<span class="lineNum"> 1048 </span> : void -<span class="lineNum"> 1049 </span> : _M_range_insert(iterator __pos, _InputIterator __first, -<span class="lineNum"> 1050 </span> : _InputIterator __last, std::input_iterator_tag); -<span class="lineNum"> 1051 </span> : -<span class="lineNum"> 1052 </span> : // Called by the second insert_dispatch above -<span class="lineNum"> 1053 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 1054 </span> : void -<span class="lineNum"> 1055 </span> : _M_range_insert(iterator __pos, _ForwardIterator __first, -<span class="lineNum"> 1056 </span> : _ForwardIterator __last, std::forward_iterator_tag); -<span class="lineNum"> 1057 </span> : -<span class="lineNum"> 1058 </span> : // Called by insert(p,n,x), and the range insert when it turns out to be -<span class="lineNum"> 1059 </span> : // the same thing. -<span class="lineNum"> 1060 </span> : void -<span class="lineNum"> 1061 </span> : _M_fill_insert(iterator __pos, size_type __n, const value_type& __x); -<span class="lineNum"> 1062 </span> : -<span class="lineNum"> 1063 </span> : // Called by insert(p,x) -<span class="lineNum"> 1064 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1065 </span> : void -<span class="lineNum"> 1066 </span> : _M_insert_aux(iterator __position, const value_type& __x); -<span class="lineNum"> 1067 </span> : #else -<span class="lineNum"> 1068 </span> : template<typename... _Args> -<span class="lineNum"> 1069 </span> : void -<span class="lineNum"> 1070 </span> : _M_insert_aux(iterator __position, _Args&&... __args); -<span class="lineNum"> 1071 </span> : #endif -<span class="lineNum"> 1072 </span> : -<span class="lineNum"> 1073 </span> : // Called by the latter. -<span class="lineNum"> 1074 </span> : size_type -<span class="lineNum"> 1075 </span><span class="lineCov"> 20708 : _M_check_len(size_type __n, const char* __s) const</span> -<span class="lineNum"> 1076 </span> : { -<span class="lineNum"> 1077 </span><span class="lineCov"> 20708 : if (max_size() - size() < __n)</span> -<span class="lineNum"> 1078 </span><span class="lineNoCov"> 0 : __throw_length_error(__N(__s));</span> -<span class="lineNum"> 1079 </span> : -<span class="lineNum"> 1080 </span><span class="lineCov"> 20708 : const size_type __len = size() + std::max(size(), __n);</span> -<span class="lineNum"> 1081 </span><span class="lineCov"> 20708 : return (__len < size() || __len > max_size()) ? max_size() : __len;</span> -<span class="lineNum"> 1082 </span> : } -<span class="lineNum"> 1083 </span> : -<span class="lineNum"> 1084 </span> : // Internal erase functions follow. -<span class="lineNum"> 1085 </span> : -<span class="lineNum"> 1086 </span> : // Called by erase(q1,q2), clear(), resize(), _M_fill_assign, -<span class="lineNum"> 1087 </span> : // _M_assign_aux. -<span class="lineNum"> 1088 </span> : void -<span class="lineNum"> 1089 </span><span class="lineCov"> 7856 : _M_erase_at_end(pointer __pos)</span> -<span class="lineNum"> 1090 </span> : { -<span class="lineNum"> 1091 </span><span class="lineCov"> 7856 : std::_Destroy(__pos, this->_M_impl._M_finish, _M_get_Tp_allocator());</span> -<span class="lineNum"> 1092 </span><span class="lineCov"> 7856 : this->_M_impl._M_finish = __pos;</span> -<span class="lineNum"> 1093 </span><span class="lineCov"> 7856 : }</span> -<span class="lineNum"> 1094 </span> : }; -<span class="lineNum"> 1095 </span> : -<span class="lineNum"> 1096 </span> : -<span class="lineNum"> 1097 </span> : /** -<span class="lineNum"> 1098 </span> : * @brief Vector equality comparison. -<span class="lineNum"> 1099 </span> : * @param x A %vector. -<span class="lineNum"> 1100 </span> : * @param y A %vector of the same type as @a x. -<span class="lineNum"> 1101 </span> : * @return True iff the size and elements of the vectors are equal. -<span class="lineNum"> 1102 </span> : * -<span class="lineNum"> 1103 </span> : * This is an equivalence relation. It is linear in the size of the -<span class="lineNum"> 1104 </span> : * vectors. Vectors are considered equivalent if their sizes are equal, -<span class="lineNum"> 1105 </span> : * and if corresponding elements compare equal. -<span class="lineNum"> 1106 </span> : */ -<span class="lineNum"> 1107 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1108 </span> : inline bool -<span class="lineNum"> 1109 </span> : operator==(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1110 </span> : { return (__x.size() == __y.size() -<span class="lineNum"> 1111 </span> : && std::equal(__x.begin(), __x.end(), __y.begin())); } -<span class="lineNum"> 1112 </span> : -<span class="lineNum"> 1113 </span> : /** -<span class="lineNum"> 1114 </span> : * @brief Vector ordering relation. -<span class="lineNum"> 1115 </span> : * @param x A %vector. -<span class="lineNum"> 1116 </span> : * @param y A %vector of the same type as @a x. -<span class="lineNum"> 1117 </span> : * @return True iff @a x is lexicographically less than @a y. -<span class="lineNum"> 1118 </span> : * -<span class="lineNum"> 1119 </span> : * This is a total ordering relation. It is linear in the size of the -<span class="lineNum"> 1120 </span> : * vectors. The elements must be comparable with @c <. -<span class="lineNum"> 1121 </span> : * -<span class="lineNum"> 1122 </span> : * See std::lexicographical_compare() for how the determination is made. -<span class="lineNum"> 1123 </span> : */ -<span class="lineNum"> 1124 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1125 </span> : inline bool -<span class="lineNum"> 1126 </span> : operator<(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1127 </span> : { return std::lexicographical_compare(__x.begin(), __x.end(), -<span class="lineNum"> 1128 </span> : __y.begin(), __y.end()); } -<span class="lineNum"> 1129 </span> : -<span class="lineNum"> 1130 </span> : /// Based on operator== -<span class="lineNum"> 1131 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1132 </span> : inline bool -<span class="lineNum"> 1133 </span> : operator!=(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1134 </span> : { return !(__x == __y); } -<span class="lineNum"> 1135 </span> : -<span class="lineNum"> 1136 </span> : /// Based on operator< -<span class="lineNum"> 1137 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1138 </span> : inline bool -<span class="lineNum"> 1139 </span> : operator>(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1140 </span> : { return __y < __x; } -<span class="lineNum"> 1141 </span> : -<span class="lineNum"> 1142 </span> : /// Based on operator< -<span class="lineNum"> 1143 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1144 </span> : inline bool -<span class="lineNum"> 1145 </span> : operator<=(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1146 </span> : { return !(__y < __x); } -<span class="lineNum"> 1147 </span> : -<span class="lineNum"> 1148 </span> : /// Based on operator< -<span class="lineNum"> 1149 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1150 </span> : inline bool -<span class="lineNum"> 1151 </span> : operator>=(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1152 </span> : { return !(__x < __y); } -<span class="lineNum"> 1153 </span> : -<span class="lineNum"> 1154 </span> : /// See std::vector::swap(). -<span class="lineNum"> 1155 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1156 </span> : inline void -<span class="lineNum"> 1157 </span> : swap(vector<_Tp, _Alloc>& __x, vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1158 </span> : { __x.swap(__y); } -<span class="lineNum"> 1159 </span> : -<span class="lineNum"> 1160 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 1161 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1162 </span> : inline void -<span class="lineNum"> 1163 </span> : swap(vector<_Tp, _Alloc>&& __x, vector<_Tp, _Alloc>& __y) -<span class="lineNum"> 1164 </span> : { __x.swap(__y); } -<span class="lineNum"> 1165 </span> : -<span class="lineNum"> 1166 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 1167 </span> : inline void -<span class="lineNum"> 1168 </span> : swap(vector<_Tp, _Alloc>& __x, vector<_Tp, _Alloc>&& __y) -<span class="lineNum"> 1169 </span> : { __x.swap(__y); } -<span class="lineNum"> 1170 </span> : #endif -<span class="lineNum"> 1171 </span> : -<span class="lineNum"> 1172 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 1173 </span> : -<span class="lineNum"> 1174 </span> : #endif /* _STL_VECTOR_H */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/stream_iterator.h.gcov.html b/rep/usr/include/c++/4.3/bits/stream_iterator.h.gcov.html deleted file mode 100644 index e74322d..0000000 --- a/rep/usr/include/c++/4.3/bits/stream_iterator.h.gcov.html +++ /dev/null @@ -1,283 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/stream_iterator.h</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - stream_iterator.h</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">33</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">100.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">33</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Stream iterators -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2004, 2005 Free Software Foundation, Inc. -<span class="lineNum"> 4 </span> : // -<span class="lineNum"> 5 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 6 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 7 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 8 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 9 </span> : // any later version. -<span class="lineNum"> 10 </span> : -<span class="lineNum"> 11 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 12 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 13 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 14 </span> : // GNU General Public License for more details. -<span class="lineNum"> 15 </span> : -<span class="lineNum"> 16 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 17 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 18 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 19 </span> : // USA. -<span class="lineNum"> 20 </span> : -<span class="lineNum"> 21 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 22 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 23 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 24 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 25 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 26 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 27 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 28 </span> : // the GNU General Public License. -<span class="lineNum"> 29 </span> : -<span class="lineNum"> 30 </span> : /** @file stream_iterator.h -<span class="lineNum"> 31 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 32 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 33 </span> : */ -<span class="lineNum"> 34 </span> : -<span class="lineNum"> 35 </span> : #ifndef _STREAM_ITERATOR_H -<span class="lineNum"> 36 </span> : #define _STREAM_ITERATOR_H 1 -<span class="lineNum"> 37 </span> : -<span class="lineNum"> 38 </span> : #pragma GCC system_header -<span class="lineNum"> 39 </span> : -<span class="lineNum"> 40 </span> : #include <debug/debug.h> -<span class="lineNum"> 41 </span> : -<span class="lineNum"> 42 </span> : _GLIBCXX_BEGIN_NAMESPACE(std) -<span class="lineNum"> 43 </span> : -<span class="lineNum"> 44 </span> : /// Provides input iterator semantics for streams. -<span class="lineNum"> 45 </span> : template<typename _Tp, typename _CharT = char, -<span class="lineNum"> 46 </span> : typename _Traits = char_traits<_CharT>, typename _Dist = ptrdiff_t> -<span class="lineNum"> 47 </span> : class istream_iterator -<span class="lineNum"> 48 </span> : : public iterator<input_iterator_tag, _Tp, _Dist, const _Tp*, const _Tp&> -<span class="lineNum"> 49 </span><span class="lineCov"> 32 : {</span> -<span class="lineNum"> 50 </span> : public: -<span class="lineNum"> 51 </span> : typedef _CharT char_type; -<span class="lineNum"> 52 </span> : typedef _Traits traits_type; -<span class="lineNum"> 53 </span> : typedef basic_istream<_CharT, _Traits> istream_type; -<span class="lineNum"> 54 </span> : -<span class="lineNum"> 55 </span> : private: -<span class="lineNum"> 56 </span> : istream_type* _M_stream; -<span class="lineNum"> 57 </span> : _Tp _M_value; -<span class="lineNum"> 58 </span> : bool _M_ok; -<span class="lineNum"> 59 </span> : -<span class="lineNum"> 60 </span> : public: -<span class="lineNum"> 61 </span> : /// Construct end of input stream iterator. -<span class="lineNum"> 62 </span><span class="lineCov"> 16 : istream_iterator()</span> -<span class="lineNum"> 63 </span><span class="lineCov"> 16 : : _M_stream(0), _M_value(), _M_ok(false) {}</span> -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : /// Construct start of input stream iterator. -<span class="lineNum"> 66 </span><span class="lineCov"> 16 : istream_iterator(istream_type& __s)</span> -<span class="lineNum"> 67 </span><span class="lineCov"> 16 : : _M_stream(&__s)</span> -<span class="lineNum"> 68 </span><span class="lineCov"> 16 : { _M_read(); }</span> -<span class="lineNum"> 69 </span> : -<span class="lineNum"> 70 </span> : istream_iterator(const istream_iterator& __obj) -<span class="lineNum"> 71 </span> : : _M_stream(__obj._M_stream), _M_value(__obj._M_value), -<span class="lineNum"> 72 </span> : _M_ok(__obj._M_ok) -<span class="lineNum"> 73 </span> : { } -<span class="lineNum"> 74 </span> : -<span class="lineNum"> 75 </span> : const _Tp& -<span class="lineNum"> 76 </span><span class="lineCov"> 112 : operator*() const</span> -<span class="lineNum"> 77 </span> : { -<span class="lineNum"> 78 </span> : __glibcxx_requires_cond(_M_ok, -<span class="lineNum"> 79 </span> : _M_message(__gnu_debug::__msg_deref_istream) -<span class="lineNum"> 80 </span> : ._M_iterator(*this)); -<span class="lineNum"> 81 </span><span class="lineCov"> 112 : return _M_value;</span> -<span class="lineNum"> 82 </span> : } -<span class="lineNum"> 83 </span> : -<span class="lineNum"> 84 </span> : const _Tp* -<span class="lineNum"> 85 </span> : operator->() const { return &(operator*()); } -<span class="lineNum"> 86 </span> : -<span class="lineNum"> 87 </span> : istream_iterator& -<span class="lineNum"> 88 </span><span class="lineCov"> 64 : operator++()</span> -<span class="lineNum"> 89 </span> : { -<span class="lineNum"> 90 </span> : __glibcxx_requires_cond(_M_ok, -<span class="lineNum"> 91 </span> : _M_message(__gnu_debug::__msg_inc_istream) -<span class="lineNum"> 92 </span> : ._M_iterator(*this)); -<span class="lineNum"> 93 </span><span class="lineCov"> 64 : _M_read();</span> -<span class="lineNum"> 94 </span><span class="lineCov"> 64 : return *this;</span> -<span class="lineNum"> 95 </span> : } -<span class="lineNum"> 96 </span> : -<span class="lineNum"> 97 </span> : istream_iterator -<span class="lineNum"> 98 </span> : operator++(int) -<span class="lineNum"> 99 </span> : { -<span class="lineNum"> 100 </span> : __glibcxx_requires_cond(_M_ok, -<span class="lineNum"> 101 </span> : _M_message(__gnu_debug::__msg_inc_istream) -<span class="lineNum"> 102 </span> : ._M_iterator(*this)); -<span class="lineNum"> 103 </span> : istream_iterator __tmp = *this; -<span class="lineNum"> 104 </span> : _M_read(); -<span class="lineNum"> 105 </span> : return __tmp; -<span class="lineNum"> 106 </span> : } -<span class="lineNum"> 107 </span> : -<span class="lineNum"> 108 </span> : bool -<span class="lineNum"> 109 </span><span class="lineCov"> 80 : _M_equal(const istream_iterator& __x) const</span> -<span class="lineNum"> 110 </span><span class="lineCov"> 80 : { return (_M_ok == __x._M_ok) && (!_M_ok || _M_stream == __x._M_stream); }</span> -<span class="lineNum"> 111 </span> : -<span class="lineNum"> 112 </span> : private: -<span class="lineNum"> 113 </span> : void -<span class="lineNum"> 114 </span><span class="lineCov"> 80 : _M_read()</span> -<span class="lineNum"> 115 </span> : { -<span class="lineNum"> 116 </span><span class="lineCov"> 80 : _M_ok = (_M_stream && *_M_stream) ? true : false;</span> -<span class="lineNum"> 117 </span><span class="lineCov"> 80 : if (_M_ok)</span> -<span class="lineNum"> 118 </span> : { -<span class="lineNum"> 119 </span><span class="lineCov"> 80 : *_M_stream >> _M_value;</span> -<span class="lineNum"> 120 </span><span class="lineCov"> 80 : _M_ok = *_M_stream ? true : false;</span> -<span class="lineNum"> 121 </span> : } -<span class="lineNum"> 122 </span><span class="lineCov"> 80 : }</span> -<span class="lineNum"> 123 </span> : }; -<span class="lineNum"> 124 </span> : -<span class="lineNum"> 125 </span> : /// Return true if x and y are both end or not end, or x and y are the same. -<span class="lineNum"> 126 </span> : template<typename _Tp, typename _CharT, typename _Traits, typename _Dist> -<span class="lineNum"> 127 </span> : inline bool -<span class="lineNum"> 128 </span> : operator==(const istream_iterator<_Tp, _CharT, _Traits, _Dist>& __x, -<span class="lineNum"> 129 </span> : const istream_iterator<_Tp, _CharT, _Traits, _Dist>& __y) -<span class="lineNum"> 130 </span> : { return __x._M_equal(__y); } -<span class="lineNum"> 131 </span> : -<span class="lineNum"> 132 </span> : /// Return false if x and y are both end or not end, or x and y are the same. -<span class="lineNum"> 133 </span> : template <class _Tp, class _CharT, class _Traits, class _Dist> -<span class="lineNum"> 134 </span> : inline bool -<span class="lineNum"> 135 </span> : operator!=(const istream_iterator<_Tp, _CharT, _Traits, _Dist>& __x, -<span class="lineNum"> 136 </span><span class="lineCov"> 80 : const istream_iterator<_Tp, _CharT, _Traits, _Dist>& __y)</span> -<span class="lineNum"> 137 </span><span class="lineCov"> 80 : { return !__x._M_equal(__y); }</span> -<span class="lineNum"> 138 </span> : -<span class="lineNum"> 139 </span> : /** -<span class="lineNum"> 140 </span> : * @brief Provides output iterator semantics for streams. -<span class="lineNum"> 141 </span> : * -<span class="lineNum"> 142 </span> : * This class provides an iterator to write to an ostream. The type Tp is -<span class="lineNum"> 143 </span> : * the only type written by this iterator and there must be an -<span class="lineNum"> 144 </span> : * operator<<(Tp) defined. -<span class="lineNum"> 145 </span> : * -<span class="lineNum"> 146 </span> : * @param Tp The type to write to the ostream. -<span class="lineNum"> 147 </span> : * @param CharT The ostream char_type. -<span class="lineNum"> 148 </span> : * @param Traits The ostream char_traits. -<span class="lineNum"> 149 </span> : */ -<span class="lineNum"> 150 </span> : template<typename _Tp, typename _CharT = char, -<span class="lineNum"> 151 </span> : typename _Traits = char_traits<_CharT> > -<span class="lineNum"> 152 </span> : class ostream_iterator -<span class="lineNum"> 153 </span> : : public iterator<output_iterator_tag, void, void, void, void> -<span class="lineNum"> 154 </span> : { -<span class="lineNum"> 155 </span> : public: -<span class="lineNum"> 156 </span> : //@{ -<span class="lineNum"> 157 </span> : /// Public typedef -<span class="lineNum"> 158 </span> : typedef _CharT char_type; -<span class="lineNum"> 159 </span> : typedef _Traits traits_type; -<span class="lineNum"> 160 </span> : typedef basic_ostream<_CharT, _Traits> ostream_type; -<span class="lineNum"> 161 </span> : //@} -<span class="lineNum"> 162 </span> : -<span class="lineNum"> 163 </span> : private: -<span class="lineNum"> 164 </span> : ostream_type* _M_stream; -<span class="lineNum"> 165 </span> : const _CharT* _M_string; -<span class="lineNum"> 166 </span> : -<span class="lineNum"> 167 </span> : public: -<span class="lineNum"> 168 </span> : /// Construct from an ostream. -<span class="lineNum"> 169 </span> : ostream_iterator(ostream_type& __s) : _M_stream(&__s), _M_string(0) {} -<span class="lineNum"> 170 </span> : -<span class="lineNum"> 171 </span> : /** -<span class="lineNum"> 172 </span> : * Construct from an ostream. -<span class="lineNum"> 173 </span> : * -<span class="lineNum"> 174 </span> : * The delimiter string @a c is written to the stream after every Tp -<span class="lineNum"> 175 </span> : * written to the stream. The delimiter is not copied, and thus must -<span class="lineNum"> 176 </span> : * not be destroyed while this iterator is in use. -<span class="lineNum"> 177 </span> : * -<span class="lineNum"> 178 </span> : * @param s Underlying ostream to write to. -<span class="lineNum"> 179 </span> : * @param c CharT delimiter string to insert. -<span class="lineNum"> 180 </span> : */ -<span class="lineNum"> 181 </span><span class="lineCov"> 5 : ostream_iterator(ostream_type& __s, const _CharT* __c)</span> -<span class="lineNum"> 182 </span><span class="lineCov"> 5 : : _M_stream(&__s), _M_string(__c) { }</span> -<span class="lineNum"> 183 </span> : -<span class="lineNum"> 184 </span> : /// Copy constructor. -<span class="lineNum"> 185 </span><span class="lineCov"> 25 : ostream_iterator(const ostream_iterator& __obj)</span> -<span class="lineNum"> 186 </span><span class="lineCov"> 25 : : _M_stream(__obj._M_stream), _M_string(__obj._M_string) { }</span> -<span class="lineNum"> 187 </span> : -<span class="lineNum"> 188 </span> : /// Writes @a value to underlying ostream using operator<<. If -<span class="lineNum"> 189 </span> : /// constructed with delimiter string, writes delimiter to ostream. -<span class="lineNum"> 190 </span> : ostream_iterator& -<span class="lineNum"> 191 </span><span class="lineCov"> 8 : operator=(const _Tp& __value)</span> -<span class="lineNum"> 192 </span> : { -<span class="lineNum"> 193 </span> : __glibcxx_requires_cond(_M_stream != 0, -<span class="lineNum"> 194 </span> : _M_message(__gnu_debug::__msg_output_ostream) -<span class="lineNum"> 195 </span> : ._M_iterator(*this)); -<span class="lineNum"> 196 </span><span class="lineCov"> 8 : *_M_stream << __value;</span> -<span class="lineNum"> 197 </span><span class="lineCov"> 8 : if (_M_string) *_M_stream << _M_string;</span> -<span class="lineNum"> 198 </span><span class="lineCov"> 8 : return *this;</span> -<span class="lineNum"> 199 </span> : } -<span class="lineNum"> 200 </span> : -<span class="lineNum"> 201 </span> : ostream_iterator& -<span class="lineNum"> 202 </span><span class="lineCov"> 8 : operator*()</span> -<span class="lineNum"> 203 </span><span class="lineCov"> 8 : { return *this; }</span> -<span class="lineNum"> 204 </span> : -<span class="lineNum"> 205 </span> : ostream_iterator& -<span class="lineNum"> 206 </span><span class="lineCov"> 8 : operator++()</span> -<span class="lineNum"> 207 </span><span class="lineCov"> 8 : { return *this; }</span> -<span class="lineNum"> 208 </span> : -<span class="lineNum"> 209 </span> : ostream_iterator& -<span class="lineNum"> 210 </span> : operator++(int) -<span class="lineNum"> 211 </span> : { return *this; } -<span class="lineNum"> 212 </span> : }; -<span class="lineNum"> 213 </span> : -<span class="lineNum"> 214 </span> : _GLIBCXX_END_NAMESPACE -<span class="lineNum"> 215 </span> : -<span class="lineNum"> 216 </span> : #endif -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> diff --git a/rep/usr/include/c++/4.3/bits/vector.tcc.gcov.html b/rep/usr/include/c++/4.3/bits/vector.tcc.gcov.html deleted file mode 100644 index e0268a8..0000000 --- a/rep/usr/include/c++/4.3/bits/vector.tcc.gcov.html +++ /dev/null @@ -1,723 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> - -<html lang="en"> - -<head> - <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> - <title>LCOV - lcov.info - /usr/include/c++/4.3/bits/vector.tcc</title> - <link rel="stylesheet" type="text/css" href="../../../../../gcov.css"> -</head> - -<body> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="title">LTP GCOV extension - code coverage report</td></tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - - <tr> - <td width="100%"> - <table cellpadding=1 border=0 width="100%"> - <tr> - <td class="headerItem" width="20%">Current view:</td> - <td class="headerValue" width="80%" colspan=4><a href="../../../../../index.html">directory</a> - <a href="index.html">usr/include/c++/4.3/bits</a> - vector.tcc</td> - </tr> - <tr> - <td class="headerItem" width="20%">Test:</td> - <td class="headerValue" width="80%" colspan=4>lcov.info</td> - </tr> - <tr> - <td class="headerItem" width="20%">Date:</td> - <td class="headerValue" width="20%">2008-08-14</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Instrumented lines:</td> - <td class="headerValue" width="20%">96</td> - </tr> - <tr> - <td class="headerItem" width="20%">Code covered:</td> - <td class="headerValue" width="20%">75.0 %</td> - <td width="20%"></td> - <td class="headerItem" width="20%">Executed lines:</td> - <td class="headerValue" width="20%">72</td> - </tr> - </table> - </td> - </tr> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - </table> - - <table cellpadding=0 cellspacing=0 border=0> - <tr> - <td><br></td> - </tr> - <tr> - <td><pre class="source"> -<span class="lineNum"> 1 </span> : // Vector implementation (out of line) -*- C++ -*- -<span class="lineNum"> 2 </span> : -<span class="lineNum"> 3 </span> : // Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007 -<span class="lineNum"> 4 </span> : // Free Software Foundation, Inc. -<span class="lineNum"> 5 </span> : // -<span class="lineNum"> 6 </span> : // This file is part of the GNU ISO C++ Library. This library is free -<span class="lineNum"> 7 </span> : // software; you can redistribute it and/or modify it under the -<span class="lineNum"> 8 </span> : // terms of the GNU General Public License as published by the -<span class="lineNum"> 9 </span> : // Free Software Foundation; either version 2, or (at your option) -<span class="lineNum"> 10 </span> : // any later version. -<span class="lineNum"> 11 </span> : -<span class="lineNum"> 12 </span> : // This library is distributed in the hope that it will be useful, -<span class="lineNum"> 13 </span> : // but WITHOUT ANY WARRANTY; without even the implied warranty of -<span class="lineNum"> 14 </span> : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -<span class="lineNum"> 15 </span> : // GNU General Public License for more details. -<span class="lineNum"> 16 </span> : -<span class="lineNum"> 17 </span> : // You should have received a copy of the GNU General Public License along -<span class="lineNum"> 18 </span> : // with this library; see the file COPYING. If not, write to the Free -<span class="lineNum"> 19 </span> : // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -<span class="lineNum"> 20 </span> : // USA. -<span class="lineNum"> 21 </span> : -<span class="lineNum"> 22 </span> : // As a special exception, you may use this file as part of a free software -<span class="lineNum"> 23 </span> : // library without restriction. Specifically, if other files instantiate -<span class="lineNum"> 24 </span> : // templates or use macros or inline functions from this file, or you compile -<span class="lineNum"> 25 </span> : // this file and link it with other files to produce an executable, this -<span class="lineNum"> 26 </span> : // file does not by itself cause the resulting executable to be covered by -<span class="lineNum"> 27 </span> : // the GNU General Public License. This exception does not however -<span class="lineNum"> 28 </span> : // invalidate any other reasons why the executable file might be covered by -<span class="lineNum"> 29 </span> : // the GNU General Public License. -<span class="lineNum"> 30 </span> : -<span class="lineNum"> 31 </span> : /* -<span class="lineNum"> 32 </span> : * -<span class="lineNum"> 33 </span> : * Copyright (c) 1994 -<span class="lineNum"> 34 </span> : * Hewlett-Packard Company -<span class="lineNum"> 35 </span> : * -<span class="lineNum"> 36 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 37 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 38 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 39 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 40 </span> : * in supporting documentation. Hewlett-Packard Company makes no -<span class="lineNum"> 41 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 42 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 43 </span> : * -<span class="lineNum"> 44 </span> : * -<span class="lineNum"> 45 </span> : * Copyright (c) 1996 -<span class="lineNum"> 46 </span> : * Silicon Graphics Computer Systems, Inc. -<span class="lineNum"> 47 </span> : * -<span class="lineNum"> 48 </span> : * Permission to use, copy, modify, distribute and sell this software -<span class="lineNum"> 49 </span> : * and its documentation for any purpose is hereby granted without fee, -<span class="lineNum"> 50 </span> : * provided that the above copyright notice appear in all copies and -<span class="lineNum"> 51 </span> : * that both that copyright notice and this permission notice appear -<span class="lineNum"> 52 </span> : * in supporting documentation. Silicon Graphics makes no -<span class="lineNum"> 53 </span> : * representations about the suitability of this software for any -<span class="lineNum"> 54 </span> : * purpose. It is provided "as is" without express or implied warranty. -<span class="lineNum"> 55 </span> : */ -<span class="lineNum"> 56 </span> : -<span class="lineNum"> 57 </span> : /** @file vector.tcc -<span class="lineNum"> 58 </span> : * This is an internal header file, included by other library headers. -<span class="lineNum"> 59 </span> : * You should not attempt to use it directly. -<span class="lineNum"> 60 </span> : */ -<span class="lineNum"> 61 </span> : -<span class="lineNum"> 62 </span> : #ifndef _VECTOR_TCC -<span class="lineNum"> 63 </span> : #define _VECTOR_TCC 1 -<span class="lineNum"> 64 </span> : -<span class="lineNum"> 65 </span> : _GLIBCXX_BEGIN_NESTED_NAMESPACE(std, _GLIBCXX_STD_D) -<span class="lineNum"> 66 </span> : -<span class="lineNum"> 67 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 68 </span> : void -<span class="lineNum"> 69 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 70 </span><span class="lineCov"> 10 : reserve(size_type __n)</span> -<span class="lineNum"> 71 </span> : { -<span class="lineNum"> 72 </span><span class="lineCov"> 10 : if (__n > this->max_size())</span> -<span class="lineNum"> 73 </span><span class="lineNoCov"> 0 : __throw_length_error(__N("vector::reserve"));</span> -<span class="lineNum"> 74 </span><span class="lineCov"> 10 : if (this->capacity() < __n)</span> -<span class="lineNum"> 75 </span> : { -<span class="lineNum"> 76 </span><span class="lineCov"> 10 : const size_type __old_size = size();</span> -<span class="lineNum"> 77 </span> : pointer __tmp = _M_allocate_and_copy(__n, -<span class="lineNum"> 78 </span> : _GLIBCXX_MAKE_MOVE_ITERATOR(this->_M_impl._M_start), -<span class="lineNum"> 79 </span><span class="lineCov"> 10 : _GLIBCXX_MAKE_MOVE_ITERATOR(this->_M_impl._M_finish));</span> -<span class="lineNum"> 80 </span><span class="lineCov"> 10 : std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish,</span> -<span class="lineNum"> 81 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 82 </span><span class="lineCov"> 10 : _M_deallocate(this->_M_impl._M_start,</span> -<span class="lineNum"> 83 </span> : this->_M_impl._M_end_of_storage -<span class="lineNum"> 84 </span> : - this->_M_impl._M_start); -<span class="lineNum"> 85 </span><span class="lineCov"> 10 : this->_M_impl._M_start = __tmp;</span> -<span class="lineNum"> 86 </span><span class="lineCov"> 10 : this->_M_impl._M_finish = __tmp + __old_size;</span> -<span class="lineNum"> 87 </span><span class="lineCov"> 10 : this->_M_impl._M_end_of_storage = this->_M_impl._M_start + __n;</span> -<span class="lineNum"> 88 </span> : } -<span class="lineNum"> 89 </span><span class="lineCov"> 10 : }</span> -<span class="lineNum"> 90 </span> : -<span class="lineNum"> 91 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 92 </span> : typename vector<_Tp, _Alloc>::iterator -<span class="lineNum"> 93 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 94 </span><span class="lineCov"> 19 : insert(iterator __position, const value_type& __x)</span> -<span class="lineNum"> 95 </span> : { -<span class="lineNum"> 96 </span><span class="lineCov"> 19 : const size_type __n = __position - begin();</span> -<span class="lineNum"> 97 </span><span class="lineCov"> 19 : if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage</span> -<span class="lineNum"> 98 </span> : && __position == end()) -<span class="lineNum"> 99 </span> : { -<span class="lineNum"> 100 </span><span class="lineNoCov"> 0 : this->_M_impl.construct(this->_M_impl._M_finish, __x);</span> -<span class="lineNum"> 101 </span><span class="lineNoCov"> 0 : ++this->_M_impl._M_finish;</span> -<span class="lineNum"> 102 </span> : } -<span class="lineNum"> 103 </span> : else -<span class="lineNum"> 104 </span> : { -<span class="lineNum"> 105 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 106 </span> : if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage) -<span class="lineNum"> 107 </span> : { -<span class="lineNum"> 108 </span> : _Tp __x_copy = __x; -<span class="lineNum"> 109 </span> : _M_insert_aux(__position, std::move(__x_copy)); -<span class="lineNum"> 110 </span> : } -<span class="lineNum"> 111 </span> : else -<span class="lineNum"> 112 </span> : #endif -<span class="lineNum"> 113 </span><span class="lineCov"> 19 : _M_insert_aux(__position, __x);</span> -<span class="lineNum"> 114 </span> : } -<span class="lineNum"> 115 </span><span class="lineCov"> 19 : return iterator(this->_M_impl._M_start + __n);</span> -<span class="lineNum"> 116 </span> : } -<span class="lineNum"> 117 </span> : -<span class="lineNum"> 118 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 119 </span> : typename vector<_Tp, _Alloc>::iterator -<span class="lineNum"> 120 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 121 </span><span class="lineCov"> 2 : erase(iterator __position)</span> -<span class="lineNum"> 122 </span> : { -<span class="lineNum"> 123 </span><span class="lineCov"> 2 : if (__position + 1 != end())</span> -<span class="lineNum"> 124 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE3(__position + 1, end(), __position);</span> -<span class="lineNum"> 125 </span><span class="lineCov"> 2 : --this->_M_impl._M_finish;</span> -<span class="lineNum"> 126 </span><span class="lineCov"> 2 : this->_M_impl.destroy(this->_M_impl._M_finish);</span> -<span class="lineNum"> 127 </span><span class="lineCov"> 2 : return __position;</span> -<span class="lineNum"> 128 </span> : } -<span class="lineNum"> 129 </span> : -<span class="lineNum"> 130 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 131 </span> : typename vector<_Tp, _Alloc>::iterator -<span class="lineNum"> 132 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 133 </span> : erase(iterator __first, iterator __last) -<span class="lineNum"> 134 </span> : { -<span class="lineNum"> 135 </span> : if (__last != end()) -<span class="lineNum"> 136 </span> : _GLIBCXX_MOVE3(__last, end(), __first); -<span class="lineNum"> 137 </span> : _M_erase_at_end(__first.base() + (end() - __last)); -<span class="lineNum"> 138 </span> : return __first; -<span class="lineNum"> 139 </span> : } -<span class="lineNum"> 140 </span> : -<span class="lineNum"> 141 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 142 </span> : vector<_Tp, _Alloc>& -<span class="lineNum"> 143 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 144 </span> : operator=(const vector<_Tp, _Alloc>& __x) -<span class="lineNum"> 145 </span> : { -<span class="lineNum"> 146 </span> : if (&__x != this) -<span class="lineNum"> 147 </span> : { -<span class="lineNum"> 148 </span> : const size_type __xlen = __x.size(); -<span class="lineNum"> 149 </span> : if (__xlen > capacity()) -<span class="lineNum"> 150 </span> : { -<span class="lineNum"> 151 </span> : pointer __tmp = _M_allocate_and_copy(__xlen, __x.begin(), -<span class="lineNum"> 152 </span> : __x.end()); -<span class="lineNum"> 153 </span> : std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish, -<span class="lineNum"> 154 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 155 </span> : _M_deallocate(this->_M_impl._M_start, -<span class="lineNum"> 156 </span> : this->_M_impl._M_end_of_storage -<span class="lineNum"> 157 </span> : - this->_M_impl._M_start); -<span class="lineNum"> 158 </span> : this->_M_impl._M_start = __tmp; -<span class="lineNum"> 159 </span> : this->_M_impl._M_end_of_storage = this->_M_impl._M_start + __xlen; -<span class="lineNum"> 160 </span> : } -<span class="lineNum"> 161 </span> : else if (size() >= __xlen) -<span class="lineNum"> 162 </span> : { -<span class="lineNum"> 163 </span> : std::_Destroy(std::copy(__x.begin(), __x.end(), begin()), -<span class="lineNum"> 164 </span> : end(), _M_get_Tp_allocator()); -<span class="lineNum"> 165 </span> : } -<span class="lineNum"> 166 </span> : else -<span class="lineNum"> 167 </span> : { -<span class="lineNum"> 168 </span> : std::copy(__x._M_impl._M_start, __x._M_impl._M_start + size(), -<span class="lineNum"> 169 </span> : this->_M_impl._M_start); -<span class="lineNum"> 170 </span> : std::__uninitialized_copy_a(__x._M_impl._M_start + size(), -<span class="lineNum"> 171 </span> : __x._M_impl._M_finish, -<span class="lineNum"> 172 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 173 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 174 </span> : } -<span class="lineNum"> 175 </span> : this->_M_impl._M_finish = this->_M_impl._M_start + __xlen; -<span class="lineNum"> 176 </span> : } -<span class="lineNum"> 177 </span> : return *this; -<span class="lineNum"> 178 </span> : } -<span class="lineNum"> 179 </span> : -<span class="lineNum"> 180 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 181 </span> : void -<span class="lineNum"> 182 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 183 </span> : _M_fill_assign(size_t __n, const value_type& __val) -<span class="lineNum"> 184 </span> : { -<span class="lineNum"> 185 </span> : if (__n > capacity()) -<span class="lineNum"> 186 </span> : { -<span class="lineNum"> 187 </span> : vector __tmp(__n, __val, _M_get_Tp_allocator()); -<span class="lineNum"> 188 </span> : __tmp.swap(*this); -<span class="lineNum"> 189 </span> : } -<span class="lineNum"> 190 </span> : else if (__n > size()) -<span class="lineNum"> 191 </span> : { -<span class="lineNum"> 192 </span> : std::fill(begin(), end(), __val); -<span class="lineNum"> 193 </span> : std::__uninitialized_fill_n_a(this->_M_impl._M_finish, -<span class="lineNum"> 194 </span> : __n - size(), __val, -<span class="lineNum"> 195 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 196 </span> : this->_M_impl._M_finish += __n - size(); -<span class="lineNum"> 197 </span> : } -<span class="lineNum"> 198 </span> : else -<span class="lineNum"> 199 </span> : _M_erase_at_end(std::fill_n(this->_M_impl._M_start, __n, __val)); -<span class="lineNum"> 200 </span> : } -<span class="lineNum"> 201 </span> : -<span class="lineNum"> 202 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 203 </span> : template<typename _InputIterator> -<span class="lineNum"> 204 </span> : void -<span class="lineNum"> 205 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 206 </span> : _M_assign_aux(_InputIterator __first, _InputIterator __last, -<span class="lineNum"> 207 </span> : std::input_iterator_tag) -<span class="lineNum"> 208 </span> : { -<span class="lineNum"> 209 </span> : pointer __cur(this->_M_impl._M_start); -<span class="lineNum"> 210 </span> : for (; __first != __last && __cur != this->_M_impl._M_finish; -<span class="lineNum"> 211 </span> : ++__cur, ++__first) -<span class="lineNum"> 212 </span> : *__cur = *__first; -<span class="lineNum"> 213 </span> : if (__first == __last) -<span class="lineNum"> 214 </span> : _M_erase_at_end(__cur); -<span class="lineNum"> 215 </span> : else -<span class="lineNum"> 216 </span> : insert(end(), __first, __last); -<span class="lineNum"> 217 </span> : } -<span class="lineNum"> 218 </span> : -<span class="lineNum"> 219 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 220 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 221 </span> : void -<span class="lineNum"> 222 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 223 </span> : _M_assign_aux(_ForwardIterator __first, _ForwardIterator __last, -<span class="lineNum"> 224 </span> : std::forward_iterator_tag) -<span class="lineNum"> 225 </span> : { -<span class="lineNum"> 226 </span> : const size_type __len = std::distance(__first, __last); -<span class="lineNum"> 227 </span> : -<span class="lineNum"> 228 </span> : if (__len > capacity()) -<span class="lineNum"> 229 </span> : { -<span class="lineNum"> 230 </span> : pointer __tmp(_M_allocate_and_copy(__len, __first, __last)); -<span class="lineNum"> 231 </span> : std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish, -<span class="lineNum"> 232 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 233 </span> : _M_deallocate(this->_M_impl._M_start, -<span class="lineNum"> 234 </span> : this->_M_impl._M_end_of_storage -<span class="lineNum"> 235 </span> : - this->_M_impl._M_start); -<span class="lineNum"> 236 </span> : this->_M_impl._M_start = __tmp; -<span class="lineNum"> 237 </span> : this->_M_impl._M_finish = this->_M_impl._M_start + __len; -<span class="lineNum"> 238 </span> : this->_M_impl._M_end_of_storage = this->_M_impl._M_finish; -<span class="lineNum"> 239 </span> : } -<span class="lineNum"> 240 </span> : else if (size() >= __len) -<span class="lineNum"> 241 </span> : _M_erase_at_end(std::copy(__first, __last, this->_M_impl._M_start)); -<span class="lineNum"> 242 </span> : else -<span class="lineNum"> 243 </span> : { -<span class="lineNum"> 244 </span> : _ForwardIterator __mid = __first; -<span class="lineNum"> 245 </span> : std::advance(__mid, size()); -<span class="lineNum"> 246 </span> : std::copy(__first, __mid, this->_M_impl._M_start); -<span class="lineNum"> 247 </span> : this->_M_impl._M_finish = -<span class="lineNum"> 248 </span> : std::__uninitialized_copy_a(__mid, __last, -<span class="lineNum"> 249 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 250 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 251 </span> : } -<span class="lineNum"> 252 </span> : } -<span class="lineNum"> 253 </span> : -<span class="lineNum"> 254 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 255 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 256 </span> : template<typename... _Args> -<span class="lineNum"> 257 </span> : typename vector<_Tp, _Alloc>::iterator -<span class="lineNum"> 258 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 259 </span> : emplace(iterator __position, _Args&&... __args) -<span class="lineNum"> 260 </span> : { -<span class="lineNum"> 261 </span> : const size_type __n = __position - begin(); -<span class="lineNum"> 262 </span> : if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage -<span class="lineNum"> 263 </span> : && __position == end()) -<span class="lineNum"> 264 </span> : { -<span class="lineNum"> 265 </span> : this->_M_impl.construct(this->_M_impl._M_finish, -<span class="lineNum"> 266 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 267 </span> : ++this->_M_impl._M_finish; -<span class="lineNum"> 268 </span> : } -<span class="lineNum"> 269 </span> : else -<span class="lineNum"> 270 </span> : _M_insert_aux(__position, std::forward<_Args>(__args)...); -<span class="lineNum"> 271 </span> : return iterator(this->_M_impl._M_start + __n); -<span class="lineNum"> 272 </span> : } -<span class="lineNum"> 273 </span> : -<span class="lineNum"> 274 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 275 </span> : template<typename... _Args> -<span class="lineNum"> 276 </span> : void -<span class="lineNum"> 277 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 278 </span> : _M_insert_aux(iterator __position, _Args&&... __args) -<span class="lineNum"> 279 </span> : #else -<span class="lineNum"> 280 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 281 </span> : void -<span class="lineNum"> 282 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 283 </span><span class="lineCov"> 20651 : _M_insert_aux(iterator __position, const _Tp& __x)</span> -<span class="lineNum"> 284 </span> : #endif -<span class="lineNum"> 285 </span> : { -<span class="lineNum"> 286 </span><span class="lineCov"> 20651 : if (this->_M_impl._M_finish != this->_M_impl._M_end_of_storage)</span> -<span class="lineNum"> 287 </span> : { -<span class="lineNum"> 288 </span><span class="lineNoCov"> 0 : this->_M_impl.construct(this->_M_impl._M_finish,</span> -<span class="lineNum"> 289 </span> : _GLIBCXX_MOVE(*(this->_M_impl._M_finish -<span class="lineNum"> 290 </span> : - 1))); -<span class="lineNum"> 291 </span><span class="lineNoCov"> 0 : ++this->_M_impl._M_finish;</span> -<span class="lineNum"> 292 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 293 </span><span class="lineNoCov"> 0 : _Tp __x_copy = __x;</span> -<span class="lineNum"> 294 </span> : #endif -<span class="lineNum"> 295 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE_BACKWARD3(__position.base(),</span> -<span class="lineNum"> 296 </span> : this->_M_impl._M_finish - 2, -<span class="lineNum"> 297 </span> : this->_M_impl._M_finish - 1); -<span class="lineNum"> 298 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 299 </span><span class="lineNoCov"> 0 : *__position = __x_copy;</span> -<span class="lineNum"> 300 </span> : #else -<span class="lineNum"> 301 </span> : *__position = _Tp(std::forward<_Args>(__args)...); -<span class="lineNum"> 302 </span> : #endif -<span class="lineNum"> 303 </span> : } -<span class="lineNum"> 304 </span> : else -<span class="lineNum"> 305 </span> : { -<span class="lineNum"> 306 </span> : const size_type __len = -<span class="lineNum"> 307 </span><span class="lineCov"> 20651 : _M_check_len(size_type(1), "vector::_M_insert_aux");</span> -<span class="lineNum"> 308 </span><span class="lineCov"> 20651 : pointer __new_start(this->_M_allocate(__len));</span> -<span class="lineNum"> 309 </span><span class="lineCov"> 20651 : pointer __new_finish(__new_start);</span> -<span class="lineNum"> 310 </span> : try -<span class="lineNum"> 311 </span> : { -<span class="lineNum"> 312 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 313 </span> : this->_M_impl.construct(__new_start + (__position - begin()), -<span class="lineNum"> 314 </span> : std::forward<_Args>(__args)...); -<span class="lineNum"> 315 </span> : #endif -<span class="lineNum"> 316 </span><span class="lineCov"> 20651 : __new_finish =</span> -<span class="lineNum"> 317 </span> : std::__uninitialized_move_a(this->_M_impl._M_start, -<span class="lineNum"> 318 </span> : __position.base(), __new_start, -<span class="lineNum"> 319 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 320 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 321 </span><span class="lineCov"> 20651 : this->_M_impl.construct(__new_finish, __x);</span> -<span class="lineNum"> 322 </span> : #endif -<span class="lineNum"> 323 </span><span class="lineCov"> 20651 : ++__new_finish;</span> -<span class="lineNum"> 324 </span><span class="lineCov"> 20651 : __new_finish =</span> -<span class="lineNum"> 325 </span> : std::__uninitialized_move_a(__position.base(), -<span class="lineNum"> 326 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 327 </span> : __new_finish, -<span class="lineNum"> 328 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 329 </span> : } -<span class="lineNum"> 330 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 331 </span> : { -<span class="lineNum"> 332 </span><span class="lineNoCov"> 0 : std::_Destroy(__new_start, __new_finish, _M_get_Tp_allocator());</span> -<span class="lineNum"> 333 </span><span class="lineNoCov"> 0 : _M_deallocate(__new_start, __len);</span> -<span class="lineNum"> 334 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 335 </span> : } -<span class="lineNum"> 336 </span><span class="lineCov"> 20651 : std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish,</span> -<span class="lineNum"> 337 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 338 </span><span class="lineCov"> 20651 : _M_deallocate(this->_M_impl._M_start,</span> -<span class="lineNum"> 339 </span> : this->_M_impl._M_end_of_storage -<span class="lineNum"> 340 </span> : - this->_M_impl._M_start); -<span class="lineNum"> 341 </span><span class="lineCov"> 20651 : this->_M_impl._M_start = __new_start;</span> -<span class="lineNum"> 342 </span><span class="lineCov"> 20651 : this->_M_impl._M_finish = __new_finish;</span> -<span class="lineNum"> 343 </span><span class="lineCov"> 20651 : this->_M_impl._M_end_of_storage = __new_start + __len;</span> -<span class="lineNum"> 344 </span> : } -<span class="lineNum"> 345 </span><span class="lineCov"> 20651 : }</span> -<span class="lineNum"> 346 </span> : -<span class="lineNum"> 347 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 348 </span> : void -<span class="lineNum"> 349 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 350 </span><span class="lineCov"> 22443 : _M_fill_insert(iterator __position, size_type __n, const value_type& __x)</span> -<span class="lineNum"> 351 </span> : { -<span class="lineNum"> 352 </span><span class="lineCov"> 22443 : if (__n != 0)</span> -<span class="lineNum"> 353 </span> : { -<span class="lineNum"> 354 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 355 </span> : value_type __x_copy = __x; -<span class="lineNum"> 356 </span> : #endif -<span class="lineNum"> 357 </span><span class="lineCov"> 22443 : if (size_type(this->_M_impl._M_end_of_storage</span> -<span class="lineNum"> 358 </span> : - this->_M_impl._M_finish) >= __n) -<span class="lineNum"> 359 </span> : { -<span class="lineNum"> 360 </span> : #ifndef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 361 </span><span class="lineCov"> 22386 : value_type __x_copy = __x;</span> -<span class="lineNum"> 362 </span> : #endif -<span class="lineNum"> 363 </span><span class="lineCov"> 22386 : const size_type __elems_after = end() - __position;</span> -<span class="lineNum"> 364 </span><span class="lineCov"> 22386 : pointer __old_finish(this->_M_impl._M_finish);</span> -<span class="lineNum"> 365 </span><span class="lineCov"> 22386 : if (__elems_after > __n)</span> -<span class="lineNum"> 366 </span> : { -<span class="lineNum"> 367 </span><span class="lineNoCov"> 0 : std::__uninitialized_move_a(this->_M_impl._M_finish - __n,</span> -<span class="lineNum"> 368 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 369 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 370 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 371 </span><span class="lineNoCov"> 0 : this->_M_impl._M_finish += __n;</span> -<span class="lineNum"> 372 </span><span class="lineNoCov"> 0 : _GLIBCXX_MOVE_BACKWARD3(__position.base(),</span> -<span class="lineNum"> 373 </span> : __old_finish - __n, __old_finish); -<span class="lineNum"> 374 </span><span class="lineNoCov"> 0 : std::fill(__position.base(), __position.base() + __n,</span> -<span class="lineNum"> 375 </span> : __x_copy); -<span class="lineNum"> 376 </span> : } -<span class="lineNum"> 377 </span> : else -<span class="lineNum"> 378 </span> : { -<span class="lineNum"> 379 </span><span class="lineCov"> 22386 : std::__uninitialized_fill_n_a(this->_M_impl._M_finish,</span> -<span class="lineNum"> 380 </span> : __n - __elems_after, -<span class="lineNum"> 381 </span> : __x_copy, -<span class="lineNum"> 382 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 383 </span><span class="lineCov"> 22386 : this->_M_impl._M_finish += __n - __elems_after;</span> -<span class="lineNum"> 384 </span><span class="lineCov"> 22386 : std::__uninitialized_move_a(__position.base(), __old_finish,</span> -<span class="lineNum"> 385 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 386 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 387 </span><span class="lineCov"> 22386 : this->_M_impl._M_finish += __elems_after;</span> -<span class="lineNum"> 388 </span><span class="lineCov"> 22386 : std::fill(__position.base(), __old_finish, __x_copy);</span> -<span class="lineNum"> 389 </span> : } -<span class="lineNum"> 390 </span> : } -<span class="lineNum"> 391 </span> : else -<span class="lineNum"> 392 </span> : { -<span class="lineNum"> 393 </span> : const size_type __len = -<span class="lineNum"> 394 </span><span class="lineCov"> 57 : _M_check_len(__n, "vector::_M_fill_insert");</span> -<span class="lineNum"> 395 </span><span class="lineCov"> 57 : pointer __new_start(this->_M_allocate(__len));</span> -<span class="lineNum"> 396 </span><span class="lineCov"> 57 : pointer __new_finish(__new_start);</span> -<span class="lineNum"> 397 </span> : try -<span class="lineNum"> 398 </span> : { -<span class="lineNum"> 399 </span><span class="lineCov"> 57 : __new_finish =</span> -<span class="lineNum"> 400 </span> : std::__uninitialized_move_a(this->_M_impl._M_start, -<span class="lineNum"> 401 </span> : __position.base(), -<span class="lineNum"> 402 </span> : __new_start, -<span class="lineNum"> 403 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 404 </span> : #ifdef __GXX_EXPERIMENTAL_CXX0X__ -<span class="lineNum"> 405 </span> : std::__uninitialized_fill_n_a(__new_finish, __n, __x_copy, -<span class="lineNum"> 406 </span> : #else -<span class="lineNum"> 407 </span><span class="lineCov"> 57 : std::__uninitialized_fill_n_a(__new_finish, __n, __x,</span> -<span class="lineNum"> 408 </span> : #endif -<span class="lineNum"> 409 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 410 </span><span class="lineCov"> 57 : __new_finish += __n;</span> -<span class="lineNum"> 411 </span><span class="lineCov"> 57 : __new_finish =</span> -<span class="lineNum"> 412 </span> : std::__uninitialized_move_a(__position.base(), -<span class="lineNum"> 413 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 414 </span> : __new_finish, -<span class="lineNum"> 415 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 416 </span> : } -<span class="lineNum"> 417 </span><span class="lineNoCov"> 0 : catch(...)</span> -<span class="lineNum"> 418 </span> : { -<span class="lineNum"> 419 </span><span class="lineNoCov"> 0 : std::_Destroy(__new_start, __new_finish,</span> -<span class="lineNum"> 420 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 421 </span><span class="lineNoCov"> 0 : _M_deallocate(__new_start, __len);</span> -<span class="lineNum"> 422 </span><span class="lineNoCov"> 0 : __throw_exception_again;</span> -<span class="lineNum"> 423 </span> : } -<span class="lineNum"> 424 </span><span class="lineCov"> 57 : std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish,</span> -<span class="lineNum"> 425 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 426 </span><span class="lineCov"> 57 : _M_deallocate(this->_M_impl._M_start,</span> -<span class="lineNum"> 427 </span> : this->_M_impl._M_end_of_storage -<span class="lineNum"> 428 </span> : - this->_M_impl._M_start); -<span class="lineNum"> 429 </span><span class="lineCov"> 57 : this->_M_impl._M_start = __new_start;</span> -<span class="lineNum"> 430 </span><span class="lineCov"> 57 : this->_M_impl._M_finish = __new_finish;</span> -<span class="lineNum"> 431 </span><span class="lineCov"> 57 : this->_M_impl._M_end_of_storage = __new_start + __len;</span> -<span class="lineNum"> 432 </span> : } -<span class="lineNum"> 433 </span> : } -<span class="lineNum"> 434 </span><span class="lineCov"> 22443 : }</span> -<span class="lineNum"> 435 </span> : -<span class="lineNum"> 436 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 437 </span> : template<typename _InputIterator> -<span class="lineNum"> 438 </span> : void -<span class="lineNum"> 439 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 440 </span> : _M_range_insert(iterator __pos, _InputIterator __first, -<span class="lineNum"> 441 </span> : _InputIterator __last, std::input_iterator_tag) -<span class="lineNum"> 442 </span> : { -<span class="lineNum"> 443 </span> : for (; __first != __last; ++__first) -<span class="lineNum"> 444 </span> : { -<span class="lineNum"> 445 </span> : __pos = insert(__pos, *__first); -<span class="lineNum"> 446 </span> : ++__pos; -<span class="lineNum"> 447 </span> : } -<span class="lineNum"> 448 </span> : } -<span class="lineNum"> 449 </span> : -<span class="lineNum"> 450 </span> : template<typename _Tp, typename _Alloc> -<span class="lineNum"> 451 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 452 </span> : void -<span class="lineNum"> 453 </span> : vector<_Tp, _Alloc>:: -<span class="lineNum"> 454 </span> : _M_range_insert(iterator __position, _ForwardIterator __first, -<span class="lineNum"> 455 </span> : _ForwardIterator __last, std::forward_iterator_tag) -<span class="lineNum"> 456 </span> : { -<span class="lineNum"> 457 </span> : if (__first != __last) -<span class="lineNum"> 458 </span> : { -<span class="lineNum"> 459 </span> : const size_type __n = std::distance(__first, __last); -<span class="lineNum"> 460 </span> : if (size_type(this->_M_impl._M_end_of_storage -<span class="lineNum"> 461 </span> : - this->_M_impl._M_finish) >= __n) -<span class="lineNum"> 462 </span> : { -<span class="lineNum"> 463 </span> : const size_type __elems_after = end() - __position; -<span class="lineNum"> 464 </span> : pointer __old_finish(this->_M_impl._M_finish); -<span class="lineNum"> 465 </span> : if (__elems_after > __n) -<span class="lineNum"> 466 </span> : { -<span class="lineNum"> 467 </span> : std::__uninitialized_move_a(this->_M_impl._M_finish - __n, -<span class="lineNum"> 468 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 469 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 470 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 471 </span> : this->_M_impl._M_finish += __n; -<span class="lineNum"> 472 </span> : _GLIBCXX_MOVE_BACKWARD3(__position.base(), -<span class="lineNum"> 473 </span> : __old_finish - __n, __old_finish); -<span class="lineNum"> 474 </span> : std::copy(__first, __last, __position); -<span class="lineNum"> 475 </span> : } -<span class="lineNum"> 476 </span> : else -<span class="lineNum"> 477 </span> : { -<span class="lineNum"> 478 </span> : _ForwardIterator __mid = __first; -<span class="lineNum"> 479 </span> : std::advance(__mid, __elems_after); -<span class="lineNum"> 480 </span> : std::__uninitialized_copy_a(__mid, __last, -<span class="lineNum"> 481 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 482 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 483 </span> : this->_M_impl._M_finish += __n - __elems_after; -<span class="lineNum"> 484 </span> : std::__uninitialized_move_a(__position.base(), -<span class="lineNum"> 485 </span> : __old_finish, -<span class="lineNum"> 486 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 487 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 488 </span> : this->_M_impl._M_finish += __elems_after; -<span class="lineNum"> 489 </span> : std::copy(__first, __mid, __position); -<span class="lineNum"> 490 </span> : } -<span class="lineNum"> 491 </span> : } -<span class="lineNum"> 492 </span> : else -<span class="lineNum"> 493 </span> : { -<span class="lineNum"> 494 </span> : const size_type __len = -<span class="lineNum"> 495 </span> : _M_check_len(__n, "vector::_M_range_insert"); -<span class="lineNum"> 496 </span> : pointer __new_start(this->_M_allocate(__len)); -<span class="lineNum"> 497 </span> : pointer __new_finish(__new_start); -<span class="lineNum"> 498 </span> : try -<span class="lineNum"> 499 </span> : { -<span class="lineNum"> 500 </span> : __new_finish = -<span class="lineNum"> 501 </span> : std::__uninitialized_move_a(this->_M_impl._M_start, -<span class="lineNum"> 502 </span> : __position.base(), -<span class="lineNum"> 503 </span> : __new_start, -<span class="lineNum"> 504 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 505 </span> : __new_finish = -<span class="lineNum"> 506 </span> : std::__uninitialized_copy_a(__first, __last, -<span class="lineNum"> 507 </span> : __new_finish, -<span class="lineNum"> 508 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 509 </span> : __new_finish = -<span class="lineNum"> 510 </span> : std::__uninitialized_move_a(__position.base(), -<span class="lineNum"> 511 </span> : this->_M_impl._M_finish, -<span class="lineNum"> 512 </span> : __new_finish, -<span class="lineNum"> 513 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 514 </span> : } -<span class="lineNum"> 515 </span> : catch(...) -<span class="lineNum"> 516 </span> : { -<span class="lineNum"> 517 </span> : std::_Destroy(__new_start, __new_finish, -<span class="lineNum"> 518 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 519 </span> : _M_deallocate(__new_start, __len); -<span class="lineNum"> 520 </span> : __throw_exception_again; -<span class="lineNum"> 521 </span> : } -<span class="lineNum"> 522 </span> : std::_Destroy(this->_M_impl._M_start, this->_M_impl._M_finish, -<span class="lineNum"> 523 </span> : _M_get_Tp_allocator()); -<span class="lineNum"> 524 </span> : _M_deallocate(this->_M_impl._M_start, -<span class="lineNum"> 525 </span> : this->_M_impl._M_end_of_storage -<span class="lineNum"> 526 </span> : - this->_M_impl._M_start); -<span class="lineNum"> 527 </span> : this->_M_impl._M_start = __new_start; -<span class="lineNum"> 528 </span> : this->_M_impl._M_finish = __new_finish; -<span class="lineNum"> 529 </span> : this->_M_impl._M_end_of_storage = __new_start + __len; -<span class="lineNum"> 530 </span> : } -<span class="lineNum"> 531 </span> : } -<span class="lineNum"> 532 </span> : } -<span class="lineNum"> 533 </span> : -<span class="lineNum"> 534 </span> : -<span class="lineNum"> 535 </span> : // vector<bool> -<span class="lineNum"> 536 </span> : -<span class="lineNum"> 537 </span> : template<typename _Alloc> -<span class="lineNum"> 538 </span> : void -<span class="lineNum"> 539 </span> : vector<bool, _Alloc>:: -<span class="lineNum"> 540 </span> : reserve(size_type __n) -<span class="lineNum"> 541 </span> : { -<span class="lineNum"> 542 </span> : if (__n > this->max_size()) -<span class="lineNum"> 543 </span> : __throw_length_error(__N("vector::reserve")); -<span class="lineNum"> 544 </span> : if (this->capacity() < __n) -<span class="lineNum"> 545 </span> : { -<span class="lineNum"> 546 </span> : _Bit_type* __q = this->_M_allocate(__n); -<span class="lineNum"> 547 </span> : this->_M_impl._M_finish = _M_copy_aligned(begin(), end(), -<span class="lineNum"> 548 </span> : iterator(__q, 0)); -<span class="lineNum"> 549 </span> : this->_M_deallocate(); -<span class="lineNum"> 550 </span> : this->_M_impl._M_start = iterator(__q, 0); -<span class="lineNum"> 551 </span> : this->_M_impl._M_end_of_storage = (__q + (__n + int(_S_word_bit) - 1) -<span class="lineNum"> 552 </span> : / int(_S_word_bit)); -<span class="lineNum"> 553 </span> : } -<span class="lineNum"> 554 </span> : } -<span class="lineNum"> 555 </span> : -<span class="lineNum"> 556 </span> : template<typename _Alloc> -<span class="lineNum"> 557 </span> : void -<span class="lineNum"> 558 </span> : vector<bool, _Alloc>:: -<span class="lineNum"> 559 </span> : _M_fill_insert(iterator __position, size_type __n, bool __x) -<span class="lineNum"> 560 </span> : { -<span class="lineNum"> 561 </span> : if (__n == 0) -<span class="lineNum"> 562 </span> : return; -<span class="lineNum"> 563 </span> : if (capacity() - size() >= __n) -<span class="lineNum"> 564 </span> : { -<span class="lineNum"> 565 </span> : std::copy_backward(__position, end(), -<span class="lineNum"> 566 </span> : this->_M_impl._M_finish + difference_type(__n)); -<span class="lineNum"> 567 </span> : std::fill(__position, __position + difference_type(__n), __x); -<span class="lineNum"> 568 </span> : this->_M_impl._M_finish += difference_type(__n); -<span class="lineNum"> 569 </span> : } -<span class="lineNum"> 570 </span> : else -<span class="lineNum"> 571 </span> : { -<span class="lineNum"> 572 </span> : const size_type __len = -<span class="lineNum"> 573 </span> : _M_check_len(__n, "vector<bool>::_M_fill_insert"); -<span class="lineNum"> 574 </span> : _Bit_type * __q = this->_M_allocate(__len); -<span class="lineNum"> 575 </span> : iterator __i = _M_copy_aligned(begin(), __position, -<span class="lineNum"> 576 </span> : iterator(__q, 0)); -<span class="lineNum"> 577 </span> : std::fill(__i, __i + difference_type(__n), __x); -<span class="lineNum"> 578 </span> : this->_M_impl._M_finish = std::copy(__position, end(), -<span class="lineNum"> 579 </span> : __i + difference_type(__n)); -<span class="lineNum"> 580 </span> : this->_M_deallocate(); -<span class="lineNum"> 581 </span> : this->_M_impl._M_end_of_storage = (__q + ((__len -<span class="lineNum"> 582 </span> : + int(_S_word_bit) - 1) -<span class="lineNum"> 583 </span> : / int(_S_word_bit))); -<span class="lineNum"> 584 </span> : this->_M_impl._M_start = iterator(__q, 0); -<span class="lineNum"> 585 </span> : } -<span class="lineNum"> 586 </span> : } -<span class="lineNum"> 587 </span> : -<span class="lineNum"> 588 </span> : template<typename _Alloc> -<span class="lineNum"> 589 </span> : template<typename _ForwardIterator> -<span class="lineNum"> 590 </span> : void -<span class="lineNum"> 591 </span> : vector<bool, _Alloc>:: -<span class="lineNum"> 592 </span> : _M_insert_range(iterator __position, _ForwardIterator __first, -<span class="lineNum"> 593 </span> : _ForwardIterator __last, std::forward_iterator_tag) -<span class="lineNum"> 594 </span> : { -<span class="lineNum"> 595 </span> : if (__first != __last) -<span class="lineNum"> 596 </span> : { -<span class="lineNum"> 597 </span> : size_type __n = std::distance(__first, __last); -<span class="lineNum"> 598 </span> : if (capacity() - size() >= __n) -<span class="lineNum"> 599 </span> : { -<span class="lineNum"> 600 </span> : std::copy_backward(__position, end(), -<span class="lineNum"> 601 </span> : this->_M_impl._M_finish -<span class="lineNum"> 602 </span> : + difference_type(__n)); -<span class="lineNum"> 603 </span> : std::copy(__first, __last, __position); -<span class="lineNum"> 604 </span> : this->_M_impl._M_finish += difference_type(__n); -<span class="lineNum"> 605 </span> : } -<span class="lineNum"> 606 </span> : else -<span class="lineNum"> 607 </span> : { -<span class="lineNum"> 608 </span> : const size_type __len = -<span class="lineNum"> 609 </span> : _M_check_len(__n, "vector<bool>::_M_insert_range"); -<span class="lineNum"> 610 </span> : _Bit_type * __q = this->_M_allocate(__len); -<span class="lineNum"> 611 </span> : iterator __i = _M_copy_aligned(begin(), __position, -<span class="lineNum"> 612 </span> : iterator(__q, 0)); -<span class="lineNum"> 613 </span> : __i = std::copy(__first, __last, __i); -<span class="lineNum"> 614 </span> : this->_M_impl._M_finish = std::copy(__position, end(), __i); -<span class="lineNum"> 615 </span> : this->_M_deallocate(); -<span class="lineNum"> 616 </span> : this->_M_impl._M_end_of_storage = (__q -<span class="lineNum"> 617 </span> : + ((__len -<span class="lineNum"> 618 </span> : + int(_S_word_bit) - 1) -<span class="lineNum"> 619 </span> : / int(_S_word_bit))); -<span class="lineNum"> 620 </span> : this->_M_impl._M_start = iterator(__q, 0); -<span class="lineNum"> 621 </span> : } -<span class="lineNum"> 622 </span> : } -<span class="lineNum"> 623 </span> : } -<span class="lineNum"> 624 </span> : -<span class="lineNum"> 625 </span> : template<typename _Alloc> -<span class="lineNum"> 626 </span> : void -<span class="lineNum"> 627 </span> : vector<bool, _Alloc>:: -<span class="lineNum"> 628 </span><span class="lineCov"> 1 : _M_insert_aux(iterator __position, bool __x)</span> -<span class="lineNum"> 629 </span> : { -<span class="lineNum"> 630 </span><span class="lineCov"> 1 : if (this->_M_impl._M_finish._M_p != this->_M_impl._M_end_of_storage)</span> -<span class="lineNum"> 631 </span> : { -<span class="lineNum"> 632 </span><span class="lineNoCov"> 0 : std::copy_backward(__position, this->_M_impl._M_finish, </span> -<span class="lineNum"> 633 </span> : this->_M_impl._M_finish + 1); -<span class="lineNum"> 634 </span><span class="lineNoCov"> 0 : *__position = __x;</span> -<span class="lineNum"> 635 </span><span class="lineNoCov"> 0 : ++this->_M_impl._M_finish;</span> -<span class="lineNum"> 636 </span> : } -<span class="lineNum"> 637 </span> : else -<span class="lineNum"> 638 </span> : { -<span class="lineNum"> 639 </span> : const size_type __len = -<span class="lineNum"> 640 </span><span class="lineCov"> 1 : _M_check_len(size_type(1), "vector<bool>::_M_insert_aux");</span> -<span class="lineNum"> 641 </span><span class="lineCov"> 1 : _Bit_type * __q = this->_M_allocate(__len);</span> -<span class="lineNum"> 642 </span> : iterator __i = _M_copy_aligned(begin(), __position, -<span class="lineNum"> 643 </span><span class="lineCov"> 1 : iterator(__q, 0));</span> -<span class="lineNum"> 644 </span><span class="lineCov"> 1 : *__i++ = __x;</span> -<span class="lineNum"> 645 </span><span class="lineCov"> 1 : this->_M_impl._M_finish = std::copy(__position, end(), __i);</span> -<span class="lineNum"> 646 </span><span class="lineCov"> 1 : this->_M_deallocate();</span> -<span class="lineNum"> 647 </span><span class="lineCov"> 1 : this->_M_impl._M_end_of_storage = (__q + ((__len</span> -<span class="lineNum"> 648 </span> : + int(_S_word_bit) - 1) -<span class="lineNum"> 649 </span> : / int(_S_word_bit))); -<span class="lineNum"> 650 </span><span class="lineCov"> 1 : this->_M_impl._M_start = iterator(__q, 0);</span> -<span class="lineNum"> 651 </span> : } -<span class="lineNum"> 652 </span><span class="lineCov"> 1 : }</span> -<span class="lineNum"> 653 </span> : -<span class="lineNum"> 654 </span> : _GLIBCXX_END_NESTED_NAMESPACE -<span class="lineNum"> 655 </span> : -<span class="lineNum"> 656 </span> : #endif /* _VECTOR_TCC */ -</pre> - </td> - </tr> - </table> - <br> - - <table width="100%" border=0 cellspacing=0 cellpadding=0> - <tr><td class="ruler"><img src="../../../../../glass.png" width=3 height=3 alt=""></td></tr> - <tr><td class="versionInfo">Generated by: <a href="http://ltp.sourceforge.net/coverage/lcov.php" target="_parent">LTP GCOV extension version 1.6</a></td></tr> - </table> - <br> - -</body> -</html> |