diff options
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | marshal.c | 2 | ||||
| -rw-r--r-- | test/ruby/test_marshal.rb | 1 | ||||
| -rw-r--r-- | version.h | 2 |
4 files changed, 8 insertions, 2 deletions
@@ -1,3 +1,8 @@ +Wed Jul 1 08:46:11 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * marshal.c (w_encoding): encodings need extra depth. + [ruby-core:24100] + Tue Jun 30 17:44:24 2009 Yukihiro Matsumoto <matz@ruby-lang.org> * re.c (reg_match_pos): adjust offset based on characters, not @@ -496,7 +496,7 @@ w_encoding(VALUE obj, long num, struct dump_call_arg *arg) name = (st_data_t)rb_str_new2(rb_enc_name(enc)); st_insert(arg->arg->encodings, (st_data_t)rb_enc_name(enc), name); } while (0); - w_object(name, arg->arg, arg->limit); + w_object(name, arg->arg, arg->limit + 1); } static void diff --git a/test/ruby/test_marshal.rb b/test/ruby/test_marshal.rb index af389d2b2..268acf2a3 100644 --- a/test/ruby/test_marshal.rb +++ b/test/ruby/test_marshal.rb @@ -116,6 +116,7 @@ class TestMarshal < Test::Unit::TestCase def test_limit assert_equal([[[]]], Marshal.load(Marshal.dump([[[]]], 3))) assert_raise(ArgumentError) { Marshal.dump([[[]]], 2) } + assert_nothing_raised(ArgumentError, '[ruby-core:24100]') { Marshal.dump("\u3042", 1) } end def test_userdef_invalid @@ -1,6 +1,6 @@ #define RUBY_VERSION "1.9.1" #define RUBY_RELEASE_DATE "2009-07-12" -#define RUBY_PATCHLEVEL 213 +#define RUBY_PATCHLEVEL 214 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 9 #define RUBY_VERSION_TEENY 1 |
