From a0e236f6065e5dfd68ac8a45ad1ca690042d47b9 Mon Sep 17 00:00:00 2001 From: mame Date: Sat, 17 May 2008 17:56:41 +0000 Subject: * pack.c (pack_pack): check errno to detect error of ruby_strtoul. * pack.c (pack_unpack): ditto. * test/ruby/test_pack.rb: add a test for above. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@16452 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 8 ++++++++ pack.c | 9 +++++++++ test/ruby/test_pack.rb | 4 ++++ version.h | 6 +++--- 4 files changed, 24 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index c8388a2c8a..214413a41f 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +Sun May 18 02:54:46 2008 Yusuke Endoh + + * pack.c (pack_pack): check errno to detect error of ruby_strtoul. + + * pack.c (pack_unpack): ditto. + + * test/ruby/test_pack.rb: add a test for above. + Sat May 17 23:53:57 2008 Nobuyoshi Nakada * file.c (file_expand_path): fix for short file name on Cygwin. diff --git a/pack.c b/pack.c index c5a5337eae..255f74de82 100644 --- a/pack.c +++ b/pack.c @@ -12,6 +12,7 @@ #include "ruby/ruby.h" #include #include +#include #define SIZE16 2 #define SIZE32 4 @@ -491,7 +492,11 @@ pack_pack(VALUE ary, VALUE fmt) p++; } else if (ISDIGIT(*p)) { + errno = 0; len = STRTOUL(p, (char**)&p, 10); + if (errno) { + rb_raise(rb_eRangeError, "pack length too big"); + } } else { len = 1; @@ -1350,7 +1355,11 @@ pack_unpack(VALUE str, VALUE fmt) p++; } else if (ISDIGIT(*p)) { + errno = 0; len = STRTOUL(p, (char**)&p, 10); + if (errno) { + rb_raise(rb_eRangeError, "pack length too big"); + } } else { len = (type != '@'); diff --git a/test/ruby/test_pack.rb b/test/ruby/test_pack.rb index b388937578..30ffe13426 100644 --- a/test/ruby/test_pack.rb +++ b/test/ruby/test_pack.rb @@ -441,4 +441,8 @@ class TestPack < Test::Unit::TestCase end.join end end + + def test_length_too_big + assert_raise(RangeError) { [].pack("C100000000000000000000") } + end end diff --git a/version.h b/version.h index 858d8b614f..e131064ff3 100644 --- a/version.h +++ b/version.h @@ -1,7 +1,7 @@ #define RUBY_VERSION "1.9.0" -#define RUBY_RELEASE_DATE "2008-05-17" +#define RUBY_RELEASE_DATE "2008-05-18" #define RUBY_VERSION_CODE 190 -#define RUBY_RELEASE_CODE 20080517 +#define RUBY_RELEASE_CODE 20080518 #define RUBY_PATCHLEVEL 0 #define RUBY_VERSION_MAJOR 1 @@ -9,7 +9,7 @@ #define RUBY_VERSION_TEENY 0 #define RUBY_RELEASE_YEAR 2008 #define RUBY_RELEASE_MONTH 5 -#define RUBY_RELEASE_DAY 17 +#define RUBY_RELEASE_DAY 18 #ifdef RUBY_EXTERN RUBY_EXTERN const char ruby_version[]; -- cgit v1.2.3