diff options
author | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-11-22 02:27:53 +0000 |
---|---|---|
committer | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-11-22 02:27:53 +0000 |
commit | 30d762795cf3078764102d9921f875116d5d77a9 (patch) | |
tree | b8b3e02e1c11f543c618b41ccc4292b814b95ced | |
parent | 033244c1b2b23c3f70a2a7c5cbdef570fdb9220e (diff) |
* bignum.c (): refix of r33536. Don't change behavior of Bignum#/.
[ruby-core:40429] [Bug #5490]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@33812 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | bignum.c | 9 | ||||
-rw-r--r-- | test/ruby/test_bignum.rb | 6 |
3 files changed, 15 insertions, 5 deletions
@@ -1,3 +1,8 @@ +Tue Nov 22 11:26:08 2011 NARUSE, Yui <[email protected]> + + * bignum.c (): refix of r33536. Don't change behavior of Bignum#/. + [ruby-core:40429] [Bug #5490] + Tue Nov 22 10:46:57 2011 NARUSE, Yui <[email protected]> * numeric.c (ruby_float_step): improve floating point calculations. @@ -2781,14 +2781,13 @@ rb_big_divide(VALUE x, VALUE y, ID op) case T_FLOAT: { - double div, dy = RFLOAT_VALUE(y); - if (dy == 0.0) rb_num_zerodiv(); - div = rb_big2dbl(x) / dy; if (op == '/') { - return DBL2NUM(div); + return DBL2NUM(rb_big2dbl(x) / RFLOAT_VALUE(y)); } else { - return rb_dbl2big(div); + double dy = RFLOAT_VALUE(y); + if (dy == 0.0) rb_num_zerodiv(); + return rb_dbl2big(rb_big2dbl(x) / dy); } } diff --git a/test/ruby/test_bignum.rb b/test/ruby/test_bignum.rb index 9256c7f3f4..8281aed7b2 100644 --- a/test/ruby/test_bignum.rb +++ b/test/ruby/test_bignum.rb @@ -268,6 +268,12 @@ class TestBignum < Test::Unit::TestCase assert_equal(0, T32 / T64) end + def test_divide + bug5490 = '[ruby-core:40429]' + assert_raise(ZeroDivisionError, bug5490) {T1024./(0)} + assert_equal(Float::INFINITY, T1024./(0.0), bug5490) + end + def test_div assert_equal(T32.to_f, T32 / 1.0) assert_raise(TypeError) { T32 / "foo" } |