summaryrefslogtreecommitdiffhomepage
path: root/src/vm.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2016-01-19 17:36:51 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2016-01-19 17:36:51 +0900
commit17bd40a566f5220c01fdb68e760e897d6d87c43a (patch)
treee410b5af1198dbed9ae7acd5741cd8af35e27abc /src/vm.c
parent70d24a9e5f501d3f237605f1c48a0ebb934a0ce9 (diff)
parent1d84b3205ae1b8bc5b8a269ffeb5a7f60e610ea6 (diff)
downloadmruby-17bd40a566f5220c01fdb68e760e897d6d87c43a.tar.gz
mruby-17bd40a566f5220c01fdb68e760e897d6d87c43a.zip
Merge pull request #3087 from kou/fix-segv-on-rerasing-no-memory-error
Fix SEGV on re-raising NoMemoryError
Diffstat (limited to 'src/vm.c')
-rw-r--r--src/vm.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/vm.c b/src/vm.c
index bcea8a056..e65b0336c 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -256,12 +256,13 @@ static void
cipop(mrb_state *mrb)
{
struct mrb_context *c = mrb->c;
-
- if (c->ci->env) {
- mrb_env_unshare(mrb, c->ci->env);
- }
+ struct REnv *env = c->ci->env;
c->ci--;
+
+ if (env) {
+ mrb_env_unshare(mrb, env);
+ }
}
void mrb_exc_set(mrb_state *mrb, mrb_value exc);