From: Jonathan Wakely Date: Tue, 14 Aug 2018 20:19:20 +0000 (+0100) Subject: PR libstdc++/86954 use non-placement operator delete X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=aa7df52e4f86b6a92ab236895a85ce2cb7b1a98b;p=gcc.git PR libstdc++/86954 use non-placement operator delete As explained in the PR, there's no reason to call the nothrow delete, we can just use the normal one. PR libstdc++/86954 * include/bits/stl_tempbuf.h (return_temporary_buffer): Use non-placement delete. From-SVN: r263542 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index cf69f216072..182c0ed2ff3 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,5 +1,9 @@ 2018-08-14 Jonathan Wakely + 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. diff --git a/libstdc++-v3/include/bits/stl_tempbuf.h b/libstdc++-v3/include/bits/stl_tempbuf.h index 159ee27a5d3..0abd3c12de7 100644 --- a/libstdc++-v3/include/bits/stl_tempbuf.h +++ b/libstdc++-v3/include/bits/stl_tempbuf.h @@ -88,10 +88,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION __gnu_cxx::__numeric_traits::__max / sizeof(_Tp); if (__len > __max) __len = __max; - - while (__len > 0) + + while (__len > 0) { - _Tp* __tmp = static_cast<_Tp*>(::operator new(__len * sizeof(_Tp), + _Tp* __tmp = static_cast<_Tp*>(::operator new(__len * sizeof(_Tp), std::nothrow)); if (__tmp != 0) return std::pair<_Tp*, ptrdiff_t>(__tmp, __len); @@ -110,7 +110,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION template inline void return_temporary_buffer(_Tp* __p) - { ::operator delete(__p, std::nothrow); } + { ::operator delete(__p); } /**