From 97d320d7d122a5720770c77f91793ace1229a5ab Mon Sep 17 00:00:00 2001 From: Justin Clarke Casey Date: Tue, 4 Nov 2008 20:23:18 +0000 Subject: * Practise some defensive programming - gracefully terminate the thread if there is a problm in the world map module rather than bringing down the whole server. --- .../Modules/World/WorldMap/WorldMapModule.cs | 48 +++++++++++++--------- 1 file changed, 28 insertions(+), 20 deletions(-) (limited to 'OpenSim/Region/Environment/Modules') diff --git a/OpenSim/Region/Environment/Modules/World/WorldMap/WorldMapModule.cs b/OpenSim/Region/Environment/Modules/World/WorldMap/WorldMapModule.cs index b6c36f8..b277626 100644 --- a/OpenSim/Region/Environment/Modules/World/WorldMap/WorldMapModule.cs +++ b/OpenSim/Region/Environment/Modules/World/WorldMap/WorldMapModule.cs @@ -390,32 +390,40 @@ namespace OpenSim.Region.Environment.Modules.World.WorldMap /// public void process() { - while (true) + try { - MapRequestState st = requests.Dequeue(); - - // end gracefully - if (st.agentID == UUID.Zero) - { - ThreadTracker.Remove(mapItemReqThread); - break; - } - - bool dorequest = true; - lock (m_rootAgents) + while (true) { - if (!m_rootAgents.Contains(st.agentID)) - dorequest = false; - } + MapRequestState st = requests.Dequeue(); + + // end gracefully + if (st.agentID == UUID.Zero) + { + ThreadTracker.Remove(mapItemReqThread); + break; + } + + bool dorequest = true; + lock (m_rootAgents) + { + if (!m_rootAgents.Contains(st.agentID)) + dorequest = false; + } - if (dorequest) - { - LLSDMap response = RequestMapItemsAsync("", st.agentID, st.flags, st.EstateID, st.godlike, st.itemtype, st.regionhandle); - RequestMapItemsCompleted(response); + if (dorequest) + { + LLSDMap response = RequestMapItemsAsync("", st.agentID, st.flags, st.EstateID, st.godlike, st.itemtype, st.regionhandle); + RequestMapItemsCompleted(response); + } } } + catch (Exception e) + { + m_log.ErrorFormat("[WorldMap]: Map item request thread terminated abnormally with exception {0}", e); + } + threadrunning = false; - m_log.Warn("[WorldMap]: Remote request thread exiting"); + m_log.Debug("[WorldMap]: Remote request thread exiting"); } /// -- cgit v1.1