ruby-changes:49270
From: ko1 <ko1@a...>
Date: Thu, 21 Dec 2017 17:30:01 +0900 (JST)
Subject: [ruby-changes:49270] ko1:r61387 (trunk): revert r61371 for [Bug #14214]
ko1 2017-12-21 17:29:56 +0900 (Thu, 21 Dec 2017) New Revision: 61387 https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=61387 Log: revert r61371 for [Bug #14214] Reverted patch doesn't check overwritten value. Modified files: trunk/compile.c Index: compile.c =================================================================== --- compile.c (revision 61386) +++ compile.c (revision 61387) @@ -3367,21 +3367,6 @@ compile_flip_flop(rb_iseq_t *iseq, LINK_ https://github.com/ruby/ruby/blob/trunk/compile.c#L3367 } static int -local_block_param_p(rb_iseq_t *iseq, ID vid) -{ - int idx = iseq->body->local_iseq->body->local_table_size - get_local_var_idx(iseq, vid); - int level = get_lvar_level(iseq); - return iseq_local_block_param_p(iseq, idx, level); -} - -static void -compile_defined_yield(rb_iseq_t *iseq, LINK_ANCHOR *const ret, int line, VALUE needstr) -{ - ADD_INSN(ret, line, putnil); - ADD_INSN3(ret, line, defined, INT2FIX(DEFINED_YIELD), 0, needstr); -} - -static int compile_branch_condition(rb_iseq_t *iseq, LINK_ANCHOR *const ret, const NODE *cond, LABEL *then_label, LABEL *else_label) { @@ -3429,11 +3414,6 @@ compile_branch_condition(rb_iseq_t *iseq https://github.com/ruby/ruby/blob/trunk/compile.c#L3414 case NODE_DEFINED: CHECK(compile_defined_expr(iseq, ret, cond, Qfalse)); goto branch; - case NODE_LVAR: - if (local_block_param_p(iseq, cond->nd_vid)) { - compile_defined_yield(iseq, ret, nd_line(cond), Qfalse); - goto branch; - } default: CHECK(COMPILE(ret, "branch condition", cond)); branch: @@ -4170,7 +4150,9 @@ defined_expr0(rb_iseq_t *iseq, LINK_ANCH https://github.com/ruby/ruby/blob/trunk/compile.c#L4150 } case NODE_YIELD: - compile_defined_yield(iseq, ret, nd_line(node), needstr); + ADD_INSN(ret, nd_line(node), putnil); + ADD_INSN3(ret, nd_line(node), defined, INT2FIX(DEFINED_YIELD), 0, + needstr); return 1; case NODE_BACK_REF: -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/