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

ruby-changes:4761

From: ko1@a...
Date: Thu, 1 May 2008 23:35:51 +0900 (JST)
Subject: [ruby-changes:4761] nobu - Ruby:r16255 (ruby_1_8, trunk): * range.c (range_step): allow float step bigger than zero but less

nobu	2008-05-01 23:35:13 +0900 (Thu, 01 May 2008)

  New Revision: 16255

  Modified files:
    branches/ruby_1_8/ChangeLog
    branches/ruby_1_8/range.c
    branches/ruby_1_8/version.h
    trunk/ChangeLog
    trunk/range.c

  Log:
    * range.c (range_step): allow float step bigger than zero but less
      than one.  [ruby-dev:34557]


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/range.c?r1=16255&r2=16254&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/ChangeLog?r1=16255&r2=16254&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=16255&r2=16254&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/range.c?r1=16255&r2=16254&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/version.h?r1=16255&r2=16254&diff_format=u

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 16254)
+++ ChangeLog	(revision 16255)
@@ -1,3 +1,8 @@
+Thu May  1 23:35:11 2008  Nobuyoshi Nakada  <nobu@r...>
+
+	* range.c (range_step): allow float step bigger than zero but less
+	  than one.  [ruby-dev:34557]
+
 Thu May  1 23:20:12 2008  Nobuyoshi Nakada  <nobu@r...>
 
 	* bignum.c (rb_big_divide): return an integer for idiv.
Index: range.c
===================================================================
--- range.c	(revision 16254)
+++ range.c	(revision 16255)
@@ -312,7 +312,7 @@
 	    unit = NUM2LONG(step);
 	}
 	else {
-	    VALUE tmp = rb_to_int(step);
+	    VALUE tmp = rb_funcall(rb_funcall(b, '+', 1, step), '-', 1, b);
 	    unit = rb_cmpint(tmp, step, INT2FIX(0));
 	}
     }
Index: ruby_1_8/ChangeLog
===================================================================
--- ruby_1_8/ChangeLog	(revision 16254)
+++ ruby_1_8/ChangeLog	(revision 16255)
@@ -1,3 +1,8 @@
+Thu May  1 23:35:11 2008  Nobuyoshi Nakada  <nobu@r...>
+
+	* range.c (range_step): allow float step bigger than zero but less
+	  than one.  [ruby-dev:34557]
+
 Wed Apr 30 20:22:40 2008  James Edward Gray II  <jeg2@r...>
 
 	Merged 16241 from trunk.
Index: ruby_1_8/version.h
===================================================================
--- ruby_1_8/version.h	(revision 16254)
+++ ruby_1_8/version.h	(revision 16255)
@@ -1,15 +1,15 @@
 #define RUBY_VERSION "1.8.7"
-#define RUBY_RELEASE_DATE "2008-04-30"
+#define RUBY_RELEASE_DATE "2008-05-01"
 #define RUBY_VERSION_CODE 187
-#define RUBY_RELEASE_CODE 20080430
+#define RUBY_RELEASE_CODE 20080501
 #define RUBY_PATCHLEVEL 5000
 
 #define RUBY_VERSION_MAJOR 1
 #define RUBY_VERSION_MINOR 8
 #define RUBY_VERSION_TEENY 7
 #define RUBY_RELEASE_YEAR 2008
-#define RUBY_RELEASE_MONTH 4
-#define RUBY_RELEASE_DAY 30
+#define RUBY_RELEASE_MONTH 5
+#define RUBY_RELEASE_DAY 1
 
 #ifdef RUBY_EXTERN
 RUBY_EXTERN const char ruby_version[];
Index: ruby_1_8/range.c
===================================================================
--- ruby_1_8/range.c	(revision 16254)
+++ ruby_1_8/range.c	(revision 16255)
@@ -314,16 +314,19 @@
 
     b = rb_ivar_get(range, id_beg);
     e = rb_ivar_get(range, id_end);
-    if (rb_scan_args(argc, argv, "01", &step) == 0) {
+    if (argc == 0) {
 	step = INT2FIX(1);
 	unit = 1;
     }
-    else if (FIXNUM_P(step)) {
-	unit = NUM2LONG(step);
-    }
     else {
-	VALUE tmp = rb_to_int(step);
-	unit = rb_cmpint(tmp, step, INT2FIX(0));
+	rb_scan_args(argc, argv, "01", &step);
+	if (FIXNUM_P(step)) {
+	    unit = NUM2LONG(step);
+	}
+	else {
+	    VALUE tmp = rb_funcall(rb_funcall(b, '+', 1, step), '-', 1, b);
+	    unit = rb_cmpint(tmp, step, INT2FIX(0));
+	}
     }
     if (unit < 0) {
 	rb_raise(rb_eArgError, "step can't be negative");

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

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