ruby-changes:2416
From: ko1@a...
Date: 13 Nov 2007 16:33:28 +0900
Subject: [ruby-changes:2416] nobu - Ruby:r13907 (trunk, ruby_1_8): * numeric.c (flodivmod): work around for inifinity.
nobu 2007-11-13 16:33:09 +0900 (Tue, 13 Nov 2007)
New Revision: 13907
Modified files:
branches/ruby_1_8/ChangeLog
branches/ruby_1_8/configure.in
branches/ruby_1_8/numeric.c
trunk/ChangeLog
trunk/configure.in
trunk/numeric.c
Log:
* numeric.c (flodivmod): work around for inifinity.
* numeric.c (flo_divmod): work around for platforms have no round().
[ruby-dev:32247]
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/numeric.c?r1=13907&r2=13906
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/configure.in?r1=13907&r2=13906
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/ChangeLog?r1=13907&r2=13906
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=13907&r2=13906
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/numeric.c?r1=13907&r2=13906
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/configure.in?r1=13907&r2=13906
Index: configure.in
===================================================================
--- configure.in (revision 13906)
+++ configure.in (revision 13907)
@@ -598,7 +598,7 @@
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.],
Index: ChangeLog
===================================================================
--- ChangeLog (revision 13906)
+++ ChangeLog (revision 13907)
@@ -1,3 +1,10 @@
+Tue Nov 13 16:33:07 2007 Nobuyoshi Nakada <nobu@r...>
+
+ * 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@f...>
* lex.c.blt: moved from lex.c.
Index: numeric.c
===================================================================
--- numeric.c (revision 13906)
+++ numeric.c (revision 13907)
@@ -644,7 +644,10 @@
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 @@
}
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);
}
Index: ruby_1_8/numeric.c
===================================================================
--- ruby_1_8/numeric.c (revision 13906)
+++ ruby_1_8/numeric.c (revision 13907)
@@ -663,7 +663,10 @@
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;
@@ -736,11 +739,18 @@
}
flodivmod(RFLOAT(x)->value, fy, &div, &mod);
if (FIXABLE(div)) {
+#ifdef HVAE_ROUND
val = round(div);
- a = LONG2FIX(val);
+#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);
+ a = rb_dbl2big(div);
}
b = rb_float_new(mod);
return rb_assoc_new(a, b);
Index: ruby_1_8/configure.in
===================================================================
--- ruby_1_8/configure.in (revision 13906)
+++ ruby_1_8/configure.in (revision 13907)
@@ -545,7 +545,7 @@
getgroups setgroups getpriority getrlimit setrlimit sysconf\
group_member dlopen sigprocmask\
sigaction _setjmp setsid telldir seekdir fchmod mktime timegm\
- cosh sinh tanh setuid setgid setenv unsetenv)
+ cosh sinh tanh round setuid setgid setenv unsetenv)
AC_ARG_ENABLE(setreuid,
[ --enable-setreuid use setreuid()/setregid() according to need even if obsolete.],
[use_setreuid=$enableval])
Index: ruby_1_8/ChangeLog
===================================================================
--- ruby_1_8/ChangeLog (revision 13906)
+++ ruby_1_8/ChangeLog (revision 13907)
@@ -1,3 +1,10 @@
+Tue Nov 13 16:33:07 2007 Nobuyoshi Nakada <nobu@r...>
+
+ * numeric.c (flodivmod): work around for inifinity.
+
+ * numeric.c (flo_divmod): work around for platforms have no round().
+ [ruby-dev:32247]
+
Tue Nov 13 13:58:51 2007 Tanaka Akira <akr@f...>
* numeric.c (numeric.c): Integer#ord implemented. [ruby-dev:32206]
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml