summaryrefslogtreecommitdiffhomepage
path: root/src/numeric.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-03-17 00:16:01 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-03-17 00:16:01 +0900
commit3687e1f97b8a3fd058791d30f5d6f58285a627c6 (patch)
tree95c83ace18e45d610145fa200406b1369a5fbe97 /src/numeric.c
parent55c1942b43b1e62956e6ce1798dc10fe742d617c (diff)
parent0d82ada9229cb01279e087246fcd1bcb4d5ddd29 (diff)
downloadmruby-3687e1f97b8a3fd058791d30f5d6f58285a627c6.tar.gz
mruby-3687e1f97b8a3fd058791d30f5d6f58285a627c6.zip
Merge branch 'master' of github.com:mruby/mruby
Diffstat (limited to 'src/numeric.c')
-rw-r--r--src/numeric.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/src/numeric.c b/src/numeric.c
index 38a05ae92..b0b80c523 100644
--- a/src/numeric.c
+++ b/src/numeric.c
@@ -690,10 +690,10 @@ mrb_fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y)
mrb_int a;
a = mrb_fixnum(x);
- if (a == 0) return x;
if (mrb_fixnum_p(y)) {
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);
@@ -1131,10 +1131,10 @@ mrb_fixnum_plus(mrb_state *mrb, mrb_value x, mrb_value y)
mrb_int a;
a = mrb_fixnum(x);
- if (a == 0) return y;
if (mrb_fixnum_p(y)) {
mrb_int b, c;
+ if (a == 0) return y;
b = mrb_fixnum(y);
c = a + b;
if (((a < 0) ^ (b < 0)) == 0 && (a < 0) != (c < 0)) {
@@ -1306,15 +1306,14 @@ num_cmp(mrb_state *mrb, mrb_value self)
* and <code>other</code>.
*/
static mrb_value
-flo_plus(mrb_state *mrb, mrb_value self)
+flo_plus(mrb_state *mrb, mrb_value x)
{
- mrb_float x, y;
-
- x = mrb_float(self);
- mrb_get_args(mrb, "f", &y);
+ mrb_value y;
- return mrb_float_value(mrb, x + y);
+ mrb_get_args(mrb, "o", &y);
+ return mrb_float_value(mrb, mrb_float(x) + mrb_to_flo(mrb, y));
}
+
/* ------------------------------------------------------------------------*/
void
mrb_init_numeric(mrb_state *mrb)