summaryrefslogtreecommitdiffhomepage
path: root/src/array.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2018-04-25 15:59:56 +0900
committerGitHub <[email protected]>2018-04-25 15:59:56 +0900
commit1c66d42e47dee04974ea83503d552d47caa5c480 (patch)
tree21954ce88a314885c6163dc03b7986118e095942 /src/array.c
parent8bfad558f8eee97b3fcfe2afab3cc84ddb1d15b3 (diff)
parente66c99023491107e3d0281af524434f4728e5f74 (diff)
downloadmruby-1c66d42e47dee04974ea83503d552d47caa5c480.tar.gz
mruby-1c66d42e47dee04974ea83503d552d47caa5c480.zip
Merge pull request #4010 from take-cheeze/fix_ary_replace_leak
Fix array replace leak error in mruby-uri.
Diffstat (limited to 'src/array.c')
-rw-r--r--src/array.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/array.c b/src/array.c
index bfa6e5f06..2152e292d 100644
--- a/src/array.c
+++ b/src/array.c
@@ -377,6 +377,9 @@ ary_replace(mrb_state *mrb, struct RArray *a, struct RArray *b)
if (ARY_EMBED_P(a)) {
ARY_UNSET_EMBED_FLAG(a);
}
+ else {
+ mrb_free(mrb, a->as.heap.ptr);
+ }
a->as.heap.ptr = b->as.heap.ptr;
a->as.heap.len = len;
a->as.heap.aux.shared = b->as.heap.aux.shared;