aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3/ChangeLog-2018
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@gcc.gnu.org>2019-01-01 13:31:55 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2019-01-01 13:31:55 +0100
commita5544970246db337977bb8b69ab120e9ef209317 (patch)
tree91c8dfebf7c0b4945090e82c03dce7f5b6a987ec /libstdc++-v3/ChangeLog-2018
parentb5fcfdba9a81e15f7d85ce8a5240a4a8a2730b2b (diff)
downloadgcc-a5544970246db337977bb8b69ab120e9ef209317.zip
gcc-a5544970246db337977bb8b69ab120e9ef209317.tar.gz
gcc-a5544970246db337977bb8b69ab120e9ef209317.tar.bz2
Update copyright years.
From-SVN: r267494
Diffstat (limited to 'libstdc++-v3/ChangeLog-2018')
-rw-r--r--libstdc++-v3/ChangeLog-20186185
1 files changed, 6185 insertions, 0 deletions
diff --git a/libstdc++-v3/ChangeLog-2018 b/libstdc++-v3/ChangeLog-2018
new file mode 100644
index 0000000..1458251
--- /dev/null
+++ b/libstdc++-v3/ChangeLog-2018
@@ -0,0 +1,6185 @@
+2018-12-23 François Dumont <fdumont@gcc.gnu.org>
+
+ * libstdc++-v3/testsuite/util/testsuite_allocator.h
+ (CustomPointerAlloc<>::allocate(size_t, pointer)): Replace by...
+ (CustomPointerAlloc<>::allocate(size_t, const_void_pointer)): ...this.
+
+ Respect pointer_traits on node deallocation in _ReuseOrAllocNode
+ parenthesis operator.
+
+ * include/bits/hashtable_policy.h
+ (_Hashtable_alloc<>::_M_deallocate_node_ptr(__node_type*)): New.
+ (_Hashtable_alloc<>::_M_deallocate_node(__node_type*)): Use latter.
+ (_ReuseOrAllocNode<>::operator<_Arg>()(_Arg&&)): Likewise.
+
+2018-12-22 Iain Sandoe <iain@sandoe.co.uk>
+
+ * /config/os/bsd/darwin/ppc-extra.ver: Append long double symbols.
+
+2018-12-20 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/27_io/filesystem/operations/proximate.cc: Fix test for
+ MinGW.
+ * testsuite/27_io/filesystem/path/append/source.cc: Likewise.
+ * testsuite/27_io/filesystem/path/compare/lwg2936.cc: Likewise.
+
+ * testsuite/27_io/filesystem/directory_entry/lwg3171.cc: New test
+ (missed from previous commit).
+
+2018-12-19 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/xml/manual/abi.xml: Add missing word.
+
+2018-12-18 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/fs_dir.h (operator<<): Overload for directory_entry,
+ as per LWG 3171.
+ * testsuite/27_io/filesystem/directory_entry/lwg3171.cc: New test.
+
+ * src/filesystem/std-dir.cc (filesystem::_Dir::advance): Move new
+ path instead of copying.
+
+ * src/filesystem/std-dir.cc (filesystem::_Dir::advance): Append
+ string to lvalue to avoid creating temporary path.
+
+ * include/bits/fs_path.h (path::compare(const string_type&))
+ (path::compare(const value_type*)): Add noexcept and construct a
+ string view to compare to instead of a path.
+ (path::compare(basic_string_view<value_type>)): Add noexcept. Remove
+ inline definition.
+ * src/filesystem/std-path.cc (path::_Parser): Track last type read
+ from input.
+ (path::_Parser::next()): Return a final empty component when the
+ input ends in a non-root directory separator.
+ (path::_M_append(basic_string_view<value_type>)): Remove special cases
+ for trailing non-root directory separator.
+ (path::_M_concat(basic_string_view<value_type>)): Likewise.
+ (path::compare(const path&)): Implement LWG 2936.
+ (path::compare(basic_string_view<value_type>)): Define in terms of
+ components returned by parser, consistent with LWG 2936.
+ * testsuite/27_io/filesystem/path/compare/lwg2936.cc: New.
+ * testsuite/27_io/filesystem/path/compare/path.cc: Test more cases.
+ * testsuite/27_io/filesystem/path/compare/strings.cc: Likewise.
+
+ * include/std/string_view [__cplusplus > 201703L]
+ (basic_string_view::starts_with(basic_string_view)): Implement
+ proposed resolution of LWG 3040 to avoid redundant length check.
+ (basic_string_view::starts_with(_CharT)): Implement proposed
+ resolution of LWG 3040 to check at most one character.
+ (basic_string_view::ends_with(_CharT)): Likewise.
+
+2018-12-17 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/71044
+ * src/filesystem/std-path.cc (path::_M_append): Fix off-by-one error
+ that caused a component to be lost from the iteration sequence.
+ (path::_M_concat): Likewise.
+ * testsuite/27_io/filesystem/path/append/source.cc: Test appending
+ long strings.
+ * testsuite/27_io/filesystem/path/concat/strings.cc: Test
+ concatenating long strings.
+ * testsuite/27_io/filesystem/path/construct/string_view.cc: Test
+ construction from long string.
+
+2018-12-13 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/filesystem/std-path.cc (SLASHSLASH_IS_ROOT_NAME): New macro to
+ control whether interpret paths with two slashes as a root-name.
+ (path::operator/=(const path&)) [SLASHSLASH_IS_ROOT_NAME]: Add a
+ root-directory when appending to a root-name.
+ (path::_M_append(basic_string_view<value_type>))
+ [SLASHSLASH_IS_ROOT_NAME]: Likewise.
+ (path::operator/=(const path&)) [SLASHSLASH_IS_ROOT_NAME]: Likewise.
+ (path::_M_concat(basic_string_view<value_type>))
+ [SLASHSLASH_IS_ROOT_NAME]: Likewise.
+ (path::lexically_normal()) [SLASHSLASH_IS_ROOT_NAME]: Use += instead
+ of /= to add a root-directory to the result.
+ * testsuite/27_io/filesystem/path/decompose/root_directory.cc: Fix
+ expected result for Cygwin.
+
+ PR libstdc++/71044
+ * include/bits/fs_path.h (path::path(path&&)): Add noexcept when
+ appropriate. Move _M_cmpts instead of reparsing the native pathname.
+ (path::operator=(const path&)): Do not define as defaulted.
+ (path::operator/=, path::append): Call _M_append.
+ (path::concat): Call _M_concat.
+ (path::path(string_type, _Type): Change type of first parameter to
+ basic_string_view<value_type>.
+ (path::_M_append(basic_string_view<value_type>)): New member function.
+ (path::_M_concat(basic_string_view<value_type>)): New member function.
+ (_S_convert(value_type*, __null_terminated)): Return string view.
+ (_S_convert(const value_type*, __null_terminated)): Return string view.
+ (_S_convert(value_type*, value_type*))
+ (_S_convert(const value_type*, const value_type*)): Add overloads for
+ pairs of pointers.
+ (_S_convert(_InputIterator, __null_terminated)): Construct string_type
+ explicitly, for cases where _S_convert returns a string view.
+ (path::_S_is_dir_sep): Replace with non-member is_dir_sep.
+ (path::_M_trim, path::_M_add_root_name, path::_M_add_root_dir)
+ (path::_M_add_filename): Remove.
+ (path::_M_type()): New member function to replace _M_type data member.
+ (path::_List): Define new struct type instead of using std::vector.
+ (path::_Cmpt::_Cmpt(string_type, _Type, size_t)): Change type of
+ first parameter to basic_string_view<value_type>.
+ (path::operator+=(const path&)): Do not define inline.
+ (path::operator+=(const string_type&)): Call _M_concat.
+ (path::operator+=(const value_type*)): Likewise.
+ (path::operator+=(value_type)): Likewise.
+ (path::operator+=(basic_string_view<value_type>)): Likewise.
+ (path::operator/=(const path&)): Do not define inline.
+ (path::_M_append(path)): Remove.
+ * python/libstdcxx/v6/printers.py (StdPathPrinter): New printer that
+ understands the new path::_List type.
+ * src/filesystem/std-path.cc (is_dir_sep): New function to replace
+ path::_S_is_dir_sep.
+ (path::_Parser): New helper class to parse strings as paths.
+ (path::_List::_Impl): Define container type for path components.
+ (path::_List): Define members.
+ (path::operator=(const path&)): Define explicitly, to provide the
+ strong exception safety guarantee.
+ (path::operator/=(const path&)): Implement manually by processing
+ each component of the argument, rather than using _M_split_cmpts
+ to parse the entire string again.
+ (path::_M_append(string_type)): Likewise.
+ (path::operator+=(const path&)): Likewise.
+ (path::_M_concat(string_type)): Likewise.
+ (path::remove_filename()): Perform trim directly instead of calling
+ _M_trim().
+ (path::_M_split_cmpts()): Rewrite in terms of _Parser class.
+ (path::_M_trim, path::_M_add_root_name, path::_M_add_root_dir)
+ (path::_M_add_filename): Remove.
+ * testsuite/27_io/filesystem/path/append/source.cc: Test appending a
+ string view that aliases the path.
+ testsuite/27_io/filesystem/path/concat/strings.cc: Test concatenating
+ a string view that aliases the path.
+
+ * testsuite/27_io/filesystem/path/generation/proximate.cc: Use
+ preferred directory separators for normalized paths.
+ * testsuite/27_io/filesystem/path/generation/relative.cc: Likewise.
+
+ * testsuite/27_io/filesystem/path/itr/traversal.cc: Fix test for
+ mingw.
+
+ * testsuite/27_io/filesystem/path/construct/80762.cc: Skip test if
+ the Filesystem TS support is not configured.
+ * testsuite/experimental/filesystem/path/construct/80762.cc: Likewise.
+
+2018-12-12 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/71044 (partial)
+ * include/bits/fs_path.h (__path_iter_distance, __path_iter_advance):
+ New friend functions to implement std::distance and std::advance more
+ efficiently.
+ (distance, advance): Add overloads for path::iterator.
+ * testsuite/27_io/filesystem/path/itr/components.cc: Test new
+ overload.
+
+ PR libstdc++/80762
+ * include/bits/fs_path.h (path::_Path): Use remove_cv_t and is_void.
+ * include/experimental/bits/fs_path.h (path::_Path): Likewise.
+ * testsuite/27_io/filesystem/path/construct/80762.cc: New test.
+ * testsuite/experimental/filesystem/path/construct/80762.cc: New test.
+
+2018-12-12 Jakub Jelinek <jakub@redhat.com>
+
+ P0595R2 - is_constant_evaluated
+ * include/bits/c++config (_GLIBCXX_HAVE_BUILTIN_IS_CONSTANT_EVALUATED):
+ Define if __builtin_is_constant_evaluated is available.
+ * include/std/type_traits (std::is_constant_evaluated): New constexpr
+ inline function.
+ * testsuite/20_util/is_constant_evaluated/1.cc: New test.
+ * testsuite/20_util/is_constant_evaluated/noexcept.cc: New test.
+
+2018-12-10 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/documentation_hacking.xml: Update reference
+ to epubcheck.
+
+2018-12-10 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/experimental/filesystem/path/query/is_absolute.cc: Fix
+ test to use TS, not C++17.
+
+2018-12-06 Iain Sandoe <iain@sandoe.co.uk>
+
+ * scripts/make_exports.pl (check names): Don’t try to export
+ construction vtable symbols.
+
+2018-12-06 Jonathan Wakely <jwakely@redhat.com>
+ Iain Sandoe <iain@sandoe.co.uk>
+
+ PR libstdc++/64883
+ * testsuite/17_intro/headers/c++1998/all_attributes.cc: Don't test
+ always_inline on Darwin.
+ * testsuite/17_intro/headers/c++2011/all_attributes.cc: Likewise.
+ * testsuite/17_intro/headers/c++2014/all_attributes.cc: Likewise.
+ * testsuite/17_intro/headers/c++2017/all_attributes.cc: Likewise.
+ * testsuite/17_intro/headers/c++2020/all_attributes.cc: Likewise.
+
+2018-12-03 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ PR libstdc++/88341 - Complex norm doesn't compile with C++11
+ * include/std/complex (_S_do_it): Make C++20 constexpr.
+ * testsuite/26_numerics/complex/value_operations/pr88341.cc: New test.
+
+2018-11-30 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Implement P0457R2 String Prefix and Suffix Checking.
+ * include/bits/basic_string.h: Add starts_with, ends_with members.
+ * include/std/string_view: Ditto.
+ * testsuite/21_strings/basic_string/operations/starts_with/
+ char/1.cc: New test.
+ * testsuite/21_strings/basic_string/operations/starts_with/
+ wchar_t/1.cc: New test.
+ * testsuite/21_strings/basic_string/operations/ends_with/
+ char/1.cc: New test.
+ * testsuite/21_strings/basic_string/operations/ends_with/
+ wchar_t/1.cc: New test.
+ * testsuite/21_strings/basic_string_view/operations/starts_with/
+ char/1.cc: New test.
+ * testsuite/21_strings/basic_string_view/operations/starts_with/
+ wchar_t/1.cc: New test.
+ * testsuite/21_strings/basic_string_view/operations/ends_with/
+ char/1.cc: New test.
+ * testsuite/21_strings/basic_string_view/operations/ends_with/
+ wchar_t/1.cc: New test.
+
+2018-11-30 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Pre-emptively support P0646R1 for std container erasure.
+ * include/bits/erase_if.h: Accumulate and return number of erased nodes.
+ * include/std/forward_list (): Return number of erased items.
+ * include/std/list (): Ditto.
+ * include/std/map (): Ditto.
+ * include/std/set (): Ditto.
+ * include/std/string (): Ditto.
+ * include/std/unordered_map (): Ditto.
+ * include/std/unordered_set (): Ditto.
+ * include/std/vector (): Ditto.
+ * include/std/deque (): Ditto.
+ * testsuite/21_strings/basic_string/erasure.cc: Test number of erasures.
+ * testsuite/23_containers/deque/erasure.cc: Ditto.
+ * testsuite/23_containers/forward_list/erasure.cc: Ditto.
+ * testsuite/23_containers/list/erasure.cc: Ditto.
+ * testsuite/23_containers/map/erasure.cc: Ditto.
+ * testsuite/23_containers/set/erasure.cc: Ditto.
+ * testsuite/23_containers/unordered_map/erasure.cc: Ditto.
+ * testsuite/23_containers/unordered_set/erasure.cc: Ditto.
+ * testsuite/23_containers/vector/erasure.cc: Ditto.
+
+2018-11-29 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Only include bits/stl_algo.h for C++20.
+ * include/std/deque: Only include bits/stl_algo.h for C++20.
+ * include/std/string: Ditto.
+ * include/std/vector: Ditto.
+
+2018-11-29 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Fix erasure goofs.
+ * include/experimental/deque: Make inline.
+ * include/std/deque: Include bits/stl_algo.h.
+ (erase, erase_if): Make inline.
+ * include/std/string: Include bits/stl_algo.h.
+ * include/std/unordered_set: Add erase, erase_if!
+ * include/std/vector: Include bits/stl_algo.h.
+ * testsuite/21_strings/basic_string/erasure.cc:
+ Add { dg-options "-std=gnu++2a" }.
+ * testsuite/23_containers/deque/erasure.cc: Ditto.
+ * testsuite/23_containers/forward_list/erasure.cc: Ditto.
+ * testsuite/23_containers/list/erasure.cc: Ditto.
+ * testsuite/23_containers/map/erasure.cc: Ditto.
+ * testsuite/23_containers/set/erasure.cc: Ditto.
+ * testsuite/23_containers/unordered_map/erasure.cc: Ditto.
+ * testsuite/23_containers/unordered_set/erasure.cc: Ditto.
+ * testsuite/23_containers/vector/erasure.cc: Ditto.
+
+2018-11-29 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/88119
+ * include/ext/aligned_buffer.h (__aligned_membuf): Add comment.
+ (__aligned_buffer): Use __alignof__ instead of std::alignment_of.
+ * include/std/type_traits (alignment_of): Use alignof instead of
+ __alignof__.
+ * testsuite/20_util/alignment_of/value.cc: Fix test to check values
+ match alignof not __alignof__, as required by the standard.
+
+ PR libstdc++/86910
+ PR libstdc++/87846
+ * src/filesystem/ops.cc (experimental::create_directories): Report
+ an error when the path resolves to an existing non-directory (P1164).
+ * src/filesystem/std-ops.cc (create_directories): Likewise. Handle
+ empty filenames due to trailing slashes.
+ * testsuite/27_io/filesystem/operations/create_directories.cc: Test
+ when some component of the path exists and is not a directory. Test
+ trailing slashes.
+ * testsuite/experimental/filesystem/operations/create_directories.cc:
+ Likewise.
+
+2018-11-28 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83306
+ * src/filesystem/path.cc (filesystem_error::_M_gen_what()): Create
+ string directly, instead of calling fs_err_concat.
+
+ PR libstdc++/83511
+ * include/std/string_view (basic_string_view::substr): Add default
+ argument to first parameter.
+ * include/experimental/string_view (basic_string_view::substr):
+ Likewise.
+ * testsuite/21_strings/basic_string_view/operations/substr/char/
+ 83511.cc: New test.
+ * testsuite/21_strings/basic_string_view/operations/substr/wchar_t/
+ 83511.cc: New test.
+ * testsuite/experimental/string_view/operations/substr/char/83511.cc:
+ New test.
+ * testsuite/experimental/string_view/operations/substr/wchar_t/83511.cc:
+ New test.
+
+2018-11-28 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Implement uniform container erasure for C++20.
+ * include/Makefile.am: Move erase_if.h.
+ * include/Makefile.in: Move erase_if.h.
+ * include/experimental/bits/erase_if.h: Move ...
+ * include/bits/erase_if.h: ... here.
+ * include/experimental/map: Move erase_if.h.
+ * include/experimental/set: Move erase_if.h.
+ * include/experimental/unordered_map: Move erase_if.h.
+ * include/experimental/unordered_set: Move erase_if.h.
+ * include/std/deque (erase_if, erase): New functions.
+ * include/std/forward_list: Ditto.
+ * include/std/list: Ditto.
+ * include/std/map: Ditto.
+ * include/std/set: Ditto.
+ * include/std/string: Ditto.
+ * include/std/unordered_map: Ditto.
+ * include/std/unordered_set: Ditto.
+ * include/std/vector: Ditto.
+ * testsuite/21_strings/basic_string/erasure.cc: New test.
+ * testsuite/23_containers/deque/erasure.cc: New test.
+ * testsuite/23_containers/forward_list/erasure.cc: New test.
+ * testsuite/23_containers/list/erasure.cc: New test.
+ * testsuite/23_containers/map/erasure.cc: New test.
+ * testsuite/23_containers/set/erasure.cc: New test.
+ * testsuite/23_containers/unordered_map/erasure.cc: New test.
+ * testsuite/23_containers/unordered_set/erasure.cc: New test.
+ * testsuite/23_containers/vector/erasure.cc: New test.
+
+2018-11-28 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/xml/manual/intro.xml: Document LWG 3096 change.
+ * src/filesystem/std-path.cc (path::lexically_relative(const path&)):
+ Treat a final empty element equivalently to a final dot element.
+ * testsuite/27_io/filesystem/path/generation/relative.cc: Add checks
+ for the examples in the DR.
+
+ PR libstdc++/83306
+ * include/bits/fs_path.h (filesystem_error): Move data members into
+ pimpl class owned by shared_ptr. Remove inline definitions of member
+ functions.
+ * src/filesystem/std-path.cc (filesystem_error::_Impl): Define.
+ (filesystem_error): Define member functions.
+ * testsuite/27_io/filesystem/filesystem_error/cons.cc: New test.
+ * testsuite/27_io/filesystem/filesystem_error/copy.cc: New test.
+
+ * doc/xml/manual/status_cxx2017.xml: Update C++17 status.
+ * doc/html/*: Regenerate.
+
+2018-11-27 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/27_io/filesystem/operations/canonical.cc: Remove
+ directory created by test.
+ * testsuite/27_io/filesystem/operations/symlink_status.cc: Remove
+ symlink created by test.
+
+ PR libstdc++/67843
+ * acinclude.m4 (GLIBCXX_ENABLE_LOCK_POLICY): Add new macro
+ that defines _GLIBCXX_HAVE_ATOMIC_LOCK_POLICY.
+ * config.h.in: Regenerate.
+ * configure: Regenerate.
+ * configure.ac: Use GLIBCXX_ENABLE_LOCK_POLICY.
+ * doc/xml/manual/configure.xml: Document new configure option.
+ * include/bits/fs_dir.h (directory_iterator): Use __shared_ptr
+ instead of shared_ptr.
+ (recursive_directory_iterator): Likewise.
+ (__shared_ptr<_Dir>): Add explicit instantiation declaration.
+ (__shared_ptr<recursive_directory_iterator::_Dir_stack>): Likewise.
+ * include/bits/shared_ptr_base.h (__allocate_shared, __make_shared):
+ Add default template argument for _Lock_policy template parameter.
+ * include/ext/concurrence.h (__default_lock_policy): Check macro
+ _GLIBCXX_HAVE_ATOMIC_LOCK_POLICY instead of checking if the current
+ target supports the builtins for compare-and-swap.
+ * src/filesystem/std-dir.cc (__shared_ptr<_Dir>): Add explicit
+ instantiation definition.
+ (__shared_ptr<recursive_directory_iterator::_Dir_stack>): Likewise.
+ (directory_iterator, recursive_directory_iterator): Use __make_shared
+ instead of make_shared.
+
+2018-11-27 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/88199
+ * include/bits/hashtable.h (_Hashtable<>::_M_assign_elements): New.
+ (_Hashtable<>::operator=(const _Hashtable&)): Use latter.
+ (_Hashtable<>::_M_move_assign(_Hashtable&&, false_type)): Likewise.
+ * testsuite/23_containers/unordered_set/allocator/move_assign.cc
+ (test03): New.
+
+2018-11-26 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/26_numerics/complex/requirements/more_constexpr.cc: Fix
+ failure on targets without __float128.
+
+2018-11-23 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Implement P0415 More constexpr for std::complex.
+ * include/std/complex (conj(complex<Tp>), norm(complex<Tp>)): Constexpr;
+ (real(Tp), imag(Tp)): Constexpr;
+ (operator@=(Tp), operator@=(complex<Tp>)): Constexpr;
+ (operator@(Tp,complex<Tp>), operator@(complex<Tp>,Tp)
+ operator@(complex<Tp>,complex<Tp>)): Constexpr.
+ * testsuite/26_numerics/complex/comparison_operators/
+ more_constexpr.cc: New test.
+ * testsuite/26_numerics/complex/operators/more_constexpr.cc: New test.
+ * testsuite/26_numerics/complex/requirements/
+ more_constexpr.cc: New test.
+ * testsuite/26_numerics/complex/value_operations/
+ more_constexpr.cc: New test.
+ * testsuite/26_numerics/headers/complex/synopsis.cc:
+ Add _GLIBCXX20_CONSTEXPR to applicable operators; Add missing proj().
+ * testsuite/26_numerics/headers/complex/synopsis.cc:
+ Add _GLIBCXX20_CONSTEXPR to relevant decls.
+
+2018-11-23 Martin Sebor <msebor@redhat.com>
+ Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/65229
+ * python/libstdcxx/v6/printers.py (StdBitsetPrinter): Handle
+ exception thrown for std::bitset<0>.
+ * testsuite/libstdc++-prettyprinters/simple.cc: Test std::bitset<0>.
+
+2018-11-23 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87308 (partial)
+ * python/libstdcxx/v6/printers.py (StdExpAnyPrinter): Adjust regex to
+ work around PR 88166.
+ * testsuite/libstdc++-prettyprinters/cxx17.cc: Test std::any
+ containing a local type.
+
+2018-11-22 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/87106
+ * include/bits/stl_algobase.h: Include <type_traits>.
+ (__niter_base): Add noexcept specification.
+ * include/bits/stl_deque.h: Include <bits/stl_uninitialized.h>.
+ (__is_trivially_relocatable): Specialize for deque.
+ * include/bits/stl_iterator.h: Include <type_traits>.
+ (__niter_base): Add noexcept specification.
+ * include/bits/stl_uninitialized.h (__is_trivially_relocatable):
+ Add parameter for meta-programming.
+ (__relocate_a_1, __relocate_a): Add noexcept specification.
+ * include/bits/stl_vector.h (__use_relocate): Test __relocate_a.
+
+2018-11-22 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85930
+ PR libstdc++/87520
+ * include/bits/shared_ptr_base.h (_Sp_make_shared_tag::_S_ti)
+ [__cpp_rtti]: Define even when RTTI is enabled. Use array of
+ sizeof(type_info) so that type-punned reference binds to an object
+ of the correct size as well as correct alignment.
+ (_Sp_counted_ptr_inplace::_M_get_deleter) [__cpp_rtti]: Check for
+ _S_ti() reference even when RTTI is enabled.
+ (__shared_ptr(_Sp_make_shared_tag, const _Alloc&, _Args&&...))
+ [__cpp_rtti]: Pass _S_ti() instead of typeid(_Sp_make_shared_tag).
+
+2018-11-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/87386
+ * testsuite/20_util/scoped_allocator/69293_neg.cc: Adjust expected
+ line.
+ * testsuite/20_util/uses_allocator/cons_neg.cc: Likewise.
+ * testsuite/20_util/uses_allocator/69293_neg.cc: Likewise.
+ * testsuite/experimental/propagate_const/requirements2.cc: Likewise.
+ * testsuite/experimental/propagate_const/requirements3.cc: Likewise.
+ * testsuite/experimental/propagate_const/requirements4.cc: Likewise.
+ * testsuite/experimental/propagate_const/requirements5.cc: Likewise.
+
+2018-11-21 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/88111
+ * include/std/memory_resource (pool_options): Add Doxygen comments.
+ * src/c++17/memory_resource.cc (pool_sizes): Only use suitable values
+ on targets with 16-bit or 20-bit size_t type.
+ (munge_options): Make default values depend on width of size_t type.
+
+ PR libstdc++/88113
+ * src/c++17/memory_resource.cc (bitset::size_type): Use the smaller
+ of uint32_t and size_t.
+ (bitset::size(), bitset::free(), bitset::update_next_word())
+ (bitset::max_blocks_per_chunk(), bitset::max_word_index()): Use
+ size_type consistently instead of size_t.
+ (chunk): Adjust static_assert checking sizeof(chunk).
+
+2018-11-20 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Housekeeping for the effective targets of optional's tests.
+ * testsuite/20_util/optional/77288.cc: Adjust.
+ * testsuite/20_util/optional/84601.cc: Likewise.
+ * testsuite/20_util/optional/assignment/1.cc: Likewise.
+ * testsuite/20_util/optional/assignment/2.cc: Likewise.
+ * testsuite/20_util/optional/assignment/3.cc: Likewise.
+ * testsuite/20_util/optional/assignment/4.cc: Likewise.
+ * testsuite/20_util/optional/assignment/5.cc: Likewise.
+ * testsuite/20_util/optional/assignment/6.cc: Likewise.
+ * testsuite/20_util/optional/assignment/7.cc: Likewise.
+ * testsuite/20_util/optional/assignment/8.cc: Likewise.
+ * testsuite/20_util/optional/cons/77727.cc: Likewise.
+ * testsuite/20_util/optional/cons/copy.cc: Likewise.
+ * testsuite/20_util/optional/cons/deduction.cc: Likewise.
+ * testsuite/20_util/optional/cons/default.cc: Likewise.
+ * testsuite/20_util/optional/cons/move.cc: Likewise.
+ * testsuite/20_util/optional/cons/trivial.cc: Likewise.
+ * testsuite/20_util/optional/cons/value.cc: Likewise.
+ * testsuite/20_util/optional/cons/value_neg.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/cons/default.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/cons/value.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/in_place.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/nullopt.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/observers/1.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/observers/4.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/observers/5.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/relops/1.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/relops/2.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/relops/3.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/relops/4.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/relops/5.cc: Likewise.
+ * testsuite/20_util/optional/constexpr/relops/6.cc: Likewise.
+ * testsuite/20_util/optional/in_place.cc: Likewise.
+ * testsuite/20_util/optional/make_optional.cc: Likewise.
+ * testsuite/20_util/optional/nullopt.cc: Likewise.
+ * testsuite/20_util/optional/observers/1.cc: Likewise.
+ * testsuite/20_util/optional/observers/2.cc: Likewise.
+ * testsuite/20_util/optional/observers/3.cc: Likewise.
+ * testsuite/20_util/optional/observers/4.cc: Likewise.
+ * testsuite/20_util/optional/observers/5.cc: Likewise.
+ * testsuite/20_util/optional/observers/6.cc: Likewise.
+ * testsuite/20_util/optional/relops/1.cc: Likewise.
+ * testsuite/20_util/optional/relops/2.cc: Likewise.
+ * testsuite/20_util/optional/relops/3.cc: Likewise.
+ * testsuite/20_util/optional/relops/4.cc: Likewise.
+ * testsuite/20_util/optional/relops/5.cc: Likewise.
+ * testsuite/20_util/optional/relops/6.cc: Likewise.
+ * testsuite/20_util/optional/relops/7.cc: Likewise.
+ * testsuite/20_util/optional/requirements.cc: Likewise.
+ * testsuite/20_util/optional/swap/1.cc: Likewise.
+ * testsuite/20_util/optional/swap/2.cc: Likewise.
+ * testsuite/20_util/optional/typedefs.cc: Likewise.
+
+2018-11-19 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/ext/throw_allocator.h
+ (annotate_base::insert(void*, size_t)): Use insert result to check for
+ double insert attempt.
+ (annotate_base::insert_construct(void*)): Likewise.
+ (annotate_base::check_allocated(void*, size_t)): Return found iterator.
+ (annotate_base::erase(void*, size_t)): Use latter method returned
+ iterator.
+ (annotate_base::check_constructed(void*, size_t)): Return found iterator.
+ (annotate_base::erase_construct(void*)): Use latter method returned
+ iterator.
+
+2018-11-19 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR libstdc++/87855
+ Also implement P0602R4 (variant and optional
+ should propagate copy/move triviality) for std::optional.
+ * include/std/optional (_Optional_payload): Change
+ the main constraints to check constructibility in
+ addition to assignability.
+ (operator=): Make constexpr.
+ (_M_reset): Likewise.
+ (_M_construct): Likewise.
+ (operator->): Likewise.
+ * testsuite/20_util/optional/assignment/8.cc: Adjust.
+ * testsuite/20_util/optional/assignment/9.cc: New.
+
+2018-11-19 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/88084 - Implement LWG 2777
+ * include/std/string_view (basic_string_view::copy): Use traits to
+ copy.
+ * testsuite/21_strings/basic_string_view/operations/copy/char/2.cc:
+ New test.
+ * testsuite/21_strings/basic_string_view/operations/copy/wchar_t/2.cc:
+ New test.
+
+2018-11-18 Michele Pezzutti <mpezz@tiscali.it>
+ Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ PR libstdc++/83566 - cyl_bessel_j returns wrong result for x>1000
+ for high orders.
+ * include/tr1/bessel_function.tcc: Perform no fewer than nu/2 iterations
+ of the asymptotic series (nu is the Bessel order).
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 09_cyl_bessel_j/check_value.cc: Add tests at nu=100, 1000<=x<=2000.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 11_cyl_neumann/check_value.cc: Ditto.
+ * testsuite/special_functions/08_cyl_bessel_j/check_value.cc: Ditto.
+ * testsuite/special_functions/10_cyl_neumann/check_value.cc: Ditto.
+
+2018-11-17 Jonathan Wakely <jwakely@redhat.com>
+
+ Implement std::pmr::synchronized_pool_resource
+ * config/abi/pre/gnu.ver: Add new symbols.
+ * include/std/memory_resource [_GLIBCXX_HAS_GTHREADS]
+ (__cpp_lib_memory_resource): Define to expected value, 201603.
+ (synchronized_pool_resource): New class.
+ [!_GLIBCXX_HAS_GTHREADS] (__cpp_lib_memory_resource): Define to 1.
+ * include/std/shared_mutex (__glibcxx_rwlock_rdlock)
+ (__glibcxx_rwlock_tryrdlock, __glibcxx_rwlock_wrlock)
+ (__glibcxx_rwlock_trywrlock, __glibcxx_rwlock_unlock)
+ (__glibcxx_rwlock_destroy, __glibcxx_rwlock_init)
+ (__glibcxx_rwlock_timedrdlock, __glibcxx_rwlock_timedwrlock): Define
+ weak symbols for POSIX rwlock functions.
+ (__shared_mutex_pthread): Use weak symbols.
+ * include/std/version (__cpp_lib_memory_resource): Define.
+ * src/c++17/memory_resource.cc [_GLIBCXX_HAS_GTHREADS]
+ (synchronized_pool_resource::_TPools): New class.
+ (destroy_TPools): New function for pthread_key_create destructor.
+ (synchronized_pool_resource::synchronized_pool_resource)
+ (synchronized_pool_resource::~synchronized_pool_resource)
+ (synchronized_pool_resource::release)
+ (synchronized_pool_resource::do_allocate)
+ (synchronized_pool_resource::do_deallocate): Define public members.
+ (synchronized_pool_resource::_M_thread_specific_pools)
+ (synchronized_pool_resource::_M_alloc_tpools)
+ (synchronized_pool_resource::_M_alloc_shared_tpools): Define private
+ members.
+ * testsuite/20_util/synchronized_pool_resource/allocate.cc: New test.
+ * testsuite/20_util/synchronized_pool_resource/cons.cc: New test.
+ * testsuite/20_util/synchronized_pool_resource/is_equal.cc: New test.
+ * testsuite/20_util/synchronized_pool_resource/multithreaded.cc: New
+ test.
+ * testsuite/20_util/synchronized_pool_resource/release.cc: New test.
+ * testsuite/performance/20_util/memory_resource/pools.cc: Add
+ multithreaded tests using pmr::synchronized_pool_resource.
+
+2018-11-16 Renlin Li <renlin.li@arm.com>
+ Tejas Belagod <tejas.belagod@arm.com>
+
+ testsuite/lib/libstdc++.exp (check_v3_target_prop_cached): New proc.
+ (check_v3_target): Use the check_v3_target_prop_cached.
+
+2018-11-15 Jonathan Wakely <jwakely@redhat.com>
+
+ * scripts/check_performance: Allow tests to choose a -std flag.
+ * src/c++17/memory_resource.cc (bitset::get_first_unset()): Use local
+ variables of the right types. Call update_next_word() unconditionally.
+ * testsuite/20_util/unsynchronized_pool_resource/cons.cc: New test.
+ * testsuite/performance/20_util/memory_resource/pools.cc: New test.
+ * testsuite/util/testsuite_performance.h (time_counter): Allow
+ timer to be restarted.
+
+ * testsuite/20_util/unsynchronized_pool_resource/allocate.cc: Fix
+ test for 32-bit targets. Test additional allocation sizes.
+
+2018-11-14 Jonathan Wakely <jwakely@redhat.com>
+
+ * scripts/create_testsuite_files: Add special_functions to the list
+ of directories to search. Add comment referring to conformance.exp.
+ * testsuite/libstdc++-dg/conformance.exp: Add comment referring
+ to create_testsuite_files.
+
+2018-11-13 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/c++17/memory_resource.cc (select_num_pools): Fix off-by-one
+ error when block_size is equal to one of the values in the array.
+
+ * src/c++17/memory_resource.cc (_Pool::deallocate): Restore
+ attributes to parameters that are only used in assertions.
+
+ * src/c++17/memory_resource.cc (bitset::find_first_unset()): Remove
+ unused function.
+ (bitset::get_first_unset()): Remove loop, if there's are unset bits
+ then _M_next_word refers to the first one and there's no need to loop.
+ (_Pool::_Pool(size_t, size_t), _Pool::block_size()): Remove dead code.
+
+ * src/c++17/memory_resource.cc (munge_options): Round up value of
+ largest_required_pool_block to multiple of smallest pool size. Round
+ excessively large values down to largest pool size.
+ (select_num_pools): Increase number of pools by one unless it exactly
+ matches requested largest_required_pool_block.
+ (__pool_resource::_M_alloc_pools()): Make largest pool size equal
+ largest_required_pool_block.
+ * testsuite/20_util/unsynchronized_pool_resource/options.cc: Check
+ that pool_options::largest_required_pool_block is set appropriately.
+
+ * src/c++17/memory_resource.cc (big_block): Improve comments.
+ (big_block::all_ones): Remove.
+ (big_block::big_block(size_t, size_t)): Use alloc_size.
+ (big_block::size()): Add comment, replace all_ones with equivalent
+ expression.
+ (big_block::align()): Shift value of correct type.
+ (big_block::alloc_size(size_t)): New function to round up size.
+ (__pool_resource::allocate(size_t, size_t)): Add comment.
+ (__pool_resource::deallocate(void*, size_t, size_t)): Likewise. Fix
+ incorrect assertion by using big_block::alloc_size(size_t).
+ * testsuite/20_util/unsynchronized_pool_resource/allocate.cc: Add
+ more tests for unpooled allocations.
+
+ * src/c++17/memory_resource.cc (bitset::full()): Handle edge case
+ for _M_next_word maximum value.
+ (bitset::get_first_unset(), bitset::set(size_type)): Use
+ update_next_word() to update _M_next_word.
+ (bitset::update_next_word()): New function, avoiding wraparound of
+ unsigned _M_next_word member.
+ (bitset::max_word_index()): New function.
+ (chunk::chunk(void*, uint32_t, void*, size_t)): Add assertion.
+ (chunk::max_bytes_per_chunk()): New function.
+ (pool::replenish(memory_resource*, const pool_options&)): Prevent
+ _M_blocks_per_chunk from exceeding max_blocks_per_chunk or from
+ causing chunk::max_bytes_per_chunk() to be exceeded.
+ * testsuite/20_util/unsynchronized_pool_resource/allocate-max-chunks.cc:
+ New test.
+
+2018-11-12 Jason Merrill <jason@redhat.com>
+
+ * libsupc++/new (std::destroying_delete_t): New.
+
+2018-11-12 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87963
+ * src/c++17/memory_resource.cc (chunk::_M_bytes): Change type from
+ unsigned to uint32_t.
+ (chunk): Fix static assertion for 64-bit targets that aren't LP64.
+ (bigblock::all_ones): Fix undefined shift.
+
+2018-11-11 Hans-Peter Nilsson <hp@axis.com>
+
+ PR libstdc++-v3/54005
+ * include/bits/atomic_base.h (__atomic_base<_TTp>::is_lock_free(),
+ __atomic_base<_PTp*>::is_lock_free()): Call __atomic_is_lock_free
+ with the type-derived _S_alignment instead of __alignof the object.
+ * include/std/atomic (atomic<T>::is_lock_free()): Likewise.
+
+2018-11-11 Jonathan Wakely <jwakely@redhat.com>
+
+ Implement P0318R1 unwrap_ref_decay and unwrap_reference
+ * include/std/type_traits (unwrap_reference, unwrap_reference_t)
+ (unwrap_ref_decay, unwrap_ref_decay_t): New traits and aliases.
+ * testsuite/20_util/unwrap_reference/1.cc: New test.
+ * testsuite/20_util/unwrap_reference/2.cc: New test.
+
+ Implement P1007R3 std::assume_aligned
+ * include/std/memory (assume_aligned): Implement for C++17.
+ * testsuite/20_util/assume_aligned/1.cc: New test.
+ * testsuite/20_util/assume_aligned/2_neg.cc: New test.
+ * testsuite/20_util/assume_aligned/3.cc: New test.
+
+2018-11-09 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87787
+ * include/bits/stl_uninitialized.h (__relocate_a_1): Do not call
+ memmove when there's nothing to copy (and pointers could be null).
+
+2018-11-07 Hafiz Abid Qadeer <abidh@codesourcery.com>
+
+ * configure: Regenerated.
+
+2018-11-07 Jonathan Wakely <jwakely@redhat.com>
+
+ * config/abi/pre/gnu.ver: Fix patterns for size_t parameters.
+
+2018-11-06 Jonathan Wakely <jwakely@redhat.com>
+
+ Implement std::pmr::unsynchronized_pool_resource
+ * config/abi/pre/gnu.ver: Add new symbols.
+ * include/std/memory_resource (std::pmr::__pool_resource): New class.
+ (std::pmr::unsynchronized_pool_resource): New class.
+ * src/c++17/Makefile.am: Add -fimplicit-templates to flags for
+ memory_resource.cc
+ * src/c++17/Makefile.in: Regenerate.
+ * src/c++17/memory_resource.cc (bitset, chunk, big_block): New
+ internal classes.
+ (__pool_resource::_Pool): Define new class.
+ (munge_options, pool_index, select_num_pools): New internal functions.
+ (__pool_resource::__pool_resource, __pool_resource::~__pool_resource)
+ (__pool_resource::allocate, __pool_resource::deallocate)
+ (__pool_resource::_M_alloc_pools): Define member functions.
+ (unsynchronized_pool_resource::unsynchronized_pool_resource)
+ (unsynchronized_pool_resource::~unsynchronized_pool_resource)
+ (unsynchronized_pool_resource::release)
+ (unsynchronized_pool_resource::_M_find_pool)
+ (unsynchronized_pool_resource::do_allocate)
+ (unsynchronized_pool_resource::do_deallocate): Define member
+ functions.
+ * testsuite/20_util/unsynchronized_pool_resource/allocate.cc: New
+ test.
+ * testsuite/20_util/unsynchronized_pool_resource/is_equal.cc: New
+ test.
+ * testsuite/20_util/unsynchronized_pool_resource/options.cc: New
+ test.
+ * testsuite/20_util/unsynchronized_pool_resource/release.cc: New
+ test.
+
+2018-11-06 John Bytheway <jbytheway@gmail.com>
+
+ PR libstdc++/87872
+ * include/debug/safe_sequence.tcc
+ (_Safe_sequence<>::_M_transfer_from_if): Skip transfer to self.
+
+2018-10-31 Joseph Myers <joseph@codesourcery.com>
+
+ PR bootstrap/82856
+ * Makefile.am: Include multilib.am.
+ * configure.ac: Remove AC_PREREQ.
+ * Makefile.in, aclocal.m4, configure, doc/Makefile.in,
+ include/Makefile.in, libsupc++/Makefile.in, po/Makefile.in,
+ python/Makefile.in, src/Makefile.in, src/c++11/Makefile.in,
+ src/c++17/Makefile.in, src/c++98/Makefile.in,
+ src/filesystem/Makefile.in, testsuite/Makefile.in: Regenerate.
+
+2018-10-31 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/20_util/pair/87822.cc: Test deeper nesting.
+
+ PR libstdc++/87822
+ * include/bits/stl_pair.h (__pair_base): Change to class template.
+ (pair): Make base class type depend on template parameters.
+ * testsuite/20_util/pair/87822.cc: New test.
+
+2018-10-30 Marek Polacek <polacek@redhat.com>
+
+ Implement P0892R2, explicit(bool).
+ * testsuite/20_util/any/cons/explicit.cc: Adjust dg-error.
+ * testsuite/20_util/pair/cons/explicit_construct.cc: Likewise.
+ * testsuite/20_util/tuple/cons/explicit_construct.cc: Likewise.
+
+2018-10-30 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87809
+ * include/bits/forward_list.h (_Fwd_list_impl::_Fwd_list_impl()): Use
+ trait in exception-specification instead of possibly invalid
+ expression.
+ * include/bits/stl_bvector.h (_Bvector_impl::_Bvector_impl()):
+ Likewise.
+ * include/bits/stl_list.h (_List_impl::_List_impl()): Likewise.
+ * include/bits/stl_vector.h (_Vector_impl::_Vector_impl()): Likewise.
+ * testsuite/23_containers/forward_list/cons/87809.cc: New test.
+ * testsuite/23_containers/list/cons/87809.cc: New test.
+ * testsuite/23_containers/vector/bool/cons/87809.cc: New test.
+ * testsuite/23_containers/vector/cons/87809.cc: New test.
+
+ PR libstdc++/87784
+ * include/tr2/dynamic_bitset (dynamic_bitset::push_back): When there
+ are no unused bits in the last block, append a new block with the
+ right value so the bit doesn't need to be set. Only increment size
+ after setting the new bit, not before.
+ * testsuite/tr2/dynamic_bitset/pr87784.cc: New test.
+
+2018-10-29 David Malcolm <dmalcolm@redhat.com>
+
+ * testsuite/17_intro/using_namespace_std_exp_neg.cc: Remove
+ "expected namespace-name before" error.
+ * testsuite/17_intro/using_namespace_std_tr1_neg.cc: Likewise.
+
+2018-10-28 François Dumont <fdumont@gcc.gnu.org>
+
+ * testsuite/23_containers/deque/48101_neg.cc: Remove dg-prune-output
+ 'std' from regex pattern for versioned namespace compatibility.
+ * testsuite/23_containers/vector/48101_neg.cc: Likewise.
+ * testsuite/27_io/filesystem/path/io/dr2989.cc: Likewise.
+
+2018-10-25 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87749
+ * include/bits/basic_string.h [_GLIBCXX_USE_CXX11_ABI]
+ (basic_string::operator=(basic_string&&)): For short strings copy the
+ buffer inline. Only fall back to using assign(const basic_string&) to
+ do a deep copy when reallocation is needed.
+ * testsuite/21_strings/basic_string/modifiers/assign/char/87749.cc:
+ New test.
+ * testsuite/21_strings/basic_string/modifiers/assign/char/
+ move_assign_optim.cc: New test.
+ * testsuite/21_strings/basic_string/modifiers/assign/wchar_t/87749.cc:
+ New test.
+ * testsuite/21_strings/basic_string/modifiers/assign/wchar_t/
+ move_assign_optim.cc: New test.
+
+2018-10-25 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/87106
+ * include/bits/alloc_traits.h (_S_construct, _S_destroy, construct,
+ destroy): Add noexcept specification.
+ * include/bits/allocator.h (construct, destroy): Likewise.
+ * include/ext/alloc_traits.h (construct, destroy): Likewise.
+ * include/ext/malloc_allocator.h (construct, destroy): Likewise.
+ * include/ext/new_allocator.h (construct, destroy): Likewise.
+ * include/bits/stl_uninitialized.h (__relocate_object_a, __relocate_a,
+ __relocate_a_1): New functions.
+ (__is_trivially_relocatable): New class.
+ * include/bits/stl_vector.h (__use_relocate): New static member.
+ * include/bits/vector.tcc (reserve, _M_realloc_insert,
+ _M_default_append): Use __relocate_a.
+ (reserve, _M_assign_aux, _M_realloc_insert, _M_fill_insert,
+ _M_default_append, _M_range_insert): Move _GLIBCXX_ASAN_ANNOTATE_REINIT
+ after _Destroy.
+ * testsuite/23_containers/vector/modifiers/push_back/49836.cc:
+ Replace CopyConsOnlyType with DelAnyAssign.
+
+2018-10-24 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/safe_unordered_container.h
+ (_Safe_unordered_container<>::_M_invalidate_locals): Take lambda
+ parameter type from local end variable.
+ (_Safe_unordered_container<>::_M_invalidate_all): Likewise.
+ * include/debug/unordered_map
+ (unordered_map<>::begin()): Use C++11 direct initialization.
+ (unordered_map<>::end()): Likewise.
+ (unordered_map<>::cbegin()): Likewise.
+ (unordered_map<>::cend()): Likewise.
+ (unordered_map<>::begin(size_type)): Likewise.
+ (unordered_map<>::end(size_type)): Likewise.
+ (unordered_map<>::cbegin(size_type)): Likewise.
+ (unordered_map<>::cend(size_type)): Likewise.
+ (unordered_map<>::emplace<>(_Args&&...)): Likewise.
+ (unordered_map<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (unordered_map<>::insert(const value_type&)): Likewise.
+ (unordered_map<>::insert(value_type&&)): Likewise.
+ (unordered_map<>::insert<>(_Pair&&)): Likewise.
+ (unordered_map<>::insert(const_iterator, const value_type&)): Likewise.
+ (unordered_map<>::insert(const_iterator, value_type&&)): Likewise.
+ (unordered_map<>::insert<>(const_iterator, _Pair&&)): Likewise.
+ (unordered_map<>::try_emplace<>(const key_type&, _Args&&...)): Likewise.
+ (unordered_map<>::try_emplace<>(key_type&&, _Args&&...)): Likewise.
+ (unordered_map<>::try_emplace<>(const_iterator, const key_type&,
+ _Args&&...)): Likewise.
+ (unordered_map<>::try_emplace<>(const_iterator, key_type&&,
+ _Args&&...)): Likewise.
+ (unordered_map<>::insert_or_assign<>(const key_type&, _Obj&&)): Likewise.
+ (unordered_map<>::insert_or_assign<>(key_type&&, _Obj&&)): Likewise.
+ (unordered_map<>::insert_or_assign<>(const_iterator, const key_type&,
+ _Obj&&)): Likewise.
+ (unordered_map<>::insert_or_assign<>(const_iterator, key_type&&,
+ _Obj&&)): Likewise.
+ (unordered_map<>::insert(note_type&&)): Likewise.
+ (unordered_map<>::find(const key_type&)): Likewise.
+ (unordered_map<>::equal_range(const key_type&)): Likewise.
+ (unordered_map<>::_M_extract): New.
+ (unordered_map<>::extract(const_iterator)): Use latter.
+ (unordered_map<>::extract(const key_type&)): Likewise.
+ (unordered_map<>::_M_erase): New.
+ (unordered_map<>::erase(const key_type&)): Use latter.
+ (unordered_map<>::erase(const_iterator)): Likewise.
+ (unordered_map<>::erase(iterator)): Likewise.
+ (unordered_map<>::_M_invalidate): New.
+ (unordered_map<>::erase(const_iterator, const_iterator)): Use latter.
+ (unordered_multimap<>::begin()): Use C++11 direct initialization.
+ (unordered_multimap<>::end()): Likewise.
+ (unordered_multimap<>::cbegin()): Likewise.
+ (unordered_multimap<>::cend()): Likewise.
+ (unordered_multimap<>::begin(size_type)): Likewise.
+ (unordered_multimap<>::end(size_type)): Likewise.
+ (unordered_multimap<>::cbegin(size_type)): Likewise.
+ (unordered_multimap<>::cend(size_type)): Likewise.
+ (unordered_multimap<>::emplace<>(_Args&&...)): Likewise.
+ (unordered_multimap<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (unordered_multimap<>::insert(const value_type&)): Likewise.
+ (unordered_multimap<>::insert(const_iterator, const value_type&)): Likewise.
+ (unordered_multimap<>::insert(const_iterator, value_type&&)): Likewise.
+ (unordered_multimap<>::insert<>(_Pair&&)): Likewise.
+ (unordered_multimap<>::insert<>(const_iterator, _Pair&&)): Likewise.
+ (unordered_multimap<>::insert(note_type&&)): Likewise.
+ (unordered_multimap<>::insert(const_iterator, note_type&&)): Likewise.
+ (unordered_multimap<>::find(const key_type&)): Likewise.
+ (unordered_multimap<>::equal_range(const key_type&)): Likewise.
+ (unordered_multimap<>::_M_extract): New.
+ (unordered_multimap<>::extract(const_iterator)): Use latter.
+ (unordered_multimap<>::extract(const key_type&)): Likewise.
+ (unordered_multimap<>::_M_erase): New.
+ (unordered_multimap<>::erase(const_iterator)): Likewise.
+ (unordered_multimap<>::erase(iterator)): Likewise.
+ (unordered_multimap<>::_M_invalidate): New.
+ (unordered_multimap<>::erase(const key_type&)): Use latter.
+ (unordered_multimap<>::erase(const_iterator, const_iterator)): Likewise.
+ * include/debug/unordered_set
+ (unordered_set<>::begin()): Use C++11 direct initialization.
+ (unordered_set<>::end()): Likewise.
+ (unordered_set<>::cbegin()): Likewise.
+ (unordered_set<>::cend()): Likewise.
+ (unordered_set<>::begin(size_type)): Likewise.
+ (unordered_set<>::end(size_type)): Likewise.
+ (unordered_set<>::cbegin(size_type)): Likewise.
+ (unordered_set<>::cend(size_type)): Likewise.
+ (unordered_set<>::emplace<>(_Args&&...)): Likewise.
+ (unordered_set<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (unordered_set<>::insert(const value_type&)): Likewise.
+ (unordered_set<>::insert(value_type&&)): Likewise.
+ (unordered_set<>::insert(const_iterator, const value_type&)): Likewise.
+ (unordered_set<>::insert(const_iterator, value_type&&)): Likewise.
+ (unordered_set<>::insert(note_type&&)): Likewise.
+ (unordered_set<>::insert(const_iterator, note_type&&)): Likewise.
+ (unordered_set<>::find(const key_type&)): Likewise.
+ (unordered_set<>::equal_range(const key_type&)): Likewise.
+ (unordered_set<>::_M_extract): New.
+ (unordered_set<>::extract(const_iterator)): Use latter.
+ (unordered_set<>::extract(const key_type&)): Likewise.
+ (unordered_set<>::_M_erase): New.
+ (unordered_set<>::erase(const key_type&)): Use latter.
+ (unordered_set<>::erase(const_iterator)): Likewise.
+ (unordered_set<>::erase(iterator)): Likewise.
+ (unordered_set<>::_M_invalidate): New.
+ (unordered_set<>::erase(const_iterator, const_iterator)): Use latter.
+ (unordered_multiset<>::begin()): Use C++11 direct initialization.
+ (unordered_multiset<>::end()): Likewise.
+ (unordered_multiset<>::cbegin()): Likewise.
+ (unordered_multiset<>::cend()): Likewise.
+ (unordered_multiset<>::begin(size_type)): Likewise.
+ (unordered_multiset<>::end(size_type)): Likewise.
+ (unordered_multiset<>::cbegin(size_type)): Likewise.
+ (unordered_multiset<>::cend(size_type)): Likewise.
+ (unordered_multiset<>::emplace<>(_Args&&...)): Likewise.
+ (unordered_multiset<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (unordered_multiset<>::insert(const value_type&)): Likewise.
+ (unordered_multiset<>::insert(const_iterator, const value_type&)): Likewise.
+ (unordered_multiset<>::insert(value_type&&)): Likewise.
+ (unordered_multiset<>::insert(const_iterator, value_type&&)): Likewise.
+ (unordered_multiset<>::insert(node_type&&)): Likewise.
+ (unordered_multiset<>::insert(const_iterator, node_type&&)): Likewise.
+ (unordered_multiset<>::find(const key_type&)): Likewise.
+ (unordered_multiset<>::equal_range(const key_type&)): Likewise.
+ (unordered_multiset<>::_M_extract): New.
+ (unordered_multiset<>::extract(const_iterator)): Use latter.
+ (unordered_multiset<>::extract(const key_type&)): Likewise.
+ (unordered_multiset<>::_M_erase): New.
+ (unordered_multiset<>::erase(const_iterator)): Likewise.
+ (unordered_multiset<>::erase(iterator)): Likewise.
+ (unordered_multiset<>::_M_invalidate): New.
+ (unordered_multiset<>::erase(const key_type&)): Use latter.
+ (unordered_multiset<>::erase(const_iterator, const_iterator)): Likewise.
+
+ * include/c_global/cstddef: Add versioned namespace.
+
+2018-10-23 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87704
+ * include/bits/unique_ptr.h (unique_ptr::unique_ptr(nullptr_t)): Do
+ not delegate to default constructor.
+ (unique_ptr<T[], D>::unique_ptr(nullptr_t)): Likewise.
+ * testsuite/20_util/unique_ptr/cons/incomplete.cc: New test.
+
+2018-10-20 François Dumont <fdumont@gcc.gnu.org>
+
+ * testsuite/util/testsuite_containers.h
+ (forward_members_unordered<>::forward_members_unordered
+ (const value_type&)): Add local_iterator pre and post increment checks.
+ * config/abi/pre/gnu.ver: Add GLIBCXX_3.4.26 new symbol.
+
+2018-10-19 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/23_containers/array/requirements/explicit_instantiation/
+ 3.cc: Skip test when compiled with a -std=c++NN strict mode.
+ * testsuite/23_containers/deque/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/forward_list/requirements/
+ explicit_instantiation/3.cc: Likewise.
+ * testsuite/23_containers/list/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/map/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/multimap/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/multiset/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/set/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/unordered_map/requirements/
+ explicit_instantiation/3.cc: Likewise.
+ * testsuite/23_containers/unordered_multimap/requirements/
+ explicit_instantiation/3.cc: Likewise.
+ * testsuite/23_containers/unordered_multiset/requirements/
+ explicit_instantiation/3.cc: Likewise.
+ * testsuite/23_containers/unordered_set/requirements/
+ explicit_instantiation/3.cc: Likewise.
+ * testsuite/23_containers/vector/ext_pointer/explicit_instantiation/
+ 3.cc: Likewise.
+ * testsuite/23_containers/vector/requirements/explicit_instantiation/
+ 3.cc: Likewise.
+
+ * testsuite/23_containers/deque/48101_neg.cc: Prune additional errors
+ printed when __STRICT_ANSI__ is defined.
+ * testsuite/23_containers/forward_list/48101_neg.cc: Likewise.
+ * testsuite/23_containers/list/48101_neg.cc: Likewise.
+ * testsuite/23_containers/multiset/48101_neg.cc: Likewise.
+ * testsuite/23_containers/set/48101_neg.cc: Likewise.
+ * testsuite/23_containers/unordered_multiset/48101_neg.cc: Likewise.
+ * testsuite/23_containers/unordered_set/48101_neg.cc: Likewise.
+ * testsuite/23_containers/vector/48101_neg.cc: Likewise.
+
+ * testsuite/23_containers/forward_list/requirements/
+ explicit_instantiation/5.cc [__STRICT_ANSI__]: Don't test non-standard
+ extension.
+ * testsuite/23_containers/list/requirements/explicit_instantiation/
+ 5.cc [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/map/requirements/explicit_instantiation/5.cc
+ [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/multimap/requirements/explicit_instantiation/
+ 5.cc [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/multiset/requirements/explicit_instantiation/
+ 5.cc [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/set/requirements/explicit_instantiation/5.cc
+ [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/unordered_map/requirements/debug_container.cc
+ [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/unordered_map/requirements/
+ explicit_instantiation/5.cc [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/unordered_multimap/requirements/
+ explicit_instantiation/5.cc [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/unordered_multiset/requirements/
+ explicit_instantiation/5.cc [__STRICT_ANSI__]: Likewise.
+ * testsuite/23_containers/unordered_set/requirements/
+ explicit_instantiation/5.cc [__STRICT_ANSI__]: Likewise.
+
+ * testsuite/20_util/scoped_allocator/1.cc: Use allocator with correct
+ value type for the container.
+ * testsuite/23_containers/forward_list/cons/14.cc: Likewise.
+ * testsuite/23_containers/map/56613.cc: Likewise.
+ * testsuite/23_containers/unordered_map/55043.cc: Likewise.
+ * testsuite/23_containers/unordered_map/allocator/copy.cc: Likewise.
+ * testsuite/23_containers/unordered_map/allocator/copy_assign.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_map/allocator/minimal.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_map/allocator/move.cc: Likewise.
+ * testsuite/23_containers/unordered_map/allocator/move_assign.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_map/allocator/noexcept.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_map/cons/81891.cc: Likewise.
+ * testsuite/23_containers/unordered_map/requirements/exception/
+ basic.cc: Likewise.
+ * testsuite/23_containers/unordered_map/requirements/exception/
+ generation_prohibited.cc: Likewise.
+ * testsuite/23_containers/unordered_map/requirements/exception/
+ propagation_consistent.cc: Likewise.
+ * testsuite/23_containers/unordered_multimap/55043.cc: Likewise.
+ * testsuite/23_containers/unordered_multimap/allocator/copy.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_multimap/allocator/copy_assign.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_multimap/allocator/minimal.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_multimap/allocator/move.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_multimap/allocator/move_assign.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_multimap/allocator/noexcept.cc:
+ Likewise.
+ * testsuite/23_containers/unordered_multimap/requirements/exception/
+ basic.cc: Likewise.
+ * testsuite/23_containers/unordered_multimap/requirements/exception/
+ generation_prohibited.cc: Likewise.
+ * testsuite/23_containers/unordered_multimap/requirements/exception/
+ propagation_consistent.cc: Likewise.
+ * testsuite/23_containers/unordered_multimap/requirements/
+ explicit_instantiation/5.cc: Likewise.
+ * testsuite/ext/malloc_allocator/sanity.cc: Likewise.
+
+ * ext/special_functions/airy_ai/check_nan.cc: Skip test for
+ non-standard extension when a strict -std=c++NN dialect is used.
+ * ext/special_functions/airy_ai/check_value.cc: Likewise.
+ * ext/special_functions/airy_ai/compile.cc: Likewise.
+ * ext/special_functions/airy_bi/check_nan.cc: Likewise.
+ * ext/special_functions/airy_bi/check_value.cc: Likewise.
+ * ext/special_functions/airy_bi/compile.cc: Likewise.
+ * ext/special_functions/conf_hyperg/check_nan.cc: Likewise.
+ * ext/special_functions/conf_hyperg/check_value.cc: Likewise.
+ * ext/special_functions/conf_hyperg/compile.cc: Likewise.
+ * ext/special_functions/hyperg/check_nan.cc: Likewise.
+ * ext/special_functions/hyperg/check_value.cc: Likewise.
+ * ext/special_functions/hyperg/compile.cc: Likewise.
+
+ * testsuite/23_containers/list/requirements/explicit_instantiation/
+ 5_c++0x.cc: Remove redundant test that is functionally identical to
+ the 5.cc test.
+ * testsuite/23_containers/map/requirements/explicit_instantiation/
+ 5_c++0x.cc: Likewise.
+ * testsuite/23_containers/multimap/requirements/explicit_instantiation/
+ 5_c++0x.cc: Likewise.
+ * testsuite/23_containers/multiset/requirements/explicit_instantiation/
+ 5_c++0x.cc: Likewise.
+ * testsuite/23_containers/set/requirements/explicit_instantiation/
+ 5_c++0x.cc: Likewise.
+
+ * include/bits/regex_executor.tcc (_Backref_matcher::_M_apply): Use
+ _GLIBCXX_STD_A to refer to normal mode algorithms.
+ * testsuite/28_regex/headers/regex/parallel_mode.cc: New test.
+ * testsuite/28_regex/headers/regex/std_c++0x_neg.cc: Remove empty
+ whitespace.
+
+ * include/debug/map.h (map::erase(iterator)): Add abi-tag so that
+ C++11 version mangles differently from incompatible C++98 version.
+ * include/debug/multimap.h (multimap::erase(iterator)): Likewise.
+ * include/debug/multiset.h (multiset::erase(iterator))
+ (multiset::erase(const_iterator, const_iterator)): Likewise.
+ * include/debug/set.h (set::erase(iterator))
+ (multiset::erase(const_iterator, const_iterator)): Likewise.
+
+2018-10-18 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/20_util/duration/cons/2.cc: Add -ffloat-store to fix
+ failure when compiled without optimisation.
+ * testsuite/ext/profile/mutex_extensions_neg.cc: Prune additional
+ errors caused by C++17 std::pmr alias templates.
+
+ PR libstdc++/87642
+ * config/locale/gnu/monetary_members.cc
+ (moneypunct<char, true>::_M_initialize_moneypunct): Use
+ __narrow_multibyte_chars to convert multibyte thousands separators
+ to a single char.
+ * config/locale/gnu/numeric_members.cc
+ (numpunct<char>::_M_initialize_numpunct): Likewise.
+ (__narrow_multibyte_chars): New function.
+
+ PR libstdc++/87641
+ * include/bits/valarray_array.h (__valarray_sum): Use first element
+ to initialize accumulator instead of value-initializing it.
+ (__valarray_product<_Tp>): Move to ...
+ * src/c++98/valarray.cc (__valarray_product<_Tp>): Here. Use first
+ element to initialize accumulator.
+ (__valarray_product(const valarray<size_t>&)): Remove const_cast made
+ unnecessary by LWG 389.
+ * testsuite/26_numerics/valarray/87641.cc: New test.
+
+2018-10-18 François Dumont <fdumont@gcc.gnu.org>
+
+ Partial revert.
+ 2018-10-08 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/list (list<>::cbegin()): Use C++11 direct
+ initialization.
+ (list<>::cend()): Likewise.
+ (list<>::erase(const_iterator, const_iterator)): Ensure consistent
+ iterator comparisons.
+ (list<>::splice(const_iterator, list&&, const_iterator,
+ const_iterator)): Likewise.
+
+ Partial revert.
+ 2018-10-15 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/vector (vector<>::cbegin()): Use C++11 direct
+ initialization.
+ (vector<>::cend()): Likewise.
+ (vector<>::insert(const_iterator, const _Tp&)): Use consistent
+ iterator comparison.
+ (vector<>::erase(const_iterator)): Likewise.
+ (vector<>::erase(const_iterator, const_iterator)): Likewise.
+
+2018-10-17 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR libstdc++/87619
+ * include/std/variant (__select_index): Fix an off-by-one.
+ * testsuite/20_util/variant/87619.cc: New.
+
+2018-10-16 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/random.h (random_device) [!_GLIBCXX_USE_DEV_RANDOM]:
+ Fix default constructor to call correct function.
+
+ * testsuite/experimental/net/internet/address/v4/creation.cc: Do not
+ declare ip in global namespace, to avoid collision with struct ip
+ defined in <netinet/ip.h>.
+
+ * include/experimental/bits/net.h: Move versioned namespace macros
+ to correct location.
+ * include/experimental/buffer: Likewise.
+ * include/experimental/executor: Likewise.
+ * include/experimental/internet: Likewise.
+ * include/experimental/io_context: Likewise.
+ * include/experimental/netfwd: Likewise.
+ * include/experimental/socket: Likewise.
+ * include/experimental/timer: Likewise.
+
+ * config.h.in: Regenerate.
+ * configure: Regenerate.
+ * configure.ac: Check for headers used by Networking TS.
+ * include/experimental/executor: Include <condition_variable>
+ instead of <mutex>.
+ * include/experimental/internet: Use autoconf macros for available
+ headers. Include <sys/socket.h> for. Remove <cstring> and use
+ __builtin_memcpy and __builtin_strchr.
+ (resolver_errc) [!_GLIBCXX_HAVE_NETDB_H]: Do not define.
+ (address_v4::to_string, address_v6::to_string)
+ [!_GLIBCXX_HAVE_ARPA_INET_H]: Likewise.
+ (basic_resolver_results) [!_GLIBCXX_HAVE_NETDB_H]: Make private
+ constructors report errors.
+ [!_GLIBCXX_HAVE_NETINET_TCP_H] (tcp::no_delay): Do not define.
+ * include/experimental/io_context: Likewise.
+ * include/experimental/socket: Likewise.
+ [!_GLIBCXX_HAVE_SYS_SOCKET_H, !_GLIBCXX_HAVE_POLL_H] (socket_base): Do
+ not define nested types when relevant header not available.
+ (__socket_impl::native_non_blocking) [!_GLIBCXX_HAVE_FCNTL_H]: Report
+ an error.
+ (__basic_socket_impl::open, __basic_socket_impl::local_endpoint)
+ (__basic_socket_impl::bind) [!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
+ (__basic_socket_impl::io_control) [!_GLIBCXX_HAVE_SYS_IOCTL_H]:
+ Likewise.
+ (basic_socket::at_mark, basic_socket::shutdown)
+ (basic_socket::remote_endpoint, basic_socket::connect)
+ (basic_socket::async_connect) [!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
+ (basic_socket::available) [_GLIBCXX_HAVE_SYS_IOCTL_H]: Check macro
+ for <sys/ioctl.h> availability.
+ (basic_socket::wait) [!_GLIBCXX_HAVE_POLL_H]: Likewise.
+ (basic_datagram_socket::receive, basic_datagram_socket::async_receive)
+ (basic_datagram_socket::receive_from)
+ (basic_datagram_socket::async_receive_from)
+ (basic_datagram_socket::send, basic_datagram_socket::async_send)
+ (basic_datagram_socket::send_to, basic_datagram_socket::async_send_to)
+ [!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
+ (basic_stream_socket::receive, basic_stream_socket::async_receive)
+ (basic_stream_socket::send, basic_stream_socket::async_send)
+ [!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
+ (basic_socket_acceptor::listen, basic_socket_acceptor::accept)
+ (basic_socket_acceptor::async_accept) [!_GLIBCXX_HAVE_SYS_SOCKET_H]:
+ Likewise.
+ (basic_socket_acceptor::wait) [!_GLIBCXX_HAVE_POLL_H]: Likewise.
+
+ * testsuite/experimental/net/headers.cc: Remove dg-options.
+ * testsuite/experimental/net/buffer/arithmetic.cc: Replace dg-options
+ with dg-do using effective target.
+ * testsuite/experimental/net/buffer/const.cc: Likewise.
+ * testsuite/experimental/net/buffer/creation.cc: Likewise.
+ * testsuite/experimental/net/buffer/mutable.cc: Likewise.
+ * testsuite/experimental/net/buffer/size.cc: Likewise.
+ * testsuite/experimental/net/buffer/traits.cc: Likewise.
+ * testsuite/experimental/net/execution_context/use_service.cc:
+ Likewise.
+ * testsuite/experimental/net/internet/address/v4/comparisons.cc:
+ Likewise.
+ * testsuite/experimental/net/internet/address/v4/cons.cc: Likewise.
+ * testsuite/experimental/net/internet/address/v4/creation.cc:
+ Likewise.
+ * testsuite/experimental/net/internet/address/v4/members.cc: Likewise.
+ * testsuite/experimental/net/internet/resolver/base.cc: Likewise.
+ * testsuite/experimental/net/internet/resolver/ops/lookup.cc:
+ Likewise.
+ * testsuite/experimental/net/internet/resolver/ops/reverse.cc:
+ Likewise.
+ * testsuite/experimental/net/timer/waitable/cons.cc: Likewise.
+ * testsuite/experimental/net/timer/waitable/dest.cc: Likewise.
+ * testsuite/experimental/net/timer/waitable/ops.cc: Likewise.
+
+ * include/experimental/socket (basic_socket::at_mark): Add missing
+ return.
+
+ * acinclude.m4 (GLIBCXX_CHECK_RANDOM_TR1): Replace with ...
+ (GLIBCXX_CHECK_DEV_RANDOM): New macro with more descriptive name.
+ Define _GLIBCXX_USE_DEV_RANDOM as well as _GLIBCXX_USE_RANDOM_TR1.
+ * config.h.in: Regenerate.
+ * configure: Regenerate.
+ * configure.ac: Use GLIBCXX_CHECK_DEV_RANDOM instead of
+ GLIBCXX_CHECK_RANDOM_TR1.
+ crossconfig.m4: Likewise.
+ * include/bits/random.h (random_device): Use _GLIBCXX_USE_DEV_RANDOM
+ instead of _GLIBCXX_USE_RANDOM_TR1.
+ * testsuite/26_numerics/random/random_device/cons/token.cc: Likewise.
+
+2018-10-16 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ * testsuite/lib/dg-options.exp (add_options_for_net_ts): New proc.
+ * testsuite/experimental/net/internet/address/v4/comparisons.cc:
+ Add dg-add-options net_ts.
+ * testsuite/experimental/net/internet/address/v4/cons.cc: Likewise.
+ * testsuite/experimental/net/internet/address/v4/creation.cc: Likewise.
+ * testsuite/experimental/net/internet/address/v4/members.cc: Likewise.
+ * testsuite/experimental/net/internet/resolver/base.cc: Likewise.
+ * testsuite/experimental/net/internet/resolver/ops/lookup.cc: Likewise.
+ * testsuite/experimental/net/internet/resolver/ops/reverse.cc: Likewise.
+
+2018-10-16 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/20_util/duration/literals/range_neg.cc: Adjust pruned
+ diagnostic to account for quotes around 'constexpr'.
+ * testsuite/23_containers/deque/capacity/max_size.cc: Define static
+ variable.
+ * testsuite/23_containers/vector/capacity/max_size.cc: Likewise.
+
+ PR libstdc++/87618
+ * config/abi/pre/gnu.ver: Fix typos in patterns for basic_stringbuf.
+ * testsuite/27_io/basic_stringbuf/cons/char/default.cc: Disable
+ optimisation to check constructor definition can be linked to.
+ * testsuite/27_io/basic_stringbuf/cons/wchar_t/default.cc: Likewise.
+
+2018-10-15 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/22_locale/numpunct/members/char/3.cc: Adjust test to
+ account for change to glibc it_IT localedata (glibc bz#10797).
+
+ PR libstdc++/87587
+ * src/c++11/cxx11-shim_facets.cc: Suppress -Wabi warnings.
+
+2018-10-15 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/vector (vector<>::cbegin()): Use C++11 direct
+ initialization.
+ (vector<>::cend()): Likewise.
+ (vector<>::emplace(const_iterator, _Args&&...)): Likewise and use
+ consistent iterator comparison.
+ (vector<>::insert(const_iterator, size_type, const _Tp&)): Likewise.
+ (vector<>::insert(const_iterator, _InputIterator, _InputIterator)):
+ Likewise.
+ (vector<>::erase(const_iterator)): Likewise.
+ (vector<>::erase(const_iterator, const_iterator)): Likewise.
+
+2018-10-12 Jonathan Wakely <jwakely@redhat.com>
+
+ Initial commit of Networking TS implementation.
+ * include/Makefile.am: Add new headers.
+ * include/Makefile.in: Regenerate.
+ * include/experimental/bits/net.h: New header for common
+ implementation details of Networking TS.
+ * include/experimental/buffer: New header.
+ * include/experimental/executor: New header.
+ * include/experimental/internet: New header.
+ * include/experimental/io_context: New header.
+ * include/experimental/net: New header.
+ * include/experimental/netfwd: New header.
+ * include/experimental/socket: New header.
+ * include/experimental/timer: New header.
+ * testsuite/experimental/net/buffer/arithmetic.cc: New test.
+ * testsuite/experimental/net/buffer/const.cc: New test.
+ * testsuite/experimental/net/buffer/creation.cc: New test.
+ * testsuite/experimental/net/buffer/mutable.cc: New test.
+ * testsuite/experimental/net/buffer/size.cc: New test.
+ * testsuite/experimental/net/buffer/traits.cc: New test.
+ * testsuite/experimental/net/execution_context/use_service.cc: New
+ test.
+ * testsuite/experimental/net/headers.cc: New test.
+ * testsuite/experimental/net/internet/address/v4/comparisons.cc: New
+ test.
+ * testsuite/experimental/net/internet/address/v4/cons.cc: New test.
+ * testsuite/experimental/net/internet/address/v4/creation.cc: New
+ test.
+ * testsuite/experimental/net/internet/address/v4/members.cc: New
+ test.
+ * testsuite/experimental/net/internet/resolver/base.cc: New test.
+ * testsuite/experimental/net/internet/resolver/ops/lookup.cc: New
+ test.
+ * testsuite/experimental/net/internet/resolver/ops/reverse.cc: New
+ test.
+ * testsuite/experimental/net/timer/waitable/cons.cc: New test.
+ * testsuite/experimental/net/timer/waitable/dest.cc: New test.
+ * testsuite/experimental/net/timer/waitable/ops.cc: New test.
+
+ PR libstdc++/77691
+ * include/experimental/memory_resource (__resource_adaptor_imp): Do
+ not allocate sizes smaller than alignment when relying on guaranteed
+ alignment.
+ * testsuite/experimental/memory_resource/new_delete_resource.cc:
+ Adjust expected number of bytes allocated for alignof(max_align_t).
+
+2018-10-11 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/forward_list
+ (forward_list<>::before_begin()): Use C++11 direct initialization.
+ (forward_list<>::begin()): Likewise.
+ (forward_list<>::end()): Likewise.
+ (forward_list<>::cbefore_begin()): Likewise.
+ (forward_list<>::cbegin()): Likewise.
+ (forward_list<>::cend()): Likewise.
+ (forward_list<>::emplace_after<>(const_iterator, _Args&&...)): Likewise.
+ (forward_list<>::insert_after(const_iterator, const _Tp&)): Likewise.
+ (forward_list<>::insert_after(const_iterator, _Tp&&)): Likewise.
+ (forward_list<>::insert_after(const_iterator, size_type, const _Tp&)):
+ Likewise.
+ (forward_list<>::insert_after(const_iterator, initializer_list<>)):
+ Likewise.
+ (forward_list<>::erase_after(const_iterator)): Likewise.
+ (forward_list<>::erase_after(const_iterator, const_iterator)): Likewise
+ and ensure consistent iterator comparison.
+
+ * include/bits/forward_list.h
+ (_Fwd_list_iterator<>::operator==): Replace member function with inline
+ friend.
+ (_Fwd_list_iterator<>::operator!=): Likewise.
+ (_Fwd_list_const_iterator<>::operator==): Likewise.
+ (_Fwd_list_const_iterator<>::operator!=): Likewise.
+ (operator==(const _Fwd_list_iterator<>&,
+ const _Fwd_list_const_iterator<>&)): Remove.
+ (operator!=(const _Fwd_list_iterator<>&,
+ const _Fwd_list_const_iterator<>&)): Remove.
+ (forward_list<>::_Node): Take typedef from base type.
+ (forward_list<>::iterator): Likewise.
+ (forward_list<>::const_iterator): Likewise.
+
+2018-10-11 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/80538
+ * src/c++11/thread.cc (this_thread::__sleep_for)
+ [_GLIBCXX_HAVE_SLEEP]: Only call sleep for non-zero values.
+ Loop while sleep call is interrupted and until steady_clock
+ shows requested duration has elapsed.
+ (!_GLIBCXX_HAVE_USLEEP]: Use the _GLIBCXX_HAVE_SLEEP code path, but
+ avoiding the usleep call.
+ * testsuite/30_threads/this_thread/60421.cc: Test repeated
+ signal interruptions.
+
+ * include/bits/allocator.h
+ (operator==(const allocator<_Tp>&, const allocator<_Tp>))
+ (operator!=(const allocator<_Tp>&, const allocator<_Tp>)): Replace
+ with inline friends.
+ * include/ext/debug_allocator.h (operator==, operator!=): Replace
+ with inline friend functions that compare to rebound allocators.
+ * include/ext/malloc_allocator.h (operator==, operator!=): Likewise.
+ * include/ext/new_allocator.h (operator==, operator!=): Likewise.
+ * testsuite/ext/debug_allocator/eq.cc: New test.
+ * testsuite/ext/ext_pointer/alloc_eq.cc: New test.
+ * testsuite/ext/malloc_allocator/eq.cc: New test.
+ * testsuite/ext/new_allocator/eq.cc: New test.
+
+2018-10-10 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87544
+ * include/bits/stl_vector.h (vector::_S_max_size): Limit size to
+ PTRDIFF_MAX / sizeof(value_type).
+ * include/ext/malloc_allocator.h (malloc_allocator::max_size):
+ Likewise.
+ * include/ext/new_allocator.h (new_allocator::max_size): Likewise.
+ * testsuite/23_containers/vector/allocator/minimal.cc: Adjust
+ expected value for max_size().
+ * testsuite/23_containers/vector/capacity/87544.cc: New test.
+
+2018-10-09 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_list.h
+ (_List_operator<>::operator==): Replace member function with inline
+ friend.
+ (_List_operator<>::operator!=): Likewise.
+ (_List_const_operator<>::operator==): Likewise.
+ (_List_const_operator<>::operator!=): Likewise.
+ (operator==(const _List_iterator<>&, const _List_const_iterator<>&)):
+ Remove.
+ (operator!=(const _List_iterator<>&, const _List_const_iterator<>&)):
+ Remove.
+
+2018-10-09 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/stringfwd.h (string, wstring, u16string, u32string):
+ Define typedefs outside of __cxx11 inline namespace.
+ * python/libstdcxx/v6/printers.py (register_type_printers): Also
+ register printers for typedefs in new location.
+
+2018-10-08 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87538
+ * testsuite/experimental/functional/87538.cc: New test.
+
+ PR libstdc++/87538
+ * include/std/functional (_Not_fn::operator()): Check value of
+ __is_nothrow_invocable as well.
+ * testsuite/20_util/function_objects/not_fn/87538.cc: New test.
+
+2018-10-08 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/list (list<>::cbegin()): Use C++11 direct
+ initialization.
+ (list<>::cend()): Likewise.
+ (list<>::emplace<>(const_iterator, _Args&&...)): Likewise.
+ (list<>::insert(const_iterator, initializer_list<>)): Likewise.
+ (list<>::insert(const_iterator, size_type, const _Tp&)): Likewise.
+ (list<>::erase(const_iterator, const_iterator)): Ensure consistent
+ iterator comparisons.
+ (list<>::splice(const_iterator, list&&, const_iterator,
+ const_iterator)): Likewise.
+
+2018-10-05 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_tree.h
+ (_Rb_tree_iterator<>::operator==): Make inline friend.
+ (_Rb_tree_iterator<>::operator!=): Likewise.
+ (_Rb_tree_const_iterator<>::operator==): Likewise.
+ (_Rb_tree_const_iterator<>::operator!=): Likewise.
+ (operator==(const _Rb_tree_iterator<>&,
+ const _Rb_tree_const_iterator&)): Remove.
+ (operator!=(const _Rb_tree_iterator<>&,
+ const _Rb_tree_const_iterator&)): Remove.
+ (operator==(const _Rb_tree<>&, const _Rb_tree<>&)): Make inline friend.
+ (operator<(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
+ (operator!=(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise and
+ deprecate.
+ (operator>(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
+ (operator<=(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
+ (operator>=(const _Rb_tree<>&, const _Rb_tree<>&)): Likewise.
+ * include/debug/map.h (map<>::erase(const_iterator, const_iterator)):
+ Compare __victim with _Base::cend().
+ * include/debug/multimap.h
+ (multimap<>::erase(const_iterator, const_iterator)): Likewise.
+ * include/debug/set.h (set<>::erase(const_iterator, const_iterator)):
+ Compare __victim with _Base::cend().
+ * include/debug/multiset.h
+ (multiset<>::erase(const_iterator, const_iterator)): Likewise.
+
+2018-10-03 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/59439
+ * src/c++98/locale.cc (locale::locale(const locale&)): Bypass
+ reference count updates for the classic locale.
+ (locale::~locale()): Likewise.
+ (locale::operator=(const locale&)): Likewise.
+ * src/c++98/locale_init.cc (locale::locale()): Likewise.
+ (locale::global(const locale&)): Likewise.
+
+2018-10-03 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/map.h
+ (map<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
+ (map<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (map<>::insert(value_type&&)): Likewise.
+ (map<>::insert<>(_Pair&&)): Likewise.
+ (map<>::insert<>(const_iterator, _Pair&&)): Likewise.
+ (map<>::try_emplace): Likewise.
+ (map<>::insert_or_assign): Likewise.
+ (map<>::insert(node_type&&)): Likewise.
+ (map<>::insert(const_iterator, node_type&&)): Likewise.
+ (map<>::erase(const_iterator)): Likewise.
+ (map<>::erase(const_iterator, const_iterator)): Likewise.
+ * include/debug/multimap.h
+ (multimap<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
+ (multimap<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (multimap<>::insert<>(_Pair&&)): Likewise.
+ (multimap<>::insert<>(const_iterator, _Pair&&)): Likewise.
+ (multimap<>::insert(node_type&&)): Likewise.
+ (multimap<>::insert(const_iterator, node_type&&)): Likewise.
+ (multimap<>::erase(const_iterator)): Likewise.
+ (multimap<>::erase(const_iterator, const_iterator)): Likewise.
+ * include/debug/set.h
+ (set<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
+ (set<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (set<>::insert(value_type&&)): Likewise.
+ (set<>::insert<>(const_iterator, value_type&&)): Likewise.
+ (set<>::insert(const_iterator, node_type&&)): Likewise.
+ (set<>::erase(const_iterator)): Likewise.
+ (set<>::erase(const_iterator, const_iterator)): Likewise.
+ * include/debug/multiset.h
+ (multiset<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
+ (multiset<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
+ (multiset<>::insert<>(value_type&&)): Likewise.
+ (multiset<>::insert<>(const_iterator, value_type&&)): Likewise.
+ (multiset<>::insert(node_type&&)): Likewise.
+ (multiset<>::insert(const_iterator, node_type&&)): Likewise.
+ (multiset<>::erase(const_iterator)): Likewise.
+ (multiset<>::erase(const_iterator, const_iterator)): Likewise.
+
+2018-10-02 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/87258
+ * include/bits/stl_bvector.h (vector::begin(), vector::cbegin()):
+ Rebuild _M_start with an explicit 0 offset.
+
+2018-10-02 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/variant (__gen_vtable_impl::__visit_invoke): Call __get
+ directly instead of get, as caller ensures correct index is used.
+ (holds_alternative, get, get_if): Remove redundant inline specifiers.
+ (_VARIANT_RELATION_FUNCTION_TEMPLATE): Likewise.
+
+2018-10-02 Joseph Myers <joseph@codesourcery.com>
+
+ * testsuite/lib/libstdc++.exp (libstdc++_init): Use
+ -fno-show-column in default cxxflags.
+
+2018-10-01 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
+
+ * config/os/uclibc/os_defines.h (__NO_STRING_INLINES): Delete.
+
+2018-10-01 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/allocator.xml: Adjust link to "Reconsidering
+ Custom Memory Allocation".
+
+2018-10-01 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/html/*: Regenerate.
+
+2018-09-30 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/messages.xml: Switch link to www.oracle.com
+ to https.
+
+2018-09-30 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/policy_data_structures_biblio.xml: Update
+ link to Microsoft Component Model Object Technologies.
+
+2018-09-29 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/gnu/fdl-1.3.xml: The Free Software Foundation web
+ site now uses https. Also omit the unnecessary trailing slash.
+ * doc/xml/gnu/gpl-3.0.xml: Ditto.
+
+2018-09-28 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/functions.h
+ (__foreign_iterator_aux3(const _Safe_iterator<>&, const _InputeIter&,
+ const _InputIter&, __true_type)): Use empty() rather than begin() ==
+ end().
+
+2018-09-25 Mike Crowe <mac@mcrowe.com>
+
+ * include/std/condition_variable (condition_variable::wait_for): Use
+ steady clock in overload that uses a predicate.
+
+2018-09-25 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87431
+ * include/std/variant (_Variant_storage<true, _Types...>::_M_valid):
+ Avoid runtime test when all alternatives are scalars and so cannot
+ throw during initialization.
+
+2018-09-25 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/codecvt.xml: Move link to "UTF-8 and Unicode FAQ"
+ to https.
+
+2018-09-24 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/policy_data_structures_biblio.xml: Update link
+ to "Priority Queues and the STL".
+
+2018-09-23 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/using_exceptions.xml: Move boost.orgs link to
+ https.
+
+2018-09-21 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/87135
+ * src/c++11/hashtable_c++0x.cc (_Prime_rehash_policy::_M_next_bkt):
+ Use __builtin_floor to compute _M_next_resize.
+ * testsuite/23_containers/unordered_set/hash_policy/71181.cc: Adapt.
+ * testsuite/23_containers/unordered_set/hash_policy/prime_rehash.cc:
+ Adapt.
+
+2018-09-21 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/26_numerics/headers/cmath/hypot-long-double.cc: Remove.
+ * testsuite/26_numerics/headers/cmath/hypot.cc: Restore test for
+ long double unconditionally, but use lower tolerance when
+ sizeof(long double) == sizeof(double).
+
+2018-09-20 Christophe Lyon <christophe.lyon@linaro.org>
+
+ * testsuite/26_numerics/headers/cmath/hypot-long-double.cc: Skip
+ on arm*.
+
+2018-09-19 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/regex_automaton.tcc (_StateSeq<_TraitsT>::_M_clone()):
+ Remove __glibcxx_assert statements and use map::find instead of
+ map::operator[].
+
+2018-09-18 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/87135
+ * src/c++11/hashtable_c++0x.cc:
+ (_Prime_rehash_policy::_M_next_bkt): Return a prime no smaller than
+ requested size, but not necessarily greater.
+ (_Prime_rehash_policy::_M_need_rehash): Rehash only if target size is
+ strictly greater than next resize threshold.
+ * testsuite/23_containers/unordered_map/modifiers/reserve.cc: Adapt test
+ to validate that there is no rehash as long as number of insertion is
+ lower or equal to the reserved number of elements.
+
+2018-09-18 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/unique_ptr.h (__uniq_ptr_impl): Remove static assertion
+ checking invocable condition.
+ (unique_ptr::~unique_ptr, unique_ptr::reset): Restore static assertion
+ here, where types must be complete. Pass pointer to deleter as an
+ rvalue.
+ * testsuite/20_util/unique_ptr/requirements/incomplete.cc: New test.
+
+2018-09-13 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/variant (variant) [__clang__]: Limit workaround to
+ Clang 7 and older.
+
+2018-09-11 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87278
+ * include/bits/shared_ptr.h (make_shared): Use remove_cv instead of
+ remove_const.
+ * testsuite/20_util/shared_ptr/creation/87278.cc: New test.
+
+ Implement LWG 2905 changes to constrain unique_ptr constructors
+ * include/bits/unique_ptr.h (__uniq_ptr_impl): Add assertions to
+ check deleter type.
+ (unique_ptr::unique_ptr(pointer, const deleter_type&)): Add copy
+ constructible constraint.
+ (unique_ptr::unique_ptr(pointer, deleter_type&&)): Disable for
+ deleters of reference type and add move constructible constraint.
+ (unique_ptr::unique_ptr(pointer, remove_reference_t<deleter_type>&&)):
+ Disable for deleters of non-reference type. Define as deleted.
+ (unique_ptr<T[], D>): Likewise.
+ * testsuite/20_util/unique_ptr/assign/48635_neg.cc: Replace dg-error
+ directives with unstable line numbers with dg-prune-output.
+ * testsuite/20_util/unique_ptr/cons/cv_qual_neg.cc: Likewise.
+ * testsuite/20_util/unique_ptr/cons/lwg2905.cc: New test.
+ * testsuite/20_util/unique_ptr/specialized_algorithms/swap_cxx17.cc:
+ Make deleter types invocable.
+
+2018-09-05 Jonathan Wakely <jwakely@redhat.com>
+
+ * libsupc++/cxxabi.h (__cxa_demangle): Clarify doxygen comment.
+
+2018-09-03 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/78179
+ * testsuite/26_numerics/headers/cmath/hypot-long-double.cc: New test
+ that runs the long double part of hypot.cc.
+ * testsuite/26_numerics/headers/cmath/hypot.cc: Disable long double
+ tests unless TEST_HYPOT_LONG_DOUBLE is defined.
+
+ * include/bits/stl_vector.h (vector::_Temporary_value::_M_ptr):
+ Return raw pointer not allocator's pointer type.
+ (vector::_Temporary_value::_M_val): Use _M_ptr.
+
+ PR libstdc++/87194
+ * include/bits/stl_map.h
+ (map::map(initializer_list<value_type>, const Compare&, const Alloc&))
+ (map::map(initializer_list<value_type>, const Alloc&))
+ (map::map(InputIterator, InputIterator, const Alloc&))
+ (map::map(InputIterator, InputIterator))
+ (map::map(InputIterator, InputIterator, const Compare&, const Alloc&))
+ (map::insert(InputIterator, InputIterator)):
+ Call _M_insert_range_unique instead of _M_insert_unique.
+ * include/bits/stl_multimap.h
+ (multimap::multimap(initializer_list<value_type>, const C&, const A&))
+ (multimap::multimap(initializer_list<value_type>, const A&))
+ (multimap::multimap(InputIterator, InputIterator, const A&))
+ (multimap::multimap(InputIterator, InputIterator))
+ (multimap::multimap(InputIterator, InputIterator, const C&, const A&))
+ (multimap::insert(InputIterator, InputIterator)): Call
+ _M_insert_range_equal instead of _M_insert_equal.
+ * include/bits/stl_multiset.h
+ (multiset::multiset(InputIterator, InputIterator))
+ (multiset::multiset(InputIterator, InputIterator, const C&, const A&))
+ (multiset::multiset(initializer_list<value_type>, const C&, const A&))
+ (multiset::multiset(initializer_list<value_type>, const A&))
+ (multiset::multiset(InputIterator, InputIterator, const A&))
+ (multiset::insert(InputIterator, InputIterator)): Call
+ _M_insert_range_equal instead of _M_insert_equal.
+ * include/bits/stl_set.h
+ (set::set(InputIterator, InputIterator))
+ (set::set(InputIterator, InputIterator, const Compare&, const Alloc&))
+ (set::set(initializer_list<value_type>, const Compare&, const Alloc&))
+ (set::set(initializer_list<value_type>, const Alloc&))
+ (set::set(InputIterator, InputIterator, const Alloc&))
+ (set::insert(InputIterator, InputIterator)):
+ Call _M_insert_range_unique instead of _M_insert_unique.
+ * include/bits/stl_tree.h
+ [__cplusplus >= 201103L] (_Rb_tree::__same_value_type): New alias
+ template for SFINAE constraints.
+ [__cplusplus >= 201103L] (_Rb_tree::_M_insert_range_unique): Pair of
+ constrained overloads that either insert or emplace, depending on
+ iterator's value_type.
+ [__cplusplus >= 201103L] (_Rb_tree::_M_insert_range_equal): Likewise.
+ [__cplusplus < 201103L] (_Rb_tree::_M_insert_range_unique)
+ (_Rb_tree::_M_insert_range_equal): New functions replacing range
+ versions of _M_insert_unique and _M_insert_equal.
+ (_Rb_tree::_M_insert_unique(_InputIterator, _InputIterator))
+ (_Rb_tree::_M_insert_equal(_InputIterator, _InputIterator)): Remove.
+ * testsuite/23_containers/map/modifiers/insert/87194.cc: New test.
+ * testsuite/23_containers/multimap/modifiers/insert/87194.cc: New test.
+ * testsuite/23_containers/multiset/modifiers/insert/87194.cc: New test.
+ * testsuite/23_containers/set/modifiers/insert/87194.cc: New test.
+
+ PR libstdc++/78595
+ * include/bits/stl_map.h (map::insert(_Pair&&))
+ (map::insert(const_iterator, _Pair&&)): Do emplace instead of insert.
+ * include/bits/stl_multimap.h (multimap::insert(_Pair&&))
+ (multimap::insert(const_iterator, _Pair&&)): Likewise.
+ * include/bits/unordered_map.h (unordered_map::insert(_Pair&&))
+ (unordered_map::insert(const_iterator, _Pair&&))
+ (unordered_multimap::insert(_Pair&&))
+ (unordered_multimap::insert(const_iterator, _Pair&&)): Likewise.
+ * testsuite/23_containers/map/modifiers/insert/78595.cc: New test.
+ * testsuite/23_containers/multimap/modifiers/insert/78595.cc: New test.
+ * testsuite/23_containers/unordered_map/modifiers/78595.cc: New test.
+ * testsuite/23_containers/unordered_multimap/modifiers/78595.cc: New
+ test.
+
+2018-09-02 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/safe_iterator.h
+ (_Safe_iterator<_It, _Seq, _Cat>::_Self): New.
+ (_Safe_iterator<_It, _Seq, std::random_access_iterator_tag>::_Self):
+ New.
+ (_Safe_iterator<_It, _Seq, std::random_access_iterator_tag>
+ ::_OtherSelf): New.
+ (_GLIBCXX_DEBUG_VERIFY_OPERANDS, _GLIBCXX_DEBUG_VERIFY_EQ_OPERANDS)
+ (_GLIBCXX_DEBUG_VERIFY_REL_OPERANDS)
+ (_GLIBCXX_DEBUG_VERIFY_DIST_OPERANDS): Define macros.
+ (_Safe_iterator<_It, _Seq, std::random_access_iterator_tag>
+ ::operator+(difference_type)): Use latters, inline as friend.
+ (_Safe_iterator<_It, _Seq, std::random_access_iterator_tag>
+ ::operator-(difference_type)): Likewise.
+ (operator==(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Likewise.
+ (operator!=(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Likewise.
+ (operator<(const _Safe_iterator<>&, const _Safe_iterator<>&)): Likewise.
+ (operator<=(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Likewise.
+ (operator>(const _Safe_iterator<>&, const _Safe_iterator<>&)): Likewise.
+ (operator>=(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Likewise.
+ (operator-(const _Safe_iterator<>&, const _Safe_iterator<>&)): Likewise.
+ (operator+(difference_type, const _Safe_iterator<>&)): Likewise.
+ (operator-(const _Safe_iterator<>&, difference_type)): Likewise.
+ * include/debug/safe_iterator.tcc
+ (_Safe_iterator<>::_M_can_advance(difference_type)): Take parameter by
+ copy.
+ * include/debug/safe_local_iterator.h
+ (_Safe_local_iterator<_It, _Seq>::_Self): New.
+ (_Safe_local_iterator<_It, _Seq>::_OtherSelf): New.
+ (_GLIBCXX_DEBUG_VERIFY_OPERANDS): Define macro.
+ (operator==(const _Safe_local_iterator<>&,
+ const _Safe_local_iterator<>&)): Use latter, inline as friend.
+ (operator!=(const _Safe_local_iterator<>&,
+ const _Safe_local_iterator<>&)): Likewise.
+ * testsuite/util/testsuite_containers.h: Include utility.
+ (struct forward_members_unordered<_Tp, bool>): Remove 2nd template
+ parameter.
+ (forward_members_unordered<>::forward_members_unordered(value_type&)):
+ Add using namespace std::rel_ops.
+ Add iterator_concept_checks on local_iterator and const_local_iterator.
+ Add asserts on comparison between const_local_iterator and
+ local_iterator.
+ (struct forward_members_unordered<_Tp, false>): Remove partial
+ specialization.
+ * testsuite/23_containers/forward_list/types/1.cc: New.
+ * testsuite/23_containers/list/types/1.cc: New.
+
+2018-09-01 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/profile_mode.xml: Update three ieeexplore.ieee.org
+ references.
+
+2018-08-31 Sandra Loosemore <sandra@codesourcery.com>
+
+ * testsuite/21_strings/basic_string/inserters_extractors/wchar_t/10.cc:
+ Add dg-require-fileio.
+ * testsuite/21_strings/basic_string/inserters_extractors/wchar_t/11.cc:
+ Likewise.
+ * testsuite/21_strings/basic_string/inserters_extractors/wchar_t/5.cc:
+ Likewise.
+ * testsuite/21_strings/basic_string_view/inserters/wchar_t/2.cc:
+ Likewise.
+ * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/4.cc:
+ Likewise.
+ * testsuite/25_algorithms/find/istreambuf_iterators/wchar_t/2.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/close/wchar_t/12790-1.cc: Likewise.
+ * testsuite/27_io/basic_filebuf/close/wchar_t/12790-2.cc: Likewise.
+ * testsuite/27_io/basic_filebuf/close/wchar_t/12790-3.cc: Likewise.
+ * testsuite/27_io/basic_filebuf/close/wchar_t/12790-4.cc: Likewise.
+ * testsuite/27_io/basic_filebuf/seekoff/wchar_t/11543.cc: Likewise.
+ * testsuite/27_io/basic_filebuf/seekoff/wchar_t/12790-1.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/seekoff/wchar_t/12790-2.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/seekoff/wchar_t/12790-3.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/seekoff/wchar_t/12790-4.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/seekpos/wchar_t/12790-1.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/seekpos/wchar_t/12790-2.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/seekpos/wchar_t/12790-4.cc:
+ Likewise.
+ * testsuite/27_io/basic_filebuf/underflow/wchar_t/2.cc: Likewise.
+ * testsuite/27_io/basic_filebuf/underflow/wchar_t/3.cc: Likewise.
+ * testsuite/27_io/basic_ifstream/cons/wchar_t/1.cc: Likewise.
+ * testsuite/27_io/basic_ifstream/open/wchar_t/1.cc: Likewise.
+ * testsuite/27_io/basic_istream/extractors_character/wchar_t/4.cc:
+ Likewise.
+ * testsuite/27_io/basic_istream/extractors_other/wchar_t/2.cc:
+ Likewise.
+ * testsuite/27_io/basic_istream/get/wchar_t/2.cc: Likewise.
+ * testsuite/27_io/basic_istream/getline/wchar_t/5.cc: Likewise.
+ * testsuite/27_io/basic_istream/ignore/wchar_t/2.cc: Likewise.
+ * testsuite/27_io/basic_istream/ignore/wchar_t/3.cc: Likewise.
+ * testsuite/27_io/basic_istream/seekg/wchar_t/sstream.cc: Likewise.
+ * testsuite/27_io/basic_istream/tellg/wchar_t/sstream.cc: Likewise.
+ * testsuite/27_io/basic_ofstream/cons/wchar_t/1.cc: Likewise.
+ * testsuite/27_io/basic_ofstream/open/wchar_t/1.cc: Likewise.
+ * testsuite/27_io/basic_ostream/inserters_other/wchar_t/1.cc:
+ Likewise.
+ * testsuite/27_io/objects/wchar_t/10.cc: Likewise.
+ * testsuite/27_io/objects/wchar_t/12048-1.cc: Likewise.
+ * testsuite/27_io/objects/wchar_t/12048-2.cc: Likewise.
+ * testsuite/27_io/objects/wchar_t/12048-3.cc: Likewise.
+ * testsuite/27_io/objects/wchar_t/12048-4.cc: Likewise.
+ * testsuite/27_io/objects/wchar_t/12048-5.cc: Likewise.
+ * testsuite/experimental/string_view/inserters/wchar_t/2.cc:
+ Likewise.
+ * testsuite/ext/stdio_sync_filebuf/wchar_t/1.cc: Likewise.
+
+2018-08-30 Sandra Loosemore <sandra@codesourcery.com>
+
+ * testsuite/experimental/propagate_const/observers/1.cc: Make
+ dependence on -fdelete-null-pointer-checks explicit.
+
+2018-08-30 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/hashtable_policy.h (__clp2): Fix calculation for LLP64
+ targets where sizeof(size_t) > sizeof(long). Avoid undefined shifts
+ of the number of bits in the type.
+ * include/std/bit (__ceil2): Avoid undefined shifts.
+ * testsuite/26_numerics/bit/bit.pow.two/ceil2.cc: Test values with
+ the most signifiant bit set.
+
+ * config/abi/pre/gnu.ver: Add missing exports for mingw.
+
+ * include/ext/pointer.h (_Pointer_adapter): Define operators for
+ pointer arithmetic using long long offsets.
+ * testsuite/ext/ext_pointer/1.cc: Test pointer arithmetic using
+ long long values.
+
+2018-08-29 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/31413
+ * testsuite/22_locale/time_get/get_date/wchar_t/4.cc: Check D_FMT
+ string for alternative format.
+
+2018-08-28 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87116
+ * src/filesystem/std-path.cc (path::lexically_normal): When handling
+ a dot-dot filename, preserve an empty final component in the iteration
+ sequence.
+ [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Use preferred-separator for
+ root-directory.
+ * testsuite/27_io/filesystem/path/generation/normal.cc: Add new tests
+ for more than two adjacent dot-dot filenames.
+ [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Replace slashes with
+ preferred-separator in expected normalized strings.
+
+2018-08-25 Iain Sandoe <iain@sandoe.co.uk>
+
+ PR libstdc++/70694
+ * configure.host (OPT_LDFLAGS): Don't append
+ -fvisibility-inlines-hidden for newer Darwin.
+
+2018-08-24 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/86822
+ * libsupc++/new (operator new(size_t, nothrow_t), operator
+ new[](size_t, nothrow_t), operator new(size_t, align_val_t, nothrow_t),
+ operator new[](size_t, align_val_t, nothrow_t)): Add malloc attribute.
+
+2018-08-24 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/debug/deque (std::__debug::deque): Declare.
+ * include/debug/forward_list (std::__debug::forward_list): Declare.
+ * include/debug/list (std::__debug::list): Declare.
+ * include/debug/map (std::__debug::map): Declare.
+ * include/debug/set (std::__debug::set): Declare.
+ * include/debug/unordered_map (std::__debug::unordered_map): Declare.
+ * include/debug/unordered_set (std::__debug::unordered_set): Declare.
+ * include/debug/vector (std::__debug::vector): Declare.
+ * testsuite/23_containers/deque/types/pmr_typedefs_debug.cc: New test.
+ * testsuite/23_containers/forward_list/pmr_typedefs_debug.cc: New
+ test.
+ * testsuite/23_containers/list/pmr_typedefs_debug.cc: New test.
+ * testsuite/23_containers/map/pmr_typedefs_debug.cc: New test.
+ * testsuite/23_containers/multimap/pmr_typedefs_debug.cc: New test.
+ * testsuite/23_containers/multiset/pmr_typedefs_debug.cc: New test.
+ * testsuite/23_containers/set/pmr_typedefs_debug.cc: New test.
+ * testsuite/23_containers/unordered_map/pmr_typedefs_debug.cc: New
+ test.
+ * testsuite/23_containers/unordered_multimap/pmr_typedefs_debug.cc:
+ New test.
+ * testsuite/23_containers/unordered_multiset/pmr_typedefs_debug.cc:
+ New test.
+ * testsuite/23_containers/unordered_set/pmr_typedefs_debug.cc: New
+ test.
+ * testsuite/23_containers/vector/cons/destructible_debug_neg.cc:
+ Adjust dg-error lineno.
+ * testsuite/23_containers/vector/types/pmr_typedefs_debug.cc: New
+ test.
+
+2018-08-23 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/util/testsuite_allocator.h (__gnu_test::memory_resource):
+ Only define when RTTI is enabled.
+
+ * include/debug/vector (__niter_base): Define for C++98.
+
+ * testsuite/25_algorithms/partial_sort_copy/debug/irreflexive_neg.cc:
+ Fix C++98 test to not use C++11 features.
+ * testsuite/25_algorithms/fill_n/2.cc: Likewise.
+
+ * scripts/check_compile: Fix comments.
+
+ * include/debug/string (insert(__const_iterator, _InIter, _InIter)):
+ [!_GLIBCXX_USE_CXX11_ABI]: Replace use of C++11-only cbegin() with
+ begin(), for C++98 compatibility.
+
+ * include/bits/basic_string.h [_GLIBCXX_USE_CXX11_ABI]
+ (basic_string::__const_iterator): Change access to protected.
+ [!_GLIBCXX_USE_CXX11_ABI] (basic_string::__const_iterator): Define
+ as typedef for iterator.
+ * include/debug/string (__const_iterator): Use typedef from base.
+ (insert(const_iterator, _CharT))
+ (replace(const_iterator, const_iterator, const basic_string&))
+ (replace(const_iterator, const_iterator, const _CharT*, size_type))
+ (replace(const_iterator, const_iterator, const CharT*))
+ (replace(const_iterator, const_iterator, size_type, _CharT))
+ (replace(const_iterator, const_iterator, _InputIter, _InputIter))
+ (replace(const_iterator, const_iterator, initializer_list<_CharT>)):
+ Change const_iterator parameters to __const_iterator.
+ (insert(iterator, size_type, _CharT)): Add C++98 overload.
+ (insert(const_iterator, _InputIterator, _InputIterator)): Change
+ const_iterator parameter to __const_iterator.
+ [!_GLIBCXX_USE_CXX11_ABI]: Add workaround for incorrect return type
+ of base's member function.
+ (insert(const_iterator, size_type, _CharT)) [!_GLIBCXX_USE_CXX11_ABI]:
+ Likewise.
+ (insert(const_iterator, initializer_list<_CharT>))
+ [!_GLIBCXX_USE_CXX11_ABI]: Likewise.
+ * testsuite/21_strings/basic_string/init-list.cc: Remove effective
+ target directive.
+
+ * testsuite/20_util/reference_wrapper/lwg2993.cc: Fix C++11 test to
+ not use C++14 feature.
+ * testsuite/23_containers/list/68222_neg.cc: Likewise.
+
+ * testsuite/21_strings/basic_string/init-list.cc:
+ Require cxx11-abi.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_match.cc:
+ Likewise.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_string.cc:
+ Likewise.
+
+ * testsuite/23_containers/deque/capacity/max_size.cc: Fix test for
+ C++98 mode.
+ * testsuite/23_containers/deque/modifiers/assign/1.cc: Likewise.
+ * testsuite/23_containers/list/modifiers/assign/1.cc: Likewise.
+ * testsuite/23_containers/vector/bool/modifiers/assign/1.cc: Likewise.
+ * testsuite/23_containers/vector/capacity/max_size.cc: Likewise.
+ * testsuite/23_containers/vector/modifiers/assign/1.cc: Likewise.
+
+2018-08-22 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/87061
+ * include/experimental/regex [!_GLIBCXX_USE_CXX11_ABI]
+ (experimental::pmr::match_results, experimental::pmr::cmatch)
+ (experimental::pmr::smatch, experimental::pmr::wcmatch)
+ (experimental::pmr::wsmatch): Do not declare for gcc4-compatible ABI,
+ because COW strings don't support C++11 allocator model.
+ * include/experimental/string [!_GLIBCXX_USE_CXX11_ABI]
+ (experimental::pmr::basic_string, experimental::pmr::string)
+ (experimental::pmr::u16string, experimental::pmr::u32string)
+ (experimental::pmr::wstring): Likewise.
+ * include/std/regex [!_GLIBCXX_USE_CXX11_ABI] (pmr::match_results)
+ (pmr::cmatch, pmr::smatch, pmr::wcmatch, pmr::wsmatch): Likewise.
+ * include/std/string [!_GLIBCXX_USE_CXX11_ABI] (pmr::basic_string)
+ (pmr::string, pmr::u16string, pmr::u32string, pmr::wstring): Likewise.
+ * testsuite/21_strings/basic_string/types/pmr_typedefs.cc: Require
+ cxx11-abi.
+ * testsuite/28_regex/match_results/pmr_typedefs.cc: Likewise.
+
+ PR libstdc++/78448
+ * include/bits/deque.tcc (deque::_M_range_initialize): Use
+ _S_check_init_len to check size.
+ (deque::_M_push_back_aux, deque::_M_push_front_aux): Throw length
+ error if size would exceed max_size().
+ * include/bits/stl_deque.h (_Deque_base::size_type): Remove typedef.
+ (_Deque_base(_Deque_base&&, const allocator_type&, size_t)): Use
+ size_t instead of size_type.
+ (deq(size_type, const allocator_type&)
+ (deq(size_type, const value_type&, const allocator_type&)
+ (deque::_M_initialize_dispatch): Use _S_check_init_len to check size.
+ (deque::max_size): Call _S_max_size.
+ (deque::_S_check_init_len, deque::_S_max_size): New functions.
+ * include/bits/stl_vector.h (vector(size_type, const allocator_type&))
+ (vector(size_type, const value_type&, const allocator_type&))
+ (vector::_M_initialize_dispatch, vector::_M_range_initialize): Use
+ _S_check_init_len to check size.
+ (vector::max_size): Call _S_max_size.
+ (vector::_M_check_len): Prevent max from being expanded as a
+ function-like macro.
+ (vector::_S_check_init_len, vector::_S_max_size): New functions.
+ * include/bits/vector.tcc (vector::_M_assign_aux): Use
+ _S_check_init_len to check size.
+ * testsuite/23_containers/deque/capacity/max_size.cc: New test.
+ * testsuite/23_containers/vector/capacity/max_size.cc: New test.
+
+2018-08-22 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/68222
+ * include/debug/safe_iterator.h
+ (_Safe_iterator<_It, _Sq, _Cat>): Add category template parameter.
+ (_Safe_iterator<>::_Const_iterator): Remove.
+ (_Safe_iterator<>::_IsConstant): New.
+ (_Safe_iterator<>::_OtherIterator): New.
+ (_Safe_iterator<_It, _Sq, _Cat>::_Safe_iterator<_MutIte>(
+ const _Safe_iterator<_MutIte, _Sq, _Cat>&)): Add _IsConstant::__value in
+ __gnu_cxx::__enable_if condition.
+ (_Safe_iterator<_It, _Sq, _Cat>::_M_get_distance_to): New.
+ (_Safe_iterator<_It, _Sq, _Cat>::_M_get_distance_from_begin): New.
+ (_Safe_iterator<_It, _Sq, _Cat>::_M_get_distance_to_end): New.
+ (_Safe_iterator<_It, _Sq, std::bidirectional_iterator_tag>): New.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator--()): Move...
+ (_Safe_iterator<_It, _Sq, std::bidirectional_iterator_tag>
+ ::operator--()): ...here.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator--(int)): Move...
+ (_Safe_iterator<_It, _Sq, std::bidirectional_iterator_tag>
+ ::operator--(int)): ...here.
+ (_Safe_iterator<_It, _Sq, _Cat>::_M_decrementable()): Move...
+ (_Safe_iterator<_It, _Sq, std::bidirectional_iterator_tag>
+ ::_M_decrementable()): ...here.
+ (_Safe_iterator<_It, _Sq, std::random_access_iterator_tag>): New.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator[](const difference_type&)):
+ Move...
+ (_Safe_iterator<_It, _Sq, std::random_access_iterator_tag>
+ ::operator[](const difference_type&)): ...here.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator+=(const difference_type&)):
+ Move...
+ (_Safe_iterator<_It, _Sq, std::random_access_iterator_tag>
+ ::operator+=(const difference_type&)): ...here.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator+(const difference_type&)):
+ Move...
+ (_Safe_iterator<_It, _Sq, std::random_access_iterator_tag>
+ ::operator+(const difference_type&)): ...here.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator-=(const difference_type&)):
+ Move...
+ (_Safe_iterator<_It, _Sq, std::random_access_iterator_tag>
+ ::operator-=(const difference_type&)): ...here.
+ (_Safe_iterator<_It, _Sq, _Cat>::operator-(const difference_type&)):
+ Move...
+ (_Safe_iterator<_It, _Sq, std::random_access_iterator_tag>
+ ::operator-(const difference_type&)): ...here.
+ (operator<(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Constraint to random access iterators.
+ (operator<=(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Likewise.
+ (operator>(const _Safe_iterator<>&, const _Safe_iterator<>&)): Likewise.
+ (operator>=(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Likewise.
+ (operator-(const _Safe_iterator<>&, const _Safe_iterator<>&)): Likewise.
+ (operator+(const difference_type&, const _Safe_iterator<>&)): Likewise.
+ (__check_dereferenceable(const _Safe_iterator<>&)): Remove.
+ (__get_distance): Remove.
+ (__get_distance_from_begin): Remove.
+ (__get_distance_to_end): Remove.
+ (struct __is_safe_random_iterator<_Safe_iterator<>>): Remove partial
+ specialization.
+ (__base(const _Safe_iterator<>&, std::input_iterator_tag)): Remove.
+ (__base(const _Safe_iterator<>&, std::random_access_iterator_tag)): Remove.
+ (__base(const _Safe_iterator<>&)): Constraint to random access iterator.
+ * include/debug/safe_iterator.tcc
+ (_Safe_iterator<>::_M_get_distance_from_begin()): New.
+ (_Safe_iterator<>::_M_get_distance_to_end()): New.
+ (_Safe_iterator<>::_M_get_distance_to(const _Safe_iterator<>&)): New.
+ (_Safe_iterator<_It, _Seq, std::random_access_iterator_tag>
+ ::_M_valid_range): New.
+ * include/debug/safe_local_iterator.h
+ (_Safe_local_iterator<>::_Const_local_iterator): Remove.
+ (_Safe_local_iterator<>::_IsConstant): New.
+ (_Safe_local_iterator<>::_OtherIterator): New.
+ (_Safe_local_iterator<_It, _Cont>::_Safe_local_iterator<_MutIte, _Cont>(
+ const _Safe_local_iterator<_MutIte, _Seq>&)): Add _IsConstant::__value
+ in __gnu_cxx::__enable_if condition. If singular compare base iterator
+ with _MutIte rather than _It.
+ (_Safe_local_iterator<>::_S_constant): Make constexpr.
+ (_Safe_local_iterator<>::_M_get_distance_to): New.
+ (__check_dereferenceable(const _Safe_local_iterator<>&)): Remove.
+ (__get_distance(const _Safe_local_iterator<>&,
+ const _Safe_local_iterator<>&, std::input_iterator_tag)): Remove.
+ (__valid_range(const _Safe_local_iterator<>&,
+ const _Safe_local_iterator<>&)): New.
+ * include/debug/safe_local_iterator.tcc
+ (_Safe_local_iterator<>::_M_get_distance_to): New.
+ * include/debug/deque (std::__debug::deque<>): Add
+ ::__gnu_debug::_Safe_iterator<> friend declaration.
+ * include/debug/forward_list (std::__debug::forward_list<>): Likewise.
+ * include/debug/list (std::__debug::list<>): Likewise.
+ * include/debug/map.h (std::__debug::map<>): Likewise.
+ * include/debug/multimap.h (std::__debug::multimap<>): Likewise.
+ * include/debug/set.h (std::__debug::set<>): Likewise.
+ * include/debug/multiset.h (std::__debug::multiset<>): Likewise.
+ * include/debug/string (std::__debug::basic_string<>): Likewise.
+ * include/debug/unordered_map (std::__debug::unordered_map<>): Likewise
+ and add ::__gnu_debug::_Safe_local_iterator<> friend declaration.
+ (std::__debug::unordered_multimap<>): Likewise.
+ * include/debug/unordered_set (std::__debug::unordered_set<>): Likewise.
+ (std::__debug::unordered_multiset<>): Likewise.
+ * include/debug/formatter.h: Adapt.
+ * include/debug/helper_functions.h
+ (__gnu_debug::_Safe_local_iterator<>): Add declaration.
+ (__get_distance<_Ite>(_Ite, _Ite, std::random_access_iterator_tag):
+ Pass parameter by copy.
+ (__get_distance<_Ite>(_Ite, _Ite, std::input_iterator_tag): Likewise.
+ (__get_distance<_Ite>(_Ite, _Ite): Likewise.
+ (__valid_range_aux<_Integral>): Pass _Integral by copy.
+ (__valid_range<_InputIterator>): Pass _InputIterator by copy.
+ (__valid_range<>(const _Safe_iterator<>&,
+ const _Safe_iterator<>&, typename _Distance_traits<>::__type&)):
+ Declare.
+ (__valid_range(const _Safe_local_iterator<>&,
+ const _Safe_local_iterator<>&, typename _Distance_traits<>::__type&)):
+ Declare.
+ (__valid_range<>(const _Safe_iterator<>&, const _Safe_iterator<>&)):
+ Declare.
+ (__valid_range(const _Safe_local_iterator<>&, const _Safe_local_iterator<>&)):
+ Declare.
+ (__can_advance): Adapt.
+ (struct __is_safe_random_iterator<>): Remove.
+ (struct _SIter_base<>): Remove.
+ * include/debug/functions.h: Include <bits/stl_iterator.h>.
+ (__check_dereferenceable): Remove.
+ (__foreign_iterator_aux4, __foreign_iterator_aux3): Adapt.
+ (__foreign_iterator_aux2, __foreign_iterator_aux): Adapt.
+ (__foreign_iterator): Adapt.
+ * include/debug/stl_iterator.h
+ (__is_safe_random_iterator<std::reverse_iterator<>>): Remove.
+ (__base(const std::reverse_iterator<_Safe_iterator<_It, _Sq>)):
+ Constraint for random access iterators.
+ (__niter_base): Adapt.
+ * testsuite/util/testsuite_containers.h:
+ Include <bits/boost_concept_check.h>.
+ (iterator_concept_checks<_It, _Mutable, _Category>): New.
+ (citerator<_Cont>::forward_members::forward_members()): Instantiate
+ latter for container iterator and const_iterator.
+ * testsuite/23_containers/list/68222_neg.cc: New.
+ * testsuite/23_containers/vector/cons/destructible_debug_neg.cc: Adapt
+ line number.
+ * testsuite/23_containers/unordered_set/debug/debug_functions.cc:
+ (test01): Remove.
+ * testsuite/23_containers/vector/debug/debug_functions.cc (test01):
+ Remove.
+
+2018-08-22 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/77854
+ * doc/xml/manual/status_cxx1998.xml: Document size_type and
+ difference_type for containers.
+ * doc/html/*: Regenerate.
+
+2018-08-21 François Dumont <fdumont@gcc.gnu.org>
+
+ P0646R1 Improving the Return Value of Erase-Like Algorithms I
+ * include/debug/forward_list (forward_list::__remove_return_type):
+ Define typedef as size_type or void, according to __cplusplus value.
+ (_GLIBCXX_FWDLIST_REMOVE_RETURN_TYPE_TAG): Define macro as abi-tag or
+ empty, according to __cplusplus value.
+ (_GLIBCXX20_ONLY): Define macro.
+ (forward_list::remove, forward_list::unique): Use typedef and macro
+ to change return type and add abi-tag for C++2a. Return number of
+ removed elements for C++2a.
+ (forward_list::remove_if<Pred>, forward_list::unique<BinPred>): Use
+ typedef to change return type for C++2a. Return number of removed
+ elements for C++2a.
+ * include/debug/list (list::__remove_return_type): Define typedef as
+ size_type or void, according to __cplusplus value.
+ (_GLIBCXX_LIST_REMOVE_RETURN_TYPE_TAG): Define macro as abi-tag or
+ empty, according to __cplusplus value.
+ (_GLIBCXX20_ONLY): Define macro.
+ (list::remove, list::unique): Use typedef and macro to change return
+ type and add abi-tag for C++2a. Return number of removed elements for
+ C++2a.
+ (list::remove_if<Predicate>, list::unique<BinaryPredicate>): Use typedef
+ to change return type for C++2a. Return number of removed elements for
+ C++2a.
+
+2018-08-21 David Edelsohn <dje.gcc@gmail.com>
+
+ * testsuite/18_support/new_nothrow.cc: XFAIL on AIX.
+
+2018-08-21 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/26_numerics/bit/bitops.count/countl_one.cc: Remove
+ redundant dg-do directive.
+ * testsuite/26_numerics/bit/bitops.count/countl_zero.cc: Likewise.
+ * testsuite/26_numerics/bit/bitops.count/countr_one.cc: Likewise.
+ * testsuite/26_numerics/bit/bitops.count/countr_zero.cc: Likewise.
+ * testsuite/26_numerics/bit/bitops.count/popcount.cc: Likewise.
+
+2018-08-20 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86963
+ * include/std/tuple (_Tuple_impl::operator=): Define as deleted.
+ (_Tuple_impl::_M_assign): New functions to perform assignment instead
+ of assignment operators.
+ (_Tuple_impl::_M_swap): Remove exception specification.
+ (_Tuple_impl<_Idx, _Head>): Likewise.
+ (_TC::_NonNestedTuple, _TC::_NotSameTuple): Use __remove_cvref_t.
+ (__tuple_base): Remove.
+ (tuple, tuple<_T1, _T2>): Remove inheritance from __tuple_base.
+ (tuple::operator=, tuple<_T1, _T2>::operator=): Call _M_assign.
+ (tuple::swap, tuple<_T1, _T2>::swap): Define exception specification
+ using __is_nothrow_swappable.
+ (tuple<_T1, _T2>::tuple(_U1&&, _U2&&)): Use __remove_cvref_t.
+
+ * include/std/optional (_Optional_payload): Use variable templates
+ for conditions in default template arguments and exception
+ specifications.
+ (optional): Likewise. Adjust indentation.
+ (optional::__not_self, optional::__not_tag, optional::_Requires): New
+ SFINAE helpers.
+ (optional::optional): Use new helpers in constructor constraints.
+ * include/std/type_traits (__or_v, __and_v): New variable templates.
+ * testsuite/20_util/optional/cons/value_neg.cc: Change dg-error to
+ dg-prune-output. Remove unused header.
+
+2018-08-18 François Dumont <fdumont@gcc.gnu.org>
+
+ * testsuite/25_algorithms/copy/86658.cc: Use dg-options to define
+ _GLIBCXX_DEBUG.
+
+2018-08-17 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86963
+ * include/std/tuple (__tuple_base): New class template with deleted
+ copy assignment operator.
+ (tuple, tuple<_T1, _T2>): Derive from __tuple_base<tuple> so that
+ implicit copy/move assignment operator will be deleted/suppressed.
+ (tuple::__assignable, tuple<_T1, _T2>::__assignable): New helper
+ functions for SFINAE constraints on assignment operators.
+ (tuple::__nothrow_assignable, tuple<_T1, _T2>::__nothrow_assignable):
+ New helper functions for exception specifications.
+ (tuple::operator=(const tuple&), tuple::operator=(tuple&&))
+ (tuple<_T1, _T2>::operator=(const tuple&))
+ (tuple<_T1, _T2>::operator=(tuple&&)): Change parameter types to
+ __nonesuch_no_braces when the operator should be defined implicitly.
+ Use __nothrow_assignable for exception specifications.
+ (tuple::operator=(const tuple<_UElements...>&))
+ (tuple::operator=(tuple<_UElements...>&&))
+ (tuple<_T1, _T2>::operator=(const tuple<_U1, _U2>&))
+ (tuple<_T1, _T2>::operator=(tuple<_U1, _U2>&&))
+ (tuple<_T1, _T2>::operator=(const pair<_U1, _U2>&))
+ (tuple<_T1, _T2>::operator=(pair<_U1, _U2>&&)): Constrain using
+ __assignable and use __nothrow_assignable for exception
+ specifications.
+ * python/libstdcxx/v6/printers.py (is_specialization_of): Accept
+ gdb.Type as first argument, instead of a string.
+ (StdTuplePrinter._iterator._is_nonempty_tuple): New method to check
+ tuple for expected structure.
+ (StdTuplePrinter._iterator.__init__): Use _is_nonempty_tuple.
+ * testsuite/20_util/tuple/dr2729.cc: New test.
+ * testsuite/20_util/tuple/element_access/get_neg.cc: Change dg-error
+ to dg-prune-output.
+
+2018-08-16 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/tr1/legendre_function.tcc (__sph_legendre): Avoid warning
+ about signed/unsigned comparison.
+
+ * include/std/ostream (basic_ostream::sentry::~sentry): Suppress
+ deprecation warnings for using uncaught_exception().
+
+ PR libstdc++/86447
+ * src/c++11/cow-stdexcept.cc [_GLIBCXX_FULLY_DYNAMIC_STRING]
+ (logic_error::logic_error(logic_error&&))
+ (logic_error::operator=(logic_error&&))
+ (runtime_error::runtime_error(runtime_error&&))
+ (runtime_error::operator=(runtime_error&&)): Copy strings instead of
+ moving, to avoid allocating empty reps for moved-from strings.
+
+2018-08-15 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/experimental/regex: Remove begin/end macros for namespace.
+ * include/experimental/string: Likewise.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_deque.cc:
+ New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_forward_list.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_list.cc:
+ New test.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_map.cc:
+ New test.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_match.cc:
+ New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_multimap.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_multiset.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_set.cc:
+ New test.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_string.cc:
+ New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_unordered_map.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_unordered_multimap.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_unordered_multiset.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/
+ pmr_typedefs_unordered_set.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/pmr_typedefs_vector.cc:
+ New test.
+
+ * include/bits/uses_allocator.h (__uses_allocator_construct): Qualify
+ calls to __uses_allocator_construct_impl and __use_alloc.
+ * include/experimental/memory_resource
+ (polymorphic_allocator::_M_construct): Remove.
+ (polymorphic_allocator::construct): Call __uses_allocator_construct.
+ Qualify calls to __use_alloc.
+ * include/std/memory_resource (polymorphic_allocator::construct): Fix
+ type in SFINAE constraint. Use constexpr if instead of tag dispatching
+ to _S_construct overloads.
+ (polymorphic_allocator::construct(pair<T1, T2>*, ...)): Fix order of
+ arguments to _S_construct_p.
+ (polymorphic_allocator::_S_construct): Remove.
+ (polymorphic_allocator::_S_construct_p): Return allocators by value
+ not by reference.
+ * include/std/scoped_allocator (scoped_allocator_adaptor::construct):
+ Qualify calls to __use_alloc.
+ * testsuite/20_util/polymorphic_allocator/construct_pair.cc: New test,
+ copied from testsuite/20_util/scoped_allocator/construct_pair.cc.
+ * testsuite/experimental/polymorphic_allocator/1.cc: New test.
+ * testsuite/experimental/polymorphic_allocator/construct_pair.cc:
+ New test.
+
+ * src/c++17/memory_resource.cc [!_GLIBCXX_HAS_GTHREADS]
+ (atomic_mem_res): Add unsynchronized definition for single-threaded.
+
+2018-08-14 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86954
+ * include/bits/stl_tempbuf.h (return_temporary_buffer): Use
+ non-placement delete.
+
+ * include/std/chrono (__check_overflow): Simplify definition.
+ (_Checked_integral_constant): Remove.
+
+ PR libstdc++/86846
+ * src/c++17/default_resource.h: New file, defining default_res.
+ * src/c++17/memory_resource.cc [ATOMIC_POINTER_LOCK_FREE != 2]
+ (atomic_mem_res): Define alternative for atomic<memory_resource*>
+ using a mutex instead of atomics.
+
+ PR libstdc++/85343
+ * config/abi/pre/gnu.ver: Export new symbol.
+ * doc/xml/manual/abi.xml: Document new versions.
+ * include/bits/fstream.tcc (basic_filebuf<C, T>::underflow)
+ (basic_filebuf<C, T>::xsgetn): Pass errno to __throw_ios_failure.
+ * include/bits/functexcept.h (__throw_ios_failure(const char*, int)):
+ Declare new overload.
+ * src/c++11/cxx11-ios_failure.cc (__ios_failure): Add new constructor
+ and static member function.
+ (__throw_ios_failure(const char*, int)): Define.
+ * src/c++98/ios_failure.cc [!_GLIBCXX_USE_DUAL_ABI]
+ (__throw_ios_failure(const char*, int)): Define.
+
+2018-08-14 Jeremy Sawicki <jeremy-gcc@sawicki.us>
+
+ * include/ext/rope (_Rope_iterator_base(const _Rope_iterator_base&))
+ (_Rope_const_iterator::operator=(const _Rope_const_iterator&))
+ (_Rope_iterator::operator=(const _Rope_iterator&)): Ensure
+ copied/assigned rope iterators don't retain pointers to the iterator
+ they were copied/assigned from.
+ * testsuite/ext/rope/7.cc: New.
+
+2018-08-13 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/45093
+ * include/bits/stl_tree.h (_Rb_tree::_M_destroy_node(_Link_type)):
+ Combine definitions to avoid --detect-odr-violations warning.
+
+ * libsupc++/new_opa.cc (operator new(size_t, align_val_t)): Use
+ __is_pow2 to check for valid alignment. Avoid branching when rounding
+ size to multiple of alignment.
+
+ * include/Makefile.am: Install <bit> and <version> for freestanding.
+ * include/Makefile.in: Regenerate.
+ * testsuite/17_intro/freestanding.cc: Check for <bit> and <version>.
+
+ Revert
+ 2018-08-10 Sebastian Huber <sebastian.huber@embedded-brains.de>
+
+ PR target/85904
+ * configure.ac: Define HAVE_ALIGNED_ALLOC if building for
+ Newlib.
+ * configure: Regenerate.
+
+2018-08-10 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/68210
+ * doc/xml/manual/intro.xml: Document LWG 206 change.
+ * libsupc++/del_op.cc: Replace _GLIBCXX_USE_NOEXCEPT with noexcept.
+ * libsupc++/del_opa.cc: Likewise.
+ * libsupc++/del_opant.cc: Likewise.
+ * libsupc++/del_opnt.cc: Likewise. Call operator delete(ptr) instead
+ of free(ptr).
+ * libsupc++/del_ops.cc: Replace _GLIBCXX_USE_NOEXCEPT with noexcept.
+ * libsupc++/del_opsa.cc: Likewise.
+ * libsupc++/del_opva.cc: Likewise.
+ * libsupc++/del_opvant.cc: Likewise.
+ * libsupc++/del_opvnt.cc: Likewise. Call operator delete[](ptr)
+ instead of operator delete(ptr).
+ * libsupc++/del_opvs.cc: Replace _GLIBCXX_USE_NOEXCEPT with noexcept.
+ * libsupc++/del_opvsa.cc: Likewise.
+ * libsupc++/new_op.cc: Use __builtin_expect in check for zero size.
+ * libsupc++/new_opa.cc: Use nullptr instead of literal 0.
+ * libsupc++/new_opant.cc: Likewise. Replace _GLIBCXX_USE_NOEXCEPT
+ with noexcept.
+ * libsupc++/new_opnt.cc: Likewise. Call operator new(sz) instead of
+ malloc(sz).
+ * libsupc++/new_opvant.cc: Use nullptr and noexcept.
+ * libsupc++/new_opvnt.cc: Likewise. Call operator new[](sz) instead of
+ operator new(sz, nothrow).
+ * testsuite/18_support/new_nothrow.cc: New test.
+
+2018-08-10 Martin Liska <mliska@suse.cz>
+
+ * libsupc++/new_op.cc (new): Remove __builtin_expect as malloc
+ predictor can handle that.
+ * libsupc++/new_opa.cc: Likewise.
+ * libsupc++/new_opnt.cc (new): Likewise.
+
+2018-08-10 Sebastian Huber <sebastian.huber@embedded-brains.de>
+
+ PR target/85904
+ * configure.ac: Define HAVE_ALIGNED_ALLOC if building for
+ Newlib.
+ * configure: Regenerate.
+
+2018-08-10 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/deque (std::pmr::deque): Declare alias.
+ * include/std/forward_list (std::pmr::forward_list): Likewise.
+ * include/std/list (std::pmr::list): Likewise.
+ * include/std/map (std::pmr::map, std::pmr::multimap): Likewise.
+ * include/std/regex (std::pmr::match_results, std::pmr::cmatch)
+ (std::pmr::smatch, std::pmr::wcmatch, std::pmr::wsmatch): Likewise.
+ * include/std/set (std::pmr::set, std::pmr::multiset): Likewise.
+ * include/std/string (std::pmr::basic_string, std::pmr::string)
+ (std::pmr::u16string, std::pmr::u32string, std::pmr::wstring):
+ Likewise.
+ * include/std/unordered_map (std::pmr::unordered_map)
+ (std::pmr::unordered_multimap): Likewise.
+ * include/std/unordered_set (std::pmr::unordered_set)
+ (std::pmr::unordered_multiset): Likewise.
+ * include/std/vector (std::pmr::vector): Likewise.
+ * testsuite/21_strings/basic_string/types/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/deque/types/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/forward_list/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/list/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/map/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/multimap/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/multiset/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/set/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/unordered_map/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/unordered_multimap/pmr_typedefs.cc: New
+ test.
+ * testsuite/23_containers/unordered_multiset/pmr_typedefs.cc: New
+ test.
+ * testsuite/23_containers/unordered_set/pmr_typedefs.cc: New test.
+ * testsuite/23_containers/vector/pmr_typedefs.cc: New test.
+ * testsuite/28_regex/match_results/pmr_typedefs.cc: New test.
+
+2018-08-08 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_algo.h
+ (__rotate(_Ite, _Ite, _Ite, forward_iterator_tag))
+ (__rotate(_Ite, _Ite, _Ite, bidirectional_iterator_tag))
+ (__rotate(_Ite, _Ite, _Ite, random_access_iterator_tag)): Move code
+ duplication...
+ (rotate(_Ite, _Ite, _Ite)): ...here.
+ (__stable_partition_adaptive(_FIt, _FIt, _Pred, _Dist, _Pointer, _Dist)):
+ Simplify rotate call.
+ (__rotate_adaptive(_BIt1, _BIt1, _BIt1, _Dist, _Dist, _Bit2, _Dist)):
+ Likewise.
+ (__merge_without_buffer(_BIt, _BIt, _BIt, _Dist, _Dist, _Comp)):
+ Likewise.
+
+2018-08-08 Jonathan Wakely <jwakely@redhat.com>
+
+ * libsupc++/new_opa.cc (aligned_alloc): Declare inside namespace to
+ avoid clashing with an ::aligned_alloc function that was not detected
+ by configure.
+
+ * doc/xml/manual/using.xml: Fix markup for empty table entry.
+ * doc/html/*: Regenerate.
+
+ * doc/xml/manual/using.xml: Add missing header to table and fix typo.
+ * doc/html/*: Regenerate.
+
+ PR libstdc++/86597
+ * include/bits/fs_dir.h (directory_entry::_M_file_type(error_code&)):
+ Clear error_code when cached type is used.
+ * testsuite/27_io/filesystem/directory_entry/86597.cc: New test.
+
+2018-08-07 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86874
+ * include/std/variant (_Copy_ctor_base::_M_destructive_move): Define
+ here instead of in _Move_assign_base.
+ (_Copy_ctor_base<true, _Types...>::_M_destructive_move): Define.
+ (_Copy_assign_base::operator=): Use _M_destructive_move when changing
+ the contained value to another alternative.
+ (_Move_assign_base::operator=): Likewise.
+ (_Move_assign_base::_M_destructive_move): Remove.
+ * testsuite/20_util/variant/86874.cc: New test.
+
+ PR libstdc++/86861
+ * libsupc++/new_opa.cc [_GLIBCXX_HAVE_MEMALIGN] (aligned_alloc):
+ Replace macro with inline function.
+ [__sun]: Increase alignment to meet memalign precondition.
+ [!HAVE__ALIGNED_MALLOC && !HAVE_POSIX_MEMALIGN && !HAVE_MEMALIGN]
+ (aligned_alloc): Move check for valid alignment to operator new.
+ Remove redundant check for non-zero size, it's enforced by the caller.
+ (operator new): Move check for valid alignment here. Use
+ __builtin_expect on check for zero size.
+
+ * config/abi/pre/gnu.ver: Export monotonic_buffer_resource members.
+ * include/std/memory_resource (monotonic_buffer_resource::release):
+ Call _M_release_buffers to free buffers.
+ (monotonic_buffer_resource::do_allocate): Call _M_new_buffer to
+ allocate a new buffer from upstream.
+ (monotonic_buffer_resource::_M_new_buffer): Declare.
+ (monotonic_buffer_resource::_M_release_buffers): Declare.
+ (monotonic_buffer_resource::_Chunk): Replace definition with
+ declaration as opaque type.
+ * src/c++17/memory_resource.cc (monotonic_buffer_resource::_Chunk):
+ Define.
+ (monotonic_buffer_resource::_M_new_buffer): Define.
+ (monotonic_buffer_resource::_M_release_buffers): Define.
+
+2018-08-05 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_iterator.h: Fix comment.
+
+2018-08-03 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/c++11/system_error.cc
+ (system_error_category::default_error_condition): Add workaround for
+ ENOTEMPTY and EEXIST having the same value on AIX.
+ * testsuite/19_diagnostics/error_category/system_category.cc: Add
+ extra testcases for EDOM, EILSEQ, ERANGE, EEXIST and ENOTEMPTY.
+
+2018-08-01 Jonathan Wakely <jwakely@redhat.com>
+
+ * configure: Regenerate.
+ * configure.ac: Add -D_GLIBCXX_ASSERTIONS to default DEBUG_FLAGS.
+ * src/c++11/futex.cc: Use __glibcxx_assert instead of
+ _GLIBCXX_DEBUG_ASSERT.
+
+2018-08-01 Mike Crowe <mac@mcrowe.com>
+
+ * include/std/condition_variable (wait_for): Use steady_clock.
+
+2018-08-01 Mike Crowe <mac@mcrowe.com>
+
+ * include/std/condition_variable (wait_until): Only report timeout
+ if we really have timed out when measured against the
+ caller-supplied clock.
+ * testsuite/30_threads/condition_variable/members/2.cc: Add test
+ case to confirm above behaviour.
+
+2018-08-01 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/60555
+ * src/c++11/system_error.cc
+ (system_error_category::default_error_condition): New override to
+ check for POSIX errno values.
+ * testsuite/19_diagnostics/error_category/generic_category.cc: New
+ * testsuite/19_diagnostics/error_category/system_category.cc: New
+ test.
+
+2018-07-31 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86751
+ * include/bits/stl_pair.h (__pair_base): New class with deleted copy
+ assignment operator.
+ (pair): Derive from __pair_base.
+ (pair::operator=): Remove deleted overload.
+ * python/libstdcxx/v6/printers.py (StdPairPrinter): New pretty printer
+ so that new base class isn't shown in GDB.
+ * testsuite/20_util/pair/86751.cc: New test.
+ * testsuite/20_util/pair/ref_assign.cc: New test.
+
+ * include/bits/c++config (_GLIBCXX_HAVE_BUILTIN_HAS_UNIQ_OBJ_REP)
+ (_GLIBCXX_HAVE_BUILTIN_IS_AGGREGATE): Move definitions here.
+ (_GLIBCXX_HAVE_BUILTIN_LAUNDER): Likewise. Use !__is_identifier
+ instead of __has_builtin.
+ * include/std/type_traits (_GLIBCXX_HAVE_BUILTIN_HAS_UNIQ_OBJ_REP)
+ (_GLIBCXX_HAVE_BUILTIN_IS_AGGREGATE): Remove definitions from here.
+ * include/std/version [!_GLIBCXX_HAS_GTHREADS]
+ (__cpp_lib_shared_timed_mutex, __cpp_lib_scoped_lock)
+ (__cpp_lib_shared_mutex): Don't define when Gthreads not in use.
+ [!_GLIBCXX_HAVE_BUILTIN_HAS_UNIQ_OBJ_REP]
+ (__cpp_lib_has_unique_object_representations): Don't define when
+ builtin not available.
+ [!_GLIBCXX_HAVE_BUILTIN_IS_AGGREGATE] (__cpp_lib_is_aggregate):
+ Likewise.
+ [!_GLIBCXX_HAVE_BUILTIN_LAUNDER] (__cpp_lib_launder): Likewise.
+ * libsupc++/new (_GLIBCXX_HAVE_BUILTIN_LAUNDER): Remove definition
+ from here.
+
+ * doc/xml/manual/test.xml: Improve documentation on writing tests for
+ newer standards.
+ * doc/xml/manual/using.xml: Document all headers for C++11 and later.
+ * doc/html/*: Regenerate.
+
+ * include/ext/pointer.h [__cplusplus >= 201103L]
+ (_Pointer_adapter::operator bool): Add explicit conversion operator
+ to replace safe bool idiom.
+
+2018-07-30 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86734
+ * include/bits/stl_iterator.h (reverse_iterator::operator->): Call
+ _S_to_pointer (LWG 1052, LWG 2118).
+ (reverse_iterator::_S_to_pointer): Define overloaded helper functions.
+ * testsuite/24_iterators/reverse_iterator/dr1052.cc: New test.
+ * testsuite/24_iterators/reverse_iterator/dr2188.cc: New test.
+
+ * libsupc++/new_opa.cc (operator new(size_t, align_val_t)): Add
+ workaround for aligned_alloc bug on AIX.
+ * testsuite/18_support/new_aligned.cc: New test.
+
+2018-07-26 Marek Polacek <polacek@redhat.com>
+
+ * testsuite/30_threads/condition_variable_any/cond.cc: New.
+
+2018-07-26 Marek Polacek <polacek@redhat.com>
+
+ * src/c++98/locale_init.cc: Fix #ifdef condition.
+
+2018-07-26 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/18_support/aligned_alloc/aligned_alloc.cc: Add
+ dg-require-cstdint directive.
+ * testsuite/20_util/allocator/overaligned.cc: Likewise.
+ * testsuite/20_util/any/cons/aligned.cc: Likewise.
+ * testsuite/20_util/monotonic_buffer_resource/allocate.cc: Likewise.
+ * testsuite/20_util/monotonic_buffer_resource/deallocate.cc: Likewise.
+ * testsuite/20_util/shared_ptr/thread/default_weaktoshared.cc:
+ Likewise.
+ * testsuite/20_util/shared_ptr/thread/mutex_weaktoshared.cc: Likewise.
+ * testsuite/23_containers/list/modifiers/insert/25288.cc: Likewise.
+ * testsuite/23_containers/set/allocator/move_assign.cc: Likewise.
+ * testsuite/25_algorithms/make_heap/complexity.cc: Likewise.
+ * testsuite/25_algorithms/pop_heap/complexity.cc: Require cstdint and
+ random_device effective-target.
+ * testsuite/25_algorithms/push_heap/complexity.cc: Likewise.
+ * testsuite/25_algorithms/sample/1.cc: Require cstdint.
+ * testsuite/25_algorithms/sample/2.cc: Likewise.
+ * testsuite/25_algorithms/sort_heap/complexity.cc: Require cstdint
+ and random_device.
+ * testsuite/26_numerics/headers/random/types_std_c++0x.cc: Require
+ cstdint.
+ * testsuite/26_numerics/random/chi_squared_distribution/83833.cc:
+ Likewise.
+ * testsuite/26_numerics/random/discard_block_engine/requirements/
+ constexpr_data.cc: Likewise.
+ * testsuite/26_numerics/random/discard_block_engine/requirements/
+ constexpr_functions.cc: Likewise.
+ * testsuite/26_numerics/random/independent_bits_engine/requirements/
+ constexpr_functions.cc: Likewise.
+ * testsuite/26_numerics/random/linear_congruential_engine/requirements/
+ constexpr_data.cc: Likewise.
+ * testsuite/26_numerics/random/linear_congruential_engine/requirements/
+ constexpr_functions.cc: Likewise.
+ * testsuite/26_numerics/random/mersenne_twister_engine/requirements/
+ constexpr_data.cc: Likewise.
+ * testsuite/26_numerics/random/mersenne_twister_engine/requirements/
+ constexpr_functions.cc: Likewise.
+ * testsuite/26_numerics/random/pr60037-neg.cc: Likewise.
+ * testsuite/26_numerics/random/seed_seq/cons/65631.cc: Likewise.
+ * testsuite/26_numerics/random/shuffle_order_engine/requirements/
+ constexpr_data.cc: Add dg-require-cstdint directive.
+ * testsuite/26_numerics/random/shuffle_order_engine/requirements/
+ constexpr_functions.cc: Likewise.
+ * testsuite/26_numerics/random/subtract_with_carry_engine/requirements/
+ constexpr_data.cc: Likewise.
+ * testsuite/26_numerics/random/subtract_with_carry_engine/requirements/
+ constexpr_functions.cc: Likewise.
+ * testsuite/26_numerics/random/uniform_real_distribution/operators/
+ 64351.cc: Likewise.
+ * testsuite/29_atomics/headers/atomic/types_std_c++0x.cc: Likewise.
+ * testsuite/experimental/algorithm/sample-2.cc: Likewise.
+ * testsuite/experimental/algorithm/sample.cc: Likewise.
+ * testsuite/experimental/algorithm/search.cc: Likewise.
+ * testsuite/experimental/algorithm/shuffle.cc: Likewise.
+ * testsuite/experimental/any/cons/aligned.cc: Likewise.
+ * testsuite/experimental/memory_resource/new_delete_resource.cc:
+ Likewise.
+ * testsuite/experimental/memory_resource/resource_adaptor.cc: Likewise.
+ * testsuite/experimental/random/randint.cc: Likewise.
+ * testsuite/experimental/source_location/1.cc: Likewise.
+ * testsuite/ext/bitmap_allocator/overaligned.cc: Likewise.
+ * testsuite/ext/malloc_allocator/overaligned.cc: Likewise.
+ * testsuite/ext/mt_allocator/overaligned.cc: Likewise.
+ * testsuite/ext/new_allocator/overaligned.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/hash_map_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/hash_set_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/list_update_map_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/list_update_set_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/priority_queue_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/tree_map_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/tree_set_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/trie_map_rand.cc: Likewise.
+ * testsuite/ext/pb_ds/regression/trie_set_rand.cc: Likewise.
+ * testsuite/ext/pool_allocator/overaligned.cc: Likewise.
+ * testsuite/ext/throw_allocator/check_allocate_max_size.cc: Likewise.
+ * testsuite/ext/throw_allocator/check_deallocate_null.cc: Likewise.
+ * testsuite/ext/throw_allocator/check_delete.cc: Likewise.
+ * testsuite/ext/throw_allocator/check_new.cc: Likewise.
+ * testsuite/ext/throw_allocator/deallocate_global.cc: Likewise.
+ * testsuite/ext/throw_allocator/deallocate_local.cc: Likewise.
+ * testsuite/ext/throw_allocator/explicit_instantiation.cc: Likewise.
+ * testsuite/ext/throw_allocator/variadic_construct.cc: Likewise.
+ * testsuite/tr1/8_c_compatibility/cinttypes/functions.cc: Likewise.
+
+ * testsuite/30_threads/recursive_mutex/cons/1.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/dest/destructor_locked.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_mutex/lock/1.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/native_handle/1.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/native_handle/typesizes.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_mutex/requirements/standard_layout.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_mutex/requirements/typedefs.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_mutex/try_lock/1.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/try_lock/2.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/unlock/1.cc: Likewise.
+ * testsuite/30_threads/recursive_mutex/unlock/2.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/cons/1.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/cons/assign_neg.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/cons/copy_neg.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/dest/
+ destructor_locked.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/lock/1.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/lock/2.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/native_handle/1.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/native_handle/
+ typesizes.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/requirements/typedefs.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock/1.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock/2.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock_for/1.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock_for/2.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock_for/3.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock_until/1.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/try_lock_until/2.cc:
+ Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/unlock/1.cc: Likewise.
+ * testsuite/30_threads/recursive_timed_mutex/unlock/2.cc: Likewise.
+ * testsuite/30_threads/scoped_lock/cons/1.cc: Likewise.
+ * testsuite/30_threads/scoped_lock/requirements/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/30_threads/scoped_lock/requirements/typedefs.cc: Likewise.
+ * testsuite/30_threads/shared_future/cons/assign.cc: Likewise.
+ * testsuite/30_threads/shared_future/cons/constexpr.cc: Likewise.
+ * testsuite/30_threads/shared_future/cons/copy.cc: Likewise.
+ * testsuite/30_threads/shared_future/cons/default.cc: Likewise.
+ * testsuite/30_threads/shared_future/cons/move.cc: Likewise.
+ * testsuite/30_threads/shared_future/cons/move_assign.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/45133.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/get.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/get2.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/valid.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/wait.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/wait_for.cc: Likewise.
+ * testsuite/30_threads/shared_future/members/wait_until.cc: Likewise.
+ * testsuite/30_threads/shared_future/requirements/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/30_threads/shared_lock/cons/1.cc: Likewise.
+ * testsuite/30_threads/shared_lock/cons/2.cc: Likewise.
+ * testsuite/30_threads/shared_lock/cons/3.cc: Likewise.
+ * testsuite/30_threads/shared_lock/cons/4.cc: Likewise.
+ * testsuite/30_threads/shared_lock/cons/5.cc: Likewise.
+ * testsuite/30_threads/shared_lock/cons/6.cc: Likewise.
+ * testsuite/30_threads/shared_lock/locking/1.cc: Likewise.
+ * testsuite/30_threads/shared_lock/locking/2.cc: Likewise.
+ * testsuite/30_threads/shared_lock/locking/3.cc: Likewise.
+ * testsuite/30_threads/shared_lock/locking/4.cc: Likewise.
+ * testsuite/30_threads/shared_lock/modifiers/1.cc: Likewise.
+ * testsuite/30_threads/shared_lock/requirements/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/30_threads/shared_lock/requirements/typedefs.cc: Likewise.
+ * testsuite/30_threads/shared_mutex/cons/1.cc: Likewise.
+ * testsuite/30_threads/shared_mutex/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/shared_mutex/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/shared_mutex/requirements/standard_layout.cc:
+ Likewise.
+ * testsuite/30_threads/shared_mutex/try_lock/1.cc: Likewise.
+ * testsuite/30_threads/shared_mutex/try_lock/2.cc: Likewise.
+ * testsuite/30_threads/shared_mutex/unlock/1.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/cons/1.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/requirements/
+ standard_layout.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/try_lock/1.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/try_lock/2.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/try_lock/3.cc: Likewise.
+ * testsuite/30_threads/shared_timed_mutex/unlock/1.cc: Likewise.
+ * testsuite/30_threads/this_thread/1.cc: Likewise.
+ * testsuite/30_threads/this_thread/2.cc: Likewise.
+ * testsuite/30_threads/this_thread/3.cc: Likewise.
+ * testsuite/30_threads/this_thread/4.cc: Likewise.
+ * testsuite/30_threads/this_thread/58038.cc: Likewise.
+ * testsuite/30_threads/thread/70503.cc: Likewise.
+ * testsuite/30_threads/thread/84532.cc: Likewise.
+ * testsuite/30_threads/thread/adl.cc: Likewise.
+ * testsuite/30_threads/thread/cons/1.cc: Likewise.
+ * testsuite/30_threads/thread/cons/2.cc: Likewise.
+ * testsuite/30_threads/thread/cons/3.cc: Likewise.
+ * testsuite/30_threads/thread/cons/4.cc: Likewise.
+ * testsuite/30_threads/thread/cons/49668.cc: Likewise.
+ * testsuite/30_threads/thread/cons/5.cc: Likewise.
+ * testsuite/30_threads/thread/cons/6.cc: Likewise.
+ * testsuite/30_threads/thread/cons/7.cc: Likewise.
+ * testsuite/30_threads/thread/cons/8.cc: Likewise.
+ * testsuite/30_threads/thread/cons/84535.cc: Likewise.
+ * testsuite/30_threads/thread/cons/9.cc: Likewise.
+ * testsuite/30_threads/thread/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/thread/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/thread/cons/lwg2097.cc: Likewise.
+ * testsuite/30_threads/thread/cons/moveable.cc: Likewise.
+ * testsuite/30_threads/thread/cons/terminate.cc: Likewise.
+ * testsuite/30_threads/thread/id/operators.cc: Likewise.
+ * testsuite/30_threads/thread/members/1.cc: Likewise.
+ * testsuite/30_threads/thread/members/2.cc: Likewise.
+ * testsuite/30_threads/thread/members/3.cc: Likewise.
+ * testsuite/30_threads/thread/members/4.cc: Likewise.
+ * testsuite/30_threads/thread/members/5.cc: Likewise.
+ * testsuite/30_threads/thread/members/hardware_concurrency.cc:
+ Likewise.
+ * testsuite/30_threads/thread/native_handle/cancel.cc: Likewise.
+ * testsuite/30_threads/thread/swap/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/cons/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/dest/destructor_locked.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/lock/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/native_handle/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/native_handle/typesizes.cc:
+ Likewise.
+ * testsuite/30_threads/timed_mutex/requirements/
+ standard_layout.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/requirements/typedefs.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock/2.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock_for/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock_for/2.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock_for/3.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock_until/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock_until/2.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/try_lock_until/57641.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/unlock/1.cc: Likewise.
+ * testsuite/30_threads/timed_mutex/unlock/2.cc: Likewise.
+ * testsuite/30_threads/try_lock/1.cc: Likewise.
+ * testsuite/30_threads/try_lock/2.cc: Likewise.
+ * testsuite/30_threads/try_lock/3.cc: Likewise.
+ * testsuite/30_threads/try_lock/4.cc: Likewise.
+ * testsuite/30_threads/unique_lock/cons/1.cc: Likewise.
+ * testsuite/30_threads/unique_lock/cons/2.cc: Likewise.
+ * testsuite/30_threads/unique_lock/cons/3.cc: Likewise.
+ * testsuite/30_threads/unique_lock/cons/4.cc: Likewise.
+ * testsuite/30_threads/unique_lock/cons/5.cc: Likewise.
+ * testsuite/30_threads/unique_lock/cons/6.cc: Likewise.
+ * testsuite/30_threads/unique_lock/locking/1.cc: Likewise.
+ * testsuite/30_threads/unique_lock/locking/2.cc: Likewise.
+ * testsuite/30_threads/unique_lock/locking/3.cc: Likewise.
+ * testsuite/30_threads/unique_lock/locking/4.cc: Likewise.
+ * testsuite/30_threads/unique_lock/modifiers/1.cc: Likewise.
+ * testsuite/30_threads/unique_lock/requirements/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/30_threads/unique_lock/requirements/typedefs.cc: Likewise.
+
+ * testsuite/30_threads/async/42819.cc: Remove dg-require-cstdint
+ directive.
+ * testsuite/30_threads/async/49668.cc: Likewise.
+ * testsuite/30_threads/async/54297.cc: Likewise.
+ * testsuite/30_threads/async/84532.cc: Likewise.
+ * testsuite/30_threads/async/any.cc: Likewise.
+ * testsuite/30_threads/async/async.cc: Likewise.
+ * testsuite/30_threads/async/except.cc: Likewise.
+ * testsuite/30_threads/async/forced_unwind.cc: Likewise.
+ * testsuite/30_threads/async/launch.cc: Likewise.
+ * testsuite/30_threads/async/lwg2021.cc: Likewise.
+ * testsuite/30_threads/async/sync.cc: Likewise.
+ * testsuite/30_threads/call_once/39909.cc: Likewise.
+ * testsuite/30_threads/call_once/49668.cc: Likewise.
+ * testsuite/30_threads/call_once/60497.cc: Likewise.
+ * testsuite/30_threads/call_once/call_once1.cc: Likewise.
+ * testsuite/30_threads/call_once/constexpr.cc: Likewise.
+ * testsuite/30_threads/call_once/dr2442.cc: Likewise.
+ * testsuite/30_threads/call_once/once_flag.cc: Likewise.
+ * testsuite/30_threads/condition_variable/54185.cc: Likewise.
+ * testsuite/30_threads/condition_variable/cons/1.cc: Likewise.
+ * testsuite/30_threads/condition_variable/cons/assign_neg.cc:
+ Likewise.
+ * testsuite/30_threads/condition_variable/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/condition_variable/members/1.cc: Likewise.
+ * testsuite/30_threads/condition_variable/members/2.cc: Likewise.
+ * testsuite/30_threads/condition_variable/members/3.cc: Likewise.
+ * testsuite/30_threads/condition_variable/members/53841.cc: Likewise.
+ * testsuite/30_threads/condition_variable/members/68519.cc: Likewise.
+ * testsuite/30_threads/condition_variable/native_handle/typesizes.cc:
+ Likewise.
+ * testsuite/30_threads/condition_variable/requirements/
+ standard_layout.cc: Likewise.
+ * testsuite/30_threads/condition_variable/requirements/typedefs.cc:
+ * Likewise.
+ * testsuite/30_threads/condition_variable_any/50862.cc: Likewise.
+ * testsuite/30_threads/condition_variable_any/53830.cc: Likewise.
+ * testsuite/30_threads/condition_variable_any/cons/1.cc: Likewise.
+ * testsuite/30_threads/condition_variable_any/cons/assign_neg.cc:
+ Likewise.
+ * testsuite/30_threads/condition_variable_any/cons/copy_neg.cc:
+ Likewise.
+ * testsuite/30_threads/condition_variable_any/members/1.cc: Likewise.
+ * testsuite/30_threads/condition_variable_any/members/2.cc: Likewise.
+ * testsuite/30_threads/future/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/future/cons/constexpr.cc: Likewise.
+ * testsuite/30_threads/future/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/future/cons/default.cc: Likewise.
+ * testsuite/30_threads/future/cons/move.cc: Likewise.
+ * testsuite/30_threads/future/cons/move_assign.cc: Likewise.
+ * testsuite/30_threads/future/members/45133.cc: Likewise.
+ * testsuite/30_threads/future/members/get.cc: Likewise.
+ * testsuite/30_threads/future/members/get2.cc: Likewise.
+ * testsuite/30_threads/future/members/share.cc: Likewise.
+ * testsuite/30_threads/future/members/valid.cc: Likewise.
+ * testsuite/30_threads/future/members/wait.cc: Likewise.
+ * testsuite/30_threads/future/members/wait_for.cc: Likewise.
+ * testsuite/30_threads/future/members/wait_until.cc: Likewise.
+ * testsuite/30_threads/future/requirements/explicit_instantiation.cc:
+ Likewise.
+ * testsuite/30_threads/headers/condition_variable/types_std_c++0x.cc:
+ Likewise.
+ * testsuite/30_threads/headers/future/types_std_c++0x.cc: Likewise.
+ * testsuite/30_threads/headers/mutex/types_std_c++0x.cc: Likewise.
+ * testsuite/30_threads/headers/thread/std_c++0x_neg.cc: Likewise.
+ * testsuite/30_threads/headers/thread/types_std_c++0x.cc: Likewise.
+ * testsuite/30_threads/lock/1.cc: Likewise.
+ * testsuite/30_threads/lock/2.cc: Likewise.
+ * testsuite/30_threads/lock/3.cc: Likewise.
+ * testsuite/30_threads/lock/4.cc: Likewise.
+ * testsuite/30_threads/lock_guard/cons/1.cc: Likewise.
+ * testsuite/30_threads/lock_guard/requirements/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/30_threads/lock_guard/requirements/typedefs.cc: Likewise.
+ * testsuite/30_threads/mutex/cons/1.cc: Likewise.
+ * testsuite/30_threads/mutex/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/mutex/cons/constexpr.cc: Likewise.
+ * testsuite/30_threads/mutex/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/mutex/dest/destructor_locked.cc: Likewise.
+ * testsuite/30_threads/mutex/lock/1.cc: Likewise.
+ * testsuite/30_threads/mutex/native_handle/1.cc: Likewise.
+ * testsuite/30_threads/mutex/native_handle/typesizes.cc: Likewise.
+ * testsuite/30_threads/mutex/requirements/standard_layout.cc::
+ Likewise.
+ * testsuite/30_threads/mutex/requirements/typedefs.cc: Likewise.
+ * testsuite/30_threads/mutex/try_lock/1.cc: Likewise.
+ * testsuite/30_threads/mutex/try_lock/2.cc: Likewise.
+ * testsuite/30_threads/mutex/unlock/1.cc: Likewise.
+ * testsuite/30_threads/mutex/unlock/2.cc: Likewise.
+ * testsuite/30_threads/once_flag/cons/constexpr.cc: Likewise.
+ * testsuite/30_threads/packaged_task/49668.cc: Likewise.
+ * testsuite/30_threads/packaged_task/60564.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/1.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/2.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/3.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/56492.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/alloc.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/alloc2.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/alloc_min.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/move.cc: Likewise.
+ * testsuite/30_threads/packaged_task/cons/move_assign.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/at_thread_exit.cc:
+ Likewise.
+ * testsuite/30_threads/packaged_task/members/get_future.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/get_future2.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/invoke.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/invoke2.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/invoke3.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/invoke4.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/invoke5.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/reset.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/reset2.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/swap.cc: Likewise.
+ * testsuite/30_threads/packaged_task/members/valid.cc: Likewise.
+ * testsuite/30_threads/packaged_task/requirements/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/30_threads/packaged_task/uses_allocator.cc: Likewise.
+ * testsuite/30_threads/promise/60966.cc: Likewise.
+ * testsuite/30_threads/promise/69106.cc: Likewise.
+ * testsuite/30_threads/promise/cons/1.cc: Likewise.
+ * testsuite/30_threads/promise/cons/alloc.cc: Likewise.
+ * testsuite/30_threads/promise/cons/alloc2.cc: Likewise.
+ * testsuite/30_threads/promise/cons/alloc_min.cc: Likewise.
+ * testsuite/30_threads/promise/cons/assign_neg.cc: Likewise.
+ * testsuite/30_threads/promise/cons/copy_neg.cc: Likewise.
+ * testsuite/30_threads/promise/cons/move.cc: Likewise.
+ * testsuite/30_threads/promise/cons/move_assign.cc: Likewise.
+ * testsuite/30_threads/promise/members/at_thread_exit.cc: Likewise.
+ * testsuite/30_threads/promise/members/at_thread_exit2.cc: Likewise.
+ * testsuite/30_threads/promise/members/get_future.cc: Likewise.
+ * testsuite/30_threads/promise/members/get_future2.cc: Likewise.
+ * testsuite/30_threads/promise/members/set_exception.cc: Likewise.
+ * testsuite/30_threads/promise/members/set_exception2.cc: Likewise.
+ * testsuite/30_threads/promise/members/set_value.cc: Likewise.
+ * testsuite/30_threads/promise/members/set_value2.cc: Likewise.
+ * testsuite/30_threads/promise/members/set_value3.cc: Likewise.
+ * testsuite/30_threads/promise/members/swap.cc: Likewise.
+ * testsuite/30_threads/promise/requirements/explicit_instantiation.cc:
+ * Likewise.
+ * testsuite/30_threads/promise/uses_allocator.cc: Likewise.
+
+ * testsuite/18_support/numeric_limits/char16_32_t.cc: Qualify names
+ from namespace std.
+ * testsuite/20_util/align/2.cc: Remove dg-require-cstdint directive.
+ * testsuite/20_util/duration/arithmetic/1.cc: Likewise.
+ * testsuite/20_util/duration/arithmetic/2.cc: Likewise.
+ * testsuite/20_util/duration/arithmetic/dr2020.cc: Likewise.
+ * testsuite/20_util/duration/arithmetic/dr934-1.cc: Likewise.
+ * testsuite/20_util/duration/arithmetic/dr934-2.cc: Likewise.
+ * testsuite/20_util/duration/comparison_operators/1.cc: Likewise.
+ * testsuite/20_util/duration/cons/1.cc: Likewise.
+ * testsuite/20_util/duration/cons/1_neg.cc: Likewise.
+ * testsuite/20_util/duration/cons/2.cc: Likewise.
+ * testsuite/20_util/duration/cons/54025.cc: Likewise.
+ * testsuite/20_util/duration/cons/dr974_neg.cc: Likewise.
+ * testsuite/20_util/duration/requirements/explicit_instantiation/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/20_util/duration/requirements/typedefs_neg1.cc: Likewise.
+ * testsuite/20_util/duration/requirements/typedefs_neg2.cc: Likewise.
+ * testsuite/20_util/duration/requirements/typedefs_neg3.cc: Likewise.
+ * testsuite/20_util/make_signed/requirements/typedefs-4.cc: Likewise.
+ * testsuite/20_util/ratio/comparisons/comp1.cc: Likewise.
+ * testsuite/20_util/ratio/comparisons/comp2.cc: Likewise.
+ * testsuite/20_util/ratio/comparisons/comp3.cc: Likewise.
+ * testsuite/20_util/ratio/cons/cons1.cc: Likewise.
+ * testsuite/20_util/ratio/operations/45866.cc: Likewise.
+ * testsuite/20_util/ratio/operations/47913.cc: Likewise.
+ * testsuite/20_util/ratio/operations/53840.cc: Likewise.
+ * testsuite/20_util/ratio/operations/ops1.cc: Likewise.
+ * testsuite/20_util/shared_ptr/atomic/3.cc: Likewise.
+ * testsuite/20_util/system_clock/1.cc: Likewise.
+ * testsuite/20_util/time_point/1.cc: Likewise.
+ * testsuite/20_util/time_point/2.cc: Likewise.
+ * testsuite/20_util/time_point/3.cc: Likewise.
+ * testsuite/20_util/time_point/requirements/explicit_instantiation/
+ explicit_instantiation.cc: Likewise.
+ * testsuite/21_strings/basic_string/requirements/
+ explicit_instantiation/char16_t/1.cc: Likewise.
+ * testsuite/21_strings/basic_string/requirements/
+ explicit_instantiation/char32_t/1.cc: Likewise.
+ * testsuite/21_strings/basic_string_view/requirements/
+ explicit_instantiation/char16_t/1.cc: Likewise.
+ * testsuite/21_strings/basic_string_view/requirements/
+ explicit_instantiation/char32_t/1.cc: Likewise.
+ * testsuite/21_strings/char_traits/requirements/
+ explicit_instantiation/char16_t/1.cc: Likewise.
+ * testsuite/21_strings/char_traits/requirements/
+ explicit_instantiation/char32_t/1.cc: Likewise.
+ * testsuite/21_strings/headers/string/types_std_c++0x.cc: Likewise.
+ * testsuite/22_locale/codecvt/char16_t.cc: Likewise.
+ * testsuite/22_locale/codecvt/char32_t.cc: Likewise.
+ * testsuite/22_locale/codecvt/codecvt_utf16/requirements/1.cc:
+ Likewise.
+ * testsuite/22_locale/codecvt/codecvt_utf8/requirements/1.cc:
+ Likewise.
+ * testsuite/22_locale/codecvt/codecvt_utf8_utf16/requirements/1.cc:
+ Likewise.
+ * testsuite/22_locale/codecvt/utf8.cc: Likewise.
+ * testsuite/23_containers/vector/bool/72847.cc: Likewise.
+ * testsuite/23_containers/vector/debug/multithreaded_swap.cc:
+ Likewise.
+ * testsuite/experimental/string_view/requirements/
+ explicit_instantiation/char16_t/1.cc: Likewise.
+ * testsuite/experimental/string_view/requirements/
+ explicit_instantiation/char32_t/1.cc: Likewise.
+ * testsuite/ext/vstring/requirements/explicit_instantiation/char16_t/
+ 1.cc: Likewise.
+ * testsuite/ext/vstring/requirements/explicit_instantiation/char32_t/
+ 1.cc: Likewise.
+
+ * include/ext/throw_allocator.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (random_condition, throw_value_random, throw_allocator_random)
+ (std::hash<throw_value_random>): Do not define when <tr1/random> is
+ not usable.
+ * src/c++11/cow-stdexcept.cc [!_GLIBCXX_USE_C99_STDINT_TR1]: Do not
+ define transactional memory support when <stdint.h> is not usable.
+
+ * include/bits/hashtable_policy.h (__detail::__clp2): Use faster
+ implementation that doesn't depend on <stdint.h> types.
+ * include/std/memory (align) [!_GLIBCXX_USE_C99_STDINT_TR1]: Use
+ std::size_t when std::uintptr_t is not usable.
+ [!_GLIBCXX_USE_C99_STDINT_TR1] (pointer_safety, declare_reachable)
+ (undeclare_reachable, declare_no_pointers, undeclare_no_pointers):
+ Define independent of _GLIBCXX_USE_C99_STDINT_TR1.
+
+ * include/bits/basic_string.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (hash<u16string>, hash<u32string>): Remove dependency on
+ _GLIBCXX_USE_C99_STDINT_TR1.
+ * include/bits/char_traits.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (char_traits<char16_t>, char_traits<char32_t>): Remove dependency on
+ _GLIBCXX_USE_C99_STDINT_TR1. Use __UINT_LEAST16_TYPE__ and
+ __UINT_LEAST32_TYPE__ or make_unsigned when <stdint.h> is not usable.
+ * include/bits/codecvt.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (codecvt<char16_t, char, mbstate_t>)
+ (codecvt<char32_t, char, mbstate_t>)
+ (codecvt_byname<char16_t, char, mbstate_t>)
+ (codecvt_byname<char32_t, char, mbstate_t>): Remove dependency
+ on _GLIBCXX_USE_C99_STDINT_TR1.
+ * include/bits/locale_facets.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (_GLIBCXX_NUM_UNICODE_FACETS): Likewise.
+ * include/bits/stringfwd.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (char_traits<char16_t>, char_traits<char32_t>)
+ (basic_string<char16_t>, basic_string<char32_t>): Remove dependency
+ on _GLIBCXX_USE_C99_STDINT_TR1.
+ * include/experimental/string_view [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (u16string_view, u32string_view, hash<u16string_view>)
+ (hash<u32string_view>, operator""sv(const char16_t, size_t))
+ (operator""sv(const char32_t, size_t)): Likewise.
+ * include/ext/vstring.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (hash<__u16vstring>, hash<__u32vstring>): Likewise.
+ * include/ext/vstring_fwd.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (__u16vstring, __u16sso_string, __u16rc_string, __u32vstring)
+ (__u32sso_string, __u32rc_string): Likewise.
+ * include/std/codecvt [!_GLIBCXX_USE_C99_STDINT_TR1] (codecvt_mode)
+ (codecvt_utf8, codecvt_utf16, codecvt_utf8_utf16): Likewise.
+ * include/std/string_view [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (u16string_view, u32string_view, hash<u16string_view>)
+ (hash<u32string_view>, operator""sv(const char16_t, size_t))
+ (operator""sv(const char32_t, size_t)): Likewise.
+ * src/c++11/codecvt.cc: Likewise.
+ * src/c++98/locale_init.cc: Likewise.
+ * src/c++98/localename.cc: Likewise.
+
+ * include/bits/atomic_futex.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (__atomic_futex_unsigned_base): Remove dependency on
+ _GLIBCXX_USE_C99_STDINT_TR1 macro.
+ * include/bits/unique_lock.h [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (unique_lock): Remove dependency on _GLIBCXX_USE_C99_STDINT_TR1.
+ * include/c_global/cstdint [!_GLIBCXX_USE_C99_STDINT_TR1] (intmax_t)
+ (uintmax_t): Define using predefined macros.
+ * include/std/chrono [!_GLIBCXX_USE_C99_STDINT_TR1] (duration)
+ (time_point, system_clock, high_resolution_clock, steady_clock): Remove
+ dependency on _GLIBCXX_USE_C99_STDINT_TR1 macro.
+ (nanoseconds, microseconds, milliseconds, seconds, minutes, hours):
+ [!_GLIBCXX_USE_C99_STDINT_TR1]: Define using __INT64_TYPE__ or
+ long long when <stdint.h> is not usable.
+ * include/std/condition_variable [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (condition_variable, condition_variable_any): Remove dependency on
+ _GLIBCXX_USE_C99_STDINT_TR1.
+ * include/std/future [!_GLIBCXX_USE_C99_STDINT_TR1] (future, promise)
+ (packaged_task, async): Likewise.
+ * include/std/mutex [!_GLIBCXX_USE_C99_STDINT_TR1] (recursive_mutex)
+ (timed_mutex, recursive_timed_mutex, try_lock, lock, scoped_lock)
+ (once_flag, call_once): Likewise.
+ * include/std/ratio [!_GLIBCXX_USE_C99_STDINT_TR1] (ratio): Likewise.
+ * include/std/shared_mutex [!_GLIBCXX_USE_C99_STDINT_TR1]
+ (shared_mutex, shared_timed_mutex, shared_lock): Likewise.
+ * include/std/thread [!_GLIBCXX_USE_C99_STDINT_TR1] (thread)
+ (this_thread::get_id, this_thread::yield, this_thread::sleep_for)
+ (this_thread::sleep_until): Likewise.
+ * src/c++11/chrono.cc: Remove dependency on
+ _GLIBCXX_USE_C99_STDINT_TR1 macro.
+ * src/c++11/condition_variable.cc: Likewise.
+ * src/c++11/futex.cc: Likewise.
+ * src/c++11/future.cc: Likewise.
+ * src/c++11/mutex.cc: Likewise.
+ * src/c++11/thread.cc: Likewise.
+ * testsuite/20_util/duration/literals/range_neg.cc: Adjust dg-error.
+ * testsuite/20_util/duration/requirements/typedefs_neg1.cc: Likewise.
+ * testsuite/20_util/duration/requirements/typedefs_neg2.cc: Likewise.
+ * testsuite/20_util/duration/requirements/typedefs_neg3.cc: Likewise.
+ * testsuite/20_util/ratio/cons/cons_overflow_neg.cc: Likewise.
+ * testsuite/20_util/ratio/operations/ops_overflow_neg.cc: Likewise.
+
+2018-07-26 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ PR libstdc++/77691
+ * testsuite/experimental/memory_resource/new_delete_resource.cc:
+ xfail execution on 32-bit Solaris/x86.
+
+2018-07-26 Marc Glisse <marc.glisse@inria.fr>
+
+ * include/bits/stl_vector.h (_Vector_impl_data::_M_copy_data): New.
+ (_Vector_impl_data::_M_swap_data): Use _M_copy_data.
+ (vector::_M_move_assign): Reorder the swaps.
+
+2018-07-26 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86676
+ * testsuite/20_util/monotonic_buffer_resource/release.cc: Request
+ same alignment for post-release allocation.
+
+2018-07-25 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86676
+ * testsuite/20_util/monotonic_buffer_resource/release.cc: Allow for
+ buffer being misaligned and so returned pointer not being at start.
+
+ * include/experimental/memory_resource: Include <cstddef> header.
+
+ * acinclude.m4 (glibcxx_SUBDIRS): Add src/c++17.
+ * src/Makefile.am: Add comment.
+ * src/c++17/Makefile.in: Regenerate.
+
+ * include/Makefile.am: Add new <bits/unique_lock.h> header.
+ * include/Makefile.in: Regenerate.
+ * include/bits/std_mutex.h [!_GLIBCXX_USE_C99_STDINT_TR1] (mutex)
+ (lock_guard): Define independent of _GLIBCXX_USE_C99_STDINT_TR1.
+ (unique_lock): Move definition to ...
+ * include/bits/unique_lock.h: New header.
+ [!_GLIBCXX_USE_C99_STDINT_TR1] (unique_lock): Define unconditionally.
+ [_GLIBCXX_USE_C99_STDINT_TR1] (unique_lock(mutex_type&, time_point))
+ (unique_lock(mutex_type&, duration), unique_lock::try_lock_until)
+ (unique_lock::try_lock_for): Define only when <chrono> is usable.
+ * include/std/condition_variable: Include <bits/unique_lock.h>.
+ * include/std/mutex: Likewise.
+
+2018-07-24 Jonathan Wakely <jwakely@redhat.com>
+
+ * config/abi/pre/gnu.ver: Export new symbols.
+ * configure: Regenerate.
+ * include/Makefile.am: Add new <memory_resource> header.
+ * include/Makefile.in: Regenerate.
+ * include/precompiled/stdc++.h: Include <memory_resource> for C++17.
+ * include/std/memory_resource: New header.
+ (memory_resource, polymorphic_allocator, new_delete_resource)
+ (null_memory_resource, set_default_resource, get_default_resource)
+ (pool_options, monotonic_buffer_resource): Define.
+ * src/Makefile.am: Add c++17 directory.
+ * src/Makefile.in: Regenerate.
+ * src/c++11/Makefile.am: Fix comment.
+ * src/c++17/Makefile.am: Add makefile for new sub-directory.
+ * src/c++17/Makefile.in: Generate.
+ * src/c++17/memory_resource.cc: New.
+ (newdel_res_t, null_res_t, constant_init, newdel_res, null_res)
+ (default_res, new_delete_resource, null_memory_resource)
+ (set_default_resource, get_default_resource): Define.
+ * testsuite/20_util/memory_resource/1.cc: New test.
+ * testsuite/20_util/memory_resource/2.cc: New test.
+ * testsuite/20_util/monotonic_buffer_resource/1.cc: New test.
+ * testsuite/20_util/monotonic_buffer_resource/allocate.cc: New test.
+ * testsuite/20_util/monotonic_buffer_resource/deallocate.cc: New test.
+ * testsuite/20_util/monotonic_buffer_resource/release.cc: New test.
+ * testsuite/20_util/monotonic_buffer_resource/upstream_resource.cc:
+ New test.
+ * testsuite/20_util/polymorphic_allocator/1.cc: New test.
+ * testsuite/20_util/polymorphic_allocator/resource.cc: New test.
+ * testsuite/20_util/polymorphic_allocator/select.cc: New test.
+ * testsuite/util/testsuite_allocator.h (__gnu_test::memory_resource):
+ Define concrete memory resource for testing.
+ (__gnu_test::default_resource_mgr): Define RAII helper for changing
+ default resource.
+
+ PR libstdc++/86658
+ * include/bits/stl_algobase.h (__niter_wrap<_Iterator>): Pass unused
+ parameter by reference, to avoid copying invalid iterators.
+ * testsuite/25_algorithms/copy/86658.cc: New test.
+
+ * include/std/bit (__countl_zero, __countr_zero, __popcount): Use
+ local variables for number of digits instead of type aliases.
+ (__log2p1): Remove redundant branch also checked in __countl_zero.
+
+ * include/bits/uses_allocator.h (__is_erased_or_convertible): Reorder
+ conditions. Add comments.
+ * testsuite/20_util/uses_allocator/69293_neg.cc: Adjust dg-error line.
+ * testsuite/20_util/uses_allocator/cons_neg.cc: Likewise.
+ * testsuite/20_util/scoped_allocator/69293_neg.cc: Likewise.
+
+ * include/bits/uses_allocator.h (__is_erased_or_convertible): Remove.
+ (__uses_allocator_helper): Check conditions directly instead of
+ using __is_erased_or_convertible.
+
+ * include/experimental/memory_resource: Adjust comments and
+ whitespace.
+ (__resource_adaptor_imp): Add second template parameter for type of
+ memory resource base class.
+ (memory_resource): Define default constructor, destructor, copy
+ constructor and copy assignment operator as defaulted.
+
+ PR libstdc++/70966
+ * include/experimental/memory_resource (__get_default_resource): Use
+ placement new to create an object with dynamic storage duration.
+
+2018-07-23 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/70940
+ * include/experimental/memory_resource
+ (__resource_adaptor_common::_AlignMgr::_M_unadjust): Add assertion.
+ (__resource_adaptor_common::__guaranteed_alignment): New helper to
+ give maximum alignment an allocator guarantees. Specialize for known
+ allocators using new and malloc.
+ (__resource_adaptor_imp::do_allocate): Use __guaranteed_alignment.
+ (__resource_adaptor_imp::do_deallocate): Likewise.
+ * testsuite/experimental/memory_resource/new_delete_resource.cc:
+ Check that new and delete are called with expected sizes.
+
+2018-07-20 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86595
+ * include/bits/fs_dir.h (directory_entry::refresh(error_code&)): Add
+ noexcept.
+
+2018-07-20 Fangrui Song <maskray@google.com>
+
+ * include/bits/shared_ptr_base.h (_Sp_make_shared_tag::_S_ti): Use
+ _GLIBCXX_VISIBILITY(default).
+
+2018-07-20 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86603
+ * include/std/version: Move __cpp_lib_list_remove_return_type macro.
+
+2018-07-19 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/type_traits (__is_member_object_pointer_helper): Use
+ __not_<is_function<_Tp>>::type instead of integral_constant.
+ (__is_member_function_pointer_helper): Likewise for
+ is_function<_Tp>::type.
+ (is_compund): Likewise for __not_<is_fundamental<_Tp>>::type.
+ (__do_is_nt_destructible_impl): Use __bool_constant and reindent.
+ (is_trivially_constructible): Remove redundant use of
+ is_constructible.
+ (__is_trivially_copy_assignable_impl): Remove redundant use of
+ is_copy_assignable.
+ (__is_trivially_move_assignable_impl): Remove redundant use of
+ is_move_assignable.
+ (is_trivially_destructible): Use __bool_constant.
+ * testsuite/20_util/is_trivially_assignable/value.cc: Add some more
+ tests for scalar types.
+
+2018-07-19 Glen Joseph Fernandes <glenjofe@gmail.com>
+
+ * include/bits/stl_algobase.h (__copy_move_a): Used
+ __is_trivially_copyable.
+ (__copy_move_backward_a): Likewise.
+ * testsuite/20_util/specialized_algorithms/uninitialized_copy/1.cc:
+ New test.
+
+2018-07-17 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86450
+ * acinclude.m4 (GLIBCXX_CHECK_COMPILER_FEATURES): Don't define WERROR.
+ (GLIBCXX_EXPORT_FLAGS): Use -Wabi=2 instead of -Wabi.
+ * configure: Regenerate.
+ * configure.ac: Change GLIBCXX_ENABLE_WERROR default to "no".
+ * doc/Makefile.in: Regenerate.
+ * fragment.am: Set WERROR_FLAG to -Werror instead of $(WERROR).
+ * include/Makefile.in: Regenerate.
+ * libsupc++/Makefile.in: Regenerate.
+ * po/Makefile.in: Regenerate.
+ * python/Makefile.in: Regenerate.
+ * src/Makefile.in: Regenerate.
+ * src/c++11/Makefile.in: Regenerate.
+ * src/c++11/debug.cc: Use diagnostic pragmas to suppress warnings
+ from -Wabi=2 that don't affect exported symbols.
+ * src/c++98/Makefile.in: Regenerate.
+ * src/filesystem/Makefile.in: Regenerate.
+ * testsuite/Makefile.in: Regenerate.
+
+ * src/c++11/compatibility-thread-c++0x.cc [_GLIBCXX_SHARED]
+ (_Async_state_common::_M_join): Simplify use of std::call_once and
+ corresponding explicit instantiation.
+ (_Maybe_wrap_member_pointer, _Bind_simple, _Bind_simple_helper)
+ (__bind_simple): Remove definitions and explicit instantiation that
+ are not required by exported symbols.
+
+2018-07-16 Jonathan Wakely <jwakely@redhat.com>
+
+ * scripts/create_testsuite_files: Fix typo in comment.
+
+ PR libstdc++/86537
+ * include/bits/shared_ptr.h (less<shared_ptr<_Tp>>): Remove
+ non-standard partial specialization.
+ * include/bits/shared_ptr_base.h (_Sp_less): Remove class definition.
+ (less<__shared_ptr<_Tp, _Lp>): Remove partial specialization.
+ * testsuite/20_util/shared_ptr/comparison/86537.cc: New test.
+
+2018-07-16 Andreas Krebbel <krebbel@linux.ibm.com>
+
+ * config/abi/post/s390-linux-gnu/baseline_symbols.txt: Update.
+ * config/abi/post/s390x-linux-gnu/32/baseline_symbols.txt: Update.
+ * config/abi/post/s390x-linux-gnu/baseline_symbols.txt: Update.
+
+2018-07-06 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/functions.h (__gnu_debug::__check_string): Move...
+ * include/debug/string (__gnu_debug::__check_string): ... here.
+ (_GLIBCXX_DEBUG_VERIFY_STR_COND_AT): New.
+ (__glibcxx_check_string_n_constructor): New.
+ (__gnu_debug::basic_string<>(const _CharT*, size_type, const _Alloc&)):
+ Use latter.
+ (__glibcxx_check_string_constructor): New.
+ (__gnu_debug::basic_string<>(const _CharT*, const _Alloc&)):
+ Use latter.
+ * testsuite/21_strings/basic_string/debug/1_neg.cc: New.
+ * testsuite/21_strings/basic_string/debug/2_neg.cc: New.
+
+2018-07-06 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/84928 use std::move in <numeric> algorithms
+ * include/bits/stl_numeric.h (_GLIBCXX_MOVE_IF_20): Define macro to
+ conditionally move, according to __cplusplus value.
+ (accumulate, inner_product, partial_sum, adjacent_difference): Use
+ _GLIBCXX_MOVE_IF_20.
+ * testsuite/26_numerics/accumulate/lwg2055.cc: New test.
+ * testsuite/26_numerics/adjacent_difference/lwg2055.cc: New test.
+ * testsuite/26_numerics/inner_product/lwg2055.cc: New test.
+ * testsuite/26_numerics/partial_sum/lwg2055.cc: New test.
+
+ * config/abi/pre/gnu.ver: Use wildcards to combine related patterns.
+
+ P0935R0 Eradicating unnecessarily explicit default constructors
+ * config/abi/pre/gnu.ver: Tighten existing patterns and export new
+ default constructor symbols.
+ * include/std/sstream (basic_stringbuf, basic_istringstream)
+ (basic_ostringstream, basic_stringstream): Remove default arguments
+ from explicit constructors taking ios_base::openmode and add separate
+ non-explicit default constructors.
+ * testsuite/27_io/basic_istringstream/cons/default.cc: New.
+ * testsuite/27_io/basic_ostringstream/cons/default.cc: New.
+ * testsuite/27_io/basic_stringstream/cons/default.cc: New.
+ * testsuite/27_io/basic_stringbuf/cons/char/default.cc: New.
+ * testsuite/27_io/basic_stringbuf/cons/wchar_t/default.cc: New.
+
+ * include/std/variant (__accepted_index): Use void_t.
+
+2018-07-05 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85831
+ * config/abi/pre/gnu.ver: Export move constructors and move
+ assignment operators for std::logic_error and std::runtime_error.
+ * include/std/stdexcept: Use _GLIBCXX_NOTHROW instead of
+ _GLIBCXX_USE_NOEXCEPT.
+ (logic_error, runtime_error): Declare move constructors and move
+ assignment operators. When not declared already, define copy
+ constructors and copy assignment operators as explicit-defaulted.
+ (domain_error, invalid_argument, length_error, out_of_range)
+ (overflow_error, underflow_error): Define move constructors and move
+ assignment operators as explicitly-defaulted.
+ * libsupc++/exception.h (exception): Likewise.
+ * src/c++11/cow-stdexcept.cc (logic_error, runtime_error): Define
+ move constructors and move assignment operators as defaulted.
+ * testsuite/19_diagnostics/stdexcept.cc: Check that constructors and
+ assignment operators are defined.
+
+ * testsuite/21_strings/basic_string/cons/char/deduction.cc: XFAIL for
+ COW strings.
+ * testsuite/21_strings/basic_string/cons/wchar_t/deduction.cc:
+ Likewise.
+ * testsuite/21_strings/basic_string/requirements/
+ explicit_instantiation/debug.cc: Likewise.
+
+ PR libstdc++/58265
+ * include/bits/basic_string.h [!_GLIBCXX_USE_CXX11_ABI]
+ (basic_string::assign(basic_string&&)): Add conditional noexcept
+ depending on the allocator's is_always_equal property (LWG 2063).
+ * testsuite/21_strings/basic_string/modifiers/assign/char/
+ move_assign.cc: Check for non-throwing exception specification.
+ * testsuite/21_strings/basic_string/modifiers/assign/wchar_t/
+ move_assign.cc: Likewise.
+
+ PR libstdc++/58265
+ * include/bits/basic_string.h [!_GLIBCXX_USE_CXX11_ABI]
+ [_GLIBCXX_FULLY_DYNAMIC_STRING==0] (basic_string::basic_string()):
+ Add GLIBCXX_NOEXCEPT.
+ (basic_string::operator=(basic_string&&)): Add _GLIBCXX_NOEXCEPT_IF
+ to depend on the allocator's is_always_equal property (LWG 2063).
+ (basic_string::swap(basic_string&)): Likewise.
+ * include/bits/basic_string.tcc [!_GLIBCXX_USE_CXX11_ABI]
+ (basic_string::swap(basic_string&)): Likewise.
+ * testsuite/21_strings/basic_string/allocator/char/move_assign.cc:
+ Check is_nothrow_move_assignable.
+ * testsuite/21_strings/basic_string/allocator/wchar_t/move_assign.cc:
+ Check is_nothrow_move_assignable.
+ * testsuite/21_strings/basic_string/cons/char/
+ noexcept_move_construct.cc: Likewise.
+ * testsuite/21_strings/basic_string/cons/wchar_t/
+ noexcept_move_construct.cc: Likewise.
+
+2018-07-04 Jonathan Wakely <jwakely@redhat.com>
+
+ P0646R1 Improving the Return Value of Erase-Like Algorithms I
+ * include/bits/forward_list.h (__cpp_lib_list_remove_return_type):
+ Define.
+ (forward_list::__remove_return_type): Define typedef as size_type or
+ void, according to __cplusplus value.
+ (_GLIBCXX_FWDLIST_REMOVE_RETURN_TYPE_TAG): Define macro as abi-tag or
+ empty, according to __cplusplus value.
+ (forward_list::remove, forward_list::unique): Use typedef and macro
+ to change return type and add abi-tag for C++2a.
+ (forward_list::remove_if<Pred>, forward_list::unique<BinPred>): Use
+ typedef to change return type for C++2a.
+ * include/bits/forward_list.tcc (_GLIBCXX20_ONLY): Define macro.
+ (forward_list::remove, forward_list::remove_if<Pred>)
+ (forward_list::unique<BinPred>): Return number of removed elements
+ for C++2a.
+ * include/bits/list.tcc (_GLIBCXX20_ONLY): Define macro.
+ (list::remove, list::unique, list::remove_if<Predicate>)
+ (list::unique<BinaryPredicate>): Return number of removed elements
+ for C++2a.
+ * include/bits/stl_list.h (__cpp_lib_list_remove_return_type): Define.
+ (list::__remove_return_type): Define typedef as size_type or
+ void, according to __cplusplus value.
+ (_GLIBCXX_LIST_REMOVE_RETURN_TYPE_TAG): Define macro as abi-tag or
+ empty, according to __cplusplus value.
+ (list::remove, list::unique): Use typedef and macro to change return
+ type and add abi-tag for C++2a.
+ (list::remove_if<Predicate>, list::unique<BinaryPredicate>): Use
+ typedef to change return type for C++2a.
+ * include/std/version (__cpp_lib_list_remove_return_type): Define.
+ * testsuite/23_containers/forward_list/operations/
+ remove_cxx20_return.cc: New.
+ * testsuite/23_containers/forward_list/operations/
+ unique_cxx20_return.cc: New.
+
+ P0458R2 Checking for Existence of an Element in Associative Containers
+ * include/bits/stl_map.h (map::contains): Add for C++2a.
+ * include/bits/stl_multimap.h (multimap::contains): Likewise.
+ * include/bits/stl_multiset.h (multiset::contains): Likewise.
+ * include/bits/stl_set.h (set::contains): Likewise.
+ * include/bits/stl_tree.h (__has_is_transparent_t): Define alias.
+ (_Rb_tree::_M_find_tr, _Rb_tree::_M_count_tr)
+ (_Rb_tree::_M_lower_bound_tr, _Rb_tree::_M_upper_bound_tr)
+ (_Rb_tree::_M_equal_range_tr): Use __has_is_transparent_t.
+ * include/bits/unordered_map.h (unordered_map::contains)
+ (unordered_multimap::contains): Add for C++2a.
+ * include/bits/unordered_set.h (unordered_set::contains)
+ (unordered_multiset::contains): Likewise.
+ * testsuite/23_containers/map/operations/contains.cc: New.
+ * testsuite/23_containers/multimap/operations/contains.cc: New.
+ * testsuite/23_containers/multiset/operations/contains.cc: New.
+ * testsuite/23_containers/set/operations/contains.cc: New.
+ * testsuite/23_containers/unordered_map/operations/contains.cc: New.
+ * testsuite/23_containers/unordered_multimap/operations/contains.cc:
+ New.
+ * testsuite/23_containers/unordered_multiset/operations/contains.cc:
+ New.
+ * testsuite/23_containers/unordered_set/operations/contains.cc: New.
+
+2018-07-04 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/86272
+ * include/debug/string
+ (__gnu_debug::basic_string<>::insert<_Ite>(const_iterator, _Ite, _Ite)):
+ Use __glibcxx_check_insert_range.
+ * 21_strings/basic_string/cons/char/1.cc: Adapt test to use
+ __gnu_debug::string when _GLIBCXX_DEBUG.
+ * 21_strings/basic_string/init-list.cc: Likewise.
+ * 21_strings/basic_string/modifiers/insert/char/1.cc: Likewise.
+ * 21_strings/basic_string/modifiers/insert/char/2.cc: Likewise.
+ * 21_strings/basic_string/modifiers/insert/char/83328.cc: Likewise.
+ * 21_strings/basic_string/types/1.cc: Likewise.
+
+2018-07-04 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/25_algorithms/make_heap/complexity.cc: Require effective
+ target for std::random_device.
+ * testsuite/26_numerics/random/random_device/cons/default.cc:
+ Likewise.
+ * testsuite/experimental/algorithm/sample-2.cc: Likewise.
+ * testsuite/experimental/algorithm/shuffle.cc: Likewise.
+ * testsuite/experimental/random/randint.cc: Likewise.
+ * testsuite/lib/libstdc++.exp
+ (check_effective_target_random_device): New proc.
+
+2018-07-04 Jonathan Wakely <jwakely@redhat.com>
+ Jakub Jelinek <jakub@redhat.com>
+
+ * include/std/bit (__rotl, __rotr): Fix for non-power of two sizes.
+
+2018-07-04 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86398
+ * include/std/type_traits (is_trivially_constructible): Check
+ is_constructible before __is_trivially_constructible.
+ * testsuite/20_util/is_trivially_constructible/value.cc: Add more
+ tests, including negative cases.
+ * testsuite/20_util/make_signed/requirements/typedefs_neg.cc: Use
+ zero for dg-error lineno.
+ * testsuite/20_util/make_unsigned/requirements/typedefs_neg.cc:
+ Likewise.
+
+ * include/std/bit (__rotl, __rotr): Avoid branch.
+ (_If_is_unsigned_integer): Use remove_cv_t.
+ * testsuite/26_numerics/bit/bitops.count/popcount.cc: New.
+
+2018-07-03 Jonathan Wakely <jwakely@redhat.com>
+
+ P0556R3 Integral power-of-2 operations, P0553R2 Bit operations
+ * include/Makefile.am: Add new header.
+ * include/Makefile.in: Regenerate.
+ * include/precompiled/stdc++.h: Include new header.
+ * include/std/bit: New header.
+ (__rotl, __rotr, __countl_zero, __countl_one, __countr_zero)
+ (__countr_one, __popcount, __ispow2, __ceil2, __floor2, __log2p1):
+ Define for C++14.
+ [!__STRICT_ANSI__] (rotl, rotr, countl_zero, countl_one, countr_zero)
+ (countr_one, popcount): Define for C++2a. Also overload for std::byte.
+ (ispow2, ceil2, floor2, log2p1): Define for C++2a.
+ [!__STRICT_ANSI__] (ispow2, ceil2, floor2, log2p1): Overload for
+ std::byte.
+ * testsuite/26_numerics/bit/bit.pow.two/ceil2.cc: New.
+ * testsuite/26_numerics/bit/bit.pow.two/floor2.cc: New.
+ * testsuite/26_numerics/bit/bit.pow.two/ispow2.cc: New.
+ * testsuite/26_numerics/bit/bit.pow.two/log2p1.cc: New.
+ * testsuite/26_numerics/bit/bitops.rot/rotl.cc: New.
+ * testsuite/26_numerics/bit/bitops.rot/rotr.cc: New.
+ * testsuite/26_numerics/bit/bitops.count/countl_one.cc: New.
+ * testsuite/26_numerics/bit/bitops.count/countl_zero.cc: New.
+ * testsuite/26_numerics/bit/bitops.count/countr_one.cc: New.
+ * testsuite/26_numerics/bit/bitops.count/countr_zero.cc: New.
+
+ * include/bits/alloc_traits.h: Remove redundant preprocessor
+ condition.
+
+2018-07-03 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_algobase.h (__niter_wrap): New.
+ (__copy_move_a2(_II, _II, _OI)): Use latter.
+ (__copy_move_backward_a2(_BI1, _BI1, _BI2)): Likewise.
+ (fill_n(_OI, _Size, const _Tp&)): Likewise.
+ (equal(_II1, _II1, _II2)): Use __glibcxx_requires_can_increment.
+ * include/debug/stl_iterator.h
+ (std::__niter_base(const __gnu_cxx::_Safe_iterator<
+ __gnu_cxx::__normal_iterator<>, _Sequence>&)): New declaration.
+ * include/debug/vector (__niter_base(const __gnu_cxx::_Safe_iterator<
+ __gnu_cxx::__normal_iterator<>, _Sequence>&)): New.
+
+2018-07-02 Jonathan Wakely <jwakely@redhat.com>
+
+ P0758R1 Implicit conversion traits
+ * include/std/type_traits [__cplusplus > 201703]
+ (__is_convertible_helper::__is_nothrow_type): Define new member.
+ (__is_convertible_helper<_From, _To, false>::__test_aux1): Add
+ noexcept.
+ (__is_convertible_helper<_From, _To, false>::__test_nothrow)
+ (__is_convertible_helper<_From, _To, false>::__is_nothrow_type): Add
+ new members.
+ (is_nothrow_convertible, is_nothrow_convertible_v): Define for C++2a.
+ * testsuite/20_util/is_nothrow_convertible/value.cc: New.
+ * testsuite/20_util/is_nothrow_convertible/requirements/
+ explicit_instantiation.cc: New.
+ * testsuite/20_util/is_nothrow_convertible/requirements/typedefs.cc:
+ New.
+
+ P0887R1 The identity metafunction
+ * include/std/type_traits (type_identity, type_identity_t): Define
+ for C++2a.
+ * testsuite/20_util/type_identity/requirements/alias_decl.cc: New.
+ * testsuite/20_util/type_identity/requirements/
+ explicit_instantiation.cc:New.
+ * testsuite/20_util/type_identity/requirements/typedefs.cc: New.
+
+ * include/bits/regex.h (sub_match::operator string_type): Call str().
+ (sub_match::compare): Use _M_str() instead of str().
+ (sub_match::_M_compare): New public function.
+ (sub_match::__string_view): New helper type.
+ (sub_match::_M_str): New overloaded functions to avoid creating a
+ string_type object when not needed.
+ (operator==, operator!=, operator<, operator>, operator<=, operator>=):
+ Use sub_match::_M_compare instead of creating string_type objects.
+ Fix Doxygen comments.
+ * include/bits/regex_compiler.h (__has_contiguous_iter): Remove.
+ (__is_contiguous_normal_iter): Rename to __is_contiguous_iter and
+ simplify.
+ (__enable_if_contiguous_iter, __disable_if_contiguous_iter): Use
+ __enable_if_t.
+ * include/std/type_traits (__enable_if_t): Define for C++11.
+ * testsuite/28_regex/sub_match/compare.cc: New.
+ * testsuite/util/testsuite_iterators.h (remove_cv): Add transformation
+ trait.
+ (input_iterator_wrapper): Use remove_cv for value_type argument of
+ std::iterator base class.
+
+2018-06-29 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/20_util/add_rvalue_reference/requirements/alias_decl.cc:
+ Add whitespace to dejagnu directive.
+ * testsuite/23_containers/array/element_access/at_neg.cc: Likewise.
+
+2018-06-27 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_vector.h
+ (struct _Vector_base<>::_Vector_impl_data): New.
+ (struct _Vector_base<>::_Vector_impl): Inherit from latter.
+ (_Vector_base<>::_Vector_impl::_M_swap_data): Move...
+ (_Vector_base<>::_Vector_impl_data::_M_swap_data): ...here.
+ (_Vector_base<>::_Vector_impl()): Add noexcept qualification.
+ (_Vector_base<>::_Vector_impl(_Vector_impl&&)): New.
+ (_Vector_base<>::_Vector_impl(_Tp_alloc_type&&, _Vector_impl&&)): New.
+ (_Vector_base(const allocator_type&, _Vector_base&&)): New, use latter.
+ (_Vector_base()): Default.
+ (_Vector_base(_Vector_base&&)): Default.
+ (_Vector_base(size_t)) [_GLIBCXX_INLINE_VERSION]: Delete.
+ (_Vector_base(_Tp_alloc_type&&)) [_GLIBCXX_INLINE_VERSION]: Delete.
+ (_Vector_base::_M_create_storage(size_t)): Make protected.
+ (vector()): Default.
+ (vector(vector&&)): Default.
+ (vector(vector&&, const allocator_type&, true_type)): New.
+ (vector(vector&&, const allocator_type&, false_type)): New.
+ (vector(vector&&, const allocator_type&)): Use latters.
+ (vector(_InputIte, _InputIte, const allocator_type&)): Call
+ _M_range_initialize directly.
+ * include/debug/vector
+ (vector(vector&&, const allocator_type&)): Add noexcept qualification.
+ * testsuite/23_containers/vector/allocator/default_init.cc: New.
+ * testsuite/23_containers/vector/cons/noexcept_move_construct.cc: Add
+ static assertions.
+
+2018-06-27 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/cpp_type_traits.h [__cplusplus >= 201703]
+ (__is_byte<byte>): Define specialization for std::byte.
+
+ PR libstdc++/86138
+ * include/bits/basic_string.tcc: [_GLIBCXX_EXTERN_TEMPLATE < 0]
+ Declare explicit instantiations of COW empty reps and I/O functions.
+
+2018-06-26 David Edelsohn <dje.gcc@gmail.com>
+
+ * testsuite/experimental/algorithm/sample-2.cc: Add TLS DejaGNU
+ directives.
+ * testsuite/experimental/algorithm/shuffle.cc: Likewise.
+
+2018-06-26 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/regex.tcc (regex_iterator::operator==): Add missing
+ noexcept.
+
+2018-06-25 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86112
+ * python/libstdcxx/v6/printers.py (add_one_template_type_printer):
+ Replace dict comprehension.
+
+ PR libstdc++/81092
+ * config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt: Update.
+
+ PR libstdc++/86292
+ * include/bits/stl_vector.h (vector::_M_range_initialize<InputIter>):
+ Add try-catch block.
+ * testsuite/23_containers/vector/cons/86292.cc: New.
+
+ * doc/xml/manual/status_cxx2017.xml: Document N4531 status.
+
+ * include/experimental/algorithm (sample, shuffle): Add new overloads
+ using per-thread random number engine.
+ * testsuite/experimental/algorithm/sample.cc: Simpify and reduce
+ dependencies by using __gnu_test::test_container.
+ * testsuite/experimental/algorithm/sample-2.cc: New.
+ * testsuite/experimental/algorithm/shuffle.cc: New.
+
+2018-06-22 Jonathan Wakely <jwakely@redhat.com>
+
+ * config/abi/pre/gnu.ver: Fix __cxx11::basic_string patterns for
+ different size_t mangling on 32-bit targets.
+
+ PR libstdc++/86280
+ * include/experimental/memory_resource
+ (__resource_adaptor_common::_AlignMgr::_M_token_size): Use type large
+ enough for result of left shift.
+
+ PR libstdc++/86138
+ * include/bits/basic_string.tcc:
+ [__cplusplus > 201402 && !_GLIBCXX_USE_CXX11_ABI]
+ (basic_string<char>::_Rep::_S_empty_rep_storage)
+ (basic_string<wchar_t>::_Rep::_S_empty_rep_storage): Add explicit
+ instantiation declarations.
+ [__cplusplus > 201402] (operator>>, operator<<, getline): Re-enable
+ explicit instantiation declarations.
+ * testsuite/21_strings/basic_string/cons/char/86138.cc: New.
+ * testsuite/21_strings/basic_string/cons/wchar_t/86138.cc: New.
+
+2018-06-21 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83328
+ * acinclude.m4 (libtool_VERSION): Bump to 6:26:0.
+ * config/abi/pre/gnu.ver: Add GLIBCXX_3.4.26 and export new symbol.
+ * configure: Regenerate.
+ * include/bits/basic_string.h [_GLIBCXX_USE_CXX11_ABI]
+ (basic_string::insert(const_iterator, initializer_list<C>)): Add.
+ [_GLIBCXX_USE_CXX11_ABI && !_GLIBCXX_DEFINING_STRING_INSTANTIATIONS]
+ (basic_string::insert(iterator, initializer_list<C>)): Suppress
+ definition.
+ * include/debug/string (basic_string::insert(iterator, C)): Change
+ first parameter to const_iterator.
+ (basic_string::insert(iterator, size_type, C)): Likewise. Change
+ return type to iterator.
+ (basic_string::insert(iterator, InputIterator, InputIterator)):
+ Likewise.
+ (basic_string::insert(iterator, initializer_list<C>)): Change first
+ parameter to const_iterator and return type to iterator.
+ * src/c++11/string-inst.cc: Extend comment.
+ * testsuite/21_strings/basic_string/modifiers/insert/char/83328.cc:
+ New.
+ * testsuite/21_strings/basic_string/modifiers/insert/wchar_t/83328.cc:
+ New.
+ * testsuite/util/testsuite_abi.cc: Add new symbol version.
+
+ * config/abi/post/x86_64-linux-gnu/baseline_symbols.txt: Update.
+
+ PR libstdc++/70940
+ * include/experimental/memory_resource
+ (__resource_adaptor_imp::do_deallocate): Add missing return.
+ * testsuite/experimental/memory_resource/new_delete_resource.cc: New.
+ * testsuite/experimental/memory_resource/resource_adaptor.cc: Test
+ resource_adaptor with std::allocator, __gnu_cxx::new_allocator and
+ __gnu_cxx::malloc_allocator.
+
+ PR libstdc++/70940
+ * include/experimental/memory_resource (__resource_adaptor_common):
+ New base class.
+ (__resource_adaptor_common::_AlignMgr): Helper for obtaining aligned
+ pointer from unaligned, and vice versa.
+ (__resource_adaptor_imp::do_allocate): Use _AlignMgr to adjust
+ allocated pointer to meet alignment request.
+ (__resource_adaptor_imp::do_deallocate): Use _AlignMgr to retrieve
+ original pointer for deallocation.
+ (__resource_adaptor_imp::do_is_equal): Reformat.
+ (__resource_adaptor_imp::_S_aligned_size): Remove.
+ (__resource_adaptor_imp::_S_supported): Remove.
+ (new_delete_resource): Use __gnu_cxx::new_allocator.
+ * testsuite/experimental/memory_resource/resource_adaptor.cc: Test
+ extended alignments and use debug_allocator to check for matching
+ allocate/deallocate pairs.
+
+2018-06-21 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/safe_iterator.h
+ (_Safe_iterator<>(const _Safe_iterator<_MutableIterator,>& __x)):
+ Compare __x base iterator with a value-initialized iterator of the
+ same type.
+
+2018-06-20 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/70966
+ * include/experimental/memory_resource (__resource_adaptor_imp): Add
+ static assertions to enforce requirements on pointer types.
+ (__resource_adaptor_imp::get_allocator()): Add noexcept.
+ (new_delete_resource, null_memory_resource): Return address of an
+ object with dynamic storage duration.
+ (__null_memory_resource): Remove.
+ * testsuite/experimental/memory_resource/70966.cc: New.
+
+ * testsuite/20_util/duration/arithmetic/dr3050.cc: Add new test
+ missed from recent commit.
+
+2018-06-19 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/utility: Remove unused <exception> header.
+
+2018-06-18 Jonathan Wakely <jwakely@redhat.com>
+
+ LWG 2975 ensure construct(pair<T,U>*, ...) used to construct pairs
+ * include/std/scoped_allocator (__not_pair): Define SFINAE helper.
+ (construct(_Tp*, _Args&&...)): Remove from overload set when _Tp is
+ a specialization of std::pair.
+ * testsuite/20_util/scoped_allocator/construct_pair.cc: Ensure
+ pair elements are constructed correctly.
+
+ LWG 2989 hide path iostream operators from normal lookup
+ * include/bits/fs_path.h (operator<<, operator>>): Define inline as
+ friends.
+ * testsuite/27_io/filesystem/path/io/dr2989.cc: New.
+
+ LWG 3050 Fix cv-qualification of convertibility constraints
+ * include/std/chrono (duration, operator*, operator/, operator%): Use
+ const-qualified type as source type in is_convertible constraints.
+ * testsuite/20_util/duration/arithmetic/dr3050.cc: New.
+ * testsuite/20_util/duration/cons/dr3050.cc: New.
+ * testsuite/20_util/duration/literals/range.cc: Rename to...
+ * testsuite/20_util/duration/literals/range_neg.cc: Here. Adjust
+ dg-error lineno.
+
+2018-06-18 Maya Rashish <coypu@sdf.org>
+
+ * crossconfig.m4: Handle OpenBSD just like NetBSD.
+ * configure: Rebuilt.
+
+2018-06-18 Jonathan Wakely <jwakely@redhat.com>
+
+ P0754R2 <version> header
+ * include/Makefile.am: Add new header.
+ * include/Makefile.in: Regenerate.
+ * include/bits/c++config: Change doxygen comment to suggest <version>
+ instead of <iosfwd>.
+ * include/precompiled/stdc++.h: Include <cwchar> and <cwctype>
+ unconditionally. Add C++17 and C++20 headers.
+ * include/std/version: New header.
+ * testsuite/17_intro/headers/c++2017/all_attributes.cc: New.
+ * testsuite/17_intro/headers/c++2017/all_no_exceptions.cc: New.
+ * testsuite/17_intro/headers/c++2017/all_no_rtti.cc: New.
+ * testsuite/17_intro/headers/c++2017/all_pedantic_errors.cc: New.
+ * testsuite/17_intro/headers/c++2017/operator_names.cc: New.
+ * testsuite/17_intro/headers/c++2017/stdc++.cc: New.
+ * testsuite/17_intro/headers/c++2017/stdc++_multiple_inclusion.cc:
+ New.
+ * testsuite/17_intro/headers/c++2020/all_attributes.cc: New.
+ * testsuite/17_intro/headers/c++2020/all_no_exceptions.cc: New.
+ * testsuite/17_intro/headers/c++2020/all_no_rtti.cc: New.
+ * testsuite/17_intro/headers/c++2020/all_pedantic_errors.cc: New.
+ * testsuite/17_intro/headers/c++2020/operator_names.cc: New.
+ * testsuite/17_intro/headers/c++2020/stdc++.cc: New.
+ * testsuite/17_intro/headers/c++2020/stdc++_multiple_inclusion.cc:
+ New.
+ * testsuite/18_support/headers/version/macros.cc: New.
+ * testsuite/18_support/headers/version/macros.cc: New.
+
+ * acinclude.m4 (GLIBCXX_CHECK_FILESYSTEM_DEPS): Only check when
+ enable_libstdcxx_filesystem_ts = yes. Check for link, readlink and
+ symlink.
+ * config.h.in: Regenerate.
+ * configure: Regenerate.
+ * configure.ac: Remove AC_CHECK_FUNCS for link, readlink and symlink.
+
+ LWG 3035. std::allocator's constructors should be constexpr
+ * include/bits/allocator.h (allocator): Add constexpr to constructors
+ for C++2a. Replace dynamic exception specifications with NOTHROW
+ macro.
+ (allocator, operator==, operator!=): Replace USE_NOEXCEPT macro with
+ NOTHROW.
+ * include/bits/c++config (_GLIBCXX20_CONSTEXPR): Define.
+ * include/ext/malloc_allocator.h (malloc_allocator): Add constexpr
+ to constructors for C++2a.
+ * include/ext/new_allocator.h (new_allocator): Likewise.
+
+2018-06-16 Jonathan Wakely <jwakely@redhat.com>
+
+ LWG 3076 basic_string CTAD ambiguity
+ * doc/xml/manual/intro.xml: Document LWG 3076 change.
+ * include/bits/basic_string.h
+ [__cpp_deduction_guides && !_GLIBCXX_DEFINING_STRING_INSTANTIATIONS]
+ (basic_string(const _CharT*, const _Alloc&)): Turn into a function
+ template constrained by _RequireAllocator.
+ (basic_string(size_type, _CharT, const _Alloc&)): Likewise.
+ * src/c++11/string-inst.cc (_GLIBCXX_DEFINING_STRING_INSTANTIATIONS):
+ Define.
+ * testsuite/21_strings/basic_string/cons/char/deduction.cc: Test
+ deduction
+ * testsuite/21_strings/basic_string/cons/wchar_t/deduction.cc:
+ Likewise.
+
+2018-06-15 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86169
+ * include/bits/basic_string.h [!_GLIBCXX_USE_CXX11_ABI]
+ (basic_string::data()): Unshare string.
+ * testsuite/21_strings/basic_string/operations/data/char/86169.cc:
+ New.
+
+ * include/std/string_view (basic_string_view(const CharT*)): Remove
+ check for null pointer and add nonnull attribute.
+ (compare(const CharT*), compare(size_type, size_type, const CharT*))
+ (find(const CharT*, size_type), rfind(const CharT*, size_type))
+ (find_first_of(const CharT*, size_type))
+ (find_last_of(const CharT*, size_type))
+ (find_first_not_of(const CharT*, size_type))
+ (find_last_not_of(const CharT*, size_type)): Add nonnull attribute.
+ * testsuite/21_strings/basic_string_view/cons/char/nonnull.cc: New.
+ * testsuite/21_strings/basic_string_view/operations/compare/char/
+ nonnull.cc: New.
+ * testsuite/21_strings/basic_string_view/operations/find/char/
+ nonnull.cc: New.
+ * testsuite/21_strings/basic_string_view/operations/rfind/char/
+ nonnull.cc: New.
+
+ PR libstdc++/86168
+ * include/bits/random.h (random_device(const string&)): Remove
+ default argument.
+
+ * include/bits/char_traits.h (__cpp_lib_constexpr_char_traits): Only
+ define for C++17 and above.
+
+ LWG 2993 reference_wrapper<T> conversion from T&&
+ * doc/xml/manual/intro.xml: Document LWG 2993 change.
+ * include/bits/refwrap.h (reference_wrapper(_Tp&)): Remove.
+ (reference_wrapper(_Tp&&)): Remove.
+ (reference_wrapper<_Up>(_Up&&)): Define new constructor as constrained
+ template.
+ (reference_wrapper): Add deduction guide.
+ * testsuite/20_util/reference_wrapper/deduction.cc: New.
+ * testsuite/20_util/reference_wrapper/lwg2993.cc: New.
+
+ LWG 3039 Unnecessary decay in thread and packaged_task
+ * include/std/future (__constrain_pkgdtask): Replace with ...
+ (packaged_task::__not_same): New alias template, using
+ __remove_cvref_t instead of decay.
+ * include/std/thread (thread::__not_same): Add comment.
+
+2018-06-14 Jonathan Wakely <jwakely@redhat.com>
+
+ LWG 3075 basic_string needs deduction guides from basic_string_view
+ * testsuite/21_strings/basic_string/cons/char/deduction.cc: Test
+ deduction from string views.
+ * testsuite/21_strings/basic_string/cons/wchar_t/deduction.cc:
+ Likewise.
+
+ LWG 3074 make scalar types non-deduced in valarray non-member functions
+ * include/bits/valarray_after.h (_DEFINE_EXPR_BINARY_FUNCTION): Change
+ scalar parameters to be a non-deduced context.
+ * include/std/valarray (_DEFINE_BINARY_OPERATOR): Likewise. Adjust
+ whitespace.
+ * testsuite/26_numerics/valarray/operators.cc: Test scalar operands.
+ * testsuite/26_numerics/valarray/transcend.cc: New.
+
+ * include/std/tuple (__cpp_lib_tuple_element_t, tuple_element_t):
+ Move back to <utility>.
+ * include/std/utility (__cpp_lib_tuple_element_t. tuple_element_t):
+ Restore to here.
+
+ P0935R0 Eradicating unnecessarily explicit default constructors
+ * include/backward/strstream (strstreambuf): Add non-explicit default
+ constructor.
+ * include/bits/locale_conv.h (wbuffer_convert, wstring_convert):
+ Likewise.
+ * include/bits/regex.h (match_results): Likewise.
+ * testsuite/22_locale/conversions/buffer/1.cc: Test for non-explicit
+ default constructor.
+ * testsuite/22_locale/conversions/string/1.cc: Likewise.
+ * testsuite/28_regex/match_results/ctors/char/default.cc: Likewise.
+ * testsuite/28_regex/match_results/ctors/wchar_t/default.cc: Likewise.
+
+ * include/std/tuple (__cpp_lib_tuple_element_t): Move feature test
+ macro from <utility> and change type to long.
+ * include/std/utility (__cpp_lib_tuple_element_t): Remove.
+ * testsuite/20_util/tuple/tuple_element_t.cc: Check for feature test
+ macro.
+
+ P0935R0 Eradicating unnecessarily explicit default constructors
+ * include/bits/random.h (uniform_real_distribution::param_type)
+ (normal_distribution::param_type, lognormal_distribution::param_type)
+ (gamma_distribution::param_type, chi_squared_distribution::param_type)
+ (cauchy_distribution::param_type, fisher_f_distribution::param_type)
+ (student_t_distribution::param_type)
+ (bernoulli_distribution::param_type)
+ (binomial_distribution::param_type)
+ (geometric_distribution::param_type)
+ (negative_binomial_distribution::param_type)
+ (poisson_distribution::param_type)
+ (exponential_distribution::param_type)
+ (weibull_distribution::param_type)
+ (extreme_value_distribution::param_type): Add non-explicit default
+ constructors. Remove default argument for first parameter of explicit
+ constructors.
+ * include/bits/uniform_int_dist.h
+ (uniform_int_distribution::param_type): Likewise.
+ * include/ext/random
+ (beta_distribution::param_type, rice_distribution::param_type)
+ (nakagami_distribution::param_type, pareto_distribution::param_type)
+ (k_distribution::param_type, arcsine_distribution::param_type)
+ (hoyt_distribution::param_type, triangular_distribution::param_type)
+ (von_mises_distribution::param_type)
+ (hypergeometric_distribution::param_type)
+ (logistic_distribution::param_type)
+ (uniform_inside_sphere_distribution::param_type): Likewise.
+ (uniform_on_sphere_distribution::param_type): Make default constructor
+ non-explicit.
+ * testsuite/26_numerics/random/bernoulli_distribution/cons/default.cc:
+ Test param_type for non-explicit default constructor.
+ * testsuite/26_numerics/random/binomial_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/cauchy_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/chi_squared_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/discrete_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/exponential_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/extreme_value_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/fisher_f_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/gamma_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/geometric_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/lognormal_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/negative_binomial_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/normal_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/piecewise_constant_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/piecewise_linear_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/poisson_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/student_t_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/uniform_int_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/uniform_real_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/weibull_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/arcsine_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/beta_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/hoyt_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/hypergeometric_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/k_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/logistic_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/nakagami_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/normal_mv_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/pareto_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/rice_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/triangular_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/uniform_inside_sphere_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/uniform_on_sphere_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/von_mises_distribution/cons/default.cc:
+ Likewise.
+
+2018-06-14 Daniel Trebbien <dtrebbien@gmail.com>
+ Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83982
+ * include/bits/vector.tcc (vector::_M_default_append(size_type)):
+ Default-construct new elements before moving existing ones.
+ * testsuite/23_containers/vector/capacity/resize/strong_guarantee.cc:
+ New.
+
+2018-06-13 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86127
+ * include/bits/forward_list.h (_Fwd_list_base::_Tp_alloc_type): Remove
+ unused typedef.
+ (_Fwd_list_base::_M_create_node, _Fwd_list_base::_M_erase_after):
+ Use node allocator to create and destroy elements.
+ (forward_list::_Tp_alloc_type): Remove unused typedef.
+ (forward_list::_Alloc_traits): Use allocator_traits instead of
+ __gnu_cxx::__alloc_traits.
+
+2018-06-13 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/helper_functions.h
+ (__gnu_debug::_Safe_iterator<>): Add declaration.
+ (__can_advance(_Ite, _Size)): New.
+ (__can_advance(const _Safe_iterator<>&, _Size)): Overload declaration.
+ * include/debug/functions.h
+ (__gnu_debug::_Safe_iterator<>): Remove declaration.
+ * include/debug/stl_iterator.h
+ (__can_advance(const _Safe_iterator<>&)): New definition.
+ * include/debug/stl_iterator.h
+ (__can_advance(const std::reverse_iterator<>&, _Size)): New.
+ (__can_advance(const std::move_iterator<>&, _Size)): New.
+ * include/debug/macros.h (__glibcxx_check_can_increment): New.
+ * include/debug/debug.h (__glibcxx_requires_can_increment): New.
+ * include/bits/stl_algobase.h (fill_n): Use latter.
+ * testsuite/25_algorithms/fill_n/2.cc: New.
+ * testsuite/25_algorithms/fill_n/debug/1_neg.cc: New.
+ * testsuite/25_algorithms/fill_n/debug/2_neg.cc: New.
+ * testsuite/25_algorithms/fill_n/debug/3_neg.cc: New.
+ * testsuite/25_algorithms/fill_n/debug/4_neg.cc: New.
+
+ * include/debug/debug.h (__glibcxx_requires_can_increment_range): New.
+ (__glibcxx_requires_can_decrement_range): New.
+
+2018-06-12 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/macros.h (__glibcxx_check_can_increment_range): New.
+ (__glibcxx_check_can_decrement_range): New.
+ * include/bits/stl_algobase.h (std::copy(_II, _II, _OI)): Use
+ __glibcxx_requires_can_increment_range.
+ (std::move(_II, _II, _OI)): Likewise.
+ (std::copy_backward(_BI, _BI, _BI2)): Use
+ __glibcxx_requires_can_decrement_range.
+ (std::move_backward(_BI, _BI, _BI2)): Likewise.
+ * testsuite/25_algorithms/copy_backward/debug/1_neg.cc: New.
+ * testsuite/25_algorithms/copy_backward/debug/2_neg.cc: New.
+ * testsuite/25_algorithms/copy_backward/debug/3_neg.cc: New.
+ * testsuite/25_algorithms/equal/debug/1_neg.cc: New.
+ * testsuite/25_algorithms/equal/debug/2_neg.cc: New.
+ * testsuite/25_algorithms/equal/debug/3_neg.cc: New.
+
+2018-06-12 Jonathan Wakely <jwakely@redhat.com>
+
+ P0935R0 Eradicating unnecessarily explicit default constructors
+ * include/bits/random.h (linear_congruential_engine)
+ (mersenne_twister_engine, subtract_with_carry_engine, random_device)
+ (uniform_real_distribution, normal_distribution)
+ (lognormal_distribution, gamma_distribution, chi_squared_distribution)
+ (cauchy_distribution, fisher_f_distribution, student_t_distribution)
+ (bernoulli_distribution, binomial_distribution,geometric_distribution)
+ (negative_binomial_distribution, exponential_distribution)
+ (weibull_distribution, extreme_value_distribution): Add non-explicit
+ default constructors. Remove default argument for first parameter of
+ explicit constructors.
+ (piecewise_constant_distribution, piecewise_linear_distribution):
+ Make default constructor non-explicit.
+ * include/bits/uniform_int_dist.h (uniform_int_distribution): Add
+ non-explicit default constructors. Remove default argument for first
+ parameter of explicit constructor.
+ * include/ext/random
+ (simd_fast_mersenne_twister_engine, beta_distribution)
+ (rice_distribution, nakagami_distribution, pareto_distribution)
+ (k_distribution, arcsine_distribution, hoyt_distribution)
+ (triangular_distribution, von_mises_distribution)
+ (hypergeometric_distribution, logistic_distribution)
+ (uniform_inside_sphere_distribution): Likewise.
+ (uniform_on_sphere_distribution): Make default constructor
+ non-explicit.
+ * testsuite/26_numerics/random/bernoulli_distribution/cons/default.cc:
+ Test for non-explicit default constructor. Fix references to standard.
+ * testsuite/26_numerics/random/binomial_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/cauchy_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/chi_squared_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/discrete_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/exponential_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/extreme_value_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/fisher_f_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/gamma_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/geometric_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/lognormal_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/negative_binomial_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/normal_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/piecewise_constant_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/piecewise_linear_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/poisson_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/student_t_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/uniform_int_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/uniform_real_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/26_numerics/random/weibull_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/arcsine_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/beta_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/hoyt_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/hypergeometric_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/k_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/logistic_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/nakagami_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/normal_mv_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/pareto_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/rice_distribution/cons/default.cc: Likewise.
+ * testsuite/ext/random/triangular_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/uniform_inside_sphere_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/uniform_on_sphere_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/ext/random/von_mises_distribution/cons/default.cc:
+ Likewise.
+ * testsuite/util/testsuite_common_types.h
+ (implicitly_default_constructible): New helper.
+
+2018-06-08 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/ios_base.h (ios::Init::Init(const Init&))
+ (ios::Init::operator=): Define as defaulted.
+ * include/bits/stl_bvector.h (_Bit_reference(const _Bit_reference&)):
+ Likewise.
+ * include/bits/stream_iterator.h (istream_iterator::operator=)
+ (ostream_iterator::operator=): Likewise.
+ * include/bits/streambuf_iterator.h (istreambuf_iterator::operator=)
+ Likewise.
+ * include/std/bitset (bitset::reference::reference(const reference&)):
+ Likewise.
+ * include/std/complex (complex<float>::complex(const complex&))
+ (complex<double>::complex(const complex&))
+ (complex<long double>::complex(const complex&)): Likewise.
+
+2018-06-07 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/regex.h (sub_match): Add noexcept to default
+ constructor and length observer.
+ (match_results): Add noexcept to default constructor and observers
+ with no preconditions. Define destructor as defaulted.
+ (operator==, operator!=, swap): Add noexcept.
+ (regex_iterator): Add default member initializers and define default
+ constructor and destructor as defaulted. Add noexcept to equality
+ and dereference operators.
+
+2018-06-07 François Dumont <fdumont@gcc.gnu.org>
+
+ * src/c++11/debug.cc
+ (_Safe_iterator_base::_M_detach()): Reset state only if needed.
+ (_Safe_iterator_base::_M_detach_single()): Likewise.
+ (_Safe_local_iterator_base::_M_detach()): Reset state only if needed.
+ (_Safe_local_iterator_base::_M_detach_single()): Likewise.
+
+2018-06-06 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/shared_ptr_base.h (__shared_count): Remove redundant
+ move of const value.
+
+2018-06-06 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/86068
+ * include/bits/c++config: Check __cpp_transactional_memory >= 201500L
+ rather than __cpp_transactional_memory >= 201505L.
+
+2018-06-06 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/86008
+ * include/bits/quoted_string.h (_Quoted_string<basic_string_view, C>):
+ Define new partial specialization.
+ * include/std/iomanip (quoted(basic_string_view<C,T>, C, C)): Define
+ new overload.
+ (operator<<(basic_ostream<C,T>&, const _Quoted_string<S,C>&)): Use
+ value not reference for iteration.
+ * testsuite/27_io/manipulators/standard/char/quoted.cc: Adjust
+ comment.
+ * testsuite/27_io/manipulators/standard/char/quoted_sv.cc: New test.
+ * testsuite/27_io/manipulators/standard/wchar_t/quoted.cc: Adjust
+ comment.
+
+2018-06-05 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/type_traits: Fix comment typos.
+
+ * testsuite/27_io/filesystem/operations/read_symlink.cc: XFAIL for
+ mingw* targets.
+ * testsuite/27_io/filesystem/operations/symlink_status.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/read_symlink.cc:
+ Likewise.
+
+2018-06-05 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_tempbuf.h
+ (_Temporary_buffer(_FwdIte, _FwdIte)): Delete, replaced by...
+ (_Temporary_buffer(_FwdIte, size_type)): ...this, new.
+ * include/ext/memory (temporary_buffer<>(_FwdIte, _FwdIte)): Adapt.
+ * include/bits/stl_algo.h (__stable_partition): Adapt.
+ (__inplace_merge): Adapt.
+ (__stable_sort): Adapt.
+
+2018-06-04 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85930
+ * include/bits/shared_ptr_base.h [!__cpp_rtti]: Include <typeinfo>
+ unconditionally. Remove redundant declaration.
+ [!__cpp_rtti] (_Sp_make_shared_tag::_S_ti): Fix location of
+ alignment-specifier.
+
+ * include/bits/postypes.h (fpos): Define special members as defaulted.
+
+ PR libstdc++/85930
+ * include/bits/shared_ptr_base.h (_Sp_make_shared_tag::_S_ti): Align
+ the static variable correctly.
+
+2018-05-24 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/78870 support std::filesystem on Windows
+ * config.h.in: Regenerate.
+ * configure: Regenerate.
+ * configure.ac: Check for link, readlink and symlink.
+ * include/bits/fs_path.h (path::operator/=(const path&)): Move
+ definition out of class body.
+ (path::is_absolute(), path::_M_append(path)): Likewise.
+ (operator<<(basic_ostream, const path&)): Use std::quoted directly.
+ (operator>>(basic_istream, path&)): Likewise.
+ (u8path): Reorder definitions and fix Windows implementation.
+ (path::is_absolute()): Define inline and fix for Windows.
+ [!_GLIBCXX_FILESYSTEM_IS_WINDOWS] (path::operator/=(const path&)):
+ Define POSIX version inline.
+ (path::_M_append(path)): Define inline.
+ * include/experimental/bits/fs_path.h (path::is_absolute()): Move
+ definition out of class body.
+ (operator<<(basic_ostream, const path&)): Fix type of delimiter and
+ escape characters.
+ (operator>>(basic_istream, path&)): Likewise.
+ (path::is_absolute()): Define inline and fix for Windows.
+ * src/filesystem/dir-common.h (__gnu_posix): New namespace.
+ (__gnu_posix::char_type, __gnu_posix::DIR, __gnu_posix::dirent)
+ (__gnu_posix::opendir, __gnu_posix::readdir, __gnu_posix::closedir):
+ Define as adaptors for Windows functions/types or as
+ using-declarations for POSIX functions/types.
+ (_Dir_base, get_file_type): Qualify names to use declarations from
+ __gnu_posix namespace.
+ (_Dir_base::is_dor_or_dotdot): New helper functions.
+ * src/filesystem/dir.cc (_Dir, recursive_directory_iterator): Qualify
+ names to use declarations from __gnu_posix namespace.
+ * src/filesystem/ops-common.h (__gnu_posix): New nested namespace.
+ (__gnu_posix::open, __gnu_posix::close, __gnu_posix::stat_type)
+ (__gnu_posix::stat, __gnu_posix::lstat, __gnu_posix::mode_t)
+ (__gnu_posix::chmod, __gnu_posix::mkdir, __gnu_posix::getcwd)
+ (__gnu_posix::chdir, __gnu_posix::utimbuf, __gnu_posix::utime)
+ (__gnu_posix::rename, __gnu_posix::truncate, __gnu_posix::char_type):
+ Define as adaptors for Windows functions/types or as
+ using-declarations for POSIX functions/types.
+ (stat_type, do_copy_file): Qualify names to use declarations from
+ __gnu_posix namespace.
+ (do_space): Declare new function.
+ (make_file_type): Only use S_ISLNK if defined.
+ * src/filesystem/ops.cc (char_ptr, filesystem::canonical): Use
+ path::value_type not char.
+ (filesystem::copy, create_dir, filesystem::create_directory): Qualify
+ names to use declarations from __gnu_posix namespace.
+ (filesystem::create_hard_link): Check HAVE_LINK autoconf macro and
+ add implementation for Windows.
+ (filesystem::create_symlink): Check HAVE_SYMLINK autoconf macro.
+ (filesystem::current_path(error_code&)): Use __gnu_posix::getcwd.
+ [!_PC_PATH_MAX]: Don't use pathconf.
+ [PATH_MAX]: Use if defined.
+ (filesystem::current_path(const path&, error_code&))
+ (filesystem::equivalent, do_stat, filesystem::hard_link_count)
+ (filesystem::last_write_time, filesystem::permissions): Use names
+ from __gnu_posix.
+ (filesystem::read_symlink): Check HAVE_READLINK autoconf macro.
+ (filesystem::remove) [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Add
+ implementation for Windows.
+ (filesystem::rename, filesystem::resize_file): Use names from
+ __gnu_posix.
+ (filesystem::space): Use do_space.
+ [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Get absolute path to directory.
+ (filesystem::status, filesystem::symlink_status): Use names from
+ __gnu_posix.
+ (filesystem::temp_directory_path): Add implementation for Windows.
+ * src/filesystem/path.cc (dot): Define constant.
+ (path::replace_extension): Use dot.
+ (path::_M_find_extension): Likewise. Use path::string_type not
+ std::string.
+ (path::_M_split_cmpts): Use dot.
+ (filesystem_error::_M_get_what): Use u8string() not native().
+ * src/filesystem/std-dir.cc (_Dir, recursive_directory_iterator):
+ Qualify names to use declarations from __gnu_posix namespace.
+ * src/filesystem/std-ops.cc (filesystem::absolute(const path&)): Use
+ correct error_code.
+ (filesystem::absolute(const path&, error_code&)): Add implementation
+ for Windows.
+ (char_ptr, filesystem::canonical): Use path::value_type not char.
+ (do_copy_file): Use names from __gnu_posix.
+ [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Do not use fchmod, fchmodat or
+ sendfile.
+ (filesystem::copy, create_dir, filesystem::create_directory): Qualify
+ names to use declarations from __gnu_posix namespace.
+ (filesystem::create_hard_link): Check HAVE_LINK autoconf macro and
+ add implementation for Windows.
+ (filesystem::create_symlink): Check HAVE_SYMLINK autoconf macro.
+ (filesystem::current_path(error_code&)): Use __gnu_posix::getcwd.
+ [!_PC_PATH_MAX]: Don't use pathconf.
+ [PATH_MAX]: Use if defined.
+ (filesystem::current_path(const path&, error_code&))
+ (filesystem::equivalent, do_stat, filesystem::hard_link_count)
+ (filesystem::last_write_time, filesystem::permissions): Use names
+ from __gnu_posix.
+ (filesystem::read_symlink): Check HAVE_READLINK autoconf macro.
+ (filesystem::remove) [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Add
+ implementation for Windows.
+ (filesystem::rename, filesystem::resize_file): Use names from
+ __gnu_posix.
+ (do_space): Define.
+ (filesystem::space): Use do_space.
+ (filesystem::status, filesystem::symlink_status): Use names from
+ __gnu_posix.
+ (filesystem::temp_directory_path): Add implementation for Windows.
+ * src/filesystem/std-path.cc
+ [_GLIBCXX_FILESYSTEM_IS_WINDOWS] (path::operator/=(const path&)):
+ Define for Windows.
+ (dot): Define constant.
+ (path::replace_extension, is_dot): Use dot.
+ (path::lexically_normal): Check _M_type instead of calling
+ non-existent function.
+ (path::_M_find_extension): Use dot. Use path::string_type not
+ std::string.
+ (path::_M_split_cmpts): Use dot.
+ (filesystem_error::_M_get_what): Use u8string() not native().
+ * testsuite/27_io/filesystem/iterators/directory_iterator.cc: Do not
+ use symlinks.
+ * testsuite/27_io/filesystem/iterators/recursive_directory_iterator.cc:
+ Likewise.
+ * testsuite/27_io/filesystem/operations/absolute.cc: Use
+ __gnu_test::root_path() instead of "/" and add Windows-specific tests.
+ * testsuite/27_io/filesystem/operations/canonical.cc: Use
+ path::string() to get narrow string, not path::native().
+ * testsuite/27_io/filesystem/operations/copy.cc: Construct fstreams
+ with std::filesystem::path not std::basic_string.
+ * testsuite/27_io/filesystem/operations/copy_file.cc: Likewise.
+ * testsuite/27_io/filesystem/operations/exists.cc: Use
+ __gnu_test::root_path() instead of "/".
+ * testsuite/27_io/filesystem/operations/is_empty.cc: Construct
+ fstreams with std::filesystem::path not std::basic_string.
+ * testsuite/27_io/filesystem/operations/last_write_time.cc: Use
+ path::string() to get narrow string.
+ * testsuite/27_io/filesystem/operations/space.cc: Check results for
+ errors, expect sensible values otherwise.
+ * testsuite/27_io/filesystem/operations/temp_directory_path.cc: Add
+ helpers for adjusting the environment on Windows.
+ * testsuite/27_io/filesystem/path/append/path.cc: Test
+ Windows-specific behaviour.
+ * testsuite/27_io/filesystem/path/construct/format.cc: Fix creation
+ of path::string_type objects.
+ * testsuite/27_io/filesystem/path/construct/locale.cc: Compare native
+ string to wide string on Windows.
+ * testsuite/27_io/filesystem/path/decompose/root_directory.cc: Allow
+ for backslash as root-directory.
+ * testsuite/27_io/filesystem/path/decompose/stem.cc: Use
+ path::string() to get narrow string.
+ * testsuite/27_io/filesystem/path/itr/traversal.cc: Test Windows-style
+ paths.
+ * testsuite/27_io/filesystem/path/native/string.cc: Use string_type
+ not std::string.
+ * testsuite/27_io/filesystem/path/query/is_absolute.cc: Adjust for
+ different definintion of absolute paths on Windows.
+ * testsuite/experimental/filesystem/iterators/directory_iterator.cc:
+ Do not use symlinks.
+ * testsuite/experimental/filesystem/operations/absolute.cc: Test
+ Windows behaviour.
+ * testsuite/experimental/filesystem/operations/copy.cc: Construct
+ fstreams with NTCTS not std::basic_string.
+ * testsuite/experimental/filesystem/operations/copy_file.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/exists.cc: Use
+ __gnu_test::root_path() instead of "/".
+ * testsuite/experimental/filesystem/operations/is_empty.cc: Construct
+ fstreams with NTCTS not std::basic_string.
+ * testsuite/experimental/filesystem/operations/last_write_time.cc:
+ Use path::string() to get narrow string.
+ * testsuite/experimental/filesystem/operations/space.cc: Use
+ __gnu_test::root_path() instead of "/".
+ * testsuite/experimental/filesystem/operations/temp_directory_path.cc:
+ Add helpers for adjusting the environment on Windows.
+ * testsuite/experimental/filesystem/path/append/path.cc: Use
+ path::string() to get narrow strings for comparisons.
+ * testsuite/experimental/filesystem/path/concat/path.cc: Likewise.
+ * testsuite/experimental/filesystem/path/decompose/root_directory.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/stem.cc: Likewise.
+ * testsuite/experimental/filesystem/path/native/string.cc: Use
+ string_type not std::string.
+ * testsuite/experimental/filesystem/path/query/is_absolute.cc:
+ Adjust for different definintion of absolute paths on Windows.
+ * testsuite/util/testsuite_fs.h (__gnu_test::root_path()): New
+ function.
+ (__gnu_test::scoped_file): Construct fstreams with NTCTS not
+ std::basic_string.
+
+2018-05-31 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85951
+ * include/std/type_traits [_GLIBCXX_USE_C99_STDINT_TR1]: Do not define
+ uint_least16_t and uint_least32_t.
+ (__make_unsigned<wchar_t>): Define unconditionally.
+ (__make_unsigned_selector<_Tp, true, false>): Remove intermediate
+ typedefs.
+ (__make_unsigned_selector_base): New type to provide helper templates.
+ (__make_unsigned_selector<_Tp, false, true>): Reimplement using
+ __make_unsigned_selector_base helpers.
+ (__make_unsigned<char16_t>, __make_unsigned<char32_t>): Define.
+ (__make_signed_selector<_Tp, true, false>): Remove intermediate
+ typedefs.
+ (__make_signed<wchar_t>, __make_signed<char16_t>)
+ (__make_signed<char32_t>)): Define unconditionally.
+ * testsuite/20_util/make_signed/requirements/typedefs-3.cc: Check
+ wchar_t, char16_t and char32_t are transformed correctly.
+ * testsuite/20_util/make_signed/requirements/typedefs_neg.cc: Adjust
+ dg-error lineno.
+ * testsuite/20_util/make_unsigned/requirements/typedefs-3.cc: Check
+ wchar_t, char16_t and char32_t are transformed correctly.
+ * testsuite/20_util/make_unsigned/requirements/typedefs_neg.cc: Adjust
+ dg-error lineno.
+
+2018-05-29 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/variant (__erased_dtor): Qualify call to __get.
+
+2018-05-27 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_tree.h (_Rb_tree_impl(_Node_allocator&&)): New.
+ (_Rb_tree(const allocator_type&)): Use latter.
+ * include/bits/stl_map.h (map(const allocator_type&)): Likewise.
+ (map(initializer_list<value_type>, const allocator_type&)): Likewise.
+ (map(_InputIterator, _InputIterator, const allocator_type&)): Likewise.
+ * include/bits/stl_multimap.h
+ (multimap(const allocator_type&)): Likewise.
+ (multimap(initializer_list<value_type>, const allocator_type&)):
+ Likewise.
+ (multimap(_InputIterator, _InputIterator, const allocator_type&)):
+ Likewise.
+ * include/bits/stl_set.h (set(const allocator_type&)): Likewise.
+ (set(initializer_list<value_type>, const allocator_type&)): Likewise.
+ (set(_InputIterator, _InputIterator, const allocator_type&)): Likewise.
+ * include/bits/stl_multiset.h
+ (multiset(const allocator_type&)): Likewise.
+ (multiset(initializer_list<value_type>, const allocator_type&)):
+ Likewise.
+ (multiset(_InputIterator, _InputIterator, const allocator_type&)):
+ Likewise.
+
+2018-05-25 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/85768
+ * src/c++11/debug.cc: Remove backtrace usage.
+
+2018-05-24 Maya Rashish <coypu@sdf.org>
+
+ PR target/85904
+ * crossconfig.m4: Test for aligned_alloc on netbsd.
+ * configure: Regenerate.
+
+2018-05-24 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/69769
+ PR libstdc++/85886
+ * include/bits/atomic_base.h (__atomic_base::value_type)
+ (__atomic_base::difference_type): Add new typedefs.
+ * include/std/atomic (atomic<bool>::value_type, atomic<T>::value_type)
+ (atomic<T*>::value_type, atomic<T*>::difference_type): Likewise.
+ (atomic<T*>::operator++, atomic<T*>::operator--)
+ (atomic<T*>::operator+=, atomic<T*>::operator-=)
+ (atomic<T*>::fetch_add, atomic<T*>::fetch_sub): Add static assertion
+ to enforce C++17 requirement on pointer arithmetic.
+ (__atomic_val_t, __atomic_diff_t): New alias templates.
+ (atomic_init, atomic_store_explicit, atomic_exchange_explicit)
+ (atomic_compare_exchange_weak_explicit)
+ (atomic_compare_exchange_strong_explicit, atomic_store)
+ (atomic_exchange, atomic_compare_exchange_weak)
+ (atomic_compare_exchange_strong): Use __atomic_val_t to make
+ scalar parameters be non-deduced contexts.
+ (atomic_fetch_add_explicit, atomic_fetch_sub_explicit)
+ (atomic_fetch_add, atomic_fetch_sub): Change first parameter to be
+ atomic instead of __atomic_base, and use __atomic_diff_t for scalar
+ parameters.
+ (atomic_fetch_and_explicit, atomic_fetch_or_explicit)
+ (atomic_fetch_xor_explicit, atomic_fetch_and, atomic_fetch_or)
+ (atomic_fetch_xor): Use __atomic_val_t for scalar parameters.
+ (atomic_fetch_add_explicit, atomic_fetch_sub_explicit)
+ (atomic_fetch_add, atomic_fetch_sub): Remove overloads for atomic
+ address types.
+ * testsuite/29_atomics/atomic/60695.cc: Adjust dg-error lineno.
+ * testsuite/29_atomics/atomic/69769.cc: New test.
+ * testsuite/29_atomics/atomic/nonmembers.cc: New test.
+ * testsuite/29_atomics/atomic/operators/pointer_partial_void.cc:
+ Disable test for C++17 and later.
+ * testsuite/29_atomics/atomic/requirements/typedefs.cc: New test.
+ * testsuite/29_atomics/atomic_integral/nonmembers.cc: New test.
+ * testsuite/29_atomics/atomic_integral/requirements/typedefs.cc: New
+ test.
+
+2018-05-23 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/fs_path.h (path::__is_encoded_char): Change from class
+ template to alias template.
+ (path::__value_type_is_char): Use remove_const_t.
+ (path:_S_string_from_iter): New helper function.
+ (path::_S_convert(InputIter, __null_terminated))
+ (path::_S_convert_loc(InputIter, __null_terminated, const locale&)):
+ Use _S_string_from_iter.
+ (path::string<_CharT, _Allocator>(const _Allocator&)): Allow sharing
+ rep for COW strings.
+ * include/experimental/bits/fs_path.h (path::__is_encoded_char):
+ Change from class template to alias template.
+ (path::__value_type_is_char): Use remove_const.
+ (path:_S_string_from_iter): New helper function.
+ (path::_S_convert(InputIter, __null_terminated))
+ (path::_S_convert_loc(InputIter, __null_terminated, const locale&)):
+ Use _S_string_from_iter.
+ * testsuite/27_io/filesystem/path/append/source.cc: Test appending
+ wide strings.
+ * testsuite/27_io/filesystem/path/concat/strings.cc: Check for exact
+ string equality, not path equivalence.
+ * testsuite/27_io/filesystem/path/construct/format.cc: Check
+ construction from std::string and std::wstring and input iterators.
+ * testsuite/27_io/filesystem/path/construct/locale.cc: Check
+ construction from iterators.
+ * testsuite/experimental/filesystem/path/concat/strings.cc: Check for
+ exact string equality, not path equivalence.
+ * testsuite/experimental/filesystem/path/construct/locale.cc: Check
+ construction from iterators.
+
+ * include/bits/fs_path.h (path::_M_type): Change default member
+ initializer to _Filename.
+ (path::begin): Create past-the-end iterator for empty path.
+ * src/filesystem/std-path.cc (path::remove_filename()): Remove
+ debugging check.
+ (path::has_relative_path()): Return false for empty filenames.
+ (path::_M_split_cmpts): Set _M_type to _Filename for empty paths.
+ Fix offset of empty final component.
+ * testsuite/27_io/filesystem/path/itr/components.cc: New.
+ * testsuite/27_io/filesystem/path/itr/traversal.cc: Add new inputs.
+
+2018-05-21 Jonathan Wakely <jwakely@redhat.com>
+
+ Add support for opening file streams from wide character strings.
+ * config/io/basic_file_stdio.cc [_GLIBCXX_HAVE__WFOPEN]
+ (__basic_file<char>::open(const wchar_t*, ios_base::openmode)):
+ Define new overload.
+ * config/io/basic_file_stdio.h [_GLIBCXX_HAVE__WFOPEN]
+ (__basic_file<char>::open(const wchar_t*, ios_base::openmode)):
+ Declare new overload.
+ * configure.ac: Check for _wfopen.
+ * crossconfig.m4: Likewise.
+ * configure: Regenerate.
+ * config.h.in: Regenerate.
+ * include/bits/fstream.tcc [_GLIBCXX_HAVE__WFOPEN]
+ (basic_filebuf<C,T>::open(const wchar_t*, ios_base::openmode)):
+ Define new overload.
+ * include/std/fstream [_GLIBCXX_HAVE__WFOPEN]
+ (basic_filebuf<C,T>::open(const wchar_t*, ios_base::openmode)):
+ Declare new overload.
+ [_GLIBCXX_HAVE__WFOPEN]
+ (basic_ifstream<C,T>::basic_ifstream(const wchar_t*, openmode))
+ (basic_ifstream<C,T>::basic_open(const wchar_t*, openmode))
+ (basic_ofstream<C,T>::basic_ifstream(const wchar_t*, openmode))
+ (basic_ofstream<C,T>::basic_open(const wchar_t*, openmode))
+ (basic_fstream<C,T>::basic_ifstream(const wchar_t*, openmode))
+ (basic_fstream<C,T>::basic_open(const wchar_t*, openmode)): Define
+ new overloads.
+ * testsuite/27_io/basic_filebuf/open/wchar_t/1.cc: New.
+ * testsuite/27_io/basic_ifstream/cons/wchar_t/1.cc: New.
+ * testsuite/27_io/basic_ifstream/open/wchar_t/1.cc: New.
+ * testsuite/27_io/basic_ofstream/cons/wchar_t/1.cc: New.
+ * testsuite/27_io/basic_ofstream/open/wchar_t/1.cc: New.
+ * testsuite/27_io/basic_fstream/cons/wchar_t/1.cc: New.
+ * testsuite/27_io/basic_fstream/open/wchar_t/1.cc: New.
+
+2018-05-21 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/85845
+ * include/bits/stl_tree.h
+ (_Rb_tree_impl(_Rb_tree_impl&&, _Node_allocator&&)): Fix noexcept
+ qualification.
+
+2018-05-21 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/filesystem/std-ops.cc (absolute): Report an error for empty
+ paths.
+ (weakly_canonical(const path&)): Do not call canonical on empty path.
+ (weakly_canonical(const path&, error_code&)): Likewise.
+ * testsuite/27_io/filesystem/operations/absolute.cc: Check for errors.
+
+ PR libstdc++/85818
+ * testsuite/experimental/filesystem/path/preferred_separator.cc: Add
+ dg-require-filesystem-ts.
+
+ PR libstdc++/85843
+ * src/c++11/cow-stdexcept.cc (logic_error, runtime_error): Explicitly
+ initialize base class to avoid warnings.
+
+2018-05-19 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/c++11/codecvt.cc (__codecvt_utf8_base<wchar_t>::do_in)
+ [__SIZEOF_WCHAR_T__==2 && __BYTE_ORDER__!=__ORDER_BIG_ENDIAN__]: Set
+ little_endian element in bitmask.
+ * testsuite/22_locale/codecvt/codecvt_utf8/69703.cc: Run all tests.
+ * testsuite/22_locale/codecvt/codecvt_utf8/wchar_t/1.cc: New.
+
+2018-05-18 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/stl_tree.h
+ (_Rb_tree_impl(_Rb_tree_impl&&, _Node_allocator&&)): New.
+ (_Rb_tree(_Rb_tree&&, _Node_allocator&&, true_type)): New, use latter.
+ (_Rb_tree(_Rb_tree&&, _Node_allocator&&, false_type)): New.
+ (_Rb_tree(_Rb_tree&&, _Node_allocator&&)): Adapt, use latters.
+ * include/debug/map.h
+ (map(map&&, const_allocator_type&)): Add noexcept qualitication.
+ * include/debug/multimap.h
+ (multimap(multimap&&, const_allocator_type&)): Likewise.
+ * include/debug/set.h
+ (set(set&&, const_allocator_type&)): Likewise.
+ * include/debug/multiset.h
+ (multiset(multiset&&, const_allocator_type&)): Likewise.
+ * testsuite/23_containers/map/cons/noexcept_default_construct.cc:
+ Add checks.
+ * testsuite/23_containers/map/cons/noexcept_move_construct.cc:
+ Add checks.
+ * testsuite/23_containers/multimap/cons/noexcept_default_construct.cc:
+ Add checks.
+ * testsuite/23_containers/multimap/cons/noexcept_move_construct.cc:
+ Add checks.
+ * testsuite/23_containers/multiset/cons/noexcept_default_construct.cc:
+ Add checks.
+ * testsuite/23_containers/multiset/cons/noexcept_move_construct.cc:
+ Add checks.
+ * testsuite/23_containers/set/cons/noexcept_default_construct.cc:
+ Add checks.
+ * testsuite/23_containers/set/cons/noexcept_move_construct.cc:
+ Add checks.
+
+2018-05-18 Jason Merrill <jason@redhat.com>
+
+ * include/bits/stl_deque.h (_Deque_iterator): Constrain constructor
+ for conversion to const_iterator. Add defaulted copy ops.
+ * libsupc++/new (bad_alloc): Add defaulted copy ops.
+ * libsupc++/exception.h (exception): Add defaulted copy ops.
+ * include/std/system_error (system_error): Add defaulted copy ops.
+ * include/std/stdexcept (domain_error, invalid_argument)
+ (length_error, out_of_range, range_error, overflow_error)
+ (underflow_error): Add defaulted copy ops.
+ * include/bits/stl_iterator.h (reverse_iterator): Add defaulted
+ copy assignment.
+ * include/bits/allocator.h (allocator): Add defaulted copy assignment.
+ * include/ext/throw_allocator.h (condition_base): Add defaulted
+ default and copy ctor and copy assignment.
+
+2018-05-18 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85098
+ * include/bits/regex.h [__cplusplus < 201703L] (basic_regex::icase)
+ (basic_regex::nosubs, basic_regex::optimize, basic_regex::collate)
+ (basic_regex::ECMAScript, basic_regex::basic, basic_regex::extended)
+ (basic_regex::awk, basic_regex::grep, basic_regex::egrep): Add
+ definitions.
+ * include/bits/regex_automaton.h (_NFA::_M_insert_state): Adjust
+ whitespace.
+ * include/bits/regex_compiler.tcc (__INSERT_REGEX_MATCHER): Add
+ braces around body of do-while.
+ * testsuite/28_regex/basic_regex/85098.cc: New
+
+2018-05-17 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85818
+ * src/filesystem/path.cc (path::preferred_separator): Add used
+ attribute.
+ * testsuite/experimental/filesystem/path/preferred_separator.cc: New.
+
+ PR libstdc++/85812
+ * libsupc++/cxxabi_init_exception.h (__cxa_free_exception): Declare.
+ * libsupc++/exception_ptr.h (make_exception_ptr) [__cpp_exceptions]:
+ Refactor to separate non-throwing and throwing implementations.
+ [__cpp_rtti && !_GLIBCXX_HAVE_CDTOR_CALLABI]: Deallocate the memory
+ if constructing the object throws.
+
+2018-05-15 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85749
+ * include/bits/random.h (__detail::__is_seed_seq): New SFINAE helper.
+ (linear_congruential_engine, mersenne_twister_engine)
+ (subtract_with_carry_engine, discard_block_engine)
+ (independent_bits_engine, shuffle_order_engine): Use __is_seed_seq to
+ constrain function templates taking seed sequences.
+ * include/bits/random.tcc (linear_congruential_engine::seed(_Sseq&))
+ (mersenne_twister_engine::seed(_Sseq&))
+ (subtract_with_carry_engine::seed(_Sseq&)): Change return types to
+ match declarations.
+ * include/ext/random (simd_fast_mersenne_twister_engine): Use
+ __is_seed_seq to constrain function templates taking seed sequences.
+ * include/ext/random.tcc (simd_fast_mersenne_twister_engine::seed):
+ Change return type to match declaration.
+ * testsuite/26_numerics/random/discard_block_engine/cons/seed_seq2.cc:
+ New.
+ * testsuite/26_numerics/random/independent_bits_engine/cons/
+ seed_seq2.cc: New.
+ * testsuite/26_numerics/random/linear_congruential_engine/cons/
+ seed_seq2.cc: New.
+ * testsuite/26_numerics/random/mersenne_twister_engine/cons/
+ seed_seq2.cc: New.
+ * testsuite/26_numerics/random/pr60037-neg.cc: Adjust dg-error lineno.
+ * testsuite/26_numerics/random/shuffle_order_engine/cons/seed_seq2.cc:
+ New.
+ * testsuite/26_numerics/random/subtract_with_carry_engine/cons/
+ seed_seq2.cc: New.
+ * testsuite/ext/random/simd_fast_mersenne_twister_engine/cons/
+ seed_seq2.cc: New.
+
+ PR libstdc++/83891
+ * include/bits/fs_path.h (path::is_absolute()): Use same definition
+ for all operating systems.
+ * include/experimental/bits/fs_path.h (path::is_absolute()): Likewise.
+ * testsuite/27_io/filesystem/path/query/is_absolute.cc: New.
+ * testsuite/27_io/filesystem/path/query/is_relative.cc: Fix comment.
+ * testsuite/experimental/filesystem/path/query/is_absolute.cc: New.
+
+ * testsuite/27_io/filesystem/path/decompose/extension.cc: Remove
+ unused <vector> header.
+ * testsuite/27_io/filesystem/path/query/empty.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/has_extension.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/has_filename.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/has_parent_path.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/has_relative_path.cc:
+ Likewise.
+ * testsuite/27_io/filesystem/path/query/has_root_directory.cc:
+ Likewise.
+ * testsuite/27_io/filesystem/path/query/has_root_name.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/has_root_path.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/has_stem.cc: Likewise.
+ * testsuite/27_io/filesystem/path/query/is_relative.cc: Likewise.
+ * testsuite/experimental/filesystem/path/decompose/extension.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/empty.cc: Likewise.
+ * testsuite/experimental/filesystem/path/query/has_extension.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_filename.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_parent_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_relative_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_root_directory.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_root_name.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_root_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_stem.cc: Likewise.
+ * testsuite/experimental/filesystem/path/query/is_relative.cc:
+ Likewise.
+
+ PR libstdc++/84159
+ * include/bits/fs_path.h (path::operator/=, path::append): Construct
+ temporary path before calling _M_append.
+ (path::_M_append): Change parameter to path and implement C++17
+ semantics.
+ * testsuite/27_io/filesystem/path/append/path.cc: Add helper function
+ and more examples from the standard.
+ * testsuite/27_io/filesystem/path/append/source.cc: New.
+ * testsuite/27_io/filesystem/path/decompose/filename.cc: Add comment.
+ * testsuite/27_io/filesystem/path/nonmember/append.cc: New.
+
+ * include/std/variant (__gen_vtable_impl::__visit_invoke): Qualify
+ __invoke to prevent ADL.
+
+2018-05-14 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/81256
+ * include/bits/fstream.tcc (basic_filebuf::close): Do not swallow
+ exceptions from _M_terminate_output().
+ * include/std/fstream (basic_filebuf::~basic_filebuf): Swallow any
+ exceptions from close().
+ * testsuite/27_io/basic_filebuf/close/81256.cc: New.
+
+ * include/bits/valarray_array.h (__valarray_get_memory): Remove.
+ (__valarray_get_storage): Call operator new directly. Remove ignored
+ top-level restrict qualifier and add malloc attribute instead.
+ (_Array<_Tp>::_Array(size_t)): Remove unused constructor.
+
+ PR libstdc++/67554
+ * include/bits/valarray_array.h (_Array_copy_ctor<_Tp, true>)
+ (_Array_copier<_Tp, true>): Do not pass null pointers to memcpy.
+
+ PR libstdc++/82966
+ * include/bits/node_handle.h (_Node_handle_common::_M_swap): Use value
+ instead of type.
+ * testsuite/23_containers/set/modifiers/node_swap.cc: New.
+
+2018-05-13 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR libstdc++/80165
+ * testsuite/20_util/variant/80165.cc: New.
+
+2018-05-10 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/xml/faq.xml: Link to C++17 status. Add note to outdated answer.
+ * doc/xml/manual/debug_mode.xml: Add array and forward_list to list
+ of C++11 containers with Debug Mode support.
+ * doc/xml/manual/using.xml: Document Dual ABI for ios_base::failure.
+ * doc/html/*: Regenerate.
+
+2018-05-10 Jason Merrill <jason@redhat.com>
+
+ * include/bits/regex_compiler.h (_S_cache_size): Change from
+ function to variable.
+
+2018-05-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ PR libstdc++/83140 - assoc_legendre returns negated value when m is odd
+ * include/tr1/legendre_function.tcc (__assoc_legendre_p): Add __phase
+ argument defaulted to +1. Doxy comments on same.
+ * testsuite/special_functions/02_assoc_legendre/
+ check_value.cc: Regen.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 02_assoc_legendre/check_value.cc: Regen.
+
+2018-05-10 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85729
+ * include/bits/c++config.h (__replacement_assert): Add linkage
+ specification.
+ * include/bits/std_abs.h: Add comment to closing brace of block.
+ * include/c_global/cstddef: Add linkage specification.
+ * include/c_global/cstring: Likewise.
+ * include/c_global/cwchar: Likewise.
+
+2018-05-09 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/debug/safe_iterator.h (_Safe_iterator<>::_M_constant()):
+ Rename in...
+ (_Safe_iterator<>::_S_constant()): ...that.
+ * include/debug/safe_local_iterator.h
+ (_Safe_local_iterator<>::_M_constant()): Rename in...
+ (_Safe_local_iterator<>::_S_constant()): ...that.
+ * include/debug/formatter.h: Remove bits/cpp_type_traits.h include.
+ (_Iterator_state::__rbegin): New.
+ (_Iterator_state::__rmiddle): New.
+ (_Iterator_state::__rend): New.
+ (_Parameter::_Parameter(const _Safe_iterator<>&, const char*,
+ _Is_iterator)): Use _Safe_iterator<>::_S_constant. Grab normal underlying
+ iterator type.
+ (_Parameter::_Parameter(const _Safe_local_iterator<>&, const char*,
+ _Is_iterator)): Likewise.
+ (_Parameter::_S_reverse_state(_Iterator_state)): New.
+ (_Parameter(__gnu_cxx::__normal_iterator<> const&, const char*,
+ _Is_iterator)): New.
+ (_Parameter(std::reverse_iterator<> const&, const char*,
+ _Is_iterator)): New.
+ (_Parameter(std::reverse_iterator<_Safe_iterator<>> const&,
+ const char*, _Is_iterator)): New.
+ (_Parameter(std::move_iterator<> const&, const char*, _Is_iterator):
+ New.
+ (_Parameter(std::move_iterator<_Safe_iterator<>> const&, const char*,
+ _Is_iterator)): New.
+ * testsuite/24_iterators/move_iterator/debug_neg.cc: New.
+ * testsuite/24_iterators/normal_iterator/debug_neg.cc: New.
+ * testsuite/24_iterators/reverse_iterator/debug_neg.cc: New.
+
+2018-05-09 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/std_function.h (_Base_manager::_M_get_pointer):
+ Use constexpr if in C++17 mode.
+ (_Base_manager::_M_clone(_Any_data&, const _Any_data&, true_type)):
+ Copy from const object.
+ * testsuite/20_util/function/cons/non_copyconstructible.cc: New.
+
+2018-05-08 François Dumont <fdumont@gcc.gnu.org>
+
+ * src/c++11/debug.cc [_GLIBCXX_HAVE_EXECINFO_H]: Include execinfo.h.
+ [_GLIBCXX_HAVE_EXECINFO_H](_Error_formatter::_M_error): Render
+ backtrace.
+
+ * include/debug/macros.h (__glibcxx_check_valid_range_at): New.
+ * include/debug/functions.h (__check_valid_range): Use latter.
+ * include/debug/macros.h (__glibcxx_check_valid_constructor_range): New,
+ use latter.
+ * include/debug/deque
+ (deque::deque<_Iter>(_Iter, _Iter, const _Alloc&)): Use latter.
+ * include/debug/forward_list
+ (forward_list::forward_list<_Iter>(_Iter, _Iter, const _Alloc&)):
+ Likewise.
+ * include/debug/list
+ (list::list<_Iter>(_Iter, _Iter, const _Alloc&)): Likewise.
+ * include/debug/list
+ (list::list<_Iter>(_Iter, _Iter, const _Alloc&)): Likewise.
+ * include/debug/map.h
+ (map::map<_Iter>(_Iter, _Iter, const _Alloc&)): Likewise.
+ (map::map<_Iter>(_Iter, _Iter, const _Compare&, const _Alloc&)):
+ Likewise.
+ * include/debug/multimap.h
+ (multimap::multimap<_Iter>(_Iter, _Iter, const _Alloc&)): Likewise.
+ (multimap::multimap<_Iter>(_Iter, _Iter, const _Compare&,
+ const _Alloc&)): Likewise.
+ * include/debug/set.h
+ (set::set<_Iter>(_Iter, _Iter, const _Alloc&)): Likewise.
+ (set::set<_Iter>(_Iter, _Iter, const _Compare&, const _Alloc&)):
+ Likewise.
+ * include/debug/multiset.h
+ (multiset::multiset<_Iter>(_Iter, _Iter, const _Alloc&)): Likewise.
+ (multiset::multiset<_Iter>(_Iter, _Iter, const _Compare&,
+ const _Alloc&)): Likewise.
+ * include/debug/string
+ (basic_string::basic_string<_Iter>(_Iter, _Iter, const _Alloc&)):
+ Likewise.
+ * include/debug/unordered_map
+ (unordered_map::unordered_map<_Iter>(_Iter, _Iter, const _Alloc&)):
+ Likewise.
+ (unordered_multimap::unordered_multimap<_Iter>(_Iter, _Iter,
+ const _Alloc&)): Likewise.
+ * include/debug/unordered_set
+ (unordered_set::unordered_set<_Iter>(_Iter, _Iter, const _Alloc&)):
+ Likewise.
+ (unordered_multiset::unordered_multiset<_Iter>(_Iter, _Iter,
+ const _Alloc&)): Likewise.
+ * include/debug/vector
+ (vector::vector<_Iter>(_Iter, _Iter, const _Alloc&)): Use latter.
+
+ * include/debug/formatter.h (_Error_formatter::_M_function): New.
+ (_Error_formatter(const char*, unsigned int)): Adapt.
+ (_Error_formatter::_M_at): Rename in...
+ (_Error_formatter::_S_at): ...that and adapt.
+ * include/debug/macros.h (_GLIBCXX_DEBUG_VERIFY_AT_F): New.
+ (_GLIBCXX_DEBUG_VERIFY_AT, _GLIBCXX_DEBUG_VERIFY): Adapt.
+ * src/c++11/debug.cc (_Error_formatter::_M_error): Render _M_function
+ when available.
+
+2018-05-08 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/bits/regex_automaton.h (_NFA_base::_M_paren_stack, _NFA):
+ Use normal std::vector even in Debug Mode.
+
+ PR libstdc++/85672
+ * include/Makefile.am [!ENABLE_FLOAT128]: Change c++config.h entry
+ to #undef _GLIBCXX_USE_FLOAT128 instead of defining it to zero.
+ * include/Makefile.in: Regenerate.
+ * include/bits/c++config (_GLIBCXX_USE_FLOAT128): Move definition
+ within conditional block.
+
+2018-05-07 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/xml/manual/using.xml (table.cmd_options): Document that the
+ C++17 Filesystem implementation also needs -lstdc++fs.
+
+ PR libstdc++/85671
+ * include/bits/fs_path.h (operator/): Permit copy elision.
+ * include/experimental/bits/fs_path.h (operator/): Likewise.
+
+2018-05-07 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Moar PR libstdc++/80506
+ * include/bits/random.tcc (gamma_distribution::__generate_impl()):
+ Fix magic number used in loop condition.
+
+2018-05-04 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85642 fix is_nothrow_default_constructible<optional<T>>
+ * include/std/optional (_Optional_payload): Add noexcept to default
+ constructor. Re-indent.
+ (_Optional_payload<_Tp, true, true, true>): Likewise. Add noexcept to
+ constructor for copying disengaged payloads.
+ (_Optional_payload<_Tp, true, false, true>): Likewise.
+ (_Optional_payload<_Tp, true, true, false>): Likewise.
+ (_Optional_payload<_Tp, true, false, false>): Likewise.
+ * testsuite/20_util/optional/cons/85642.cc: New.
+ * testsuite/20_util/optional/cons/value_neg.cc: Adjust dg-error lines.
+
+2018-05-03 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/82644
+ * include/tr1/cmath [__STRICT_ANSI__] (hypergf, hypergl, hyperg): Use
+ inline definitions instead of using-declarations.
+ [__STRICT_ANSI__] (conf_hypergf, conf_hypergl, conf_hyperg): Likewise.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 07_conf_hyperg/compile_cxx17.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 17_hyperg/compile_cxx17.cc: New.
+
+ PR libstdc++/84769
+ * include/std/variant (visit): Qualify std::get call.
+
+ PR libstdc++/85632 use uintmax_t for arithmetic
+ * src/filesystem/ops.cc (experimental::filesystem::space): Perform
+ arithmetic in result type.
+ * src/filesystem/std-ops.cc (filesystem::space): Likewise.
+ * testsuite/27_io/filesystem/operations/space.cc: Check total capacity
+ is greater than free space.
+ * testsuite/experimental/filesystem/operations/space.cc: New.
+
+ * testsuite/20_util/remove_cvref/requirements/alias_decl.cc: New.
+ * testsuite/20_util/remove_cvref/requirements/explicit_instantiation.cc:
+ New.
+ * testsuite/20_util/remove_cvref/value.cc: New.
+ * testsuite/20_util/remove_cvref/value_ext.cc: New.
+
+ PR libstdc++/84087 LWG DR 2268 basic_string default arguments
+ * include/bits/basic_string.h [_GLIBCXX_USE_CXX11_ABI=1]
+ (append(const basic_string&, size_type, size_type)
+ (assign(const basic_string&, size_type, size_type)
+ (insert(size_type, const basic_string&, size_type, size_type)
+ (replace(size_type,size_type,const basic_string&,size_type,size_type)
+ (compare(size_type,size_type,constbasic_string&,size_type,size_type)):
+ Add default arguments (LWG 2268).
+ [_GLIBCXX_USE_CXX11_ABI=0]
+ (append(const basic_string&, size_type, size_type)
+ (assign(const basic_string&, size_type, size_type)
+ (insert(size_type, const basic_string&, size_type, size_type)
+ (replace(size_type,size_type,const basic_string&,size_type,size_type)
+ (compare(size_type,size_type,constbasic_string&,size_type,size_type)):
+ Likewise.
+ * testsuite/21_strings/basic_string/dr2268.cc: New test.
+
+ PR libstdc++/84535
+ * include/std/thread (thread::__not_same): New SFINAE helper.
+ (thread::thread(_Callable&&, _Args&&...)): Add SFINAE constraint that
+ first argument is not a std::thread. Add static assertion to check
+ INVOKE expression is valid.
+ (thread::thread(thread&), thread::thread(const thread&&)): Remove.
+ (thread::_Invoke::_M_invoke, thread::_Invoke::operator()): Use
+ __invoke_result for return types and remove exception specifications.
+ * testsuite/30_threads/thread/cons/84535.cc: New.
+
+ * include/std/future (__async_result_of): Use __invoke_result instead
+ of result_of.
+
+ * include/std/any (any_cast): Use __remove_cvref_t.
+ * include/std/tuple (__make_tuple): Likewise.
+ * include/std/type_traits (__remove_cvref_t): Define.
+ (__result_of_memobj, __result_of_memfun): Use __remove_cvref_t.
+ [__cplusplus > 201703L] (remove_cvref, remove_cvref_t): Define.
+ * include/std/variant (__erased_hash): Use __remove_cvref_t.
+
+2018-05-02 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/deque.tcc (deque<>::_M_assign_aux): Cast to void to
+ ensure overloaded comma not used.
+ * include/bits/list.tcc (list<>::_M_assign_dispatch): Likewise.
+ * include/bits/vector.tcc (vector<>::_M_assign_aux): Likewise.
+ * include/bits/stl_bvector.h (vector<bool>::_M_assign_aux): Likewise.
+ * testsuite/23_containers/deque/modifiers/assign/1.cc: New.
+ * testsuite/23_containers/list/modifiers/assign/1.cc: New.
+ * testsuite/23_containers/vector/bool/modifiers/assign/1.cc: New.
+ * testsuite/23_containers/vector/modifiers/assign/1.cc: New.
+
+2018-05-02 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/68197
+ * include/bits/ios_base.h (ios_base::iword, ios_base::pword): Cast
+ indices to unsigned.
+ * src/c++11/ios.cc (ios_base::_M_grow_words): Treat negative indices
+ as failure. Refactor error handling.
+ * testsuite/27_io/ios_base/storage/68197.cc: New.
+
+ PR libstdc++/57997
+ PR libstdc++/83860
+ * include/bits/gslice_array.h (gslice_array): Define default
+ constructor as deleted, as per C++11 standard.
+ * include/bits/mask_array.h (mask_array): Likewise.
+ * include/bits/slice_array.h (slice_array): Likewise.
+ * include/bits/valarray_after.h (_GBase, _GClos, _IBase, _IClos): Move
+ to namespace __detail.
+ (_GBase::_M_expr, _IBase::_M_expr): Use _ValArrayRef for type of data
+ members.
+ * include/bits/valarray_before.h (_ValArrayRef): New helper for type
+ of data members in closure objects.
+ (_FunBase, _ValFunClos, _RefFunClos, _UnBase, _UnClos, _BinBase)
+ (_BinBase2, _BinBase1, _BinClos, _SBase, _SClos): Move to namespace
+ __detail.
+ (_FunBase::_M_expr, _UnBase::_M_expr, _BinBase::_M_expr1)
+ (_BinBase::_M_expr2, _BinBase2::_M_expr1, _BinBase1::_M_expr2)
+ (_SBase::_M_expr): Use _ValArrayRef for type of data members.
+ * include/std/valarray (_UnClos, _BinClos, _SClos, _GClos, _IClos)
+ (_ValFunClos, _RefFunClos): Move to namespace __detail and add
+ using-declarations to namespace std.
+ * testsuite/26_numerics/valarray/83860.cc: New.
+
+ * testsuite/backward/strstream_move.cc: Remove duplicate function
+ call.
+
+ PR libstdc++/69608
+ * include/backward/strstream (strstreambuf): Define move constructor
+ and move assignment operator.
+ (istrstream, ostrstream, strstream): Likewise.
+ * testsuite/backward/strstream_move.cc: New.
+
+2018-05-01 Tulio Magno Quites Machado Filho <tuliom@linux.vnet.ibm.com>
+
+ PR libstdc++/84654
+ * acinclude.m4: Set ENABLE_FLOAT128 instead of _GLIBCXX_USE_FLOAT128.
+ * config.h.in: Remove references to _GLIBCXX_USE_FLOAT128.
+ * configure: Regenerate.
+ * include/Makefile.am: Replace the value of _GLIBCXX_USE_FLOAT128
+ based on ENABLE_FLOAT128.
+ * include/Makefile.in: Regenerate.
+ * include/bits/c++config: Define _GLIBCXX_USE_FLOAT128.
+ [!defined(__FLOAT128__) && !defined(__SIZEOF_FLOAT128__)]: Undefine
+ _GLIBCXX_USE_FLOAT128.
+
+2018-04-24 H.J. Lu <hongjiu.lu@intel.com>
+
+ * configure: Regenerated.
+
+2018-04-19 Jakub Jelinek <jakub@redhat.com>
+
+ * configure: Regenerated.
+
+2018-04-18 Jonathan Wakely <jwakely@redhat.com>
+ Jakub Jelinek <jakub@redhat.com>
+
+ PR libstdc++/85442
+ * src/c++11/Makefile.am: Don't generate debuginfo again for
+ cxx11-ios_failure-lt.s and cxx11-ios_failure.s files.
+ * src/c++11/Makefile.in: Regenerate.
+
+2018-04-18 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/84442
+ * testsuite/30_threads/thread/cons/terminate.cc
+ [!_GLIBCXX_USE_C99_STDLIB] : Use _exit or std::exit instead of _Exit.
+
+2018-04-18 David Malcolm <dmalcolm@redhat.com>
+
+ PR jit/85384
+ * configure: Regenerate.
+
+2018-04-16 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/experimental/filesystem/file_status/1.cc: Add
+ -DUSE_FILESYSTEM_TS to dg-options.
+ * testsuite/experimental/filesystem/iterators/directory_iterator.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/iterators/pop.cc: Likewise.
+ * testsuite/experimental/filesystem/iterators/
+ recursive_directory_iterator.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/absolute.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/canonical.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/copy.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/copy_file.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/create_directories.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/create_directory.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/create_symlink.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/current_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/equivalent.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/exists.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/file_size.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/is_empty.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/last_write_time.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/permissions.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/read_symlink.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/operations/remove.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/remove_all.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/status.cc: Likewise.
+ * testsuite/experimental/filesystem/operations/temp_directory_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/append/path.cc: Likewise.
+ * testsuite/experimental/filesystem/path/assign/assign.cc: Likewise.
+ * testsuite/experimental/filesystem/path/assign/copy.cc: Likewise.
+ * testsuite/experimental/filesystem/path/compare/compare.cc: Likewise.
+ * testsuite/experimental/filesystem/path/compare/path.cc: Likewise.
+ * testsuite/experimental/filesystem/path/compare/strings.cc: Likewise.
+ * testsuite/experimental/filesystem/path/concat/path.cc: Likewise.
+ * testsuite/experimental/filesystem/path/concat/strings.cc: Likewise.
+ * testsuite/experimental/filesystem/path/construct/copy.cc: Likewise.
+ * testsuite/experimental/filesystem/path/construct/default.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/construct/locale.cc: Likewise.
+ * testsuite/experimental/filesystem/path/construct/range.cc: Likewise.
+ * testsuite/experimental/filesystem/path/construct/string_view.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/extension.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/filename.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/parent_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/relative_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/root_directory.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/root_name.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/root_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/decompose/stem.cc: Likewise.
+ * testsuite/experimental/filesystem/path/generic/generic_string.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/itr/traversal.cc: Likewise.
+ * testsuite/experimental/filesystem/path/modifiers/clear.cc: Likewise.
+ * testsuite/experimental/filesystem/path/modifiers/make_preferred.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/modifiers/remove_filename.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/modifiers/replace_extension.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/modifiers/replace_filename.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/modifiers/swap.cc: Likewise.
+ * testsuite/experimental/filesystem/path/native/string.cc: Likewise.
+ * testsuite/experimental/filesystem/path/nonmember/hash_value.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/empty.cc: Likewise.
+ * testsuite/experimental/filesystem/path/query/has_extension.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_filename.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_parent_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_relative_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_root_directory.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_root_name.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_root_path.cc:
+ Likewise.
+ * testsuite/experimental/filesystem/path/query/has_stem.cc: Likewise.
+ * testsuite/experimental/filesystem/path/query/is_relative.cc:
+ Likewise.
+
+2018-04-13 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/c++11/Makefile.am: Fix sed command.
+ * src/c++11/Makefile.in: Regenerate.
+
+ * src/c++11/Makefile.am: Rewrite sed rule to be less fragile and to
+ handle mangled names starting with double underscores on darwin.
+ * src/c++11/Makefile.in: Regenerate.
+
+2018-04-12 Jonathan Wakely <jwakely@redhat.com>
+
+ * src/c++11/Makefile.am: Fix comment.
+ * src/c++11/Makefile.in: Regenerate.
+ * src/c++11/cxx11-ios_failure.cc: Fix comment.
+ * src/c++98/ios_failure.cc: Likewise.
+
+ * src/c++11/ios.cc: Remove redundant macro definition.
+
+2018-04-11 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/xml/manual/abi.xml: Document header locations in recent
+ releases.
+ * doc/xml/manual/evolution.xml: Add API changes since GCC 5.
+ * doc/xml/manual/spine.xml: Update copyright years.
+ * doc/xml/manual/strings.xml: Adjust tolower example to avoid
+ undefined behaviour.
+ * doc/xml/manual/test.xml: Update outdated notes on VERIFY in tests.
+ * doc/html/*: Regenerate.
+
+2018-04-10 Jonathan Wakely <jwakely@redhat.com>
+
+ * doc/xml/faq.xml: Update links to archived copy of SGI STL docs.
+ * doc/xml/manual/backwards_compatibility.xml: Likewise.
+ * doc/xml/manual/containers.xml: Likewise.
+ * doc/xml/manual/debug_mode.xml: Likewise.
+ * doc/xml/manual/extensions.xml: Likewise.
+ * doc/xml/manual/policy_data_structures_biblio.xml: Likewise.
+ * doc/xml/manual/using.xml: Likewise.
+ * doc/xml/manual/utilities.xml: Likewise.
+
+ PR libstdc++/85222
+ * src/c++11/Makefile.am [ENABLE_DUAL_ABI]: Add special rules for
+ cxx11-ios_failure.cc to rewrite type info for __ios_failure.
+ * src/c++11/Makefile.in: Regenerate.
+ * src/c++11/cxx11-ios_failure.cc (__ios_failure, __iosfail_type_info):
+ New types.
+ [_GLIBCXX_USE_DUAL_ABI] (__throw_ios_failure): Define here.
+ * src/c++11/ios.cc (__throw_ios_failure): Remove definition.
+ * src/c++98/ios_failure.cc (__construct_ios_failure)
+ (__destroy_ios_failure, is_ios_failure_handler): New functions.
+ [!_GLIBCXX_USE_DUAL_ABI] (__throw_ios_failure): Define here.
+ * testsuite/27_io/ios_base/failure/dual_abi.cc: New.
+ * testsuite/27_io/basic_ios/copyfmt/char/1.cc: Revert changes to
+ handler types, to always catch std::ios_base::failure.
+ * testsuite/27_io/basic_ios/exceptions/char/1.cc: Likewise.
+ * testsuite/27_io/basic_istream/extractors_arithmetic/char/
+ exceptions_failbit.cc: Likewise.
+ * testsuite/27_io/basic_istream/extractors_arithmetic/wchar_t/
+ exceptions_failbit.cc: Likewise.
+ * testsuite/27_io/basic_istream/extractors_other/char/
+ exceptions_null.cc: Likewise.
+ * testsuite/27_io/basic_istream/extractors_other/wchar_t/
+ exceptions_null.cc: Likewise.
+ * testsuite/27_io/basic_istream/sentry/char/12297.cc: Likewise.
+ * testsuite/27_io/basic_istream/sentry/wchar_t/12297.cc: Likewise.
+ * testsuite/27_io/basic_ostream/inserters_other/char/
+ exceptions_null.cc: Likewise.
+ * testsuite/27_io/basic_ostream/inserters_other/wchar_t/
+ exceptions_null.cc: Likewise.
+ * testsuite/27_io/ios_base/storage/2.cc: Likewise.
+
+2018-04-05 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/variant (_VARIANT_RELATION_FUNCTION_TEMPLATE): Qualify
+ __get calls to avoid ADL and avoid ambiguity due to Clang bug.
+
+2018-04-03 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85183
+ * include/std/variant (_Move_assign_base::operator=): Fix incorrect
+ value categories.
+ * testsuite/20_util/variant/85183.cc: New.
+
+2018-03-26 Jonathan Wakely <jwakely@redhat.com>
+
+ * include/std/variant (__get): Qualify calls to avoid ADL.
+ (__select_index): Adjust whitespace.
+ (variant): Add using-declaration to workaround Clang bug.
+
+2018-03-22 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/85040
+ * include/bits/stl_function.h (greater::__not_overloaded)
+ (less::__not_overloaded, greater_equal::__not_overloaded)
+ (less_equal::__not_overloaded): Fix ambiguous specializations.
+ * testsuite/20_util/function_objects/comparisons_pointer.cc: Add
+ tests for type with overloaded operators.
+
+2018-03-22 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ PR libstdc++/77691
+ * testsuite/experimental/memory_resource/resource_adaptor.cc:
+ xfail execution on 32-bit Solaris/x86.
+
+2018-03-21 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/20_util/function_objects/comparisons_pointer.cc: Use
+ VERIFY instead of assert.
+ * testsuite/20_util/hash/84998.cc: New test.
+ * testsuite/23_containers/vector/cons/destructible_debug_neg.cc: New
+ copy of test adjusted for Debug Mode.
+ * testsuite/23_containers/vector/cons/destructible_neg.cc: Do not run
+ test in Debug Mode.
+
+2018-03-20 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/84998
+ * include/bits/stl_bvector.h: Fix std::hash friend declaration.
+ * include/std/bitset: Likewise.
+ * include/bits/stl_map.h (std::map<>): Fix _Rb_tree_merge_helper friend
+ declaration.
+ * include/bits/stl_multimap.h (std::multimap<>): Likewise.
+ * include/bits/stl_multiset.h (std::multiset<>): Likewise.
+ * include/bits/stl_set.h (std::set<>): Likewise.
+ * include/bits/unordered_map.h (std::unordered_map<>): Fix
+ _Hash_merge_helper friend declaration.
+ (std::unordered_multimap<>): Likewise.
+ * include/bits/unordered_set.h (std::unordered_set<>): Likewise.
+ (std::unordered_multiset<>): Likewise.
+
+2018-03-19 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/api.xml: www.fsf.org has moved to https. Also omit
+ trailing slash for domain level link.
+ * doc/xml/faq.xml: Ditto.
+ * doc/xml/manual/appendix_free.xml (software): Ditto.
+ * doc/xml/manual/intro.xml: Ditto.
+ * doc/xml/manual/spine.xml: Ditto.
+ * doc/xml/spine.xml: Ditto.
+
+2018-03-19 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/xml/manual/documentation_hacking.xml: Adjust link to
+ docbook.org.
+
+2018-03-17 Jonathan Wakely <jwakely@redhat.com>
+
+ * testsuite/20_util/function_objects/comparisons_pointer.cc: Adjust
+ to compile as C++98.
+
+2018-03-14 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/78420
+ * include/bits/stl_function.h (greater<_Tp*>, less<_Tp*>)
+ (greater_equal<_Tp*>, less_equal<_Tp>*): Add partial specializations
+ to ensure total order for pointers.
+ (greater<void>, less<void>, greater_equal<void>, less_equal<void>):
+ Add operator() overloads for pointer arguments and make generic
+ overloads dispatch to new _S_cmp functions when comparisons would
+ use built-in operators for pointers.
+ * testsuite/20_util/function_objects/comparisons_pointer.cc: New.
+
+2018-03-12 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/84773
+ PR libstdc++/83662
+ * crossconfig.m4: Check for aligned_alloc etc. on freebsd and mingw32.
+ * configure: Regenerate.
+ * include/c_global/cstdlib [_GLIBCXX_HAVE_ALIGNED_ALLOC]
+ (aligned_alloc): Add using-declaration.
+ * testsuite/18_support/aligned_alloc/aligned_alloc.cc: New test.
+
+2018-03-09 François Dumont <fdumont@gcc.gnu.org>
+
+ * python/libstdcxx/v6/printers.py (build_libstdcxx_dictionary):
+ Fix std::_Fwd_list_iterator and std::_Fwd_list_const_iterator printers
+ registration.
+
+2018-03-09 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/84769
+ * include/std/variant (get<_Tp, _Types...>, get_if<_Tp, _Types...>):
+ Qualify calls to get<_Np, Types...> and get_if<_Np, _Types...>.
+
+ src/filesystem/ops.cc (create_dir): Pass error_code to is_directory.
+ src/filesystem/std-ops.cc (create_dir): Likewise.
+
+2018-03-08 François Dumont <fdumont@gcc.gnu.org>
+
+ * python/libstdcxx/v6/printers.py (NodeIteratorPrinter): New.
+ (StdListIteratorPrinter): Inherit from latter.
+ (StdFwdListIteratorPrinter): New, inherit from latter.
+ (StdDebugIteratorPrinter.to_string): Use non-debug iterator printer
+ when iterator has no associated container.
+ (build_libstdcxx_dictionary): Add __gnu_cxx::_Fwd_list_iterator and
+ __gnu_cxx::_Fwd_list_const_iterator printers. Remove __norm namespace
+ registrations.
+ * testsuite/libstdc++-prettyprinters/debug.cc: Adapt.
+ * testsuite/libstdc++-prettyprinters/debug_cxx11.cc: Adapt.
+
+2018-03-06 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR libstdc++/84601
+ * include/std/optional (_Optional_payload): Split into multiple
+ specializations that can handle different cases of trivial or
+ non-trivial assignment operators.
+ * testsuite/20_util/optional/84601.cc: New.
+ * testsuite/20_util/optional/cons/value_neg.cc: Adjust.
+
+2018-03-02 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/84671
+ * include/bits/parse_numbers.h (_Number_help): Add partial
+ specialization to handle digit separators. Adjust partial
+ specialization for recursion temrination to require _Pow == 1ULL.
+ * testsuite/20_util/duration/literals/84671.cc: New
+
+2018-02-27 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Implement the missing bits of LWG 2769
+ * include/std/any (any_cast(const any&)): Add static_assert.
+ (any_cast(any&)): Likewise.
+ (any_cast(any&&)): Likewise, and remove the handling
+ for copyable-but-not-movable type.
+ * testsuite/20_util/any/misc/any_cast.cc: Adjust.
+ * testsuite/20_util/any/misc/any_cast_neg.cc: Likewise, and
+ add new tests.
+
+2018-02-23 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/84532
+ * include/std/thread (thread::__make_invoker): Construct tuple
+ directly instead of using make_tuple.
+ * testsuite/30_threads/async/84532.cc: New.
+ * testsuite/30_threads/thread/84532.cc: New.
+
+2018-02-20 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/ext/aligned_buffer.h [_GLIBCXX_INLINE_VERSION]
+ (template<> __aligned_buffer): Define as __aligned_membuf alias.
+
+2018-02-19 Igor Tsimbalist <igor.v.tsimbalist@intel.com>
+
+ PR target/84148
+ * configure: Regenerate.
+
+2018-02-15 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/81797
+ * configure.ac (INCLUDE_DIR_NOTPARALLEL): Define.
+ * configure: Regenerate.
+ * include/Makefile.am (INCLUDE_DIR_NOTPARALLEL): Add .NOTPARALLEL when
+ defined.
+ * include/Makefile.in: Regenerate.
+
+2018-01-29 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83833
+ * testsuite/26_numerics/random/chi_squared_distribution/83833.cc:
+ Add -ffloat-store to options for m68k and ia32.
+
+ * doc/xml/faq.xml: Update copyright years.
+ * doc/html/*: Regenerate.
+
+ PR libstdc++/83658
+ * include/std/any (any::__do_emplace): Only set _M_manager after
+ constructing the contained object.
+ * testsuite/20_util/any/misc/any_cast_neg.cc: Adjust dg-error line.
+ * testsuite/20_util/any/modifiers/83658.cc: New test.
+
+2018-01-25 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/81076
+ * include/c_global/cstddef (__byte_operand): Define primary template.
+ * testsuite/18_support/byte/81076.cc: New test.
+
+2018-01-19 Christophe Lyon <christophe.lyon@linaro.org>
+
+ * testsuite/ext/special_functions/airy_ai/check_nan.cc: Fix
+ dg-options and dg-add-options order.
+ * testsuite/ext/special_functions/airy_bi/check_nan.cc: Likewise.
+ * testsuite/ext/special_functions/conf_hyperg/check_nan.cc:
+ Likewise.
+ * testsuite/ext/special_functions/hyperg/check_nan.cc: Likewise.
+ * testsuite/special_functions/01_assoc_laguerre/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/02_assoc_legendre/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/03_beta/check_nan.cc: Likewise.
+ * testsuite/special_functions/04_comp_ellint_1/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/05_comp_ellint_2/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/06_comp_ellint_3/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/06_comp_ellint_3/pr66689.cc:
+ Likewise.
+ * testsuite/special_functions/07_cyl_bessel_i/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/08_cyl_bessel_j/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/09_cyl_bessel_k/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/10_cyl_neumann/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/11_ellint_1/check_nan.cc: Likewise.
+ * testsuite/special_functions/12_ellint_2/check_nan.cc: Likewise.
+ * testsuite/special_functions/13_ellint_3/check_nan.cc: Likewise.
+ * testsuite/special_functions/13_ellint_3/pr66689.cc: Likewise.
+ * testsuite/special_functions/14_expint/check_nan.cc: Likewise.
+ * testsuite/special_functions/15_hermite/check_nan.cc: Likewise.
+ * testsuite/special_functions/16_laguerre/check_nan.cc: Likewise.
+ * testsuite/special_functions/17_legendre/check_nan.cc: Likewise.
+ * testsuite/special_functions/18_riemann_zeta/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/19_sph_bessel/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/20_sph_legendre/check_nan.cc:
+ Likewise.
+ * testsuite/special_functions/21_sph_neumann/check_nan.cc:
+ Likewise.
+
+2018-01-18 Uros Bizjak <ubizjak@gmail.com>
+
+ * configure.ac (AC_CHECK_HEADERS): Add linux/types.h. Conditionally
+ include linux/types.h when checking linux/random.h header.
+ * config.h.in: Regenerate.
+ * configure: Ditto.
+ * src/c++11/random.cc: Conditionally include linux/types.h.
+
+2018-01-16 Eric Botcazou <ebotcazou@adacore.com>
+
+ * testsuite/17_intro/names.cc: Undefine 'y' on SPARC/Linux.
+
+2018-01-16 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83834
+ * config/abi/pre/gnu.ver (GLIBCXX_3.4): Replace std::c[a-g]* wildcard
+ pattern with exact match for std::cerr.
+
+2018-01-15 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83833
+ * include/bits/random.h (chi_squared_distribution::param): Update
+ gamma distribution parameter.
+ * testsuite/26_numerics/random/chi_squared_distribution/83833.cc: New
+ test.
+
+ PR libstdc++/83830
+ * include/std/type_traits (has_unique_object_representations_v): Add
+ variable template.
+ * testsuite/20_util/has_unique_object_representations/value.cc: Check
+ variable template.
+
+2018-01-15 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Make optional conditionally
+ trivially_{copy,move}_{constructible,assignable}
+ * include/std/optional (_Optional_payload): Fix the comment in
+ the class head and turn into a primary and one specialization.
+ (_Optional_payload::_M_engaged): Strike the NSDMI.
+ (_Optional_payload<_Tp, false>::operator=(const _Optional_payload&)):
+ New.
+ (_Optional_payload<_Tp, false>::operator=(_Optional_payload&&)):
+ Likewise.
+ (_Optional_payload<_Tp, false>::_M_get): Likewise.
+ (_Optional_payload<_Tp, false>::_M_reset): Likewise.
+ (_Optional_base_impl): Likewise.
+ (_Optional_base): Turn into a primary and three specializations.
+ (optional(nullopt)): Change the base init.
+ * testsuite/20_util/optional/assignment/8.cc: New.
+ * testsuite/20_util/optional/cons/trivial.cc: Likewise.
+ * testsuite/20_util/optional/cons/value_neg.cc: Adjust.
+
+2018-01-15 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/80276
+ * python/libstdcxx/v6/printers.py (strip_inline_namespaces): New.
+ (get_template_arg_list): New.
+ (StdVariantPrinter._template_args): Remove, use get_template_arg_list
+ instead.
+ (TemplateTypePrinter): Rewrite to work with gdb.Type objects instead
+ of strings and regular expressions.
+ (add_one_template_type_printer): Adapt to new TemplateTypePrinter.
+ (FilteringTypePrinter): Add docstring. Match using startswith. Use
+ strip_inline_namespaces instead of strip_versioned_namespace.
+ (add_one_type_printer): Prepend namespace to match argument.
+ (register_type_printers): Add type printers for char16_t and char32_t
+ string types and for types using cxx11 ABI. Update calls to
+ add_one_template_type_printer to provide default argument dicts.
+ * testsuite/libstdc++-prettyprinters/80276.cc: New test.
+ * testsuite/libstdc++-prettyprinters/whatis.cc: Remove tests for
+ basic_string<unsigned char> and basic_string<signed char>.
+ * testsuite/libstdc++-prettyprinters/whatis2.cc: Duplicate whatis.cc
+ to test local variables, without overriding _GLIBCXX_USE_CXX11_ABI.
+
+2018-01-14 Andreas Schwab <schwab@linux-m68k.org>
+
+ PR libstdc++/81092
+ * config/abi/post/ia64-linux-gnu/baseline_symbols.txt: Update.
+
+2018-01-13 Tim Shen <timshen@google.com>
+
+ PR libstdc++/83601
+ * include/bits/regex.tcc (regex_replace): Fix escaping in sed.
+ * testsuite/28_regex/algorithms/regex_replace/char/pr83601.cc: Tests.
+ * testsuite/28_regex/algorithms/regex_replace/wchar_t/pr83601.cc: Tests.
+
+2018-01-12 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ PR libstdc++/64054
+ * testsuite/27_io/basic_ostream/inserters_arithmetic/char/hexfloat.cc:
+ Remove dg-xfail-run-if.
+
+2018-01-10 François Dumont <fdumont@gcc.gnu.org>
+
+ * include/bits/forward_list.h
+ (_Fwd_list_node_base(_Fwd_list_node_base&&)): New.
+ (_Fwd_list_node_base& operator=(_Fwd_list_node_base&&)): New.
+ (_Fwd_list_node_base(const _Fwd_list_node_base&)): Explicit delete.
+ (_Fwd_list_node_base& operator=(const _Fwd_list_node_base&)): Likewise.
+ (_Fwd_list_impl()): Add noexcept qualification.
+ (_Fwd_list_impl(const _Node_alloc_type&)): Delete.
+ (_Fwd_list_impl(_Fwd_list_impl&&)): New, default.
+ (_Fwd_list_impl(_Fwd_list_impl&&, _Node_alloc_type&&)): New.
+ (_Fwd_list_base()): Default.
+ (_Fwd_list_base(_Fwd_list_base&&, _Node_alloc_type&&, true_type)): New.
+ (_Fwd_list_base(_Fwd_list_base&&)): Default.
+ (forward_list<>()): Default.
+ (forward_list<>(forward_list&&)): Default.
+ (forward_list(forward_list&&, _Node_alloc_type&&, false_type)): New.
+ (forward_list(forward_list&&, _Node_alloc_type&&, true_type)): New.
+ (forward_list(forward_list&&, const _Alloc&)): Adapt to use latters.
+ * include/bits/forward_list.tcc
+ (_Fwd_list_base(_Fwd_list_base&&, _Node_alloc_type&&)): Adapt to use
+ _M_impl._M_head move assignment.
+ (forward_list<>::merge(forward_list<>&&, _Comp)): Likewise.
+ * testsuite/23_containers/forward_list/allocator/default_init.cc: New.
+
+2018-01-09 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/80276
+ * python/libstdcxx/v6/printers.py (SharedPointerPrinter)
+ (UniquePointerPrinter): Print correct template argument, not type of
+ the pointer.
+ (TemplateTypePrinter._recognizer.recognize): Handle failure to lookup
+ a type.
+ * testsuite/libstdc++-prettyprinters/cxx11.cc: Test unique_ptr of
+ array type.
+ * testsuite/libstdc++-prettyprinters/cxx17.cc: Test shared_ptr and
+ weak_ptr of array types.
+
+2018-01-09 François Dumont <fdumont@gcc.gnu.org>
+
+ PR libstdc++/83709
+ * include/bits/hashtable_policy.h
+ (__distance_fwd(_Iterator, _Iterator, input_iterator_tag)): Return 1 if
+ __first != __last.
+ (_Insert_base::_M_insert_range(_Ite, _Ite, _NodeGetter, true_type)): New.
+ (_Insert_base::_M_insert_range(_Ite, _Ite, _NodeGetter, false_type)):
+ Add false_type parameter.
+ (_Insert_base::insert): Adapt.
+ * include/bits/hashtable.h (_Hashtable::operator=(initializzr_list<>)):
+ Adapt.
+ (_Hashtable::_M_insert(_Arg&&, const _NodeGen&, true_type, size_t)):
+ Add __n_elt parameter, defaulted to 1.
+ (_Hashtable::_M_insert_unique_node): Likewise. Use it to call rehash
+ policy _M_need_rehash.
+ (_Hashtable::_M_merge_unique): Pass target number of elements to add to
+ produce only 1 rehash if necessary.
+ * testsuite/23_containers/unordered_map/insert/83709.cc: New.
+ * testsuite/23_containers/unordered_set/insert/83709.cc: New.
+
+2018-01-09 Juraj Oršulić <juraj.orsulic@fer.hr>
+ Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/59253 (partial)
+ * python/libstdcxx/v6/printers.py (SmartPtrIterator): Common iterator
+ type for pointer stored by shared_ptr, weak_ptr and unique_ptr.
+ (SharedPointerPrinter, UniquePointerPrinter): Treat stored values as
+ children.
+ * testsuite/libstdc++-prettyprinters/cxx11.cc: Update expected output
+ of unique_ptr printer.
+ * testsuite/libstdc++-prettyprinters/shared_ptr.cc: Update expected
+ output of shared_ptr printer.
+
+2018-01-05 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83626
+ * src/filesystem/ops.cc (remove(const path&, error_code&)): Remove
+ unnecessary symlink_status call.
+ (remove_all(const path&, error_code&)): Use filesystem::remove.
+ * src/filesystem/std-ops.cc: Likewise.
+
+ PR libstdc++/83279
+ * src/filesystem/std-ops.cc (do_copy_file): Use non-null offset with
+ sendfile.
+
+ PR libstdc++/83626
+ * src/filesystem/ops.cc (remove(const path&, error_code&)): Do not
+ report an error for ENOENT.
+ (remove_all(const path&)): Fix type of result variable.
+ (remove_all(const path&, error_code&)): Use non-throwing increment
+ for directory iterator. Call POSIX remove directly to avoid redundant
+ calls to symlink_status. Do not report errors for ENOENT.
+ * src/filesystem/std-ops.cc: Likewise.
+ * testsuite/27_io/filesystem/operations/remove_all.cc: Test throwing
+ overload.
+ * testsuite/experimental/filesystem/operations/remove_all.cc:
+ Likewise.
+
+2018-01-04 Jonathan Wakely <jwakely@redhat.com>
+
+ PR libstdc++/83626
+ * src/filesystem/ops.cc (remove(const path&, error_code&))): Remove
+ redundant call to ec.clear().
+ (remove_all(const path&, error_code&))): Do not return an error for
+ non-existent paths.
+ * src/filesystem/std-ops.cc: Likewise.
+ * testsuite/27_io/filesystem/operations/remove.cc: New test.
+ * testsuite/27_io/filesystem/operations/remove_all.cc: Fix expected
+ results for non-existent paths.
+ * testsuite/experimental/filesystem/operations/remove.cc: New test.
+ * testsuite/experimental/filesystem/operations/remove_all.cc: Fix
+ expected results for non-existent paths.
+
+ * include/bits/fs_ops.h (exists(const path&, error_code&))): Only
+ check status_known once.
+ * include/experimental/bits/fs_ops.h: Likewise.
+
+ PR libstdc++/83607
+ * include/std/functional (__is_byte_like): New trait.
+ (__is_std_equal_to): Remove.
+ (__boyer_moore_base_t): Use __is_byte_like instead of
+ __is_std_equal_to.
+ * include/experimental/functional (__is_std_equal_to): Remove.
+ (__boyer_moore_base_t): Use __is_byte_like instead of
+ __is_std_equal_to.
+ * testsuite/20_util/function_objects/83607.cc: New test.
+
+2018-01-03 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Protect optional's deduction guide with the feature macro
+ * include/std/optional: Use the feature macro.
+
+2018-01-03 Jakub Jelinek <jakub@redhat.com>
+
+ Update copyright years.
+
+Copyright (C) 2018 Free Software Foundation, Inc.
+
+Copying and distribution of this file, with or without modification,
+are permitted in any medium without royalty provided the copyright
+notice and this notice are preserved.