[前][次][番号順一覧][スレッド一覧]

ruby-changes:18624

From: nobu <ko1@a...>
Date: Tue, 25 Jan 2011 07:03:29 +0900 (JST)
Subject: [ruby-changes:18624] Ruby:r30648 (trunk): * string.c (rb_string_value_cstr): rb_str_modify can change

nobu	2011-01-25 07:00:55 +0900 (Tue, 25 Jan 2011)

  New Revision: 30648

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=30648

  Log:
    * string.c (rb_string_value_cstr): rb_str_modify can change
      RSTRING_PTR.

  Added files:
    trunk/ext/-test-/string/cstr.c
    trunk/test/-ext-/string/test_cstr.rb
  Modified files:
    trunk/ChangeLog
    trunk/string.c

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 30647)
+++ ChangeLog	(revision 30648)
@@ -1,3 +1,8 @@
+Tue Jan 25 07:00:52 2011  Nobuyoshi Nakada  <nobu@r...>
+
+	* string.c (rb_string_value_cstr): rb_str_modify can change
+	  RSTRING_PTR.
+
 Tue Jan 25 03:24:28 2011  KOSAKI Motohiro  <kosaki.motohiro@g...>
 
 	* test/ruby/test_thread.rb: Added various ConditionVariable tests.
Index: string.c
===================================================================
--- string.c	(revision 30647)
+++ string.c	(revision 30648)
@@ -1392,7 +1392,11 @@
     if (!s || memchr(s, 0, len)) {
 	rb_raise(rb_eArgError, "string contains null byte");
     }
-    if (s[len]) rb_str_modify(str);
+    if (s[len]) {
+	rb_str_modify(str);
+	s = RSTRING_PTR(str);
+	s[RSTRING_LEN(str)] = 0;
+    }
     return s;
 }
 
Index: ext/-test-/string/cstr.c
===================================================================
--- ext/-test-/string/cstr.c	(revision 0)
+++ ext/-test-/string/cstr.c	(revision 30648)
@@ -0,0 +1,20 @@
+#include "ruby.h"
+
+static VALUE
+bug_str_cstr_term(VALUE str)
+{
+    long len;
+    char *s;
+    rb_str_modify(str);
+    len = RSTRING_LEN(str);
+    RSTRING_PTR(str)[len] = 'x';
+    s = StringValueCStr(str);
+    rb_gc();
+    return INT2NUM(s[len]);
+}
+
+void
+Init_cstr(VALUE klass)
+{
+    rb_define_method(klass, "cstr_term", bug_str_cstr_term, 0);
+}

Property changes on: ext/-test-/string/cstr.c
___________________________________________________________________
Added: svn:eol-style
   + LF

Index: test/-ext-/string/test_cstr.rb
===================================================================
--- test/-ext-/string/test_cstr.rb	(revision 0)
+++ test/-ext-/string/test_cstr.rb	(revision 30648)
@@ -0,0 +1,17 @@
+require 'test/unit'
+require "-test-/string/string"
+
+class Test_StringCStr < Test::Unit::TestCase
+  Bug4319 = '[ruby-dev:43094]'
+
+  def test_embed
+    s = Bug::String.new("abcdef")
+    s.set_len(3)
+    assert_equal(0, s.cstr_term, Bug4319)
+  end
+
+  def test_long
+    s = Bug::String.new("abcdef")*100000
+    assert_equal(0, s.cstr_term, Bug4319)
+  end
+end

Property changes on: test/-ext-/string/test_cstr.rb
___________________________________________________________________
Added: svn:eol-style
   + LF


--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]