Add new functions for numerical operation; ref 237a57bb

New functions:
* mrb_num_plus(mrb, x, y)
* mrb_num_minus(mrb, x, y)
* num_num_mul(mrb, x, y)
parent 05e75445
...@@ -36,6 +36,10 @@ MRB_API mrb_value mrb_float_to_str(mrb_state *mrb, mrb_value x, const char *fmt) ...@@ -36,6 +36,10 @@ MRB_API mrb_value mrb_float_to_str(mrb_state *mrb, mrb_value x, const char *fmt)
MRB_API mrb_float mrb_to_flo(mrb_state *mrb, mrb_value x); MRB_API mrb_float mrb_to_flo(mrb_state *mrb, mrb_value x);
#endif #endif
MRB_API mrb_value mrb_num_plus(mrb_state *mrb, mrb_value x, mrb_value y);
MRB_API mrb_value mrb_num_minus(mrb_state *mrb, mrb_value x, mrb_value y);
MRB_API mrb_value mrb_num_mul(mrb_state *mrb, mrb_value x, mrb_value y);
#ifndef __has_builtin #ifndef __has_builtin
#define __has_builtin(x) 0 #define __has_builtin(x) 0
#endif #endif
......
...@@ -788,7 +788,7 @@ int_to_i(mrb_state *mrb, mrb_value num) ...@@ -788,7 +788,7 @@ int_to_i(mrb_state *mrb, mrb_value num)
} }
static mrb_value static mrb_value
mrb_fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y) fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y)
{ {
mrb_int a; mrb_int a;
...@@ -812,6 +812,20 @@ mrb_fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y) ...@@ -812,6 +812,20 @@ mrb_fixnum_mul(mrb_state *mrb, mrb_value x, mrb_value y)
#endif #endif
} }
MRB_API mrb_value
mrb_num_mul(mrb_state *mrb, mrb_value x, mrb_value y)
{
if (mrb_fixnum_p(x)) {
return fixnum_mul(mrb, x, y);
}
#ifndef MRB_WITHOUT_FLOAT
if (mrb_float_p(x)) {
return mrb_float_value(mrb, mrb_float(x) * mrb_to_flo(mrb, y));
}
#endif
mrb_raise(mrb, E_TYPE_ERROR, "no number multiply");
}
/* 15.2.8.3.3 */ /* 15.2.8.3.3 */
/* /*
* call-seq: * call-seq:
...@@ -828,7 +842,7 @@ fix_mul(mrb_state *mrb, mrb_value x) ...@@ -828,7 +842,7 @@ fix_mul(mrb_state *mrb, mrb_value x)
mrb_value y; mrb_value y;
mrb_get_args(mrb, "o", &y); mrb_get_args(mrb, "o", &y);
return mrb_fixnum_mul(mrb, x, y); return fixnum_mul(mrb, x, y);
} }
static void static void
...@@ -1245,7 +1259,7 @@ mrb_flo_to_fixnum(mrb_state *mrb, mrb_value x) ...@@ -1245,7 +1259,7 @@ mrb_flo_to_fixnum(mrb_state *mrb, mrb_value x)
#endif #endif
static mrb_value static mrb_value
mrb_fixnum_plus(mrb_state *mrb, mrb_value x, mrb_value y) fixnum_plus(mrb_state *mrb, mrb_value x, mrb_value y)
{ {
mrb_int a; mrb_int a;
...@@ -1269,6 +1283,20 @@ mrb_fixnum_plus(mrb_state *mrb, mrb_value x, mrb_value y) ...@@ -1269,6 +1283,20 @@ mrb_fixnum_plus(mrb_state *mrb, mrb_value x, mrb_value y)
#endif #endif
} }
MRB_API mrb_value
mrb_num_plus(mrb_state *mrb, mrb_value x, mrb_value y)
{
if (mrb_fixnum_p(x)) {
return fixnum_plus(mrb, x, y);
}
#ifndef MRB_WITHOUT_FLOAT
if (mrb_float_p(x)) {
return mrb_float_value(mrb, mrb_float(x) + mrb_to_flo(mrb, y));
}
#endif
mrb_raise(mrb, E_TYPE_ERROR, "no number addition");
}
/* 15.2.8.3.1 */ /* 15.2.8.3.1 */
/* /*
* call-seq: * call-seq:
...@@ -1284,11 +1312,11 @@ fix_plus(mrb_state *mrb, mrb_value self) ...@@ -1284,11 +1312,11 @@ fix_plus(mrb_state *mrb, mrb_value self)
mrb_value other; mrb_value other;
mrb_get_args(mrb, "o", &other); mrb_get_args(mrb, "o", &other);
return mrb_fixnum_plus(mrb, self, other); return fixnum_plus(mrb, self, other);
} }
static mrb_value static mrb_value
mrb_fixnum_minus(mrb_state *mrb, mrb_value x, mrb_value y) fixnum_minus(mrb_state *mrb, mrb_value x, mrb_value y)
{ {
mrb_int a; mrb_int a;
...@@ -1311,6 +1339,20 @@ mrb_fixnum_minus(mrb_state *mrb, mrb_value x, mrb_value y) ...@@ -1311,6 +1339,20 @@ mrb_fixnum_minus(mrb_state *mrb, mrb_value x, mrb_value y)
#endif #endif
} }
MRB_API mrb_value
mrb_num_minus(mrb_state *mrb, mrb_value x, mrb_value y)
{
if (mrb_fixnum_p(x)) {
return fixnum_minus(mrb, x, y);
}
#ifdef MRB_WITHOUT_FLOAT
if (mrb_float_p(x)) {
return mrb_float_value(mrb, mrb_float(x) - mrb_to_flo(mrb, y));
}
#endif
mrb_raise(mrb, E_TYPE_ERROR, "no number subtraction");
}
/* 15.2.8.3.2 */ /* 15.2.8.3.2 */
/* 15.2.8.3.16 */ /* 15.2.8.3.16 */
/* /*
...@@ -1327,7 +1369,7 @@ fix_minus(mrb_state *mrb, mrb_value self) ...@@ -1327,7 +1369,7 @@ fix_minus(mrb_state *mrb, mrb_value self)
mrb_value other; mrb_value other;
mrb_get_args(mrb, "o", &other); mrb_get_args(mrb, "o", &other);
return mrb_fixnum_minus(mrb, self, other); return fixnum_minus(mrb, self, other);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment