OSDN Git Service

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