diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-04-28 02:47:22 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-04-28 02:47:22 +0900 |
| commit | 5c68195c88ed45164373b0ca435a7be2421dcc7c (patch) | |
| tree | c1e56af6ca069a0625ae86a25bc24b8bb409656a /src/symbol.c | |
| parent | 160eb71338205813b9b9c599249b4a5e2bec4217 (diff) | |
| download | mruby-5c68195c88ed45164373b0ca435a7be2421dcc7c.tar.gz mruby-5c68195c88ed45164373b0ca435a7be2421dcc7c.zip | |
mrb_str_new_static(): zero copy string creation
Diffstat (limited to 'src/symbol.c')
| -rw-r--r-- | src/symbol.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/src/symbol.c b/src/symbol.c index 24db3a4b6..e913f95c8 100644 --- a/src/symbol.c +++ b/src/symbol.c @@ -213,7 +213,7 @@ mrb_sym_to_s(mrb_state *mrb, mrb_value sym) size_t len; p = mrb_sym2name_len(mrb, id, &len); - return mrb_str_new(mrb, p, len); + return mrb_str_new_static(mrb, p, len); } /* 15.2.11.3.4 */ @@ -381,14 +381,14 @@ mrb_sym2str(mrb_state *mrb, mrb_sym sym) { size_t len; const char *name = mrb_sym2name_len(mrb, sym, &len); - + mrb_value str; + if (!name) return mrb_undef_value(); /* can't happen */ + str = mrb_str_new_static(mrb, name, len); if (symname_p(name) && strlen(name) == len) { - return mrb_str_new(mrb, name, len); - } - else { - return mrb_str_dump(mrb, mrb_str_new(mrb, name, len)); + return str; } + return mrb_str_dump(mrb, str); } const char* @@ -402,7 +402,7 @@ mrb_sym2name(mrb_state *mrb, mrb_sym sym) return name; } else { - mrb_value str = mrb_str_dump(mrb, mrb_str_new(mrb, name, len)); + mrb_value str = mrb_str_dump(mrb, mrb_str_new_static(mrb, name, len)); return RSTRING(str)->ptr; } } |
