summaryrefslogtreecommitdiff
path: root/random.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-08-26 14:58:44 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-08-26 14:58:44 +0000
commit31875e97b4e11493da07f34096bb4b89180a62b5 (patch)
tree8d879c8196c39e60f6132c225d5fe963b64fb158 /random.c
parent0170c2fc4df2002568c896176b4c7868dee3e6c3 (diff)
* random.c (random_rand): fixed for edge cases of ranges.
[ruby-dev:39166] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24674 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'random.c')
-rw-r--r--random.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/random.c b/random.c
index 3b5729f965..17e5bef3c6 100644
--- a/random.c
+++ b/random.c
@@ -760,10 +760,11 @@ make_mask(unsigned long x)
static unsigned long
limited_rand(struct MT *mt, unsigned long limit)
{
- unsigned long mask = make_mask(limit);
int i;
- unsigned long val;
+ unsigned long val, mask;
+ if (!limit) return 0;
+ mask = make_mask(limit);
retry:
val = 0;
for (i = SIZEOF_LONG/SIZEOF_INT32-1; 0 <= i; i--) {
@@ -1016,7 +1017,7 @@ random_rand(int argc, VALUE *argv, VALUE obj)
v = Qnil;
if (FIXNUM_P(vmax)) {
fixnum:
- if ((max = FIX2LONG(vmax) - excl) > 0) {
+ if ((max = FIX2LONG(vmax) - excl) >= 0) {
unsigned long r = limited_rand(&rnd->mt, (unsigned long)max);
v = ULONG2NUM(r);
}
@@ -1042,6 +1043,9 @@ random_rand(int argc, VALUE *argv, VALUE obj)
}
v = rb_float_new(r * max);
}
+ else if (max == 0.0 && !excl) {
+ v = rb_float_new(0.0);
+ }
}
}
else {