mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* ext/bigdecimal/bigdecimal.c (BigDecimal_coerce): support
coercing into Rational. [ruby-core:23415] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23389 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
81cf906bbd
commit
70abf7e8fa
2 changed files with 15 additions and 5 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
Mon May 11 08:37:04 2009 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
|
* ext/bigdecimal/bigdecimal.c (BigDecimal_coerce): support
|
||||||
|
coercing into Rational. [ruby-core:23415]
|
||||||
|
|
||||||
Mon May 11 04:39:45 2009 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Mon May 11 04:39:45 2009 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
* lib/net/smtp.rb (Net::SMTP#check_auth_args): should not change
|
* lib/net/smtp.rb (Net::SMTP#check_auth_args): should not change
|
||||||
|
|
|
@ -675,9 +675,14 @@ BigDecimal_coerce(VALUE self, VALUE other)
|
||||||
ENTER(2);
|
ENTER(2);
|
||||||
VALUE obj;
|
VALUE obj;
|
||||||
Real *b;
|
Real *b;
|
||||||
if(TYPE(other) == T_FLOAT) {
|
switch (TYPE(other)) {
|
||||||
|
case T_FLOAT:
|
||||||
obj = rb_assoc_new(other, BigDecimal_to_f(self));
|
obj = rb_assoc_new(other, BigDecimal_to_f(self));
|
||||||
} else {
|
break;
|
||||||
|
case T_RATIONAL:
|
||||||
|
obj = rb_assoc_new(other, BigDecimal_to_r(self));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
GUARD_OBJ(b,GetVpValue(other,1));
|
GUARD_OBJ(b,GetVpValue(other,1));
|
||||||
obj = rb_assoc_new(b->obj, self);
|
obj = rb_assoc_new(b->obj, self);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue