From 74dcda0d418c5a5eb27047cd0e4a2bf04b637834 Mon Sep 17 00:00:00 2001 From: naruse Date: Wed, 13 Oct 2010 12:13:53 +0000 Subject: * numeric.c (int_chr): raise error when the value is negative. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29483 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- numeric.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'numeric.c') diff --git a/numeric.c b/numeric.c index c27187f4f4..26ce683daa 100644 --- a/numeric.c +++ b/numeric.c @@ -2120,9 +2120,18 @@ static VALUE int_chr(int argc, VALUE *argv, VALUE num) { char c; - unsigned int i = NUM2UINT(num); + unsigned int i; rb_encoding *enc; + if (rb_num_to_uint(num, &i) == 0) { + } + else if (FIXNUM_P(num)) { + rb_raise(rb_eRangeError, "%ld out of char range", FIX2LONG(num)); + } + else { + rb_raise(rb_eRangeError, "bignum out of char range"); + } + switch (argc) { case 0: if (0xff < i) { -- cgit v1.2.3