summaryrefslogtreecommitdiffstats
path: root/rational.c
diff options
context:
space:
mode:
authortadf <tadf@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-06-18 13:41:44 +0000
committertadf <tadf@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-06-18 13:41:44 +0000
commit7b974232fd5458b96996dfd7e3b5420aadb46b01 (patch)
treeceacba47fb0d461ee9846a40f194c2a87544bbb3 /rational.c
parent98a08fe6aae9b1cc8bdb1658407e27d4c28a591c (diff)
downloadruby-7b974232fd5458b96996dfd7e3b5420aadb46b01.tar.gz
ruby-7b974232fd5458b96996dfd7e3b5420aadb46b01.tar.xz
ruby-7b974232fd5458b96996dfd7e3b5420aadb46b01.zip
* rational.c (nurat_s_convert): calls to_r when the given argument
is non-integer. * rational.c (nurat_s_convert): raises TypeError when the given argument is nil. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@23735 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'rational.c')
-rw-r--r--rational.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/rational.c b/rational.c
index a75235f65..be441e01a 100644
--- a/rational.c
+++ b/rational.c
@@ -1410,6 +1410,9 @@ nurat_s_convert(int argc, VALUE *argv, VALUE klass)
rb_scan_args(argc, argv, "11", &a1, &a2);
+ if (NIL_P(a1) || (argc == 2 && NIL_P(a2)))
+ rb_raise(rb_eTypeError, "can't convert nil into Rational");
+
switch (TYPE(a1)) {
case T_COMPLEX:
if (k_exact_p(RCOMPLEX(a1)->imag) && f_zero_p(RCOMPLEX(a1)->imag))
@@ -1458,8 +1461,8 @@ nurat_s_convert(int argc, VALUE *argv, VALUE klass)
}
if (argc == 1) {
- if (k_numeric_p(a1) && !f_integer_p(a1))
- return a1;
+ if (!(k_numeric_p(a1) && k_integer_p(a1)))
+ return rb_convert_type(a1, T_RATIONAL, "Rational", "to_r");
}
else {
if ((k_numeric_p(a1) && k_numeric_p(a2)) &&