diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2016-05-11 09:41:19 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2016-05-11 09:41:19 +0900 |
| commit | 5933651ac78b598469130ff95243f2a1674855bc (patch) | |
| tree | 11f3e76a469369d5e3e32f4eb52aba890605cb03 /src/numeric.c | |
| parent | 0be4b8960e1a04ff0681847811bee4398b5664a5 (diff) | |
| parent | 7453a5dfea75e696122ba7895bca76e6ca013d23 (diff) | |
| download | mruby-5933651ac78b598469130ff95243f2a1674855bc.tar.gz mruby-5933651ac78b598469130ff95243f2a1674855bc.zip | |
Merge pull request #3157 from cremno/add-mrb_int_mul_overflow
add function for checked mrb_int multiplication
Diffstat (limited to 'src/numeric.c')
| -rw-r--r-- | src/numeric.c | 16 |
1 files changed, 4 insertions, 12 deletions
diff --git a/src/numeric.c b/src/numeric.c index 7b49b29f7..85847284e 100644 --- a/src/numeric.c +++ b/src/numeric.c @@ -541,10 +541,6 @@ int_to_i(mrb_state *mrb, mrb_value num) return num; } -/*tests if N*N would overflow*/ -#define SQRT_INT_MAX ((mrb_int)1<<((MRB_INT_BIT-1-MRB_FIXNUM_SHIFT)/2)) -#define FIT_SQRT_INT(n) (((n)<SQRT_INT_MAX)&&((n)>=-SQRT_INT_MAX)) - mrb_value mrb_fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y) { @@ -552,18 +548,14 @@ mrb_fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y) a = mrb_fixnum(x); if (mrb_fixnum_p(y)) { - mrb_float c; - mrb_int b; + mrb_int b, c; if (a == 0) return x; b = mrb_fixnum(y); - if (FIT_SQRT_INT(a) && FIT_SQRT_INT(b)) - return mrb_fixnum_value(a*b); - c = a * b; - if ((a != 0 && c/a != b) || !FIXABLE(c)) { - return mrb_float_value(mrb, (mrb_float)a*(mrb_float)b); + if (mrb_int_mul_overflow(a, b, &c)) { + return mrb_float_value(mrb, (mrb_float)a * (mrb_float)b); } - return mrb_fixnum_value((mrb_int)c); + return mrb_fixnum_value(c); } return mrb_float_value(mrb, (mrb_float)a * mrb_to_flo(mrb, y)); } |
