ruby-changes:16938
From: yugui <ko1@a...>
Date: Mon, 9 Aug 2010 13:40:22 +0900 (JST)
Subject: [ruby-changes:16938] Ruby:r28934 (ruby_1_9_2): merges r28877 from trunk into ruby_1_9_2.
yugui 2010-08-09 13:40:07 +0900 (Mon, 09 Aug 2010) New Revision: 28934 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=28934 Log: merges r28877 from trunk into ruby_1_9_2. -- * compile.c (NODE_ARGSCAT, NODE_ARGSPUSH): drop unused ARGSCAT results when poped is true. [ruby-dev:41933], [Bug #3658] This is retry of r28870 and r28873 which were reverted. Modified files: branches/ruby_1_9_2/ChangeLog branches/ruby_1_9_2/compile.c branches/ruby_1_9_2/test/ruby/test_primitive.rb Index: ruby_1_9_2/ChangeLog =================================================================== --- ruby_1_9_2/ChangeLog (revision 28933) +++ ruby_1_9_2/ChangeLog (revision 28934) @@ -1,3 +1,9 @@ +Thu Aug 5 21:20:31 2010 Yusuke Endoh <mame@t...> + + * compile.c (NODE_ARGSCAT, NODE_ARGSPUSH): drop unused ARGSCAT + results when poped is true. [ruby-dev:41933], [Bug #3658] + This is retry of r28870 and r28873 which were reverted. + Thu Aug 5 16:57:20 2010 Nobuyoshi Nakada <nobu@r...> * dir.c (glob_make_pattern): fold continuous PLAINs to get rid of Index: ruby_1_9_2/compile.c =================================================================== --- ruby_1_9_2/compile.c (revision 28933) +++ ruby_1_9_2/compile.c (revision 28934) @@ -4525,16 +4525,34 @@ break; } case NODE_ARGSCAT:{ - COMPILE(ret, "argscat head", node->nd_head); - COMPILE(ret, "argscat body", node->nd_body); - ADD_INSN(ret, nd_line(node), concatarray); + if (poped) { + COMPILE(ret, "argscat head", node->nd_head); + ADD_INSN1(ret, nd_line(node), splatarray, Qfalse); + ADD_INSN(ret, nd_line(node), pop); + COMPILE(ret, "argscat body", node->nd_body); + ADD_INSN1(ret, nd_line(node), splatarray, Qfalse); + ADD_INSN(ret, nd_line(node), pop); + } + else { + COMPILE(ret, "argscat head", node->nd_head); + COMPILE(ret, "argscat body", node->nd_body); + ADD_INSN(ret, nd_line(node), concatarray); + } break; } case NODE_ARGSPUSH:{ - COMPILE(ret, "arsgpush head", node->nd_head); - COMPILE(ret, "argspush body", node->nd_body); - ADD_INSN1(ret, nd_line(node), newarray, INT2FIX(1)); - ADD_INSN(ret, nd_line(node), concatarray); + if (poped) { + COMPILE(ret, "arsgpush head", node->nd_head); + ADD_INSN1(ret, nd_line(node), splatarray, Qfalse); + ADD_INSN(ret, nd_line(node), pop); + COMPILE_(ret, "argspush body", node->nd_body, poped); + } + else { + COMPILE(ret, "arsgpush head", node->nd_head); + COMPILE_(ret, "argspush body", node->nd_body, poped); + ADD_INSN1(ret, nd_line(node), newarray, INT2FIX(1)); + ADD_INSN(ret, nd_line(node), concatarray); + } break; } case NODE_SPLAT:{ Index: ruby_1_9_2/test/ruby/test_primitive.rb =================================================================== --- ruby_1_9_2/test/ruby/test_primitive.rb (revision 28933) +++ ruby_1_9_2/test/ruby/test_primitive.rb (revision 28934) @@ -400,4 +400,24 @@ #assert_equal [0,1,2,3,4], [0, *a, 4] end + def test_concatarray_ruby_dev_41933 + bug3658 = '[ruby-dev:41933]' + [0, *x=1] + assert_equal(1, x, bug3658) + [0, *x=1, 2] + assert_equal(1, x, bug3658) + class << (x = Object.new) + attr_accessor :to_a_called + def to_a + @to_a_called = true + [self] + end + end + x.to_a_called = false + [0, *x] + assert(x.to_a_called, bug3658) + x.to_a_called = false + [0, *x, 2] + assert(x.to_a_called, bug3658) + end end -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/