From 09b3d38c724f8e12efe69ea5ee0942335b100764 Mon Sep 17 00:00:00 2001 From: mrkn Date: Fri, 21 Dec 2018 00:03:39 +0000 Subject: enumerator.c: Fix airth_seq_each for Rational Fix the wrong uses of rb_int_ge in arith_seq_each. [ruby-core:90648] [Bug #15444] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66474 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- enumerator.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'enumerator.c') diff --git a/enumerator.c b/enumerator.c index d2d3b29369..338a9e7584 100644 --- a/enumerator.c +++ b/enumerator.c @@ -3030,6 +3030,8 @@ arith_seq_hash(VALUE self) return LONG2FIX(hash); } +#define NUM_GE(x, y) RTEST(rb_num_coerce_relop((x), (y), idGE)) + struct arith_seq_gen { VALUE current; VALUE end; @@ -3083,13 +3085,13 @@ arith_seq_each(VALUE self) } if (rb_num_negative_int_p(s)) { - while (RTEST(rb_int_ge(c, last))) { + while (NUM_GE(c, last)) { rb_yield(c); c = rb_int_plus(c, s); } } else { - while (RTEST(rb_int_ge(last, c))) { + while (NUM_GE(last, c)) { rb_yield(c); c = rb_int_plus(c, s); } -- cgit v1.2.3