diff options
| author | tadf <tadf@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-06-17 14:49:10 +0000 |
|---|---|---|
| committer | tadf <tadf@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-06-17 14:49:10 +0000 |
| commit | ea2c82e774b796c6aeda1d1a6b16f5168236e404 (patch) | |
| tree | d01b332bd6df8828734fe78a081ca1ed3cf307c0 | |
| parent | 210af9bf295d0f8e1b96737b5cb69c4dda2e2afb (diff) | |
| download | ruby-ea2c82e774b796c6aeda1d1a6b16f5168236e404.tar.gz ruby-ea2c82e774b796c6aeda1d1a6b16f5168236e404.tar.xz ruby-ea2c82e774b796c6aeda1d1a6b16f5168236e404.zip | |
* rational.c (nurat_coerce): accepts Complex when the imag is
exact zero.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@23727 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | rational.c | 4 |
2 files changed, 9 insertions, 0 deletions
@@ -1,3 +1,8 @@ +Wed Jun 17 23:46:08 2009 Tadayoshi Funaba <tadf@dotrb.org> + + * rational.c (nurat_coerce): accepts Complex when the imag is + exact zero. + Wed Jun 17 21:25:54 2009 Tadayoshi Funaba <tadf@dotrb.org> * bignum.c (rb_big_fdiv): checks whether the given second argument diff --git a/rational.c b/rational.c index de676dc47..a75235f65 100644 --- a/rational.c +++ b/rational.c @@ -902,6 +902,10 @@ nurat_coerce(VALUE self, VALUE other) return rb_assoc_new(other, f_to_f(self)); case T_RATIONAL: return rb_assoc_new(other, self); + case T_COMPLEX: + if (k_exact_p(RCOMPLEX(other)->imag) && f_zero_p(RCOMPLEX(other)->imag)) + return rb_assoc_new(f_rational_new_bang1 + (CLASS_OF(self), RCOMPLEX(other)->real), self); } rb_raise(rb_eTypeError, "%s can't be coerced into %s", |
