diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-07-10 17:37:52 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-07-10 17:37:52 +0000 |
commit | d902a27aeabe00dffc72f94bd591db15f109226e (patch) | |
tree | 795eb1b9f5e6386f1d78282c09c3db52a9948f3c | |
parent | d85b7f16d054a84806e51bf134ca38bda694c667 (diff) | |
download | ruby-d902a27aeabe00dffc72f94bd591db15f109226e.tar.gz ruby-d902a27aeabe00dffc72f94bd591db15f109226e.tar.xz ruby-d902a27aeabe00dffc72f94bd591db15f109226e.zip |
* random.c (limited_rand): expands to long before shift so that
the result does not overflow.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@24029 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | random.c | 4 |
2 files changed, 7 insertions, 2 deletions
@@ -1,3 +1,8 @@ +Sat Jul 11 02:37:37 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * random.c (limited_rand): expands to long before shift so tha + the result does not overflow. + Sat Jul 11 00:16:27 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> * random.c (rand_init): got rid of buffer overflow. @@ -414,8 +414,8 @@ limited_rand(struct MT *mt, unsigned long limit) retry: val = 0; for (i = SIZEOF_LONG/4-1; 0 <= i; i--) { - if (mask >> (i * 32)) { - val |= genrand_int32(mt) << (i * 32); + if ((mask >> (i * 32)) & 0xffffffff) { + val |= (unsigned long)genrand_int32(mt) << (i * 32); val &= mask; if (limit < val) goto retry; |