summaryrefslogtreecommitdiff
path: root/range.c
diff options
context:
space:
mode:
authorshyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-22 12:43:42 +0000
committershyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-22 12:43:42 +0000
commit6cec674877a48c64201254e80b76dfdab126b750 (patch)
treeea74e2de89d913f463186486c0b8272929c7de43 /range.c
parent6d55a704454c197b725fa91acb061841aa6805df (diff)
merge revision(s) 21298:
* numeric.c (ruby_float_step): extracted from num_step(). * range.c (range_step): uses ruby_float_step() for float range. [ruby-dev:37691] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_7@22528 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'range.c')
-rw-r--r--range.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/range.c b/range.c
index 7526324da7..864ca9fb28 100644
--- a/range.c
+++ b/range.c
@@ -273,6 +273,8 @@ step_i(i, arg)
return Qnil;
}
+extern int ruby_float_step _((VALUE from, VALUE to, VALUE step, int excl));
+
/*
* call-seq:
* rng.step(n=1) {| obj | block } => rng
@@ -343,6 +345,9 @@ range_step(argc, argv, range)
}
}
+ else if (ruby_float_step(b, e, step, EXCL(range))) {
+ /* done */
+ }
else if (rb_obj_is_kind_of(b, rb_cNumeric) ||
!NIL_P(rb_check_to_integer(b, "to_int")) ||
!NIL_P(rb_check_to_integer(e, "to_int"))) {