path: root/numeric.c
diff options
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-03-06 06:44:11 (GMT)
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-03-06 06:44:11 (GMT)
commit63f298b0c1ec1909ec536ae2fbcbaeb1a8dcf878 (patch)
treea987bdab0c0b55f166117d9e5d87821a39d2c67a /numeric.c
parent3106f9412ab7bd89cd9fd4931bb7b4865b892d78 (diff)
opt_eq_func refactor
* vm_insnhelper.c (opt_eq_func): method to dispatch is resolved by only the receiver's class, not including the argument class. even if basic operation is redefined, other class conditions never meet. optimize Float and non-Float case, delegate to rb_float_equal directly. git-svn-id: svn+ssh:// b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'numeric.c')
1 files changed, 4 insertions, 2 deletions
diff --git a/numeric.c b/numeric.c
index 6afd95e..3d2b501 100644
--- a/numeric.c
+++ b/numeric.c
@@ -1418,8 +1418,8 @@ num_equal(VALUE x, VALUE y)
-static VALUE
-flo_eq(VALUE x, VALUE y)
+rb_float_equal(VALUE x, VALUE y)
volatile double a, b;
@@ -1442,6 +1442,8 @@ flo_eq(VALUE x, VALUE y)
return (a == b)?Qtrue:Qfalse;
+#define flo_eq rb_float_equal
* call-seq:
* float.hash -> integer