From 6557ee938a5404b31b064f08c58bb54dfc0ac468 Mon Sep 17 00:00:00 2001 From: "Yukihiro \"Matz\" Matsumoto" Date: Sun, 26 May 2013 02:13:02 +0900 Subject: mruby error messages should be directed to stderr --- src/backtrace.c | 8 ++++---- src/print.c | 16 ++++++++++++++++ 2 files changed, 20 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/backtrace.c b/src/backtrace.c index f6e3e2eb0..d5d0818ae 100644 --- a/src/backtrace.c +++ b/src/backtrace.c @@ -17,7 +17,7 @@ mrb_print_backtrace(mrb_state *mrb) const char *filename, *method, *sep; int i, line; - printf("trace:\n"); + fputs("trace:\n", stderr); ciidx = mrb_fixnum(mrb_obj_iv_get(mrb, mrb->exc, mrb_intern(mrb, "ciidx"))); if (ciidx >= mrb->c->ciend - mrb->c->cibase) ciidx = 10; /* ciidx is broken... */ @@ -59,14 +59,14 @@ mrb_print_backtrace(mrb_state *mrb) const char *cn = mrb_class_name(mrb, ci->proc->target_class); if (cn) { - printf("\t[%d] %s:%d:in %s%s%s\n", i, filename, line, cn, sep, method); + fprintf(stderr, "\t[%d] %s:%d:in %s%s%s\n", i, filename, line, cn, sep, method); } else { - printf("\t[%d] %s:%d:in %s\n", i, filename, line, method); + fprintf(stderr, "\t[%d] %s:%d:in %s\n", i, filename, line, method); } } else { - printf("\t[%d] %s:%d\n", i, filename, line); + fprintf(stderr, "\t[%d] %s:%d\n", i, filename, line); } } #endif diff --git a/src/print.c b/src/print.c index 5367781f5..01c9b3cd0 100644 --- a/src/print.c +++ b/src/print.c @@ -34,6 +34,22 @@ mrb_p(mrb_state *mrb, mrb_value obj) #endif } +void +mrb_print_error(mrb_state *mrb) +{ +#ifdef ENABLE_STDIO + mrb_value s; + + mrb_print_backtrace(mrb); + s = mrb_funcall(mrb, mrb_obj_value(mrb->exc), "inspect", 0); + if (mrb_string_p(s)) { + struct RString *str = mrb_str_ptr(s); + fwrite(str->ptr, str->len, 1, stderr); + putc('\n', stderr); + } +#endif +} + void mrb_show_version(mrb_state *mrb) { -- cgit v1.2.3