aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-07-25 07:08:14 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-07-25 07:08:14 +0000
commitf65273b4191230447bc7aa8feeaa252b9a2fa60c (patch)
tree7f0a3ae50907e6732cbb438fc5e1ee2b5be6bf8b
parentb535e9b004097dd567a7c6d461a5b224bbf47991 (diff)
downloadruby-f65273b4191230447bc7aa8feeaa252b9a2fa60c.tar.gz
* bignum.c (rb_big_eq): reduce isnan(). [ruby-dev:26600]
* numeric.c (flo_eq, flo_gt, flo_ge, flo_lt, flo_le): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@8831 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rw-r--r--bignum.c2
-rw-r--r--numeric.c15
3 files changed, 17 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 792f08c4cf..5b42230006 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -19,6 +19,12 @@ Sat Jul 23 10:01:41 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
* missing/vsnprintf.c: made the output changeable.
+Fri Jul 22 21:06:08 2005 Tadashi Saito <shiba@mail2.accsnet.ne.jp>
+
+ * bignum.c (rb_big_eq): reduce isnan(). [ruby-dev:26600]
+
+ * numeric.c (flo_eq, flo_gt, flo_ge, flo_lt, flo_le): ditto.
+
Fri Jul 22 15:02:39 2005 Kouhei Sutou <kou@cozmixng.org>
* lib/rss/rss.rb: moved copyright description to lib/rss.rb.
diff --git a/bignum.c b/bignum.c
index c5154dbe13..3d11efa8c4 100644
--- a/bignum.c
+++ b/bignum.c
@@ -983,8 +983,8 @@ rb_big_eq(x, y)
volatile double a, b;
a = RFLOAT(y)->value;
+ if (isnan(a)) return Qfalse;
b = rb_big2dbl(x);
- if (isnan(a) || isnan(b)) return Qfalse;
return (a == b)?Qtrue:Qfalse;
}
default:
diff --git a/numeric.c b/numeric.c
index 86c180ccd3..f602679d1e 100644
--- a/numeric.c
+++ b/numeric.c
@@ -833,12 +833,13 @@ flo_eq(x, y)
break;
case T_FLOAT:
b = RFLOAT(y)->value;
+ if (isnan(b)) return Qfalse;
break;
default:
return num_equal(x, y);
}
a = RFLOAT(x)->value;
- if (isnan(a) || isnan(b)) return Qfalse;
+ if (isnan(a)) return Qfalse;
return (a == b)?Qtrue:Qfalse;
}
@@ -938,12 +939,13 @@ flo_gt(x, y)
case T_FLOAT:
b = RFLOAT(y)->value;
+ if (isnan(b)) return Qfalse;
break;
default:
return rb_num_coerce_relop(x, y);
}
- if (isnan(a) || isnan(b)) return Qfalse;
+ if (isnan(a)) return Qfalse;
return (a > b)?Qtrue:Qfalse;
}
@@ -973,12 +975,13 @@ flo_ge(x, y)
case T_FLOAT:
b = RFLOAT(y)->value;
+ if (isnan(b)) return Qfalse;
break;
default:
return rb_num_coerce_relop(x, y);
}
- if (isnan(a) || isnan(b)) return Qfalse;
+ if (isnan(a)) return Qfalse;
return (a >= b)?Qtrue:Qfalse;
}
@@ -1007,12 +1010,13 @@ flo_lt(x, y)
case T_FLOAT:
b = RFLOAT(y)->value;
+ if (isnan(b)) return Qfalse;
break;
default:
return rb_num_coerce_relop(x, y);
}
- if (isnan(a) || isnan(b)) return Qfalse;
+ if (isnan(a)) return Qfalse;
return (a < b)?Qtrue:Qfalse;
}
@@ -1042,12 +1046,13 @@ flo_le(x, y)
case T_FLOAT:
b = RFLOAT(y)->value;
+ if (isnan(b)) return Qfalse;
break;
default:
return rb_num_coerce_relop(x, y);
}
- if (isnan(a) || isnan(b)) return Qfalse;
+ if (isnan(a)) return Qfalse;
return (a <= b)?Qtrue:Qfalse;
}