Use the value of the first element as the initial value of the __valarray_sum accumulator. Value-initialization might not create the additive identity for the value type. Make a similar change to __valarray_product even though it's only ever used internally with a value_type of size_t. 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. From-SVN: r265270
Name |
Last commit
|
Last update |
---|---|---|
.. | ||
requirements | Loading commit data... | |
27867.cc | Loading commit data... | |
28277.cc | Loading commit data... | |
30416.cc | Loading commit data... | |
33084.cc | Loading commit data... | |
40691.cc | Loading commit data... | |
69116.cc | Loading commit data... | |
83860.cc | Loading commit data... | |
87641.cc | Loading commit data... | |
algo.cc | Loading commit data... | |
binary_closure.cc | Loading commit data... | |
const_bracket.cc | Loading commit data... | |
deduction.cc | Loading commit data... | |
dr543.cc | Loading commit data... | |
dr630-1.cc | Loading commit data... | |
dr630-2.cc | Loading commit data... | |
dr630-3.C | Loading commit data... | |
init-list.cc | Loading commit data... | |
moveable.cc | Loading commit data... | |
name_lookup.cc | Loading commit data... | |
noexcept_move_construct.cc | Loading commit data... | |
operators.cc | Loading commit data... | |
range_access.cc | Loading commit data... | |
range_access2.cc | Loading commit data... | |
subset_assignment.cc | Loading commit data... | |
swap.cc | Loading commit data... | |
transcend.cc | Loading commit data... |