diff options
| author | Yukihiro Matz Matsumoto <[email protected]> | 2012-12-13 00:50:19 +0900 |
|---|---|---|
| committer | Yukihiro Matz Matsumoto <[email protected]> | 2012-12-13 00:50:19 +0900 |
| commit | 35abbd1486c49a35d6a3414fd647ae8f2fc7ebbe (patch) | |
| tree | d55073cb5a53662d41333a8adb1d4e15dd801b99 /src/codegen.c | |
| parent | 1207e245eaf3fe32e3ee2089522b4afcdc881c18 (diff) | |
| parent | f2d3c4d2f7361cbd5e246f78630cca919e342673 (diff) | |
| download | mruby-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.c | 8 |
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); } |
