diff options
| author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-07-04 08:54:47 +0000 |
|---|---|---|
| committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-07-04 08:54:47 +0000 |
| commit | 5b3dd029bd672c8ef50e49710279d2eb65d3922f (patch) | |
| tree | ef968fd84e709f2d51629cc938902f3f5dbbb23e /numeric.c | |
| parent | 368b0b849cc77931f59f4e787a21118ded6171a5 (diff) | |
* numeric.c (check_uint, rb_num2uint, rb_fix2uint): proper check.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@17871 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'numeric.c')
| -rw-r--r-- | numeric.c | 15 |
1 files changed, 10 insertions, 5 deletions
@@ -1600,12 +1600,11 @@ check_int(num) } static void -check_uint(num, sign) +check_uint(num) unsigned long num; - int sign; { if (num > UINT_MAX) { - rb_raise(rb_eRangeError, "integer %lu too %s to convert to `unsigned int'", num, sign ? "small" : "big"); + rb_raise(rb_eRangeError, "integer %"PRIuVALUE " too big to convert to `unsigned int'", num); } } @@ -1635,7 +1634,10 @@ rb_num2uint(val) { unsigned long num = rb_num2ulong(val); - check_uint(num, RTEST(rb_funcall(val, '<', 1, INT2FIX(0)))); + if (RTEST(rb_funcall(val, '<', 1, INT2FIX(0)))) + check_int(num); + else + check_uint(num); return num; } @@ -1649,7 +1651,10 @@ rb_fix2uint(val) return rb_num2uint(val); } num = FIX2ULONG(val); - check_uint(num, RTEST(rb_funcall(val, '<', 1, INT2FIX(0)))); + if (RTEST(rb_funcall(val, '<', 1, INT2FIX(0)))) + check_int(num); + else + check_uint(num); return num; } #else |
