summaryrefslogtreecommitdiffstats
path: root/numeric.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-11-30 09:22:47 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-11-30 09:22:47 +0000
commit55a5557f3256596ace71613564a4704f259c75f2 (patch)
treec93ee93a343414378884a6ce63130983d75ecf2f /numeric.c
parent186faf3809b336c9005c456a244e796e79c7926c (diff)
downloadruby-55a5557f3256596ace71613564a4704f259c75f2.tar.gz
ruby-55a5557f3256596ace71613564a4704f259c75f2.tar.xz
ruby-55a5557f3256596ace71613564a4704f259c75f2.zip
merges r20348 from trunk into ruby_1_9_1.
* numeric.c (num_step): treat infinite step specially. [ruby-dev:37157] fix: #781. git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1@20409 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'numeric.c')
-rw-r--r--numeric.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/numeric.c b/numeric.c
index 042e0c306..c2f5e60c1 100644
--- a/numeric.c
+++ b/numeric.c
@@ -1503,10 +1503,15 @@ num_step(int argc, VALUE *argv, VALUE from)
double err = (fabs(beg) + fabs(end) + fabs(end-beg)) / fabs(unit) * epsilon;
long i;
- if (err>0.5) err=0.5;
- n = floor(n + err) + 1;
- for (i=0; i<n; i++) {
- rb_yield(DBL2NUM(i*unit+beg));
+ if (isinf(unit)) {
+ if (unit > 0) rb_yield(DBL2NUM(beg));
+ }
+ else {
+ if (err>0.5) err=0.5;
+ n = floor(n + err) + 1;
+ for (i=0; i<n; i++) {
+ rb_yield(DBL2NUM(i*unit+beg));
+ }
}
}
else {