]> git.ipfire.org Git - thirdparty/gcc.git/commit
libstdc++: Avoid reusing moved-from iterators in PSTL tests [PR90276]
authorJonathan Wakely <jwakely@redhat.com>
Wed, 31 Jan 2024 10:41:49 +0000 (10:41 +0000)
committerJonathan Wakely <jwakely@redhat.com>
Thu, 8 Feb 2024 12:17:43 +0000 (12:17 +0000)
commit3c04a1533b32362c7c28fc32b05623dda45a1b44
treece45728f99281b2abe1580ee2120733abfc59618
parent2dcf47ce0204a08b724cd5b637e9e8d281e3abbb
libstdc++: Avoid reusing moved-from iterators in PSTL tests [PR90276]

The reverse_invoker utility for PSTL tests uses forwarding references for
all parameters, but some of those parameters get forwarded to move
constructors which then leave the objects in a moved-from state. When
the parameters are forwarded a second time that results in making new
copies of moved-from iterators.  For libstdc++ debug mode iterators, the
moved-from state is singular, which means copying them will abort at
runtime.

The fix is to make copies of iterator arguments instead of forwarding
them.

The callers of reverse_invoker::operator() also forward the iterators
multiple times, but that's OK because reverse_invoker accepts them by
forwarding reference but then breaks the chain of forwarding and copies
them as lvalues.

libstdc++-v3/ChangeLog:

PR libstdc++/90276
* testsuite/util/pstl/test_utils.h (reverse_invoker): Do not use
perfect forwarding for iterator arguments.

(cherry picked from commit 723a7c1ad29523b9ddff53c7b147bffea56fbb63)
libstdc++-v3/testsuite/util/pstl/test_utils.h