diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2018-04-17 12:34:30 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2018-04-17 12:34:30 +0900 |
| commit | 5c15aa2f3b7bca49b49384951fc5aba1e36bfd79 (patch) | |
| tree | d83ff8f184cca5f39368310d5a30d6e1617bb057 /src | |
| parent | c078783a5aabea571a42961b615d957072e5fb85 (diff) | |
| download | mruby-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.c | 6 |
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"); } |
