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

ruby-changes:11716

From: nobu <ko1@a...>
Date: Thu, 7 May 2009 14:28:07 +0900 (JST)
Subject: [ruby-changes:11716] Ruby:r23359 (trunk): * array.c (rb_ary_sample): negative sample number is invalid.

nobu	2009-05-07 14:26:16 +0900 (Thu, 07 May 2009)

  New Revision: 23359

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=23359

  Log:
    * array.c (rb_ary_sample): negative sample number is invalid.
      [ruby-core:23374]

  Modified files:
    trunk/ChangeLog
    trunk/array.c
    trunk/test/ruby/test_array.rb

Index: array.c
===================================================================
--- array.c	(revision 23358)
+++ array.c	(revision 23359)
@@ -3450,6 +3450,7 @@
     }
     rb_scan_args(argc, argv, "1", &nv);
     n = NUM2LONG(nv);
+    if (n < 0) rb_raise(rb_eArgError, "negative sample number");
     ptr = RARRAY_PTR(ary);
     len = RARRAY_LEN(ary);
     if (n > len) n = len;
Index: ChangeLog
===================================================================
--- ChangeLog	(revision 23358)
+++ ChangeLog	(revision 23359)
@@ -1,3 +1,8 @@
+Thu May  7 14:26:14 2009  Nobuyoshi Nakada  <nobu@r...>
+
+	* array.c (rb_ary_sample): negative sample number is invalid.
+	  [ruby-core:23374]
+
 Thu May  7 14:16:24 2009  Nobuyoshi Nakada  <nobu@r...>
 
 	* string.c, include/ruby/encoding.h: fixed types.
Index: test/ruby/test_array.rb
===================================================================
--- test/ruby/test_array.rb	(revision 23358)
+++ test/ruby/test_array.rb	(revision 23359)
@@ -1605,6 +1605,8 @@
       end
       assert_operator(h.values.min * 2, :>=, h.values.max) if n != 0
     end
+
+    assert_raise(ArgumentError, '[ruby-core:23374]') {[1, 2].sample(-1)}
   end
 
   def test_cycle

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

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