ruby-changes:16869
From: nobu <ko1@a...>
Date: Thu, 5 Aug 2010 16:43:03 +0900 (JST)
Subject: [ruby-changes:16869] Ruby:r28865 (trunk): * string.c (rb_str_set_len): should fail to modify shared string.
nobu 2010-08-05 16:42:47 +0900 (Thu, 05 Aug 2010) New Revision: 28865 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=28865 Log: * string.c (rb_str_set_len): should fail to modify shared string. Added directories: trunk/ext/-test-/string/ trunk/test/-ext-/string/ Added files: trunk/ext/-test-/string/extconf.rb trunk/ext/-test-/string/init.c trunk/ext/-test-/string/set_len.c trunk/test/-ext-/string/test_set_len.rb Modified files: trunk/ChangeLog trunk/string.c Index: ChangeLog =================================================================== --- ChangeLog (revision 28864) +++ ChangeLog (revision 28865) @@ -1,3 +1,7 @@ +Thu Aug 5 16:42:41 2010 Nobuyoshi Nakada <nobu@r...> + + * string.c (rb_str_set_len): should fail to modify shared string. + Thu Aug 5 14:12:44 2010 Nobuyoshi Nakada <nobu@r...> * ruby.c (ruby_init_loadpath_safe): ensure sopath to be modifiable Index: string.c =================================================================== --- string.c (revision 28864) +++ string.c (revision 28865) @@ -1694,6 +1694,9 @@ rb_str_set_len(VALUE str, long len) { str_modifiable(str); + if (STR_SHARED_P(str)) { + rb_raise(rb_eRuntimeError, "can't set length of shared string"); + } STR_SET_LEN(str, len); RSTRING_PTR(str)[len] = '\0'; } Index: ext/-test-/string/init.c =================================================================== --- ext/-test-/string/init.c (revision 0) +++ ext/-test-/string/init.c (revision 28865) @@ -0,0 +1,19 @@ +#include "ruby.h" + +#define init(n) {void Init_##n(VALUE klass); Init_##n(klass);} + +VALUE +bug_str_modify(VALUE str) +{ + rb_str_modify(str); + return str; +} + +void +Init_string(void) +{ + VALUE mBug = rb_define_module("Bug"); + VALUE klass = rb_define_class_under(mBug, "String", rb_cString); + rb_define_method(klass, "modify!", bug_str_modify, 0); + TEST_INIT_FUNCS(init); +} Property changes on: ext/-test-/string/init.c ___________________________________________________________________ Added: svn:eol-style + LF Index: ext/-test-/string/extconf.rb =================================================================== --- ext/-test-/string/extconf.rb (revision 0) +++ ext/-test-/string/extconf.rb (revision 28865) @@ -0,0 +1,6 @@ +$srcs = Dir[File.join($srcdir, "*.{#{SRC_EXT.join(%q{,})}}")] +inits = $srcs.map {|s| File.basename(s, ".*")} +inits.delete("init") +inits.map! {|s|"X(#{s})"} +$defs << "-DTEST_INIT_FUNCS(X)=\"#{inits.join(' ')}\"" +create_makefile("-test-/string/string") Property changes on: ext/-test-/string/extconf.rb ___________________________________________________________________ Added: svn:eol-style + LF Index: ext/-test-/string/set_len.c =================================================================== --- ext/-test-/string/set_len.c (revision 0) +++ ext/-test-/string/set_len.c (revision 28865) @@ -0,0 +1,14 @@ +#include "ruby.h" + +static VALUE +bug_str_set_len(VALUE str, VALUE len) +{ + rb_str_set_len(str, NUM2LONG(len)); + return str; +} + +void +Init_set_len(VALUE klass) +{ + rb_define_method(klass, "set_len", bug_str_set_len, 1); +} Property changes on: ext/-test-/string/set_len.c ___________________________________________________________________ Added: svn:eol-style + LF Index: test/-ext-/string/test_set_len.rb =================================================================== --- test/-ext-/string/test_set_len.rb (revision 0) +++ test/-ext-/string/test_set_len.rb (revision 28865) @@ -0,0 +1,25 @@ +require 'test/unit' +require "-test-/string/string" + +class Test_StrSetLen < Test::Unit::TestCase + def setup + @s0 = [*"a".."z"].join("").freeze + @s1 = Bug::String.new(@s0) + end + + def teardown + orig = [*"a".."z"].join("") + assert_equal(orig, @s0) + end + + def test_non_shared + @s1.modify! + assert_equal("abc", @s1.set_len(3)) + end + + def test_shared + assert_raise(RuntimeError) { + assert_equal("abc", @s1.set_len(3)) + } + end +end Property changes on: test/-ext-/string/test_set_len.rb ___________________________________________________________________ Added: svn:eol-style + LF -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/