diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-13 07:33:09 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-13 07:33:09 +0000 |
commit | 5586a27a6128d2119f92c02d96abc4c43fc4ec31 (patch) | |
tree | 494cd08c763113f23a6b09ad55dbea0964e8d8a9 | |
parent | eafd91f9c4a062102ef1a80663564a8160d85f82 (diff) | |
download | ruby-5586a27a6128d2119f92c02d96abc4c43fc4ec31.tar.gz ruby-5586a27a6128d2119f92c02d96abc4c43fc4ec31.tar.xz ruby-5586a27a6128d2119f92c02d96abc4c43fc4ec31.zip |
* numeric.c (flodivmod): work around for inifinity.
* numeric.c (flo_divmod): work around for platforms have no round().
[ruby-dev:32247]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@13907 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | configure.in | 2 | ||||
-rw-r--r-- | numeric.c | 12 |
3 files changed, 19 insertions, 2 deletions
@@ -1,3 +1,10 @@ +Tue Nov 13 16:33:07 2007 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * numeric.c (flodivmod): work around for inifinity. + + * numeric.c (flo_divmod): work around for platforms have no round(). + [ruby-dev:32247] + Tue Nov 13 15:26:33 2007 Tanaka Akira <akr@fsij.org> * lex.c.blt: moved from lex.c. diff --git a/configure.in b/configure.in index 8c9c14318..a1b82d1cf 100644 --- a/configure.in +++ b/configure.in @@ -598,7 +598,7 @@ AC_CHECK_FUNCS(fmod killpg wait4 waitpid fork spawnv syscall chroot fsync getcwd getpgrp setpgrp getpgid setpgid initgroups getgroups setgroups\ getpriority getrlimit setrlimit sysconf group_member\ dlopen sigprocmask sigaction _setjmp vsnprintf snprintf\ - setsid telldir seekdir fchmod mktime timegm cosh sinh tanh log2\ + setsid telldir seekdir fchmod mktime timegm cosh sinh tanh log2 round\ setuid setgid daemon select_large_fdset setenv unsetenv) AC_ARG_ENABLE(setreuid, [ --enable-setreuid use setreuid()/setregid() according to need even if obsolete.], @@ -644,7 +644,10 @@ flodivmod(double x, double y, double *divp, double *modp) mod = x - z * y; } #endif - div = (x - mod) / y; + if (isinf(x) && !isinf(y) && !isnan(y)) + div = x; + else + div = (x - mod) / y; if (y*mod < 0) { mod += y; div -= 1.0; @@ -715,9 +718,16 @@ flo_divmod(VALUE x, VALUE y) } flodivmod(RFLOAT(x)->value, fy, &div, &mod); if (FIXABLE(div)) { +#ifdef HVAE_ROUND val = round(div); +#else + val = (div < 0) ? ceil(x - 0.5) : floor(x + 0.5); +#endif a = LONG2FIX(val); } + else if (isnan(div) || isinf(div)) { + a = rb_float_new(div); + } else { a = rb_dbl2big(div); } |