summaryrefslogtreecommitdiff
path: root/numeric.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-07-21 18:48:58 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-07-21 18:48:58 +0000
commitc26663f24b0c26906b62d70ae113fbc45efe29f8 (patch)
tree6edefae6c56ef50b55a4ef0795f29adf35e181a6 /numeric.c
parentfa284f8127be2cccb3775309fd5747d79f55ca3d (diff)
* numeric.c (num_equal): should not use rb_equal().
* object.c (rb_equal): back out the last change. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4113 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'numeric.c')
-rw-r--r--numeric.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/numeric.c b/numeric.c
index d97c1493d4..37ff50e8c3 100644
--- a/numeric.c
+++ b/numeric.c
@@ -57,7 +57,7 @@
#define DBL_EPSILON 2.2204460492503131e-16
#endif
-static ID id_coerce, id_to_i;
+static ID id_coerce, id_to_i, id_eq;
VALUE rb_cNumeric;
VALUE rb_cFloat;
@@ -515,7 +515,8 @@ static VALUE
num_equal(x, y)
VALUE x, y;
{
- return rb_equal(y, x);
+ if (x == y) return Qtrue;
+ return rb_funcall(y, id_eq, 1, x);
}
static VALUE
@@ -1804,6 +1805,7 @@ Init_Numeric()
#endif
id_coerce = rb_intern("coerce");
id_to_i = rb_intern("to_i");
+ id_eq = rb_intern("==");
rb_eZeroDivError = rb_define_class("ZeroDivisionError", rb_eStandardError);
rb_eFloatDomainError = rb_define_class("FloatDomainError", rb_eRangeError);