summaryrefslogtreecommitdiffhomepage
path: root/src/string.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-11-20 07:29:55 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2013-11-20 07:29:55 +0900
commitd73dfa87087879ca3b06e1f30a68a120549e0a57 (patch)
treea4bc7d8fe8f495fdf5784c7e6477c8abe3856cd9 /src/string.c
parent6742421907765ecd4bfb80f74a080e91bf5b0d52 (diff)
parent54c5b12fb7bc5fdd57326780e970ee467387f81a (diff)
downloadmruby-d73dfa87087879ca3b06e1f30a68a120549e0a57.tar.gz
mruby-d73dfa87087879ca3b06e1f30a68a120549e0a57.zip
resolve conflict
Diffstat (limited to 'src/string.c')
-rw-r--r--src/string.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/string.c b/src/string.c
index af70e8e45..6ec98c778 100644
--- a/src/string.c
+++ b/src/string.c
@@ -734,6 +734,28 @@ mrb_str_dup(mrb_state *mrb, mrb_value str)
return mrb_str_new(mrb, s->ptr, s->len);
}
+mrb_value
+mrb_str_dup_static(mrb_state *mrb, mrb_value str)
+{
+ struct RString *s = mrb_str_ptr(str);
+ struct RString *ns;
+ mrb_int len;
+
+ ns = (struct RString *)mrb_malloc(mrb, sizeof(struct RString));
+ ns->tt = MRB_TT_STRING;
+ ns->c = mrb->string_class;
+
+ len = s->len;
+ ns->len = len;
+ ns->ptr = (char *)mrb_malloc(mrb, (size_t)len+1);
+ if (s->ptr) {
+ memcpy(ns->ptr, s->ptr, len);
+ }
+ ns->ptr[len] = '\0';
+
+ return mrb_obj_value(ns);
+}
+
static mrb_value
mrb_str_aref(mrb_state *mrb, mrb_value str, mrb_value indx)
{