diff options
author | Jonathan Wakely <jwakely@redhat.com> | 2020-04-28 23:26:21 +0100 |
---|---|---|
committer | Jonathan Wakely <jwakely@redhat.com> | 2020-04-28 23:39:38 +0100 |
commit | 162c40a4c127cc55d701bb8760e17708d0ca2fe0 (patch) | |
tree | 79244a5440aa1ad1b33afbf2433de764ed0fb673 /gcc/tree-ssa-loop-im.c | |
parent | 50714f45eeaf315a0b55d3db3de3bf8df8e94b04 (diff) | |
download | gcc-162c40a4c127cc55d701bb8760e17708d0ca2fe0.zip gcc-162c40a4c127cc55d701bb8760e17708d0ca2fe0.tar.gz gcc-162c40a4c127cc55d701bb8760e17708d0ca2fe0.tar.bz2 |
libstdc++: Fix regression in std::_Construct (PR 94831)
By trying to reuse the existing std::_Construct function as a wrapper
for std::construct_at I introduced regressions, because changing
std::_Construct to return non-void made it ill-formed for array types.
The solution is to revert _Construct to its former state, and change
allocator_traits::construct to explicitly call construct_at instead.
This decouples all the existing callers of _Construct from the new
construct_at requirements.
PR libstdc++/94831
* include/bits/alloc_traits.h (_S_construct): Restore placement
new-expression for C++11/14/17 and call std::construct_at directly
for C++20.
* include/bits/stl_construct.h (_Construct): Revert to non-constexpr
function returning void.
* testsuite/20_util/specialized_algorithms/
uninitialized_value_construct/94831.cc: New test.
* testsuite/23_containers/vector/cons/94831.cc: New test.
Diffstat (limited to 'gcc/tree-ssa-loop-im.c')
0 files changed, 0 insertions, 0 deletions