ruby-changes:11947
From: matz <ko1@a...>
Date: Mon, 1 Jun 2009 07:54:52 +0900 (JST)
Subject: [ruby-changes:11947] Ruby:r23611 (ruby_1_8): * ext/bigdecimal/bigdecimal.c (BigDecimal_to_f): returns Inf if
matz 2009-06-01 07:54:40 +0900 (Mon, 01 Jun 2009) New Revision: 23611 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=23611 Log: * ext/bigdecimal/bigdecimal.c (BigDecimal_to_f): returns Inf if exp is bigger than DBL_MANT_DIG. Modified files: branches/ruby_1_8/ChangeLog branches/ruby_1_8/ext/bigdecimal/bigdecimal.c Index: ruby_1_8/ext/bigdecimal/bigdecimal.c =================================================================== --- ruby_1_8/ext/bigdecimal/bigdecimal.c (revision 23610) +++ ruby_1_8/ext/bigdecimal/bigdecimal.c (revision 23611) @@ -592,14 +592,16 @@ GUARD_OBJ(p,GetVpValue(self,1)); if(VpVtoD(&d, &e, p)!=1) return rb_float_new(d); + if (e > DBL_MAX_10_EXP) goto erange; buf = ALLOCA_N(char,(unsigned int)VpNumOfChars(p,"E")); VpToString(p, buf, 0, 0); errno = 0; d = strtod(buf, 0); if(errno == ERANGE) { + erange: VpException(VP_EXCEPTION_OVERFLOW,"BigDecimal to Float conversion",0); - if(d>0.0) return rb_float_new(DBL_MAX); - else return rb_float_new(-DBL_MAX); + if(d>0.0) d = VpGetDoublePosInf(); + else d = VpGetDoubleNegInf(); } return rb_float_new(d); } Index: ruby_1_8/ChangeLog =================================================================== --- ruby_1_8/ChangeLog (revision 23610) +++ ruby_1_8/ChangeLog (revision 23611) @@ -1,3 +1,8 @@ +Mon Jun 1 07:20:02 2009 Yukihiro Matsumoto <matz@r...> + + * ext/bigdecimal/bigdecimal.c (BigDecimal_to_f): returns Inf if + exp is bigger than DBL_MANT_DIG. + Sun May 31 23:28:00 2009 Nobuyoshi Nakada <nobu@r...> * lib/mkmf.rb (create_makefile): checks for duplication of source -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/