diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-04-21 10:31:09 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-04-21 22:29:28 +0900 |
| commit | 5d67d9b10da2cae489d34f8b31914f081d80889b (patch) | |
| tree | 61c2dea64b4109618bcf5ee9be6afba074898c1f | |
| parent | 15fba69710c7395b4e9523edb191ef84f672fa28 (diff) | |
| download | mruby-5d67d9b10da2cae489d34f8b31914f081d80889b.tar.gz mruby-5d67d9b10da2cae489d34f8b31914f081d80889b.zip | |
Fixed a possible memory leak.
| -rw-r--r-- | src/vm.c | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -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); } |
