From f19b3d28bd9a467f1da7fef51fe86b9da223462c Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Tue, 26 Jul 2016 22:09:06 +0100 Subject: do GridUserService.SetLastPosition async on crossings --- .../GridUser/ActivityDetector.cs | 33 +++++++++++++++------- 1 file changed, 23 insertions(+), 10 deletions(-) (limited to 'OpenSim/Region') diff --git a/OpenSim/Region/CoreModules/ServiceConnectorsOut/GridUser/ActivityDetector.cs b/OpenSim/Region/CoreModules/ServiceConnectorsOut/GridUser/ActivityDetector.cs index 2238c90..98ccc95 100644 --- a/OpenSim/Region/CoreModules/ServiceConnectorsOut/GridUser/ActivityDetector.cs +++ b/OpenSim/Region/CoreModules/ServiceConnectorsOut/GridUser/ActivityDetector.cs @@ -63,18 +63,31 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.GridUser scene.EventManager.OnNewClient -= OnNewClient; } - public void OnMakeRootAgent(ScenePresence sp) - { - if (sp.PresenceType != PresenceType.Npc) + public void OnMakeRootAgent(ScenePresence sp) + { + if (sp.isNPC) + return; + + if(sp.gotCrossUpdate) { - string userid; - //m_log.DebugFormat("[ACTIVITY DETECTOR]: Detected root presence {0} in {1}", userid, sp.Scene.RegionInfo.RegionName); - if (sp.Scene.UserManagementModule.GetUserUUI(sp.UUID, out userid)) + Util.FireAndForget(delegate { - /* we only setposition on known agents that have a valid lookup */ - m_GridUserService.SetLastPosition( - userid, UUID.Zero, sp.Scene.RegionInfo.RegionID, sp.AbsolutePosition, sp.Lookat); - } + DoOnMakeRootAgent(sp); + }, null, "ActivityDetector_MakeRoot"); + } + else + DoOnMakeRootAgent(sp); + } + + public void DoOnMakeRootAgent(ScenePresence sp) + { + string userid; + //m_log.DebugFormat("[ACTIVITY DETECTOR]: Detected root presence {0} in {1}", userid, sp.Scene.RegionInfo.RegionName); + if (sp.Scene.UserManagementModule.GetUserUUI(sp.UUID, out userid)) + { + /* we only setposition on known agents that have a valid lookup */ + m_GridUserService.SetLastPosition( + userid, UUID.Zero, sp.Scene.RegionInfo.RegionID, sp.AbsolutePosition, sp.Lookat); } } -- cgit v1.1