[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]