diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-05-14 17:36:22 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-05-14 17:36:22 +0900 |
| commit | 232ec102d6264cd5e79cf4e900a5cc946ca76a67 (patch) | |
| tree | e78eb654803532bd56b566c2d6e0eaa1424957cb /src/codegen.c | |
| parent | 625988eea1731c50d8f69f74b31a90d64f81eac9 (diff) | |
| parent | 9184d254e23c14a67b5b1aa5dc5dbbbf747a9ff6 (diff) | |
| download | mruby-232ec102d6264cd5e79cf4e900a5cc946ca76a67.tar.gz mruby-232ec102d6264cd5e79cf4e900a5cc946ca76a67.zip | |
Merge branch 'take-cheeze-dump_lv'
Diffstat (limited to 'src/codegen.c')
| -rw-r--r-- | src/codegen.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/codegen.c b/src/codegen.c index 52ab9213b..6406c58b3 100644 --- a/src/codegen.c +++ b/src/codegen.c @@ -66,8 +66,8 @@ typedef struct scope { size_t scapa; size_t rcapa; - int nlocals; - int nregs; + uint16_t nlocals; + uint16_t nregs; int ai; int debug_start_pos; @@ -2500,11 +2500,12 @@ scope_new(mrb_state *mrb, codegen_scope *prev, node *lv) node *n = lv; size_t i = 0; - p->irep->lv = (struct mrb_locals*)mrb_malloc(mrb, sizeof(struct mrb_locals)*p->nlocals); + p->irep->lv = (struct mrb_locals*)mrb_malloc(mrb, sizeof(struct mrb_locals) * (p->nlocals - 1)); for (i=0, n=lv; n; i++,n=n->cdr) { p->irep->lv[i].name = lv_name(n); p->irep->lv[i].r = lv_idx(p, lv_name(n)); } + mrb_assert(i + 1 == p->nlocals); } p->ai = mrb_gc_arena_save(mrb); |
