ruby-changes:32726
From: ko1 <ko1@a...>
Date: Tue, 4 Feb 2014 16:12:54 +0900 (JST)
Subject: [ruby-changes:32726] ko1:r44805 (trunk): * string.c: remvoe STR_ASSOC related code.
ko1 2014-02-04 16:12:49 +0900 (Tue, 04 Feb 2014) New Revision: 44805 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=44805 Log: * string.c: remvoe STR_ASSOC related code. By r44804, string objects can not have STR_ASSOC flag. * internal.h: ditto. * ext/objspace/objspace_dump.c (dump_object): ditto. Modified files: trunk/ChangeLog trunk/ext/objspace/objspace_dump.c trunk/internal.h trunk/string.c Index: ChangeLog =================================================================== --- ChangeLog (revision 44804) +++ ChangeLog (revision 44805) @@ -1,3 +1,12 @@ https://github.com/ruby/ruby/blob/trunk/ChangeLog#L1 +Tue Feb 4 16:09:14 2014 Koichi Sasada <ko1@a...> + + * string.c: remvoe STR_ASSOC related code. + By r44804, string objects can not have STR_ASSOC flag. + + * internal.h: ditto. + + * ext/objspace/objspace_dump.c (dump_object): ditto. + Tue Feb 4 14:07:20 2014 Nobuyoshi Nakada <nobu@r...> * pack.c (str_associate, str_associated): keep associated objects Index: string.c =================================================================== --- string.c (revision 44804) +++ string.c (revision 44805) @@ -50,7 +50,7 @@ VALUE rb_cSymbol; https://github.com/ruby/ruby/blob/trunk/string.c#L50 #define RUBY_MAX_CHAR_LEN 16 #define STR_TMPLOCK FL_USER7 #define STR_UNSET_NOCAPA(s) do {\ - if (FL_TEST((s),STR_NOEMBED)) FL_UNSET((s),(ELTS_SHARED|STR_ASSOC));\ + if (FL_TEST((s),STR_NOEMBED)) FL_UNSET((s),(ELTS_SHARED));\ } while (0) #define STR_SET_NOEMBED(str) do {\ @@ -819,9 +819,7 @@ str_new4(VALUE klass, VALUE str) https://github.com/ruby/ruby/blob/trunk/string.c#L819 STR_SET_SHARED(str2, shared); /* TODO: WB is not needed because str2 is *new* object */ } else { - if (!STR_ASSOC_P(str)) { - RSTRING(str2)->as.heap.aux.capa = RSTRING(str)->as.heap.aux.capa; - } + RSTRING(str2)->as.heap.aux.capa = RSTRING(str)->as.heap.aux.capa; STR_SET_SHARED(str, str2); } rb_enc_cr_str_exact_copy(str2, str); @@ -855,14 +853,6 @@ rb_str_new_frozen(VALUE orig) https://github.com/ruby/ruby/blob/trunk/string.c#L853 rb_enc_cr_str_exact_copy(str, orig); OBJ_INFECT(str, orig); } - else if (STR_ASSOC_P(orig)) { - VALUE assoc = RSTRING(orig)->as.heap.aux.shared; - FL_UNSET(orig, STR_ASSOC); - str = str_new4(klass, orig); - FL_SET(str, STR_ASSOC); - RB_OBJ_WRITE(str, &RSTRING(str)->as.heap.aux.shared, assoc); - /* TODO: WB is not needed because str is new object */ - } else { str = str_new4(klass, orig); } @@ -1028,9 +1018,6 @@ str_replace(VALUE str, VALUE str2) https://github.com/ruby/ruby/blob/trunk/string.c#L1018 long len; len = RSTRING_LEN(str2); - if (STR_ASSOC_P(str2)) { - str2 = rb_str_new4(str2); - } if (STR_SHARED_P(str2)) { VALUE shared = RSTRING(str2)->as.heap.aux.shared; assert(OBJ_FROZEN(shared)); @@ -1038,7 +1025,6 @@ str_replace(VALUE str, VALUE str2) https://github.com/ruby/ruby/blob/trunk/string.c#L1025 RSTRING(str)->as.heap.len = len; RSTRING(str)->as.heap.ptr = RSTRING_PTR(str2); FL_SET(str, ELTS_SHARED); - FL_UNSET(str, STR_ASSOC); STR_SET_SHARED(str, shared); } else { @@ -1926,10 +1912,6 @@ rb_str_substr(VALUE str, long beg, long https://github.com/ruby/ruby/blob/trunk/string.c#L1912 VALUE rb_str_freeze(VALUE str) { - if (STR_ASSOC_P(str)) { - VALUE ary = RSTRING(str)->as.heap.aux.shared; - OBJ_FREEZE(ary); - } return rb_obj_freeze(str); } @@ -2040,11 +2022,7 @@ str_buf_cat(VALUE str, const char *ptr, https://github.com/ruby/ruby/blob/trunk/string.c#L2022 } rb_str_modify(str); if (len == 0) return 0; - if (STR_ASSOC_P(str)) { - FL_UNSET(str, STR_ASSOC); - capa = RSTRING(str)->as.heap.aux.capa = RSTRING_LEN(str); - } - else if (STR_EMBED_P(str)) { + if (STR_EMBED_P(str)) { capa = RSTRING_EMBED_LEN_MAX; } else { @@ -2098,15 +2076,6 @@ rb_str_cat(VALUE str, const char *ptr, l https://github.com/ruby/ruby/blob/trunk/string.c#L2076 if (len < 0) { rb_raise(rb_eArgError, "negative string size (or size too big)"); } - if (STR_ASSOC_P(str)) { - char *p; - rb_str_modify_expand(str, len); - p = RSTRING(str)->as.heap.ptr; - memcpy(p + RSTRING(str)->as.heap.len, ptr, len); - len = RSTRING(str)->as.heap.len += len; - TERM_FILL(p, TERM_LEN(str)); /* sentinel */ - return str; - } return rb_str_buf_cat(str, ptr, len); } @@ -2253,26 +2222,7 @@ rb_str_buf_append(VALUE str, VALUE str2) https://github.com/ruby/ruby/blob/trunk/string.c#L2222 VALUE rb_str_append(VALUE str, VALUE str2) { - rb_encoding *enc; - int cr, cr2; - long len2; - StringValue(str2); - if ((len2 = RSTRING_LEN(str2)) > 0 && STR_ASSOC_P(str)) { - long len1 = RSTRING(str)->as.heap.len, len = len1 + len2; - enc = rb_enc_check(str, str2); - cr = ENC_CODERANGE(str); - if ((cr2 = ENC_CODERANGE(str2)) > cr || RSTRING_LEN(str) == 0) - cr = cr2; - rb_str_modify_expand(str, len2); - memcpy(RSTRING(str)->as.heap.ptr + len1, RSTRING_PTR(str2), len2); - TERM_FILL(RSTRING(str)->as.heap.ptr + len, rb_enc_mbminlen(enc)); - RSTRING(str)->as.heap.len = len; - rb_enc_associate(str, enc); - ENC_CODERANGE_SET(str, cr); - OBJ_INFECT(str, str2); - return str; - } return rb_str_buf_append(str, str2); } Index: ext/objspace/objspace_dump.c =================================================================== --- ext/objspace/objspace_dump.c (revision 44804) +++ ext/objspace/objspace_dump.c (revision 44805) @@ -174,8 +174,6 @@ dump_object(VALUE obj, struct dump_confi https://github.com/ruby/ruby/blob/trunk/ext/objspace/objspace_dump.c#L174 case T_STRING: if (STR_EMBED_P(obj)) dump_append(dc, ", \"embedded\":true"); - if (STR_ASSOC_P(obj)) - dump_append(dc, ", \"associated\":true"); if (is_broken_string(obj)) dump_append(dc, ", \"broken\":true"); if (FL_TEST(obj, RSTRING_FSTR)) Index: internal.h =================================================================== --- internal.h (revision 44804) +++ internal.h (revision 44805) @@ -715,14 +715,12 @@ VALUE rb_str_locktmp_ensure(VALUE str, V https://github.com/ruby/ruby/blob/trunk/internal.h#L715 #ifdef RUBY_ENCODING_H VALUE rb_external_str_with_enc(VALUE str, rb_encoding *eenc); #endif -#define STR_NOEMBED FL_USER1 -#define STR_SHARED FL_USER2 /* = ELTS_SHARED */ -#define STR_ASSOC FL_USER3 -#define STR_SHARED_P(s) FL_ALL((s), STR_NOEMBED|ELTS_SHARED) -#define STR_ASSOC_P(s) FL_ALL((s), STR_NOEMBED|STR_ASSOC) -#define STR_NOCAPA (STR_NOEMBED|ELTS_SHARED|STR_ASSOC) -#define STR_NOCAPA_P(s) (FL_TEST((s),STR_NOEMBED) && FL_ANY((s),ELTS_SHARED|STR_ASSOC)) +#define STR_NOEMBED FL_USER1 +#define STR_SHARED FL_USER2 /* = ELTS_SHARED */ +#define STR_NOCAPA (STR_NOEMBED|ELTS_SHARED) #define STR_EMBED_P(str) (!FL_TEST((str), STR_NOEMBED)) +#define STR_SHARED_P(s) FL_ALL((s), STR_NOCAPA) +#define STR_NOCAPA_P(s) FL_ALL((s), STR_NOCAPA) #define is_ascii_string(str) (rb_enc_str_coderange(str) == ENC_CODERANGE_7BIT) #define is_broken_string(str) (rb_enc_str_coderange(str) == ENC_CODERANGE_BROKEN) -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/