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