984ded41708df39b4a4b338c89e539e611eaa27c
[gcc.git] / libstdc++-v3 / ChangeLog
1 2006-09-18 Paolo Carlini <pcarlini@suse.de>
2
3 * include/bits/locale_facets.tcc (_M_group_int): Remove
4 redundant using-declaration.
5
6 2006-09-18 Benjamin Kosnik <bkoz@redhat.com>
7
8 * include/ext/typelist.h (cond_type): Remove, use __conditional_type.
9
10 2006-09-18 Benjamin Kosnik <bkoz@redhat.com>
11 Peter Doerfler <gcc@pdoerfler.com>
12 Paolo Carlini <pcarlini@suse.de>
13
14 * include/ext/type_traits.h: New.
15 (__conditional_type): New.
16 (__numeric_traits): New.
17 (__add_unsigned): New.
18 (__remove_unsigned): New.
19 (__enable_if): New.
20 * include/Makefile.am: Add.
21 * include/Makefile.in: Regenerate.
22 * include/ext/pb_ds/detail/type_utils.hpp: Use ext include,
23 remove duplicates.
24 * include/tr1/hashtable_policy.h (IF): Use __conditional_type.
25 (_Max_digits10): Same.
26 (identity): Use _Identity.
27 (extract1st): Use _Select1st.
28 * include/tr1/random (_Select): Use __conditional_type.
29 (_To_Unsigned_Type): Use __add_unsigned. Linebreak fixups.
30 * include/bits/locale_facets.tcc (__to_unsigned_type): Remove, use
31 __add_unsigned.
32 * include/tr1/random.tcc: Fixups as above.
33 * include/tr1/unordered_map: Same.
34 * include/tr1/hashtable: Same.
35 * include/tr1/unordered_set: Same.
36 * include/ext/pb_ds/detail/gp_hash_table_map_/
37 standard_policies.hpp: Same.
38 * include/ext/pb_ds/detail/standard_policies.hpp: Same.
39 * include/ext/pb_ds/detail/typelist/typelist_filter.hpp: Same.
40 * include/ext/pb_ds/detail/binary_heap_/binary_heap_.hpp: Same.
41 * include/ext/pb_ds/detail/type_utils.hpp: Same.
42 * include/ext/pb_ds/trie_policy.hpp: Same.
43 * docs/html/ext/pb_ds/string_trie_e_access_traits.html: Same.
44
45 * include/bits/cpp_type_traits.h (__enable_if): Move to ext, make
46 boolean argument first.
47 * include/bits/locale_facets.h: Fixups for __enable_if argument
48 and namespace switch.
49 * include/bits/stl_algobase.h: Same.
50 * include/bits/stl_algo.h: Same.
51 * include/bits/stl_iterator.h: Same.
52 * include/bits/streambuf_iterator.h: Same.
53 * include/debug/safe_iterator.h: Same.
54 * include/tr1/hashtable_policy.h: Same.
55 * include/tr1/cmath: Same.
56 * include/tr1/functional: Same.
57 * include/tr1/functional_iterate.h: Same.
58 * include/std/std_streambuf.h: Same.
59 * include/c_std/std_cmath.h: Same.
60 * testsuite/util/testsuite_tr1.h: Same.
61 * testsuite/util/performance/assoc/multimap_common_type.hpp: Same.
62
63 2006-09-18 Paolo Carlini <pcarlini@suse.de>
64
65 PR libstdc++/29063
66 * include/bits/valarray_array.h: Fix typo, undefine
67 _DEFINE_ARRAY_FUNCTION.
68 * include/std/std_valarray.h: Undefine _DEFINE_BINARY_OPERATOR.
69
70 2006-09-14 Benjamin Kosnik <bkoz@redhat.com>
71
72 * include/bits/concurrence.h (__mutex::__mutex): Pass address of
73 mutex to *_MUTEX_INIT_FUNCTION.
74
75 2006-09-13 Benjamin Kosnik <bkoz@redhat.com>
76
77 * include/bits/atomicity.h: Move to...
78 * include/ext/atomicity.h: ...here.
79 * include/bits/concurrence.h: Move to...
80 * include/ext/concurrence.h: ...here.
81 * include/Makefile.am (ext_headers): Additions.
82 (bits_headers): Subtractions.
83 * include/Makefile.in: Regenerate.
84
85 * include/ext/bitmap_allocator.h (_Mutex), __threads_enabled,
86 _Lock, _Auto_Lock): Subsume into...
87 * include/bits/concurrence.h (__mutex): ..this. Error check
88 locking and unlocking.
89 (lock): Uglify to...
90 (__scoped_lock): Use __mutex.
91 (__glibcxx_mutex_define_initialized): Remove.
92 (__glibcxx_mutex_type): Remove.
93
94 * include/tr1/boost_shared_ptr.h: Formating tweaks, adjustments.
95 (_Lock_policy): Move from here...
96 * include/ext/concurrence.h: ... to here.
97 (__shared_ptr_default_lock_mode): To __default_lock_policy.
98 (_S_lockfree): To _S_atomic.
99 Document.
100
101 * libsupc++/guard.cc (static_mutex): Subsume into and fixup for...
102 * include/ext/concurrence.h (__recursive_mutex): ...this. Error
103 check locking and unlocking.
104 * libsupc++/eh_alloc.cc: Use __scoped_lock.
105
106 * config/os/aix/atomicity.h: Fixups for include paths, mutex to
107 __scoped_mutex change, removal of locking defines.
108 * config/os/irix/atomicity.h: Same.
109 * config/cpu/cris/atomicity.h: Same.
110 * config/cpu/m68k/atomicity.h: Same.
111 * config/cpu/hppa/atomicity.h: Same.
112 * config/cpu/mips/atomicity.h: Same.
113 * config/cpu/sparc/atomicity.h: Same.
114 * config/cpu/i386/atomicity.h: Same.
115 * config/cpu/i486/atomicity.h: Same.
116 * config/cpu/sh/atomicity.h: Same.
117 * config/cpu/generic/atomicity_mutex/atomicity.h: Same.
118 * include/ext/pool_allocator.h: Same.
119 * include/ext/bitmap_allocator.h: Same.
120 * include/ext/rc_string_base.h: Same.
121 * include/ext/mt_allocator.h: Same.
122 * include/bits/locale_classes.h: Same.
123 * include/bits/basic_string.h: Same.
124 * include/bits/ios_base.h: Same.
125 * include/tr1/memory: Same.
126 * src/pool_allocator.cc: Same.
127 * src/mt_allocator.cc: Same.
128 * src/locale_init.cc: Same.
129 * src/ios.cc: Same.
130 * src/locale.cc: Same.
131 * src/bitmap_allocator.cc: Same.
132 * src/ios_init.cc: Same.
133 * src/debug.cc: Same.
134
135 2006-09-12 Benjamin Kosnik <bkoz@redhat.com>
136
137 * libsupc++/eh_globals.cc: Remove __gnu_internal.
138 * config/io/basic_file_stdio.cc: Same.
139 * config/abi/compatibility.h: Same.
140 * config/cpu/generic/atomicity_mutex/atomicity.h: Same.
141 * config/cpu/sh/atomicity.h: Same.
142
143 2006-09-10 Paolo Carlini <pcarlini@suse.de>
144
145 * include/bits/stl_heap.h (sort_heap): Iterator post-decrement is
146 only required to be convertible to the iterator type.
147
148 2006-09-08 Paolo Carlini <pcarlini@suse.de>
149
150 * include/tr1/random.tcc (poisson_distribution<>::operator()):
151 Avoid potential warnings when _IntType is unsigned.
152
153 2006-09-08 Benjamin Kosnik <bkoz@redhat.com>
154
155 * include/debug/debug.h (_GLIBCXX_DEBUG_ONLY): New.
156 * include/ext/bitmap_allocator.h (_BALLOC_SANITY_CHECK,
157 _BALLOC_ASSERT): Remove. Use _GLIBCXX_DEBUG,
158 _GLIBCXX_DEBUG_ASSERT.
159 * include/ext/pb_ds/hash_policy.hpp (PB_DS_DBG_ASSERT): Convert to
160 _GLIBCXX_DEBUG_ASSERT. Formatting corrections.
161 (PB_DS_DBG_VERIFY): Remove, unused.
162 (PB_DS_DBG_ONLY): Convert to _GLIBCXX_DEBUG blocks.
163 * include/ext/pb_ds/detail/resize_policy/
164 hash_load_check_resize_trigger_imp.hpp: Same.
165 * include/ext/pb_ds/detail/binomial_heap_base_/erase_fn_imps.hpp: Same.
166 * include/ext/pb_ds/detail/binomial_heap_base_/find_fn_imps.hpp: Same.
167 * include/ext/pb_ds/detail/binomial_heap_base_/
168 insert_fn_imps.hpp: Same.
169 * include/ext/pb_ds/detail/binomial_heap_base_/
170 binomial_heap_base_.hpp: Same.
171 * include/ext/pb_ds/detail/binomial_heap_base_/
172 constructors_destructor_fn_imps.hpp: Same.
173 * include/ext/pb_ds/detail/binomial_heap_base_/debug_fn_imps.hpp: Same.
174 * include/ext/pb_ds/detail/binomial_heap_base_/
175 split_join_fn_imps.hpp: Same.
176 * include/ext/pb_ds/detail/cc_hash_table_map_/
177 constructor_destructor_no_store_hash_fn_imps.hpp: Same.
178 * include/ext/pb_ds/detail/cc_hash_table_map_/
179 erase_store_hash_fn_imps.hpp: Same.
180 * include/ext/pb_ds/detail/cc_hash_table_map_/
181 insert_no_store_hash_fn_imps.hpp: Same.
182 * include/ext/pb_ds/detail/cc_hash_table_map_/cmp_fn_imps.hpp: Same.
183 * include/ext/pb_ds/detail/cc_hash_table_map_/find_fn_imps.hpp: Same.
184 * include/ext/pb_ds/detail/cc_hash_table_map_/
185 constructor_destructor_store_hash_fn_imps.hpp: Same.
186 * include/ext/pb_ds/detail/cc_hash_table_map_/
187 insert_store_hash_fn_imps.hpp: Same.
188 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_fn_imps.hpp: Same.
189 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_fn_imps.hpp: Same.
190 * include/ext/pb_ds/detail/cc_hash_table_map_/
191 debug_no_store_hash_fn_imps.hpp: Same.
192 * include/ext/pb_ds/detail/cc_hash_table_map_/cc_ht_map_.hpp: Same.
193 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_fn_imps.hpp: Same.
194 * include/ext/pb_ds/detail/cc_hash_table_map_/
195 constructor_destructor_fn_imps.hpp: Same.
196 * include/ext/pb_ds/detail/cc_hash_table_map_/
197 debug_store_hash_fn_imps.hpp: Same.
198 * include/ext/pb_ds/detail/cc_hash_table_map_/
199 erase_no_store_hash_fn_imps.hpp: Same.
200 * include/ext/pb_ds/detail/unordered_iterator/iterator.hpp: Same.
201 * include/ext/pb_ds/detail/unordered_iterator/point_iterator.hpp: Same.
202 * include/ext/pb_ds/detail/unordered_iterator/
203 const_point_iterator.hpp: Same.
204 * include/ext/pb_ds/detail/pat_trie_/r_erase_fn_imps.hpp: Same.
205 * include/ext/pb_ds/detail/pat_trie_/find_fn_imps.hpp: Same.
206 * include/ext/pb_ds/detail/pat_trie_/child_iterator.hpp: Same.
207 * include/ext/pb_ds/detail/pat_trie_/insert_join_fn_imps.hpp: Same.
208 * include/ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp: Same.
209 * include/ext/pb_ds/detail/pat_trie_/
210 constructors_destructor_fn_imps.hpp: Same.
211 * include/ext/pb_ds/detail/pat_trie_/debug_fn_imps.hpp: Same.
212 * include/ext/pb_ds/detail/pat_trie_/head.hpp: Same.
213 * include/ext/pb_ds/detail/pat_trie_/const_child_iterator.hpp: Same.
214 * include/ext/pb_ds/detail/pat_trie_/split_fn_imps.hpp: Same.
215 * include/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp: Same.
216 * include/ext/pb_ds/detail/pat_trie_/leaf.hpp: Same.
217 * include/ext/pb_ds/detail/pat_trie_/rotate_fn_imps.hpp: Same.
218 * include/ext/pb_ds/detail/pat_trie_/erase_fn_imps.hpp: Same.
219 * include/ext/pb_ds/detail/pat_trie_/node_base.hpp: Same.
220 * include/ext/pb_ds/detail/pat_trie_/synth_e_access_traits.hpp: Same.
221 * include/ext/pb_ds/detail/pat_trie_/node_iterators.hpp: Same.
222 * include/ext/pb_ds/detail/pat_trie_/internal_node.hpp: Same.
223 * include/ext/pb_ds/detail/pat_trie_/point_iterators.hpp: Same.
224 * include/ext/pb_ds/detail/bin_search_tree_/find_fn_imps.hpp: Same.
225 * include/ext/pb_ds/detail/bin_search_tree_/r_erase_fn_imps.hpp: Same.
226 * include/ext/pb_ds/detail/bin_search_tree_/
227 constructors_destructor_fn_imps.hpp: Same.
228 * include/ext/pb_ds/detail/bin_search_tree_/debug_fn_imps.hpp: Same.
229 * include/ext/pb_ds/detail/bin_search_tree_/rotate_fn_imps.hpp: Same.
230 * include/ext/pb_ds/detail/bin_search_tree_/erase_fn_imps.hpp: Same.
231 * include/ext/pb_ds/detail/bin_search_tree_/bin_search_tree_.hpp: Same.
232 * include/ext/pb_ds/detail/bin_search_tree_/insert_fn_imps.hpp: Same.
233 * include/ext/pb_ds/detail/bin_search_tree_/
234 split_join_fn_imps.hpp: Same.
235 * include/ext/pb_ds/detail/bin_search_tree_/point_iterators.hpp: Same.
236 * include/ext/pb_ds/detail/gp_hash_table_map_/
237 constructor_destructor_no_store_hash_fn_imps.hpp: Same.
238 * include/ext/pb_ds/detail/gp_hash_table_map_/
239 erase_store_hash_fn_imps.hpp: Same.
240 * include/ext/pb_ds/detail/gp_hash_table_map_/
241 insert_no_store_hash_fn_imps.hpp: Same.
242 * include/ext/pb_ds/detail/gp_hash_table_map_/
243 resize_store_hash_fn_imps.hpp: Same.
244 * include/ext/pb_ds/detail/gp_hash_table_map_/find_fn_imps.hpp: Same.
245 * include/ext/pb_ds/detail/gp_hash_table_map_/
246 constructor_destructor_store_hash_fn_imps.hpp: Same.
247 * include/ext/pb_ds/detail/gp_hash_table_map_/gp_ht_map_.hpp: Same.
248 * include/ext/pb_ds/detail/gp_hash_table_map_/
249 insert_store_hash_fn_imps.hpp: Same.
250 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_fn_imps.hpp: Same.
251 * include/ext/pb_ds/detail/gp_hash_table_map_/trace_fn_imps.hpp: Same.
252 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_fn_imps.hpp: Same.
253 * include/ext/pb_ds/detail/gp_hash_table_map_/
254 debug_no_store_hash_fn_imps.hpp: Same.
255 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_fn_imps.hpp: Same.
256 * include/ext/pb_ds/detail/gp_hash_table_map_/
257 constructor_destructor_fn_imps.hpp: Same.
258 * include/ext/pb_ds/detail/gp_hash_table_map_/
259 debug_store_hash_fn_imps.hpp: Same.
260 * include/ext/pb_ds/detail/gp_hash_table_map_/
261 erase_no_store_hash_fn_imps.hpp: Same.
262 * include/ext/pb_ds/detail/gp_hash_table_map_/
263 resize_no_store_hash_fn_imps.hpp: Same.
264 * include/ext/pb_ds/detail/types_traits.hpp: Same.
265 * include/ext/pb_ds/detail/binary_heap_/find_fn_imps.hpp: Same.
266 * include/ext/pb_ds/detail/binary_heap_/const_iterator.hpp: Same.
267 * include/ext/pb_ds/detail/binary_heap_/
268 constructors_destructor_fn_imps.hpp: Same.
269 * include/ext/pb_ds/detail/binary_heap_/debug_fn_imps.hpp: Same.
270 * include/ext/pb_ds/detail/binary_heap_/const_point_iterator.hpp: Same.
271 * include/ext/pb_ds/detail/binary_heap_/erase_fn_imps.hpp: Same.
272 * include/ext/pb_ds/detail/binary_heap_/insert_fn_imps.hpp: Same.
273 * include/ext/pb_ds/detail/binary_heap_/binary_heap_.hpp: Same.
274 * include/ext/pb_ds/detail/binary_heap_/resize_policy.hpp: Same.
275 * include/ext/pb_ds/detail/binary_heap_/split_join_fn_imps.hpp: Same.
276 * include/ext/pb_ds/detail/pairing_heap_/erase_fn_imps.hpp: Same.
277 * include/ext/pb_ds/detail/pairing_heap_/find_fn_imps.hpp: Same.
278 * include/ext/pb_ds/detail/pairing_heap_/insert_fn_imps.hpp: Same.
279 * include/ext/pb_ds/detail/pairing_heap_/
280 constructors_destructor_fn_imps.hpp: Same.
281 * include/ext/pb_ds/detail/pairing_heap_/debug_fn_imps.hpp: Same.
282 * include/ext/pb_ds/detail/pairing_heap_/pairing_heap_.hpp: Same.
283 * include/ext/pb_ds/detail/pairing_heap_/split_join_fn_imps.hpp: Same.
284 * include/ext/pb_ds/detail/binomial_heap_/
285 constructors_destructor_fn_imps.hpp: Same.
286 * include/ext/pb_ds/detail/binomial_heap_/debug_fn_imps.hpp: Same.
287 * include/ext/pb_ds/detail/binomial_heap_/binomial_heap_.hpp: Same.
288 * include/ext/pb_ds/detail/eq_fn/hash_eq_fn.hpp: Same.
289 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
290 erase_fn_imps.hpp: Same.
291 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
292 left_child_next_sibling_heap_.hpp: Same.
293 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
294 const_iterator.hpp: Same.
295 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
296 insert_fn_imps.hpp: Same.
297 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
298 constructors_destructor_fn_imps.hpp: Same.
299 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
300 debug_fn_imps.hpp: Same.
301 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/
302 const_point_iterator.hpp: Same.
303 * include/ext/pb_ds/detail/thin_heap_/erase_fn_imps.hpp: Same.
304 * include/ext/pb_ds/detail/thin_heap_/find_fn_imps.hpp: Same.
305 * include/ext/pb_ds/detail/thin_heap_/thin_heap_.hpp: Same.
306 * include/ext/pb_ds/detail/thin_heap_/insert_fn_imps.hpp: Same.
307 * include/ext/pb_ds/detail/thin_heap_/
308 constructors_destructor_fn_imps.hpp: Same.
309 * include/ext/pb_ds/detail/thin_heap_/debug_fn_imps.hpp: Same.
310 * include/ext/pb_ds/detail/thin_heap_/split_join_fn_imps.hpp: Same.
311 * include/ext/pb_ds/detail/ov_tree_map_/erase_fn_imps.hpp: Same.
312 * include/ext/pb_ds/detail/ov_tree_map_/cond_dtor.hpp: Same.
313 * include/ext/pb_ds/detail/ov_tree_map_/ov_tree_map_.hpp: Same.
314 * include/ext/pb_ds/detail/ov_tree_map_/
315 constructors_destructor_fn_imps.hpp: Same.
316 * include/ext/pb_ds/detail/ov_tree_map_/debug_fn_imps.hpp: Same.
317 * include/ext/pb_ds/detail/ov_tree_map_/node_iterators.hpp: Same.
318 * include/ext/pb_ds/detail/ov_tree_map_/split_join_fn_imps.hpp: Same.
319 * include/ext/pb_ds/detail/ov_tree_map_/info_fn_imps.hpp: Same.
320 * include/ext/pb_ds/detail/map_debug_base.hpp: Same.
321 * include/ext/pb_ds/detail/hash_fn/ranged_probe_fn.hpp: Same.
322 * include/ext/pb_ds/detail/hash_fn/probe_fn_base.hpp: Same.
323 * include/ext/pb_ds/detail/hash_fn/ranged_hash_fn.hpp: Same.
324 * include/ext/pb_ds/detail/splay_tree_/erase_fn_imps.hpp: Same.
325 * include/ext/pb_ds/detail/splay_tree_/find_fn_imps.hpp: Same.
326 * include/ext/pb_ds/detail/splay_tree_/insert_fn_imps.hpp: Same.
327 * include/ext/pb_ds/detail/splay_tree_/
328 constructors_destructor_fn_imps.hpp: Same.
329 * include/ext/pb_ds/detail/splay_tree_/debug_fn_imps.hpp: Same.
330 * include/ext/pb_ds/detail/splay_tree_/splay_fn_imps.hpp: Same.
331 * include/ext/pb_ds/detail/splay_tree_/split_join_fn_imps.hpp: Same.
332 * include/ext/pb_ds/detail/splay_tree_/splay_tree_.hpp: Same.
333 * include/ext/pb_ds/detail/list_update_map_/erase_fn_imps.hpp: Same.
334 * include/ext/pb_ds/detail/list_update_map_/find_fn_imps.hpp: Same.
335 * include/ext/pb_ds/detail/list_update_map_/lu_map_.hpp: Same.
336 * include/ext/pb_ds/detail/list_update_map_/
337 constructor_destructor_fn_imps.hpp: Same.
338 * include/ext/pb_ds/detail/list_update_map_/insert_fn_imps.hpp: Same.
339 * include/ext/pb_ds/detail/list_update_map_/debug_fn_imps.hpp: Same.
340 * include/ext/pb_ds/detail/list_update_map_/
341 iterators_fn_imps.hpp: Same.
342 * include/ext/pb_ds/detail/rc_binomial_heap_/erase_fn_imps.hpp: Same.
343 * include/ext/pb_ds/detail/rc_binomial_heap_/
344 rc_binomial_heap_.hpp: Same.
345 * include/ext/pb_ds/detail/rc_binomial_heap_/insert_fn_imps.hpp: Same.
346 * include/ext/pb_ds/detail/rc_binomial_heap_/
347 constructors_destructor_fn_imps.hpp: Same.
348 * include/ext/pb_ds/detail/rc_binomial_heap_/debug_fn_imps.hpp: Same.
349 * include/ext/pb_ds/detail/rc_binomial_heap_/rc.hpp: Same.
350 * include/ext/pb_ds/detail/rc_binomial_heap_/
351 split_join_fn_imps.hpp: Same.
352 * include/ext/pb_ds/detail/rb_tree_map_/erase_fn_imps.hpp: Same.
353 * include/ext/pb_ds/detail/rb_tree_map_/insert_fn_imps.hpp: Same.
354 * include/ext/pb_ds/detail/rb_tree_map_/
355 constructors_destructor_fn_imps.hpp: Same.
356 * include/ext/pb_ds/detail/rb_tree_map_/debug_fn_imps.hpp: Same.
357 * include/ext/pb_ds/detail/rb_tree_map_/rb_tree_.hpp: Same.
358 * include/ext/pb_ds/detail/rb_tree_map_/split_join_fn_imps.hpp: Same.
359 * testsuite/util/regression/res_mng/forced_exception.hpp: Same.
360 * testsuite/util/regression/res_mng/dbg_ex_allocator_base.hpp: Same.
361 * testsuite/util/regression/res_mng/dbg_ex_allocator.hpp: Same.
362 * testsuite/util/rng/twister_rand_gen.cc
363 * testsuite/util/native_type/assoc/native_multimap.hpp: Same.
364 * testsuite/util/native_type/assoc/native_hash_multimap.hpp: Same.
365
366 2006-09-05 Paolo Carlini <pcarlini@suse.de>
367
368 * include/bits/basic_string.tcc (find(const _CharT*, size_type,
369 size_type)): Robustify.
370 * include/ext/vstring.tcc (find(const _CharT*, size_type,
371 size_type)): Likewise.
372
373 2006-09-05 Paolo Carlini <pcarlini@suse.de>
374
375 * include/bits/basic_string.tcc (find(const _CharT*, size_type,
376 size_type)): Reimplement in terms of traits::eq and traits::compare.
377 * include/ext/vstring.tcc (find(const _CharT*, size_type,
378 size_type)): Likewise.
379 * src/string-inst.cc: Remove unneded std::search instantiation.
380
381 2006-09-04 Benjamin Kosnik <bkoz@redhat.com>
382
383 PR c++/28871
384 * include/ext/bitmap_allocator.h: Add comment for end of anonymous
385 namespace.
386 * include/ext/rope: Same.
387 * include/bits/cpp_type_traits.h: Same.
388 * include/tr1/tuple: Same.
389 * include/tr1/functional_iterate.h: Same.
390
391 * include/bits/cpp_type_traits.h: Revert anonymous namespace
392 change, use nested detail instead.
393
394 * testsuite/lib/libstdc++.exp (libstdc++_init): PCHFLAGS revert to
395 stdc++.h.
396
397 2006-09-04 Paolo Carlini <pcarlini@suse.de>
398
399 * src/mt_allocator.cc (__pool<true>::_M_reclaim_block): Do
400 not name a variable __used, badname on BSD.
401
402 2006-09-02 Paolo Carlini <pcarlini@suse.de>
403 Richard Guenther <rguenther@suse.de>
404
405 PR libstdc++/24469
406 * src/mt_allocator.cc (__pool<true>::_M_reserve_block,
407 __pool<true>::_M_reclaim_block): Fix the logic to avoid
408 races, exploit atomic counters stored in second part of
409 the memory pointed by _M_used.
410 (__pool<true>::_M_initialize): Adjust _M_used allocation.
411 * include/ext/mt_allocator.h (__pool<true>::_Bin_record):
412 Update comment.
413
414 2006-08-31 Benjamin Kosnik <bkoz@redhat.com>
415
416 PR libstdc++/28671 continued
417 * acinclude.m4 (GLIBCXX_ENABLE_ATOMIC_BUILTINS): Don't use
418 CXXFLAGS when checking for atomic builtins.
419 * configure: Regenerate.
420 * include/bits/atomicity.h: Revert.
421
422 2006-08-31 Richard Guenther <rguenther@suse.de>
423
424 * include/ext/mt_allocator.h: Remove volatile qualifiers
425 from data members and corresponding locals and function
426 signatures.
427
428 2006-08-31 Paolo Carlini <pcarlini@suse.de>
429
430 * config/abi/pre/gnu.ver: Correct atomic helper function signature
431 for case where _Atomic_word is long.
432
433 2006-08-31 Benjamin Kosnik <bkoz@redhat.com>
434
435 PR libstdc++/28671
436 * include/bits/atomicity.h (__exchange_and_add): Declare only.
437 (__atomic_add): Same.
438 * config/cpu/generic/atomicity_builtins/atomicity.h: Remove comment.
439
440 2006-08-30 Benjamin Kosnik <bkoz@redhat.com>
441 Richard Guenther <rguenther@suse.de>
442
443 * config/abi/pre/gnu.ver: Spell out exact signatures for atomic
444 access functions.
445
446 * include/bits/atomicity.h (__atomic_add_dispatch): Remove
447 volatile qualification for _Atomic_word argument.
448 (__atomic_add_single): Same.
449 (__exchange_and_add_dispatch): Same.
450 (__exchange_and_add_single): Same.
451
452 2006-08-29 Paolo Carlini <pcarlini@suse.de>
453
454 * include/tr1/random (subtract_with_carry_01<>::_M_initialize_npows):
455 New.
456 (subtract_with_carry_01<>::subtract_with_carry_01(),
457 subtract_with_carry_01<>::subtract_with_carry_01(unsigned long),
458 subtract_with_carry_01<>::subtract_with_carry_01(_Gen&)): Use it.
459 * include/tr1/random.tcc: Define.
460
461 * include/tr1/random (xor_combine<>::_M_initialize_max()): New.
462 (xor_combine<>::xor_combine(), xor_combine<>::xor_combine(const
463 base1_type&, const base2_type&), xor_combine<>::xor_combine(unsigned
464 long), xor_combine<>::xor_combine(_Gen&)): Use it.
465 (xor_combine<>::min, xor_combine<>::max): Adjust.
466 * include/tr1/random.tcc: Define.
467
468 2006-08-29 Benjamin Kosnik <bkoz@redhat.com>
469
470 * acinclude.m4(glibcxx_PCHFLAGS): Set to stdtr1c++.h.
471 * configure: Regenerate.
472
473 * scripts/check_compile: Output current compile line.
474
475 2006-08-28 Benjamin Kosnik <bkoz@redhat.com>
476
477 PR libstdc++/23773 partial
478 * docs/html/abi.html: Update.
479
480 2006-08-28 Roger Sayle <roger@eyesopen.com>
481 Paolo Carlini <pcarlini@suse.de>
482
483 * include/bits/stl_algo.h (__heap_select, __introselect): New.
484 (nth_element): New implementation.
485 (partial_copy): Use __heap_select.
486 * testsuite/performance/25_algorithms/nth_element_worst_case.cc: New.
487
488 2006-08-28 Paolo Carlini <pcarlini@suse.de>
489 Roger Sayle <roger@eyesopen.com>
490
491 * testsuite/25_algorithms/nth_element/2.cc: New.
492
493 2006-08-27 Paolo Carlini <pcarlini@suse.de>
494
495 PR libstdc++/28830
496 * testsuite/tr1/2_general_utilities/memory/shared_ptr/thread/
497 lockfree_weaktoshared.cc: Rename to...
498 * testsuite/tr1/2_general_utilities/memory/shared_ptr/thread/
499 default_weaktoshared.cc: ... this; test the default base class.
500 * testsuite/tr1/2_general_utilities/memory/shared_ptr/thread/
501 mutex_weaktoshared.cc: Run like the other thread tests.
502
503 2006-08-25 Paolo Carlini <pcarlini@suse.de>
504
505 * docs/html/ext/tr1.html: Update.
506
507 2006-08-25 Paolo Carlini <pcarlini@suse.de>
508
509 * include/tr1/random (bernoulli_distribution::operator()): Fix
510 wrt generators returning integers.
511 (uniform_int<>::_M_call): Add.
512 (uniform_int<>::operator()): Use it.
513
514 * include/tr1/random (_Adaptor<>::min, _Adaptor<>::max): Add.
515 (_Adaptor<>::operator()): Allow for nonzero _M_g.min().
516
517 * include/tr1/random.tcc (linear_congruential<>::min, max):
518 Move inline...
519 (__mod): Move ...
520 * include/tr1/random: ... here.
521 (struct _Mod): Declare.
522
523 * include/tr1/random (struct _To_Unsigned_Type): Only declare,
524 move...
525 * include/tr1/random.tcc: ... here.
526
527 2006-08-22 Phillip Jordan <phillip.m.jordan@gmail.com>
528
529 *include/tr1/boost_shared_ptr.h: Added locking policy to
530 tr1::shared_ptr<> and related classes.
531 * testsuite/tr1/2_general_utilities/memory/shared_ptr/thread: New.
532 * testsuite/tr1/2_general_utilities/memory/shared_ptr/thread/
533 lockfree_weaktoshared.cc: New.
534 * testsuite/tr1/2_general_utilities/memory/shared_ptr/thread/
535 mutex_weaktoshared.cc: New.
536 *testsuite/tr1/2_general_utilities/memory/shared_ptr/assign/
537 shared_ptr_neg.cc: Modify.
538
539 2006-08-22 Paolo Carlini <pcarlini@suse.de>
540
541 * include/tr1/random.tcc (subtract_with_carry_01<>::
542 seed(_Gen&, false_type)): Fix _M_carry initialization.
543
544 * testsuite/tr1/5_numerical_facilities/random/
545 subtract_with_carry/cons/default.cc: Qualify 1 as 1UL.
546 * testsuite/tr1/5_numerical_facilities/random/
547 subtract_with_carry/cons/gen1.cc: Likewise.
548
549 2006-08-22 Paolo Carlini <pcarlini@suse.de>
550
551 * include/tr1/random (class subtract_with_carry_01<>): Add.
552 * include/tr1/random.tcc (subtract_with_carry_01<>::
553 seed(unsigned long), subtract_with_carry_01<>::
554 seed(_Gen&, false_type), subtract_with_carry_01<>::
555 operator(), operator<<(std::basic_ostream<>&, const
556 subtract_with_carry_01<>&), operator>>(std::basic_istream<>&,
557 subtract_with_carry_01<>&)): Define.
558 * testsuite/tr1/5_numerical_facilities/random/ranlux3_01.cc:
559 New.
560 * testsuite/tr1/5_numerical_facilities/random/ranlux4_01.cc:
561 Likewise.
562 * testsuite/tr1/5_numerical_facilities/random/
563 subtract_with_carry_01/cons/seed1.cc: Likewise.
564 * testsuite/tr1/5_numerical_facilities/random/
565 subtract_with_carry_01/cons/seed2.cc: Likewise.
566 * testsuite/tr1/5_numerical_facilities/random/
567 subtract_with_carry_01/cons/default.cc: Likewise.
568 * testsuite/tr1/5_numerical_facilities/random/
569 subtract_with_carry_01/cons/gen1.cc: Likewise.
570 * testsuite/tr1/5_numerical_facilities/random/
571 subtract_with_carry_01/requirements/typedefs.cc: Likewise.
572 * testsuite/tr1/5_numerical_facilities/random/
573 subtract_with_carry_01/operators/equal.cc: Likewise.
574 * testsuite/tr1/5_numerical_facilities/random/
575 subtract_with_carry_01/operators/not_equal.cc: Likewise.
576 * testsuite/tr1/5_numerical_facilities/random/
577 subtract_with_carry_01/operators/serialize.cc: Likewise.
578
579 * docs/html/ext/howto.html: Add two implemented TR1 issues.
580
581 * include/tr1/random.tcc (struct _To_Unsigned_Type<>): Move...
582 * include/tr1/random: ... here.
583 (class subtract_with_carry<>): Use it everywhere.
584
585 * testsuite/tr1/5_numerical_facilities/random/
586 subtract_with_carry/cons/seed1.cc: Qualify 1 as 1UL.
587 * testsuite/tr1/5_numerical_facilities/random/
588 subtract_with_carry/cons/seed2.cc: Likewise.
589 * testsuite/tr1/5_numerical_facilities/random/
590 subtract_with_carry/cons/default.cc: Likewise.
591 * testsuite/tr1/5_numerical_facilities/random/
592 subtract_with_carry/cons/gen1.cc: Likewise.
593 * testsuite/tr1/5_numerical_facilities/random/
594 subtract_with_carry/requirements/typedefs.cc: Likewise.
595 * testsuite/tr1/5_numerical_facilities/random/
596 subtract_with_carry/operators/equal.cc: Likewise.
597 * testsuite/tr1/5_numerical_facilities/random/
598 subtract_with_carry/operators/not_equal.cc: Likewise.
599 * testsuite/tr1/5_numerical_facilities/random/
600 subtract_with_carry/operators/serialize.cc: Likewise.
601
602 * include/tr1/random (class binomial_distribution<>): Reorder the
603 data members to save space.
604
605 2006-08-20 Paolo Carlini <pcarlini@suse.de>
606
607 * include/tr1/random (gamma_distribution<>::_M_initialize,
608 gamma_distribution<>::_M_l_d): Add.
609 (gamma_distribution<>::gamma_distribution(const result_type&),
610 operator>>(std::basic_istream<>&, gamma_distribution&)): Use it.
611 include/tr1/random.tcc (gamma_distribution<>::_M_initialize):
612 Define.
613 (gamma_distribution<>::operator()): Adjust.
614
615 * include/tr1/random (geometric_distribution<>::_M_initialize): Add.
616 (geometric_distribution<>::geometric_distribution(const _RealType&),
617 operator>>(std::basic_istream<>&, geometric_distribution&)): Use it.
618
619 2006-08-18 Paolo Carlini <pcarlini@suse.de>
620
621 * include/tr1/random (class binomial_distribution<>): Add.
622 * include/tr1/random.tcc (binomial_distribution<>::operator(),
623 operator<<(std::basic_ostream<>&, const binomial_distribution<>&),
624 operator>>(std::basic_istream<>&, binomial_distribution<>&,
625 binomial_distribution<>::_M_waiting(), binomial_distribution<>::
626 _M_initialize()): Define.
627 * testsuite/tr1/5_numerical_facilities/random/binomial_distribution/
628 requirements/typedefs.cc: New.
629
630 * include/tr1/random (geometric_distribution<>::
631 geometric_distribution(const _RealType&)): Fix DEBUG_ASSERT
632 limits.
633
634 * include/tr1/random (poisson_distribution): Add normal_distribution
635 member, adjust consistently; minor tweaks and rearrangements of the
636 arithmetic.
637 (operator>>(std::basic_istream<>&, poisson_distribution<>&)): Move
638 out of line.
639 * include/tr1/random.tcc: Adjust.
640
641 * include/tr1/random.tcc (normal_distribution<>::operator()): Minor
642 tweaks.
643
644 2006-08-18 Paolo Carlini <pcarlini@suse.de>
645
646 PR libstdc++/28765
647 * include/ext/rc_string_base.h (_M_clear): New.
648 * include/ext/sso_string_base.h (_M_clear): Likewise.
649 * include/ext/vstring.h (clear): Use it.
650
651 2006-08-15 Paolo Carlini <pcarlini@suse.de>
652
653 * include/tr1/random (poisson_distribution<>::_M_initialize): Add.
654 (poisson_distribution<>::poisson_distribution(const _RealType&):
655 Use it.
656 (operator>>(std::basic_istream<>&, poisson_distribution<>&)):
657 Likewise.
658 (poisson_distribution<>::_M_large): Remove.
659 * include/tr1/random.tcc (poisson_distribution<>::_M_initialize):
660 Define.
661 (operator<<(std::basic_ostream<>&, const poisson_distribution<>&)):
662 Do not output the constants.
663
664 * include/tr1/random (operator>>(std::basic_istream<>&,
665 gamma_distribution&)): Minor tweak.
666
667 * include/tr1/random.tcc (poisson_distribution<>::operator()):
668 Minor tweak.
669
670 * include/tr1/random: Consistently, all data members private.
671
672 2006-08-15 Paolo Carlini <pcarlini@suse.de>
673
674 * include/tr1/random.tcc (mersenne_twister<>::operator()): Revert
675 last change (per gcc-patches/2006-08/msg00484.html).
676
677 2006-08-14 Paolo Carlini <pcarlini@suse.de>
678
679 * include/tr1/random (class poisson_distribution<>): Add.
680 * include/tr1/random.tcc (poisson_distribution<>::operator(),
681 operator<<(std::basic_ostream<>&, const poisson_distribution<>&),
682 operator>>(std::basic_istream<>&, poisson_distribution<>&,
683 poisson_distribution<>::poisson_distribution(const _RealType&)):
684 Define.
685 * testsuite/tr1/5_numerical_facilities/random/poisson_distribution/
686 requirements/typedefs.cc: New.
687
688 * include/tr1/random.tcc (mersenne_twister<>::operator()): Tweak
689 a bit for efficiency.
690
691 * include/tr1/random.tcc (operator<<(std::basic_ostream<>&,
692 const normal_distribution<>&), operator>>(std::basic_istream<>&,
693 normal_distribution<>&)): Do not output _M_saved unnecessarily.
694
695 * include/tr1/random: Trivial formatting fixes.
696 * include/tr1/cmath: Likewise.
697
698 2006-08-11 Paolo Carlini <pcarlini@suse.de>
699
700 * include/bits/stl_bvector.h (__fill_bvector(_Bit_iterator,
701 _Bit_iterator, bool)): New.
702 (fill(_Bit_iterator, _Bit_iterator, const bool&)): Use it.
703
704 2006-08-10 Paolo Carlini <pcarlini@suse.de>
705
706 * include/tr1/random.tcc (gamma_distribution<>::operator()): Fixes
707 from the Errata of Devroye's book.
708
709 2006-08-10 Paolo Carlini <pcarlini@suse.de>
710
711 * include/bits/stl_bvector.h (_Bit_iterator_base::_M_incr(ptrdiff_t)):
712 Tidy a bit, thus reducing generated code size.
713
714 2006-08-09 Paolo Carlini <pcarlini@suse.de>
715
716 * include/bits/stl_bvector.h (vector<bool>::_M_copy_aligned): New.
717 (vector<bool>::vector(const vector&), operator=(const vector&),
718 reserve(size_type), _M_fill_insert(iterator, size_type, bool),
719 _M_insert_range(iterator, _ForwardIterator, _ForwardIterator,
720 std::forward_iterator_tag), _M_insert_aux(iterator, bool)): Use it.
721 * testsuite/performance/23_containers/copy_construct/
722 vector_bool.cc: New.
723
724 * testsuite/23_containers/vector/bool/cons/1.cc: New.
725 * testsuite/23_containers/vector/bool/cons/2.cc: Likewise.
726
727 * include/bits/stl_bvector.h (vector<bool>::_M_fill): Remove.
728 (fill(_Bit_iterator, _Bit_iterator, const bool&)): New.
729 (vector<bool>::_M_fill_insert(iterator, size_type, bool)): Adjust.
730
731 * include/bits/stl_bvector.h (_M_initialize_range(_InputIterator,
732 _InputIterator, std::input_iterator_tag)): Remove redundant
733 assignments.
734
735 * include/bits/stl_algo.h (find(istreambuf_iterator<>,
736 istreambuf_iterator<>, _CharT)): Adjust signature.
737 * include/bits/streambuf_iterator.h: Likewise.
738 * include/std/std_streambuf.h: Likewise.
739
740 2006-08-09 Paolo Carlini <pcarlini@suse.de>
741
742 * include/bits/stl_algobase.h (fill(const _Deque_iterator<>&,
743 const _Deque_iterator<>&, const _Tp&)): Move...
744 * include/bits/deque.tcc: ... here.
745 * include/bits/stl_deque.h: Declare.
746
747 2006-08-06 Paolo Carlini <pcarlini@suse.de>
748
749 PR libstdc++/16611
750 * include/bits/stl_bvector.h (vector<bool>::operator[],
751 vector<bool>::operator[] const): Do not use iterator::operator+,
752 hand code.
753
754 2006-08-05 Paolo Carlini <pcarlini@suse.de>
755
756 PR libstdc++/28587
757 * include/bits/stl_bvector.h (vector<bool>::_M_fill): New.
758 (vector<bool>::_M_fill_insert): Use it.
759 * testsuite/performance/23_containers/resize/vector_bool.cc: New.
760
761 * testsuite/23_containers/vector/bool/modifiers/insert/1.cc: New.
762 * testsuite/23_containers/vector/bool/capacity/1.cc: Likewise.
763
764 2006-08-04 Paolo Carlini <pcarlini@suse.de>
765
766 * include/bits/stl_queue.h (priority_queue<>::push,
767 priority_queue<>::pop): Remove try/catch, just follow the
768 letter of the Standard.
769
770 2006-08-03 Paolo Carlini <pcarlini@suse.de>
771
772 * include/bits/stl_queue.h: Trivial formatting fixes.
773 * include/bits/stl_stack.h: Likewise.
774
775 2006-08-01 Ed Smith-Rowland <3dw4rd@verizon.net>
776
777 * docs/html/ext/tr1.html: Update.
778
779 2006-07-31 Paolo Carlini <pcarlini@suse.de>
780
781 * include/bits/locale_facets.tcc (num_put<>::_M_insert_float):
782 Find the decimal point in cs, instead of ws; tidy.
783
784 2006-07-30 Roger Sayle <roger@eyesopen.com>
785
786 * include/ext/codevt_specializations.h (__iconv_adaptor): Use
787 identifier _Tp instead of _T in template argument to avoid conflict.
788
789 2006-07-30 Paolo Carlini <pcarlini@suse.de>
790
791 * include/bits/stl_algo.h (stable_sort): Uglify the buf variable.
792 * include/bits/stl_tempbuf.h (_Temporary_buffer<>::
793 _M_initialize_buffer): Uglify the val parameter.
794
795 2006-07-27 Benjamin Kosnik <bkoz@wells.artheist.org>
796
797 PR libstdc++/19664 round 3
798 * include/Makefile.am (tr1_headers): Add hashtable_policy.h.
799 * include/Makefile.in: Regenerate.
800 * include/tr1/hashtable: Move policy classes into...
801 * include/tr1/hashtable_policy.h: ... this. New.
802
803 * src/globals_locale.cc: Move contents....
804 * src/locale_init.cc: ... to here, put in anonymous namespace.
805 * src/Makefile.am: Remove globals_locale.cc.
806 * src/Makefile.in: Regenerate.
807
808 * src/locale.cc: Convert __gnu_internal to anonymous namespace.
809 * src/debug.cc: Same.
810 * src/ext-inst.cc: Same.
811 * src/mt_allocator.cc: Same.
812 * src/pool_allocator.cc: Same.
813
814 * include/tr1/random: Convert std::tr1::_Private to anonymous
815 namespace.
816 * include/tr1/random.tcc: Same.
817
818 * include/tr1/hashtable: Move ::Internal to std::tr1::detail and
819 enclose bits that can actually be internal in in anonymous
820 namespace.
821 * include/tr1/unordered_set: Adjust explicit qualifications for
822 namespace changes.
823 * include/tr1/unordered_map: Same.
824
825 * include/tr1/cmath: Convert __gnu_internal to nested detail namespace.
826
827 * include/bits/cpp_type_traits.h: Move __type_type into anonymous
828 namespace.
829
830 * include/ext/rope: Change _Rope_constants to anonymous namespace.
831 * include/ext/ropeimpl.h: Same.
832 * src/ext-inst.cc: Same.
833
834 2006-07-24 Paolo Carlini <pcarlini@suse.de>
835
836 * include/tr1/cinttypes: Simply protect everything with
837 _GLIBCXX_USE_C99_INTTYPES_TR1.
838 * include/tr1/cfenv: Likewise with _GLIBCXX_USE_C99_FENV_TR1.
839 * include/tr1/cstdint: Likewise with _GLIBCXX_USE_C99_STDINT_TR1.
840
841 2006-07-21 Benjamin Kosnik <bkoz@redhat.com>
842
843 * include/tr1/random: Make include guards consistent.
844 * include/tr1/unordered_map: Same.
845 * include/tr1/hashtable: Same.
846 * include/tr1/unordered_set: Same.
847
848 2006-07-21 Steve Ellcey <sje@cup.hp.com>
849
850 PR target/26792
851 * configure.ac: Use GCC_CHECK_UNWIND_GETIPINFO to
852 define HAVE_GETIPINFO.
853 * aclocal.m4: Add include of ../config/unwind_ipinfo.m4.
854 * config.h.in: Regenerate.
855 * configure: Regenerate.
856 * Makefile.in: Regenerate.
857 * libmath/Makefile.in: Regenerate.
858 * include/Makefile.in: Regenerate.
859 * src/Makefile.in: Regenerate.
860 * libsupc++/Makefile.in: Regenerate.
861 * testsuite/Makefile.in: Regenerate.
862 * po/Makefile.in: Regenerate.
863 * libsupc++/eh_personality.cc: Check HAVE_GETIPINFO.
864
865 2006-07-21 Jason Merrill <jason@redhat.com>
866
867 PR libstdc++/19664 round 2
868 * libsupc++/eh_personality.cc: Wrap extern "C" function
869 definitions in namespace __cxxabiv1.
870
871 2006-07-21 David Daney <ddaney@avtrex.com>
872
873 PR libgcj/28426
874 * acinclude.m4: Added a comment.
875
876 2006-07-20 Benjamin Kosnik <bkoz@redhat.com>
877 Jakub Jelinek <jakub@redhat.com>
878
879 PR libstdc++/19664 round 1
880 * acinclude.m4 (GLIBCXX_ENABLE_VISIBILITY): Check it.
881 * configure.ac: Use it.
882 * configure: Regenerate.
883 * docs/html/configopts.html: Document it.
884 * include/Makefile.am: Slip in to c++config.
885 * include/Makefile.in: Regenerate.
886 * include/bits/c++config (_GLIBCXX_VISIBILITY): New.
887 (_GLIBCXX_BEGIN_NAMESPACE): Use it.
888 (_GLIBCXX_END_NAMESPACE): Use it.
889 (_GLIBCXX_BEGIN_NESTED_NAMESPACE): Use it.
890 (_GLIBCXX_END_NESTED_NAMESPACE): Use it.
891 * src/debug.cc: Mark __gnu_internal namespace with hidden
892 visibility attribute.
893 * src/ext-inst.cc: Same.
894 * src/globals_io.cc: Same.
895 * src/globals_locale.cc: Same.
896 * src/ios_init.cc: Same.
897 * src/locale.cc: Same.
898 * src/mt_allocator.cc: Same.
899 * src/pool_allocator.cc: Same.
900
901 2006-07-16 Paolo Carlini <pcarlini@suse.de>
902
903 PR libstdc++/28277 (partial: valarray bits)
904 * include/std/std_valarray.h (valarray<>::shift(int),
905 valarray<>::cshift(int)): Avoid __builtin_alloca with no limit,
906 do the work in place.
907 * testsuite/26_numerics/valarray/28277.cc: New.
908
909 2006-07-15 Paolo Carlini <pcarlini@suse.de>
910
911 PR libstdc++/28277 (partial: ostream bits 1)
912 * include/bits/ostream.tcc (operator<<(basic_ostream<_CharT>&,
913 const char*)): Avoid __builtin_alloca with no limit in the
914 widening.
915 * testsuite/27_io/basic_ostream/inserters_character/wchar_t/
916 28277-1.cc: New.
917
918 2006-07-14 Benjamin Kosnik <bkoz@redhat.com>
919
920 * acinclude.m4 (GLIBCXX_ENABLE_ATOMIC_BUILTINS): New.
921 * configure.ac: Use it.
922 * configure: Regenerated.
923 * config.h.in: Regenerated.
924 * configure.host: Simplify.
925 * include/bits/atomicity.h: Adjust macros.
926 * config/cpu/generic/atomicity.h: Move...
927 * config/cpu/generic/atomicity_mutex: New.
928 * config/cpu/generic/atomicity_mutex/atomicity.h: ...here.
929 * config/cpu/generic/atomic_builtins: Rename...
930 * config/cpu/generic/atomicity_builtins: ...to this.
931 * config/cpu/generic/atomicity_builtins/atomicity.h: Moved.
932 * config/cpu/mips/atomicity.h: Comment MIPS II requirement.
933
934 * scripts/testsuite_flags.in: Make --cxxflags reflect CXXFLAGS.
935
936 2006-07-14 Paolo Carlini <pcarlini@suse.de>
937
938 * include/tr1/random (minstd_rand0, minstd_rand, ranlux3, ranlux4):
939 Use unsigned long as implementation-defined type.
940
941 2006-07-14 Paolo Carlini <pcarlini@suse.de>
942
943 * include/tr1/random.tcc (struct _To_Unsigned_Type): Add.
944 (subtract_with_carry<>::seed(_Gen&, false_type)): Use an
945 unsigned type in the loop, fix factor multiplier, take g
946 invocations modulo 2^32.
947
948 * include/tr1/random.tcc (subtract_with_carry<>::
949 seed(unsigned long)): Fix value == 0 special case.
950
951 * include/tr1/random (struct _Shift): Fix for large shifts.
952
953 2006-07-13 Paolo Carlini <pcarlini@suse.de>
954
955 * testsuite/performance/21_strings/string_copy_cons_and_dest.cc: New.
956
957 2006-07-13 Benjamin Kosnik <bkoz@redhat.com>
958
959 * include/Makefile.am (pch*_output_anchor): Add.
960 (pch*_output): Use.
961 (CLEANFILES): Use.
962 * include/Makefile.in: Regenerate.
963
964 * scripts/check_performance: Be verbose on compile error.
965
966 2006-07-12 Benjamin Kosnik <bkoz@redhat.com>
967
968 * include/Makefile.am: Revert last change.
969 * include/Makefile.in: Same.
970
971 2006-07-12 Benjamin Kosnik <bkoz@redhat.com>
972
973 * include/Makefile.am (pch_output): Don't precompile extc++.h.
974 (pch_output_dirs): Same.
975 * include/Makefile.in: Regenerate.
976
977 * testsuite/lib/libstdc++.exp: Test PCH with stdtr1c++.h.
978
979 2006-07-11 Paolo Carlini <pcarlini@suse.de>
980
981 * include/ext/codecvt_specializations.h: Fix typo in commit
982 for libstdc++/28290.
983
984 2006-07-11 Paolo Carlini <pcarlini@suse.de>
985
986 * include/bits/locale_facets.tcc (collate<>::do_transform(
987 const _CharT*, const _CharT*)): Simplify previous fix for
988 libstdc++/28277, always allocate memory dynamically.
989
990 2006-07-11 Paolo Carlini <pcarlini@suse.de>
991
992 PR libstdc++/28344
993 * include/tr1/random (gamma_distribution<>::
994 gamma_distribution(const result_type&)): Don't use __alpha as
995 parameter name, a predefined macro on Alpha systems.
996
997 2006-07-11 Paolo Carlini <pcarlini@suse.de>
998
999 PR libstdc++/28290
1000 * include/ext/codecvt_specializations.h: Fix, adding missing
1001 includes and guards.
1002
1003 2006-07-11 Paolo Carlini <pcarlini@suse.de>
1004
1005 PR libstdc++/28277 (partial: collate bits)
1006 * include/bits/locale_facets.tcc (collate<>::do_transform(
1007 const _CharT*, const _CharT*)): Avoid __builtin_alloca with no
1008 limit; also avoid multiple calls (in a loop).
1009 * testsuite/22_locale/collate/transform/char/28277.cc: New.
1010 * testsuite/22_locale/collate/transform/wchar_t/28277.cc: Likewise.
1011
1012 2006-07-10 Mike Stump <mrs@apple.com>
1013
1014 * libsupc++/eh_globals.cc (~__eh_globals_init): Unset _M_init.
1015
1016 2006-07-10 Benjamin Kosnik <bkoz@redhat.com>
1017
1018 PR libstdc++/15448
1019 * include/Makefile.am: Clean up pch rules.
1020 * include/Makefile.in: Regenerate.
1021
1022 2006-07-09 Paolo Carlini <pcarlini@suse.de>
1023
1024 * include/bits/locale_facets.tcc (__int_to_char<>(_CharT*,
1025 long, const _CharT*, ios_base::fmtflags), __int_to_char<>(_CharT*,
1026 unsigned long, const _CharT*, ios_base::fmtflags),
1027 __int_to_char<>(_CharT*, long long, const _CharT*, ios_base::fmtflags),
1028 __int_to_char<>(_CharT*, unsigned long long, const _CharT*,
1029 ios_base::fmtflags)): Remove.
1030 (__int_to_char<>(_CharT*, _ValueT, const _CharT*, ios_base::fmtflags,
1031 bool)): Adjust.
1032 (num_put<>::_M_insert_int(_OutIter, ios_base&, _CharT, _ValueT)):
1033 Likewise.
1034
1035 2006-07-06 Paolo Carlini <pcarlini@suse.de>
1036
1037 * include/tr1/random (class gamma_distribution<>): Add.
1038 * include/tr1/random.tcc (gamma_distribution<>::operator(),
1039 operator<<(std::basic_ostream<>&, const gamma_distribution<>&)):
1040 Define.
1041 * testsuite/tr1/5_numerical_facilities/random/gamma_distribution/
1042 requirements/typedefs.cc: New.
1043
1044 2006-07-06 Benjamin Kosnik <bkoz@redhat.com>
1045
1046 * testsuite/util/regression/trait/assoc/trait.hpp: Format.
1047 * testsuite/util/regression/rand/priority_queue/
1048 rand_regression_test.hpp: Same.
1049 * testsuite/util/regression/rand/assoc/rand_regression_test.hpp: Same.
1050 * testsuite/util/regression/rand/
1051 assoc/container_rand_regression_test.hpp: Same.
1052 * testsuite/util/regression/priority_queue/common_type.hpp: Same.
1053 * testsuite/util/regression/assoc/common_type.hpp: Same.
1054 * testsuite/util/regression/basic_type.hpp: Same.
1055
1056 2006-07-05 Benjamin Kosnik <bkoz@redhat.com>
1057
1058 * include/Makefile.am (pch_output): New.
1059 (clean-local): Use it.
1060 * include/Makefile.in: Regenerate.
1061
1062 2006-07-04 Paolo Carlini <pcarlini@suse.de>
1063
1064 * include/tr1/random (_Adaptor<>::operator()()): Cast 1 to
1065 result_type.
1066 (variate_generator<>::operator()(),
1067 variate_generator<>::operator()(_Tp)): Inline.
1068
1069 * include/tr1/random: Minor cosmetic changes.
1070
1071 2006-07-03 Paolo Carlini <pcarlini@suse.de>
1072
1073 * include/ext/rc_string_base.h (__rc_string_base::_S_max_size):
1074 Adjust, take into account rounding in _M_create.
1075 (__rc_string_base::_M_create): Add early _S_max_size check.
1076
1077 2006-07-03 Ian Lance Taylor <ian@airs.com>
1078 Paolo Carlini <pcarlini@suse.de>
1079
1080 * include/ext/rc_string_base.h (__rc_string_base::_S_max_size):
1081 Increase by a factor of two.
1082 * include/ext/sso_string_base.h (__sso_string_base::_S_max_size):
1083 Likewise.
1084
1085 2006-07-03 Paolo Carlini <pcarlini@suse.de>
1086
1087 * include/ext/sso_string_base.h (__sso_string_base::_M_create): Never
1088 allocate a string bigger than _S_max_size.
1089
1090 2006-06-29 Benjamin Kosnik <bkoz@redhat.com>
1091
1092 * include/Makefile.am (pch1_input, pch1_output_builddir,
1093 pch1_outputj_installdir, pch1_source): Move from pch_*.
1094 (pch2_input, pch2_output_builddir,
1095 pch2_output_installdir, pch2_source): Clone for ext.
1096 (pch3_input, pch3_output_builddir,
1097 pch3_output_installdir, pch3_source): Clone for tr1.
1098 (install-pch): Same.
1099 * include/Makefile.in: Regenerate.
1100
1101 * include/precompiled: New directory.
1102 * include/stdc++.h: Move...
1103 * include/precompiled/stdc++.h: ... here.
1104 * include/precompiled/stdtr1c++.h: New.
1105 * include/precompiled/extc++.h: New.
1106
1107 * testsuite/lib/libstdc++.exp (libstdc++_init): Set PCH_CXXFLAGS
1108 to -include bits/stdtr1c++.h.
1109
1110 2006-06-29 Benjamin Kosnik <bkoz@redhat.com>
1111
1112 * testsuite/lib/libstdc++.exp (v3_target_compile): Set timeout to
1113 600.
1114
1115 2006-06-27 Benjamin Kosnik <bkoz@redhat.com>
1116
1117 * testsuite/util/regression/rand/priority_queue/
1118 rand_regression_test.hpp: Revert.
1119
1120 2006-06-27 Benjamin Kosnik <bkoz@redhat.com>
1121
1122 * include/ext/typelist.h (typelist_append): To append_typelist.
1123 (typelist): To node.
1124 Enclose in namespace typelist.
1125 * testsuite/util/testsuite_common_types.h: Adjust names, namespaces.
1126 * testsuite/performance/23_containers/find/map.cc: Same.
1127 * testsuite/performance/23_containers/create/map.cc: Same.
1128 * testsuite/performance/23_containers/insert_erase/associative.cc:
1129 Same.
1130 * testsuite/performance/23_containers/insert/sequence.cc: Same.
1131 * testsuite/performance/23_containers/insert/associative.cc: Same.
1132 * testsuite/performance/23_containers/create_from_sorted/set.cc: Same.
1133 * testsuite/performance/23_containers/index/map.cc: Same.
1134 * testsuite/performance/23_containers/insert_from_sorted/set.cc: Same.
1135 * testsuite/performance/23_containers/create_sort/list.cc: Same.
1136 * testsuite/performance/23_containers/sort_search/list.cc: Same.
1137 * testsuite/performance/23_containers/producer_consumer/sequence.cc:
1138 Same.
1139 * testsuite/performance/23_containers/producer_consumer/associative.cc:
1140 Same.
1141
1142 2006-06-26 Benjamin Kosnik <bkoz@redhat.com>
1143
1144 * testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc:
1145 Reduce iterations by half.
1146 * testsuite/ext/pb_ds/regression/hash_data_map_rand.cc: Same.
1147 * testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc: Same.
1148 * testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc: Same.
1149 * testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc: Same.
1150 * testsuite/ext/pb_ds/regression/priority_queue_rand.cc: Same.
1151 * testsuite/ext/pb_ds/regression/tree_data_map_rand.cc: Same.
1152 * testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc: Same.
1153 * testsuite/ext/pb_ds/regression/trie_data_map_rand.cc: Same.
1154
1155 * testsuite/util/regression/rand/assoc/rand_regression_test.hpp:
1156 Set probability of compare from 1 to 0.25.
1157 * testsuite/util/regression/rand/priority_queue/
1158 rand_regression_test.hpp: Same.
1159
1160 2006-06-25 Paolo Carlini <pcarlini@suse.de>
1161
1162 * include/tr1/random (operator<<(std::basic_ostream<>&,
1163 const linear_congruential<>&), operator>>(std::basic_istream<>&,
1164 linear_congruential<>&), operator<<(std::basic_ostream<>&,
1165 const mersenne_twister<>&), operator>>(std::basic_istream<>&,
1166 mersenne_twister<>&), operator<<(std::basic_ostream<>&,
1167 const subtract_with_carry<>&), operator>>(std::basic_istream<>&,
1168 subtract_with_carry<>&), operator<<(std::basic_ostream<>&,
1169 const discard_block<>&), operator>>(std::basic_istream<>&,
1170 discard_block<>&), operator<<(std::basic_ostream<>&,
1171 const xor_combine<>&), operator>>(std::basic_istream<>&,
1172 xor_combine<>&), operator<<(std::basic_ostream<>&,
1173 const uniform_int<>&), operator>>(std::basic_istream<>&,
1174 uniform_int<>&), operator<<(std::basic_ostream<>&,
1175 const bernoulli_distribution&), operator<<(std::basic_ostream<>&,
1176 const geometric_distribution<>&), operator<<(std::basic_ostream<>&,
1177 const uniform_real<>&), operator>>(std::basic_istream<>&,
1178 uniform_real<>&), operator<<(std::basic_ostream<>&,
1179 const exponential_distribution<>&), operator<<(std::basic_ostream<>&,
1180 const normal_distribution<>&), operator>>(std::basic_istream<>&,
1181 normal_distribution<>&)): Redo per TR1 specs; move out of line...
1182 * include/tr1/random.tcc: ... here.
1183
1184 2006-06-24 Paolo Carlini <pcarlini@suse.de>
1185
1186 * include/tr1/random (class normal_distribution<>): Add.
1187 * include/tr1/random.tcc (normal_distribution<>::operator()): Define.
1188
1189 * include/tr1/random.tcc (struct _Max): Remove, "inline" in the
1190 only user, mersenne_twister<>::max().
1191
1192 * include/tr1/random.tcc (struct _Shift): Move...
1193 * include/tr1/random: ... here.
1194
1195 * include/tr1/random.tcc (linear_congruential<>::
1196 linear_congruential(unsigned long), linear_congruential<>::
1197 linear_congruential(_Gen&), mersenne_twister<>::max())): Move inline...
1198 * include/tr1/random: ... here.
1199
1200 * include/tr1/random (exponential_distribution<>::
1201 exponential_distribution(const result_type&)): Add missing
1202 _GLIBCXX_DEBUG_ASSERT.
1203
1204 * testsuite/tr1/5_numerical_facilities/random/
1205 exponential_distribution/requirements/typedefs.cc: New.
1206 * testsuite/tr1/5_numerical_facilities/random/
1207 normal_distribution/requirements/typedefs.cc: Likewise.
1208 * testsuite/tr1/5_numerical_facilities/random/
1209 bernoulli_distribution/requirements/typedefs.cc: Likewise.
1210 * testsuite/tr1/5_numerical_facilities/random/
1211 geometric_distribution/requirements/typedefs.cc: Likewise.
1212
1213 2006-06-23 Benjamin Kosnik <bkoz@redhat.com>
1214
1215 PR libstdc++/27984
1216 * testsuite/lib/libstdc++.exp (libstdc++_init): Adjust
1217 testing includes.
1218 * docs/html/test.html: Adjust for testsuite changes.
1219
1220 2006-06-22 Jonathan Lennox <lennox@cs.columbia.edu>
1221 Paolo Carlini <pcarlini@suse.de>
1222
1223 * include/ext/pb_ds/detail/resize_policy/
1224 hash_prime_size_policy_imp.hpp: Cast to size_t instead.
1225
1226 2006-06-22 Ami Tavory <atavory@gmail.com>
1227
1228 * include/ext/pb_ds/detail/resize_policy/
1229 hash_prime_size_policy_imp.hpp: Fix for 64-bit machines.
1230
1231 2006-06-21 Paolo Carlini <pcarlini@suse.de>
1232
1233 * include/bits/postypes.h (operator==(const fpos<>&, const fpos<>&),
1234 operator!=(const fpos<>&, const fpos<>&)): Add.
1235 * testsuite/27_io/fpos/mbstate_t/6.cc: New.
1236
1237 2006-06-21 Mark Mitchell <mark@codesourcery.com>
1238
1239 * acinclude.m4 (GLIBCXX_EXPORT_INSTALL_INFO): When
1240 cross-compiling, put headers in $prefix/$target/include/c++.
1241 * configure: Regenerated.
1242
1243 2006-06-20 Paolo Carlini <pcarlini@suse.de>
1244
1245 * include/tr1/random.tcc (struct _Private::_Mod_w<>,
1246 _Private::__mod_w<>): Remove.
1247 (struct _Private::_Shift<>): New.
1248 (struct _Private::_Max_w<>): Rename to _Max, use the latter.
1249 (mersenne_twister<>::seed(unsigned long), seed(_Gen&, false_type),
1250 max()): Adjust.
1251
1252 2006-06-20 Vladimir Prus <vladimir@codesourcery.com>
1253
1254 * libsupc++/eh_arm.cc (__cxa_begin_cleanup): Always return 'true'.
1255
1256 2006-06-19 Paolo Carlini <pcarlini@suse.de>
1257
1258 * include/tr1/random (xor_combine<>::operator<<): Fix typo.
1259
1260 * include/tr1/random (bernoulli_distribution::min(),
1261 bernoulli_distribution::max(), geometric_distribution<>::min(),
1262 geometric_distribution<>::max()): Remove.
1263
1264 * include/tr1/random (geometric_distribution<>::operator()):
1265 Simplify formula.
1266
1267 * include/tr1/random: Minor cosmetic changes.
1268
1269 * testsuite/tr1/5_numerical_facilities/random/discard_block/
1270 operators/equal.cc: New.
1271 * testsuite/tr1/5_numerical_facilities/random/discard_block/
1272 operators/not_equal.cc: Likewise.
1273 * testsuite/tr1/5_numerical_facilities/random/discard_block/
1274 operators/serialize.cc: Likewise.
1275 * testsuite/tr1/5_numerical_facilities/random/xor_combine/
1276 operators/equal.cc: Likewise.
1277 * testsuite/tr1/5_numerical_facilities/random/xor_combine/
1278 operators/not_equal.cc: Likewise.
1279 * testsuite/tr1/5_numerical_facilities/random/xor_combine/
1280 operators/serialize.cc: Likewise.
1281
1282 2006-06-17 Ami Tavory <atavory@gmail.com>
1283 Paolo Carlini <pcarlini@suse.de>
1284
1285 * testsuite/util/rng/twister_rand_gen.cc: Adapt to simply use
1286 tr1::mt19937.
1287 * testsuite/util/rng/twister_rand_gen.hpp: Likewise.
1288
1289 2006-06-16 Paolo Carlini <pcarlini@suse.de>
1290
1291 * include/tr1/random (uniform_real<>::uniform_real(_RealType,
1292 _RealType)): Implement.
1293 (uniform_real<>::min()): Likewise.
1294 (uniform_real<>::max()): Likewise.
1295 (uniform_real<>::reset()): Likewise.
1296
1297 * include/tr1/random (class uniform_real<>): Minor cosmetic tweaks.
1298
1299 2006-06-16 Paolo Carlini <pcarlini@suse.de>
1300
1301 * include/bits/locale_facets.tcc (time_get<>::_M_extract_via_format):
1302 Ignore the value of the __err argument.
1303 (time_get<>::do_get_weekday): Likewise.
1304 (time_get<>::do_get_monthname): Likewise.
1305 * testsuite/22_locale/time_get/get_year/wchar_t/5.cc: New.
1306 * testsuite/22_locale/time_get/get_year/char/5.cc: Likewise.
1307 * testsuite/22_locale/time_get/get_monthname/wchar_t/5.cc: Likewise.
1308 * testsuite/22_locale/time_get/get_monthname/char/5.cc: Likewise.
1309 * testsuite/22_locale/time_get/get_weekday/wchar_t/5.cc: Likewise.
1310 * testsuite/22_locale/time_get/get_weekday/char/5.cc: Likewise.
1311 * testsuite/22_locale/time_get/get_date/wchar_t/5.cc: Likewise.
1312 * testsuite/22_locale/time_get/get_date/char/5.cc: Likewise.
1313 * testsuite/22_locale/time_get/get_time/wchar_t/5.cc: Likewise.
1314 * testsuite/22_locale/time_get/get_time/char/5.cc: Likewise.
1315
1316 2006-06-15 Benjamin Kosnik <bkoz@redhat.com>
1317
1318 * include/ext/pb_ds/detail/type_utils.hpp (numeric_traits): Add,
1319 const expression interface to std::numeric_limits::min and max
1320 functions.
1321 * include/ext/pb_ds/trie_policy.hpp (string_trie_e_access_traits):
1322 Use it.
1323
1324 * include/ext/pb_ds/detail/resize_policy/
1325 hash_load_check_resize_trigger_imp.hpp: Format.
1326 * include/ext/pb_ds/detail/pat_trie_/internal_node.hpp: Same.
1327
1328 2006-06-15 Paolo Carlini <pcarlini@suse.de>
1329
1330 * include/tr1/random.tcc (mersenne_twister<>::operator()()):
1331 Reload the last position of the _M_x vector too.
1332
1333 2006-06-15 Paolo Carlini <pcarlini@suse.de>
1334
1335 * include/tr1/random (class xor_combine): Fix result_type typedef.
1336 * testsuite/tr1/5_numerical_facilities/random/xor_combine/
1337 cons/default.cc: New.
1338 * testsuite/tr1/5_numerical_facilities/random/xor_combine/
1339 requirements/typedefs.cc: Tweak.
1340
1341 * include/tr1/random: Minor cosmetic changes.
1342
1343 2006-06-14 Ami Tavory <atavory@gmail.com>
1344 Benjamin Kosnik <bkoz@redhat.com>
1345
1346 * include/ext/pb_assoc: Delete.
1347 * include/ext/pb_ds: Add.
1348 * docs/html/ext/pb_assoc: Delete.
1349 * docs/html/ext/pb_ds: Add.
1350 * testsuite/ext/pb_assoc: Delete.
1351 * testsuite/ext/pb_ds: Add.
1352 * testsuite/performance/ext: Add.
1353 * testsuite/performance/ext/pb_ds: Add.
1354
1355 * testsuite/util/regression: New.
1356 * testsuite/util/rng: New.
1357 * testsuite/util/native_type: New.
1358 * testsuite/util/common_type: New.
1359 * testsuite/util/performance: New.
1360 * testsuite/util/hash_fn: New.
1361 * testsuite/util/io: New.
1362 * testsuite/util/statistic: New.
1363
1364 * scripts/make_graph.py: New.
1365 * scripts/make_graphs.py: New.
1366 * testsuite/data/thirty_years_among_the_dead_preproc.txt: Add.
1367 * testsuite/data/make_graph_htmls.xml: Add.
1368 * testsuite/data/make_graph_test_infos.xml: Add.
1369
1370 * testsuite/lib/libstdc++.exp (v3-build_support): Add in new
1371 object files for regression testing.
1372 * docs/html/documentation.html: Adjust links.
1373 * include/Makefile.am (install-headers): Update for new sources,
1374 directories.
1375 * include/Makefine.in: Regenerate.
1376 * scripts/testsuite_flags.in: Adjust to testsuite/util path.
1377 * scripts/check_performance: Simplify, adjust for new testsuite output.
1378 * testsuite/Makefile.am (check-performance): Adjust.
1379 (doc-performance): New.
1380 * testsuite/Makefile.in: Regenerate.
1381
1382 * include/ext/pb_ds: New.
1383 * include/ext/pb_ds/assoc_container.hpp: Same.
1384 * include/ext/pb_ds/detail: New.
1385 * include/ext/pb_ds/detail/binomial_heap_base_: New.
1386 * include/ext/pb_ds/detail/binomial_heap_base_/erase_fn_imps.hpp: Same.
1387 * include/ext/pb_ds/detail/binomial_heap_base_/find_fn_imps.hpp: Same.
1388 * include/ext/pb_ds/detail/binomial_heap_base_/insert_fn_imps.hpp: Same.
1389 * include/ext/pb_ds/detail/binomial_heap_base_/binomial_heap_base_.hpp: Same.
1390 * include/ext/pb_ds/detail/binomial_heap_base_/debug_fn_imps.hpp: Same.
1391 * include/ext/pb_ds/detail/binomial_heap_base_/constructors_destructor_fn_imps.hpp: Same.
1392 * include/ext/pb_ds/detail/binomial_heap_base_/split_join_fn_imps.hpp: Same.
1393 * include/ext/pb_ds/detail/resize_policy: New.
1394 * include/ext/pb_ds/detail/resize_policy/sample_size_policy.hpp: Same.
1395 * include/ext/pb_ds/detail/resize_policy/hash_prime_size_policy_imp.hpp: Same.
1396 * include/ext/pb_ds/detail/resize_policy/cc_hash_max_collision_check_resize_trigger_imp.hpp: Same.
1397 * include/ext/pb_ds/detail/resize_policy/sample_resize_policy.hpp: Same.
1398 * include/ext/pb_ds/detail/resize_policy/sample_resize_trigger.hpp: Same.
1399 * include/ext/pb_ds/detail/resize_policy/hash_load_check_resize_trigger_size_base.hpp: Same.
1400 * include/ext/pb_ds/detail/resize_policy/hash_exponential_size_policy_imp.hpp: Same.
1401 * include/ext/pb_ds/detail/resize_policy/hash_load_check_resize_trigger_imp.hpp: Same.
1402 * include/ext/pb_ds/detail/resize_policy/hash_standard_resize_policy_imp.hpp: Same.
1403 * include/ext/pb_ds/detail/container_base_dispatch.hpp: Same.
1404 * include/ext/pb_ds/detail/cc_hash_table_map_: New.
1405 * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_no_store_hash_fn_imps.hpp: Same.
1406 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_store_hash_fn_imps.hpp: Same.
1407 * include/ext/pb_ds/detail/cc_hash_table_map_/cmp_fn_imps.hpp: Same.
1408 * include/ext/pb_ds/detail/cc_hash_table_map_/insert_no_store_hash_fn_imps.hpp: Same.
1409 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_store_hash_fn_imps.hpp: Same.
1410 * include/ext/pb_ds/detail/cc_hash_table_map_/policy_access_fn_imps.hpp: Same.
1411 * include/ext/pb_ds/detail/cc_hash_table_map_/find_fn_imps.hpp: Same.
1412 * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_store_hash_fn_imps.hpp: Same.
1413 * include/ext/pb_ds/detail/cc_hash_table_map_/insert_store_hash_fn_imps.hpp: Same.
1414 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_fn_imps.hpp: Same.
1415 * include/ext/pb_ds/detail/cc_hash_table_map_/info_fn_imps.hpp: Same.
1416 * include/ext/pb_ds/detail/cc_hash_table_map_/entry_list_fn_imps.hpp: Same.
1417 * include/ext/pb_ds/detail/cc_hash_table_map_/trace_fn_imps.hpp: Same.
1418 * include/ext/pb_ds/detail/cc_hash_table_map_/find_store_hash_fn_imps.hpp: Same.
1419 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_fn_imps.hpp: Same.
1420 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_fn_imps.hpp: Same.
1421 * include/ext/pb_ds/detail/cc_hash_table_map_/cc_ht_map_.hpp: Same.
1422 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_no_store_hash_fn_imps.hpp: Same.
1423 * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_fn_imps.hpp: Same.
1424 * include/ext/pb_ds/detail/cc_hash_table_map_/cond_key_dtor_entry_dealtor.hpp: Same.
1425 * include/ext/pb_ds/detail/cc_hash_table_map_/insert_fn_imps.hpp: Same.
1426 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_store_hash_fn_imps.hpp: Same.
1427 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_no_store_hash_fn_imps.hpp: Same.
1428 * include/ext/pb_ds/detail/cc_hash_table_map_/size_fn_imps.hpp: Same.
1429 * include/ext/pb_ds/detail/cc_hash_table_map_/standard_policies.hpp: Same.
1430 * include/ext/pb_ds/detail/cc_hash_table_map_/iterators_fn_imps.hpp: Same.
1431 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_no_store_hash_fn_imps.hpp: Same.
1432 * include/ext/pb_ds/detail/typelist_assoc_container.hpp: Same.
1433 * include/ext/pb_ds/detail/tree_trace_base.hpp: Same.
1434 * include/ext/pb_ds/detail/unordered_iterator: New.
1435 * include/ext/pb_ds/detail/unordered_iterator/iterator.hpp: Same.
1436 * include/ext/pb_ds/detail/unordered_iterator/const_iterator.hpp: Same.
1437 * include/ext/pb_ds/detail/unordered_iterator/point_iterator.hpp: Same.
1438 * include/ext/pb_ds/detail/unordered_iterator/const_point_iterator.hpp: Same.
1439 * include/ext/pb_ds/detail/typelist.hpp: Same.
1440 * include/ext/pb_ds/detail/pat_trie_: New.
1441 * include/ext/pb_ds/detail/pat_trie_/r_erase_fn_imps.hpp: Same.
1442 * include/ext/pb_ds/detail/pat_trie_/policy_access_fn_imps.hpp: Same.
1443 * include/ext/pb_ds/detail/pat_trie_/find_fn_imps.hpp: Same.
1444 * include/ext/pb_ds/detail/pat_trie_/child_iterator.hpp: Same.
1445 * include/ext/pb_ds/detail/pat_trie_/update_fn_imps.hpp: Same.
1446 * include/ext/pb_ds/detail/pat_trie_/insert_join_fn_imps.hpp: Same.
1447 * include/ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp: Same.
1448 * include/ext/pb_ds/detail/pat_trie_/constructors_destructor_fn_imps.hpp: Same.
1449 * include/ext/pb_ds/detail/pat_trie_/debug_fn_imps.hpp: Same.
1450 * include/ext/pb_ds/detail/pat_trie_/head.hpp: Same.
1451 * include/ext/pb_ds/detail/pat_trie_/const_child_iterator.hpp: Same.
1452 * include/ext/pb_ds/detail/pat_trie_/split_fn_imps.hpp: Same.
1453 * include/ext/pb_ds/detail/pat_trie_/traits.hpp: Same.
1454 * include/ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp: Same.
1455 * include/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp: Same.
1456 * include/ext/pb_ds/detail/pat_trie_/info_fn_imps.hpp: Same.
1457 * include/ext/pb_ds/detail/pat_trie_/leaf.hpp: Same.
1458 * include/ext/pb_ds/detail/pat_trie_/trace_fn_imps.hpp: Same.
1459 * include/ext/pb_ds/detail/pat_trie_/rotate_fn_imps.hpp: Same.
1460 * include/ext/pb_ds/detail/pat_trie_/erase_fn_imps.hpp: Same.
1461 * include/ext/pb_ds/detail/pat_trie_/node_base.hpp: Same.
1462 * include/ext/pb_ds/detail/pat_trie_/node_metadata_base.hpp: Same.
1463 * include/ext/pb_ds/detail/pat_trie_/synth_e_access_traits.hpp: Same.
1464 * include/ext/pb_ds/detail/pat_trie_/node_iterators.hpp: Same.
1465 * include/ext/pb_ds/detail/pat_trie_/internal_node.hpp: Same.
1466 * include/ext/pb_ds/detail/pat_trie_/point_iterators.hpp: Same.
1467 * include/ext/pb_ds/detail/pat_trie_/iterators_fn_imps.hpp: Same.
1468 * include/ext/pb_ds/detail/bin_search_tree_: New.
1469 * include/ext/pb_ds/detail/bin_search_tree_/policy_access_fn_imps.hpp: Same.
1470 * include/ext/pb_ds/detail/bin_search_tree_/find_fn_imps.hpp: Same.
1471 * include/ext/pb_ds/detail/bin_search_tree_/r_erase_fn_imps.hpp: Same.
1472 * include/ext/pb_ds/detail/bin_search_tree_/constructors_destructor_fn_imps.hpp: Same.
1473 * include/ext/pb_ds/detail/bin_search_tree_/debug_fn_imps.hpp: Same.
1474 * include/ext/pb_ds/detail/bin_search_tree_/cond_dtor_entry_dealtor.hpp: Same.
1475 * include/ext/pb_ds/detail/bin_search_tree_/traits.hpp: Same.
1476 * include/ext/pb_ds/detail/bin_search_tree_/info_fn_imps.hpp: Same.
1477 * include/ext/pb_ds/detail/bin_search_tree_/rotate_fn_imps.hpp: Same.
1478 * include/ext/pb_ds/detail/bin_search_tree_/erase_fn_imps.hpp: Same.
1479 * include/ext/pb_ds/detail/bin_search_tree_/bin_search_tree_.hpp: Same.
1480 * include/ext/pb_ds/detail/bin_search_tree_/cond_key_dtor_entry_dealtor.hpp: Same.
1481 * include/ext/pb_ds/detail/bin_search_tree_/insert_fn_imps.hpp: Same.
1482 * include/ext/pb_ds/detail/bin_search_tree_/node_iterators.hpp: Same.
1483 * include/ext/pb_ds/detail/bin_search_tree_/point_iterators.hpp: Same.
1484 * include/ext/pb_ds/detail/bin_search_tree_/split_join_fn_imps.hpp: Same.
1485 * include/ext/pb_ds/detail/bin_search_tree_/iterators_fn_imps.hpp: Same.
1486 * include/ext/pb_ds/detail/gp_hash_table_map_: New.
1487 * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_no_store_hash_fn_imps.hpp: Same.
1488 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_store_hash_fn_imps.hpp: Same.
1489 * include/ext/pb_ds/detail/gp_hash_table_map_/insert_no_store_hash_fn_imps.hpp: Same.
1490 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_store_hash_fn_imps.hpp: Same.
1491 * include/ext/pb_ds/detail/gp_hash_table_map_/policy_access_fn_imps.hpp: Same.
1492 * include/ext/pb_ds/detail/gp_hash_table_map_/find_fn_imps.hpp: Same.
1493 * include/ext/pb_ds/detail/gp_hash_table_map_/gp_ht_map_.hpp: Same.
1494 * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_store_hash_fn_imps.hpp: Same.
1495 * include/ext/pb_ds/detail/gp_hash_table_map_/insert_store_hash_fn_imps.hpp: Same.
1496 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_fn_imps.hpp: Same.
1497 * include/ext/pb_ds/detail/gp_hash_table_map_/iterator_fn_imps.hpp: Same.
1498 * include/ext/pb_ds/detail/gp_hash_table_map_/info_fn_imps.hpp: Same.
1499 * include/ext/pb_ds/detail/gp_hash_table_map_/find_no_store_hash_fn_imps.hpp: Same.
1500 * include/ext/pb_ds/detail/gp_hash_table_map_/trace_fn_imps.hpp: Same.
1501 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_fn_imps.hpp: Same.
1502 * include/ext/pb_ds/detail/gp_hash_table_map_/find_store_hash_fn_imps.hpp: Same.
1503 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_fn_imps.hpp: Same.
1504 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_no_store_hash_fn_imps.hpp: Same.
1505 * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_fn_imps.hpp: Same.
1506 * include/ext/pb_ds/detail/gp_hash_table_map_/insert_fn_imps.hpp: Same.
1507 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_store_hash_fn_imps.hpp: Same.
1508 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_no_store_hash_fn_imps.hpp: Same.
1509 * include/ext/pb_ds/detail/gp_hash_table_map_/standard_policies.hpp: Same.
1510 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_no_store_hash_fn_imps.hpp: Same.
1511 * include/ext/pb_ds/detail/standard_policies.hpp: Same.
1512 * include/ext/pb_ds/detail/typelist: New.
1513 * include/ext/pb_ds/detail/typelist/typelist_flatten.hpp: Same.
1514 * include/ext/pb_ds/detail/typelist/typelist_contains.hpp: Same.
1515 * include/ext/pb_ds/detail/typelist/typelist_typelist_append.hpp: Same.
1516 * include/ext/pb_ds/detail/typelist/typelist_apply.hpp: Same.
1517 * include/ext/pb_ds/detail/typelist/typelist_filter.hpp: Same.
1518 * include/ext/pb_ds/detail/typelist/typelist_append.hpp: Same.
1519 * include/ext/pb_ds/detail/typelist/typelist_assoc_container_find.hpp: Same.
1520 * include/ext/pb_ds/detail/typelist/typelist_transform.hpp: Same.
1521 * include/ext/pb_ds/detail/typelist/typelist_at_index.hpp: Same.
1522 * include/ext/pb_ds/detail/tree_policy: New.
1523 * include/ext/pb_ds/detail/tree_policy/order_statistics_imp.hpp: Same.
1524 * include/ext/pb_ds/detail/tree_policy/node_metadata_selector.hpp: Same.
1525 * include/ext/pb_ds/detail/tree_policy/null_node_update_imp.hpp: Same.
1526 * include/ext/pb_ds/detail/tree_policy/sample_tree_node_update.hpp: Same.
1527 * include/ext/pb_ds/detail/basic_tree_policy: New.
1528 * include/ext/pb_ds/detail/basic_tree_policy/basic_tree_policy_base.hpp: Same.
1529 * include/ext/pb_ds/detail/basic_tree_policy/null_node_metadata.hpp: Same.
1530 * include/ext/pb_ds/detail/basic_tree_policy/traits.hpp: Same.
1531 * include/ext/pb_ds/detail/types_traits.hpp: Same.
1532 * include/ext/pb_ds/detail/binary_heap_: New.
1533 * include/ext/pb_ds/detail/binary_heap_/policy_access_fn_imps.hpp: Same.
1534 * include/ext/pb_ds/detail/binary_heap_/find_fn_imps.hpp: Same.
1535 * include/ext/pb_ds/detail/binary_heap_/const_iterator.hpp: Same.
1536 * include/ext/pb_ds/detail/binary_heap_/entry_cmp.hpp: Same.
1537 * include/ext/pb_ds/detail/binary_heap_/constructors_destructor_fn_imps.hpp: Same.
1538 * include/ext/pb_ds/detail/binary_heap_/debug_fn_imps.hpp: Same.
1539 * include/ext/pb_ds/detail/binary_heap_/info_fn_imps.hpp: Same.
1540 * include/ext/pb_ds/detail/binary_heap_/const_point_iterator.hpp: Same.
1541 * include/ext/pb_ds/detail/binary_heap_/trace_fn_imps.hpp: Same.
1542 * include/ext/pb_ds/detail/binary_heap_/erase_fn_imps.hpp: Same.
1543 * include/ext/pb_ds/detail/binary_heap_/entry_pred.hpp: Same.
1544 * include/ext/pb_ds/detail/binary_heap_/insert_fn_imps.hpp: Same.
1545 * include/ext/pb_ds/detail/binary_heap_/resize_policy.hpp: Same.
1546 * include/ext/pb_ds/detail/binary_heap_/binary_heap_.hpp: Same.
1547 * include/ext/pb_ds/detail/binary_heap_/split_join_fn_imps.hpp: Same.
1548 * include/ext/pb_ds/detail/binary_heap_/iterators_fn_imps.hpp: Same.
1549 * include/ext/pb_ds/detail/trie_policy: New.
1550 * include/ext/pb_ds/detail/trie_policy/string_trie_e_access_traits_imp.hpp: Same.
1551 * include/ext/pb_ds/detail/trie_policy/order_statistics_imp.hpp: Same.
1552 * include/ext/pb_ds/detail/trie_policy/sample_trie_node_update.hpp: Same.
1553 * include/ext/pb_ds/detail/trie_policy/trie_policy_base.hpp: Same.
1554 * include/ext/pb_ds/detail/trie_policy/prefix_search_node_update_imp.hpp: Same.
1555 * include/ext/pb_ds/detail/trie_policy/sample_trie_e_access_traits.hpp: Same.
1556 * include/ext/pb_ds/detail/trie_policy/node_metadata_selector.hpp: Same.
1557 * include/ext/pb_ds/detail/trie_policy/null_node_update_imp.hpp: Same.
1558 * include/ext/pb_ds/detail/cond_dealtor.hpp: Same.
1559 * include/ext/pb_ds/detail/priority_queue_base_dispatch.hpp: Same.
1560 * include/ext/pb_ds/detail/pairing_heap_: Name.
1561 * include/ext/pb_ds/detail/pairing_heap_/erase_fn_imps.hpp: Same.
1562 * include/ext/pb_ds/detail/pairing_heap_/find_fn_imps.hpp: Same.
1563 * include/ext/pb_ds/detail/pairing_heap_/insert_fn_imps.hpp: Same.
1564 * include/ext/pb_ds/detail/pairing_heap_/debug_fn_imps.hpp: Same.
1565 * include/ext/pb_ds/detail/pairing_heap_/constructors_destructor_fn_imps.hpp: Same.
1566 * include/ext/pb_ds/detail/pairing_heap_/pairing_heap_.hpp: Same.
1567 * include/ext/pb_ds/detail/pairing_heap_/split_join_fn_imps.hpp: Same.
1568 * include/ext/pb_ds/detail/binomial_heap_: New.
1569 * include/ext/pb_ds/detail/binomial_heap_/debug_fn_imps.hpp: Same.
1570 * include/ext/pb_ds/detail/binomial_heap_/constructors_destructor_fn_imps.hpp: Same.
1571 * include/ext/pb_ds/detail/binomial_heap_/binomial_heap_.hpp: Same.
1572 * include/ext/pb_ds/detail/constructors_destructor_fn_imps.hpp: Same.
1573 * include/ext/pb_ds/detail/type_utils.hpp: Same.
1574 * include/ext/pb_ds/detail/eq_fn: New.
1575 * include/ext/pb_ds/detail/eq_fn/hash_eq_fn.hpp: Same.
1576 * include/ext/pb_ds/detail/eq_fn/eq_by_less.hpp: Same.
1577 * include/ext/pb_ds/detail/basic_types.hpp: Same.
1578 * include/ext/pb_ds/detail/list_update_policy: New.
1579 * include/ext/pb_ds/detail/list_update_policy/mtf_lu_policy_imp.hpp: Same.
1580 * include/ext/pb_ds/detail/list_update_policy/counter_lu_metadata.hpp: Same.
1581 * include/ext/pb_ds/detail/list_update_policy/sample_update_policy.hpp: Same.
1582 * include/ext/pb_ds/detail/list_update_policy/counter_lu_policy_imp.hpp: Same.
1583 * include/ext/pb_ds/detail/thin_heap_: New.
1584 * include/ext/pb_ds/detail/thin_heap_/trace_fn_imps.hpp: Same.
1585 * include/ext/pb_ds/detail/thin_heap_/erase_fn_imps.hpp: Same.
1586 * include/ext/pb_ds/detail/thin_heap_/find_fn_imps.hpp: Same.
1587 * include/ext/pb_ds/detail/thin_heap_/thin_heap_.hpp: Same.
1588 * include/ext/pb_ds/detail/thin_heap_/insert_fn_imps.hpp: Same.
1589 * include/ext/pb_ds/detail/thin_heap_/debug_fn_imps.hpp: Same.
1590 * include/ext/pb_ds/detail/thin_heap_/constructors_destructor_fn_imps.hpp: Same.
1591 * include/ext/pb_ds/detail/thin_heap_/split_join_fn_imps.hpp: Same.
1592 * include/ext/pb_ds/detail/left_child_next_sibling_heap_: New.
1593 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/trace_fn_imps.hpp: Same.
1594 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/erase_fn_imps.hpp: Same.
1595 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/null_metadata.hpp: Same.
1596 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/policy_access_fn_imps.hpp: Same.
1597 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/left_child_next_sibling_heap_.hpp: Same.
1598 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/insert_fn_imps.hpp: Same.
1599 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/const_iterator.hpp: Same.
1600 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/debug_fn_imps.hpp: Same.
1601 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/constructors_destructor_fn_imps.hpp: Same.
1602 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/node.hpp: Same.
1603 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/info_fn_imps.hpp: Same.
1604 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/iterators_fn_imps.hpp: Same.
1605 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/const_point_iterator.hpp: Same.
1606 * include/ext/pb_ds/detail/ov_tree_map_: New.
1607 * include/ext/pb_ds/detail/ov_tree_map_/erase_fn_imps.hpp: Same.
1608 * include/ext/pb_ds/detail/ov_tree_map_/policy_access_fn_imps.hpp: Same.
1609 * include/ext/pb_ds/detail/ov_tree_map_/cond_dtor.hpp: Same.
1610 * include/ext/pb_ds/detail/ov_tree_map_/insert_fn_imps.hpp: Same.
1611 * include/ext/pb_ds/detail/ov_tree_map_/ov_tree_map_.hpp: Same.
1612 * include/ext/pb_ds/detail/ov_tree_map_/node_iterators.hpp: Same.
1613 * include/ext/pb_ds/detail/ov_tree_map_/debug_fn_imps.hpp: Same.
1614 * include/ext/pb_ds/detail/ov_tree_map_/constructors_destructor_fn_imps.hpp: Same.
1615 * include/ext/pb_ds/detail/ov_tree_map_/split_join_fn_imps.hpp: Same.
1616 * include/ext/pb_ds/detail/ov_tree_map_/traits.hpp: Same.
1617 * include/ext/pb_ds/detail/ov_tree_map_/info_fn_imps.hpp: Same.
1618 * include/ext/pb_ds/detail/ov_tree_map_/iterators_fn_imps.hpp: Same.
1619 * include/ext/pb_ds/detail/map_debug_base.hpp: Same.
1620 * include/ext/pb_ds/detail/hash_fn: New.
1621 * include/ext/pb_ds/detail/hash_fn/linear_probe_fn_imp.hpp: Same.
1622 * include/ext/pb_ds/detail/hash_fn/mod_based_range_hashing.hpp: Same.
1623 * include/ext/pb_ds/detail/hash_fn/ranged_probe_fn.hpp: Same.
1624 * include/ext/pb_ds/detail/hash_fn/sample_probe_fn.hpp: Same.
1625 * include/ext/pb_ds/detail/hash_fn/direct_mod_range_hashing_imp.hpp: Same.
1626 * include/ext/pb_ds/detail/hash_fn/sample_ranged_probe_fn.hpp: Same.
1627 * include/ext/pb_ds/detail/hash_fn/quadratic_probe_fn_imp.hpp: Same.
1628 * include/ext/pb_ds/detail/hash_fn/sample_range_hashing.hpp: Same.
1629 * include/ext/pb_ds/detail/hash_fn/probe_fn_base.hpp: Same.
1630 * include/ext/pb_ds/detail/hash_fn/ranged_hash_fn.hpp: Same.
1631 * include/ext/pb_ds/detail/hash_fn/mask_based_range_hashing.hpp: Same.
1632 * include/ext/pb_ds/detail/hash_fn/sample_ranged_hash_fn.hpp: Same.
1633 * include/ext/pb_ds/detail/hash_fn/direct_mask_range_hashing_imp.hpp: Same.
1634 * include/ext/pb_ds/detail/splay_tree_: New.
1635 * include/ext/pb_ds/detail/splay_tree_/erase_fn_imps.hpp: Same.
1636 * include/ext/pb_ds/detail/splay_tree_/find_fn_imps.hpp: Same.
1637 * include/ext/pb_ds/detail/splay_tree_/insert_fn_imps.hpp: Same.
1638 * include/ext/pb_ds/detail/splay_tree_/debug_fn_imps.hpp: Same.
1639 * include/ext/pb_ds/detail/splay_tree_/constructors_destructor_fn_imps.hpp: Same.
1640 * include/ext/pb_ds/detail/splay_tree_/splay_fn_imps.hpp: Same.
1641 * include/ext/pb_ds/detail/splay_tree_/node.hpp: Same.
1642 * include/ext/pb_ds/detail/splay_tree_/split_join_fn_imps.hpp: Same.
1643 * include/ext/pb_ds/detail/splay_tree_/splay_tree_.hpp: Same.
1644 * include/ext/pb_ds/detail/splay_tree_/traits.hpp: Same.
1645 * include/ext/pb_ds/detail/splay_tree_/info_fn_imps.hpp: Same.
1646 * include/ext/pb_ds/detail/list_update_map_: New.
1647 * include/ext/pb_ds/detail/list_update_map_/trace_fn_imps.hpp: Same.
1648 * include/ext/pb_ds/detail/list_update_map_/erase_fn_imps.hpp: Same.
1649 * include/ext/pb_ds/detail/list_update_map_/find_fn_imps.hpp: Same.
1650 * include/ext/pb_ds/detail/list_update_map_/entry_metadata_base.hpp: Same.
1651 * include/ext/pb_ds/detail/list_update_map_/lu_map_.hpp: Same.
1652 * include/ext/pb_ds/detail/list_update_map_/constructor_destructor_fn_imps.hpp: Same.
1653 * include/ext/pb_ds/detail/list_update_map_/insert_fn_imps.hpp: Same.
1654 * include/ext/pb_ds/detail/list_update_map_/debug_fn_imps.hpp: Same.
1655 * include/ext/pb_ds/detail/list_update_map_/info_fn_imps.hpp: Same.
1656 * include/ext/pb_ds/detail/list_update_map_/iterators_fn_imps.hpp: Same.
1657 * include/ext/pb_ds/detail/rc_binomial_heap_: New.
1658 * include/ext/pb_ds/detail/rc_binomial_heap_/trace_fn_imps.hpp: Same.
1659 * include/ext/pb_ds/detail/rc_binomial_heap_/erase_fn_imps.hpp: Same.
1660 * include/ext/pb_ds/detail/rc_binomial_heap_/rc_binomial_heap_.hpp: Same.
1661 * include/ext/pb_ds/detail/rc_binomial_heap_/insert_fn_imps.hpp: Same.
1662 * include/ext/pb_ds/detail/rc_binomial_heap_/debug_fn_imps.hpp: Same.
1663 * include/ext/pb_ds/detail/rc_binomial_heap_/constructors_destructor_fn_imps.hpp: Same.
1664 * include/ext/pb_ds/detail/rc_binomial_heap_/rc.hpp: Same.
1665 * include/ext/pb_ds/detail/rc_binomial_heap_/split_join_fn_imps.hpp: Same.
1666 * include/ext/pb_ds/detail/rb_tree_map_: New.
1667 * include/ext/pb_ds/detail/rb_tree_map_/erase_fn_imps.hpp: Same.
1668 * include/ext/pb_ds/detail/rb_tree_map_/find_fn_imps.hpp: Same.
1669 * include/ext/pb_ds/detail/rb_tree_map_/insert_fn_imps.hpp: Same.
1670 * include/ext/pb_ds/detail/rb_tree_map_/rb_tree_.hpp: Same.
1671 * include/ext/pb_ds/detail/rb_tree_map_/debug_fn_imps.hpp: Same.
1672 * include/ext/pb_ds/detail/rb_tree_map_/constructors_destructor_fn_imps.hpp: Same.
1673 * include/ext/pb_ds/detail/rb_tree_map_/node.hpp: Same.
1674 * include/ext/pb_ds/detail/rb_tree_map_/split_join_fn_imps.hpp: Same.
1675 * include/ext/pb_ds/detail/rb_tree_map_/traits.hpp: Same.
1676 * include/ext/pb_ds/detail/rb_tree_map_/info_fn_imps.hpp: Same.
1677 * include/ext/pb_ds/list_update_policy.hpp: Same.
1678 * include/ext/pb_ds/exception.hpp: Same.
1679 * include/ext/pb_ds/tree_policy.hpp: Same.
1680 * include/ext/pb_ds/tag_and_trait.hpp: Same.
1681 * include/ext/pb_ds/hash_policy.hpp: Same.
1682 * include/ext/pb_ds/trie_policy.hpp: Same.
1683 * include/ext/pb_ds/priority_queue.hpp: Same.
1684
1685 * docs/html/ext/pb_ds: New.
1686 * docs/html/ext/pb_ds/container_tag.html: Same.
1687 * docs/html/ext/pb_ds/trivial_iterator_tag.html: Same.
1688 * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_local.png
1689 * docs/html/ext/pb_ds/sample_trie_e_access_traits.html: Same.
1690 * docs/html/ext/pb_ds/gp_hash_table.html: Same.
1691 * docs/html/ext/pb_ds/priority_queue_tag_cd.svg
1692 * docs/html/ext/pb_ds/container_cd.svg
1693 * docs/html/ext/pb_ds/linear_probe_fn.html: Same.
1694 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_local.png
1695 * docs/html/ext/pb_ds/quadratic_probe_fn.html: Same.
1696 * docs/html/ext/pb_ds/assoc_regression_tests.html: Same.
1697 * docs/html/ext/pb_ds/tree_tag.html: Same.
1698 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test.html: Same.
1699 * docs/html/ext/pb_ds/interface.html: Same.
1700 * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_msvc.png
1701 * docs/html/ext/pb_ds/hash_random_int_subscript_find_timing_test.html: Same.
1702 * docs/html/ext/pb_ds/lu_based_containers.html: Same.
1703 * docs/html/ext/pb_ds/embedded_lists_3.png
1704 * docs/html/ext/pb_ds/tree_text_find_find_timing_test.html: Same.
1705 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_local.png
1706 * docs/html/ext/pb_ds/assoc_performance_tests.html: Same.
1707 * docs/html/ext/pb_ds/list_update.html: Same.
1708 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_gcc.png
1709 * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_local.png
1710 * docs/html/ext/pb_ds/point_iterators_range_ops_1.png
1711 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_msvc.png
1712 * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_gcc.png
1713 * docs/html/ext/pb_ds/text_find_timing_test_tree_like_msvc.png
1714 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_local.png
1715 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_local.png
1716 * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_msvc.png
1717 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test.html: Same.
1718 * docs/html/ext/pb_ds/move_to_front_lu_policy.html: Same.
1719 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_gcc.png
1720 * docs/html/ext/pb_ds/hash_random_int_find_find_timing_test.html: Same.
1721 * docs/html/ext/pb_ds/string_trie_e_access_traits.html: Same.
1722 * docs/html/ext/pb_ds/prerequisites.html: Same.
1723 * docs/html/ext/pb_ds/gp_hash_tag.html: Same.
1724 * docs/html/ext/pb_ds/priority_queue_tag_cd.png
1725 * docs/html/ext/pb_ds/container_cd.png
1726 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_gcc.png
1727 * docs/html/ext/pb_ds/container_base.html: Same.
1728 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_msvc.png
1729 * docs/html/ext/pb_ds/tree_random_int_find_find_timing_test.html: Same.
1730 * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_msvc.png
1731 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_local.png
1732 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_gcc.png
1733 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_msvc.png
1734 * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_msvc.png
1735 * docs/html/ext/pb_ds/text_find_timing_test_hash_local.png
1736 * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_msvc.png
1737 * docs/html/ext/pb_ds/ov_tree_tag.html: Same.
1738 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_local.png
1739 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_msvc.png
1740 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_msvc.png
1741 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_msvc.png
1742 * docs/html/ext/pb_ds/list_update_tag.html: Same.
1743 * docs/html/ext/pb_ds/balls_and_bins.png
1744 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_local.png
1745 * docs/html/ext/pb_ds/disclaimer.html: Same.
1746 * docs/html/ext/pb_ds/insert_error.html: Same.
1747 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_gcc.png
1748 * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_gcc.png
1749 * docs/html/ext/pb_ds/examples.html: Same.
1750 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small.html: Same.
1751 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_gcc.png
1752 * docs/html/ext/pb_ds/sample_probe_fn.html: Same.
1753 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_local.png
1754 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test.html: Same.
1755 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_gcc.png
1756 * docs/html/ext/pb_ds/null_mapped_type.html: Same.
1757 * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_gcc.png
1758 * docs/html/ext/pb_ds/tree_order_statistics_timing_test_gcc.png
1759 * docs/html/ext/pb_ds/associative_container_tag.html: Same.
1760 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_local.png
1761 * docs/html/ext/pb_ds/design.html: Same.
1762 * docs/html/ext/pb_ds/cc_hash_max_collision_check_resize_trigger.html: Same.
1763 * docs/html/ext/pb_ds/pairing_heap_tag.html: Same.
1764 * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_gcc.png
1765 * docs/html/ext/pb_ds/references.html: Same.
1766 * docs/html/ext/pb_ds/tree_order_statistics_timing_test_msvc.png
1767 * docs/html/ext/pb_ds/hash_load_check_resize_trigger.html: Same.
1768 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_gcc.png
1769 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_gcc.png
1770 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_gcc.png
1771 * docs/html/ext/pb_ds/pq_different_underlying_dss.png
1772 * docs/html/ext/pb_ds/insert_resize_sequence_diagram1.png
1773 * docs/html/ext/pb_ds/pq_regression_tests.html: Same.
1774 * docs/html/ext/pb_ds/sample_tree_node_update.html: Same.
1775 * docs/html/ext/pb_ds/invalidation_guarantee_erase.png
1776 * docs/html/ext/pb_ds/basic_invalidation_guarantee.html: Same.
1777 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_local.png
1778 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_gcc.png
1779 * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_local.png
1780 * docs/html/ext/pb_ds/point_iterators_range_ops_2.png
1781 * docs/html/ext/pb_ds/null_probe_fn.html: Same.
1782 * docs/html/ext/pb_ds/hash_prime_size_policy.html: Same.
1783 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_msvc.png
1784 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_gcc.png
1785 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_local.png
1786 * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_local.png
1787 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_msvc.png
1788 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_gcc.png
1789 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large.html: Same.
1790 * docs/html/ext/pb_ds/sample_resize_policy.html: Same.
1791 * docs/html/ext/pb_ds/binomial_heap_tag.html: Same.
1792 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_local.png
1793 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_local.png
1794 * docs/html/ext/pb_ds/tree_text_lor_find_find_timing_test.html: Same.
1795 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_msvc.png
1796 * docs/html/ext/pb_ds/trie_based_containers.html: Same.
1797 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_gcc.png
1798 * docs/html/ext/pb_ds/tree_split_join_timing_test_local.png
1799 * docs/html/ext/pb_ds/text_find_timing_test_hash_gcc.png
1800 * docs/html/ext/pb_ds/motivation.html: Same.
1801 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_msvc.png
1802 * docs/html/ext/pb_ds/tree_split_join_timing_test_gcc.png
1803 * docs/html/ext/pb_ds/tree.html: Same.
1804 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_gcc.png
1805 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_msvc.png
1806 * docs/html/ext/pb_ds/invalidation_guarantee_cd.png
1807 * docs/html/ext/pb_ds/tutorial.html: Same.
1808 * docs/html/ext/pb_ds/null_trie_node_update.html: Same.
1809 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_gcc.png
1810 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_msvc.png
1811 * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_local.png
1812 * docs/html/ext/pb_ds/point_iterators_cd.png
1813 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_local.png
1814 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_local.png
1815 * docs/html/ext/pb_ds/rb_tree_tag.html: Same.
1816 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_msvc.png
1817 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_msvc.png
1818 * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_gcc.png
1819 * docs/html/ext/pb_ds/exceptions.html: Same.
1820 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_msvc.png
1821 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_local.png
1822 * docs/html/ext/pb_ds/hash_policy_cd.png
1823 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_gcc.png
1824 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small.html: Same.
1825 * docs/html/ext/pb_ds/ds_gen.html: Same.
1826 * docs/html/ext/pb_ds/hash_exponential_size_policy.html: Same.
1827 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_local.png
1828 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_msvc.png
1829 * docs/html/ext/pb_ds/index.html: Same.
1830 * docs/html/ext/pb_ds/binary_heap_tag.html: Same.
1831 * docs/html/ext/pb_ds/basic_hash_tag.html: Same.
1832 * docs/html/ext/pb_ds/trie_order_statistics_node_update.html: Same.
1833 * docs/html/ext/pb_ds/sample_resize_trigger.html: Same.
1834 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_local.png
1835 * docs/html/ext/pb_ds/hash_text_find_find_timing_test.html: Same.
1836 * docs/html/ext/pb_ds/tree_text_insert_timing_test.html: Same.
1837 * docs/html/ext/pb_ds/trie_tag.html: Same.
1838 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_local.png
1839 * docs/html/ext/pb_ds/pq_tests.html: Same.
1840 * docs/html/ext/pb_ds/insert_resize_sequence_diagram2.png
1841 * docs/html/ext/pb_ds/node_invariant_invalidations.png
1842 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_msvc.png
1843 * docs/html/ext/pb_ds/resize_policy_cd.png
1844 * docs/html/ext/pb_ds/embedded_lists_1.png
1845 * docs/html/ext/pb_ds/hash_ranged_hash_range_hashing_fns.png
1846 * docs/html/ext/pb_ds/null_lu_metadata.html: Same.
1847 * docs/html/ext/pb_ds/tree_order_statistics_timing_test.html: Same.
1848 * docs/html/ext/pb_ds/trie_prefix_search_node_update.html: Same.
1849 * docs/html/ext/pb_ds/hash_range_hashing_seq_diagram.png
1850 * docs/html/ext/pb_ds/point_invalidation_guarantee.html: Same.
1851 * docs/html/ext/pb_ds/direct_mod_range_hashing.html: Same.
1852 * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_local.png
1853 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_msvc.png
1854 * docs/html/ext/pb_ds/misc.html: Same.
1855 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_local.png
1856 * docs/html/ext/pb_ds/counter_lu_policy.html: Same.
1857 * docs/html/ext/pb_ds/different_underlying_dss.png
1858 * docs/html/ext/pb_ds/restoring_node_invariants.png
1859 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large.html: Same.
1860 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_local.png
1861 * docs/html/ext/pb_ds/sample_update_policy.html: Same.
1862 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_gcc.png
1863 * docs/html/ext/pb_ds/tree_order_statistics_timing_test_local.png
1864 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_msvc.png
1865 * docs/html/ext/pb_ds/simple_list.png
1866 * docs/html/ext/pb_ds/text_find_timing_test_hash_msvc.png
1867 * docs/html/ext/pb_ds/assoc_examples.html: Same.
1868 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_local.png
1869 * docs/html/ext/pb_ds/hash_based_containers.html: Same.
1870 * docs/html/ext/pb_ds/text_find_timing_test_tree_like_local.png
1871 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_local.png
1872 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_gcc.png
1873 * docs/html/ext/pb_ds/tree_node_iterator.html: Same.
1874 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_msvc.png
1875 * docs/html/ext/pb_ds/trie_node_iterator.html: Same.
1876 * docs/html/ext/pb_ds/tree_based_containers.html: Same.
1877 * docs/html/ext/pb_ds/hash_random_int_subscript_insert_timing_test.html: Same.
1878 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_msvc.png
1879 * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_msvc.png
1880 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_msvc.png
1881 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_gcc.png
1882 * docs/html/ext/pb_ds/rationale_null_node_updator.png
1883 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_local.png
1884 * docs/html/ext/pb_ds/lu.png
1885 * docs/html/ext/pb_ds/assoc_container_traits.html: Same.
1886 * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_msvc.png
1887 * docs/html/ext/pb_ds/assoc_design.html: Same.
1888 * docs/html/ext/pb_ds/splay_tree_tag.html: Same.
1889 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_gcc.png
1890 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test.html: Same.
1891 * docs/html/ext/pb_ds/assoc_container_tag_cd.svg
1892 * docs/html/ext/pb_ds/resize_error.html: Same.
1893 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_msvc.png
1894 * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_gcc.png
1895 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test.html: Same.
1896 * docs/html/ext/pb_ds/basic_tree_assoc_container_const_node_iterator.html: Same.
1897 * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_gcc.png
1898 * docs/html/ext/pb_ds/trie_const_node_iterator.html: Same.
1899 * docs/html/ext/pb_ds/hash_zlob_random_int_find_find_timing_test.html: Same.
1900 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_gcc.png
1901 * docs/html/ext/pb_ds/sample_size_policy.html: Same.
1902 * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_gcc.png
1903 * docs/html/ext/pb_ds/cc_hash_table.html: Same.
1904 * docs/html/ext/pb_ds/node_invariants.png
1905 * docs/html/ext/pb_ds/tree_split_join_timing_test_msvc.png
1906 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test.html: Same.
1907 * docs/html/ext/pb_ds/tree_order_statistics_node_update.html: Same.
1908 * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_msvc.png
1909 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_local.png
1910 * docs/html/ext/pb_ds/priority_queue.html: Same.
1911 * docs/html/ext/pb_ds/assoc_tests.html: Same.
1912 * docs/html/ext/pb_ds/assoc_container_tag_cd.png
1913 * docs/html/ext/pb_ds/basic_hash_table.html: Same.
1914 * docs/html/ext/pb_ds/basic_tree_tag.html: Same.
1915 * docs/html/ext/pb_ds/tree_split_join_timing_test.html: Same.
1916 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_local.png
1917 * docs/html/ext/pb_ds/insert_resize_sequence_diagram3.png
1918 * docs/html/ext/pb_ds/embedded_lists_2.png
1919 * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_local.png
1920 * docs/html/ext/pb_ds/sample_ranged_probe_fn.html: Same.
1921 * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_gcc.png
1922 * docs/html/ext/pb_ds/sample_trie_node_update.html: Same.
1923 * docs/html/ext/pb_ds/introduction.html: Same.
1924 * docs/html/ext/pb_ds/pq_performance_tests.html: Same.
1925 * docs/html/ext/pb_ds/pat_trie.png
1926 * docs/html/ext/pb_ds/range_invalidation_guarantee.html: Same.
1927 * docs/html/ext/pb_ds/contact.html: Same.
1928 * docs/html/ext/pb_ds/sample_range_hashing.html: Same.
1929 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_local.png
1930 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_gcc.png
1931 * docs/html/ext/pb_ds/update_seq_diagram.png
1932 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_gcc.png
1933 * docs/html/ext/pb_ds/direct_mask_range_hashing.html: Same.
1934 * docs/html/ext/pb_ds/tests.html: Same.
1935 * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_gcc.png
1936 * docs/html/ext/pb_ds/tree_node_updator_policy_cd.png
1937 * docs/html/ext/pb_ds/text_find_timing_test_tree_like_gcc.png
1938 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large.html: Same.
1939 * docs/html/ext/pb_ds/trie_node_updator_policy_cd.png
1940 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_msvc.png
1941 * docs/html/ext/pb_ds/concepts.html: Same.
1942 * docs/html/ext/pb_ds/pq_examples.html: Same.
1943 * docs/html/ext/pb_ds/priority_queue_tag.html: Same.
1944 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test.html: Same.
1945 * docs/html/ext/pb_ds/update_policy_cd.png
1946 * docs/html/ext/pb_ds/thin_heap_tag.html: Same.
1947 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_msvc.png
1948 * docs/html/ext/pb_ds/basic_tree.html: Same.
1949 * docs/html/ext/pb_ds/null_hash_fn.html: Same.
1950 * docs/html/ext/pb_ds/null_tree_node_update.html: Same.
1951 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_gcc.png
1952 * docs/html/ext/pb_ds/trie.html: Same.
1953 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_msvc.png
1954 * docs/html/ext/pb_ds/rc_binomial_heap_tag.html: Same.
1955 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_msvc.png
1956 * docs/html/ext/pb_ds/pq_container_traits.html: Same.
1957 * docs/html/ext/pb_ds/pq_design.html: Same.
1958 * docs/html/ext/pb_ds/checked_by_tidy.gif
1959 * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_local.png
1960 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_gcc.png
1961 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test.html: Same.
1962 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_gcc.png
1963 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_local.png
1964 * docs/html/ext/pb_ds/acks.html: Same.
1965 * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_local.png
1966 * docs/html/ext/pb_ds/cc_hash_tag.html: Same.
1967 * docs/html/ext/pb_ds/sample_ranged_hash_fn.html: Same.
1968 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_msvc.png
1969 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test.html: Same.
1970 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small.html: Same.
1971 * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_msvc.png
1972 * docs/html/ext/pb_ds/hash_range_hashing_seq_diagram2.png
1973 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_msvc.png
1974 * docs/html/ext/pb_ds/PythonPoweredSmall.gif
1975 * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_local.png
1976 * docs/html/ext/pb_ds/pat_trie_tag.html: Same.
1977 * docs/html/ext/pb_ds/hash_standard_resize_policy.html: Same.
1978 * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_msvc.png
1979 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_gcc.png
1980 * docs/html/ext/pb_ds/join_error.html: Same.
1981 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_gcc.png
1982 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_local.png
1983
1984 * testsuite/ext/pb_ds: New.
1985 * testsuite/ext/pb_ds/regression: New.
1986 * testsuite/ext/pb_ds/regression/trie_data_map_rand.cc: Same.
1987 * testsuite/ext/pb_ds/regression/hash_data_map_rand.cc: Same.
1988 * testsuite/ext/pb_ds/regression/associative_containers.cc: Same.
1989 * testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc: Same.
1990 * testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc: Same.
1991 * testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc: Same.
1992 * testsuite/ext/pb_ds/regression/priority_queues.cc: Same.
1993 * testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc: Same.
1994 * testsuite/ext/pb_ds/regression/priority_queue_rand.cc: Same.
1995 * testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc: Same.
1996 * testsuite/ext/pb_ds/regression/tree_data_map_rand.cc: Same.
1997 * testsuite/ext/pb_ds/example: New.
1998 * testsuite/ext/pb_ds/example/hash_shift_mask.cc: Same.
1999 * testsuite/ext/pb_ds/example/basic_set.cc: Same.
2000 * testsuite/ext/pb_ds/example/hash_illegal_resize.cc: Same.
2001 * testsuite/ext/pb_ds/example/hash_resize_neg.cc: Same.
2002 * testsuite/ext/pb_ds/example/store_hash.cc: Same.
2003 * testsuite/ext/pb_ds/example/assoc_container_traits.cc: Same.
2004 * testsuite/ext/pb_ds/example/hash_load_set_change.cc: Same.
2005 * testsuite/ext/pb_ds/example/ranged_hash.cc: Same.
2006 * testsuite/ext/pb_ds/example/hash_resize.cc: Same.
2007 * testsuite/ext/pb_ds/example/tree_order_statistics.cc: Same.
2008 * testsuite/ext/pb_ds/example/trie_prefix_search.cc: Same.
2009 * testsuite/ext/pb_ds/example/basic_multiset.cc: Same.
2010 * testsuite/ext/pb_ds/example/priority_queue_xref.cc: Same.
2011 * testsuite/ext/pb_ds/example/hash_find_neg.cc: Same.
2012 * testsuite/ext/pb_ds/example/erase_if.cc: Same.
2013 * testsuite/ext/pb_ds/example/priority_queue_container_traits.cc: Same.
2014 * testsuite/ext/pb_ds/example/tree_join.cc: Same.
2015 * testsuite/ext/pb_ds/example/basic_map.cc: Same.
2016 * testsuite/ext/pb_ds/example/trie_split.cc: Same.
2017 * testsuite/ext/pb_ds/example/priority_queue_split_join.cc: Same.
2018 * testsuite/ext/pb_ds/example/priority_queue_dijkstra.cc: Same.
2019 * testsuite/ext/pb_ds/example/priority_queue_erase_if.cc: Same.
2020 * testsuite/ext/pb_ds/example/hash_mod.cc: Same.
2021 * testsuite/ext/pb_ds/example/tree_order_statistics_join.cc: Same.
2022 * testsuite/ext/pb_ds/example/trie_dna.cc: Same.
2023 * testsuite/ext/pb_ds/example/hash_initial_size.cc: Same.
2024 * testsuite/ext/pb_ds/example/basic_priority_queue.cc: Same.
2025 * testsuite/ext/pb_ds/example/tree_intervals.cc: Same.
2026 * testsuite/ext/pb_ds/example/basic_multimap.cc: Same.
2027 * testsuite/performance/ext: New.
2028 * testsuite/performance/ext/pb_ds: New.
2029 * testsuite/performance/ext/pb_ds/multimap_text_find_timing_small.cc: Same.
2030 * testsuite/performance/ext/pb_ds/text_find_timing.cc: Same.
2031 * testsuite/performance/ext/pb_ds/hash_random_int_erase_mem_usage.cc: Same.
2032 * testsuite/performance/ext/pb_ds/tree_text_insert_timing.cc: Same.
2033 * testsuite/performance/ext/pb_ds/priority_queue_text_modify_down_timing.cc: Same.
2034 * testsuite/performance/ext/pb_ds/random_int_subscript_find_timing.cc: Same.
2035 * testsuite/performance/ext/pb_ds/priority_queue_text_push_timing.cc: Same.
2036 * testsuite/performance/ext/pb_ds/tree_split_join_timing.cc: Same.
2037 * testsuite/performance/ext/pb_ds/random_int_find_timing.cc: Same.
2038 * testsuite/performance/ext/pb_ds/multimap_text_insert_timing_large.cc: Same.
2039 * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage.hpp: Same.
2040 * testsuite/performance/ext/pb_ds/priority_queue_random_int_push_timing.cc: Same.
2041 * testsuite/performance/ext/pb_ds/multimap_text_find_timing.hpp: Same.
2042 * testsuite/performance/ext/pb_ds/priority_queue_text_modify_timing.hpp: Same.
2043 * testsuite/performance/ext/pb_ds/tree_order_statistics_timing.cc: Same.
2044 * testsuite/performance/ext/pb_ds/priority_queue_text_modify_up_timing.cc: Same.
2045 * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage_large.cc: Same.
2046 * testsuite/performance/ext/pb_ds/priority_queue_text_push_pop_timing.cc: Same.
2047 * testsuite/performance/ext/pb_ds/multimap_text_find_timing_large.cc: Same.
2048 * testsuite/performance/ext/pb_ds/priority_queue_text_join_timing.cc: Same.
2049 * testsuite/performance/ext/pb_ds/multimap_text_insert_timing_small.cc: Same.
2050 * testsuite/performance/ext/pb_ds/priority_queue_random_int_push_pop_timing.cc: Same.
2051 * testsuite/performance/ext/pb_ds/random_int_subscript_insert_timing.cc: Same.
2052 * testsuite/performance/ext/pb_ds/tree_text_lor_find_timing.cc: Same.
2053 * testsuite/performance/ext/pb_ds/priority_queue_text_pop_mem_usage.cc: Same.
2054 * testsuite/performance/ext/pb_ds/multimap_text_insert_timing.hpp: Same.
2055 * testsuite/performance/ext/pb_ds/hash_zlob_random_int_find_timing.cc: Same.
2056 * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage_small.cc: Same.
2057 * testsuite/data/make_graph_test_infos.xml: Same.
2058 * testsuite/data/thirty_years_among_the_dead_preproc.txt: New.
2059 * testsuite/data/make_graph_htmls.xml: Same.
2060 * testsuite/util/regression: New.
2061 * testsuite/util/regression/trait: New.
2062 * testsuite/util/regression/trait/priority_queue: New.
2063 * testsuite/util/regression/trait/priority_queue/trait.hpp: Same.
2064 * testsuite/util/regression/trait/erase_if_fn.hpp: Same.
2065 * testsuite/util/regression/trait/assoc: New.
2066 * testsuite/util/regression/trait/assoc/native_type_trait.hpp: Same.
2067 * testsuite/util/regression/trait/assoc/node_update_trait.hpp: Same.
2068 * testsuite/util/regression/trait/assoc/get_set_load_trait.hpp: Same.
2069 * testsuite/util/regression/trait/assoc/get_set_loads_trait.hpp: Same.
2070 * testsuite/util/regression/trait/assoc/trait.hpp: Same.
2071 * testsuite/util/regression/trait/assoc/type_trait.hpp: Same.
2072 * testsuite/util/regression/trait/assoc/resize_trait.hpp: Same.
2073 * testsuite/util/regression/trait/assoc/to_string.hpp: Same.
2074 * testsuite/util/regression/rand: New.
2075 * testsuite/util/regression/rand/priority_queue: New.
2076 * testsuite/util/regression/rand/priority_queue/detail: New.
2077 * testsuite/util/regression/rand/priority_queue/detail/erase_fn_imps.hpp: Same.
2078 * testsuite/util/regression/rand/priority_queue/detail/cmp_fn_imps.hpp: Same.
2079 * testsuite/util/regression/rand/priority_queue/detail/policy_access_fn_imps.hpp: Same.
2080 * testsuite/util/regression/rand/priority_queue/detail/defs_fn_imps.hpp: Same.
2081 * testsuite/util/regression/rand/priority_queue/detail/it_conversion_fn_imps.hpp: Same.
2082 * testsuite/util/regression/rand/priority_queue/detail/constructor_destructor_fn_imps.hpp: Same.
2083 * testsuite/util/regression/rand/priority_queue/detail/diagnostic_fn_imps.hpp: Same.
2084 * testsuite/util/regression/rand/priority_queue/detail/insert_fn_imps.hpp: Same.
2085 * testsuite/util/regression/rand/priority_queue/detail/clear_fn_imps.hpp: Same.
2086 * testsuite/util/regression/rand/priority_queue/detail/modify_fn_imps.hpp: Same.
2087 * testsuite/util/regression/rand/priority_queue/detail/split_join_fn_imps.hpp: Same.
2088 * testsuite/util/regression/rand/priority_queue/detail/operator_fn_imps.hpp: Same.
2089 * testsuite/util/regression/rand/priority_queue/rand_regression_test.hpp: Same.
2090 * testsuite/util/regression/rand/priority_queue/container_rand_regression_test.hpp: Same.
2091 * testsuite/util/regression/rand/io: New.
2092 * testsuite/util/regression/rand/io/priority_queue: New.
2093 * testsuite/util/regression/rand/io/priority_queue/xml_formatter.hpp: Same.
2094 * testsuite/util/regression/rand/io/assoc: New.
2095 * testsuite/util/regression/rand/io/assoc/xml_formatter.hpp: Same.
2096 * testsuite/util/regression/rand/io/xml_formatter.hpp: Same.
2097 * testsuite/util/regression/rand/assoc: New.
2098 * testsuite/util/regression/rand/assoc/detail: New.
2099 * testsuite/util/regression/rand/assoc/detail/subscript_fn_imps.hpp: Same.
2100 * testsuite/util/regression/rand/assoc/detail/cmp_fn_imps.hpp: Same.
2101 * testsuite/util/regression/rand/assoc/detail/policy_access_fn_imps.hpp: Same.
2102 * testsuite/util/regression/rand/assoc/detail/defs_fn_imps.hpp: Same.
2103 * testsuite/util/regression/rand/assoc/detail/it_conversion_fn_imps.hpp: Same.
2104 * testsuite/util/regression/rand/assoc/detail/diagnostic_fn_imps.hpp: Same.
2105 * testsuite/util/regression/rand/assoc/detail/clear_fn_imps.hpp: Same.
2106 * testsuite/util/regression/rand/assoc/detail/get_set_load_fn_imps.hpp: Same.
2107 * testsuite/util/regression/rand/assoc/detail/operator_fn_imps.hpp: Same.
2108 * testsuite/util/regression/rand/assoc/detail/erase_fn_imps.hpp: Same.
2109 * testsuite/util/regression/rand/assoc/detail/resize_fn_imps.hpp: Same.
2110 * testsuite/util/regression/rand/assoc/detail/constructor_destructor_fn_imps.hpp: Same.
2111 * testsuite/util/regression/rand/assoc/detail/insert_fn_imps.hpp: Same.
2112 * testsuite/util/regression/rand/assoc/detail/split_join_fn_imps.hpp: Same.
2113 * testsuite/util/regression/rand/assoc/detail/get_set_loads_fn_imps.hpp: Same.
2114 * testsuite/util/regression/rand/assoc/rand_regression_test.hpp: Same.
2115 * testsuite/util/regression/rand/assoc/container_rand_regression_test.hpp: Same.
2116 * testsuite/util/regression/priority_queue: New.
2117 * testsuite/util/regression/priority_queue/common_type.hpp: Same.
2118 * testsuite/util/regression/basic_type.hpp: Same.
2119 * testsuite/util/regression/assoc: New.
2120 * testsuite/util/regression/assoc/common_type.hpp: Same.
2121 * testsuite/util/regression/res_mng: New.
2122 * testsuite/util/regression/res_mng/forced_exception.hpp: Same.
2123 * testsuite/util/regression/res_mng/dbg_ex_allocator_base.cc: Same.
2124 * testsuite/util/regression/res_mng/dbg_ex_allocator_base.hpp: Same.
2125 * testsuite/util/regression/res_mng/dbg_ex_allocator.hpp: Same.
2126 * testsuite/util/rng: New.
2127 * testsuite/util/rng/twister_rand_gen.cc: Same.
2128 * testsuite/util/rng/twister_rand_gen.hpp: Same.
2129 * testsuite/util/native_type: New.
2130 * testsuite/util/native_type/priority_queue: New.
2131 * testsuite/util/native_type/priority_queue/native_priority_queue.hpp: Same.
2132 * testsuite/util/native_type/priority_queue/native_pq_tag.hpp: Same.
2133 * testsuite/util/native_type/assoc: New.
2134 * testsuite/util/native_type/assoc/native_multimap.hpp: Same.
2135 * testsuite/util/native_type/assoc/native_tree_tag.hpp: Same.
2136 * testsuite/util/native_type/assoc/native_set.hpp: Same.
2137 * testsuite/util/native_type/assoc/native_hash_multimap.hpp: Same.
2138 * testsuite/util/native_type/assoc/native_map.hpp: Same.
2139 * testsuite/util/native_type/assoc/native_hash_tag.hpp: Same.
2140 * testsuite/util/native_type/assoc/native_hash_set.hpp: Same.
2141 * testsuite/util/native_type/assoc/native_hash_map.hpp: Same.
2142 * testsuite/util/common_type: New.
2143 * testsuite/util/common_type/priority_queue
2144 * testsuite/util/common_type/priority_queue/common_type.hpp: Same.
2145 * testsuite/util/common_type/priority_queue/string_form.hpp: Same.
2146 * testsuite/util/common_type/priority_queue/detail
2147 * testsuite/util/common_type/priority_queue/detail/ds_string_form.hpp: Same.
2148 * testsuite/util/common_type/assoc: New.
2149 * testsuite/util/common_type/assoc/common_type.hpp: Same.
2150 * testsuite/util/common_type/assoc/string_form.hpp: Same.
2151 * testsuite/util/common_type/assoc/template_policy.hpp: Same.
2152 * testsuite/util/common_type/assoc/detail: New.
2153 * testsuite/util/common_type/assoc/detail/resize_policy_string_form.hpp: Same.
2154 * testsuite/util/common_type/assoc/detail/trigger_policy_string_form.hpp: Same.
2155 * testsuite/util/common_type/assoc/detail/ds_string_form.hpp: Same.
2156 * testsuite/util/common_type/assoc/detail/comb_hash_fn_string_form.hpp: Same.
2157 * testsuite/util/common_type/assoc/detail/size_policy_string_form.hpp: Same.
2158 * testsuite/util/common_type/assoc/detail/probe_fn_string_form.hpp: Same.
2159 * testsuite/util/common_type/assoc/detail/tree_supports_order_statistics.hpp: Same.
2160 * testsuite/util/common_type/assoc/detail/trie_supports_prefix_search.hpp: Same.
2161 * testsuite/util/common_type/assoc/detail/list_update_policy_string_form.hpp: Same.
2162 * testsuite/util/common_type/assoc/detail/trie_supports_order_statistics.hpp: Same.
2163 * testsuite/util/common_type/assoc/detail/store_hash_string_form.hpp: Same.
2164 * testsuite/util/common_type/assoc/native_set.hpp: Same.
2165 * testsuite/util/performance: New.
2166 * testsuite/util/performance/priority_queue: New.
2167 * testsuite/util/performance/priority_queue/mem_usage: New.
2168 * testsuite/util/performance/priority_queue/mem_usage/pop_test.hpp: Same.
2169 * testsuite/util/performance/priority_queue/timing: New.
2170 * testsuite/util/performance/priority_queue/timing/push_pop_test.hpp: Same.
2171 * testsuite/util/performance/priority_queue/timing/push_test.hpp: Same.
2172 * testsuite/util/performance/priority_queue/timing/join_test.hpp: Same.
2173 * testsuite/util/performance/priority_queue/timing/modify_test.hpp: Same.
2174 * testsuite/util/performance/io: New.
2175 * testsuite/util/performance/io/xml_formatter.hpp: Same.
2176 * testsuite/util/performance/assoc: New.
2177 * testsuite/util/performance/assoc/mem_usage: New.
2178 * testsuite/util/performance/assoc/mem_usage/multimap_insert_test.hpp: Same.
2179 * testsuite/util/performance/assoc/mem_usage/erase_test.hpp: Same.
2180 * testsuite/util/performance/assoc/multimap_common_type.hpp: Same.
2181 * testsuite/util/performance/assoc/timing: New.
2182 * testsuite/util/performance/assoc/timing/common_type.hpp: Same.
2183 * testsuite/util/performance/assoc/timing/multimap_insert_test.hpp: Same.
2184 * testsuite/util/performance/assoc/timing/subscript_find_test.hpp: Same.
2185 * testsuite/util/performance/assoc/timing/find_test.hpp: Same.
2186 * testsuite/util/performance/assoc/timing/subscript_insert_test.hpp: Same.
2187 * testsuite/util/performance/assoc/timing/insert_test.hpp: Same.
2188 * testsuite/util/performance/assoc/timing/tree_order_statistics_test.hpp: Same.
2189 * testsuite/util/performance/assoc/timing/multimap_find_test.hpp: Same.
2190 * testsuite/util/performance/assoc/timing/tree_split_join_test.hpp: Same.
2191 * testsuite/util/performance/time: New.
2192 * testsuite/util/performance/time/elapsed_timer.cc: Same.
2193 * testsuite/util/performance/time/elapsed_timer.hpp: Same.
2194 * testsuite/util/performance/time/timing_test_base.hpp: Same.
2195 * testsuite/util/performance/mem: New.
2196 * testsuite/util/performance/mem/mem_track_allocator_base.hpp: Same.
2197 * testsuite/util/performance/mem/mem_track_allocator.hpp: Same.
2198 * testsuite/util/hash_fn: New.
2199 * testsuite/util/hash_fn/limit_string_hash_fn.hpp: Same.
2200 * testsuite/util/hash_fn/string_ranged_hash_fn.hpp: Same.
2201 * testsuite/util/hash_fn/string_hash_fn.hpp: Same.
2202 * testsuite/util/hash_fn/string_ranged_probe_fn.hpp: Same.
2203 * testsuite/util/hash_fn/dna_str_limit.hpp: Same.
2204 * testsuite/util/io: New.
2205 * testsuite/util/io/prog_bar.cc: Same.
2206 * testsuite/util/io/prog_bar.hpp: Same.
2207 * testsuite/util/io/text_populate.hpp: Same.
2208 * testsuite/util/io/xml.hpp: Same.
2209 * testsuite/util/io/illegal_input_error.hpp: Same.
2210 * testsuite/util/io/xml_test_formatter.hpp: Same.
2211 * testsuite/util/io/verified_cmd_line_input.cc: Same.
2212 * testsuite/util/io/verified_cmd_line_input.hpp: Same.
2213 * testsuite/util/statistic: New.
2214 * testsuite/util/statistic/sample_var.hpp: Same.
2215 * testsuite/util/statistic/res_recorder.hpp: Same.
2216 * testsuite/util/statistic/sample_mean.hpp: Same.
2217 * testsuite/util/statistic/sample_mean_confidence_checker.hpp: Same.
2218
2219 2006-06-12 Paolo Carlini <pcarlini@suse.de>
2220
2221 PR libstdc++/26970
2222 * config/locale/gnu/c_locale.h (__convert_from_v<>): Change to
2223 variadic function, instead of template function.
2224 * config/locale/generic/c_locale.h (__convert_from_v<>): Likewise.
2225 * include/bits/locale_facets.tcc (num_put<>::_M_insert_float):
2226 Adjust.
2227 (money_put<>::do_put(long double)): Likewise.
2228 * src/locale-misc-inst.cc: Remove.
2229 * src/Makefile.am: Adjust.
2230 * src/Makefile.in: Regenerate.
2231
2232 2006-06-09 Paolo Carlini <pcarlini@suse.de>
2233
2234 * include/tr1/random (random_device::random_device(const
2235 std::string& = "/dev/urandom")): Open in binary mode.
2236
2237 * include/tr1/random (random_device::random_device(const
2238 std::string& = "rand")): Use mersenne_twister.
2239 (random_device::_M_strtoul): New.
2240 (random_device::operator()()): Update.
2241
2242 * include/tr1/random: Minor stylistic changes, consistently
2243 qualify with std::.
2244
2245 2006-06-09 Paolo Carlini <pcarlini@suse.de>
2246
2247 * acinclude.m4 ([GLIBCXX_CHECK_RANDOM_TR1]): New, check for
2248 the availability of "/dev/random" and "/dev/urandom".
2249 * configure.ac: Use it.
2250 * include/tr1/random (random_device): Implement, a fall-back for
2251 systems not providing "/dev/random" and "/dev/urandom" included.
2252 * testsuite/tr1/5_numerical_facilities/random/random_device/
2253 cons/default.cc: New.
2254 * testsuite/tr1/5_numerical_facilities/random/random_device/
2255 cons/token.cc: Likewise.
2256 * testsuite/tr1/5_numerical_facilities/random/random_device/
2257 requirements/typedefs.cc: Likewise.
2258 * config.h.in: Regenerate.
2259 * configure: Likewise.
2260
2261 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
2262 cons/gen1.cc: Minor tweak, add bool test.
2263
2264 2006-06-06 Benjamin Kosnik <bkoz@redhat.com>
2265
2266 * testsuite/util: New directory.
2267 * testsuite/testsuite_hooks.cc: Move to util sub-directory.
2268 * testsuite/testsuite_abi_check.cc: Same.
2269 * testsuite/testsuite_abi.cc: Same.
2270 * testsuite/testsuite_tr1.h: Same.
2271 * testsuite/testsuite_io.h: Same.
2272 * testsuite/testsuite_iterators.h: Same.
2273 * testsuite/testsuite_allocator.cc: Same.
2274 * testsuite/testsuite_allocator.h: Same.
2275 * testsuite/testsuite_hooks.h: Same.
2276 * testsuite/testsuite_character.cc: Same.
2277 * testsuite/testsuite_abi.h: Same.
2278 * testsuite/testsuite_character.h: Same.
2279 * testsuite/testsuite_visualization.h: Same.
2280 * testsuite/testsuite_performance.h: Same.
2281 * testsuite/testsuite_shared.cc: Same.
2282 * testsuite/testsuite_common_types.h: Same.
2283
2284 * testsuite/lib/libstdc++.exp (v3-build_support): Adjust paths.
2285 * testsuite/libstdc++-abi/abi.exp: Same.
2286 * testsuite/libstdc++-dg/conformance.exp: Remove any files in the
2287 utilities subdirectory from the list of test cases.
2288
2289 * scripts/testsuite_flags.in (build-includes): Adjust path for
2290 testsuite includes.
2291 * scripts/create_testsuite_files (dlist): Don't let utility files
2292 creep into the testsuite_files list.
2293
2294 2006-06-06 Paolo Carlini <pcarlini@suse.de>
2295
2296 * include/tr1/random (mersenne_twister<>::operator==,
2297 operator!=, operator<<, operator>>): Implement.
2298 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
2299 operators/equal.cc: New.
2300 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
2301 operators/not_equal.cc: Likewise.
2302 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
2303 operators/serialize.cc: Likewise.
2304
2305 * include/tr1/random (subtract_with_carry<>::operator==): Fix,
2306 compare the whole state; use std::equal.
2307
2308 * include/tr1/random: Minor formatting and style changes.
2309
2310 2006-06-06 Benjamin Kosnik <bkoz@redhat.com>
2311
2312 * testsuite/tr1/5_numerical_facilies: Move to...
2313 * testsuite/tr1/5_numerical_facilities: ...this.
2314
2315 2006-06-06 Paolo Carlini <pcarlini@suse.de>
2316
2317 * include/tr1/random: Trivial uglification fixes.
2318 * include/tr1/random.tcc: Likewise.
2319
2320 * include/tr1/random (subtract_with_carry<>::
2321 subtract_with_carry(_IntType)): Fix parameter type to unsigned long.
2322 (subtract_with_carry<>::seed(_IntType)): Likewise.
2323 * include/tr1/random.tcc (subtract_with_carry<>::seed(_IntType)):
2324 Adjust.
2325
2326 2006-06-05 Paolo Carlini <pcarlini@suse.de>
2327
2328 * include/tr1/random (mersenne_twister<>::seed()): Fix per
2329 tr1/5.1.4.2, p8.
2330 * include/tr1/random.tcc (mod_w): Add.
2331 (mersenne_twister<>::seed(unsigned long)): Fix per tr1/5.1.4.2, p9.
2332 (mersenne_twister<>::seed(Gen&, false_type)): Adjust to use mod_w.
2333 * testsuite/tr1/5_numerical_facilies/random/mt19937.cc: Fix
2334 expected result per tr1/5.1.5, p2.
2335 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2336 cons/default.cc: Adjust.
2337
2338 * include/tr1/random (exponential_distribution<>::operator()()): Fix.
2339
2340 2006-06-05 Paolo Carlini <pcarlini@suse.de>
2341
2342 * include/tr1/random.tcc (Max::value()): Cast 1 to Tp(1) and
2343 adjust shift count to w; rename as Max_w.
2344 (struct Mod_w): New.
2345 (mersenne_twister<>::seed(Gen&, false_type): Use the latter.
2346 (mersenne_twister<>::operator()()): Fix ~0ul to ~_UInt().
2347 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2348 cons/default.cc: Fix ~0ul to 2^32-1.
2349 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2350 cons/gen1.cc: Likewise.
2351
2352 2006-06-05 Stephen M. Webb <stephen.webb@bregmasoft.com>
2353
2354 * include/tr1/random: New.
2355 * include/tr1/random.tcc: Likewise.
2356 * include/Makefile.am: Add.
2357 * testsuite/tr1/5_numerical_facilies/random/ranlux3.cc: New.
2358 * testsuite/tr1/5_numerical_facilies/random/ranlux4.cc: Likewise.
2359 * testsuite/tr1/5_numerical_facilies/random/mt19937.cc: Likewise.
2360 * testsuite/tr1/5_numerical_facilies/random/variate_generator/
2361 requirements/typedefs.cc: Likewise.
2362 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2363 cons/seed1.cc: Likewise.
2364 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2365 cons/seed2.cc: Likewise.
2366 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2367 cons/default.cc: Likewise.
2368 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2369 cons/gen1.cc: Likewise.
2370 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2371 requirements/typedefs.cc: Likewise.
2372 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2373 operators/equal.cc: Likewise.
2374 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2375 operators/not_equal.cc: Likewise.
2376 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
2377 operators/serialize.cc: Likewise.
2378 * testsuite/tr1/5_numerical_facilies/random/uniform_real/
2379 requirements/typedefs.cc: Likewise.
2380 * testsuite/tr1/5_numerical_facilies/random/discard_block/
2381 requirements/requirements.cc: Likewise.
2382 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2383 cons/seed1.cc: Likewise.
2384 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2385 cons/seed2.cc: Likewise.
2386 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2387 cons/default.cc: Likewise.
2388 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2389 cons/gen1.cc: Likewise.
2390 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2391 requirements/non_uint_neg.cc: Likewise.
2392 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2393 requirements/typedefs.cc: Likewise.
2394 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2395 operators/equal.cc: Likewise.
2396 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2397 operators/not_equal.cc: Likewise.
2398 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
2399 operators/serialize.cc: Likewise.
2400 * testsuite/tr1/5_numerical_facilies/random/xor_combine/
2401 requirements/typedefs.cc: Likewise.
2402 * testsuite/tr1/5_numerical_facilies/random/minstd_rand.cc: Likewise.
2403 * testsuite/tr1/5_numerical_facilies/random/minstd_rand0.cc: Likewise.
2404 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
2405 cons/range.cc: Likewise.
2406 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
2407 cons/default.cc: Likewise.
2408 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
2409 cons/range_neg.cc: Likewise.
2410 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
2411 requirements/typedefs.cc: Likewise.
2412 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2413 cons/seed1.cc: Likewise.
2414 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2415 cons/seed2.cc: Likewise.
2416 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2417 cons/default.cc: Likewise.
2418 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2419 cons/gen1.cc: Likewise.
2420 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
2421 requirements/typedefs.cc: Likewise.
2422 * include/Makefile.in: Regenerate.
2423 * testsuite/tr1/headers.cc: Update.
2424
2425 2006-06-04 Paolo Carlini <pcarlini@suse.de>
2426
2427 PR libstdc++/27867
2428 * include/bits/valarray_before.h (struct _BinClos<_Oper, _ValArray,
2429 _ValArray, _Tp, _Tp>): Fix value_type typedef.
2430 * testsuite/26_numerics/valarray/27867.cc: New.
2431
2432 2006-05-29 Paolo Carlini <pcarlini@suse.de>
2433
2434 PR libstdc++/24692
2435 * include/bits/atomicity.h (__exchange_and_add_multi,
2436 __atomic_add_multi): New, depending on _GLIBCXX_ATOMIC_BUILTINS,
2437 inline the atomic builtins.
2438 (__exchange_and_add_dispatch, __atomic_add_dispatch): Adjust.
2439 * configure.ac: Define _GLIBCXX_ATOMIC_BUILTINS when the atomic
2440 builtins are available.
2441 * configure: Regenerate.
2442 * config.h.in: Likewise.
2443
2444 2006-05-27 Paolo Carlini <pcarlini@suse.de>
2445
2446 * configure.host: If the CPU provides atomic builtins select
2447 generic/atomic_builtins/atomicity.h.
2448 * config/cpu/generic/atomic_builtins/atomicity.h: Add.
2449 * config/cpu/powerpc/atomicity.h: Remove.
2450 * config/cpu/ia64/atomicity.h: Likewise.
2451 * config/cpu/alpha/atomicity.h: Likewise.
2452 * config/cpu/s390/atomicity.h: Likewise.
2453
2454 2006-05-26 Carlos O'Donell <carlos@codesourcery.com>
2455
2456 * Makefile.am: Add install-html target. Add install-html to .PHONY
2457 * Makefile.in: Regenerate.
2458
2459 2006-05-24 Paolo Carlini <pcarlini@suse.de>
2460
2461 PR libstdc++/24704
2462 * include/bits/atomicity.h (__exchange_and_add_single,
2463 __atomic_add_single): New, single thread versions of the atomic
2464 functions.
2465 (__exchange_and_add_dispatch, __atomic_add_dispatch): New,
2466 depending on __GTHREADS and __gthread_active_p() dispatch either
2467 to the above or to the existing atomic functions.
2468 * include/ext/pool_allocator.h: Update callers.
2469 * include/ext/rc_string_base.h: Likewise.
2470 * include/bits/locale_classes.h: Likewise.
2471 * include/bits/basic_string.h: Likewise.
2472 * include/bits/ios_base.h: Likewise.
2473 * include/tr1/boost_shared_ptr.h: Likewise.
2474 * src/ios.cc: Likewise.
2475 * src/locale.cc: Likewise.
2476 * src/ios_init.cc: Likewise.
2477
2478 2006-05-23 Paolo Carlini <pcarlini@suse.de>
2479
2480 * testsuite/testsuite_shared.cc: Fix --enable-threads=single build.
2481
2482 2006-05-19 Paolo Carlini <pcarlini@suse.de>
2483
2484 * testsuite/27_io/objects/wchar_t/9661-1.cc: Avoid leaking the
2485 semaphores if a VERIFY fails.
2486 * testsuite/27_io/objects/wchar_t/7.cc: Likewise.
2487 * testsuite/27_io/objects/char/9661-1.cc: Likewise.
2488 * testsuite/27_io/objects/char/7.cc: Likewise.
2489 * testsuite/27_io/basic_filebuf/seekoff/char/26777.cc: Likewise.
2490 * testsuite/27_io/basic_filebuf/imbue/wchar_t/14975-2.cc: Likewise.
2491 * testsuite/27_io/basic_filebuf/imbue/char/13171-2.cc: Likewise.
2492 * testsuite/27_io/basic_filebuf/close/char/4879.cc: Likewise.
2493 * testsuite/27_io/basic_filebuf/close/char/9964.cc: Likewise.
2494 * testsuite/27_io/basic_filebuf/underflow/char/10097.cc: Likewise.
2495
2496 2006-05-17 Paolo Carlini <pcarlini@suse.de>
2497
2498 * include/tr1/hashtable (hashtable<>::m_find): Remove; update callers.
2499
2500 * include/tr1/hashtable (map_base<>::operator[]): Move out of line.
2501
2502 * include/tr1/hashtable (hashtable<>::m_insert(const value_type&,
2503 std::tr1::false_type)): Avoid memory leak risk for new_node.
2504
2505 2006-05-15 Paolo Carlini <pcarlini@suse.de>
2506
2507 * include/tr1/hashtable (hashtable<>::m_find, m_insert_bucket): Add.
2508 (hashtable<>::find, m_insert(const value_type&, std::tr1::true_type),
2509 map_base<>::operator[]): Use the above.
2510 * testsuite/performance/23_containers/insert/unordered_map_array.cc:
2511 New.
2512
2513 * include/tr1/hashtable (hashtable<>::find_node,
2514 insert(const value_type&, ...), erase_node): Rename to m_*, adjust
2515 callers.
2516 * include/tr1/hashtable: Minor cosmetic changes.
2517
2518 2006-05-13 Peter Doerfler <gcc@pdoerfler.com>
2519
2520 * include/tr1/hashtable (identity<>::operator(),
2521 extract1st<>::operator()): Return by const ref.
2522
2523 2006-05-10 Steve Ellcey <sje@cup.hp.com>
2524
2525 * testsuite/lib/libstdc++.exp (check_v3_target_cxa_atexit):
2526 Move to gcc subdir.
2527 * testsuite/lib/dg-options.exp (dg-require-iconv): Remove.
2528 (dg-require-cxa-atexit): Move to gcc subdir.
2529
2530 2006-05-10 Paolo Carlini <pcarlini@suse.de>
2531 Peter Doerfler <gcc@pdoerfler.com>
2532
2533 * include/tr1/hashtable (hashtable_iterator<>::hashtable_iterator(),
2534 hashtable_const_iterator<>::hashtable_const_iterator(),
2535 node_iterator<>::node_iterator(),
2536 node_const_iterator<>::node_const_iterator()): Add.
2537 (node_iterator<>::node_iterator(hash_node<>*),
2538 node_const_iterator<>::node_const_iterator(hash_node<>*)): Tweak,
2539 remove default.
2540 * testsuite/tr1/6_containers/unordered/hashtable/
2541 iterators_default_constructor.c: New.
2542
2543 2006-05-10 Marc Glisse <marc.glisse@normalesup.org>
2544
2545 * include/ext/pool_allocator.h: Add missing std:: qualifications.
2546 * include/ext/mt_allocator.h: Likewise.
2547 * include/ext/pb_assoc/detail/resize_policy/
2548 hash_load_check_resize_trigger_imp.hpp: Likewise.
2549 * include/ext/pb_assoc/detail/resize_policy/
2550 hash_standard_resize_policy_imp.hpp: Likewise.
2551 * include/ext/pb_assoc/detail/lu_policy/
2552 counter_lu_metadata_imp.hpp: Likewise.
2553 * include/ext/pb_assoc/detail/map_debug_base.hpp: Likewise.
2554 * libsupc++/eh_alloc.cc: Typo: memcpy -> memset.
2555
2556 2006-05-07 Paolo Carlini <pcarlini@suse.de>
2557
2558 * include/tr1/type_traits (integral_constant<>::value): Define.
2559 * testsuite/tr1/4_metaprogramming/helper_classes/static_definition.cc:
2560 New.
2561
2562 2006-05-04 Douglas Gregor <dgregor@cs.indiana.edu>
2563
2564 PR libstdc++/27404
2565 * include/ext/rope (_Rope_const_iterator<>::operator*() const,
2566 _Rope_iterator<>::operator*() const): Add.
2567
2568 2006-05-01 Paolo Carlini <pcarlini@suse.de>
2569
2570 * acinclude.m4 (GLIBCXX_ENABLE_WCHAR_T): Always check the
2571 presence of wctype.h, for use in GLIBCXX_ENABLE_C99.
2572 * configure: Regenerate.
2573
2574 2006-04-29 Paolo Carlini <pcarlini@suse.de>
2575
2576 * include/bits/locale_facets.tcc (num_get<>::_M_extract_float):
2577 Special case main parsing loop for !_M_allocated (i.e., "C" locale).
2578 (num_get<>::_M_extract_int): Likewise.
2579 * include/bits/locale_facets.h (num_get<>::_M_find): New.
2580
2581 2006-04-27 Benjamin Kosnik <bkoz@redhat.com>
2582
2583 * docs/html/17_intro/TODO: Update.
2584
2585 2006-04-26 Benjamin Kosnik <bkoz@redhat.com>
2586
2587 PR libstdc++/26875
2588 * include/ext/array_allocator.h (array_allocator): _M_used, new
2589 data member.
2590 * testsuite/ext/array_allocator/26875.cc: New.
2591
2592 2006-04-26 Shantonu Sen <ssen@opendarwin.org>
2593
2594 PR libstdc++/26513
2595 * scripts/make_exports.pl: Use $ENV{NM_FOR_TARGET}, if present.
2596
2597 2006-04-23 Marc Glisse <marc.glisse@normalesup.org>
2598
2599 PR libstdc++/27199
2600 * ext/pool_allocator.h: Add using declarations for size_t, ptrdiff_t.
2601 * ext/bitmap_allocator.h: Likewise; qualify with std::.
2602 * ext/new_allocator.h: Likewise.
2603 * ext/malloc_allocator.h: Likewise.
2604 * ext/array_allocator.h: Likewise.
2605 * ext/mt_allocator.h: Likewise.
2606 * ext/functional: Likewise for size_t.
2607 * ext/debug_allocator.h: Likewise.
2608 * bits/char_traits.h: Qualify with std:: size_t.
2609 * debug/hash_multimap.h: Likewise.
2610
2611 2006-04-23 Paolo Carlini <pcarlini@suse.de>
2612
2613 * docs/html/ext/lwg-active.html, lwg-defects.html: Import Revision 42.
2614
2615 2006-04-19 Paolo Carlini <pcarlini@suse.de>
2616
2617 PR libstdc++/26424
2618 * include/tr1/hashtable (X<>::primes): Extend for 64-bit machines.
2619 (X<>::n_primes): Adjust.
2620 (prime_rehash_policy::next_bkt, bkt_for_elements, need_rehash): Adjust.
2621
2622 2006-04-18 Paolo Carlini <pcarlini@suse.de>
2623
2624 * docs/html/faq/index.html ([5.5]): Adjust to mention function
2625 objects and reference_wrapper; minor tweaks.
2626 * docs/html/faq/index.txt: Regenerate.
2627
2628 2006-04-16 Paolo Carlini <pcarlini@suse.de>
2629
2630 PR libstdc++/6702 (again)
2631 * acinclude.m4 (GLIBCXX_ENABLE_C99): Don't check non-C99
2632 wchar_t functions...
2633 (GLIBCXX_ENABLE_WCHAR_T): ... do that here.
2634 * configure.ac: Adjust order of checks.
2635 * configure: Regenerate.
2636
2637 2006-04-14 Douglas Gregor <dgregor@cs.indiana.edu>
2638
2639 PR libstdc++/27162
2640 * include/bits/stl_algo.h (__search_n(,,,, _BinaryPredicate,
2641 std::forward_iterator_tag)): Use __binary_pred, not ==.
2642
2643 2006-04-10 Matthias Klose <doko@debian.org>
2644
2645 * testsuite/lib/libstdc++.exp (libstdc++_init): Recognize multilib
2646 directory names containing underscores.
2647
2648 2006-04-10 Paolo Carlini <pcarlini@suse.de>
2649
2650 DR 538, [Ready]
2651 * include/bits/stl_algo.h (__unique_copy(,,, input_iterator_tag,
2652 output_iterator_tag), and predicated counterpart): Revert to the
2653 algorithm pre-DR 241, i.e., value_type of InputIterator is now
2654 required to be Assignable too.
2655 * testsuite/25_algorithms/unique_copy/3.cc: Remove.
2656 * docs/html/ext/howto.html: Add an entry for DR 538.
2657
2658 2006-03-29 Benjamin Kosnik <bkoz@redhat.com>
2659
2660 * testsuite/data/sgetn.txt: Correct copyright holder.
2661 * testsuite/data/wistream_extractor_other-1.tst: Same.
2662 * testsuite/data/wistream_extractor_other-2.tst: Same.
2663 * testsuite/data/istream_extractor_other-1.txt: Same.
2664 * testsuite/data/filebuf_virtuals-1.txt: Same.
2665 * testsuite/data/wostream_inserter_other-1.tst: Same.
2666 * testsuite/data/wostream_inserter_other-2.tst: Same.
2667 * testsuite/data/ostream_inserter_other-1.tst: Same.
2668 * testsuite/data/ostream_inserter_other-2.tst: Same.
2669 * testsuite/data/wistream_extractor_other-1.txt: Same.
2670 * testsuite/data/istream_extractor_other-1.tst: Same.
2671 * testsuite/data/istream_extractor_other-2.tst: Same.
2672 * testsuite/data/filebuf_virtuals-1.tst: Same.
2673 * testsuite/27_io/basic_filebuf/sgetn/char/1-in.cc: Adjust test
2674 conditions.
2675 * testsuite/27_io/basic_filebuf/sgetn/char/1-io.cc: Same.
2676 * testsuite/27_io/basic_filebuf/sgetn/char/2-in.cc: Same.
2677 * testsuite/27_io/basic_filebuf/sgetn/char/2-io.cc: Same.
2678
2679 2006-03-28 Paolo Carlini <pcarlini@suse.de>
2680
2681 * include/ext/vstring.h (operator[]): Allow s[s.size()] in
2682 debug mode, but not pedantic mode.
2683
2684 2006-03-24 Mark Mitchell <mark@codesourcery.com>
2685 Joseph S. Myers <joseph@codesourcery.com>
2686
2687 PR libstdc++/20448
2688 PR libstdc++/20451
2689 * scripts/testsuite_flags.in (--cxxflags): Don't define LOCALEDIR.
2690 * testsuite/lib/libstdc++.exp (libstdc++_init): Always define
2691 LOCALEDIR to ".".
2692 (v3-build_support): Build MO files.
2693
2694 2006-03-22 Paolo Carlini <pcarlini@suse.de>
2695
2696 PR libstdc++/26777
2697 * include/bits/fstream.tcc (basic_filebuf<>::_M_seek): Check
2698 the return value of _M_file.seekoff.
2699 * testsuite/27_io/basic_filebuf/seekoff/char/26777.cc: New.
2700
2701 2006-03-21 Paolo Carlini <pcarlini@suse.de>
2702
2703 PR libstdc++/25482
2704 * include/bits/stl_algobase.h (__copy_aux(_CharT*, _CharT*,
2705 ostreambuf_iterator<_CharT>), __copy_aux(const _CharT*, const _CharT*,
2706 ostreambuf_iterator<_CharT>), __copy_aux(istreambuf_iterator<_CharT>,
2707 istreambuf_iterator<_CharT>, _CharT*), copy(istreambuf_iterator<_CharT>,
2708 istreambuf_iterator<_CharT>, ostreambuf_iterator<_CharT>)): Declare.
2709 * include/bits/stl_algo.h (find(istreambuf_iterator<_CharT>,
2710 istreambuf_iterator<_CharT>, _CharT)): Likewise.
2711 * include/bits/streambuf_iterator.h (copy(istreambuf_iterator<_CharT>,
2712 istreambuf_iterator<_CharT>, ostreambuf_iterator<_CharT>),
2713 __copy_aux(_CharT*, _CharT*, ostreambuf_iterator<_CharT>),
2714 __copy_aux(const _CharT*, const _CharT*, ostreambuf_iterator<_CharT>),
2715 __copy_aux(istreambuf_iterator<_CharT>, istreambuf_iterator<_CharT>,
2716 _CharT*), find(istreambuf_iterator<_CharT>, istreambuf_iterator<_CharT>,
2717 _CharT)): Define.
2718 (class istreambuf_iterator<>, class ostreambuf_iterator<>): Declare
2719 friends.
2720 * include/std/std_streambuf.h (class basic_streambuf<>): Likewise.
2721 * include/bits/cpp_type_traits.h (struct __is_char<>): Add.
2722 * testsuite/25_algorithms/copy/streambuf_iterators/char/1.cc: New.
2723 * testsuite/25_algorithms/copy/streambuf_iterators/char/2.cc: New.
2724 * testsuite/25_algorithms/copy/streambuf_iterators/char/3.cc: New.
2725 * testsuite/25_algorithms/copy/streambuf_iterators/char/4.cc: New.
2726 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/1.cc: New.
2727 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/2.cc: New.
2728 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/3.cc: New.
2729 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/4.cc: New.
2730 * testsuite/25_algorithms/find/istreambuf_iterators/char/1.cc: New.
2731 * testsuite/25_algorithms/find/istreambuf_iterators/char/2.cc: New.
2732 * testsuite/25_algorithms/find/istreambuf_iterators/wchar_t/1.cc: New.
2733 * testsuite/25_algorithms/find/istreambuf_iterators/wchar_t/2.cc: New.
2734 * testsuite/performance/25_algorithms/copy_streambuf_iterators.cc: New.
2735 * testsuite/performance/25_algorithms/find_istreambuf_iterators.cc: New.
2736
2737 006-03-13 Paolo Carlini <pcarlini@suse.de>
2738
2739 * include/bits/postypes.h (fpos<>::operator==, operator!=): Remove,
2740 exploit conversion to streamoff.
2741 * testsuite/27_io/fpos/mbstate_t/5.cc: New.
2742
2743 2006-03-12 Howard Hinnant <hhinnant@apple.com>
2744
2745 * testsuite/27_io/basic_filebuf/underflow/char/10097.cc:
2746 Fix race condition.
2747 * testsuite/27_io/objects/char/9661-1.cc: Likewise.
2748 * testsuite/27_io/objects/wchar_t/9661-1.cc: Likewise.
2749
2750 2006-03-10 Paolo Carlini <pcarlini@suse.de>
2751
2752 * include/tr1/cmath: Add atan2 and pow bits; add using declarations.
2753 * include/tr1/math.h: Add using declarations.
2754 * include/tr1/complex: Add using declarations.
2755 * testsuite/tr1/8_c_compatibility/cmath/functions.cc: Fully
2756 qualify calls.
2757 * testsuite/tr1/8_c_compatibility/cmath/overloads.cc: Likewise;
2758 add atan2 and pow bits.
2759 * testsuite/tr1/8_c_compatibility/complex/overloads_float.cc: Likewise.
2760 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc: Likewise;
2761 adjust polar bits.
2762
2763 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add checks for double_t
2764 and float_t typedefs.
2765 * include/tr1/cmath: Add double_t and float_t.
2766 * testsuite/tr1/8_c_compatibility/cmath/types.cc: New.
2767
2768 * include/tr1/ctgmath: New.
2769 * include/tr1/tgmath.h: Likewise.
2770 * include/Makefile.am: Add.
2771 * testsuite/tr1/headers.cc: Update.
2772
2773 * include/Makefile.in: Regenerate.
2774 * configure: Likewise.
2775
2776 * docs/html/ext/tr1.html: Update.
2777
2778 2006-03-08 Paolo Carlini <pcarlini@suse.de>
2779
2780 Implement the resolution of DR 455, [DR].
2781 * src/ios_init.cc (ios_base::Init::Init()): Do it.
2782 * testsuite/27_io/objects/char/dr455.cc: New.
2783 * testsuite/27_io/objects/wchar_t/dr455.cc: Likewise.
2784 * docs/html/ext/howto.html: Add an entry for DR 455.
2785
2786 2006-03-07 Paolo Carlini <pcarlini@suse.de>
2787
2788 * include/tr1/cmath: Add C99 overloads.
2789 * include/tr1/common.h (struct __promote_3): Add.
2790 * testsuite/tr1/8_c_compatibility/cmath/overloads.cc: New.
2791
2792 * testsuite/tr1/8_c_compatibility/cmath/functions.cc: Tweak.
2793 * testsuite/tr1/8_c_compatibility/complex/overloads_float.cc: Likewise.
2794
2795 2006-03-06 Paolo Carlini <pcarlini@suse.de>
2796
2797 PR target/26532
2798 * config/io/c_io_stdio.h (struct __ios_flags): Remove.
2799 * include/bits/ios_base.h: Adjust consistently.
2800 (ios_base::_S_local_word_size): Change to an anonymous enum.
2801 * src/ios.cc: Do not define static const data of __ios_flags,
2802 likewise for ios_base::_S_local_word_size.
2803 * include/bits/locale_classes.h (locale::_S_categories_size):
2804 Change to an anonymous enum.
2805 * src/locale.cc: Don't define.
2806
2807 2006-03-03 Paolo Carlini <pcarlini@suse.de>
2808
2809 PR libstdc++/26526
2810 * config/abi/pre/gnu.ver (__copy_streambufs, 64-bit version): Add
2811 @GLIBCXX_3.4.8; move existing symbols @GLIBCXX_3.4.8 to 3.4.9.
2812 * configure.ac (libtool_VERSION): To 6:9:0.
2813 * testsuite/testsuite_abi.cc (check_version): Add GLIBCXX_3.4.9.
2814 * configure: Regenerate.
2815
2816 2006-03-02 Paolo Carlini <pcarlini@suse.de>
2817
2818 * config/abi/pre/gnu.ver: Adjust __copy_streambufs_eof export
2819 vs 64-bit arches.
2820
2821 2006-03-01 Paolo Carlini <pcarlini@suse.de>
2822
2823 * docs/html/ext/lwg-active.html, lwg-defects.html: Import Revision 41.
2824
2825 2006-02-27 Jakub Jelinek <jakub@redhat.com>
2826
2827 PR other/26208
2828 * libsupc++/eh_personality.cc (PERSONALITY_FUNCTION): Use
2829 _Unwind_GetIPInfo instead of _Unwind_GetIP.
2830
2831 2006-02-27 Paolo Carlini <pcarlini@suse.de>
2832
2833 PR libstdc++/14866
2834 * testsuite/27_io/ios_base/sync_with_stdio/1.cc: Redirect
2835 stderr instead.
2836
2837 2006-02-26 Paolo Carlini <pcarlini@suse.de>
2838
2839 * include/tr1/cmath: Add templates (8.16.3).
2840 * include/tr1/cstdbool: New.
2841 * include/tr1/stdbool.h: Likewise.
2842 * include/Makefile.am: Add.
2843 * testsuite/tr1/8_c_compatibility/cmath/templates.cc: New.
2844 * testsuite/tr1/headers.cc: Update.
2845 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <stdbool.h> check.
2846 * docs/html/ext/tr1.html: Update.
2847 * include/Makefile.in: Regenerate.
2848 * config.h.in: Likewise.
2849 * configure: Likewise.
2850
2851 2006-02-24 Paolo Carlini <pcarlini@suse.de>
2852
2853 * include/tr1/array (array<>::swap, assign): Implement.
2854 * include/tr1/array (operator==, operator!=, operator<,
2855 operator>, operator>=, operator<=, swap, get): Inline.
2856 * testsuite/tr1/6_containers/array/requirements/member_swap.cc: New.
2857 * testsuite/tr1/6_containers/array/requirements/assign.cc: Likewise.
2858 * testsuite/tr1/6_containers/array/specialized_algorithms/swap.cc:
2859 Likewise.
2860
2861 2006-02-23 Benjamin Kosnik <bkoz@redhat.com>
2862
2863 * testsuite/22_locale/codecvt/in/wchar_t/1.cc (test01): Change int
2864 to size_t. Use explicit static_cast for casts.
2865 * testsuite/22_locale/codecvt/in/wchar_t/6.cc (test06): Same.
2866 * testsuite/22_locale/codecvt/in/wchar_t/5.cc (test05): Same.
2867 * testsuite/ext/stdio_sync_filebuf/wchar_t/1.cc (test01): Same.
2868
2869 2006-02-22 Paolo Carlini <pcarlini@suse.de>
2870
2871 * docs/html/ext/pb_assoc/
2872 basic_tree_assoc_cntnr_const_node_iterator.html:Fix links
2873 * docs/html/ext/pb_assoc/basic_tree_assoc_cntnr_node_iterator.html:
2874 Likewise.
2875 * docs/html/ext/pb_assoc/hash_based_containers.html: Likewise.
2876 * docs/html/ext/pb_assoc/hash_standard_resize_policy.html: Likewise.
2877 * docs/html/ext/pb_assoc/interface.html: Likewise..
2878 * docs/html/ext/pb_assoc/list_updates.html: Likewise.
2879 * docs/html/ext/pb_assoc/lu_based_containers.html: Likewise.
2880 * docs/html/ext/pb_assoc/resize_policies.html: Likewise.
2881 * docs/html/ext/pb_assoc/sample_probe_fn.html: Likewise.
2882 * docs/html/ext/pb_assoc/sample_range_hashing.html: Likewise.
2883 * docs/html/ext/pb_assoc/sample_ranged_hash_fn.html: Likewise.
2884 * docs/html/ext/pb_assoc/sample_ranged_probe_fn.html: Likewise.
2885 * docs/html/ext/pb_assoc/sample_resize_policy.html: Likewise.
2886 * docs/html/ext/pb_assoc/tree_assoc_cntnr_const_node_iterator.html:
2887 Likewise.
2888 * docs/html/ext/pb_assoc/tree_assoc_cntnr_node_iterator.html: Likewise.
2889
2890 2006-02-22 Paolo Carlini <pcarlini@suse.de>
2891
2892 PR libstdc++/26132
2893 * include/tr1/hashtable (hashtable<>::rehash): Define.
2894 * testsuite/tr1/6_containers/unordered/hashtable/26132.cc: New.
2895
2896 * include/tr1/hashtable: Trivial formatting and stylistic fixes.
2897
2898 * testsuite/tr1/headers.cc: remove <tr1/hashtable>, not a tr1 header,
2899 only an implementation detail.
2900
2901 2006-02-22 Paolo Carlini <pcarlini@suse.de>
2902
2903 * include/debug/list (splice): Remove splice_alloc check, redundant
2904 after implementing the splice bits of N1599.
2905
2906 2006-02-21 Benjamin Kosnik <bkoz@redhat.com>
2907
2908 * include/c_std/cmath.tcc: Use _GLIBCXX_BEGIN_NAMESPACE,
2909 _GLIBCXX_END_NAMESPACE.
2910
2911 2006-02-21 Benjamin Kosnik <bkoz@redhat.com>
2912
2913 * include/bits/c++config: Simplify debug namespaces.
2914 * include/ext/hash_set: Specialize insert_iterator after norm,
2915 debug containers have been (optionally) declared. Use nested
2916 namespaces.
2917 * include/ext/hash_map: Same.
2918 * include/debug/hash_map.h (insert): Add specialization for value
2919 pointer types.
2920 * include/debug/hash_set.h (insert): Same.
2921 * include/debug/hash_multimap.h: Change __gnu_debug_def to __debug.
2922 * include/debug/set.h: Same.
2923 * include/debug/bitset: Same.
2924 * include/debug/multiset.h: Same.
2925 * include/debug/hash_multiset.h: Same.
2926 * include/debug/vector: Same.
2927 * include/debug/map.h: Same.
2928 * include/debug/deque: Same.
2929 * include/debug/list: Same.
2930 * include/debug/multimap.h. Same.
2931 * include/debug/macros.h: Use __gnu_debug.
2932 * include/debug/debug.h: Same.
2933 * include/debug/formatter.h: Same.
2934 * include/debug/safe_sequence.h: Same.
2935 * include/debug/functions.h: Same.
2936 * include/debug/safe_base.h: Same.
2937 * include/debug/safe_iterator.h: Same.
2938 * include/debug/safe_iterator.tcc: Same.
2939 (_M_invalidate): Adjust compare order.
2940 * include/debug/string: Change std::__gnu_debug to __gnu_debug.
2941 * include/ext/hashtable.h: Formatting fixes.
2942 * include/bits/stl_map.h: Formatting fixes.
2943 * src/compatibility.cc: Adjust compatibility symbols for old debug
2944 mode model.
2945 * src/debug_list.cc: Tweak.
2946 * src/debug.cc: Adjust namespaces.
2947 * docs/html/debug_mode.html: Adjust namespace names.
2948 * testsuite/25_algorithms/heap/heap.cc: Restore _GLIBCXX_DEBUG
2949 macro guards, as count values differ when in debug mode.
2950 * testsuite/23_containers/vector/26412.cc: Move to...
2951 * testsuite/23_containers/vector/26412-1.cc: ... here.
2952 * testsuite/23_containers/vector/26412-2.cc: Add.
2953
2954 * include/ext/pb_assoc/detail/standard_policies.hpp
2955 (PB_ASSOC_HASH_NAMESPACE): Remove, use __gnu_cxx::hash_map and
2956 std::equal_to.
2957
2958 * configure.ac (libtool_VERSION): To 6:8:0.
2959 * configure: Regenerate.
2960 * config/abi/pre/gnu.ver: Revert to exporting __gnu_debug symbols.
2961 (GLIBCXX_3.4.8): New.
2962 * testsuite/testsuite_abi.cc: Add GLIBCXX_3.4.8 to known versions.
2963
2964 2006-02-21 Paolo Carlini <pcarlini@suse.de>
2965
2966 * include/tr1/hashtable: Trivial formatting fixes.
2967
2968 2006-02-20 Paolo Carlini <pcarlini@suse.de>
2969
2970 Revert recent commit for libstdc++/26211, now suspended waiting for
2971 DR 342 (reopened) to reach a new resolution.
2972 * include/bits/istream.tcc (basic_istream<>::tellg, seekg(pos_type),
2973 seekg(off_type, ios_base::seekdir)): Remove sentry.
2974 * testsuite/27_io/basic_istream/seekg/char/26211.cc: Remove.
2975 * testsuite/27_io/basic_istream/seekg/wchar_t/26211.cc: Likewise.
2976 * testsuite/27_io/basic_istream/tellg/char/26211.cc: Likewise.
2977 * testsuite/27_io/basic_istream/tellg/wchar_t/26211.cc: Likewise.
2978 * testsuite/27_io/basic_istream/seekg/char/8348-1.cc: Revert changes.
2979 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
2980 * testsuite/27_io/basic_istream/seekg/char/8348-2.cc: Likewise.
2981 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
2982 * testsuite/27_io/basic_istream/tellg/char/8348.cc: Likewise.
2983 * testsuite/27_io/basic_istream/tellg/wchar_t/8348.cc: Likewise.
2984
2985 2006-02-19 Paolo Carlini <pcarlini@suse.de>
2986
2987 * include/std/std_sstream.h (basic_stringbuf<>::setbuf): Simply
2988 clear the internal _M_string, adjust _M_sync call.
2989 * include/bits/sstream.tcc (basic_stringbuf<>::_M_sync): Adjust
2990 consistently for calls from setbuf.
2991
2992 2006-02-17 Paolo Carlini <pcarlini@suse.de>
2993 Howard Hinnant <hhinnant@apple.com>
2994
2995 PR libstdc++/26250
2996 * include/bits/sstream.tcc (basic_stringbuf<>::overflow): Tweak
2997 to leave epgtr() just past the new write position, as per the
2998 relevant bits of 27.7.1.3/8 (not changed by DR 432).
2999 * testsuite/27_io/basic_stringbuf/overflow/char/26250.cc: New.
3000 * testsuite/27_io/basic_stringbuf/overflow/wchar_t/26250.cc: Same.
3001
3002 * docs/html/ext/howto.html: Add entries for DR 169 and DR 432.
3003
3004 * include/std/std_sstream.h (basic_stringbuf<>::_M_sync): Move out
3005 of line...
3006 * include/bits/sstream.tcc: ... here.
3007
3008 2006-02-16 Joseph S. Myers <joseph@codesourcery.com>
3009
3010 PR libstdc++/14939
3011 * config/os/uclibc/ctype_base.h, config/os/uclibc/ctype_inline.h,
3012 config/os/uclibc/ctype_noninline.h, config/os/uclibc/os_defines.h:
3013 New.
3014 * acinclude.m4 (GLIBCXX_CONFIGURE): Test whether using uClibc.
3015 * configure.host: Use os/uclibc for uClibc.
3016 * crossconfig.m4 (*-linux*): Use link tests. Don't hardcode
3017 presence of math functions.
3018 * configure: Regenerate.
3019
3020 2006-02-12 Paolo Carlini <pcarlini@suse.de>
3021
3022 PR libstdc++/26211
3023 * include/bits/istream.tcc (basic_istream<>::tellg, seekg(pos_type),
3024 seekg(off_type, ios_base::seekdir)): Construct a sentry, as per
3025 27.6.1.3/1.
3026 * testsuite/27_io/basic_istream/seekg/char/26211.cc: New.
3027 * testsuite/27_io/basic_istream/seekg/wchar_t/26211.cc: Likewise.
3028 * testsuite/27_io/basic_istream/tellg/char/26211.cc: Likewise.
3029 * testsuite/27_io/basic_istream/tellg/wchar_t/26211.cc: Likewise.
3030 * testsuite/27_io/basic_istream/seekg/char/8348-1.cc: Adjust.
3031 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
3032 * testsuite/27_io/basic_istream/seekg/char/8348-2.cc: Likewise.
3033 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
3034 * testsuite/27_io/basic_istream/tellg/char/8348.cc: Likewise.
3035 * testsuite/27_io/basic_istream/tellg/wchar_t/8348.cc: Likewise.
3036
3037 2006-02-10 Paolo Carlini <pcarlini@suse.de>
3038
3039 PR libstdc++/26181
3040 * include/bits/streambuf.tcc (__copy_streambufs_eof): New, like
3041 the existing __copy_streambufs but reporting eof in input.
3042 (__copy_streambufs): Just use the latter.
3043 * src/streambuf.cc (__copy_streambufs_eof): Adjust specializations
3044 of __copy_streambufs.
3045 * include/bits/istream.tcc (operator>>(__streambuf_type*)): Use
3046 __copy_streambufs_eof instead.
3047 * include/std/std_streambuf.h: Adjust.
3048 * src/streambuf-inst.cc: Adjust.
3049 * config/abi/pre/gnu.ver: Export the new symbols.
3050 * testsuite/27_io/basic_istream/extractors_other/char/26181.cc: New.
3051 * testsuite/27_io/basic_istream/extractors_other/wchar_t/26181.cc:
3052 Likewise.
3053 * testsuite/27_io/basic_istream/extractors_other/char/1.cc: Adjust.
3054 * testsuite/27_io/basic_istream/extractors_other/wchar_t/1.cc:
3055 Likewise.
3056
3057 2006-02-08 Benjamin Kosnik <bkoz@redhat.com>
3058
3059 PR libstdc++/26142
3060 * include/debug/debug.h: Move debug alias inside namespace std,
3061 same with namespace __gnu_cxx. Add top-level __gnu_debug
3062 namespace.
3063 * include/debug/hash_multimap.h: Nest within __gnu_cxx, not
3064 std. Also, change nesting namespace name from __gnu_debug_def to
3065 __gnu_debug.
3066 * include/debug/hash_map.h: Same.
3067 * include/debug/hash_multiset.h: Same.
3068 * include/debug/hash_set.h: Same.
3069 * docs/html/debug.html: Same.
3070 * testsuite/23_containers/vector/26412.cc: New.
3071 * testsuite/23_containers/vector/invalidation/1.cc: Correct
3072 qualifications for debug namespace change.
3073 * testsuite/23_containers/vector/invalidation/2.cc: Same.
3074 * testsuite/23_containers/vector/invalidation/3.cc: Same.
3075 * testsuite/23_containers/vector/invalidation/4.cc: Same.
3076 * testsuite/23_containers/deque/invalidation/1.cc: Same.
3077 * testsuite/23_containers/deque/invalidation/2.cc: Same.
3078 * testsuite/23_containers/deque/invalidation/3.cc: Same.
3079 * testsuite/23_containers/deque/invalidation/4.cc: Same.
3080 * testsuite/23_containers/multiset/invalidation/1.cc: Same.
3081 * testsuite/23_containers/multiset/invalidation/2.cc: Same.
3082 * testsuite/23_containers/multimap/invalidation/1.cc: Same.
3083 * testsuite/23_containers/multimap/invalidation/2.cc: Same.
3084 * testsuite/23_containers/bitset/invalidation/1.cc: Same.
3085 * testsuite/23_containers/bitset/cons/16020.cc: Same.
3086 * testsuite/23_containers/bitset/operations/13838.cc: Same.
3087 * testsuite/23_containers/list/invalidation/1.cc: Same.
3088 * testsuite/23_containers/list/invalidation/2.cc: Same.
3089 * testsuite/23_containers/list/invalidation/3.cc: Same.
3090 * testsuite/23_containers/list/invalidation/4.cc: Same.
3091 * testsuite/23_containers/set/invalidation/1.cc: Same.
3092 * testsuite/23_containers/set/invalidation/2.cc: Same.
3093 * testsuite/23_containers/map/invalidation/1.cc: Same.
3094 * testsuite/23_containers/map/invalidation/2.cc: Same.
3095 * testsuite/23_containers/map/modifiers/insert/16813.cc: Same.
3096 * testsuite/21_strings/basic_string/2.cc: Same.
3097
3098 2006-02-08 Paolo Carlini <pcarlini@suse.de>
3099
3100 PR libstdc++/26133 (DR 241, [WP])
3101 * include/bits/stl_algo.h (__unique_copy(,,, forward_iterator_tag,
3102 output_iterator_tag), __unique_copy(,,, input_iterator_tag,
3103 output_iterator_tag), __unique_copy(,,, input_iterator_tag,
3104 forward_iterator_tag), and predicated counterparts): Add.
3105 (__unique_copy(,,, output_iterator_tag), __unique_copy(,,,
3106 forward_iterator_tag), and predicated counterparts): Remove.
3107 (unique_copy): Adjust, dispatch to the three helpers above.
3108 * testsuite/25_algorithms/unique_copy/2.cc: New.
3109 * testsuite/25_algorithms/unique_copy/26133.cc: Likewise.
3110 * testsuite/25_algorithms/unique_copy/3.cc: Likewise.
3111 * docs/html/ext/howto.html: Add an entry for DR 241.
3112
3113 * testsuite/25_algorithms/unique_copy/1.cc: Minor cosmetic changes.
3114
3115 2006-02-07 Jakub Jelinek <jakub@redhat.com>
3116 Benjamin Kosnik <bkoz@redhat.com>
3117
3118 * configure.ac (_GLIBCXX_LONG_DOUBLE_COMPAT): New check.
3119 If true, set also port_specific_symbol_files and create
3120 as_symver_specs.
3121 (GLIBCXX_LDBL_COMPAT): New GLIBCXX_CONDITIONAL.
3122 * configure: Rebuilt.
3123 * config.h.in: Rebuilt.
3124 * config/os/gnu-linux/ldbl-extra.ver: New file.
3125 * config/abi/pre/gnu.ver: Make sure no __float128 symbols are
3126 exported.
3127 * include/bits/c++config (_GLIBCXX_LONG_DOUBLE_COMPAT,
3128 _GLIBCXX_LDBL_NAMESPACE, _GLIBCXX_BEGIN_LDBL_NAMESPACE,
3129 _GLIBCXX_END_LDBL_NAMESPACE): Define.
3130 * include/bits/localefwd.h: Use them to conditionally scope facets.
3131 * include/bits/locale_facets.h: Surround std::{money,num}_{get,put}
3132 with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE.
3133 Surround std::{money,num}_{get,put}
3134 with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE.
3135 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::money_get): Add __do_get method.
3136 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::money_put): Add __do_put method.
3137 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::num_get): Add __do_get method.
3138 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::num_put): Add __do_put method.
3139 * include/bits/locale_facets.tcc: Surround std::{money,num}_{get,put}
3140 with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE.
3141 (std::money_get::__do_get, std::money_put::__do_put,
3142 std::num_get::__do_get, std::num_put::__do_put): New
3143 specializations.
3144 * include/Makefile.am: Conditionally define
3145 _GLIBCXX_LONG_DOUBLE_COMPAT in c++config.
3146 * include/Makefile.in: Regenerate.
3147 * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT] (_GLIBCXX_LOC_ID,
3148 _GLIBCXX_SYNC_ID): Define, use them.
3149 * src/compatibility-ldbl.cc: New file.
3150 * src/complex_io.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Add compatibility
3151 symbols.
3152 * src/limits.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3153 * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3154 * src/locale-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3155 * src/locale-misc-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3156 * src/istream-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3157 * src/ostream-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3158 * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3159 * src/wlocale-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3160 * src/compatibility.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
3161 * config/locale/generic/c_locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]:
3162 Likewise.
3163 * config/locale/gnu/c_locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]:
3164 Likewise.
3165 * src/Makefile.am (libstdc++-symbol.ver): Append instead of
3166 insert in the middle if port specific symbol file requests it.
3167 (ldbl_compat_sources): New variable.
3168 (sources): Use it.
3169 (compatibility-ldbl.lo, compatibility-ldbl.o): New rules.
3170 * src/Makefile.in: Rebuilt.
3171 * testsuite/testsuite_abi.cc: Recognize GLIBCXX_LDBL_3.4,
3172 GLIBCXX_LDBL_3.4.7, CXXABI_LDBL_1.3.
3173
3174 2006-02-07 Paolo Carlini <pcarlini@suse.de>
3175
3176 * include/tr1/hashtable: Trivial formatting fixes.
3177
3178 2006-02-07 Paolo Carlini <pcarlini@suse.de>
3179 Zak Kipling <zak@transversal.com>
3180
3181 PR libstdc++/26127
3182 * include/tr1/hashtable (hashtable<>::key_equal): Define.
3183 (hashtable<>::bucket, rehash_base<>::max_load_factor): Fix.
3184 * testsuite/tr1/6_containers/unordered/hashtable/26127.cc: New.
3185
3186 2006-02-07 Paolo Carlini <pcarlini@suse.de>
3187
3188 * include/tr1/cmath: New.
3189 * include/tr1/cstdlib: Likewise.
3190 * include/tr1/ctime: Likewise.
3191 * include/tr1/math.h: Likewise.
3192 * include/tr1/stdlib.h: Likewise.
3193 * include/Makefile.am: Add.
3194 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <math.h> checks.
3195 * testsuite/tr1/8_c_compatibility/cmath/functions.cc: New.
3196 * testsuite/tr1/8_c_compatibility/cstdlib/functions.cc: Likewise.
3197 * testsuite/tr1/8_c_compatibility/cstdlib/types.cc: Likewise.
3198 * testsuite/tr1/headers.cc: Update.
3199
3200 * include/tr1/cinttypes: Do not provide abs and div, conflicting
3201 with the above overloads for _Longlong types.
3202 * include/tr1/inttypes.h: Adjust.
3203 * testsuite/tr1/8_c_compatibility/cinttypes/functions.cc: Adjust.
3204
3205 * docs/html/ext/tr1.html: Update.
3206
3207 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: Tweak.
3208
3209 * include/Makefile.in: Regenerate.
3210 * config.h.in: Likewise.
3211 * configure: Likewise.
3212
3213 2006-02-07 Mark Mitchell <mark@codesourcery.com>
3214
3215 * testsuite/testsuite_tr1.h (test_property): New function.
3216 * testsuite/tr1/4_metaprogramming/type_properties/extent/extent.cc
3217 (test01)
3218
3219 2006-02-05 Paolo Carlini <pcarlini@suse.de>
3220
3221 * include/tr1/cstdio: New.
3222 * include/tr1/stdio.h: Likewise.
3223 * include/Makefile.am: Add.
3224 * testsuite/tr1/8_c_compatibility/cstdio/functions.cc: New.
3225 * testsuite/tr1/headers.cc: Update.
3226 * docs/html/ext/tr1.html: Update.
3227
3228 * include/tr1/cwchar: Simplify, use _GLIBCXX_USE_C99, consistently
3229 with the facilities in std::.
3230 * include/tr1/cwctype: Likewise.
3231 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: Tweak.
3232 * testsuite/tr1/8_c_compatibility/cwctype/functions.cc: Likewise.
3233 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Remove <wchar.h> and
3234 <wctype.h> checks.
3235
3236 * include/Makefile.in: Regenerate.
3237 * config.h.in: Likewise.
3238 * configure: Likewise.
3239
3240 2006-02-04 Paolo Carlini <pcarlini@suse.de>
3241
3242 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: Fix.
3243
3244 2006-02-04 Paolo Carlini <pcarlini@suse.de>
3245
3246 * testsuite/27_io/basic_stringbuf/in_avail/char/21955.cc: Avoid
3247 warning on string constant.
3248
3249 2006-02-03 Paolo Carlini <pcarlini@suse.de>
3250
3251 * include/tr1/cwchar: New.
3252 * include/tr1/cwctype: Likewise.
3253 * include/tr1/wchar.h: Likewise.
3254 * include/tr1/wctype.h: Likewise.
3255 * include/Makefile.am: Add.
3256 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: New.
3257 * testsuite/tr1/8_c_compatibility/cwctype/functions.cc: Likewise.
3258 * testsuite/tr1/headers.cc: Update.
3259 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <wchar.h> and
3260 <wctype.h> checks.
3261 * docs/html/ext/tr1.html: Update.
3262 * include/Makefile.in: Regenerate.
3263 * config.h.in: Likewise.
3264 * configure: Likewise.
3265
3266 * testsuite/tr1/8_c_compatibility/cctype/functions.cc: Cosmetic tweak.
3267
3268 2006-02-02 Paolo Carlini <pcarlini@suse.de>
3269
3270 * include/tr1/cfloat: New.
3271 * include/tr1/climits: Likewise.
3272 * include/tr1/cstdarg: Likewise.
3273 * include/tr1/ctype.h: Likewise.
3274 * include/tr1/fenv.h: Likewise.
3275 * include/tr1/float.h: Likewise.
3276 * include/tr1/inttypes.h: Likewise.
3277 * include/tr1/limits.h: Likewise.
3278 * include/tr1/stdint.h: Likewise.
3279 * include/tr1/stdarg.h: Likewise.
3280 * include/Makefile.am: Add.
3281 * include/Makefile.in: Regenerate.
3282 * docs/html/ext/tr1.html: Update.
3283 * testsuite/tr1/headers.cc: New.
3284
3285 * include/tr1/cctype: Include <cctype> instead.
3286
3287 2006-01-31 Paolo Carlini <pcarlini@suse.de>
3288
3289 PR libstdc++/21554
3290 * include/tr1/array (array<>::_M_instance): Maximally align.
3291 * testsuite/ext/array_allocator/2.cc: Do not xfail for powerpc.
3292
3293 2006-01-31 Ed Smith-Rowland <3dw4rd@verizon.net>
3294
3295 * docs/html/faq/index.html ([1.0]): Replace references to CVS
3296 with appropriate references to SVN.
3297 ([1.3]): Likewise.
3298 ([1.4]): Likewise.
3299 ([2.3]): Likewise.
3300 * docs/html/faq/index.txt: Regenerated.
3301
3302 2006-01-30 Gabriel Dos Reis <gdr@integrable-solutions.net>
3303
3304 * include/bits/valarray_array.h (__valarray_default_construct):
3305 Replace use __is_fundamental with __is_pod.
3306 (__valarray_fill_construct): Likewise.
3307 (__valarray_copy_construct): Likewise.
3308 (__valarray_destroy_elements): Likewise.
3309 (__valarray_copy): Likewise.
3310
3311 2006-01-30 Paolo Carlini <pcarlini@suse.de>
3312
3313 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Do the <inttypes.h>
3314 checks only if the <stdint.h> checks are successful.
3315 * configure: Regenerate.
3316
3317 2006-01-30 Paolo Carlini <pcarlini@suse.de>
3318
3319 * include/tr1/cinttypes: New.
3320 * include/Makefile.am: Add.
3321 * testsuite/tr1/8_c_compatibility/cinttypes/functions: New.
3322 * testsuite/tr1/8_c_compatibility/cinttypes/types: Likewise.
3323 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <inttypes.h> checks.
3324 * docs/html/ext/tr1.html: Update.
3325 * include/Makefile.in: Regenerate.
3326 * config.h.in: Likewise.
3327 * configure: Likewise.
3328
3329 * testsuite/tr1/8_c_compatibility/cfenv/functions.cc: Cosmetic tweak.
3330 * testsuite/tr1/8_c_compatibility/cfenv/types.cc: Likewise.
3331
3332 * testsuite/tr1/8_c_compatibility/cstdint/types.cc: Fix, check in
3333 std::tr1.
3334
3335 2006-01-29 Paolo Carlini <pcarlini@suse.de>
3336
3337 * include/tr1/cstdint: New.
3338 * include/Makefile.am: Add.
3339 * testsuite/tr1/8_c_compatibility/cstdint/types: New.
3340 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <stdint.h> checks.
3341 * docs/html/ext/tr1.html: Update.
3342 * include/Makefile.in: Regenerate.
3343 * config.h.in: Likewise.
3344 * configure: Likewise.
3345
3346 * testsuite/tr1/8_c_compatibility/cfenv/types.cc: Cosmetic tweak.
3347
3348 2006-01-29 Paolo Carlini <pcarlini@suse.de>
3349
3350 PR libstdc++/26006
3351 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Tighten <ctype.h> and
3352 <fenv.h> checks.
3353 * configure: Regenerate.
3354
3355 2006-01-26 Paolo Carlini <pcarlini@suse.de>
3356
3357 * include/std/std_bitset.h (bitset<>::_M_copy_to_string):
3358 Call the internal _Unchecked_set(size_t) instead of set.
3359
3360 2006-01-26 Paolo Carlini <pcarlini@suse.de>
3361
3362 * docs/html/install.html ([Tools you will need beforehand]):
3363 Clarify that the de_DE locale is used by configure; clarify
3364 that missing localedata leads to skipped tests, not fails.
3365
3366 2006-01-26 Paolo Carlini <pcarlini@suse.de>
3367
3368 * include/tr1/cfenv: New.
3369 * include/Makefile.am: Add.
3370 * testsuite/tr1/8_c_compatibility/cfenv/functions.cc: New.
3371 * testsuite/tr1/8_c_compatibility/cfenv/types.cc: Likewise.
3372 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <fenv.h> checks.
3373 * docs/html/ext/tr1.html: Update; add note.
3374 * include/Makefile.in: Regenerate.
3375 * config.h.in: Likewise.
3376 * configure: Likewise.
3377
3378 * testsuite/tr1/8_c_compatibility/complex/functions.cc: Tweak.
3379 * testsuite/tr1/8_c_compatibility/cctype/functions.cc: Likewise.
3380
3381 * docs/html/faq/index.html: Fix link to tr1.html text; fix
3382 formatting.
3383
3384 2006-01-25 Paolo Carlini <pcarlini@suse.de>
3385
3386 * include/tr1/cctype: New.
3387 * include/Makefile.am: Add.
3388 * testsuite/tr1/8_c_compatibility/cctype/functions.cc: New.
3389 * include/Makefile.in: Regenerate.
3390
3391 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): New, check for C99
3392 support to TR1, Chapter 8.
3393 * configure.ac: Use it.
3394 * include/tr1/complex: Adjust.
3395 * config.h.in: Regenerate.
3396 * configure: Likewise.
3397
3398 2006-01-25 Benjamin Kosnik <bkoz@redhat.com>
3399
3400 * docs/html/configopts.html: Tweak docs.
3401
3402 * libsupc++/eh_personality.cc: Fix typos.
3403
3404 2006-01-24 Paolo Carlini <pcarlini@suse.de>
3405
3406 PR libstdc++/25649
3407 * include/std/std_istream.h (operator>>(short&), operator>>(int&)):
3408 Move out of line...
3409 * include/bits/istream.tcc: ... here.
3410 * include/std/std_ostream.h (operator<<(short), operator<<(int)):
3411 Move out of line...
3412 * include/bits/ostream.tcc: ... here.
3413
3414 2006-01-24 Ed Smith-Rowland <3dw4rd@verizon.net>
3415
3416 * docs/html/faq/index.html ([5.2]): Mention TR1 and point to
3417 paragraph [5.5], describing it.
3418 ([5.5]): New.
3419 * docs/html/ext/tr1.html: New.
3420
3421 2006-01-20 Benjamin Kosnik <bkoz@redhat.com>
3422
3423 * acinclude.m4 (GLIBCXX_CHECK_LINKER_FEATURES): Verbose ld version
3424 reporting. Disable --gc-sections for old binutils, by version.
3425 * configure: Regenerate.
3426
3427 2006-01-20 Joseph S. Myers <joseph@codesourcery.com>
3428
3429 PR libstdc++/25524
3430 * include/Makefile.am: Install host-specific headers in multilib
3431 subdirectory.
3432 * include/Makefile.in: Regenerate.
3433
3434 2006-01-19 Paolo Carlini <pcarlini@suse.de>
3435
3436 Implement list::splice (and merge) bits of N1599
3437 * include/bits/stl_list.h (list<>::_M_check_equal_allocators): New.
3438 (list<>::splice(iterator, list&), splice(iterator, list&, iterator),
3439 splice(iterator, list&, iterator, iterator)): Use it.
3440 * include/bits/list.tcc (list<>::merge(list&), merge(list&,
3441 _StrictWeakOrdering)): Likewise.
3442 * testsuite/23_containers/list/operators/5.cc: New.
3443
3444 2006-01-19 H.J. Lu <hongjiu.lu@intel.com>
3445
3446 PR libstdc++/25797
3447 * acinclude.m4 (GLIBCXX_CHECK_LINKER_FEATURES): Remove -Werror
3448 from CFLAGS. Check if linker really supports --gc-sections.
3449 * configure: Regenerated.
3450
3451 2006-01-18 Paul Brook <paul@codesourcery.com>
3452
3453 * libsupc++/eh_personality.cc (PERSONALITY_FUNCTION): Use std::abort.
3454
3455 2006-01-18 Paolo Carlini <pcarlini@suse.de>
3456
3457 * include/bits/allocator.h: Include <bits/cpp_type_traits.h>.
3458
3459 2006-01-18 Perry Smith <pedz@easesoftware.net>
3460
3461 PR libstdc++/25823
3462 PR libstdc++/25824
3463 * libsupc++/eh_alloc.cc: Fix return type of memset declaration.
3464 * libsupc++/eh_globals.cc: If !_GLIBCXX_HOSTED declare malloc and free.
3465
3466 2006-01-18 Paolo Carlini <pcarlini@suse.de>
3467
3468 * include/ext/pb_assoc/detail/value_type_adapter/
3469 value_type_adapter.hpp: Include <tr1/type_traits>.
3470 * include/ext/pb_assoc/detail/value_type_adapter/
3471 it_value_type_traits.hpp (it_value_type_traits_<>::value_type_holder):
3472 Use tr1::aligned_storage and tr1::alignment_of.
3473 (it_value_type_traits_<>::buf_t): Remove.
3474 (it_value_type_traits_<>::make_valid, recast): Adjust.
3475
3476 2006-01-16 Benjamin Kosnik <bkoz@redhat.com>
3477
3478 PR libstdc++/25797
3479 * acinclude.m4 (GLIBCXX_CHECK_LINKER_FEATURES): Add -Werror to
3480 CFLAGS for --gc-sections test. Correct compile test.
3481 * configure: Regenerated.
3482
3483 2006-01-15 Paolo Carlini <pcarlini@suse.de>
3484 Gabriel Dos Reis <gdr@integrable-solutions.net>
3485
3486 PR libstdc++/25626
3487 * include/std/std_valarray.h (valarray(const slice_array<>&),
3488 valarray(const gslice_array<>&), valarray(const mask_array<>&),
3489 valarray(const indirect_array<>&), valarray(const _Expr<>&)):
3490 Forward to __valarray_copy_construct, not __valarray_copy.
3491 * include/bits/valarray_array.h
3492 (__valarray_copy_construct(_Array<>, _Array<>, _Array<>, size_t),
3493 __valarray_copy_construct(_Array<>, size_t, size_t, _Array<>)):
3494 New.
3495
3496 2006-01-15 Paolo Carlini <pcarlini@suse.de>
3497
3498 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc:
3499 Fix norm test, use casts everywhere.
3500
3501 2006-01-14 Paolo Carlini <pcarlini@suse.de>
3502
3503 * testsuite/testsuite_tr1.h: Add missing include; use std::__are_same.
3504
3505 2006-01-14 Paolo Carlini <pcarlini@suse.de>
3506
3507 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc:
3508 Fix wrong test (don't pick by mistake the (const complex<>&, int)
3509 overload); add some.
3510
3511 2006-01-13 Paolo Carlini <pcarlini@suse.de>
3512 Howard Hinnant <hhinnant@apple.com>
3513
3514 * include/tr1/complex (arg, conj, imag, norm, polar, pow, real):
3515 Add, implementing TR1, 8.1.9.
3516 (__promote_2): New.
3517 * include/tr1/common.h: New, provides __promote, __promote_2.
3518 * include/Makefile.am: Add.
3519 * include/Makefile.in: Regenerate.
3520 * testsuite/testsuite_tr1.h (check_ret_type): New.
3521 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc: New.
3522 * testsuite/tr1/8_c_compatibility/complex/overloads_float.cc: New.
3523
3524 2006-01-12 Benjamin Kosnik <bkoz@redhat.com>
3525
3526 * acinclude.m4(GLIBCXX_CHECK_LINKER_FEATURES): Enable
3527 --gc-sections in more cases.
3528 * configure: Regenerate.
3529 * scripts/testsuite_flags.in: Remove SECTION_LDFLAGS.
3530 * scripts/testsuite_flags.in (cxxldflags): New.
3531 * testsuite/lib/libstdc++.exp (v3_target_compile): Add cxxldflags.
3532 (libstdc++_init ): Same.
3533
3534 2006-01-12 Jan Beulich <jbeulich@novell.com>
3535
3536 * crossconfig.m4: Add AC_DEFINE-s for HAVE_HYPOT, HAVE_ISINF, and
3537 HAVE_ISNAN for *-*-netware*.
3538 * configure: Refresh.
3539
3540 2006-01-11 Benjamin Kosnik <bkoz@redhat.com>
3541
3542 * acinclude.m4(GLIBCXX_CHECK_LINKER_FEATURES): Use -Wl,-z,relro if
3543 possible.
3544 * configure: Regenerate.
3545
3546 2006-01-10 Paolo Carlini <pcarlini@suse.de>
3547
3548 * include/tr1/complex: New file, hosts the additions to header
3549 <complex> described in TR1, Chapter 8 [tr.c99].
3550 * include/Makefile.am: Add.
3551 * include/Makefile.in: Regenerate.
3552 * testsuite/tr1/8_c_compatibility/complex/functions.cc: New.
3553
3554 2006-01-09 Paolo Carlini <pcarlini@suse.de>
3555
3556 PR libstdc++/25658
3557 * testsuite/23_containers/deque/cons/assign/1.cc: Divide
3558 sizes by 10.
3559
3560 2006-01-08 Paolo Carlini <pcarlini@suse.de>
3561
3562 PR libstdc++/22102 (insert as close to hint as possible)
3563 * include/bits/stl_tree.h (_Rb_tree<>::_M_insert_lower,
3564 _M_insert_equal_lower): New.
3565 (_M_insert_equal(iterator, const _Val&),
3566 _M_insert_equal(const_iterator, const _Val&)): Use the above.
3567 * docs/html/ext/howto.html: Add an entry for DR 233.
3568 * testsuite/23_containers/multiset/modifiers/insert/22102.cc: New.
3569 * testsuite/23_containers/multimap/modifiers/insert/22102.cc: New.
3570
3571 * testsuite/23_containers/set/insert/: Move...
3572 * testsuite/23_containers/set/modifiers/insert/: ...here.
3573 * testsuite/23_containers/map/insert/: Move...
3574 * testsuite/23_containers/map/modifiers/insert/: ...here.
3575 * testsuite/23_containers/multiset/insert/: Move...
3576 * testsuite/23_containers/multiset/modifiers/insert/: ...here.
3577
3578 2006-01-06 Paolo Carlini <pcarlini@suse.de>
3579
3580 * include/bits/stl_tree.h (_Rb_tree<>::insert_unique): Rename
3581 to _M_insert_unique.
3582 (_Rb_tree<>::insert_equal): Rename to _M_insert_equal.
3583 * include/bits/stl_map.h (class map<>): Update callers.
3584 * include/bits/stl_set.h (class set<>): Likewise.
3585 * include/bits/stl_multimap.h (class multimap<>): Likewise.
3586 * include/bits/stl_multiset.h (class multiset<>): Likewise.
3587
3588 2006-01-06 Paolo Carlini <pcarlini@suse.de>
3589
3590 * include/bits/stl_bvector.h (vector<bool>::erase(iterator,
3591 iterator)): Just use _M_erase_at_end.
3592
3593 2006-01-06 Paolo Carlini <pcarlini@suse.de>
3594
3595 * include/bits/stl_bvector.h (class vector<bool>): Move all the
3596 helpers under protected access mode, consistently with the primary
3597 vector template.
3598 (vector<bool>::_M_erase_at_end): Add.
3599 (erase(iterator, iterator), clear, resize, _M_fill_assign,
3600 _M_assign_aux): Use it.
3601 * testsuite/23_containers/vector/bool/modifiers/erase/1.cc: New.
3602
3603 2006-01-06 Paolo Carlini <pcarlini@suse.de>
3604
3605 Implement Option 3 of DR 431 for vector<bool>.
3606 * include/bits/stl_bvector.h (class _Bvector_base): Change to
3607 a struct, consistently with the primary vector template.
3608 (class vector<bool>): Adjust to protected inheritance, tidy
3609 typedefs.
3610 (_Bvector_base<>::_M_get_Bit_allocator): Add.
3611 (vector<bool>::vector(const vector&)): Use it.
3612 (_Bvector_base<>::get_allocator): Tidy.
3613 (vector<bool>::swap): Use __alloc_swap.
3614 * testsuite/23_containers/vector/bool/modifiers/swap/1.cc: New.
3615 * testsuite/23_containers/vector/bool/modifiers/swap/2.cc: New.
3616
3617 2006-01-05 Paolo Carlini <pcarlini@suse.de>
3618
3619 * testsuite/testsuite_hooks.h (test_tm(unsigned)): Change to
3620 take all the tm members.
3621 * testsuite/testsuite_hooks.cc (test_tm): Adjust.
3622 * testsuite/22_locale/time_put/put/wchar_t/10.cc: Update.
3623 * testsuite/22_locale/time_put/put/wchar_t/1.cc: Likewise.
3624 * testsuite/22_locale/time_put/put/wchar_t/2.cc: Likewise.
3625 * testsuite/22_locale/time_put/put/wchar_t/3.cc: Likewise.
3626 * testsuite/22_locale/time_put/put/wchar_t/4.cc: Likewise.
3627 * testsuite/22_locale/time_put/put/wchar_t/5.cc: Likewise.
3628 * testsuite/22_locale/time_put/put/wchar_t/6.cc: Likewise.
3629 * testsuite/22_locale/time_put/put/wchar_t/7.cc: Likewise.
3630 * testsuite/22_locale/time_put/put/wchar_t/8.cc: Likewise.
3631 * testsuite/22_locale/time_put/put/wchar_t/9.cc: Likewise.
3632 * testsuite/22_locale/time_put/put/wchar_t/17038.cc: Likewise.
3633 * testsuite/22_locale/time_put/put/char/10.cc: Likewise.
3634 * testsuite/22_locale/time_put/put/char/1.cc: Likewise.
3635 * testsuite/22_locale/time_put/put/char/2.cc: Likewise.
3636 * testsuite/22_locale/time_put/put/char/3.cc: Likewise.
3637 * testsuite/22_locale/time_put/put/char/4.cc: Likewise.
3638 * testsuite/22_locale/time_put/put/char/5.cc: Likewise.
3639 * testsuite/22_locale/time_put/put/char/6.cc: Likewise.
3640 * testsuite/22_locale/time_put/put/char/7.cc: Likewise.
3641 * testsuite/22_locale/time_put/put/char/8.cc: Likewise.
3642 * testsuite/22_locale/time_put/put/char/9.cc: Likewise.
3643 * testsuite/22_locale/time_put/put/char/17038.cc: Likewise.
3644 * testsuite/22_locale/time_get/get_year/wchar_t/1.cc: Likewise.
3645 * testsuite/22_locale/time_get/get_year/wchar_t/3.cc: Likewise.
3646 * testsuite/22_locale/time_get/get_year/char/1.cc: Likewise.
3647 * testsuite/22_locale/time_get/get_year/char/3.cc: Likewise.
3648 * testsuite/22_locale/time_get/get_monthname/wchar_t/1.cc: Likewise.
3649 * testsuite/22_locale/time_get/get_monthname/wchar_t/2.cc: Likewise.
3650 * testsuite/22_locale/time_get/get_monthname/char/1.cc: Likewise.
3651 * testsuite/22_locale/time_get/get_monthname/char/2.cc: Likewise.
3652 * testsuite/22_locale/time_get/get_weekday/wchar_t/1.cc: Likewise.
3653 * testsuite/22_locale/time_get/get_weekday/wchar_t/2.cc: Likewise.
3654 * testsuite/22_locale/time_get/get_weekday/wchar_t/3.cc: Likewise.
3655 * testsuite/22_locale/time_get/get_weekday/char/1.cc: Likewise.
3656 * testsuite/22_locale/time_get/get_weekday/char/2.cc: Likewise.
3657 * testsuite/22_locale/time_get/get_weekday/char/3.cc: Likewise.
3658 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
3659 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
3660 * testsuite/22_locale/time_get/get_date/wchar_t/1.cc: Likewise.
3661 * testsuite/22_locale/time_get/get_date/wchar_t/2.cc: Likewise.
3662 * testsuite/22_locale/time_get/get_date/wchar_t/3.cc: Likewise.
3663 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
3664 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
3665 * testsuite/22_locale/time_get/get_date/char/1.cc: Likewise.
3666 * testsuite/22_locale/time_get/get_date/char/2.cc: Likewise.
3667 * testsuite/22_locale/time_get/get_date/char/3.cc: Likewise.
3668 * testsuite/22_locale/time_get/get_time/wchar_t/1.cc: Likewise.
3669 * testsuite/22_locale/time_get/get_time/wchar_t/2.cc: Likewise.
3670 * testsuite/22_locale/time_get/get_time/wchar_t/3.cc: Likewise.
3671 * testsuite/22_locale/time_get/get_time/wchar_t/4.cc: Likewise.
3672 * testsuite/22_locale/time_get/get_time/char/1.cc: Likewise.
3673 * testsuite/22_locale/time_get/get_time/char/2.cc: Likewise.
3674 * testsuite/22_locale/time_get/get_time/char/3.cc: Likewise.
3675 * testsuite/22_locale/time_get/get_time/char/4.cc: Likewise.
3676
3677 2006-01-05 Paolo Carlini <pcarlini@suse.de>
3678
3679 * testsuite/testsuite_hooks.h (test_tm(unsigned)): New.
3680 * testsuite/testsuite_hooks.cc (test_tm(unsigned)): Define.
3681 * testsuite/22_locale/time_put/put/wchar_t/10.cc: Use it.
3682 * testsuite/22_locale/time_put/put/wchar_t/1.cc: Likewise.
3683 * testsuite/22_locale/time_put/put/wchar_t/2.cc: Likewise.
3684 * testsuite/22_locale/time_put/put/wchar_t/3.cc: Likewise.
3685 * testsuite/22_locale/time_put/put/wchar_t/4.cc: Likewise.
3686 * testsuite/22_locale/time_put/put/wchar_t/5.cc: Likewise.
3687 * testsuite/22_locale/time_put/put/wchar_t/6.cc: Likewise.
3688 * testsuite/22_locale/time_put/put/wchar_t/7.cc: Likewise.
3689 * testsuite/22_locale/time_put/put/wchar_t/8.cc: Likewise.
3690 * testsuite/22_locale/time_put/put/wchar_t/9.cc: Likewise.
3691 * testsuite/22_locale/time_put/put/wchar_t/17038.cc: Likewise.
3692 * testsuite/22_locale/time_put/put/char/10.cc: Likewise.
3693 * testsuite/22_locale/time_put/put/char/1.cc: Likewise.
3694 * testsuite/22_locale/time_put/put/char/2.cc: Likewise.
3695 * testsuite/22_locale/time_put/put/char/3.cc: Likewise.
3696 * testsuite/22_locale/time_put/put/char/4.cc: Likewise.
3697 * testsuite/22_locale/time_put/put/char/5.cc: Likewise.
3698 * testsuite/22_locale/time_put/put/char/6.cc: Likewise.
3699 * testsuite/22_locale/time_put/put/char/7.cc: Likewise.
3700 * testsuite/22_locale/time_put/put/char/8.cc: Likewise.
3701 * testsuite/22_locale/time_put/put/char/9.cc: Likewise.
3702 * testsuite/22_locale/time_put/put/char/17038.cc: Likewise.
3703 * testsuite/22_locale/time_get/get_year/wchar_t/1.cc: Likewise.
3704 * testsuite/22_locale/time_get/get_year/wchar_t/3.cc: Likewise.
3705 * testsuite/22_locale/time_get/get_year/char/1.cc: Likewise.
3706 * testsuite/22_locale/time_get/get_year/char/3.cc: Likewise.
3707 * testsuite/22_locale/time_get/get_monthname/wchar_t/1.cc: Likewise.
3708 * testsuite/22_locale/time_get/get_monthname/wchar_t/2.cc: Likewise.
3709 * testsuite/22_locale/time_get/get_monthname/char/1.cc: Likewise.
3710 * testsuite/22_locale/time_get/get_monthname/char/2.cc: Likewise.
3711 * testsuite/22_locale/time_get/get_weekday/wchar_t/1.cc: Likewise.
3712 * testsuite/22_locale/time_get/get_weekday/wchar_t/2.cc: Likewise.
3713 * testsuite/22_locale/time_get/get_weekday/wchar_t/3.cc: Likewise.
3714 * testsuite/22_locale/time_get/get_weekday/char/1.cc: Likewise.
3715 * testsuite/22_locale/time_get/get_weekday/char/2.cc: Likewise.
3716 * testsuite/22_locale/time_get/get_weekday/char/3.cc: Likewise.
3717 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
3718 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
3719 * testsuite/22_locale/time_get/get_date/wchar_t/1.cc: Likewise.
3720 * testsuite/22_locale/time_get/get_date/wchar_t/2.cc: Likewise.
3721 * testsuite/22_locale/time_get/get_date/wchar_t/3.cc: Likewise.
3722 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
3723 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
3724 * testsuite/22_locale/time_get/get_date/char/1.cc: Likewise.
3725 * testsuite/22_locale/time_get/get_date/char/2.cc: Likewise.
3726 * testsuite/22_locale/time_get/get_date/char/3.cc: Likewise.
3727 * testsuite/22_locale/time_get/get_time/wchar_t/1.cc: Likewise.
3728 * testsuite/22_locale/time_get/get_time/wchar_t/2.cc: Likewise.
3729 * testsuite/22_locale/time_get/get_time/wchar_t/3.cc: Likewise.
3730 * testsuite/22_locale/time_get/get_time/wchar_t/4.cc: Likewise.
3731 * testsuite/22_locale/time_get/get_time/char/1.cc: Likewise.
3732 * testsuite/22_locale/time_get/get_time/char/2.cc: Likewise.
3733 * testsuite/22_locale/time_get/get_time/char/3.cc: Likewise.
3734 * testsuite/22_locale/time_get/get_time/char/4.cc: Likewise.
3735
3736 2006-01-04 Paolo Carlini <pcarlini@suse.de>
3737
3738 * include/ext/sso_string_base.h (__sso_string_base<>::_M_dataplus):
3739 Use _CharT_alloc_type as base class.
3740 (_M_get_allocator, _M_swap, _M_create, _M_destroy): Adjust.
3741 * include/ext/vstring.h (get_allocator): Tidy.
3742
3743 2006-01-04 Paolo Carlini <pcarlini@suse.de>
3744
3745 Implement Option 3 of DR 431 for all the containers.
3746 * include/bits/allocator.h (struct __alloc_swap): Add, swaps
3747 allocators, optimized to nothing in case they are empty.
3748 * include/bits/stl_deque.h (deque<>::swap): Use it.
3749 * include/bits/stl_list.h (list<>::swap): Likewise.
3750 * include/bits/stl_tree.h (_Rb_tree<>::swap): Likewise.
3751 * include/bits/stl_vector.h (vector<>::swap): Likewise.
3752 * include/tr1/hashtable (hashtable<>::swap): Likewise.
3753 * include/ext/rc_string_base.h (__rc_string_base<>::_M_swap):
3754 Likewise.
3755 * include/ext/sso_string_base.h (__sso_string_base<>::_M_swap):
3756 Likewise.
3757 * include/ext/vstring_util.h (__vstring_utility<>::_Alloc_hider):
3758 Clean-up (now vstring uses the generic __alloc_swap facility).
3759 * include/tr1/unordered_map: Adjust includes.
3760 * include/tr1/unordered_set: Likewise.
3761 * docs/html/ext/howto.html: Add an entry for DR 431.
3762 * testsuite/23_containers/deque/modifiers/swap.cc: Move to...
3763 * testsuite/23_containers/deque/modifiers/swap/1.cc: ... here.
3764 * testsuite/23_containers/deque/modifiers/swap/2.cc: New.
3765 * testsuite/23_containers/deque/modifiers/swap/3.cc: New.
3766 * testsuite/23_containers/list/modifiers/swap.cc: Move to...
3767 * testsuite/23_containers/list/modifiers/swap/1.cc: ... here.
3768 * testsuite/23_containers/list/modifiers/swap/2.cc: New.
3769 * testsuite/23_containers/list/modifiers/swap/3.cc: New.
3770 * testsuite/23_containers/vector/modifiers/swap.cc: Move to...
3771 * testsuite/23_containers/vector/modifiers/swap/1.cc: ... here.
3772 * testsuite/23_containers/vector/modifiers/swap/2.cc: New.
3773 * testsuite/23_containers/vector/modifiers/swap/3.cc: New.
3774 * testsuite/23_containers/set/modifiers/swap.cc: Move to...
3775 * testsuite/23_containers/set/modifiers/swap/1.cc: ... here.
3776 * testsuite/23_containers/set/modifiers/swap/2.cc: New.
3777 * testsuite/23_containers/set/modifiers/swap/3.cc: New.
3778 * testsuite/23_containers/map/modifiers/swap.cc: Move to...
3779 * testsuite/23_containers/map/modifiers/swap/1.cc: ... here.
3780 * testsuite/23_containers/map/modifiers/swap/2.cc: New.
3781 * testsuite/23_containers/map/modifiers/swap/3.cc: New.
3782 * testsuite/23_containers/multiset/modifiers/swap.cc: Move to...
3783 * testsuite/23_containers/multiset/modifiers/swap/1.cc: ... here.
3784 * testsuite/23_containers/multiset/modifiers/swap/2.cc: New.
3785 * testsuite/23_containers/multiset/modifiers/swap/3.cc: New.
3786 * testsuite/23_containers/multimap/modifiers/swap.cc: Move to...
3787 * testsuite/23_containers/multimap/modifiers/swap/1.cc: ... here.
3788 * testsuite/23_containers/multimap/modifiers/swap/2.cc: New.
3789 * testsuite/23_containers/multimap/modifiers/swap/3.cc: New.
3790 * testsuite/tr1/6_containers/unordered/swap/unordered_set/1.cc: New.
3791 * testsuite/tr1/6_containers/unordered/swap/unordered_set/2.cc: New.
3792 * testsuite/tr1/6_containers/unordered/swap/unordered_map/1.cc: New.
3793 * testsuite/tr1/6_containers/unordered/swap/unordered_map/2.cc: New.
3794 * testsuite/tr1/6_containers/unordered/swap/unordered_multiset/1.cc: New.
3795 * testsuite/tr1/6_containers/unordered/swap/unordered_multiset/2.cc: New.
3796 * testsuite/tr1/6_containers/unordered/swap/unordered_multimap/1.cc: New.
3797 * testsuite/tr1/6_containers/unordered/swap/unordered_multimap/2.cc: New.
3798
3799 2006-01-03 Paolo Carlini <pcarlini@suse.de>
3800
3801 * include/bits/stl_list.h (_List_base<>::_M_get_Node_allocator): Add.
3802 (_M_get_Tp_allocator, get_allocator): Tidy.
3803 (list<>::list(const list&), insert(iterator, size_type, const
3804 value_type&), insert(iterator, _InputIterator, _InputIterator)):
3805 Use _M_get_Node_allocator.
3806 * include/bits/stl_tree.h (_Rb_tree<>::_M_get_Node_allocator()): Add.
3807 (_Rb_tree(const _Rb_tree<>&): Use it.
3808 * include/bits/stl_deque.h (_Deque_base<>::_M_get_map_allocator,
3809 get_allocator): Tidy.
3810 * include/bits/stl_vector.h (_Vector_base<>::get_allocator): Tidy.
3811 * testsuite/23_containers/map/operators/1_neg.cc: Adjust dg-error
3812 line numbers.
3813 * testsuite/23_containers/set/operators/1_neg.cc: Likewise.
3814
3815 * testsuite/testsuite_allocator.h (uneq_allocator<>::swap): Fix.
3816
3817 * testsuite/testsuite_allocator.h (class uneq_allocator): A simple
3818 non-empty testing allocator which can be endowed of a "personality"
3819 at construction time.
3820
3821 2006-01-03 Paolo Carlini <pcarlini@suse.de>
3822
3823 * testsuite/27_io/basic_stringstream/str/char/1.cc: Initialize vars.
3824 * testsuite/27_io/basic_stringstream/str/wchar_t/1.cc: Likewise.
3825 * testsuite/27_io/basic_istringstream/str/char/1.cc: Likewise, tidy.
3826 * testsuite/27_io/basic_istringstream/str/wchar_t/1.cc: Likewise.
3827
3828 2006-01-02 Mark Mitchell <mark@codesourcery.com>
3829
3830 * src/Makefile.am (LTLDFLAGS): New variable.
3831 (CXXLINK): Use LTLDFLAGS.
3832 * src/Makefile.in: Regenerated.
3833 * libsupc++/Makefile.am (LTLDFLAGS): New variable.
3834 (CXXLINK): Use LTLDFLAGS.
3835 * libsupc++/Makefile.in: Regenerated.
3836
3837 2006-01-02 Paolo Carlini <pcarlini@suse.de>
3838
3839 PR libstdc++/24645
3840 * include/std/std_istream.h (basic_istream<>::_M_extract): New.
3841 (operator>>(bool&), operator>>(short&), operator>>(unsigned short&),
3842 operator>>(int&), operator>>(unsigned int&), operator>>(long&),
3843 operator>>(unsigned long&), operator>>(long long&), operator>>
3844 (unsigned long long&), operator>>(float&), operator>>(double&),
3845 operator>>(long double&), operator>>(void*&)): Use it.
3846 * include/bits/istream.tcc (basic_istream<>::_M_extract): Define.
3847 * include/std/std_ostream.h (basic_ostream<>::_M_insert): New.
3848 (operator<<(long), operator<<(unsigned long), operator<<(bool),
3849 operator<<(short), operator<<(unsigned short), operator<<(int),
3850 operator<<(unsigned int), operator<<(long long), operator<<
3851 (unsigned long long), operator<<(double), operator<<(float),
3852 operator<<(long double), operator<<(const void*): Use it.
3853 * include/bits/ostream.tcc (basic_ostream<>::_M_insert): Define.
3854 * src/istream-inst.cc: Add _M_extract instantiations.
3855 * src/ostream-inst.cc: Add _M_insert instantiations.
3856 * config/abi/pre/gnu.ver: Export the new symbols @GLIBCXX_3.4.7;
3857 detail existing @GLIBCXX_3.4 exports of basic_ostream, num_put,
3858 money_put, etc., symbols to avoid exporting _M_insert symbols
3859 @GLIBCXX_3.4.