mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Fix Enumerable#inject with high negative fixnums [Bug #17731]
This commit is contained in:
parent
c576e63ee7
commit
a85ed626f1
Notes:
git
2021-03-19 13:22:07 +09:00
2 changed files with 3 additions and 1 deletions
2
enum.c
2
enum.c
|
@ -805,7 +805,7 @@ ary_inject_op(VALUE ary, VALUE init, VALUE op)
|
||||||
if (FIXNUM_P(e)) {
|
if (FIXNUM_P(e)) {
|
||||||
n += FIX2LONG(e); /* should not overflow long type */
|
n += FIX2LONG(e); /* should not overflow long type */
|
||||||
if (!FIXABLE(n)) {
|
if (!FIXABLE(n)) {
|
||||||
v = rb_big_plus(ULONG2NUM(n), v);
|
v = rb_big_plus(LONG2NUM(n), v);
|
||||||
n = 0;
|
n = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -248,11 +248,13 @@ class TestEnumerable < Test::Unit::TestCase
|
||||||
assert_equal(15, [3, 5, 7].inject(:+))
|
assert_equal(15, [3, 5, 7].inject(:+))
|
||||||
assert_float_equal(15.0, [3, 5, 7.0].inject(:+))
|
assert_float_equal(15.0, [3, 5, 7.0].inject(:+))
|
||||||
assert_equal(2*FIXNUM_MAX, Array.new(2, FIXNUM_MAX).inject(:+))
|
assert_equal(2*FIXNUM_MAX, Array.new(2, FIXNUM_MAX).inject(:+))
|
||||||
|
assert_equal(3*FIXNUM_MAX, Array.new(3, FIXNUM_MAX).inject(:+))
|
||||||
assert_equal(2*(FIXNUM_MAX+1), Array.new(2, FIXNUM_MAX+1).inject(:+))
|
assert_equal(2*(FIXNUM_MAX+1), Array.new(2, FIXNUM_MAX+1).inject(:+))
|
||||||
assert_equal(10*FIXNUM_MAX, Array.new(10, FIXNUM_MAX).inject(:+))
|
assert_equal(10*FIXNUM_MAX, Array.new(10, FIXNUM_MAX).inject(:+))
|
||||||
assert_equal(0, ([FIXNUM_MAX, 1, -FIXNUM_MAX, -1]*10).inject(:+))
|
assert_equal(0, ([FIXNUM_MAX, 1, -FIXNUM_MAX, -1]*10).inject(:+))
|
||||||
assert_equal(FIXNUM_MAX*10, ([FIXNUM_MAX+1, -1]*10).inject(:+))
|
assert_equal(FIXNUM_MAX*10, ([FIXNUM_MAX+1, -1]*10).inject(:+))
|
||||||
assert_equal(2*FIXNUM_MIN, Array.new(2, FIXNUM_MIN).inject(:+))
|
assert_equal(2*FIXNUM_MIN, Array.new(2, FIXNUM_MIN).inject(:+))
|
||||||
|
assert_equal(3*FIXNUM_MIN, Array.new(3, FIXNUM_MIN).inject(:+))
|
||||||
assert_equal((FIXNUM_MAX+1).to_f, [FIXNUM_MAX, 1, 0.0].inject(:+))
|
assert_equal((FIXNUM_MAX+1).to_f, [FIXNUM_MAX, 1, 0.0].inject(:+))
|
||||||
assert_float_equal(10.0, [3.0, 5].inject(2.0, :+))
|
assert_float_equal(10.0, [3.0, 5].inject(2.0, :+))
|
||||||
assert_float_equal((FIXNUM_MAX+1).to_f, [0.0, FIXNUM_MAX+1].inject(:+))
|
assert_float_equal((FIXNUM_MAX+1).to_f, [0.0, FIXNUM_MAX+1].inject(:+))
|
||||||
|
|
Loading…
Reference in a new issue