summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2022-01-02 18:04:18 +0900
committerGitHub <[email protected]>2022-01-02 18:04:18 +0900
commit4e0b1622536ea43dae3f628f4f2ca02727bcc428 (patch)
tree86ab763545c76ae639148be59d1f0c739e755063 /src
parentab4baba283a15c7b44812f60afbd35fe17d9807c (diff)
parentac22a63ae3c29ac3921f53ac63ae981ab0def744 (diff)
downloadmruby-4e0b1622536ea43dae3f628f4f2ca02727bcc428.tar.gz
mruby-4e0b1622536ea43dae3f628f4f2ca02727bcc428.zip
Merge pull request #5622 from dearblue/to_f
Call functions directly from `mrb_ensure_float_type()`
Diffstat (limited to 'src')
-rw-r--r--src/object.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/object.c b/src/object.c
index 8a2addc20..21376d08c 100644
--- a/src/object.c
+++ b/src/object.c
@@ -499,6 +499,9 @@ mrb_ensure_int_type(mrb_state *mrb, mrb_value val)
}
#ifndef MRB_NO_FLOAT
+mrb_value mrb_complex_to_f(mrb_state *mrb, mrb_value comp); // provided by mruby-complex with MRB_USE_COMPLEX
+mrb_value mrb_rational_to_f(mrb_state *mrb, mrb_value rat); // provided by mruby-rational with MRB_USE_RATIONAL
+
MRB_API mrb_value
mrb_ensure_float_type(mrb_state *mrb, mrb_value val)
{
@@ -512,9 +515,15 @@ mrb_ensure_float_type(mrb_state *mrb, mrb_value val)
case MRB_TT_FLOAT:
return val;
+#ifdef MRB_USE_RATIONAL
case MRB_TT_RATIONAL:
+ return mrb_rational_to_f(mrb, val);
+#endif
+
+#ifdef MRB_USE_COMPLEX
case MRB_TT_COMPLEX:
- return mrb_type_convert(mrb, val, MRB_TT_FLOAT, MRB_SYM(to_f));
+ return mrb_complex_to_f(mrb, val);
+#endif
default:
mrb_raisef(mrb, E_TYPE_ERROR, "%Y cannot be converted to Float", val);