diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2016-10-27 00:42:11 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2016-10-27 00:42:11 +0000 |
commit | c94855855ed2abbfc9abd3d74ad2984d1b8ff14e (patch) | |
tree | 111fd30fd67a4d049baba70a3a36b470a7de8366 | |
parent | cc08515cf8ed0cdb5c38bbb4ef84a110e8868cd6 (diff) |
object.c: fixable float to fixnum
* object.c (rb_convert_to_integer): convert a fixable float to a
fixnum directly without the convesion method, as well as bignum
case.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56497 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | object.c | 29 | ||||
-rw-r--r-- | test/ruby/test_integer.rb | 10 |
3 files changed, 26 insertions, 19 deletions
@@ -1,4 +1,8 @@ -Thu Oct 27 09:12:32 2016 Nobuyoshi Nakada <[email protected]> +Thu Oct 27 09:42:09 2016 Nobuyoshi Nakada <[email protected]> + + * object.c (rb_convert_to_integer): convert a fixable float to a + fixnum directly without the convesion method, as well as bignum + case. * object.c (rb_convert_to_integer): should not drop the converted string. @@ -2684,30 +2684,23 @@ rb_convert_to_integer(VALUE val, int base) { VALUE tmp; - switch (TYPE(val)) { - case T_FLOAT: + if (RB_FLOAT_TYPE_P(val)) { + double f; if (base != 0) goto arg_error; - if (RFLOAT_VALUE(val) <= (double)FIXNUM_MAX - && RFLOAT_VALUE(val) >= (double)FIXNUM_MIN) { - break; - } - return rb_dbl2big(RFLOAT_VALUE(val)); - - case T_FIXNUM: - case T_BIGNUM: + f = RFLOAT_VALUE(val); + if (FIXABLE(f)) return LONG2FIX((long)f); + return rb_dbl2big(f); + } + else if (RB_INTEGER_TYPE_P(val)) { if (base != 0) goto arg_error; return val; - - case T_STRING: + } + else if (RB_TYPE_P(val, T_STRING)) { return rb_str_to_inum(val, base, TRUE); - - case T_NIL: + } + else if (NIL_P(val)) { if (base != 0) goto arg_error; rb_raise(rb_eTypeError, "can't convert nil into Integer"); - break; - - default: - break; } if (base != 0) { tmp = rb_check_string_type(val); diff --git a/test/ruby/test_integer.rb b/test/ruby/test_integer.rb index 32c3511576..00c3c12577 100644 --- a/test/ruby/test_integer.rb +++ b/test/ruby/test_integer.rb @@ -104,6 +104,16 @@ class TestInteger < Test::Unit::TestCase obj = Struct.new(:s).new(%w[42 not-an-integer]) def obj.to_str; s.shift; end assert_equal(42, Integer(obj, 10)) + + assert_separately([], "#{<<-"begin;"}\n#{<<-"end;"}") + begin; + class Float + undef to_int + def to_int; raise "conversion failed"; end + end + assert_equal (1 << 100), Integer((1 << 100).to_f) + assert_equal 1, Integer(1.0) + end; end def test_int_p |