diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-07-18 15:41:47 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-07-18 15:41:47 +0000 |
commit | 61a2d6baf35a0c61cc183659be040205a1e6e43b (patch) | |
tree | ae10bacfdb48b9b87cbd233a0fd6fffc2cd34ae5 /numeric.c | |
parent | fda0d27347e6eb86be2e71bcaf5a4b2fe1ea1ecc (diff) |
Sat Jul 19 00:27:58 2008 NAKAMURA Usaku <[email protected]>
* numeric.c (check_uint, rb_num2uint, rb_fix2uint): fixed wrong check
about 64bit positive value.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@18129 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'numeric.c')
-rw-r--r-- | numeric.c | 25 |
1 files changed, 13 insertions, 12 deletions
@@ -1600,20 +1600,21 @@ check_int(num) } static void -check_uint(num) +check_uint(num, sign) unsigned long num; + VALUE sign; { static const unsigned long mask = ~(unsigned long)UINT_MAX; - static const unsigned long msb = ~LONG_MAX; - const char *s; - if ((num & mask) != 0 && - ((num & mask) != mask || (num & ~mask) <= INT_MAX + 1UL)) { - if ((num & msb) == 0) - s = "big"; - else - s = "small"; - rb_raise(rb_eRangeError, "integer %ld too %s to convert to `unsigned int'", num, s); + if (RTEST(sign)) { + /* minus */ + if ((num & mask) != mask || (num & ~mask) <= INT_MAX + 1UL) + rb_raise(rb_eRangeError, "integer %ld too small to convert to `unsigned int'", num); + } + else { + /* plus */ + if ((num & mask) != 0) + rb_raise(rb_eRangeError, "integer %lu too big to convert to `unsigned int'", num); } } @@ -1643,7 +1644,7 @@ rb_num2uint(val) { unsigned long num = rb_num2ulong(val); - check_uint(num); + check_uint(num, rb_funcall(val, '<', 1, INT2FIX(0))); return num; } @@ -1658,7 +1659,7 @@ rb_fix2uint(val) } num = FIX2ULONG(val); - check_uint(num); + check_uint(num, rb_funcall(val, '<', 1, INT2FIX(0))); return num; } #else |