summaryrefslogtreecommitdiffhomepage
path: root/src/array.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2016-11-29 22:36:11 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2016-11-29 22:36:11 +0900
commit246a9a8acd4e45a184ffd11bdd92a5b7736bf1cd (patch)
tree9307d05b81a1245b3fb59423c6e711c1105bede5 /src/array.c
parent9fc62d28d0e5738368571d70f1be191876e91d8b (diff)
downloadmruby-246a9a8acd4e45a184ffd11bdd92a5b7736bf1cd.tar.gz
mruby-246a9a8acd4e45a184ffd11bdd92a5b7736bf1cd.zip
ary_concat: support self concatenation; fix #3302
Diffstat (limited to 'src/array.c')
-rw-r--r--src/array.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/src/array.c b/src/array.c
index 106353c07..ed83bd446 100644
--- a/src/array.c
+++ b/src/array.c
@@ -245,13 +245,15 @@ mrb_ary_s_create(mrb_state *mrb, mrb_value self)
}
static void
-ary_concat(mrb_state *mrb, struct RArray *a, mrb_value *ptr, mrb_int blen)
+ary_concat(mrb_state *mrb, struct RArray *a, struct RArray *a2)
{
- mrb_int len = a->len + blen;
+ mrb_int len = a->len + a2->len;
ary_modify(mrb, a);
- if (a->aux.capa < len) ary_expand_capa(mrb, a, len);
- array_copy(a->ptr+a->len, ptr, blen);
+ if (a->aux.capa < len) {
+ ary_expand_capa(mrb, a, len);
+ }
+ array_copy(a->ptr+a->len, a2->ptr, a2->len);
mrb_write_barrier(mrb, (struct RBasic*)a);
a->len = len;
}
@@ -261,17 +263,16 @@ mrb_ary_concat(mrb_state *mrb, mrb_value self, mrb_value other)
{
struct RArray *a2 = mrb_ary_ptr(other);
- ary_concat(mrb, mrb_ary_ptr(self), a2->ptr, a2->len);
+ ary_concat(mrb, mrb_ary_ptr(self), a2);
}
static mrb_value
mrb_ary_concat_m(mrb_state *mrb, mrb_value self)
{
- mrb_value *ptr;
- mrb_int blen;
+ mrb_value ary;
- mrb_get_args(mrb, "a", &ptr, &blen);
- ary_concat(mrb, mrb_ary_ptr(self), ptr, blen);
+ mrb_get_args(mrb, "A", &ary);
+ mrb_ary_concat(mrb, self, ary);
return self;
}