From 412b6b5b0234a21b91fafc101fc8175b8e1b97f8 Mon Sep 17 00:00:00 2001 From: shyouhei Date: Mon, 19 Nov 2018 08:10:48 +0000 Subject: io.c: ungetbyte silently ignores upper bits The behaviour of IO#ungetbyte has been depending on the width of Fixnums. Fixnums should be invisible nowadays. It must be a bug. Fix [Bug #14359] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@65802 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- io.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) (limited to 'io.c') diff --git a/io.c b/io.c index ec90407c86..491f2f9585 100644 --- a/io.c +++ b/io.c @@ -4212,8 +4212,18 @@ rb_io_ungetbyte(VALUE io, VALUE b) rb_io_check_byte_readable(fptr); if (NIL_P(b)) return Qnil; if (FIXNUM_P(b)) { - char cc = FIX2INT(b); - b = rb_str_new(&cc, 1); + int i = FIX2INT(b); + if (0 <= i && i <= UCHAR_MAX) { + unsigned char cc = i & 0xFF; + b = rb_str_new((const char *)&cc, 1); + } + else { + rb_raise(rb_eRangeError, + "integer % d too big to convert into `unsigned char'", i); + } + } + else if (RB_TYPE_P(b, T_BIGNUM)) { + rb_raise(rb_eRangeError, "bignum too big to convert into `unsigned char'"); } else { SafeStringValue(b); -- cgit v1.2.3