diff options
| author | Tomoyuki Sahara <[email protected]> | 2017-11-02 15:44:05 +0900 |
|---|---|---|
| committer | Tomoyuki Sahara <[email protected]> | 2017-11-02 15:44:05 +0900 |
| commit | f6896751b454451fe05636d9d8b4f80eb191fd9c (patch) | |
| tree | 96b1da4b8aebacfbb08383e79c73c655c5221f1c | |
| parent | ddfb24908c701b742edbad171da395e16c8cda1a (diff) | |
| download | mruby-f6896751b454451fe05636d9d8b4f80eb191fd9c.tar.gz mruby-f6896751b454451fe05636d9d8b4f80eb191fd9c.zip | |
don't overwrite backtrace info.
| -rw-r--r-- | src/backtrace.c | 7 | ||||
| -rw-r--r-- | src/error.c | 1 |
2 files changed, 6 insertions, 2 deletions
diff --git a/src/backtrace.c b/src/backtrace.c index 232d1c2f4..ddeb2a3ca 100644 --- a/src/backtrace.c +++ b/src/backtrace.c @@ -215,11 +215,14 @@ packed_backtrace(mrb_state *mrb) void mrb_keep_backtrace(mrb_state *mrb, mrb_value exc) { + mrb_sym sym = mrb_intern_lit(mrb, "backtrace"); mrb_value backtrace; - int ai = mrb_gc_arena_save(mrb); + int ai; + if (mrb_iv_defined(mrb, exc, sym)) return; + ai = mrb_gc_arena_save(mrb); backtrace = packed_backtrace(mrb); - mrb_iv_set(mrb, exc, mrb_intern_lit(mrb, "backtrace"), backtrace); + mrb_iv_set(mrb, exc, sym, backtrace); mrb_gc_arena_restore(mrb, ai); } diff --git a/src/error.c b/src/error.c index fd4182eb2..a9b6db07a 100644 --- a/src/error.c +++ b/src/error.c @@ -200,6 +200,7 @@ exc_debug_info(mrb_state *mrb, struct RObject *exc) mrb_callinfo *ci = mrb->c->ci; mrb_code *pc = ci->pc; + if (mrb_obj_iv_defined(mrb, exc, mrb_intern_lit(mrb, "file"))) return; while (ci >= mrb->c->cibase) { mrb_code *err = ci->err; |
