aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-loop-distribution.c
diff options
context:
space:
mode:
authorJonathan Wakely <jwakely@redhat.com>2020-06-04 13:52:21 +0100
committerJonathan Wakely <jwakely@redhat.com>2020-06-04 14:21:34 +0100
commite1008cd1d8504775e6a5e39325e396e61b39b84c (patch)
tree3df865cdfe150813345a81e41e68517808edce10 /gcc/tree-loop-distribution.c
parenta3a70bf6690e310fb1d4afa4b3dd1b19ddd0e2f4 (diff)
downloadgcc-e1008cd1d8504775e6a5e39325e396e61b39b84c.zip
gcc-e1008cd1d8504775e6a5e39325e396e61b39b84c.tar.gz
gcc-e1008cd1d8504775e6a5e39325e396e61b39b84c.tar.bz2
libstdc++: Make std::copy_n work with negative and non-integral sizes
Since it was added in C++11, std::copy_n and std::ranges::copy_n should do nothing given a negative size, but for random access iterators we add the size to the iterator, possibly resulting in undefined behaviour. Also, C++20 clarified that std::copy_n requires the Size type to be convertible to an integral type. We previously assumed that it could be directly used in arithmetic expressions, without conversion to an integral type. This also fixes a bug in the random_access_iterator_wrapper helper adds some convenience aliases for using the iterator wrappers. libstdc++-v3/ChangeLog: * include/bits/ranges_algobase.h (__copy_n_fn): Only call ranges::copy for positive values. * include/bits/stl_algo.h (copy_n): Convert Size argument to an integral type and only call __copy_n for positive values. * testsuite/util/testsuite_iterators.h (random_access_iterator_wrapper::operator+=): Fix range check for negative values. (output_container, input_container, forward_container) (bidirectional_container, random_access_container): New alias templates. * testsuite/25_algorithms/copy_n/5.cc: New test.
Diffstat (limited to 'gcc/tree-loop-distribution.c')
0 files changed, 0 insertions, 0 deletions