summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-time/src
diff options
context:
space:
mode:
authorksss <[email protected]>2017-03-28 10:58:18 +0900
committerksss <[email protected]>2017-03-28 10:58:18 +0900
commit397f1fc94631072b76c750c1be3b809ad6dbc060 (patch)
treeb914ec5a662a862f9017678610217f1c2eda1b34 /mrbgems/mruby-time/src
parent66980493ae2f4d587a4a45b6b1061f46c01e34be (diff)
downloadmruby-397f1fc94631072b76c750c1be3b809ad6dbc060.tar.gz
mruby-397f1fc94631072b76c750c1be3b809ad6dbc060.zip
Fix infinity loop
And some cases should raise FloatDomainError
Diffstat (limited to 'mrbgems/mruby-time/src')
-rw-r--r--mrbgems/mruby-time/src/time.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/mrbgems/mruby-time/src/time.c b/mrbgems/mruby-time/src/time.c
index 43d87e5ff..7e5f68f43 100644
--- a/mrbgems/mruby-time/src/time.c
+++ b/mrbgems/mruby-time/src/time.c
@@ -211,6 +211,16 @@ mrb_time_wrap(mrb_state *mrb, struct RClass *tc, struct mrb_time *tm)
return mrb_obj_value(Data_Wrap_Struct(mrb, tc, &mrb_time_type, tm));
}
+static void
+check_num_exact(mrb_state *mrb, double num)
+{
+ if (isinf(num)) {
+ mrb_raise(mrb, E_FLOATDOMAIN_ERROR, num < 0 ? "-Infinity" : "Infinity");
+ }
+ if (isnan(num)) {
+ mrb_raise(mrb, E_FLOATDOMAIN_ERROR, "NaN");
+ }
+}
/* Allocates a mrb_time object and initializes it. */
static struct mrb_time*
@@ -219,6 +229,9 @@ time_alloc(mrb_state *mrb, double sec, double usec, enum mrb_timezone timezone)
struct mrb_time *tm;
time_t tsec = 0;
+ check_num_exact(mrb, sec);
+ check_num_exact(mrb, usec);
+
if (sizeof(time_t) == 4 && (sec > (double)INT32_MAX || (double)INT32_MIN > sec)) {
goto out_of_range;
}