diff --git a/ChangeLog b/ChangeLog index 28b386a95e..64cdcdfa79 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +Mon Apr 21 11:00:27 2008 Yukihiro Matsumoto + + * compile.c (defined_expr): capture exception during defined? + evaluation. a patch from wanabe in + [ruby-dev:34461]. [ruby-core:16010] + Mon Apr 21 10:06:26 2008 Yukihiro Matsumoto * time.c: should include to refer errno. diff --git a/compile.c b/compile.c index dc26a4c1cf..c4cbf837e1 100644 --- a/compile.c +++ b/compile.c @@ -2421,10 +2421,21 @@ defined_expr(rb_iseq_t *iseq, LINK_ANCHOR *ret, ADD_INSNL(ret, nd_line(node), branchunless, lfinish[1]); } if (!self) { + LABEL *lstart = NEW_LABEL(nd_line(node)); + LABEL *lend = NEW_LABEL(nd_line(node)); + VALUE rescue = NEW_CHILD_ISEQVAL(NEW_NIL(), + rb_str_concat(rb_str_new2 + ("defined guard in "), + iseq->name), + ISEQ_TYPE_DEFINED_GUARD); + defined_expr(iseq, ret, node->nd_recv, lfinish, Qfalse); ADD_INSNL(ret, nd_line(node), branchunless, lfinish[1]); + ADD_LABEL(ret, lstart); COMPILE(ret, "defined/recv", node->nd_recv); + ADD_LABEL(ret, lend); + ADD_CATCH_ENTRY(CATCH_TYPE_RESCUE, lstart, lend, rescue, lfinish[1]); ADD_INSN3(ret, nd_line(node), defined, INT2FIX(DEFINED_METHOD), ID2SYM(node->nd_mid), needstr); }