[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]