diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-08-20 03:28:34 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-08-20 03:28:34 +0000 |
commit | b7fb713ade9365d4917833a3bba52b35ed36f59f (patch) | |
tree | 10e71e5b0d14150aa4a76b2415e431572565f584 | |
parent | 0beace84517ac61d3d7088802c40709fe29e7db1 (diff) | |
download | ruby-b7fb713ade9365d4917833a3bba52b35ed36f59f.tar.gz ruby-b7fb713ade9365d4917833a3bba52b35ed36f59f.tar.xz ruby-b7fb713ade9365d4917833a3bba52b35ed36f59f.zip |
* array.c (rb_ary_sample): get rid of infinite loop. #455
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@18718 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | array.c | 3 |
2 files changed, 6 insertions, 1 deletions
@@ -1,3 +1,7 @@ +Wed Aug 20 12:28:31 2008 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * array.c (rb_ary_sample): get rid of infinite loop. #455 + Wed Aug 20 06:09:31 2008 Tanaka Akira <akr@fsij.org> * include/ruby/io.h (FMODE_TRUNC): value changed because 0x100 is used @@ -3032,8 +3032,9 @@ rb_ary_sample(int argc, VALUE *argv, VALUE ary) return RARRAY_PTR(ary)[i]; } rb_scan_args(argc, argv, "1", &nv); - if (len == 0) return rb_ary_new2(0); n = NUM2INT(nv); + if (n > len) n = len; + if (n == 0) return rb_ary_new2(0); result = rb_ary_new2(n); for (i=0; i<n; i++) { retry: |