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

ruby-changes:1982

From: ko1@a...
Date: 21 Sep 2007 01:46:38 +0900
Subject: [ruby-changes:1982] nobu - Ruby:r13473 (ruby_1_8): * string.c (str_alloc): defaults to null_str instead of NULL.

nobu	2007-09-21 01:46:21 +0900 (Fri, 21 Sep 2007)

  New Revision: 13473

  Modified files:
    branches/ruby_1_8/ChangeLog
    branches/ruby_1_8/string.c
    branches/ruby_1_8/version.h

  Log:
    * string.c (str_alloc): defaults to null_str instead of NULL.
      [ruby-dev:31774]


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/ChangeLog?r1=13473&r2=13472
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/version.h?r1=13473&r2=13472
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/string.c?r1=13473&r2=13472

Index: ruby_1_8/ChangeLog
===================================================================
--- ruby_1_8/ChangeLog	(revision 13472)
+++ ruby_1_8/ChangeLog	(revision 13473)
@@ -1,3 +1,8 @@
+Fri Sep 21 01:46:19 2007  Nobuyoshi Nakada  <nobu@r...>
+
+	* string.c (str_alloc): defaults to null_str instead of NULL.
+	  [ruby-dev:31774]
+
 Thu Sep 20 17:24:59 2007  Nobuyoshi Nakada  <nobu@r...>
 
 	* process.c (rb_detach_process): cast for the platforms where size of
Index: ruby_1_8/version.h
===================================================================
--- ruby_1_8/version.h	(revision 13472)
+++ ruby_1_8/version.h	(revision 13473)
@@ -1,7 +1,7 @@
 #define RUBY_VERSION "1.8.6"
-#define RUBY_RELEASE_DATE "2007-09-20"
+#define RUBY_RELEASE_DATE "2007-09-21"
 #define RUBY_VERSION_CODE 186
-#define RUBY_RELEASE_CODE 20070920
+#define RUBY_RELEASE_CODE 20070921
 #define RUBY_PATCHLEVEL 5000
 
 #define RUBY_VERSION_MAJOR 1
@@ -9,7 +9,7 @@
 #define RUBY_VERSION_TEENY 6
 #define RUBY_RELEASE_YEAR 2007
 #define RUBY_RELEASE_MONTH 9
-#define RUBY_RELEASE_DAY 20
+#define RUBY_RELEASE_DAY 21
 
 #ifdef RUBY_EXTERN
 RUBY_EXTERN const char ruby_version[];
Index: ruby_1_8/string.c
===================================================================
--- ruby_1_8/string.c	(revision 13472)
+++ ruby_1_8/string.c	(revision 13473)
@@ -59,13 +59,17 @@
     }
 }
 
+static VALUE str_alloc0 _((VALUE, int));
 static VALUE str_alloc _((VALUE));
+static VALUE str_alloc1 _((VALUE));
+
 static VALUE
-str_alloc(klass)
+str_alloc0(klass, flags)
     VALUE klass;
+    int flags;
 {
     NEWOBJ(str, struct RString);
-    OBJSETUP(str, klass, T_STRING);
+    OBJSETUP(str, klass, flags);
 
     str->ptr = 0;
     str->len = 0;
@@ -74,7 +78,26 @@
     return (VALUE)str;
 }
 
+static const char null_str[] = "";
+#define null_str (char *)null_str
+
 static VALUE
+str_alloc(klass)
+    VALUE klass;
+{
+    VALUE str = str_alloc0(klass, T_STRING | ELTS_SHARED);
+    RSTRING(str)->ptr = null_str;
+    return str;
+}
+
+static VALUE
+str_alloc1(klass)
+    VALUE klass;
+{
+    return str_alloc0(klass, T_STRING);
+}
+
+static VALUE
 str_new(klass, ptr, len)
     VALUE klass;
     const char *ptr;
@@ -86,7 +109,7 @@
 	rb_raise(rb_eArgError, "negative string size (or size too big)");
     }
 
-    str = str_alloc(klass);
+    str = str_alloc1(klass);
     RSTRING(str)->len = len;
     RSTRING(str)->aux.capa = len;
     RSTRING(str)->ptr = ALLOC_N(char,len+1);
@@ -145,7 +168,6 @@
     RSTRING(str2)->len = RSTRING(str)->len;
     RSTRING(str2)->ptr = RSTRING(str)->ptr;
     RSTRING(str2)->aux.shared = str;
-    FL_SET(str2, ELTS_SHARED);
 
     return str2;
 }
@@ -164,7 +186,7 @@
 str_new4(klass, str)
     VALUE klass, str;
 {
-    VALUE str2 = str_alloc(klass);
+    VALUE str2 = str_alloc1(klass);
 
     RSTRING(str2)->len = RSTRING(str)->len;
     RSTRING(str2)->ptr = RSTRING(str)->ptr;
@@ -223,7 +245,7 @@
 rb_str_buf_new(capa)
     long capa;
 {
-    VALUE str = str_alloc(rb_cString);
+    VALUE str = str_alloc1(rb_cString);
 
     if (capa < STR_BUF_MIN_SIZE) {
 	capa = STR_BUF_MIN_SIZE;
@@ -257,13 +279,14 @@
     return rb_convert_type(str, T_STRING, "String", "to_str");
 }
 
+static int str_independent _((VALUE));
+
 static void
 rb_str_shared_replace(str, str2)
     VALUE str, str2;
 {
     if (str == str2) return;
-    rb_str_modify(str);
-    if (!FL_TEST(str, ELTS_SHARED)) free(RSTRING(str)->ptr);
+    if (str_independent(str)) xfree(RSTRING(str)->ptr);
     if (NIL_P(str2)) {
 	RSTRING(str)->ptr = 0;
 	RSTRING(str)->len = 0;
@@ -538,8 +561,6 @@
     return Qfalse;
 }
 
-static char *null_str = "";
-
 VALUE
 rb_string_value(ptr)
     volatile VALUE *ptr;
@@ -2265,8 +2286,11 @@
 	FL_UNSET(str, STR_ASSOC);
 	RSTRING(str)->aux.shared = RSTRING(str2)->aux.shared;
     }
+    else if (!RSTRING(str2)->len) {
+	FL_SET(str, ELTS_SHARED);
+	RSTRING(str)->ptr = null_str;
+    }
     else {
-	rb_str_modify(str);
 	rb_str_resize(str, RSTRING(str2)->len);
 	memcpy(RSTRING(str)->ptr, RSTRING(str2)->ptr, RSTRING(str2)->len);
 	if (FL_TEST(str2, STR_ASSOC)) {

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

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