summaryrefslogtreecommitdiffhomepage
path: root/src/vm.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2016-05-11 09:41:19 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2016-05-11 09:41:19 +0900
commit5933651ac78b598469130ff95243f2a1674855bc (patch)
tree11f3e76a469369d5e3e32f4eb52aba890605cb03 /src/vm.c
parent0be4b8960e1a04ff0681847811bee4398b5664a5 (diff)
parent7453a5dfea75e696122ba7895bca76e6ca013d23 (diff)
downloadmruby-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/vm.c')
-rw-r--r--src/vm.c22
1 files changed, 6 insertions, 16 deletions
diff --git a/src/vm.c b/src/vm.c
index fd2a9384c..6f8c5109f 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -1862,25 +1862,15 @@ RETRY_TRY_BLOCK:
switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {
case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):
{
- mrb_value z;
-
- z = mrb_fixnum_mul(mrb, regs[a], regs[a+1]);
+ mrb_int x, y, z;
- switch (mrb_type(z)) {
- case MRB_TT_FIXNUM:
- {
- SET_INT_VALUE(regs[a], mrb_fixnum(z));
- }
- break;
- case MRB_TT_FLOAT:
- {
- SET_FLOAT_VALUE(mrb, regs[a], mrb_float(z));
- }
- break;
- default:
- /* cannot happen */
+ x = mrb_fixnum(regs[a]);
+ y = mrb_fixnum(regs[a+1]);
+ if (mrb_int_mul_overflow(x, y, &z)) {
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x * (mrb_float)y);
break;
}
+ SET_INT_VALUE(regs[a], z);
}
break;
case TYPES2(MRB_TT_FIXNUM,MRB_TT_FLOAT):