summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2017-04-21 10:31:09 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-04-21 22:29:28 +0900
commit5d67d9b10da2cae489d34f8b31914f081d80889b (patch)
tree61c2dea64b4109618bcf5ee9be6afba074898c1f
parent15fba69710c7395b4e9523edb191ef84f672fa28 (diff)
downloadmruby-5d67d9b10da2cae489d34f8b31914f081d80889b.tar.gz
mruby-5d67d9b10da2cae489d34f8b31914f081d80889b.zip
Fixed a possible memory leak.
-rw-r--r--src/vm.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/vm.c b/src/vm.c
index adc345439..d60e90f72 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -257,8 +257,8 @@ MRB_API void
mrb_env_unshare(mrb_state *mrb, struct REnv *e)
{
size_t len = (size_t)MRB_ENV_STACK_LEN(e);
- mrb_value *p = (mrb_value *)mrb_malloc(mrb, sizeof(mrb_value)*len);
ptrdiff_t cioff = e->cioff;
+ mrb_value *p;
if (!MRB_ENV_STACK_SHARED_P(e)) return;
MRB_ENV_UNSHARE_STACK(e);
@@ -266,6 +266,7 @@ mrb_env_unshare(mrb_state *mrb, struct REnv *e)
/* save block argument position (negated) */
e->cioff = -mrb->c->cibase[cioff].argc-1;
}
+ p = (mrb_value *)mrb_malloc(mrb, sizeof(mrb_value)*len);
if (len > 0) {
stack_copy(p, e->stack, len);
}