mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
compile.c: side effect in splat
* compile.c (compile_array): splat which may have side effects should be compiled even if the result will be popped. [ruby-core:84340] [Bug #14201] From: Nobuyoshi Nakada <nobu@ruby-lang.org> git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@61329 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
494b3aeaea
commit
5c3f9641c0
2 changed files with 11 additions and 2 deletions
|
@ -3619,7 +3619,7 @@ compile_array(rb_iseq_t *iseq, LINK_ANCHOR *const ret, const NODE *const node_ro
|
|||
}
|
||||
}
|
||||
else {
|
||||
if (!popped) {
|
||||
if (!popped || kw) {
|
||||
switch (type) {
|
||||
case COMPILE_ARRAY_TYPE_ARRAY:
|
||||
ADD_INSN1(anchor, line, newarray, INT2FIX(i));
|
||||
|
@ -3660,6 +3660,9 @@ compile_array(rb_iseq_t *iseq, LINK_ANCHOR *const ret, const NODE *const node_ro
|
|||
APPEND_LIST(ret, anchor);
|
||||
break;
|
||||
}
|
||||
if (popped) {
|
||||
ADD_INSN(ret, line, pop);
|
||||
}
|
||||
}
|
||||
else {
|
||||
/* popped */
|
||||
|
@ -6268,7 +6271,7 @@ iseq_compile_each0(rb_iseq_t *iseq, LINK_ANCHOR *const ret, const NODE *node, in
|
|||
}
|
||||
case NODE_HASH:{
|
||||
DECL_ANCHOR(list);
|
||||
int type = node->nd_head ? nd_type(node->nd_head) : NODE_ZARRAY;
|
||||
enum node_type type = node->nd_head ? nd_type(node->nd_head) : NODE_ZARRAY;
|
||||
|
||||
INIT_ANCHOR(list);
|
||||
switch (type) {
|
||||
|
|
|
@ -702,4 +702,10 @@ class TestRubyOptimization < Test::Unit::TestCase
|
|||
}
|
||||
END
|
||||
end
|
||||
|
||||
def test_side_effect_in_popped_splat
|
||||
bug = '[ruby-core:84340] [Bug #14201]'
|
||||
eval("{**(bug = nil; {})};42")
|
||||
assert_nil(bug)
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue