summaryrefslogtreecommitdiff
path: root/complex.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-04 08:55:10 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-04 08:55:10 +0000
commit4cef7e44c2fa2182f0c0b7798a9499ae0806cb21 (patch)
tree9e1d4bd24842489379194df462db56dde7f66375 /complex.c
parenta78d9cd85ad3ea62c2a07163b1ab8fdc54ee7026 (diff)
merges r20473 from trunk into ruby_1_9_1.
* complex.c (f_signbit): NaN may be signed value. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@20501 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'complex.c')
-rw-r--r--complex.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/complex.c b/complex.c
index 95a278e3ac..4230af22d6 100644
--- a/complex.c
+++ b/complex.c
@@ -887,15 +887,17 @@ f_signbit(VALUE x)
switch (TYPE(x)) {
case T_FLOAT:
#ifdef HAVE_SIGNBIT
- return f_boolcast(signbit(RFLOAT_VALUE(x)));
+ {
+ double f = RFLOAT_VALUE(x);
+ return f_boolcast(!isnan(f) && signbit(f));
+ }
#else
- {
- char s[2];
-
- (void)snprintf(s, sizeof s, "%.0f", RFLOAT_VALUE(x));
+ {
+ char s[2];
- return f_boolcast(s[0] == '-');
- }
+ (void)snprintf(s, sizeof s, "%.0f", RFLOAT_VALUE(x));
+ return f_boolcast(s[0] == '-');
+ }
#endif
}
return f_negative_p(x);