diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-01-08 04:12:29 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-01-08 04:12:29 +0000 |
commit | 902b1094655145946e6432f24d0f275123d59c26 (patch) | |
tree | 45f7e0f13d7e7e42164cef0316fb6f583131e86c | |
parent | 59a56629b5c6ebaca9bb9d0c24e841de4e4739b6 (diff) | |
download | ruby-902b1094655145946e6432f24d0f275123d59c26.tar.gz |
* marshal.c (w_symbol): dump no encoding for 7bit only coderange
symbol. [ruby-core:27375]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26249 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | marshal.c | 5 | ||||
-rw-r--r-- | test/ruby/test_marshal.rb | 3 | ||||
-rw-r--r-- | version.h | 4 |
4 files changed, 13 insertions, 4 deletions
@@ -1,3 +1,8 @@ +Fri Jan 8 13:12:26 2010 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * marshal.c (w_symbol): dump no encoding for 7bit only coderange + symbol. [ruby-core:27375] + Thu Jan 7 07:56:09 2010 Ryan Davis <ryand-ruby@zenspider.com> * lib/minitest/*.rb: Imported minitest 1.5.0 r5596. @@ -424,10 +424,11 @@ w_symbol(ID id, struct dump_arg *arg) rb_raise(rb_eTypeError, "can't dump anonymous ID %ld", id); } encidx = rb_enc_get_index(sym); - if (encidx == rb_usascii_encindex()) { + if (encidx == rb_usascii_encindex() || + rb_enc_str_coderange(sym) == ENC_CODERANGE_7BIT) { encidx = -1; } - else if (rb_enc_str_coderange(sym) != ENC_CODERANGE_7BIT) { + else { w_byte(TYPE_IVAR, arg); } w_byte(TYPE_SYMBOL, arg); diff --git a/test/ruby/test_marshal.rb b/test/ruby/test_marshal.rb index 704385897c..28cf38c7db 100644 --- a/test/ruby/test_marshal.rb +++ b/test/ruby/test_marshal.rb @@ -261,6 +261,9 @@ class TestMarshal < Test::Unit::TestCase [:ruby, :"\u{7d05}\u{7389}"].each do |sym| assert_equal(sym, Marshal.load(Marshal.dump(sym)), '[ruby-core:24788]') end + bug2548 = '[ruby-core:27375]' + ary = [:$1, nil] + assert_equal(ary, Marshal.load(Marshal.dump(ary)), bug2548) end ClassUTF8 = eval("class R\u{e9}sum\u{e9}; self; end") @@ -1,5 +1,5 @@ #define RUBY_VERSION "1.9.2" -#define RUBY_RELEASE_DATE "2010-01-07" +#define RUBY_RELEASE_DATE "2010-01-08" #define RUBY_PATCHLEVEL -1 #define RUBY_BRANCH_NAME "trunk" @@ -8,7 +8,7 @@ #define RUBY_VERSION_TEENY 1 #define RUBY_RELEASE_YEAR 2010 #define RUBY_RELEASE_MONTH 1 -#define RUBY_RELEASE_DAY 7 +#define RUBY_RELEASE_DAY 8 #include "ruby/version.h" |