ruby-changes:11101
From: seki <ko1@a...>
Date: Mon, 2 Mar 2009 01:01:26 +0900 (JST)
Subject: [ruby-changes:11101] Ruby:r22699 (trunk): merged a patch from Alessandro Di Maria in .
seki 2009-03-02 00:57:33 +0900 (Mon, 02 Mar 2009) New Revision: 22699 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=22699 Log: merged a patch from Alessandro Di Maria in [ruby-core:22560]. Modified files: trunk/ChangeLog trunk/lib/drb/observer.rb Index: ChangeLog =================================================================== --- ChangeLog (revision 22698) +++ ChangeLog (revision 22699) @@ -1,3 +1,9 @@ +Mon Mar 2 00:56:45 2009 Masatoshi SEKI <m_seki@m...> + + * lib/drb/observer.rb: The module oberservable uses now a hash to + store listeners. merged a patch from Alessandro Di Maria in + [ruby-core:22560]. + Sun Mar 1 22:59:41 2009 Tanaka Akira <akr@f...> * ext/socket/raddrinfo.c: suppress warnings. Index: lib/drb/observer.rb =================================================================== --- lib/drb/observer.rb (revision 22698) +++ lib/drb/observer.rb (revision 22699) @@ -6,16 +6,16 @@ def notify_observers(*arg) if defined? @observer_state and @observer_state - if defined? @observer_peers - for i in @observer_peers.dup - begin - i.update(*arg) - rescue - delete_observer(i) - end - end - end - @observer_state = false + if defined? @observer_peers + @observer_peers.each do |observer, method| + begin + observer.send(method, *arg) + rescue + delete_observer(observer) + end + end + end + @observer_state = false end end end -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/