ruby-changes:5700
From: shyouhei <ko1@a...>
Date: Sun, 15 Jun 2008 20:21:51 +0900 (JST)
Subject: [ruby-changes:5700] Ruby:r17206 (ruby_1_8_6): merge revision(s) 15749:
shyouhei 2008-06-15 20:21:40 +0900 (Sun, 15 Jun 2008)
New Revision: 17206
Modified files:
branches/ruby_1_8_6/ChangeLog
branches/ruby_1_8_6/numeric.c
branches/ruby_1_8_6/version.h
Log:
merge revision(s) 15749:
* numeric.c (fix_coerce): try conversion before type check.
[ruby-core:15838]
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8_6/ChangeLog?r1=17206&r2=17205&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8_6/version.h?r1=17206&r2=17205&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8_6/numeric.c?r1=17206&r2=17205&diff_format=u
Index: ruby_1_8_6/numeric.c
===================================================================
--- ruby_1_8_6/numeric.c (revision 17205)
+++ ruby_1_8_6/numeric.c (revision 17206)
@@ -1537,6 +1537,7 @@
rb_num2long(val)
VALUE val;
{
+ again:
if (NIL_P(val)) {
rb_raise(rb_eTypeError, "no implicit conversion from nil to integer");
}
@@ -1563,7 +1564,7 @@
default:
val = rb_to_int(val);
- return NUM2LONG(val);
+ goto again;
}
}
@@ -2427,6 +2428,16 @@
return LONG2NUM(val);
}
+static VALUE
+fix_coerce(x)
+ VALUE x;
+{
+ while (!FIXNUM_P(x) && TYPE(x) != T_BIGNUM) {
+ x = rb_to_int(x);
+ }
+ return x;
+}
+
/*
* call-seq:
* fix & other => integer
@@ -2440,10 +2451,10 @@
{
long val;
- if (TYPE(y) == T_BIGNUM) {
+ if (!FIXNUM_P(y = fix_coerce(y))) {
return rb_big_and(y, x);
}
- val = FIX2LONG(x) & NUM2LONG(y);
+ val = FIX2LONG(x) & FIX2LONG(y);
return LONG2NUM(val);
}
@@ -2460,10 +2471,10 @@
{
long val;
- if (TYPE(y) == T_BIGNUM) {
+ if (!FIXNUM_P(y = fix_coerce(y))) {
return rb_big_or(y, x);
}
- val = FIX2LONG(x) | NUM2LONG(y);
+ val = FIX2LONG(x) | FIX2LONG(y);
return LONG2NUM(val);
}
@@ -2480,10 +2491,10 @@
{
long val;
- if (TYPE(y) == T_BIGNUM) {
+ if (!FIXNUM_P(y = fix_coerce(y))) {
return rb_big_xor(y, x);
}
- val = FIX2LONG(x) ^ NUM2LONG(y);
+ val = FIX2LONG(x) ^ FIX2LONG(y);
return LONG2NUM(val);
}
@@ -2582,7 +2593,7 @@
long val = FIX2LONG(fix);
long i;
- if (TYPE(idx) == T_BIGNUM) {
+ if (!FIXNUM_P(idx = fix_coerce(idx))) {
idx = rb_big_norm(idx);
if (!FIXNUM_P(idx)) {
if (!RBIGNUM(idx)->sign || val >= 0)
@@ -2590,7 +2601,7 @@
return INT2FIX(1);
}
}
- i = NUM2LONG(idx);
+ i = FIX2LONG(idx);
if (i < 0) return INT2FIX(0);
if (sizeof(VALUE)*CHAR_BIT-1 < i) {
Index: ruby_1_8_6/ChangeLog
===================================================================
--- ruby_1_8_6/ChangeLog (revision 17205)
+++ ruby_1_8_6/ChangeLog (revision 17206)
@@ -1,3 +1,8 @@
+Sun Jun 15 20:20:59 2008 Nobuyoshi Nakada <nobu@r...>
+
+ * numeric.c (fix_coerce): try conversion before type check.
+ [ruby-core:15838]
+
Sun Jun 15 19:56:53 2008 Nobuyoshi Nakada <nobu@r...>
* bignum.c (BIGZEROP): fix for longer Bignum zeros. [ruby-Bugs-17454]
Index: ruby_1_8_6/version.h
===================================================================
--- ruby_1_8_6/version.h (revision 17205)
+++ ruby_1_8_6/version.h (revision 17206)
@@ -2,7 +2,7 @@
#define RUBY_RELEASE_DATE "2008-06-15"
#define RUBY_VERSION_CODE 186
#define RUBY_RELEASE_CODE 20080615
-#define RUBY_PATCHLEVEL 185
+#define RUBY_PATCHLEVEL 186
#define RUBY_VERSION_MAJOR 1
#define RUBY_VERSION_MINOR 8
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/