OSDN Git Service

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