Where Online Learning is simpler!
The C and C++ Include Header Files
/usr/include/c++/13/tr1/unordered_set.h
$ cat -n /usr/include/c++/13/tr1/unordered_set.h 1 // TR1 unordered_set implementation -*- C++ -*- 2 3 // Copyright (C) 2010-2023 Free Software Foundation, Inc. 4 // 5 // This file is part of the GNU ISO C++ Library. This library is free 6 // software; you can redistribute it and/or modify it under the 7 // terms of the GNU General Public License as published by the 8 // Free Software Foundation; either version 3, or (at your option) 9 // any later version. 10 11 // This library is distributed in the hope that it will be useful, 12 // but WITHOUT ANY WARRANTY; without even the implied warranty of 13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 // GNU General Public License for more details. 15 16 // Under Section 7 of GPL version 3, you are granted additional 17 // permissions described in the GCC Runtime Library Exception, version 18 // 3.1, as published by the Free Software Foundation. 19 20 // You should have received a copy of the GNU General Public License and 21 // a copy of the GCC Runtime Library Exception along with this program; 22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see 23 //
. 24 25 /** @file tr1/unordered_set.h 26 * This is an internal header file, included by other library headers. 27 * Do not attempt to use it directly. @headername{tr1/unordered_set} 28 */ 29 30 namespace std _GLIBCXX_VISIBILITY(default) 31 { 32 _GLIBCXX_BEGIN_NAMESPACE_VERSION 33 34 namespace tr1 35 { 36 // NB: When we get typedef templates these class definitions 37 // will be unnecessary. 38 template
, 40 class _Pred = std::equal_to<_Value>, 41 class _Alloc = std::allocator<_Value>, 42 bool __cache_hash_code = false> 43 class __unordered_set 44 : public _Hashtable<_Value, _Value, _Alloc, 45 std::_Identity<_Value>, _Pred, 46 _Hash, __detail::_Mod_range_hashing, 47 __detail::_Default_ranged_hash, 48 __detail::_Prime_rehash_policy, 49 __cache_hash_code, true, true> 50 { 51 typedef _Hashtable<_Value, _Value, _Alloc, 52 std::_Identity<_Value>, _Pred, 53 _Hash, __detail::_Mod_range_hashing, 54 __detail::_Default_ranged_hash, 55 __detail::_Prime_rehash_policy, 56 __cache_hash_code, true, true> 57 _Base; 58 59 public: 60 typedef typename _Base::size_type size_type; 61 typedef typename _Base::hasher hasher; 62 typedef typename _Base::key_equal key_equal; 63 typedef typename _Base::allocator_type allocator_type; 64 65 explicit 66 __unordered_set(size_type __n = 10, 67 const hasher& __hf = hasher(), 68 const key_equal& __eql = key_equal(), 69 const allocator_type& __a = allocator_type()) 70 : _Base(__n, __hf, __detail::_Mod_range_hashing(), 71 __detail::_Default_ranged_hash(), __eql, 72 std::_Identity<_Value>(), __a) 73 { } 74 75 template
76 __unordered_set(_InputIterator __f, _InputIterator __l, 77 size_type __n = 10, 78 const hasher& __hf = hasher(), 79 const key_equal& __eql = key_equal(), 80 const allocator_type& __a = allocator_type()) 81 : _Base(__f, __l, __n, __hf, __detail::_Mod_range_hashing(), 82 __detail::_Default_ranged_hash(), __eql, 83 std::_Identity<_Value>(), __a) 84 { } 85 }; 86 87 template
, 89 class _Pred = std::equal_to<_Value>, 90 class _Alloc = std::allocator<_Value>, 91 bool __cache_hash_code = false> 92 class __unordered_multiset 93 : public _Hashtable<_Value, _Value, _Alloc, 94 std::_Identity<_Value>, _Pred, 95 _Hash, __detail::_Mod_range_hashing, 96 __detail::_Default_ranged_hash, 97 __detail::_Prime_rehash_policy, 98 __cache_hash_code, true, false> 99 { 100 typedef _Hashtable<_Value, _Value, _Alloc, 101 std::_Identity<_Value>, _Pred, 102 _Hash, __detail::_Mod_range_hashing, 103 __detail::_Default_ranged_hash, 104 __detail::_Prime_rehash_policy, 105 __cache_hash_code, true, false> 106 _Base; 107 108 public: 109 typedef typename _Base::size_type size_type; 110 typedef typename _Base::hasher hasher; 111 typedef typename _Base::key_equal key_equal; 112 typedef typename _Base::allocator_type allocator_type; 113 114 explicit 115 __unordered_multiset(size_type __n = 10, 116 const hasher& __hf = hasher(), 117 const key_equal& __eql = key_equal(), 118 const allocator_type& __a = allocator_type()) 119 : _Base(__n, __hf, __detail::_Mod_range_hashing(), 120 __detail::_Default_ranged_hash(), __eql, 121 std::_Identity<_Value>(), __a) 122 { } 123 124 125 template
126 __unordered_multiset(_InputIterator __f, _InputIterator __l, 127 typename _Base::size_type __n = 0, 128 const hasher& __hf = hasher(), 129 const key_equal& __eql = key_equal(), 130 const allocator_type& __a = allocator_type()) 131 : _Base(__f, __l, __n, __hf, __detail::_Mod_range_hashing(), 132 __detail::_Default_ranged_hash(), __eql, 133 std::_Identity<_Value>(), __a) 134 { } 135 }; 136 137 template
139 inline void 140 swap(__unordered_set<_Value, _Hash, _Pred, _Alloc, __cache_hash_code>& __x, 141 __unordered_set<_Value, _Hash, _Pred, _Alloc, __cache_hash_code>& __y) 142 { __x.swap(__y); } 143 144 template
146 inline void 147 swap(__unordered_multiset<_Value, _Hash, _Pred, 148 _Alloc, __cache_hash_code>& __x, 149 __unordered_multiset<_Value, _Hash, _Pred, 150 _Alloc, __cache_hash_code>& __y) 151 { __x.swap(__y); } 152 153 154 /** 155 * @brief A standard container composed of unique keys (containing 156 * at most one of each key value) in which the elements' keys are 157 * the elements themselves. 158 * 159 * @ingroup unordered_associative_containers 160 * 161 * Meets the requirements of a
container
, and 162 *
unordered associative container
163 * 164 * @param Value Type of key objects. 165 * @param Hash Hashing function object type, defaults to hash
. 166 * @param Pred Predicate function object type, defaults to equal_to
. 167 * @param Alloc Allocator type, defaults to allocator
. 168 */ 169 template
, 171 class _Pred = std::equal_to<_Value>, 172 class _Alloc = std::allocator<_Value> > 173 class unordered_set 174 : public __unordered_set<_Value, _Hash, _Pred, _Alloc> 175 { 176 typedef __unordered_set<_Value, _Hash, _Pred, _Alloc> _Base; 177 178 public: 179 typedef typename _Base::value_type value_type; 180 typedef typename _Base::size_type size_type; 181 typedef typename _Base::hasher hasher; 182 typedef typename _Base::key_equal key_equal; 183 typedef typename _Base::allocator_type allocator_type; 184 185 explicit 186 unordered_set(size_type __n = 10, 187 const hasher& __hf = hasher(), 188 const key_equal& __eql = key_equal(), 189 const allocator_type& __a = allocator_type()) 190 : _Base(__n, __hf, __eql, __a) 191 { } 192 193 template
194 unordered_set(_InputIterator __f, _InputIterator __l, 195 size_type __n = 10, 196 const hasher& __hf = hasher(), 197 const key_equal& __eql = key_equal(), 198 const allocator_type& __a = allocator_type()) 199 : _Base(__f, __l, __n, __hf, __eql, __a) 200 { } 201 }; 202 203 /** 204 * @brief A standard container composed of equivalent keys 205 * (possibly containing multiple of each key value) in which the 206 * elements' keys are the elements themselves. 207 * 208 * @ingroup unordered_associative_containers 209 * 210 * Meets the requirements of a
container
, and 211 *
unordered associative container
212 * 213 * @param Value Type of key objects. 214 * @param Hash Hashing function object type, defaults to hash
. 215 * @param Pred Predicate function object type, defaults to equal_to
. 216 * @param Alloc Allocator type, defaults to allocator
. 217 */ 218 template
, 220 class _Pred = std::equal_to<_Value>, 221 class _Alloc = std::allocator<_Value> > 222 class unordered_multiset 223 : public __unordered_multiset<_Value, _Hash, _Pred, _Alloc> 224 { 225 typedef __unordered_multiset<_Value, _Hash, _Pred, _Alloc> _Base; 226 227 public: 228 typedef typename _Base::value_type value_type; 229 typedef typename _Base::size_type size_type; 230 typedef typename _Base::hasher hasher; 231 typedef typename _Base::key_equal key_equal; 232 typedef typename _Base::allocator_type allocator_type; 233 234 explicit 235 unordered_multiset(size_type __n = 10, 236 const hasher& __hf = hasher(), 237 const key_equal& __eql = key_equal(), 238 const allocator_type& __a = allocator_type()) 239 : _Base(__n, __hf, __eql, __a) 240 { } 241 242 243 template
244 unordered_multiset(_InputIterator __f, _InputIterator __l, 245 typename _Base::size_type __n = 0, 246 const hasher& __hf = hasher(), 247 const key_equal& __eql = key_equal(), 248 const allocator_type& __a = allocator_type()) 249 : _Base(__f, __l, __n, __hf, __eql, __a) 250 { } 251 }; 252 253 template
254 inline void 255 swap(unordered_set<_Value, _Hash, _Pred, _Alloc>& __x, 256 unordered_set<_Value, _Hash, _Pred, _Alloc>& __y) 257 { __x.swap(__y); } 258 259 template
260 inline void 261 swap(unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __x, 262 unordered_multiset<_Value, _Hash, _Pred, _Alloc>& __y) 263 { __x.swap(__y); } 264 } 265 266 _GLIBCXX_END_NAMESPACE_VERSION 267 }
Contact us
|
About us
|
Term of use
|
Copyright © 2000-2025 MyWebUniversity.com ™