OSDN Git Service

PR target/26792
[pf3gnuchains/gcc-fork.git] / libstdc++-v3 / ChangeLog
index 1c04e88..c0092fd 100644 (file)
+2006-07-21  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/26792
+       * configure.ac: Use GCC_CHECK_UNWIND_GETIPINFO to
+       define HAVE_GETIPINFO.
+       * aclocal.m4: Add include of ../config/unwind_ipinfo.m4.
+       * config.h.in: Regenerate.
+       * configure: Regenerate.
+       * Makefile.in: Regenerate.
+       * libmath/Makefile.in: Regenerate.
+       * include/Makefile.in: Regenerate.
+       * src/Makefile.in: Regenerate.
+       * libsupc++/Makefile.in: Regenerate.
+       * testsuite/Makefile.in: Regenerate.
+       * po/Makefile.in: Regenerate.
+       * libsupc++/eh_personality.cc: Check HAVE_GETIPINFO.
+
+2006-07-21  Jason Merrill  <jason@redhat.com>
+
+       * libsupc++/eh_personality.cc: Wrap extern "C" function
+       definitions in namespace __cxxabiv1.
+
+2006-07-21  David Daney  <ddaney@avtrex.com>
+
+       PR libgcj/28426
+       * acinclude.m4: Added a comment.
+
+2006-07-20  Benjamin Kosnik  <bkoz@redhat.com>
+           Jakub Jelinek  <jakub@redhat.com>
+       
+       PR libstdc++/19664 round 1
+       * acinclude.m4 (GLIBCXX_ENABLE_VISIBILITY): Check it.
+       * configure.ac: Use it.
+       * configure: Regenerate.
+       * docs/html/configopts.html: Document it.
+       * include/Makefile.am: Slip in to c++config.
+       * include/Makefile.in: Regenerate.
+       * include/bits/c++config (_GLIBCXX_VISIBILITY): New.
+       (_GLIBCXX_BEGIN_NAMESPACE): Use it.
+       (_GLIBCXX_END_NAMESPACE): Use it.
+       (_GLIBCXX_BEGIN_NESTED_NAMESPACE): Use it.
+       (_GLIBCXX_END_NESTED_NAMESPACE): Use it.                
+       * src/debug.cc: Mark __gnu_internal namespace with hidden
+       visibility attribute.
+       * src/ext-inst.cc: Same.
+       * src/globals_io.cc: Same.
+       * src/globals_locale.cc: Same.
+       * src/ios_init.cc: Same.
+       * src/locale.cc: Same.
+       * src/mt_allocator.cc: Same.
+       * src/pool_allocator.cc: Same.
+
+2006-07-16  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/28277 (partial: valarray bits)
+       * include/std/std_valarray.h (valarray<>::shift(int),
+       valarray<>::cshift(int)): Avoid __builtin_alloca with no limit,
+       do the work in place.
+       * testsuite/26_numerics/valarray/28277.cc: New.
+
+2006-07-15  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/28277 (partial: ostream bits 1)
+       * include/bits/ostream.tcc (operator<<(basic_ostream<_CharT>&,
+       const char*)): Avoid __builtin_alloca with no limit in the
+       widening.
+       * testsuite/27_io/basic_ostream/inserters_character/wchar_t/
+       28277-1.cc: New.
+
+2006-07-14  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * acinclude.m4 (GLIBCXX_ENABLE_ATOMIC_BUILTINS): New.
+       * configure.ac: Use it.
+       * configure: Regenerated.
+       * config.h.in: Regenerated.
+       * configure.host: Simplify.
+       * include/bits/atomicity.h: Adjust macros.
+       * config/cpu/generic/atomicity.h: Move...
+       * config/cpu/generic/atomicity_mutex: New.
+       * config/cpu/generic/atomicity_mutex/atomicity.h: ...here.
+       * config/cpu/generic/atomic_builtins: Rename...
+       * config/cpu/generic/atomicity_builtins: ...to this.
+       * config/cpu/generic/atomicity_builtins/atomicity.h: Moved.
+       * config/cpu/mips/atomicity.h: Comment MIPS II requirement.
+
+       * scripts/testsuite_flags.in: Make --cxxflags reflect CXXFLAGS.
+       
+2006-07-14  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (minstd_rand0, minstd_rand, ranlux3, ranlux4):
+       Use unsigned long as implementation-defined type.
+
+2006-07-14  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random.tcc (struct _To_Unsigned_Type): Add.
+       (subtract_with_carry<>::seed(_Gen&, false_type)): Use an
+       unsigned type in the loop, fix factor multiplier, take g
+       invocations modulo 2^32.
+
+       * include/tr1/random.tcc (subtract_with_carry<>::
+       seed(unsigned long)): Fix value == 0 special case.
+
+       * include/tr1/random (struct _Shift): Fix for large shifts.
+
+2006-07-13  Paolo Carlini  <pcarlini@suse.de>
+
+       * testsuite/performance/21_strings/string_copy_cons_and_dest.cc: New.
+
+2006-07-13  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/Makefile.am (pch*_output_anchor): Add.
+       (pch*_output): Use.
+       (CLEANFILES): Use.
+       * include/Makefile.in: Regenerate.
+       
+       * scripts/check_performance: Be verbose on compile error.
+
+2006-07-12  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/Makefile.am: Revert last change.
+       * include/Makefile.in: Same.
+
+2006-07-12  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/Makefile.am (pch_output): Don't precompile extc++.h.
+       (pch_output_dirs): Same.
+       * include/Makefile.in: Regenerate.
+
+       * testsuite/lib/libstdc++.exp: Test PCH with stdtr1c++.h.
+       
+2006-07-11  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/ext/codecvt_specializations.h: Fix typo in commit
+       for libstdc++/28290.
+
+2006-07-11  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/bits/locale_facets.tcc (collate<>::do_transform(
+       const _CharT*, const _CharT*)): Simplify previous fix for
+       libstdc++/28277, always allocate memory dynamically.
+
+2006-07-11  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/28344
+       * include/tr1/random (gamma_distribution<>::
+       gamma_distribution(const result_type&)): Don't use __alpha as
+       parameter name, a predefined macro on Alpha systems.
+
+2006-07-11  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/28290
+       * include/ext/codecvt_specializations.h: Fix, adding missing
+       includes and guards.
+
+2006-07-11  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/28277 (partial: collate bits)
+       * include/bits/locale_facets.tcc (collate<>::do_transform(
+       const _CharT*, const _CharT*)): Avoid __builtin_alloca with no
+       limit; also avoid multiple calls (in a loop).
+       * testsuite/22_locale/collate/transform/char/28277.cc: New.
+       * testsuite/22_locale/collate/transform/wchar_t/28277.cc: Likewise.
+
+2006-07-10  Mike Stump  <mrs@apple.com>
+
+       * libsupc++/eh_globals.cc (~__eh_globals_init): Unset _M_init.
+
+2006-07-10  Benjamin Kosnik  <bkoz@redhat.com>
+
+       PR libstdc++/15448
+       * include/Makefile.am: Clean up pch rules.
+       * include/Makefile.in: Regenerate.
+
+2006-07-09  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/bits/locale_facets.tcc (__int_to_char<>(_CharT*,
+       long, const _CharT*, ios_base::fmtflags), __int_to_char<>(_CharT*,
+       unsigned long, const _CharT*, ios_base::fmtflags),
+       __int_to_char<>(_CharT*, long long, const _CharT*, ios_base::fmtflags),
+       __int_to_char<>(_CharT*, unsigned long long, const _CharT*,
+       ios_base::fmtflags)): Remove.
+       (__int_to_char<>(_CharT*, _ValueT, const _CharT*, ios_base::fmtflags,
+       bool)): Adjust.
+       (num_put<>::_M_insert_int(_OutIter, ios_base&, _CharT, _ValueT)):
+       Likewise.
+
+2006-07-06  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (class gamma_distribution<>): Add.
+       * include/tr1/random.tcc (gamma_distribution<>::operator(),
+       operator<<(std::basic_ostream<>&, const gamma_distribution<>&)):
+       Define.
+       * testsuite/tr1/5_numerical_facilities/random/gamma_distribution/
+       requirements/typedefs.cc: New.
+
+2006-07-06  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * testsuite/util/regression/trait/assoc/trait.hpp: Format.
+       * testsuite/util/regression/rand/priority_queue/
+       rand_regression_test.hpp: Same.
+       * testsuite/util/regression/rand/assoc/rand_regression_test.hpp: Same.
+       * testsuite/util/regression/rand/
+       assoc/container_rand_regression_test.hpp: Same.
+       * testsuite/util/regression/priority_queue/common_type.hpp: Same.
+       * testsuite/util/regression/assoc/common_type.hpp: Same.
+       * testsuite/util/regression/basic_type.hpp: Same.
+
+2006-07-05  Benjamin Kosnik  <bkoz@redhat.com> 
+
+       * include/Makefile.am (pch_output): New.
+       (clean-local): Use it.
+       * include/Makefile.in: Regenerate.
+
+2006-07-04  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (_Adaptor<>::operator()()): Cast 1 to
+       result_type.
+       (variate_generator<>::operator()(),
+       variate_generator<>::operator()(_Tp)): Inline.
+
+       * include/tr1/random: Minor cosmetic changes.
+
+2006-07-03  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/ext/rc_string_base.h (__rc_string_base::_S_max_size):
+       Adjust, take into account rounding in _M_create.
+       (__rc_string_base::_M_create): Add early _S_max_size check.
+
+2006-07-03  Ian Lance Taylor  <ian@airs.com>
+           Paolo Carlini  <pcarlini@suse.de>
+
+       * include/ext/rc_string_base.h (__rc_string_base::_S_max_size):
+       Increase by a factor of two.
+       * include/ext/sso_string_base.h (__sso_string_base::_S_max_size):
+       Likewise.
+
+2006-07-03  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/ext/sso_string_base.h (__sso_string_base::_M_create): Never
+       allocate a string bigger than _S_max_size.
+
+2006-06-29  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/Makefile.am (pch1_input, pch1_output_builddir,
+       pch1_outputj_installdir, pch1_source): Move from pch_*.
+       (pch2_input, pch2_output_builddir,
+       pch2_output_installdir, pch2_source): Clone for ext.
+       (pch3_input, pch3_output_builddir,
+       pch3_output_installdir, pch3_source): Clone for tr1.
+       (install-pch): Same.
+       * include/Makefile.in: Regenerate.
+
+       * include/precompiled: New directory.
+       * include/stdc++.h: Move...
+       * include/precompiled/stdc++.h: ... here.               
+       * include/precompiled/stdtr1c++.h: New.
+       * include/precompiled/extc++.h: New.
+
+       * testsuite/lib/libstdc++.exp (libstdc++_init): Set PCH_CXXFLAGS
+       to -include bits/stdtr1c++.h.
+
+2006-06-29  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * testsuite/lib/libstdc++.exp (v3_target_compile): Set timeout to
+       600.
+
+2006-06-27  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * testsuite/util/regression/rand/priority_queue/
+       rand_regression_test.hpp: Revert.
+
+2006-06-27  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/ext/typelist.h (typelist_append): To append_typelist. 
+       (typelist): To node.
+       Enclose in namespace typelist.
+       * testsuite/util/testsuite_common_types.h: Adjust names, namespaces.
+       * testsuite/performance/23_containers/find/map.cc: Same.
+       * testsuite/performance/23_containers/create/map.cc: Same.
+       * testsuite/performance/23_containers/insert_erase/associative.cc: 
+       Same.
+       * testsuite/performance/23_containers/insert/sequence.cc: Same.
+       * testsuite/performance/23_containers/insert/associative.cc: Same.
+       * testsuite/performance/23_containers/create_from_sorted/set.cc: Same.
+       * testsuite/performance/23_containers/index/map.cc: Same.
+       * testsuite/performance/23_containers/insert_from_sorted/set.cc: Same.
+       * testsuite/performance/23_containers/create_sort/list.cc: Same.
+       * testsuite/performance/23_containers/sort_search/list.cc: Same.
+       * testsuite/performance/23_containers/producer_consumer/sequence.cc: 
+       Same.
+       * testsuite/performance/23_containers/producer_consumer/associative.cc:
+       Same.
+
+2006-06-26  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc:
+       Reduce iterations by half.
+       * testsuite/ext/pb_ds/regression/hash_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/priority_queue_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/tree_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/trie_data_map_rand.cc: Same.
+
+       * testsuite/util/regression/rand/assoc/rand_regression_test.hpp:
+       Set probability of compare from 1 to 0.25.
+       * testsuite/util/regression/rand/priority_queue/
+       rand_regression_test.hpp: Same.
+
+2006-06-25  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (operator<<(std::basic_ostream<>&,
+       const linear_congruential<>&), operator>>(std::basic_istream<>&,
+       linear_congruential<>&), operator<<(std::basic_ostream<>&,
+       const mersenne_twister<>&), operator>>(std::basic_istream<>&,
+       mersenne_twister<>&), operator<<(std::basic_ostream<>&,
+       const subtract_with_carry<>&), operator>>(std::basic_istream<>&,
+       subtract_with_carry<>&), operator<<(std::basic_ostream<>&,
+       const discard_block<>&), operator>>(std::basic_istream<>&,
+       discard_block<>&), operator<<(std::basic_ostream<>&,
+       const xor_combine<>&), operator>>(std::basic_istream<>&,
+       xor_combine<>&), operator<<(std::basic_ostream<>&,
+       const uniform_int<>&), operator>>(std::basic_istream<>&,
+       uniform_int<>&), operator<<(std::basic_ostream<>&,
+       const bernoulli_distribution&), operator<<(std::basic_ostream<>&,
+       const geometric_distribution<>&), operator<<(std::basic_ostream<>&,
+       const uniform_real<>&), operator>>(std::basic_istream<>&,
+       uniform_real<>&), operator<<(std::basic_ostream<>&,
+       const exponential_distribution<>&), operator<<(std::basic_ostream<>&,
+       const normal_distribution<>&), operator>>(std::basic_istream<>&,
+       normal_distribution<>&)): Redo per TR1 specs; move out of line...
+       * include/tr1/random.tcc: ... here.
+
+2006-06-24  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (class normal_distribution<>): Add.
+       * include/tr1/random.tcc (normal_distribution<>::operator()): Define.
+       
+       * include/tr1/random.tcc (struct _Max): Remove, "inline" in the
+       only user, mersenne_twister<>::max().
+
+       * include/tr1/random.tcc (struct _Shift): Move...
+       * include/tr1/random: ... here.
+
+       * include/tr1/random.tcc (linear_congruential<>::
+       linear_congruential(unsigned long), linear_congruential<>::
+       linear_congruential(_Gen&), mersenne_twister<>::max())): Move inline...
+       * include/tr1/random: ... here.
+
+       * include/tr1/random (exponential_distribution<>::
+       exponential_distribution(const result_type&)): Add missing
+       _GLIBCXX_DEBUG_ASSERT.
+
+       * testsuite/tr1/5_numerical_facilities/random/
+       exponential_distribution/requirements/typedefs.cc: New.
+       * testsuite/tr1/5_numerical_facilities/random/
+       normal_distribution/requirements/typedefs.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/
+       bernoulli_distribution/requirements/typedefs.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/
+       geometric_distribution/requirements/typedefs.cc: Likewise.
+
+2006-06-23  Benjamin Kosnik  <bkoz@redhat.com>
+
+       PR libstdc++/27984
+       * testsuite/lib/libstdc++.exp (libstdc++_init): Adjust
+       testing includes.
+       * docs/html/test.html: Adjust for testsuite changes.
+       
+2006-06-22  Jonathan Lennox  <lennox@cs.columbia.edu>
+           Paolo Carlini  <pcarlini@suse.de>
+
+       * include/ext/pb_ds/detail/resize_policy/
+       hash_prime_size_policy_imp.hpp: Cast to size_t instead.
+
+2006-06-22  Ami Tavory  <atavory@gmail.com>
+
+       * include/ext/pb_ds/detail/resize_policy/
+       hash_prime_size_policy_imp.hpp: Fix for 64-bit machines.
+
+2006-06-21  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/bits/postypes.h (operator==(const fpos<>&, const fpos<>&),
+       operator!=(const fpos<>&, const fpos<>&)): Add.
+       * testsuite/27_io/fpos/mbstate_t/6.cc: New.
+
+2006-06-21  Mark Mitchell  <mark@codesourcery.com>
+
+       * acinclude.m4 (GLIBCXX_EXPORT_INSTALL_INFO): When
+       cross-compiling, put headers in $prefix/$target/include/c++.
+       * configure: Regenerated.
+
+2006-06-20  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random.tcc (struct _Private::_Mod_w<>,
+       _Private::__mod_w<>): Remove.
+       (struct _Private::_Shift<>): New.
+       (struct _Private::_Max_w<>): Rename to _Max, use the latter.
+       (mersenne_twister<>::seed(unsigned long), seed(_Gen&, false_type),
+       max()): Adjust.
+
+2006-06-20  Vladimir Prus  <vladimir@codesourcery.com>
+
+       * libsupc++/eh_arm.cc (__cxa_begin_cleanup): Always return 'true'.
+
+2006-06-19  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (xor_combine<>::operator<<): Fix typo.
+       
+       * include/tr1/random (bernoulli_distribution::min(),
+       bernoulli_distribution::max(), geometric_distribution<>::min(),
+       geometric_distribution<>::max()): Remove.
+
+       * include/tr1/random (geometric_distribution<>::operator()):
+       Simplify formula.
+
+       * include/tr1/random: Minor cosmetic changes.
+
+       * testsuite/tr1/5_numerical_facilities/random/discard_block/
+       operators/equal.cc: New.
+       * testsuite/tr1/5_numerical_facilities/random/discard_block/
+       operators/not_equal.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/discard_block/
+       operators/serialize.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/xor_combine/
+       operators/equal.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/xor_combine/
+       operators/not_equal.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/xor_combine/
+       operators/serialize.cc: Likewise.
+
+2006-06-17  Ami Tavory  <atavory@gmail.com>
+           Paolo Carlini  <pcarlini@suse.de>
+
+       * testsuite/util/rng/twister_rand_gen.cc: Adapt to simply use
+       tr1::mt19937.
+       * testsuite/util/rng/twister_rand_gen.hpp: Likewise.
+
+2006-06-16  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (uniform_real<>::uniform_real(_RealType,
+       _RealType)): Implement.
+       (uniform_real<>::min()): Likewise.
+       (uniform_real<>::max()): Likewise.
+       (uniform_real<>::reset()): Likewise.
+
+       * include/tr1/random (class uniform_real<>): Minor cosmetic tweaks.
+
+2006-06-16  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/bits/locale_facets.tcc (time_get<>::_M_extract_via_format):
+       Ignore the value of the __err argument.
+       (time_get<>::do_get_weekday): Likewise.
+       (time_get<>::do_get_monthname): Likewise.
+       * testsuite/22_locale/time_get/get_year/wchar_t/5.cc: New.
+       * testsuite/22_locale/time_get/get_year/char/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_monthname/wchar_t/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_monthname/char/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_weekday/wchar_t/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_weekday/char/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_date/wchar_t/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_date/char/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_time/wchar_t/5.cc: Likewise.
+       * testsuite/22_locale/time_get/get_time/char/5.cc: Likewise.
+
+2006-06-15  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/ext/pb_ds/detail/type_utils.hpp (numeric_traits): Add,
+       const expression interface to std::numeric_limits::min and max
+       functions.
+       * include/ext/pb_ds/trie_policy.hpp (string_trie_e_access_traits):
+       Use it.
+
+       * include/ext/pb_ds/detail/resize_policy/
+       hash_load_check_resize_trigger_imp.hpp: Format.
+       * include/ext/pb_ds/detail/pat_trie_/internal_node.hpp: Same.
+
+2006-06-15  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random.tcc (mersenne_twister<>::operator()()):
+       Reload the last position of the _M_x vector too.
+
+2006-06-15  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (class xor_combine): Fix result_type typedef.
+       * testsuite/tr1/5_numerical_facilities/random/xor_combine/
+       cons/default.cc: New.
+       * testsuite/tr1/5_numerical_facilities/random/xor_combine/
+       requirements/typedefs.cc: Tweak.
+
+       * include/tr1/random: Minor cosmetic changes.
+
+2006-06-14  Ami Tavory  <atavory@gmail.com>
+           Benjamin Kosnik  <bkoz@redhat.com>
+
+       * include/ext/pb_assoc: Delete.
+       * include/ext/pb_ds: Add.
+       * docs/html/ext/pb_assoc: Delete.
+       * docs/html/ext/pb_ds: Add.
+       * testsuite/ext/pb_assoc: Delete.
+       * testsuite/ext/pb_ds: Add.
+       * testsuite/performance/ext: Add.
+       * testsuite/performance/ext/pb_ds: Add. 
+
+       * testsuite/util/regression: New.
+       * testsuite/util/rng: New.
+       * testsuite/util/native_type: New.
+       * testsuite/util/common_type: New.
+       * testsuite/util/performance: New.
+       * testsuite/util/hash_fn: New.
+       * testsuite/util/io: New.
+       * testsuite/util/statistic: New.
+
+       * scripts/make_graph.py: New.
+       * scripts/make_graphs.py: New.
+       * testsuite/data/thirty_years_among_the_dead_preproc.txt: Add.
+       * testsuite/data/make_graph_htmls.xml: Add.
+       * testsuite/data/make_graph_test_infos.xml: Add.        
+
+       * testsuite/lib/libstdc++.exp (v3-build_support): Add in new
+       object files for regression testing.
+       * docs/html/documentation.html: Adjust links.
+       * include/Makefile.am (install-headers): Update for new sources,
+       directories.
+       * include/Makefine.in: Regenerate.
+       * scripts/testsuite_flags.in: Adjust to testsuite/util path.
+       * scripts/check_performance: Simplify, adjust for new testsuite output.
+       * testsuite/Makefile.am (check-performance): Adjust.
+       (doc-performance): New.
+       * testsuite/Makefile.in: Regenerate.
+
+       * include/ext/pb_ds: New.
+       * include/ext/pb_ds/assoc_container.hpp: Same.
+       * include/ext/pb_ds/detail: New.
+       * include/ext/pb_ds/detail/binomial_heap_base_: New.
+       * include/ext/pb_ds/detail/binomial_heap_base_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_base_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_base_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_base_/binomial_heap_base_.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_base_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_base_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_base_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy: New.
+       * include/ext/pb_ds/detail/resize_policy/sample_size_policy.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/hash_prime_size_policy_imp.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/cc_hash_max_collision_check_resize_trigger_imp.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/sample_resize_policy.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/sample_resize_trigger.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/hash_load_check_resize_trigger_size_base.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/hash_exponential_size_policy_imp.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/hash_load_check_resize_trigger_imp.hpp: Same.
+       * include/ext/pb_ds/detail/resize_policy/hash_standard_resize_policy_imp.hpp: Same.
+       * include/ext/pb_ds/detail/container_base_dispatch.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_: New.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/erase_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/cmp_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/insert_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/resize_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/insert_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/entry_list_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/find_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/resize_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/cc_ht_map_.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/debug_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/cond_key_dtor_entry_dealtor.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/debug_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/erase_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/size_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/standard_policies.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/cc_hash_table_map_/resize_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/typelist_assoc_container.hpp: Same.
+       * include/ext/pb_ds/detail/tree_trace_base.hpp: Same.
+       * include/ext/pb_ds/detail/unordered_iterator: New.
+       * include/ext/pb_ds/detail/unordered_iterator/iterator.hpp: Same.
+       * include/ext/pb_ds/detail/unordered_iterator/const_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/unordered_iterator/point_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/unordered_iterator/const_point_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/typelist.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_: New.
+       * include/ext/pb_ds/detail/pat_trie_/r_erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/child_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/update_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/insert_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/head.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/const_child_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/split_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/traits.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/leaf.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/rotate_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/node_base.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/node_metadata_base.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/synth_e_access_traits.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/node_iterators.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/internal_node.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/point_iterators.hpp: Same.
+       * include/ext/pb_ds/detail/pat_trie_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_: New.
+       * include/ext/pb_ds/detail/bin_search_tree_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/r_erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/cond_dtor_entry_dealtor.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/traits.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/rotate_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/bin_search_tree_.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/cond_key_dtor_entry_dealtor.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/node_iterators.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/point_iterators.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/bin_search_tree_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_: New.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/erase_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/insert_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/resize_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/gp_ht_map_.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/insert_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/iterator_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/find_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/find_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/resize_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/debug_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/debug_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/erase_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/standard_policies.hpp: Same.
+       * include/ext/pb_ds/detail/gp_hash_table_map_/resize_no_store_hash_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/standard_policies.hpp: Same.
+       * include/ext/pb_ds/detail/typelist: New.
+       * include/ext/pb_ds/detail/typelist/typelist_flatten.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_contains.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_typelist_append.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_apply.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_filter.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_append.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_assoc_container_find.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_transform.hpp: Same.
+       * include/ext/pb_ds/detail/typelist/typelist_at_index.hpp: Same.
+       * include/ext/pb_ds/detail/tree_policy: New.
+       * include/ext/pb_ds/detail/tree_policy/order_statistics_imp.hpp: Same.
+       * include/ext/pb_ds/detail/tree_policy/node_metadata_selector.hpp: Same.
+       * include/ext/pb_ds/detail/tree_policy/null_node_update_imp.hpp: Same.
+       * include/ext/pb_ds/detail/tree_policy/sample_tree_node_update.hpp: Same.
+       * include/ext/pb_ds/detail/basic_tree_policy: New.
+       * include/ext/pb_ds/detail/basic_tree_policy/basic_tree_policy_base.hpp: Same.
+       * include/ext/pb_ds/detail/basic_tree_policy/null_node_metadata.hpp: Same.
+       * include/ext/pb_ds/detail/basic_tree_policy/traits.hpp: Same.
+       * include/ext/pb_ds/detail/types_traits.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_: New.
+       * include/ext/pb_ds/detail/binary_heap_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/const_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/entry_cmp.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/const_point_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/entry_pred.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/resize_policy.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/binary_heap_.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binary_heap_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy: New.
+       * include/ext/pb_ds/detail/trie_policy/string_trie_e_access_traits_imp.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/order_statistics_imp.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/sample_trie_node_update.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/trie_policy_base.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/prefix_search_node_update_imp.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/sample_trie_e_access_traits.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/node_metadata_selector.hpp: Same.
+       * include/ext/pb_ds/detail/trie_policy/null_node_update_imp.hpp: Same.
+       * include/ext/pb_ds/detail/cond_dealtor.hpp: Same.
+       * include/ext/pb_ds/detail/priority_queue_base_dispatch.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_: Name.
+       * include/ext/pb_ds/detail/pairing_heap_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_/pairing_heap_.hpp: Same.
+       * include/ext/pb_ds/detail/pairing_heap_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_: New.
+       * include/ext/pb_ds/detail/binomial_heap_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/binomial_heap_/binomial_heap_.hpp: Same.
+       * include/ext/pb_ds/detail/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/type_utils.hpp: Same.
+       * include/ext/pb_ds/detail/eq_fn: New.
+       * include/ext/pb_ds/detail/eq_fn/hash_eq_fn.hpp: Same.
+       * include/ext/pb_ds/detail/eq_fn/eq_by_less.hpp: Same.
+       * include/ext/pb_ds/detail/basic_types.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_policy: New.
+       * include/ext/pb_ds/detail/list_update_policy/mtf_lu_policy_imp.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_policy/counter_lu_metadata.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_policy/sample_update_policy.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_policy/counter_lu_policy_imp.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_: New.
+       * include/ext/pb_ds/detail/thin_heap_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/thin_heap_.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/thin_heap_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_: New.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/null_metadata.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/left_child_next_sibling_heap_.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/const_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/node.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/left_child_next_sibling_heap_/const_point_iterator.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_: New.
+       * include/ext/pb_ds/detail/ov_tree_map_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/policy_access_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/cond_dtor.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/ov_tree_map_.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/node_iterators.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/traits.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/ov_tree_map_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/map_debug_base.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn: New.
+       * include/ext/pb_ds/detail/hash_fn/linear_probe_fn_imp.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/mod_based_range_hashing.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/ranged_probe_fn.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/sample_probe_fn.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/direct_mod_range_hashing_imp.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/sample_ranged_probe_fn.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/quadratic_probe_fn_imp.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/sample_range_hashing.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/probe_fn_base.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/ranged_hash_fn.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/mask_based_range_hashing.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/sample_ranged_hash_fn.hpp: Same.
+       * include/ext/pb_ds/detail/hash_fn/direct_mask_range_hashing_imp.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_: New.
+       * include/ext/pb_ds/detail/splay_tree_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/splay_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/node.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/splay_tree_.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/traits.hpp: Same.
+       * include/ext/pb_ds/detail/splay_tree_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_: New.
+       * include/ext/pb_ds/detail/list_update_map_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/entry_metadata_base.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/lu_map_.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/constructor_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/list_update_map_/iterators_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_: New.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/trace_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/rc_binomial_heap_.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/rc.hpp: Same.
+       * include/ext/pb_ds/detail/rc_binomial_heap_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_: New.
+       * include/ext/pb_ds/detail/rb_tree_map_/erase_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/find_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/insert_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/rb_tree_.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/debug_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/constructors_destructor_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/node.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/split_join_fn_imps.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/traits.hpp: Same.
+       * include/ext/pb_ds/detail/rb_tree_map_/info_fn_imps.hpp: Same.
+       * include/ext/pb_ds/list_update_policy.hpp: Same.
+       * include/ext/pb_ds/exception.hpp: Same.
+       * include/ext/pb_ds/tree_policy.hpp: Same.
+       * include/ext/pb_ds/tag_and_trait.hpp: Same.
+       * include/ext/pb_ds/hash_policy.hpp: Same.
+       * include/ext/pb_ds/trie_policy.hpp: Same.
+       * include/ext/pb_ds/priority_queue.hpp: Same.
+
+       * docs/html/ext/pb_ds: New.
+       * docs/html/ext/pb_ds/container_tag.html: Same.
+       * docs/html/ext/pb_ds/trivial_iterator_tag.html: Same.
+       * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_local.png
+       * docs/html/ext/pb_ds/sample_trie_e_access_traits.html: Same.
+       * docs/html/ext/pb_ds/gp_hash_table.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_tag_cd.svg
+       * docs/html/ext/pb_ds/container_cd.svg
+       * docs/html/ext/pb_ds/linear_probe_fn.html: Same.
+       * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_local.png
+       * docs/html/ext/pb_ds/quadratic_probe_fn.html: Same.
+       * docs/html/ext/pb_ds/assoc_regression_tests.html: Same.
+       * docs/html/ext/pb_ds/tree_tag.html: Same.
+       * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test.html: Same.
+       * docs/html/ext/pb_ds/interface.html: Same.
+       * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_msvc.png
+       * docs/html/ext/pb_ds/hash_random_int_subscript_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/lu_based_containers.html: Same.
+       * docs/html/ext/pb_ds/embedded_lists_3.png
+       * docs/html/ext/pb_ds/tree_text_find_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_local.png
+       * docs/html/ext/pb_ds/assoc_performance_tests.html: Same.
+       * docs/html/ext/pb_ds/list_update.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_gcc.png
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_local.png
+       * docs/html/ext/pb_ds/point_iterators_range_ops_1.png
+       * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_msvc.png
+       * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_gcc.png
+       * docs/html/ext/pb_ds/text_find_timing_test_tree_like_msvc.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_local.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_local.png
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test.html: Same.
+       * docs/html/ext/pb_ds/move_to_front_lu_policy.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_gcc.png
+       * docs/html/ext/pb_ds/hash_random_int_find_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/string_trie_e_access_traits.html: Same.
+       * docs/html/ext/pb_ds/prerequisites.html: Same.
+       * docs/html/ext/pb_ds/gp_hash_tag.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_tag_cd.png
+       * docs/html/ext/pb_ds/container_cd.png
+       * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_gcc.png
+       * docs/html/ext/pb_ds/container_base.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_msvc.png
+       * docs/html/ext/pb_ds/tree_random_int_find_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_msvc.png
+       * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_local.png
+       * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_gcc.png
+       * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_msvc.png
+       * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_msvc.png
+       * docs/html/ext/pb_ds/text_find_timing_test_hash_local.png
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_msvc.png
+       * docs/html/ext/pb_ds/ov_tree_tag.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_local.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_msvc.png
+       * docs/html/ext/pb_ds/list_update_tag.html: Same.
+       * docs/html/ext/pb_ds/balls_and_bins.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_local.png
+       * docs/html/ext/pb_ds/disclaimer.html: Same.
+       * docs/html/ext/pb_ds/insert_error.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_gcc.png
+       * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_gcc.png
+       * docs/html/ext/pb_ds/examples.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small.html: Same.
+       * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_gcc.png
+       * docs/html/ext/pb_ds/sample_probe_fn.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_local.png
+       * docs/html/ext/pb_ds/priority_queue_text_push_timing_test.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_gcc.png
+       * docs/html/ext/pb_ds/null_mapped_type.html: Same.
+       * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_gcc.png
+       * docs/html/ext/pb_ds/tree_order_statistics_timing_test_gcc.png
+       * docs/html/ext/pb_ds/associative_container_tag.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_local.png
+       * docs/html/ext/pb_ds/design.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_max_collision_check_resize_trigger.html: Same.
+       * docs/html/ext/pb_ds/pairing_heap_tag.html: Same.
+       * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_gcc.png
+       * docs/html/ext/pb_ds/references.html: Same.
+       * docs/html/ext/pb_ds/tree_order_statistics_timing_test_msvc.png
+       * docs/html/ext/pb_ds/hash_load_check_resize_trigger.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_gcc.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_gcc.png
+       * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_gcc.png
+       * docs/html/ext/pb_ds/pq_different_underlying_dss.png
+       * docs/html/ext/pb_ds/insert_resize_sequence_diagram1.png
+       * docs/html/ext/pb_ds/pq_regression_tests.html: Same.
+       * docs/html/ext/pb_ds/sample_tree_node_update.html: Same.
+       * docs/html/ext/pb_ds/invalidation_guarantee_erase.png
+       * docs/html/ext/pb_ds/basic_invalidation_guarantee.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_local.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_gcc.png
+       * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_local.png
+       * docs/html/ext/pb_ds/point_iterators_range_ops_2.png
+       * docs/html/ext/pb_ds/null_probe_fn.html: Same.
+       * docs/html/ext/pb_ds/hash_prime_size_policy.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_gcc.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_local.png
+       * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_local.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_msvc.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_gcc.png
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large.html: Same.
+       * docs/html/ext/pb_ds/sample_resize_policy.html: Same.
+       * docs/html/ext/pb_ds/binomial_heap_tag.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_local.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_local.png
+       * docs/html/ext/pb_ds/tree_text_lor_find_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_msvc.png
+       * docs/html/ext/pb_ds/trie_based_containers.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_gcc.png
+       * docs/html/ext/pb_ds/tree_split_join_timing_test_local.png
+       * docs/html/ext/pb_ds/text_find_timing_test_hash_gcc.png
+       * docs/html/ext/pb_ds/motivation.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_msvc.png
+       * docs/html/ext/pb_ds/tree_split_join_timing_test_gcc.png
+       * docs/html/ext/pb_ds/tree.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_gcc.png
+       * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_msvc.png
+       * docs/html/ext/pb_ds/invalidation_guarantee_cd.png
+       * docs/html/ext/pb_ds/tutorial.html: Same.
+       * docs/html/ext/pb_ds/null_trie_node_update.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_gcc.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_msvc.png
+       * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_local.png
+       * docs/html/ext/pb_ds/point_iterators_cd.png
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_local.png
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_local.png
+       * docs/html/ext/pb_ds/rb_tree_tag.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_msvc.png
+       * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_msvc.png
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_gcc.png
+       * docs/html/ext/pb_ds/exceptions.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_msvc.png
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_local.png
+       * docs/html/ext/pb_ds/hash_policy_cd.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_gcc.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small.html: Same.
+       * docs/html/ext/pb_ds/ds_gen.html: Same.
+       * docs/html/ext/pb_ds/hash_exponential_size_policy.html: Same.
+       * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_local.png
+       * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_msvc.png
+       * docs/html/ext/pb_ds/index.html: Same.
+       * docs/html/ext/pb_ds/binary_heap_tag.html: Same.
+       * docs/html/ext/pb_ds/basic_hash_tag.html: Same.
+       * docs/html/ext/pb_ds/trie_order_statistics_node_update.html: Same.
+       * docs/html/ext/pb_ds/sample_resize_trigger.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_local.png
+       * docs/html/ext/pb_ds/hash_text_find_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test.html: Same.
+       * docs/html/ext/pb_ds/trie_tag.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_local.png
+       * docs/html/ext/pb_ds/pq_tests.html: Same.
+       * docs/html/ext/pb_ds/insert_resize_sequence_diagram2.png
+       * docs/html/ext/pb_ds/node_invariant_invalidations.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_msvc.png
+       * docs/html/ext/pb_ds/resize_policy_cd.png
+       * docs/html/ext/pb_ds/embedded_lists_1.png
+       * docs/html/ext/pb_ds/hash_ranged_hash_range_hashing_fns.png
+       * docs/html/ext/pb_ds/null_lu_metadata.html: Same.
+       * docs/html/ext/pb_ds/tree_order_statistics_timing_test.html: Same.
+       * docs/html/ext/pb_ds/trie_prefix_search_node_update.html: Same.
+       * docs/html/ext/pb_ds/hash_range_hashing_seq_diagram.png
+       * docs/html/ext/pb_ds/point_invalidation_guarantee.html: Same.
+       * docs/html/ext/pb_ds/direct_mod_range_hashing.html: Same.
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_local.png
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_msvc.png
+       * docs/html/ext/pb_ds/misc.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_local.png
+       * docs/html/ext/pb_ds/counter_lu_policy.html: Same.
+       * docs/html/ext/pb_ds/different_underlying_dss.png
+       * docs/html/ext/pb_ds/restoring_node_invariants.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large.html: Same.
+       * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_local.png
+       * docs/html/ext/pb_ds/sample_update_policy.html: Same.
+       * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_gcc.png
+       * docs/html/ext/pb_ds/tree_order_statistics_timing_test_local.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_msvc.png
+       * docs/html/ext/pb_ds/simple_list.png
+       * docs/html/ext/pb_ds/text_find_timing_test_hash_msvc.png
+       * docs/html/ext/pb_ds/assoc_examples.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_local.png
+       * docs/html/ext/pb_ds/hash_based_containers.html: Same.
+       * docs/html/ext/pb_ds/text_find_timing_test_tree_like_local.png
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_local.png
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_gcc.png
+       * docs/html/ext/pb_ds/tree_node_iterator.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_msvc.png
+       * docs/html/ext/pb_ds/trie_node_iterator.html: Same.
+       * docs/html/ext/pb_ds/tree_based_containers.html: Same.
+       * docs/html/ext/pb_ds/hash_random_int_subscript_insert_timing_test.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_msvc.png
+       * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_msvc.png
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_gcc.png
+       * docs/html/ext/pb_ds/rationale_null_node_updator.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_local.png
+       * docs/html/ext/pb_ds/lu.png
+       * docs/html/ext/pb_ds/assoc_container_traits.html: Same.
+       * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_msvc.png
+       * docs/html/ext/pb_ds/assoc_design.html: Same.
+       * docs/html/ext/pb_ds/splay_tree_tag.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_gcc.png
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test.html: Same.
+       * docs/html/ext/pb_ds/assoc_container_tag_cd.svg
+       * docs/html/ext/pb_ds/resize_error.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_msvc.png
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_gcc.png
+       * docs/html/ext/pb_ds/priority_queue_text_join_timing_test.html: Same.
+       * docs/html/ext/pb_ds/basic_tree_assoc_container_const_node_iterator.html: Same.
+       * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_gcc.png
+       * docs/html/ext/pb_ds/trie_const_node_iterator.html: Same.
+       * docs/html/ext/pb_ds/hash_zlob_random_int_find_find_timing_test.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_gcc.png
+       * docs/html/ext/pb_ds/sample_size_policy.html: Same.
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_gcc.png
+       * docs/html/ext/pb_ds/cc_hash_table.html: Same.
+       * docs/html/ext/pb_ds/node_invariants.png
+       * docs/html/ext/pb_ds/tree_split_join_timing_test_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test.html: Same.
+       * docs/html/ext/pb_ds/tree_order_statistics_node_update.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_msvc.png
+       * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_local.png
+       * docs/html/ext/pb_ds/priority_queue.html: Same.
+       * docs/html/ext/pb_ds/assoc_tests.html: Same.
+       * docs/html/ext/pb_ds/assoc_container_tag_cd.png
+       * docs/html/ext/pb_ds/basic_hash_table.html: Same.
+       * docs/html/ext/pb_ds/basic_tree_tag.html: Same.
+       * docs/html/ext/pb_ds/tree_split_join_timing_test.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_local.png
+       * docs/html/ext/pb_ds/insert_resize_sequence_diagram3.png
+       * docs/html/ext/pb_ds/embedded_lists_2.png
+       * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_local.png
+       * docs/html/ext/pb_ds/sample_ranged_probe_fn.html: Same.
+       * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_gcc.png
+       * docs/html/ext/pb_ds/sample_trie_node_update.html: Same.
+       * docs/html/ext/pb_ds/introduction.html: Same.
+       * docs/html/ext/pb_ds/pq_performance_tests.html: Same.
+       * docs/html/ext/pb_ds/pat_trie.png
+       * docs/html/ext/pb_ds/range_invalidation_guarantee.html: Same.
+       * docs/html/ext/pb_ds/contact.html: Same.
+       * docs/html/ext/pb_ds/sample_range_hashing.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_local.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_gcc.png
+       * docs/html/ext/pb_ds/update_seq_diagram.png
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_gcc.png
+       * docs/html/ext/pb_ds/direct_mask_range_hashing.html: Same.
+       * docs/html/ext/pb_ds/tests.html: Same.
+       * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_gcc.png
+       * docs/html/ext/pb_ds/tree_node_updator_policy_cd.png
+       * docs/html/ext/pb_ds/text_find_timing_test_tree_like_gcc.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large.html: Same.
+       * docs/html/ext/pb_ds/trie_node_updator_policy_cd.png
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_msvc.png
+       * docs/html/ext/pb_ds/concepts.html: Same.
+       * docs/html/ext/pb_ds/pq_examples.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_tag.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test.html: Same.
+       * docs/html/ext/pb_ds/update_policy_cd.png
+       * docs/html/ext/pb_ds/thin_heap_tag.html: Same.
+       * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_msvc.png
+       * docs/html/ext/pb_ds/basic_tree.html: Same.
+       * docs/html/ext/pb_ds/null_hash_fn.html: Same.
+       * docs/html/ext/pb_ds/null_tree_node_update.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_gcc.png
+       * docs/html/ext/pb_ds/trie.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_msvc.png
+       * docs/html/ext/pb_ds/rc_binomial_heap_tag.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_msvc.png
+       * docs/html/ext/pb_ds/pq_container_traits.html: Same.
+       * docs/html/ext/pb_ds/pq_design.html: Same.
+       * docs/html/ext/pb_ds/checked_by_tidy.gif
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_local.png
+       * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_gcc.png
+       * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_gcc.png
+       * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_local.png
+       * docs/html/ext/pb_ds/acks.html: Same.
+       * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_local.png
+       * docs/html/ext/pb_ds/cc_hash_tag.html: Same.
+       * docs/html/ext/pb_ds/sample_ranged_hash_fn.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_msvc.png
+       * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test.html: Same.
+       * docs/html/ext/pb_ds/multimap_text_find_timing_test_small.html: Same.
+       * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_msvc.png
+       * docs/html/ext/pb_ds/hash_range_hashing_seq_diagram2.png
+       * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_msvc.png
+       * docs/html/ext/pb_ds/PythonPoweredSmall.gif
+       * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_local.png
+       * docs/html/ext/pb_ds/pat_trie_tag.html: Same.
+       * docs/html/ext/pb_ds/hash_standard_resize_policy.html: Same.
+       * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_msvc.png
+       * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_gcc.png
+       * docs/html/ext/pb_ds/join_error.html: Same.
+       * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_gcc.png
+       * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_local.png
+
+       * testsuite/ext/pb_ds: New.
+       * testsuite/ext/pb_ds/regression: New.
+       * testsuite/ext/pb_ds/regression/trie_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/hash_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/associative_containers.cc: Same.
+       * testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/priority_queues.cc: Same.
+       * testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/priority_queue_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/regression/tree_data_map_rand.cc: Same.
+       * testsuite/ext/pb_ds/example: New.
+       * testsuite/ext/pb_ds/example/hash_shift_mask.cc: Same.
+       * testsuite/ext/pb_ds/example/basic_set.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_illegal_resize.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_resize_neg.cc: Same.
+       * testsuite/ext/pb_ds/example/store_hash.cc: Same.
+       * testsuite/ext/pb_ds/example/assoc_container_traits.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_load_set_change.cc: Same.
+       * testsuite/ext/pb_ds/example/ranged_hash.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_resize.cc: Same.
+       * testsuite/ext/pb_ds/example/tree_order_statistics.cc: Same.
+       * testsuite/ext/pb_ds/example/trie_prefix_search.cc: Same.
+       * testsuite/ext/pb_ds/example/basic_multiset.cc: Same.
+       * testsuite/ext/pb_ds/example/priority_queue_xref.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_find_neg.cc: Same.
+       * testsuite/ext/pb_ds/example/erase_if.cc: Same.
+       * testsuite/ext/pb_ds/example/priority_queue_container_traits.cc: Same.
+       * testsuite/ext/pb_ds/example/tree_join.cc: Same.
+       * testsuite/ext/pb_ds/example/basic_map.cc: Same.
+       * testsuite/ext/pb_ds/example/trie_split.cc: Same.
+       * testsuite/ext/pb_ds/example/priority_queue_split_join.cc: Same.
+       * testsuite/ext/pb_ds/example/priority_queue_dijkstra.cc: Same.
+       * testsuite/ext/pb_ds/example/priority_queue_erase_if.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_mod.cc: Same.
+       * testsuite/ext/pb_ds/example/tree_order_statistics_join.cc: Same.
+       * testsuite/ext/pb_ds/example/trie_dna.cc: Same.
+       * testsuite/ext/pb_ds/example/hash_initial_size.cc: Same.
+       * testsuite/ext/pb_ds/example/basic_priority_queue.cc: Same.
+       * testsuite/ext/pb_ds/example/tree_intervals.cc: Same.
+       * testsuite/ext/pb_ds/example/basic_multimap.cc: Same.
+       * testsuite/performance/ext: New.
+       * testsuite/performance/ext/pb_ds: New.
+       * testsuite/performance/ext/pb_ds/multimap_text_find_timing_small.cc: Same.
+       * testsuite/performance/ext/pb_ds/text_find_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/hash_random_int_erase_mem_usage.cc: Same.
+       * testsuite/performance/ext/pb_ds/tree_text_insert_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_modify_down_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/random_int_subscript_find_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_push_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/tree_split_join_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/random_int_find_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_insert_timing_large.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage.hpp: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_random_int_push_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_find_timing.hpp: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_modify_timing.hpp: Same.
+       * testsuite/performance/ext/pb_ds/tree_order_statistics_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_modify_up_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage_large.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_push_pop_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_find_timing_large.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_join_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_insert_timing_small.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_random_int_push_pop_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/random_int_subscript_insert_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/tree_text_lor_find_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/priority_queue_text_pop_mem_usage.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_insert_timing.hpp: Same.
+       * testsuite/performance/ext/pb_ds/hash_zlob_random_int_find_timing.cc: Same.
+       * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage_small.cc: Same.
+       * testsuite/data/make_graph_test_infos.xml: Same.
+       * testsuite/data/thirty_years_among_the_dead_preproc.txt: New.
+       * testsuite/data/make_graph_htmls.xml: Same.
+       * testsuite/util/regression: New.
+       * testsuite/util/regression/trait: New.
+       * testsuite/util/regression/trait/priority_queue: New.
+       * testsuite/util/regression/trait/priority_queue/trait.hpp: Same.
+       * testsuite/util/regression/trait/erase_if_fn.hpp: Same.
+       * testsuite/util/regression/trait/assoc: New.
+       * testsuite/util/regression/trait/assoc/native_type_trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/node_update_trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/get_set_load_trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/get_set_loads_trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/type_trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/resize_trait.hpp: Same.
+       * testsuite/util/regression/trait/assoc/to_string.hpp: Same.
+       * testsuite/util/regression/rand: New.
+       * testsuite/util/regression/rand/priority_queue: New.
+       * testsuite/util/regression/rand/priority_queue/detail: New.
+       * testsuite/util/regression/rand/priority_queue/detail/erase_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/cmp_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/policy_access_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/defs_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/it_conversion_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/constructor_destructor_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/diagnostic_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/insert_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/clear_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/modify_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/split_join_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/detail/operator_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/rand_regression_test.hpp: Same.
+       * testsuite/util/regression/rand/priority_queue/container_rand_regression_test.hpp: Same.
+       * testsuite/util/regression/rand/io: New.
+       * testsuite/util/regression/rand/io/priority_queue: New.
+       * testsuite/util/regression/rand/io/priority_queue/xml_formatter.hpp: Same.
+       * testsuite/util/regression/rand/io/assoc: New.
+       * testsuite/util/regression/rand/io/assoc/xml_formatter.hpp: Same.
+       * testsuite/util/regression/rand/io/xml_formatter.hpp: Same.
+       * testsuite/util/regression/rand/assoc: New.
+       * testsuite/util/regression/rand/assoc/detail: New.
+       * testsuite/util/regression/rand/assoc/detail/subscript_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/cmp_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/policy_access_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/defs_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/it_conversion_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/diagnostic_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/clear_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/get_set_load_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/operator_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/erase_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/resize_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/constructor_destructor_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/insert_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/split_join_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/detail/get_set_loads_fn_imps.hpp: Same.
+       * testsuite/util/regression/rand/assoc/rand_regression_test.hpp: Same.
+       * testsuite/util/regression/rand/assoc/container_rand_regression_test.hpp: Same.
+       * testsuite/util/regression/priority_queue: New.
+       * testsuite/util/regression/priority_queue/common_type.hpp: Same.
+       * testsuite/util/regression/basic_type.hpp: Same.
+       * testsuite/util/regression/assoc: New.
+       * testsuite/util/regression/assoc/common_type.hpp: Same.
+       * testsuite/util/regression/res_mng: New.
+       * testsuite/util/regression/res_mng/forced_exception.hpp: Same.
+       * testsuite/util/regression/res_mng/dbg_ex_allocator_base.cc: Same.
+       * testsuite/util/regression/res_mng/dbg_ex_allocator_base.hpp: Same.
+       * testsuite/util/regression/res_mng/dbg_ex_allocator.hpp: Same.
+       * testsuite/util/rng: New.
+       * testsuite/util/rng/twister_rand_gen.cc: Same.
+       * testsuite/util/rng/twister_rand_gen.hpp: Same.
+       * testsuite/util/native_type: New.
+       * testsuite/util/native_type/priority_queue: New.
+       * testsuite/util/native_type/priority_queue/native_priority_queue.hpp: Same.
+       * testsuite/util/native_type/priority_queue/native_pq_tag.hpp: Same.
+       * testsuite/util/native_type/assoc: New.
+       * testsuite/util/native_type/assoc/native_multimap.hpp: Same.
+       * testsuite/util/native_type/assoc/native_tree_tag.hpp: Same.
+       * testsuite/util/native_type/assoc/native_set.hpp: Same.
+       * testsuite/util/native_type/assoc/native_hash_multimap.hpp: Same.
+       * testsuite/util/native_type/assoc/native_map.hpp: Same.
+       * testsuite/util/native_type/assoc/native_hash_tag.hpp: Same.
+       * testsuite/util/native_type/assoc/native_hash_set.hpp: Same.
+       * testsuite/util/native_type/assoc/native_hash_map.hpp: Same.
+       * testsuite/util/common_type: New.
+       * testsuite/util/common_type/priority_queue
+       * testsuite/util/common_type/priority_queue/common_type.hpp: Same.
+       * testsuite/util/common_type/priority_queue/string_form.hpp: Same.
+       * testsuite/util/common_type/priority_queue/detail
+       * testsuite/util/common_type/priority_queue/detail/ds_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc: New.
+       * testsuite/util/common_type/assoc/common_type.hpp: Same.
+       * testsuite/util/common_type/assoc/string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/template_policy.hpp: Same.
+       * testsuite/util/common_type/assoc/detail: New.
+       * testsuite/util/common_type/assoc/detail/resize_policy_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/trigger_policy_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/ds_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/comb_hash_fn_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/size_policy_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/probe_fn_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/tree_supports_order_statistics.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/trie_supports_prefix_search.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/list_update_policy_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/trie_supports_order_statistics.hpp: Same.
+       * testsuite/util/common_type/assoc/detail/store_hash_string_form.hpp: Same.
+       * testsuite/util/common_type/assoc/native_set.hpp: Same.
+       * testsuite/util/performance: New.
+       * testsuite/util/performance/priority_queue: New.
+       * testsuite/util/performance/priority_queue/mem_usage: New.
+       * testsuite/util/performance/priority_queue/mem_usage/pop_test.hpp: Same.
+       * testsuite/util/performance/priority_queue/timing: New.
+       * testsuite/util/performance/priority_queue/timing/push_pop_test.hpp: Same.
+       * testsuite/util/performance/priority_queue/timing/push_test.hpp: Same.
+       * testsuite/util/performance/priority_queue/timing/join_test.hpp: Same.
+       * testsuite/util/performance/priority_queue/timing/modify_test.hpp: Same.
+       * testsuite/util/performance/io: New.
+       * testsuite/util/performance/io/xml_formatter.hpp: Same.
+       * testsuite/util/performance/assoc: New.
+       * testsuite/util/performance/assoc/mem_usage: New.
+       * testsuite/util/performance/assoc/mem_usage/multimap_insert_test.hpp: Same.
+       * testsuite/util/performance/assoc/mem_usage/erase_test.hpp: Same.
+       * testsuite/util/performance/assoc/multimap_common_type.hpp: Same.
+       * testsuite/util/performance/assoc/timing: New.
+       * testsuite/util/performance/assoc/timing/common_type.hpp: Same.
+       * testsuite/util/performance/assoc/timing/multimap_insert_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/subscript_find_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/find_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/subscript_insert_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/insert_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/tree_order_statistics_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/multimap_find_test.hpp: Same.
+       * testsuite/util/performance/assoc/timing/tree_split_join_test.hpp: Same.
+       * testsuite/util/performance/time: New.
+       * testsuite/util/performance/time/elapsed_timer.cc: Same.
+       * testsuite/util/performance/time/elapsed_timer.hpp: Same.
+       * testsuite/util/performance/time/timing_test_base.hpp: Same.
+       * testsuite/util/performance/mem: New.
+       * testsuite/util/performance/mem/mem_track_allocator_base.hpp: Same.
+       * testsuite/util/performance/mem/mem_track_allocator.hpp: Same.
+       * testsuite/util/hash_fn: New.
+       * testsuite/util/hash_fn/limit_string_hash_fn.hpp: Same.
+       * testsuite/util/hash_fn/string_ranged_hash_fn.hpp: Same.
+       * testsuite/util/hash_fn/string_hash_fn.hpp: Same.
+       * testsuite/util/hash_fn/string_ranged_probe_fn.hpp: Same.
+       * testsuite/util/hash_fn/dna_str_limit.hpp: Same.
+       * testsuite/util/io: New.
+       * testsuite/util/io/prog_bar.cc: Same.
+       * testsuite/util/io/prog_bar.hpp: Same.
+       * testsuite/util/io/text_populate.hpp: Same.
+       * testsuite/util/io/xml.hpp: Same.
+       * testsuite/util/io/illegal_input_error.hpp: Same.
+       * testsuite/util/io/xml_test_formatter.hpp: Same.
+       * testsuite/util/io/verified_cmd_line_input.cc: Same.
+       * testsuite/util/io/verified_cmd_line_input.hpp: Same.
+       * testsuite/util/statistic: New.
+       * testsuite/util/statistic/sample_var.hpp: Same.
+       * testsuite/util/statistic/res_recorder.hpp: Same.
+       * testsuite/util/statistic/sample_mean.hpp: Same.
+       * testsuite/util/statistic/sample_mean_confidence_checker.hpp: Same.
+       
+2006-06-12  Paolo Carlini  <pcarlini@suse.de>
+
+       PR libstdc++/26970
+       * config/locale/gnu/c_locale.h (__convert_from_v<>): Change to
+       variadic function, instead of template function.
+       * config/locale/generic/c_locale.h (__convert_from_v<>): Likewise.
+       * include/bits/locale_facets.tcc (num_put<>::_M_insert_float):
+       Adjust.
+       (money_put<>::do_put(long double)): Likewise.
+       * src/locale-misc-inst.cc: Remove.
+       * src/Makefile.am: Adjust.
+       * src/Makefile.in: Regenerate.
+
+2006-06-09  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (random_device::random_device(const
+       std::string& = "/dev/urandom")): Open in binary mode.
+
+       * include/tr1/random (random_device::random_device(const
+       std::string& = "rand")): Use mersenne_twister.
+       (random_device::_M_strtoul): New.
+       (random_device::operator()()): Update.
+
+       * include/tr1/random: Minor stylistic changes, consistently
+       qualify with std::.
+
+2006-06-09  Paolo Carlini  <pcarlini@suse.de>
+
+       * acinclude.m4 ([GLIBCXX_CHECK_RANDOM_TR1]): New, check for
+       the availability of "/dev/random" and "/dev/urandom".
+       * configure.ac: Use it.
+       * include/tr1/random (random_device): Implement, a fall-back for
+       systems not providing "/dev/random" and "/dev/urandom" included.
+       * testsuite/tr1/5_numerical_facilities/random/random_device/
+       cons/default.cc: New.
+       * testsuite/tr1/5_numerical_facilities/random/random_device/
+       cons/token.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/random_device/
+       requirements/typedefs.cc: Likewise.
+       * config.h.in: Regenerate.
+       * configure: Likewise.
+
+       * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
+       cons/gen1.cc: Minor tweak, add bool test.
+
+2006-06-06  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * testsuite/util: New directory.
+       * testsuite/testsuite_hooks.cc: Move to util sub-directory.
+       * testsuite/testsuite_abi_check.cc: Same.
+       * testsuite/testsuite_abi.cc: Same.
+       * testsuite/testsuite_tr1.h: Same.
+       * testsuite/testsuite_io.h: Same.
+       * testsuite/testsuite_iterators.h: Same.
+       * testsuite/testsuite_allocator.cc: Same.
+       * testsuite/testsuite_allocator.h: Same.
+       * testsuite/testsuite_hooks.h: Same.
+       * testsuite/testsuite_character.cc: Same.
+       * testsuite/testsuite_abi.h: Same.
+       * testsuite/testsuite_character.h: Same.
+       * testsuite/testsuite_visualization.h: Same.
+       * testsuite/testsuite_performance.h: Same.
+       * testsuite/testsuite_shared.cc: Same.
+       * testsuite/testsuite_common_types.h: Same.
+
+       * testsuite/lib/libstdc++.exp (v3-build_support): Adjust paths.
+       * testsuite/libstdc++-abi/abi.exp: Same.
+       * testsuite/libstdc++-dg/conformance.exp: Remove any files in the
+       utilities subdirectory from the list of test cases.
+       
+       * scripts/testsuite_flags.in (build-includes): Adjust path for
+       testsuite includes.
+       * scripts/create_testsuite_files (dlist): Don't let utility files
+       creep into the testsuite_files list.
+       
+2006-06-06  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (mersenne_twister<>::operator==,
+       operator!=, operator<<, operator>>): Implement.
+       * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
+       operators/equal.cc: New.        
+       * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
+       operators/not_equal.cc: Likewise.
+       * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
+       operators/serialize.cc: Likewise.
+
+       * include/tr1/random (subtract_with_carry<>::operator==): Fix,
+       compare the whole state; use std::equal.
+
+       * include/tr1/random: Minor formatting and style changes.
+
+2006-06-06  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * testsuite/tr1/5_numerical_facilies: Move to...
+       * testsuite/tr1/5_numerical_facilities: ...this.        
+
+2006-06-06  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random: Trivial uglification fixes.
+       * include/tr1/random.tcc: Likewise.
+
+       * include/tr1/random (subtract_with_carry<>::
+       subtract_with_carry(_IntType)): Fix parameter type to unsigned long.
+       (subtract_with_carry<>::seed(_IntType)): Likewise.
+       * include/tr1/random.tcc (subtract_with_carry<>::seed(_IntType)):
+       Adjust.
+
+2006-06-05  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/tr1/random (mersenne_twister<>::seed()): Fix per
+       tr1/5.1.4.2, p8.
+       * include/tr1/random.tcc (mod_w): Add.
+       (mersenne_twister<>::seed(unsigned long)): Fix per tr1/5.1.4.2, p9.
+       (mersenne_twister<>::seed(Gen&, false_type)): Adjust to use mod_w.
+       * testsuite/tr1/5_numerical_facilies/random/mt19937.cc: Fix
+       expected result per tr1/5.1.5, p2.
+       * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
+       cons/default.cc: Adjust.
+
+       * include/tr1/random (exponential_distribution<>::operator()()): Fix.
+
 2006-06-05  Paolo Carlini  <pcarlini@suse.de>
 
        * include/tr1/random.tcc (Max::value()): Cast 1 to Tp(1) and