summaryrefslogtreecommitdiffhomepage
path: root/src/codegen.c
diff options
context:
space:
mode:
authorYukihiro Matz Matsumoto <[email protected]>2012-12-13 00:50:19 +0900
committerYukihiro Matz Matsumoto <[email protected]>2012-12-13 00:50:19 +0900
commit35abbd1486c49a35d6a3414fd647ae8f2fc7ebbe (patch)
treed55073cb5a53662d41333a8adb1d4e15dd801b99 /src/codegen.c
parent1207e245eaf3fe32e3ee2089522b4afcdc881c18 (diff)
parentf2d3c4d2f7361cbd5e246f78630cca919e342673 (diff)
downloadmruby-35abbd1486c49a35d6a3414fd647ae8f2fc7ebbe.tar.gz
mruby-35abbd1486c49a35d6a3414fd647ae8f2fc7ebbe.zip
Merge branch 'master' of github.com:mruby/mruby
Diffstat (limited to 'src/codegen.c')
-rw-r--r--src/codegen.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/codegen.c b/src/codegen.c
index 75ccce648..4244370e5 100644
--- a/src/codegen.c
+++ b/src/codegen.c
@@ -1812,10 +1812,10 @@ codegen(codegen_scope *s, node *tree, int val)
if (val) {
char *p = (char*)tree->car;
size_t len = (intptr_t)tree->cdr;
- int ai = s->mrb->arena_idx;
+ int ai = mrb_gc_arena_save(s->mrb);
int off = new_lit(s, mrb_str_new(s->mrb, p, len));
- s->mrb->arena_idx = ai;
+ mrb_gc_arena_restore(s->mrb, ai);
genop(s, MKOP_ABx(OP_STRING, cursp(), off));
push();
}
@@ -2083,7 +2083,7 @@ scope_new(mrb_state *mrb, codegen_scope *prev, node *lv)
p->lv = lv;
p->sp += node_len(lv)+1; /* add self */
p->nlocals = p->sp;
- p->ai = mrb->arena_idx;
+ p->ai = mrb_gc_arena_save(mrb);
p->filename = prev->filename;
if (p->filename) {
@@ -2118,7 +2118,7 @@ scope_finish(codegen_scope *s)
irep->nlocals = s->nlocals;
irep->nregs = s->nregs;
- mrb->arena_idx = s->ai;
+ mrb_gc_arena_restore(mrb, s->ai);
mrb_pool_close(s->mpool);
}