From: Yusuke Endoh Date: 2011-06-11T16:04:37+09:00 Subject: [ruby-dev:43727] [Ruby 1.9 - Bug #4443] odd evaluation order in a multiple assignment Issue #4443 has been updated by Yusuke Endoh. http://redmine.ruby-lang.org/issues/4440 に matz の返事があります。 > 優先順位は高くありませんが、直すべきだと思います。 > > とはいうものの、1.8のころからこうだったのですし、直すのが難しいのも確 > かなのですが。 確か redmine の更新直後で、インターフェイスの違いにハマってチケット登録に失敗してしまったのでした。 -- Yusuke Endoh ---------------------------------------- Bug #4443: odd evaluation order in a multiple assignment http://redmine.ruby-lang.org/issues/4443 Author: Yusuke Endoh Status: Assigned Priority: Normal Assignee: Yukihiro Matsumoto Category: Target version: 2.0 ruby -v: ruby 1.9.2p0 (2010-08-18 revision 29036) [i686-linux] =begin 遠藤です。core に投げてしまったようなので登録し直し。 Ruby は左から右に評価が進むと信じていたのですが、多重代入で裏切られました。 def foo p :foo [] end def bar p :bar end x, foo[0] = bar, 0 bar より foo が左にあるので、:foo 、:bar の順に出力されることを期待するのですが、なんと :bar 、:foo になります。 具体的に何が困るかというと、例えば obj, obj.foo = obj.foo, obj には swap を期待するわけですが、そうなりません。こういうコードは実際に、木の回転などを実装するときにしばしば書きたくなります。この挙動に気がついたのも splay tree を実装していたときでした。こんなの: t.left, t.left.right, t = t.left.right, t, t.left 1.9 系列で修正すべきとまでは思いませんが、2.0 で直る可能性はあるでしょうか。 IRC で話したら「それで普通」みたいな反応もありましたが、 foo[0] = bar はちゃんと :foo 、:bar の順に出ます。 -- Yusuke Endoh =end -- http://redmine.ruby-lang.org