summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/codegen.c11
-rw-r--r--src/debug.c4
2 files changed, 10 insertions, 5 deletions
diff --git a/src/codegen.c b/src/codegen.c
index b46ddf87e..1efc44ba0 100644
--- a/src/codegen.c
+++ b/src/codegen.c
@@ -1111,12 +1111,14 @@ static void
codegen(codegen_scope *s, node *tree, int val)
{
int nt;
+ mrb_irep_debug_info_file const *finished_file;
if (!tree) return;
if (s->irep && s->pc > 0 && s->filename_index != tree->filename) {
- s->irep->filename = s->filename = mrb_parser_get_filename(s->parser, s->filename_index);
- mrb_debug_info_append_file(s->mrb, s->irep, s->debug_start_pos, s->pc);
+ s->irep->filename = mrb_parser_get_filename(s->parser, s->filename_index);
+ finished_file = mrb_debug_info_append_file(s->mrb, s->irep, s->debug_start_pos, s->pc);
+ mrb_assert(finished_file);
s->debug_start_pos = s->pc;
s->filename_index = tree->filename;
s->filename = mrb_parser_get_filename(s->parser, tree->filename);
@@ -2434,6 +2436,7 @@ scope_finish(codegen_scope *s)
mrb_irep *irep = s->irep;
size_t fname_len;
char *fname;
+ mrb_irep_debug_info_file const *finished_file;
irep->flags = 0;
if (s->iseq) {
@@ -2449,7 +2452,9 @@ scope_finish(codegen_scope *s)
irep->pool = (mrb_value *)codegen_realloc(s, irep->pool, sizeof(mrb_value)*irep->plen);
irep->syms = (mrb_sym *)codegen_realloc(s, irep->syms, sizeof(mrb_sym)*irep->slen);
if (s->filename) {
- mrb_debug_info_append_file(mrb, s->irep, s->debug_start_pos, s->pc);
+ s->irep->filename = mrb_parser_get_filename(s->parser, s->filename_index);
+ finished_file = mrb_debug_info_append_file(mrb, s->irep, s->debug_start_pos, s->pc);
+ mrb_assert(finished_file);
fname_len = strlen(s->filename);
fname = codegen_malloc(s, fname_len + 1);
diff --git a/src/debug.c b/src/debug.c
index 7902c09ba..8e4311f6c 100644
--- a/src/debug.c
+++ b/src/debug.c
@@ -73,8 +73,8 @@ mrb_debug_get_line(mrb_irep *irep, uint32_t pc)
else if ((f = get_file(irep->debug_info, pc))) {
switch(f->line_type) {
case mrb_debug_line_ary:
- mrb_assert(pc < (f->start_pos + f->line_entry_count));
- return f->line_ary[pc];
+ mrb_assert(f->start_pos <= pc && pc < (f->start_pos + f->line_entry_count));
+ return f->line_ary[pc - f->start_pos];
case mrb_debug_line_flat_map: {
// get upper bound