summaryrefslogtreecommitdiffhomepage
path: root/src/vm.c
diff options
context:
space:
mode:
authorCarson McDonald <[email protected]>2014-05-13 11:46:47 -0400
committerCarson McDonald <[email protected]>2014-05-13 11:46:47 -0400
commitf0fed9dbec5f6a334ede9f7ccd3e6ceba014ab4f (patch)
treee6abf620395b395dfddf0ea0216bfe88ebe6fefe /src/vm.c
parent01988e3be7554c0743b8f8b4913bce828f360e35 (diff)
downloadmruby-f0fed9dbec5f6a334ede9f7ccd3e6ceba014ab4f.tar.gz
mruby-f0fed9dbec5f6a334ede9f7ccd3e6ceba014ab4f.zip
Consolidate muliptlication into one place
Diffstat (limited to 'src/vm.c')
-rw-r--r--src/vm.c29
1 files changed, 17 insertions, 12 deletions
diff --git a/src/vm.c b/src/vm.c
index 6e30eab72..9757cf705 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -1729,19 +1729,24 @@ RETRY_TRY_BLOCK:
switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {
case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):
{
- mrb_int x, y, z;
+ mrb_value z;
- x = mrb_fixnum(regs[a]);
- y = mrb_fixnum(regs[a+1]);
- z = x * y;
-#ifdef MRB_WORD_BOXING
- z = (z << MRB_FIXNUM_SHIFT) / (1 << MRB_FIXNUM_SHIFT);
-#endif
- if (x != 0 && z/x != y) {
- SET_FLT_VALUE(mrb, regs[a], (mrb_float)x * (mrb_float)y);
- }
- else {
- SET_INT_VALUE(regs[a], z);
+ z = mrb_fixnum_mul(mrb, regs[a], regs[a+1]);
+
+ switch (mrb_type(z)) {
+ case MRB_TT_FIXNUM:
+ {
+ SET_INT_VALUE(regs[a], mrb_fixnum(z));
+ }
+ break;
+ case MRB_TT_FLOAT:
+ {
+ SET_FLT_VALUE(mrb, regs[a], mrb_float(z));
+ }
+ break;
+ default:
+ /* cannot happen */
+ break;
}
}
break;