diff options
| author | Tomoyuki Sahara <[email protected]> | 2012-10-31 11:47:59 +0900 |
|---|---|---|
| committer | Tomoyuki Sahara <[email protected]> | 2012-11-02 10:32:39 +0900 |
| commit | 5bae6459ff6649fdc622b0c4f2a8ee93865197e3 (patch) | |
| tree | db5e3890805e3f1195b38dacfcffad70a92809a1 | |
| parent | 3b86394afc66385a69e28313b60cf505dc37c621 (diff) | |
| download | mruby-5bae6459ff6649fdc622b0c4f2a8ee93865197e3.tar.gz mruby-5bae6459ff6649fdc622b0c4f2a8ee93865197e3.zip | |
show backtrace.
| -rw-r--r-- | tools/mruby/mruby.c | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/tools/mruby/mruby.c b/tools/mruby/mruby.c index db26d23a1..94fddf4c7 100644 --- a/tools/mruby/mruby.c +++ b/tools/mruby/mruby.c @@ -162,6 +162,40 @@ cleanup(mrb_state *mrb, struct _args *args) mrb_close(mrb); } +static void +showcallinfo(mrb_state *mrb) +{ + mrb_callinfo *ci; + const char *filename, *sep; + int i; + + printf("trace:\n"); + for (i = 0; &mrb->cibase[i] < mrb->ciend; i++) { + ci = &mrb->cibase[i]; + if (ci->target_class == NULL) + break; + + if (MRB_PROC_CFUNC_P(ci->proc)) + filename = "(cfunc)"; + else { + filename = ci->proc->body.irep->filename; + if (filename == NULL) + filename = "(unknown)"; + } + + if (ci->target_class == ci->proc->target_class) + sep = "."; + else + sep = "#"; + + printf(" ci[%d]: %s:in %s%s%s\n", + i, filename, + mrb_class_name(mrb, ci->proc->target_class), + sep, + mrb_sym2name(mrb, ci->mid)); + } +} + int main(int argc, char **argv) { @@ -198,6 +232,7 @@ main(int argc, char **argv) mrb_run(mrb, mrb_proc_new(mrb, mrb->irep[n]), mrb_top_self(mrb)); n = 0; if (mrb->exc) { + showcallinfo(mrb); p(mrb, mrb_obj_value(mrb->exc)); n = -1; } @@ -223,6 +258,7 @@ main(int argc, char **argv) mrbc_context_free(mrb, c); if (mrb->exc) { if (!mrb_undef_p(v)) { + showcallinfo(mrb); p(mrb, mrb_obj_value(mrb->exc)); } n = -1; |
