summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2018-04-17 12:34:30 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2018-04-17 12:34:30 +0900
commit5c15aa2f3b7bca49b49384951fc5aba1e36bfd79 (patch)
treed83ff8f184cca5f39368310d5a30d6e1617bb057 /src
parentc078783a5aabea571a42961b615d957072e5fb85 (diff)
downloadmruby-5c15aa2f3b7bca49b49384951fc5aba1e36bfd79.tar.gz
mruby-5c15aa2f3b7bca49b49384951fc5aba1e36bfd79.zip
Make `ary_concat()` to replace the receiver when it is empty.
Diffstat (limited to 'src')
-rw-r--r--src/array.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/array.c b/src/array.c
index 270193e09..09de566f8 100644
--- a/src/array.c
+++ b/src/array.c
@@ -285,11 +285,17 @@ mrb_ary_s_create(mrb_state *mrb, mrb_value klass)
return ary;
}
+static void ary_replace(mrb_state*, struct RArray*, struct RArray*);
+
static void
ary_concat(mrb_state *mrb, struct RArray *a, struct RArray *a2)
{
mrb_int len;
+ if (ARY_LEN(a) == 0) {
+ ary_replace(mrb, a, a2);
+ return;
+ }
if (ARY_LEN(a2) > ARY_MAX_SIZE - ARY_LEN(a)) {
mrb_raise(mrb, E_ARGUMENT_ERROR, "array size too big");
}