mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* 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. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44805 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
4b146b2533
commit
c77a745aab
4 changed files with 17 additions and 62 deletions
|
@ -1,3 +1,12 @@
|
|||
Tue Feb 4 16:09:14 2014 Koichi Sasada <ko1@atdot.net>
|
||||
|
||||
* 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@ruby-lang.org>
|
||||
|
||||
* pack.c (str_associate, str_associated): keep associated objects
|
||||
|
|
|
@ -174,8 +174,6 @@ dump_object(VALUE obj, struct dump_config *dc)
|
|||
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))
|
||||
|
|
12
internal.h
12
internal.h
|
@ -715,14 +715,12 @@ VALUE rb_str_locktmp_ensure(VALUE str, VALUE (*func)(VALUE), VALUE arg);
|
|||
#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)
|
||||
|
||||
|
|
56
string.c
56
string.c
|
@ -50,7 +50,7 @@ VALUE rb_cSymbol;
|
|||
#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)
|
|||
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)
|
|||
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)
|
|||
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)
|
|||
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 len)
|
|||
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, long len)
|
|||
}
|
||||
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, long len)
|
|||
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)
|
|||
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);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue