From b9137e2deeb5d207c3f8d39596a666217a642b0e Mon Sep 17 00:00:00 2001
From: UbitUmarov
Date: Tue, 15 Sep 2015 22:30:39 +0100
Subject: avoid a null ref (that should not happen after last commit), also
reduce use of thread jobs, where one is good enought
---
.../Framework/Scenes/SceneCommunicationService.cs | 48 +++++++++++++---------
1 file changed, 28 insertions(+), 20 deletions(-)
diff --git a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs
index 28df1c1..3eefd3c 100644
--- a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs
@@ -66,7 +66,7 @@ namespace OpenSim.Region.Framework.Scenes
private void InformNeighborsThatRegionisUpCompleted(IAsyncResult iar)
{
- InformNeighbourThatRegionUpDelegate icon = (InformNeighbourThatRegionUpDelegate) iar.AsyncState;
+ InformNeighbourThatRegionUpDelegate icon = (InformNeighbourThatRegionUpDelegate)iar.AsyncState;
icon.EndInvoke(iar);
}
@@ -84,11 +84,11 @@ namespace OpenSim.Region.Framework.Scenes
if (neighbourService != null)
neighbour = neighbourService.HelloNeighbour(regionhandle, region);
else
- m_log.DebugFormat( "{0} neighbour service provided for region {0} to inform neigbhours of status", LogHeader, m_scene.Name);
+ m_log.DebugFormat("{0} neighbour service provided for region {0} to inform neigbhours of status", LogHeader, m_scene.Name);
if (neighbour != null)
{
- m_log.DebugFormat( "{0} Region {1} successfully informed neighbour {2} at {3}-{4} that it is up",
+ m_log.DebugFormat("{0} Region {1} successfully informed neighbour {2} at {3}-{4} that it is up",
LogHeader, m_scene.Name, neighbour.RegionName, Util.WorldToRegionLoc(x), Util.WorldToRegionLoc(y));
m_scene.EventManager.TriggerOnRegionUp(neighbour);
@@ -114,9 +114,9 @@ namespace OpenSim.Region.Framework.Scenes
{
OpenSim.Framework.RegionFlags? regionFlags = n.RegionFlags;
-// m_log.DebugFormat(
-// "{0}: Region flags for {1} as seen by {2} are {3}",
-// LogHeader, n.RegionName, m_scene.Name, regionFlags != null ? regionFlags.ToString() : "not present");
+ // m_log.DebugFormat(
+ // "{0}: Region flags for {1} as seen by {2} are {3}",
+ // LogHeader, n.RegionName, m_scene.Name, regionFlags != null ? regionFlags.ToString() : "not present");
// Robust services before 2015-01-14 do not return the regionFlags information. In this case, we could
// make a separate RegionFlags call but this would involve a network call for each neighbour.
@@ -132,7 +132,7 @@ namespace OpenSim.Region.Framework.Scenes
}
m_log.DebugFormat(
- "{0} Informing {1} neighbours that region {2} is up",
+ "{0} Informing {1} neighbours that region {2} is up",
LogHeader, onlineNeighbours.Count, m_scene.Name);
foreach (GridRegion n in onlineNeighbours)
@@ -168,15 +168,15 @@ namespace OpenSim.Region.Framework.Scenes
private void SendChildAgentDataUpdateCompleted(IAsyncResult iar)
{
- SendChildAgentDataUpdateDelegate icon = (SendChildAgentDataUpdateDelegate) iar.AsyncState;
+ SendChildAgentDataUpdateDelegate icon = (SendChildAgentDataUpdateDelegate)iar.AsyncState;
icon.EndInvoke(iar);
}
public void SendChildAgentDataUpdate(AgentPosition cAgentData, ScenePresence presence)
{
-// m_log.DebugFormat(
-// "[SCENE COMMUNICATION SERVICE]: Sending child agent position updates for {0} in {1}",
-// presence.Name, m_scene.Name);
+ // m_log.DebugFormat(
+ // "[SCENE COMMUNICATION SERVICE]: Sending child agent position updates for {0} in {1}",
+ // presence.Name, m_scene.Name);
// This assumes that we know what our neighbors are.
try
@@ -234,6 +234,13 @@ namespace OpenSim.Region.Framework.Scenes
GridRegion destination = m_scene.GridService.GetRegionByPosition(m_regionInfo.ScopeID, (int)x, (int)y);
+ if (destination == null)
+ {
+ m_log.DebugFormat(
+ "[SCENE COMMUNICATION SERVICE]: Sending close agent ID {0} FAIL, region with handle {1} not found", agentID, regionHandle);
+ return;
+ }
+
m_log.DebugFormat(
"[SCENE COMMUNICATION SERVICE]: Sending close agent ID {0} to {1}", agentID, destination.RegionName);
@@ -248,16 +255,17 @@ namespace OpenSim.Region.Framework.Scenes
///
public void SendCloseChildAgentConnections(UUID agentID, string auth_code, List regionslst)
{
- foreach (ulong handle in regionslst)
+ if (regionslst.Count == 0)
+ return;
+
+ // use a single thread job for all
+ Util.FireAndForget(o =>
{
- // We must take a copy here since handle acts like a reference when used in an iterator.
- // This leads to race conditions if directly passed to SendCloseChildAgent with more than one neighbour region.
- ulong handleCopy = handle;
- Util.FireAndForget(
- o => SendCloseChildAgent(agentID, handleCopy, auth_code),
- null,
- "SceneCommunicationService.SendCloseChildAgentConnections");
- }
+ foreach (ulong handle in regionslst)
+ {
+ SendCloseChildAgent(agentID, handle, auth_code);
+ }
+ }, null, "SceneCommunicationService.SendCloseChildAgentConnections");
}
public List RequestNamedRegions(string name, int maxNumber)
--
cgit v1.1