summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-complex/src/complex.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2021-03-24 10:27:49 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2021-03-24 10:27:49 +0900
commit3deb62d653e23b175e0c7688976f8af776808980 (patch)
treeb3d61e39337cc0faa8ee5897982637aa893ebe1f /mrbgems/mruby-complex/src/complex.c
parent5573707d7f0ea82fc6fd6335bd23dd9ab6ccbca7 (diff)
downloadmruby-3deb62d653e23b175e0c7688976f8af776808980.tar.gz
mruby-3deb62d653e23b175e0c7688976f8af776808980.zip
complex.c: implement `Complex#/` and `#quo` in C.
Diffstat (limited to 'mrbgems/mruby-complex/src/complex.c')
-rw-r--r--mrbgems/mruby-complex/src/complex.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/mrbgems/mruby-complex/src/complex.c b/mrbgems/mruby-complex/src/complex.c
index c0db0f957..b4e3499cf 100644
--- a/mrbgems/mruby-complex/src/complex.c
+++ b/mrbgems/mruby-complex/src/complex.c
@@ -236,8 +236,15 @@ div_pair(struct float_pair *q, struct float_pair const *a,
static mrb_value
complex_div(mrb_state *mrb, mrb_value self)
{
- mrb_value rhs = mrb_get_arg1(mrb);
struct mrb_complex *a, *b;
+ mrb_value rhs = mrb_get_arg1(mrb);
+
+ a = complex_ptr(mrb, self);
+ if (mrb_type(rhs) != MRB_TT_COMPLEX) {
+ mrb_float f = mrb_to_flo(mrb, rhs);
+ return complex_new(mrb, a->real / f, a->imaginary / f);
+ }
+
struct float_pair ar, ai, br, bi;
struct float_pair br2, bi2;
struct float_pair div;
@@ -245,7 +252,6 @@ complex_div(mrb_state *mrb, mrb_value self)
struct float_pair ai_br, ar_bi;
struct float_pair zr, zi;
- a = complex_ptr(mrb, self);
b = complex_ptr(mrb, rhs);
/* Split floating point components into significand and exponent */
@@ -345,7 +351,8 @@ void mrb_mruby_complex_gem_init(mrb_state *mrb)
mrb_define_method(mrb, comp, "to_i", complex_to_i, MRB_ARGS_NONE());
mrb_define_method(mrb, comp, "to_c", complex_to_c, MRB_ARGS_NONE());
mrb_define_method(mrb, comp, "*", complex_mul, MRB_ARGS_REQ(1));
- mrb_define_method(mrb, comp, "__div__", complex_div, MRB_ARGS_REQ(1));
+ mrb_define_method(mrb, comp, "/", complex_div, MRB_ARGS_REQ(1));
+ mrb_define_method(mrb, comp, "quo", complex_div, MRB_ARGS_REQ(1));
mrb_define_method(mrb, comp, "==", complex_eq, MRB_ARGS_REQ(1));
#ifndef MRB_USE_RATIONAL
mrb_define_method(mrb, mrb->integer_class, "/", int_div, MRB_ARGS_REQ(1)); /* overrride */