summaryrefslogtreecommitdiffhomepage
path: root/src/codegen.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-05-14 17:36:22 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-05-14 17:36:22 +0900
commit232ec102d6264cd5e79cf4e900a5cc946ca76a67 (patch)
treee78eb654803532bd56b566c2d6e0eaa1424957cb /src/codegen.c
parent625988eea1731c50d8f69f74b31a90d64f81eac9 (diff)
parent9184d254e23c14a67b5b1aa5dc5dbbbf747a9ff6 (diff)
downloadmruby-232ec102d6264cd5e79cf4e900a5cc946ca76a67.tar.gz
mruby-232ec102d6264cd5e79cf4e900a5cc946ca76a67.zip
Merge branch 'take-cheeze-dump_lv'
Diffstat (limited to 'src/codegen.c')
-rw-r--r--src/codegen.c7
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);