ruby-changes:20385
From: naruse <ko1@a...>
Date: Thu, 7 Jul 2011 15:23:54 +0900 (JST)
Subject: [ruby-changes:20385] naruse:r32433 (trunk): * numeric.c (rb_num2ull): use own switch sentense.
naruse 2011-07-07 15:23:40 +0900 (Thu, 07 Jul 2011) New Revision: 32433 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=32433 Log: * numeric.c (rb_num2ull): use own switch sentense. Current implementation can't convert 18446744073709551615. Modified files: trunk/ChangeLog trunk/numeric.c Index: ChangeLog =================================================================== --- ChangeLog (revision 32432) +++ ChangeLog (revision 32433) @@ -1,3 +1,8 @@ +Thu Jul 7 15:16:51 2011 NARUSE, Yui <naruse@r...> + + * numeric.c (rb_num2ull): use own switch sentense. + Current implementation can't convert 18446744073709551615. + Thu Jul 7 06:56:15 2011 NARUSE, Yui <naruse@r...> * cont.c (FIBER_STACK_FLAGS): workaround fix for r32420 on FreeBSD. Index: numeric.c =================================================================== --- numeric.c (revision 32432) +++ numeric.c (revision 32433) @@ -1973,10 +1973,43 @@ unsigned LONG_LONG rb_num2ull(VALUE val) { - if (TYPE(val) == T_BIGNUM) { + switch (TYPE(val)) { + case T_NIL: + rb_raise(rb_eTypeError, "no implicit conversion from nil"); + + case T_FIXNUM: + return (LONG_LONG)FIX2ULONG(val); + + case T_FLOAT: + if (RFLOAT_VALUE(val) < ULLONG_MAX_PLUS_ONE + && RFLOAT_VALUE(val) > 0) { + return (unsigned LONG_LONG)(RFLOAT_VALUE(val)); + } + else { + char buf[24]; + char *s; + + snprintf(buf, sizeof(buf), "%-.10g", RFLOAT_VALUE(val)); + if ((s = strchr(buf, ' ')) != 0) *s = '\0'; + rb_raise(rb_eRangeError, "float %s out of range of unsgined long long", buf); + } + + case T_BIGNUM: return rb_big2ull(val); + + case T_STRING: + rb_raise(rb_eTypeError, "no implicit conversion from string"); + return Qnil; /* not reached */ + + case T_TRUE: + case T_FALSE: + rb_raise(rb_eTypeError, "no implicit conversion from boolean"); + return Qnil; /* not reached */ + + default: + val = rb_to_int(val); + return NUM2ULL(val); } - return (unsigned LONG_LONG)rb_num2ll(val); } #endif /* HAVE_LONG_LONG */ -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/