From 0ff424bc3ca851ad4bbb71b7e552d24db60221f6 Mon Sep 17 00:00:00 2001 From: shyouhei Date: Tue, 22 May 2007 14:41:37 +0000 Subject: merge -c 12126 git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8_6@12309 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- eval.c | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) (limited to 'eval.c') diff --git a/eval.c b/eval.c index bc657c186..abec95861 100644 --- a/eval.c +++ b/eval.c @@ -1562,11 +1562,15 @@ ruby_cleanup(ex) int ex; { int state; - volatile VALUE err = ruby_errinfo; + VALUE err; + volatile VALUE errs[2]; + int nerr; + errs[0] = ruby_errinfo; ruby_safe_level = 0; Init_stack((void*)&state); ruby_finalize_0(); + errs[1] = ruby_errinfo; PUSH_TAG(PROT_NONE); PUSH_ITER(ITER_NOT); if ((state = EXEC_TAG()) == 0) { @@ -1577,15 +1581,15 @@ ruby_cleanup(ex) ex = state; } POP_ITER(); - ruby_errinfo = err; + ruby_errinfo = errs[0]; ex = error_handle(ex); ruby_finalize_1(); POP_TAG(); - if (err) { + for (nerr = sizeof(errs) / sizeof(errs[0]); nerr;) { + if (!(err = errs[--nerr])) continue; if (rb_obj_is_kind_of(err, rb_eSystemExit)) { - VALUE st = rb_iv_get(err, "status"); - return NUM2INT(st); + return sysexit_status(err); } else if (rb_obj_is_kind_of(err, rb_eSignal)) { VALUE sig = rb_iv_get(err, "signo"); -- cgit