From c18bcf3d8db61fd704b229da77fb3ecc190fa742 Mon Sep 17 00:00:00 2001 From: Diva Canto Date: Fri, 7 Jan 2011 10:25:49 -0800 Subject: A bit more frugal on the caller side of closing agents, now that the receiving end is async. No need for so much concurrency. --- .../Framework/Scenes/SceneCommunicationService.cs | 36 ++++++++++++---------- 1 file changed, 20 insertions(+), 16 deletions(-) (limited to 'OpenSim/Region') diff --git a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs index 69ebe9e..f8ff308 100644 --- a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs +++ b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs @@ -258,13 +258,17 @@ namespace OpenSim.Region.Framework.Scenes } - public delegate void SendCloseChildAgentDelegate(UUID agentID, ulong regionHandle); + //public delegate void SendCloseChildAgentDelegate(UUID agentID, ulong regionHandle); + //private void SendCloseChildAgentCompleted(IAsyncResult iar) + //{ + // SendCloseChildAgentDelegate icon = (SendCloseChildAgentDelegate)iar.AsyncState; + // icon.EndInvoke(iar); + //} /// - /// This Closes child agents on neighboring regions - /// Calls an asynchronous method to do so.. so it doesn't lag the sim. + /// Closes a child agent on a given region /// - protected void SendCloseChildAgentAsync(UUID agentID, ulong regionHandle) + protected void SendCloseChildAgent(UUID agentID, ulong regionHandle) { m_log.Debug("[INTERGRID]: Sending close agent to " + regionHandle); @@ -277,21 +281,21 @@ namespace OpenSim.Region.Framework.Scenes m_scene.SimulationService.CloseAgent(destination, agentID); } - private void SendCloseChildAgentCompleted(IAsyncResult iar) - { - SendCloseChildAgentDelegate icon = (SendCloseChildAgentDelegate)iar.AsyncState; - icon.EndInvoke(iar); - } - + /// + /// Closes a child agents in a collection of regions. Does so asynchronously + /// so that the caller doesn't wait. + /// + /// + /// public void SendCloseChildAgentConnections(UUID agentID, List regionslst) { - foreach (ulong handle in regionslst) + Util.FireAndForget(delegate { - SendCloseChildAgentDelegate d = SendCloseChildAgentAsync; - d.BeginInvoke(agentID, handle, - SendCloseChildAgentCompleted, - d); - } + foreach (ulong handle in regionslst) + { + SendCloseChildAgent(agentID, handle); + } + }); } public List RequestNamedRegions(string name, int maxNumber) -- cgit v1.1