summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-03-09 14:52:33 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-03-09 14:52:33 +0000
commit8767705eb238d7c2391c5cce3c2945db99fc0c24 (patch)
tree202a7fd3734af7ed64b1dd3138752bd2a82de03e
parentb78c7fa106da832f4fe7d2ad8c1f25410fa6b538 (diff)
merge revision(s) 39376: [Backport #7903]
* random.c (rb_random_ulong_limited): fix error message for negative value. [ruby-dev:47061] [Bug #7903] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@39674 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--internal.h1
-rw-r--r--numeric.c6
-rw-r--r--random.c4
-rw-r--r--test/ruby/test_rand.rb15
-rw-r--r--version.h2
6 files changed, 32 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index ee9b14ac71..ba3b493410 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sat Mar 9 23:51:58 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * random.c (rb_random_ulong_limited): fix error message for negative
+ value. [ruby-dev:47061] [Bug #7903]
+
Sat Mar 9 23:41:11 2013 Zachary Scott <zachary@zacharyscott.net>
* thread.c: Document ThreadGroup::Default
diff --git a/internal.h b/internal.h
index b5871fcd55..e66b5fd038 100644
--- a/internal.h
+++ b/internal.h
@@ -168,6 +168,7 @@ int rb_num_to_uint(VALUE val, unsigned int *ret);
VALUE num_interval_step_size(VALUE from, VALUE to, VALUE step, int excl);
int ruby_float_step(VALUE from, VALUE to, VALUE step, int excl);
double ruby_float_mod(double x, double y);
+int rb_num_negative_p(VALUE);
/* object.c */
VALUE rb_obj_equal(VALUE obj1, VALUE obj2);
diff --git a/numeric.c b/numeric.c
index a512ba8991..fe85d6cc31 100644
--- a/numeric.c
+++ b/numeric.c
@@ -185,6 +185,12 @@ negative_int_p(VALUE num)
return RTEST(rb_funcall(num, mid, 1, INT2FIX(0)));
}
+int
+rb_num_negative_p(VALUE num)
+{
+ return negative_int_p(num);
+}
+
/*
* call-seq:
* num.coerce(numeric) -> array
diff --git a/random.c b/random.c
index 6e635d912f..9b62cc1add 100644
--- a/random.c
+++ b/random.c
@@ -947,9 +947,13 @@ rb_random_ulong_limited(VALUE obj, unsigned long limit)
{
rb_random_t *rnd = try_get_rnd(obj);
if (!rnd) {
+ extern int rb_num_negative_p(VALUE);
VALUE lim = ULONG2NUM(limit);
VALUE v = rb_funcall2(obj, id_rand, 1, &lim);
unsigned long r = NUM2ULONG(v);
+ if (rb_num_negative_p(v)) {
+ rb_raise(rb_eRangeError, "random number too small %ld", r);
+ }
if (r > limit) {
rb_raise(rb_eRangeError, "random number too big %ld", r);
}
diff --git a/test/ruby/test_rand.rb b/test/ruby/test_rand.rb
index b482773c00..9fabfc607f 100644
--- a/test/ruby/test_rand.rb
+++ b/test/ruby/test_rand.rb
@@ -1,4 +1,5 @@
require 'test/unit'
+require_relative 'envutil'
class TestRand < Test::Unit::TestCase
def assert_random_int(ws, m, init = 0)
@@ -514,4 +515,18 @@ END
l.call
end
end
+
+ def test_random_ulong_limited
+ def (gen = Object.new).rand(*) 1 end
+ assert_equal([2], (1..100).map {[1,2,3].sample(random: gen)}.uniq)
+
+ def (gen = Object.new).rand(*) 100 end
+ e = assert_raise(RangeError) {[1,2,3].sample(random: gen)}
+ assert_match(/big 100\z/, e.message)
+
+ bug7903 = '[ruby-dev:47061] [Bug #7903]'
+ def (gen = Object.new).rand(*) -1 end
+ e = assert_raise(RangeError) {[1,2,3].sample(random: gen)}
+ assert_match(/small -1\z/, e.message, bug7903)
+ end
end
diff --git a/version.h b/version.h
index 9709ef0795..789049c680 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.0.0"
#define RUBY_RELEASE_DATE "2013-03-09"
-#define RUBY_PATCHLEVEL 43
+#define RUBY_PATCHLEVEL 44
#define RUBY_RELEASE_YEAR 2013
#define RUBY_RELEASE_MONTH 3