more changes to god level control. Not that this is work in progress, for now it still works mainly as with option implicit_gods = true. speed up some regions child updates, some cleanup
							parent
							
								
									f46d70ada5
								
							
						
					
					
						commit
						d761a20cce
					
				|  | @ -47,6 +47,12 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| { | { | ||||||
|     public class GodController |     public class GodController | ||||||
|     { |     { | ||||||
|  |         public enum ImplicitGodLevels : int | ||||||
|  |         { | ||||||
|  |             EstateManager = 210,    // estate manager implicit god level | ||||||
|  |             RegionOwner = 220       // region owner implicit god level should be >= than estate | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         ScenePresence m_scenePresence; |         ScenePresence m_scenePresence; | ||||||
|         Scene m_scene; |         Scene m_scene; | ||||||
|         protected bool m_allowGridGods; |         protected bool m_allowGridGods; | ||||||
|  | @ -56,14 +62,20 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         protected bool m_forceGodModeAlwaysOn; |         protected bool m_forceGodModeAlwaysOn; | ||||||
|         protected bool m_allowGodActionsWithoutGodMode; |         protected bool m_allowGodActionsWithoutGodMode; | ||||||
| 
 | 
 | ||||||
|         protected bool m_viewerUiIsGod = false; |  | ||||||
| 
 |  | ||||||
|         protected int m_userLevel = 0; |         protected int m_userLevel = 0; | ||||||
|  |         // the god level from local or grid user rights | ||||||
|  |         protected int m_rightsGodLevel = 0; | ||||||
|  |         // the level seen by viewers | ||||||
|  |         protected int m_godlevel = 0; | ||||||
|  |         // new level that can be fixed or equal to godlevel, acording to options | ||||||
|  |         protected int m_effectivegodlevel = 0; | ||||||
|  |         protected int m_lastLevelToViewer = 0; | ||||||
| 
 | 
 | ||||||
|         public GodController(Scene scene, ScenePresence sp) |         public GodController(Scene scene, ScenePresence sp, int userlevel) | ||||||
|         { |         { | ||||||
|             m_scene = scene; |             m_scene = scene; | ||||||
|             m_scenePresence = sp; |             m_scenePresence = sp; | ||||||
|  |             m_userLevel = userlevel; | ||||||
| 
 | 
 | ||||||
|             IConfigSource config = scene.Config; |             IConfigSource config = scene.Config; | ||||||
| 
 | 
 | ||||||
|  | @ -81,7 +93,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     Util.GetConfigVarFromSections<bool>(config, |                     Util.GetConfigVarFromSections<bool>(config, | ||||||
|                     "force_grid_gods_only", sections, false); |                     "force_grid_gods_only", sections, false); | ||||||
| 
 | 
 | ||||||
|             if(!m_forceGridGodsOnly) // damm redundant and error prone option |             if(!m_forceGridGodsOnly) | ||||||
|             { |             { | ||||||
|                 // The owner of a region is a god in his region only. |                 // The owner of a region is a god in his region only. | ||||||
|                 m_regionOwnerIsGod = |                 m_regionOwnerIsGod = | ||||||
|  | @ -95,7 +107,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|                 m_allowGridGods = true; // reduce user mistakes increased by this over complex options set |                 m_allowGridGods = true; // reduce potencial user mistakes | ||||||
|                   |                   | ||||||
|             // God mode should be turned on in the viewer whenever |             // God mode should be turned on in the viewer whenever | ||||||
|             // the user has god rights somewhere. They may choose |             // the user has god rights somewhere. They may choose | ||||||
|  | @ -110,76 +122,122 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             m_allowGodActionsWithoutGodMode = |             m_allowGodActionsWithoutGodMode = | ||||||
|                     Util.GetConfigVarFromSections<bool>(config, |                     Util.GetConfigVarFromSections<bool>(config, | ||||||
|                     "implicit_gods", sections, false); |                     "implicit_gods", sections, false); | ||||||
|  | 
 | ||||||
|  |             m_rightsGodLevel = CalcRightsGodLevel(); | ||||||
|  | 
 | ||||||
|  |             if(m_allowGodActionsWithoutGodMode) | ||||||
|  |             { | ||||||
|  |                 m_effectivegodlevel = m_rightsGodLevel; | ||||||
|  | 
 | ||||||
|  |                 m_forceGodModeAlwaysOn = false; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             else if(m_forceGodModeAlwaysOn) | ||||||
|  |             { | ||||||
|  |                 m_godlevel = m_rightsGodLevel; | ||||||
|  |                 m_effectivegodlevel = m_rightsGodLevel; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             m_scenePresence.isGod = (m_effectivegodlevel >= 200); | ||||||
|  |             m_scenePresence.isLegacyGod = (m_godlevel >= 200); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected int PotentialGodLevel() |         // calculates god level at sp creation from local and grid user god rights | ||||||
|  |         // for now this is assumed static until user leaves region. | ||||||
|  |         // later estate and gride level updates may update this | ||||||
|  |         protected int CalcRightsGodLevel() | ||||||
|         { |         { | ||||||
|             int godLevel = m_allowGridGods ? m_userLevel : 200; |             int level = 0; | ||||||
|             if ((!m_forceGridGodsOnly) && m_userLevel < 200) |             if (m_allowGridGods && m_userLevel >= 200) | ||||||
|                 godLevel = 200; |                 level = m_userLevel; | ||||||
| 
 | 
 | ||||||
|             return godLevel; |             if(m_forceGridGodsOnly || level >= (int)ImplicitGodLevels.RegionOwner) | ||||||
|  |                 return level; | ||||||
|  | 
 | ||||||
|  |             if (m_regionOwnerIsGod && m_scene.RegionInfo.EstateSettings.IsEstateOwner(m_scenePresence.UUID)) | ||||||
|  |                 level = (int)ImplicitGodLevels.RegionOwner; | ||||||
|  | 
 | ||||||
|  |             if(level >= (int)ImplicitGodLevels.EstateManager) | ||||||
|  |                 return level; | ||||||
|  | 
 | ||||||
|  |             if (m_regionManagerIsGod && m_scene.Permissions.IsEstateManager(m_scenePresence.UUID)) | ||||||
|  |                 level = (int)ImplicitGodLevels.EstateManager; | ||||||
|  | 
 | ||||||
|  |             return level; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected bool CanBeGod() |         protected bool CanBeGod() | ||||||
|         { |         { | ||||||
|             if (m_allowGridGods && m_userLevel > 0) |             return m_rightsGodLevel >= 200; | ||||||
|                 return true; |         } | ||||||
| 
 | 
 | ||||||
|             if(m_forceGridGodsOnly) |         protected void UpdateGodLevels(bool viewerState) | ||||||
|                 return false; |         { | ||||||
|  |             if(!CanBeGod()) | ||||||
|  |             { | ||||||
|  |                 m_godlevel = 0; | ||||||
|  |                 m_effectivegodlevel = 0; | ||||||
|  |                 m_scenePresence.isGod = false; | ||||||
|  |                 m_scenePresence.isLegacyGod = false; | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             if (m_regionOwnerIsGod && m_scene.RegionInfo.EstateSettings.IsEstateOwner(m_scenePresence.UUID)) |             // legacy some are controled by viewer, others are static | ||||||
|                 return true; |             if(m_allowGodActionsWithoutGodMode) | ||||||
|  |             { | ||||||
|  |                 if(viewerState) | ||||||
|  |                     m_godlevel = m_rightsGodLevel; | ||||||
|  |                 else | ||||||
|  |                     m_godlevel = 0; | ||||||
| 
 | 
 | ||||||
|             if (m_regionManagerIsGod && m_scene.Permissions.IsEstateManager(m_scenePresence.UUID)) |                 m_effectivegodlevel = m_rightsGodLevel; | ||||||
|                 return true; |             } | ||||||
| 
 |             else | ||||||
|             return false; |             { | ||||||
|  |                 // new all change with viewer | ||||||
|  |                 if(viewerState) | ||||||
|  |                 { | ||||||
|  |                     m_godlevel = m_rightsGodLevel; | ||||||
|  |                     m_effectivegodlevel = m_rightsGodLevel; | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     m_godlevel = 0; | ||||||
|  |                     m_effectivegodlevel = 0; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             m_scenePresence.isGod = (m_effectivegodlevel >= 200); | ||||||
|  |             m_scenePresence.isLegacyGod = (m_godlevel >= 200); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void SyncViewerState() |         public void SyncViewerState() | ||||||
|         { |         { | ||||||
|             bool canBeGod = CanBeGod(); |             if(m_lastLevelToViewer == m_godlevel) | ||||||
|  |                 return; | ||||||
| 
 | 
 | ||||||
|             bool shoudBeGod = m_forceGodModeAlwaysOn ? canBeGod : (m_viewerUiIsGod && canBeGod); |             m_lastLevelToViewer = m_godlevel; | ||||||
| 
 | 
 | ||||||
|             int godLevel = PotentialGodLevel(); |             if(m_scenePresence.IsChildAgent) | ||||||
|  |                 return;             | ||||||
| 
 | 
 | ||||||
|             if (!shoudBeGod) |             m_scenePresence.ControllingClient.SendAdminResponse(UUID.Zero, (uint)m_godlevel); | ||||||
|                 godLevel = 0; |  | ||||||
| 
 |  | ||||||
|             if (m_viewerUiIsGod != shoudBeGod && (!m_scenePresence.IsChildAgent)) |  | ||||||
|             { |  | ||||||
|                 m_scenePresence.ControllingClient.SendAdminResponse(UUID.Zero, (uint)godLevel); |  | ||||||
|                 m_viewerUiIsGod = shoudBeGod; |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public bool RequestGodMode(bool god) |         public void RequestGodMode(bool god) | ||||||
|         { |         { | ||||||
|             // this is used by viewer protocol |             UpdateGodLevels(god); | ||||||
|             // and they may want a answer | 
 | ||||||
|             if (!god) |             if(m_lastLevelToViewer != m_godlevel) | ||||||
|             { |             { | ||||||
|                 m_scenePresence.ControllingClient.SendAdminResponse(UUID.Zero, 0); |                 m_scenePresence.ControllingClient.SendAdminResponse(UUID.Zero, (uint)m_godlevel); | ||||||
|                 m_viewerUiIsGod = false; |                 m_lastLevelToViewer = m_godlevel; | ||||||
|                 return true; |  | ||||||
|             } |             } | ||||||
| 
 |  | ||||||
|             if (!CanBeGod()) |  | ||||||
|                 return false; |  | ||||||
| 
 |  | ||||||
|             int godLevel = PotentialGodLevel(); |  | ||||||
|             m_scenePresence.ControllingClient.SendAdminResponse(UUID.Zero, (uint)godLevel); |  | ||||||
|             m_viewerUiIsGod = true; |  | ||||||
|             return true; |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public OSD State() |        public OSD State() | ||||||
|         { |         { | ||||||
|             OSDMap godMap = new OSDMap(2); |             OSDMap godMap = new OSDMap(2); | ||||||
| 
 |             bool m_viewerUiIsGod = m_godlevel >= 200; | ||||||
|             godMap.Add("ViewerUiIsGod", OSD.FromBoolean(m_viewerUiIsGod)); |             godMap.Add("ViewerUiIsGod", OSD.FromBoolean(m_viewerUiIsGod)); | ||||||
| 
 | 
 | ||||||
|             return godMap; |             return godMap; | ||||||
|  | @ -187,13 +245,26 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         public void SetState(OSD state) |         public void SetState(OSD state) | ||||||
|         { |         { | ||||||
|             if(state == null) |             bool newstate = false; | ||||||
|                 return; |             if(m_forceGodModeAlwaysOn) | ||||||
|  |                 newstate = true; | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 if(state != null) | ||||||
|  |                 { | ||||||
|  |                     OSDMap s = (OSDMap)state; | ||||||
| 
 | 
 | ||||||
|             OSDMap s = (OSDMap)state; |                     if (s.ContainsKey("ViewerUiIsGod")) | ||||||
|  |                         newstate = s["ViewerUiIsGod"].AsBoolean(); | ||||||
|  |                     m_lastLevelToViewer = m_godlevel; // we are not changing viewer level by default | ||||||
|  |                 } | ||||||
|  |             }        | ||||||
|  |             UpdateGodLevels(newstate); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|             if (s.ContainsKey("ViewerUiIsGod")) |         public void HasMovedAway() | ||||||
|                 m_viewerUiIsGod = s["ViewerUiIsGod"].AsBoolean(); |         { | ||||||
|  |             m_lastLevelToViewer = 0; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public int UserLevel |         public int UserLevel | ||||||
|  | @ -204,29 +275,12 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         public int GodLevel |         public int GodLevel | ||||||
|         { |         { | ||||||
|             get |             get { return m_godlevel; } | ||||||
|             { |  | ||||||
|                 int godLevel = PotentialGodLevel(); |  | ||||||
|                 if (!m_viewerUiIsGod) |  | ||||||
|                     godLevel = 0; |  | ||||||
| 
 |  | ||||||
|                 return godLevel; |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public int EffectiveLevel |         public int EffectiveLevel | ||||||
|         { |         { | ||||||
|             get |             get { return m_effectivegodlevel; } | ||||||
|             { |  | ||||||
|                 int godLevel = PotentialGodLevel(); |  | ||||||
|                 if (m_viewerUiIsGod) |  | ||||||
|                     return godLevel; |  | ||||||
| 
 |  | ||||||
|                 if (m_allowGodActionsWithoutGodMode && CanBeGod()) |  | ||||||
|                     return godLevel; |  | ||||||
| 
 |  | ||||||
|                 return 0; |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -92,6 +92,14 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         public bool isNPC { get; private set; } |         public bool isNPC { get; private set; } | ||||||
| 
 | 
 | ||||||
|  |         // simple yes or no isGOD from god level >= 200 | ||||||
|  |         // should only be set by GodController | ||||||
|  |         // we have two to suport legacy behaviour | ||||||
|  |         // isLegacyGod was controlled by viewer in older versions | ||||||
|  |         // isGod may now be also controled by viewer acording to options | ||||||
|  |         public bool isLegacyGod { get; set; } | ||||||
|  |         public bool isGod { get; set; } | ||||||
|  | 
 | ||||||
|         private PresenceType m_presenceType; |         private PresenceType m_presenceType; | ||||||
|         public PresenceType PresenceType { |         public PresenceType PresenceType { | ||||||
|             get {return m_presenceType;} |             get {return m_presenceType;} | ||||||
|  | @ -155,7 +163,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         public static readonly float MOVEMENT = .25f; |         public static readonly float MOVEMENT = .25f; | ||||||
|         public static readonly float SIGNIFICANT_MOVEMENT = 16.0f; |         public static readonly float SIGNIFICANT_MOVEMENT = 16.0f; | ||||||
|         public static readonly float CHILDUPDATES_MOVEMENT = 100.0f; |         public static readonly float CHILDUPDATES_MOVEMENT = 100.0f; | ||||||
|         public static readonly float CHILDUPDATES_TIME = 10000f; // min time between child updates (ms) |         public static readonly float CHILDUPDATES_TIME = 2000f; // min time between child updates (ms) | ||||||
| 
 | 
 | ||||||
|         private UUID m_previusParcelUUID = UUID.Zero; |         private UUID m_previusParcelUUID = UUID.Zero; | ||||||
|         private UUID m_currentParcelUUID = UUID.Zero; |         private UUID m_currentParcelUUID = UUID.Zero; | ||||||
|  | @ -186,7 +194,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                         m_currentParcelHide = true; |                         m_currentParcelHide = true; | ||||||
| 
 | 
 | ||||||
|                     if (m_previusParcelUUID != UUID.Zero || checksame) |                     if (m_previusParcelUUID != UUID.Zero || checksame) | ||||||
|                         ParcelCrossCheck(m_currentParcelUUID,m_previusParcelUUID,m_currentParcelHide, m_previusParcelHide, oldhide,checksame); |                         ParcelCrossCheck(m_currentParcelUUID, m_previusParcelUUID, m_currentParcelHide, m_previusParcelHide, oldhide,checksame); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -267,8 +275,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         private ScriptControlled IgnoredControls = ScriptControlled.CONTROL_ZERO; |         private ScriptControlled IgnoredControls = ScriptControlled.CONTROL_ZERO; | ||||||
|         private ScriptControlled LastCommands = ScriptControlled.CONTROL_ZERO; |         private ScriptControlled LastCommands = ScriptControlled.CONTROL_ZERO; | ||||||
|         private bool MouseDown = false; |         private bool MouseDown = false; | ||||||
| //        private SceneObjectGroup proxyObjectGroup; |  | ||||||
|         //private SceneObjectPart proxyObjectPart = null; |  | ||||||
|         public Vector3 lastKnownAllowedPosition; |         public Vector3 lastKnownAllowedPosition; | ||||||
|         public bool sentMessageAboutRestrictedParcelFlyingDown; |         public bool sentMessageAboutRestrictedParcelFlyingDown; | ||||||
|         public Vector4 CollisionPlane = Vector4.UnitW; |         public Vector4 CollisionPlane = Vector4.UnitW; | ||||||
|  | @ -281,9 +287,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         private bool m_followCamAuto = false; |         private bool m_followCamAuto = false; | ||||||
| 
 | 
 | ||||||
| //        private object m_forceToApplyLock = new object(); |  | ||||||
| //        private bool m_forceToApplyValid; |  | ||||||
| //        private Vector3 m_forceToApply; |  | ||||||
|         private int m_userFlags; |         private int m_userFlags; | ||||||
|         public int UserFlags |         public int UserFlags | ||||||
|         { |         { | ||||||
|  | @ -304,9 +307,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             set { PhysicsActor.IsColliding = value; } |             set { PhysicsActor.IsColliding = value; } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| //        private int m_lastColCount = -1;		//KF: Look for Collision chnages |  | ||||||
| //        private int m_updateCount = 0;			//KF: Update Anims for a while |  | ||||||
| //        private static readonly int UPDATE_COUNT = 10;		// how many frames to update for |  | ||||||
|         private List<uint> m_lastColliders = new List<uint>(); |         private List<uint> m_lastColliders = new List<uint>(); | ||||||
| 
 | 
 | ||||||
|         private TeleportFlags m_teleportFlags; |         private TeleportFlags m_teleportFlags; | ||||||
|  | @ -332,8 +332,10 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         private float m_sitAvatarHeight = 2.0f; |         private float m_sitAvatarHeight = 2.0f; | ||||||
| 
 | 
 | ||||||
|         private bool childUpdatesBusy = false; |         private bool m_childUpdatesBusy = false; | ||||||
|         private int lastChildUpdatesTime; |         private int m_lastChildUpdatesTime; | ||||||
|  |         private int m_lastChildAgentUpdateGodLevel; | ||||||
|  |         private float m_lastChildAgentUpdateDrawDistance; | ||||||
|         private Vector3 m_lastChildAgentUpdatePosition; |         private Vector3 m_lastChildAgentUpdatePosition; | ||||||
| //        private Vector3 m_lastChildAgentUpdateCamPosition; | //        private Vector3 m_lastChildAgentUpdateCamPosition; | ||||||
| 
 | 
 | ||||||
|  | @ -348,8 +350,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         private float m_healRate = 1f; |         private float m_healRate = 1f; | ||||||
|         private float m_healRatePerFrame = 0.05f; |         private float m_healRatePerFrame = 0.05f; | ||||||
| 
 | 
 | ||||||
| //        protected ulong crossingFromRegion; |  | ||||||
| 
 |  | ||||||
|         private readonly Vector3[] Dir_Vectors = new Vector3[12]; |         private readonly Vector3[] Dir_Vectors = new Vector3[12]; | ||||||
| 
 | 
 | ||||||
|         protected int  m_reprioritizationLastTime; |         protected int  m_reprioritizationLastTime; | ||||||
|  | @ -372,10 +372,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         private const int NumMovementsBetweenRayCast = 5; |         private const int NumMovementsBetweenRayCast = 5; | ||||||
| 
 | 
 | ||||||
|         private bool CameraConstraintActive; |         private bool CameraConstraintActive; | ||||||
|         //private int m_moveToPositionStateStatus; |  | ||||||
|         //***************************************************** |  | ||||||
| 
 | 
 | ||||||
|         //private bool m_collisionEventFlag = false; |  | ||||||
|         private object m_collisionEventLock = new Object(); |         private object m_collisionEventLock = new Object(); | ||||||
| 
 | 
 | ||||||
|         private int m_movementAnimationUpdateCounter = 0; |         private int m_movementAnimationUpdateCounter = 0; | ||||||
|  | @ -529,7 +526,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         private bool m_doingCamRayCast = false; |         private bool m_doingCamRayCast = false; | ||||||
| 
 | 
 | ||||||
|         public Vector3 CameraPosition { get; set; } |         public Vector3 CameraPosition { get; set; } | ||||||
| 
 |  | ||||||
|         public Quaternion CameraRotation { get; private set; } |         public Quaternion CameraRotation { get; private set; } | ||||||
| 
 | 
 | ||||||
|         // Use these three vectors to figure out what the agent is looking at |         // Use these three vectors to figure out what the agent is looking at | ||||||
|  | @ -589,7 +585,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         public bool AllowMovement { get; set; } |         public bool AllowMovement { get; set; } | ||||||
| 
 | 
 | ||||||
|         private bool m_setAlwaysRun; |         private bool m_setAlwaysRun; | ||||||
| 
 |  | ||||||
|         public bool SetAlwaysRun |         public bool SetAlwaysRun | ||||||
|         { |         { | ||||||
|             get |             get | ||||||
|  | @ -613,7 +608,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         public byte State { get; set; } |         public byte State { get; set; } | ||||||
| 
 | 
 | ||||||
|         private AgentManager.ControlFlags m_AgentControlFlags; |         private AgentManager.ControlFlags m_AgentControlFlags; | ||||||
|  | @ -935,27 +929,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 seeds = Scene.CapsModule.GetChildrenSeeds(UUID); |                 seeds = Scene.CapsModule.GetChildrenSeeds(UUID); | ||||||
|             else |             else | ||||||
|                 seeds = new Dictionary<ulong, string>(); |                 seeds = new Dictionary<ulong, string>(); | ||||||
| 
 |  | ||||||
| /* we can't do this anymore |  | ||||||
|             List<ulong> old = new List<ulong>(); |  | ||||||
|             foreach (ulong handle in seeds.Keys) |  | ||||||
|             { |  | ||||||
|                 uint x, y; |  | ||||||
|                 Util.RegionHandleToRegionLoc(handle, out x, out y); |  | ||||||
| //                if (Util.IsOutsideView(DrawDistance, x, Scene.RegionInfo.RegionLocX, y, Scene.RegionInfo.RegionLocY,)) |  | ||||||
|                 { |  | ||||||
|                     old.Add(handle); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             DropOldNeighbours(old); |  | ||||||
| 
 |  | ||||||
|             if (Scene.CapsModule != null) |  | ||||||
|                 Scene.CapsModule.SetChildrenSeed(UUID, seeds); |  | ||||||
| */ |  | ||||||
|             KnownRegions = seeds; |             KnownRegions = seeds; | ||||||
|             //m_log.Debug(" ++++++++++AFTER+++++++++++++ "); |  | ||||||
|             //DumpKnownRegions(); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void DumpKnownRegions() |         public void DumpKnownRegions() | ||||||
|  | @ -1045,7 +1019,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         public ScenePresence( |         public ScenePresence( | ||||||
|             IClientAPI client, Scene world, AvatarAppearance appearance, PresenceType type) |             IClientAPI client, Scene world, AvatarAppearance appearance, PresenceType type) | ||||||
|         { |         { | ||||||
| 
 |  | ||||||
|             m_scene = world; |             m_scene = world; | ||||||
|             AttachmentsSyncLock = new Object(); |             AttachmentsSyncLock = new Object(); | ||||||
|             AllowMovement = true; |             AllowMovement = true; | ||||||
|  | @ -1075,9 +1048,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (account != null) |             if (account != null) | ||||||
|                 userlevel = account.UserLevel; |                 userlevel = account.UserLevel; | ||||||
| 
 | 
 | ||||||
| //            GodController = new GodController(world, this, userlevel); |             GodController = new GodController(world, this, userlevel); | ||||||
|             GodController = new GodController(world, this); |  | ||||||
|             GodController.UserLevel = userlevel; |  | ||||||
| 
 | 
 | ||||||
|  //           IGroupsModule gm = m_scene.RequestModuleInterface<IGroupsModule>(); |  //           IGroupsModule gm = m_scene.RequestModuleInterface<IGroupsModule>(); | ||||||
|  //           if (gm != null) |  //           if (gm != null) | ||||||
|  | @ -1091,7 +1062,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             m_reprioritizationLastDrawDistance = DrawDistance; |             m_reprioritizationLastDrawDistance = DrawDistance; | ||||||
| 
 | 
 | ||||||
|             // disable updates workjobs for now |             // disable updates workjobs for now | ||||||
|             childUpdatesBusy = true; |             m_childUpdatesBusy = true; | ||||||
|             m_reprioritizationBusy = true; |             m_reprioritizationBusy = true; | ||||||
| 
 | 
 | ||||||
|             AdjustKnownSeeds(); |             AdjustKnownSeeds(); | ||||||
|  | @ -1293,8 +1264,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     IsLoggingIn = false; |                     IsLoggingIn = false; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 IsChildAgent = false; |                 IsChildAgent = false;                | ||||||
|                  |  | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             m_log.DebugFormat("[MakeRootAgent] out lock: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |             m_log.DebugFormat("[MakeRootAgent] out lock: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
|  | @ -1304,7 +1274,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             // Should not be needed if we are not trying to tell this region to close |             // Should not be needed if we are not trying to tell this region to close | ||||||
|             //            DoNotCloseAfterTeleport = false; |             //            DoNotCloseAfterTeleport = false; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             RegionHandle = m_scene.RegionInfo.RegionHandle; |             RegionHandle = m_scene.RegionInfo.RegionHandle; | ||||||
| 
 | 
 | ||||||
|             m_scene.EventManager.TriggerSetRootAgentScene(m_uuid, m_scene); |             m_scene.EventManager.TriggerSetRootAgentScene(m_uuid, m_scene); | ||||||
|  | @ -1447,7 +1416,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             m_log.DebugFormat("[MakeRootAgent] position and physical: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |             m_log.DebugFormat("[MakeRootAgent] position and physical: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
|             m_scene.SwapRootAgentCount(false); |             m_scene.SwapRootAgentCount(false); | ||||||
| 
 | 
 | ||||||
|  | @ -1782,17 +1750,14 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|             if (m_AngularVelocity.Z > 0) |             if (m_AngularVelocity.Z > 0) | ||||||
|             { |             { | ||||||
| 
 |  | ||||||
|                 float leftOverToMin = m_AngularVelocity.Z - rollMinRadians; |                 float leftOverToMin = m_AngularVelocity.Z - rollMinRadians; | ||||||
|                 if (amount > leftOverToMin) |                 if (amount > leftOverToMin) | ||||||
|                     return -leftOverToMin; |                     return -leftOverToMin; | ||||||
|                 else |                 else | ||||||
|                     return -amount; |                     return -amount; | ||||||
| 
 |  | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
| 
 |  | ||||||
|                 float leftOverToMin = -m_AngularVelocity.Z - rollMinRadians; |                 float leftOverToMin = -m_AngularVelocity.Z - rollMinRadians; | ||||||
|                 if (amount > leftOverToMin) |                 if (amount > leftOverToMin) | ||||||
|                     return leftOverToMin; |                     return leftOverToMin; | ||||||
|  | @ -1801,8 +1766,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         // neighbouring regions we have enabled a child agent in |         // neighbouring regions we have enabled a child agent in | ||||||
|         // holds the seed cap for the child agent in that region |         // holds the seed cap for the child agent in that region | ||||||
|         private Dictionary<ulong, string> m_knownChildRegions = new Dictionary<ulong, string>(); |         private Dictionary<ulong, string> m_knownChildRegions = new Dictionary<ulong, string>(); | ||||||
|  | @ -1815,7 +1778,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         private Dictionary<ulong, spRegionSizeInfo> m_knownChildRegionsSizeInfo = new Dictionary<ulong, spRegionSizeInfo>(); |         private Dictionary<ulong, spRegionSizeInfo> m_knownChildRegionsSizeInfo = new Dictionary<ulong, spRegionSizeInfo>(); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         public void AddNeighbourRegionSizeInfo(GridRegion region) |         public void AddNeighbourRegionSizeInfo(GridRegion region) | ||||||
|         { |         { | ||||||
|             lock (m_knownChildRegions) |             lock (m_knownChildRegions) | ||||||
|  | @ -1946,7 +1908,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             lock (m_originRegionIDAccessLock) |             lock (m_originRegionIDAccessLock) | ||||||
|                 originID = m_originRegionID; |                 originID = m_originRegionID; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             while (originID.Equals(UUID.Zero) && count-- > 0) |             while (originID.Equals(UUID.Zero) && count-- > 0) | ||||||
|             { |             { | ||||||
|                 lock (m_originRegionIDAccessLock) |                 lock (m_originRegionIDAccessLock) | ||||||
|  | @ -2020,8 +1981,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     if (!WaitForUpdateAgent(client)) |                     if (!WaitForUpdateAgent(client)) | ||||||
|                         // The sending region never sent the UpdateAgent data, we have to refuse |                         // The sending region never sent the UpdateAgent data, we have to refuse | ||||||
|                         return; |                         return; | ||||||
| 
 |  | ||||||
|                     GodController.SyncViewerState(); |  | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 m_log.DebugFormat("[CompleteMovement] WaitForUpdateAgent: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |                 m_log.DebugFormat("[CompleteMovement] WaitForUpdateAgent: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
|  | @ -2070,13 +2029,11 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     m_log.DebugFormat("[CompleteMovement]: Missing COF for {0} is {1}", client.AgentId, COF); |                     m_log.DebugFormat("[CompleteMovement]: Missing COF for {0} is {1}", client.AgentId, COF); | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|                 // Tell the client that we're totally ready |                 // Tell the client that we're totally ready | ||||||
|                 ControllingClient.MoveAgentIntoRegion(m_scene.RegionInfo, AbsolutePosition, look); |                 ControllingClient.MoveAgentIntoRegion(m_scene.RegionInfo, AbsolutePosition, look); | ||||||
| 
 | 
 | ||||||
|                 m_log.DebugFormat("[CompleteMovement] MoveAgentIntoRegion: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |                 m_log.DebugFormat("[CompleteMovement] MoveAgentIntoRegion: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|                 if (!string.IsNullOrEmpty(m_callbackURI)) |                 if (!string.IsNullOrEmpty(m_callbackURI)) | ||||||
|                 { |                 { | ||||||
|                     // We cannot sleep here since this would hold up the inbound packet processing thread, as |                     // We cannot sleep here since this would hold up the inbound packet processing thread, as | ||||||
|  | @ -2105,7 +2062,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| //                    client.Name, client.AgentId, m_scene.RegionInfo.RegionName); | //                    client.Name, client.AgentId, m_scene.RegionInfo.RegionName); | ||||||
| //            } | //            } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|                 m_log.DebugFormat("[CompleteMovement] ReleaseAgent: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |                 m_log.DebugFormat("[CompleteMovement] ReleaseAgent: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
| 
 | 
 | ||||||
|                 if(m_teleportFlags > 0) |                 if(m_teleportFlags > 0) | ||||||
|  | @ -2125,18 +2081,19 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     m_log.DebugFormat("[CompleteMovement] HG"); |                     m_log.DebugFormat("[CompleteMovement] HG"); | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 if(!IsChildAgent && !isNPC) |  | ||||||
|                     GodController.SyncViewerState(); |  | ||||||
|                      |  | ||||||
| // start sending terrain patchs |  | ||||||
|                 if (!gotCrossUpdate && !isNPC) |  | ||||||
|                     Scene.SendLayerData(ControllingClient); |  | ||||||
| 
 |  | ||||||
|                 m_previusParcelHide = false; |                 m_previusParcelHide = false; | ||||||
|                 m_previusParcelUUID = UUID.Zero; |                 m_previusParcelUUID = UUID.Zero; | ||||||
|                 m_currentParcelHide = false; |                 m_currentParcelHide = false; | ||||||
|                 m_currentParcelUUID = UUID.Zero; |                 m_currentParcelUUID = UUID.Zero; | ||||||
| 
 | 
 | ||||||
|  |                 if(!isNPC) | ||||||
|  |                 { | ||||||
|  |                     GodController.SyncViewerState(); | ||||||
|  |                      | ||||||
|  |                     // start sending terrain patchs | ||||||
|  |                     if (!gotCrossUpdate) | ||||||
|  |                         Scene.SendLayerData(ControllingClient); | ||||||
|  |                 } | ||||||
|                 // send initial land overlay and parcel |                 // send initial land overlay and parcel | ||||||
|                 ILandChannel landch = m_scene.LandChannel; |                 ILandChannel landch = m_scene.LandChannel; | ||||||
|                 if (landch != null) |                 if (landch != null) | ||||||
|  | @ -2185,7 +2142,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     if (haveAnims) |                     if (haveAnims) | ||||||
|                         SendAnimPackToAgent(this, animIDs, animseqs, animsobjs); |                         SendAnimPackToAgent(this, animIDs, animseqs, animsobjs); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|                     // we should be able to receive updates, etc |                     // we should be able to receive updates, etc | ||||||
|                     // so release them |                     // so release them | ||||||
|                     m_inTransit = false; |                     m_inTransit = false; | ||||||
|  | @ -2200,7 +2156,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                             if (p == this) |                             if (p == this) | ||||||
|                                 continue; |                                 continue; | ||||||
| 
 | 
 | ||||||
|                             if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                             if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                                 continue; |                                 continue; | ||||||
| 
 | 
 | ||||||
|                             SendAppearanceToAgentNF(p); |                             SendAppearanceToAgentNF(p); | ||||||
|  | @ -2250,7 +2206,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                                     continue; |                                     continue; | ||||||
|                                 } |                                 } | ||||||
| 
 | 
 | ||||||
|                                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                                     continue; |                                     continue; | ||||||
| 
 | 
 | ||||||
|                                 SendAttachmentsToAgentNF(p); |                                 SendAttachmentsToAgentNF(p); | ||||||
|  | @ -2267,10 +2223,13 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                         { |                         { | ||||||
|                             m_agentTransfer.EnableChildAgents(this); |                             m_agentTransfer.EnableChildAgents(this); | ||||||
|                         } |                         } | ||||||
|                         // let updates be sent,  with some delay |  | ||||||
|                         lastChildUpdatesTime = Util.EnvironmentTickCount() + 10000; |  | ||||||
|                         childUpdatesBusy = false; // allow them |  | ||||||
|                     } |                     } | ||||||
|  |                     // let updates be sent,  with some delay | ||||||
|  |                     m_lastChildUpdatesTime = Util.EnvironmentTickCount() + 10000; | ||||||
|  |                     m_lastChildAgentUpdateGodLevel = GodController.GodLevel; | ||||||
|  |                     m_lastChildAgentUpdateDrawDistance = DrawDistance; | ||||||
|  |                     m_lastChildAgentUpdatePosition = AbsolutePosition; | ||||||
|  |                     m_childUpdatesBusy = false; // allow them | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 m_log.DebugFormat("[CompleteMovement] openChildAgents: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |                 m_log.DebugFormat("[CompleteMovement] openChildAgents: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
|  | @ -2300,7 +2259,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     m_log.DebugFormat("[CompleteMovement] friendsModule: {0}ms",    Util.EnvironmentTickCountSubtract(ts)); |                     m_log.DebugFormat("[CompleteMovement] friendsModule: {0}ms",    Util.EnvironmentTickCountSubtract(ts)); | ||||||
| 
 | 
 | ||||||
|                 } |                 } | ||||||
| 
 |  | ||||||
|             } |             } | ||||||
|             finally |             finally | ||||||
|             { |             { | ||||||
|  | @ -2309,14 +2267,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 crossingFlags = 0; |                 crossingFlags = 0; | ||||||
|                 m_inTransit = false; |                 m_inTransit = false; | ||||||
|             } |             } | ||||||
|             // if hide force a check |   | ||||||
|  //           if (!IsChildAgent && newhide) |  | ||||||
|  //           { |  | ||||||
|  //               ParcelLoginCheck(m_currentParcelUUID); |  | ||||||
|  //               m_currentParcelHide = newhide; |  | ||||||
|  //           } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|             m_scene.EventManager.OnRegionHeartbeatEnd += RegionHeartbeatEnd; |             m_scene.EventManager.OnRegionHeartbeatEnd += RegionHeartbeatEnd; | ||||||
| 
 | 
 | ||||||
|             m_log.DebugFormat("[CompleteMovement] end: {0}ms", Util.EnvironmentTickCountSubtract(ts)); |             m_log.DebugFormat("[CompleteMovement] end: {0}ms", Util.EnvironmentTickCountSubtract(ts)); | ||||||
|  | @ -3228,7 +3179,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (part == null) |             if (part == null) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             if (PhysicsActor != null) |             if (PhysicsActor != null) | ||||||
|                 m_sitAvatarHeight = PhysicsActor.Size.Z * 0.5f; |                 m_sitAvatarHeight = PhysicsActor.Size.Z * 0.5f; | ||||||
| 
 | 
 | ||||||
|  | @ -3257,7 +3207,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|             if (canSit) |             if (canSit) | ||||||
|             { |             { | ||||||
| 
 |  | ||||||
|                 if (PhysicsActor != null) |                 if (PhysicsActor != null) | ||||||
|                 { |                 { | ||||||
|                     // We can remove the physicsActor until they stand up. |                     // We can remove the physicsActor until they stand up. | ||||||
|  | @ -3368,7 +3317,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         private bool CanEnterLandPosition(Vector3 testPos) |         private bool CanEnterLandPosition(Vector3 testPos) | ||||||
|         { |         { | ||||||
|             ILandObject land = m_scene.LandChannel.GetLandObject(testPos.X, testPos.Y); |             ILandObject land = m_scene.LandChannel.GetLandObject(testPos.X, testPos.Y); | ||||||
|  | @ -3448,7 +3396,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             ControllingClient.SendSitResponse( |             ControllingClient.SendSitResponse( | ||||||
|                 part.ParentGroup.UUID, offset, Orientation, true, cameraAtOffset, cameraEyeOffset, forceMouselook); |                 part.ParentGroup.UUID, offset, Orientation, true, cameraAtOffset, cameraEyeOffset, forceMouselook); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             SendAvatarDataToAllAgents(); |             SendAvatarDataToAllAgents(); | ||||||
| 
 | 
 | ||||||
|             if (status == 3) |             if (status == 3) | ||||||
|  | @ -3658,8 +3605,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             Animator.avnChangeAnim(animID, addRemove, sendPack); |             Animator.avnChangeAnim(animID, addRemove, sendPack); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Rotate the avatar to the given rotation and apply a movement in the given relative vector |         /// Rotate the avatar to the given rotation and apply a movement in the given relative vector | ||||||
|         /// </summary> |         /// </summary> | ||||||
|  | @ -3866,7 +3811,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (!remoteClient.IsActive) |             if (!remoteClient.IsActive) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             if (ParcelHideThisAvatar && p.currentParcelUUID != currentParcelUUID && p.GodController.GodLevel < 200) |             if (ParcelHideThisAvatar && p.currentParcelUUID != currentParcelUUID && !p.isLegacyGod) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             //m_log.DebugFormat("[SCENE PRESENCE]: " + Name + " sending TerseUpdate to " + remoteClient.Name + " : Pos={0} Rot={1} Vel={2}", m_pos, Rotation, m_velocity); |             //m_log.DebugFormat("[SCENE PRESENCE]: " + Name + " sending TerseUpdate to " + remoteClient.Name + " : Pos={0} Rot={1} Vel={2}", m_pos, Rotation, m_velocity); | ||||||
|  | @ -3976,7 +3921,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 // get the avatar, then a kill if can't see it |                 // get the avatar, then a kill if can't see it | ||||||
|                 p.SendInitialAvatarDataToAgent(this); |                 p.SendInitialAvatarDataToAgent(this); | ||||||
| 
 | 
 | ||||||
|                 if (p.ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && GodController.GodLevel < 200) |                 if (p.ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !isLegacyGod) | ||||||
|                     return; |                     return; | ||||||
| 
 | 
 | ||||||
|                 p.SendAppearanceToAgentNF(this); |                 p.SendAppearanceToAgentNF(this); | ||||||
|  | @ -4024,7 +3969,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             foreach (ScenePresence p in presences) |             foreach (ScenePresence p in presences) | ||||||
|             { |             { | ||||||
|                 p.ControllingClient.SendAvatarDataImmediate(this); |                 p.ControllingClient.SendAvatarDataImmediate(this); | ||||||
|                 if (p != this && ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                 if (p != this && ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     // either just kill the object |                     // either just kill the object | ||||||
|                     // p.ControllingClient.SendKillObject(new List<uint> {LocalId}); |                     // p.ControllingClient.SendKillObject(new List<uint> {LocalId}); | ||||||
|                     // or also attachments viewer may still know about |                     // or also attachments viewer may still know about | ||||||
|  | @ -4037,7 +3982,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         public void SendInitialAvatarDataToAgent(ScenePresence p) |         public void SendInitialAvatarDataToAgent(ScenePresence p) | ||||||
|         { |         { | ||||||
|             p.ControllingClient.SendAvatarDataImmediate(this); |             p.ControllingClient.SendAvatarDataImmediate(this); | ||||||
|             if (p != this && ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |             if (p != this && ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     // either just kill the object |                     // either just kill the object | ||||||
|                     // p.ControllingClient.SendKillObject(new List<uint> {LocalId}); |                     // p.ControllingClient.SendKillObject(new List<uint> {LocalId}); | ||||||
|                     // or also attachments viewer may still know about |                     // or also attachments viewer may still know about | ||||||
|  | @ -4051,7 +3996,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         public void SendAvatarDataToAgent(ScenePresence avatar) |         public void SendAvatarDataToAgent(ScenePresence avatar) | ||||||
|         { |         { | ||||||
|             //m_log.DebugFormat("[SCENE PRESENCE] SendAvatarDataToAgent from {0} ({1}) to {2} ({3})", Name, UUID, avatar.Name, avatar.UUID); |             //m_log.DebugFormat("[SCENE PRESENCE] SendAvatarDataToAgent from {0} ({1}) to {2} ({3})", Name, UUID, avatar.Name, avatar.UUID); | ||||||
|             if (ParcelHideThisAvatar && currentParcelUUID != avatar.currentParcelUUID && avatar.GodController.GodLevel < 200) |             if (ParcelHideThisAvatar && currentParcelUUID != avatar.currentParcelUUID && !avatar.isLegacyGod) | ||||||
|                 return; |                 return; | ||||||
|             avatar.ControllingClient.SendAvatarDataImmediate(this); |             avatar.ControllingClient.SendAvatarDataImmediate(this); | ||||||
|         } |         } | ||||||
|  | @ -4096,7 +4041,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         { |         { | ||||||
|             //            m_log.DebugFormat( |             //            m_log.DebugFormat( | ||||||
|             //                "[SCENE PRESENCE]: Sending appearance data from {0} {1} to {2} {3}", Name, m_uuid, avatar.Name, avatar.UUID); |             //                "[SCENE PRESENCE]: Sending appearance data from {0} {1} to {2} {3}", Name, m_uuid, avatar.Name, avatar.UUID); | ||||||
|             if (ParcelHideThisAvatar && currentParcelUUID != avatar.currentParcelUUID && avatar.GodController.GodLevel < 200) |             if (ParcelHideThisAvatar && currentParcelUUID != avatar.currentParcelUUID && !avatar.isLegacyGod) | ||||||
|                 return; |                 return; | ||||||
|             SendAppearanceToAgentNF(avatar); |             SendAppearanceToAgentNF(avatar); | ||||||
|         } |         } | ||||||
|  | @ -4112,7 +4057,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (IsChildAgent || Animator == null) |             if (IsChildAgent || Animator == null) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |             if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             Animator.SendAnimPackToClient(p.ControllingClient); |             Animator.SendAnimPackToClient(p.ControllingClient); | ||||||
|  | @ -4123,7 +4068,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (IsChildAgent) |             if (IsChildAgent) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |             if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             p.ControllingClient.SendAnimations(animations, seqs, ControllingClient.AgentId, objectIDs); |             p.ControllingClient.SendAnimations(animations, seqs, ControllingClient.AgentId, objectIDs); | ||||||
|  | @ -4148,7 +4093,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|             m_scene.ForEachScenePresence(delegate(ScenePresence p) |             m_scene.ForEachScenePresence(delegate(ScenePresence p) | ||||||
|             { |             { | ||||||
|                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     return; |                     return; | ||||||
|                 p.ControllingClient.SendAnimations(animations, seqs, ControllingClient.AgentId, objectIDs); |                 p.ControllingClient.SendAnimations(animations, seqs, ControllingClient.AgentId, objectIDs); | ||||||
|             }); |             }); | ||||||
|  | @ -4183,7 +4128,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 if(DrawDistance > minregionSize && m_reprioritizationLastDrawDistance > minregionSize) |                 if(DrawDistance > minregionSize && m_reprioritizationLastDrawDistance > minregionSize) | ||||||
|                     byDrawdistance = false; |                     byDrawdistance = false; | ||||||
|                 else |                 else | ||||||
|                     byDrawdistance = (Math.Abs(DrawDistance-m_reprioritizationLastDrawDistance) > 0.5f * limit); |                     byDrawdistance = (Math.Abs(DrawDistance - m_reprioritizationLastDrawDistance) > 0.5f * limit); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             int tdiff =  Util.EnvironmentTickCountSubtract(m_reprioritizationLastTime); |             int tdiff =  Util.EnvironmentTickCountSubtract(m_reprioritizationLastTime); | ||||||
|  | @ -4232,7 +4177,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             // updates priority recalc |             // updates priority recalc | ||||||
|             checkRePrioritization(); |             checkRePrioritization(); | ||||||
| 
 | 
 | ||||||
|             if(childUpdatesBusy) |             if(m_childUpdatesBusy) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             //possible KnownRegionHandles always contains current region and this check is not needed |             //possible KnownRegionHandles always contains current region and this check is not needed | ||||||
|  | @ -4242,37 +4187,52 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|             if(KnownRegionHandles.Count > minhandles) |             if(KnownRegionHandles.Count > minhandles) | ||||||
|             { |             { | ||||||
|                 int tdiff = Util.EnvironmentTickCountSubtract(lastChildUpdatesTime); |                 int tdiff = Util.EnvironmentTickCountSubtract(m_lastChildUpdatesTime); | ||||||
|                 if(tdiff > CHILDUPDATES_TIME) |                 if(tdiff < CHILDUPDATES_TIME) | ||||||
|  |                     return; | ||||||
|  | 
 | ||||||
|  |                 bool doUpdate = false; | ||||||
|  |                 if(m_lastChildAgentUpdateGodLevel != GodController.GodLevel) | ||||||
|  |                     doUpdate = true; | ||||||
|  |                 | ||||||
|  |                 if(!doUpdate && Math.Abs(DrawDistance - m_lastChildAgentUpdateDrawDistance) > 32.0f) | ||||||
|  |                     doUpdate = true; | ||||||
|  | 
 | ||||||
|  |                 if(!doUpdate) | ||||||
|                 { |                 { | ||||||
|                     diff = pos - m_lastChildAgentUpdatePosition; |                     diff = pos - m_lastChildAgentUpdatePosition; | ||||||
|                     if (diff.LengthSquared() > CHILDUPDATES_MOVEMENT) |                     if (diff.LengthSquared() > CHILDUPDATES_MOVEMENT) | ||||||
|                     { |                         doUpdate = true; | ||||||
|                         childUpdatesBusy = true; |                 } | ||||||
|                         m_lastChildAgentUpdatePosition = pos; | 
 | ||||||
|  |                 if(doUpdate) | ||||||
|  |                 { | ||||||
|  |                     m_childUpdatesBusy = true; | ||||||
|  |                     m_lastChildAgentUpdatePosition = pos; | ||||||
|  |                     m_lastChildAgentUpdateGodLevel = GodController.GodLevel; | ||||||
|  |                     m_lastChildAgentUpdateDrawDistance = DrawDistance; | ||||||
| //                        m_lastChildAgentUpdateCamPosition = CameraPosition; | //                        m_lastChildAgentUpdateCamPosition = CameraPosition; | ||||||
| 
 | 
 | ||||||
|                         AgentPosition agentpos = new AgentPosition(); |                     AgentPosition agentpos = new AgentPosition(); | ||||||
|                         agentpos.AgentID = new UUID(UUID.Guid); |                     agentpos.AgentID = new UUID(UUID.Guid); | ||||||
|                         agentpos.SessionID = ControllingClient.SessionId; |                     agentpos.SessionID = ControllingClient.SessionId; | ||||||
|                         agentpos.Size = Appearance.AvatarSize; |                     agentpos.Size = Appearance.AvatarSize; | ||||||
|                         agentpos.Center = CameraPosition; |                     agentpos.Center = CameraPosition; | ||||||
|                         agentpos.Far = DrawDistance; |                     agentpos.Far = DrawDistance; | ||||||
|                         agentpos.Position = AbsolutePosition; |                     agentpos.Position = AbsolutePosition; | ||||||
|                         agentpos.Velocity = Velocity; |                     agentpos.Velocity = Velocity; | ||||||
|                         agentpos.RegionHandle = RegionHandle; |                     agentpos.RegionHandle = RegionHandle; | ||||||
|                         agentpos.GodData = GodController.State(); |                     agentpos.GodData = GodController.State(); | ||||||
|                         agentpos.Throttles = ControllingClient.GetThrottlesPacked(1); |                     agentpos.Throttles = ControllingClient.GetThrottlesPacked(1); | ||||||
| 
 | 
 | ||||||
|                         // Let's get this out of the update loop |                     // Let's get this out of the update loop | ||||||
|                         Util.FireAndForget( |                     Util.FireAndForget( | ||||||
|                             o => |                         o => | ||||||
|                             { |                         { | ||||||
|                                 m_scene.SendOutChildAgentUpdates(agentpos, this); |                             m_scene.SendOutChildAgentUpdates(agentpos, this); | ||||||
|                                 lastChildUpdatesTime = Util.EnvironmentTickCount(); |                             m_lastChildUpdatesTime = Util.EnvironmentTickCount(); | ||||||
|                                 childUpdatesBusy = false; |                             m_childUpdatesBusy = false; | ||||||
|                             }, null, "ScenePresence.SendOutChildAgentUpdates"); |                         }, null, "ScenePresence.SendOutChildAgentUpdates"); | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -4513,11 +4473,10 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (isNPC) |             if (isNPC) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             bool wasgod = (GodController.GodLevel >= 200); |             bool wasgod = isLegacyGod; | ||||||
|             GodController.RequestGodMode(godStatus); |             GodController.RequestGodMode(godStatus); | ||||||
|             bool isgod = GodController.GodLevel >= 200; |             if (wasgod != isLegacyGod) | ||||||
|             if (wasgod != isgod) |                 parcelGodCheck(m_currentParcelUUID); | ||||||
|                 parcelGodCheck(m_currentParcelUUID, isgod); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         #region Child Agent Updates |         #region Child Agent Updates | ||||||
|  | @ -4697,7 +4656,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             Quaternion camRot = Util.Axes2Rot(CameraAtAxis, CameraLeftAxis, CameraUpAxis); |             Quaternion camRot = Util.Axes2Rot(CameraAtAxis, CameraLeftAxis, CameraUpAxis); | ||||||
|             CameraRotation = camRot; |             CameraRotation = camRot; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             ParentUUID = cAgent.ParentPart; |             ParentUUID = cAgent.ParentPart; | ||||||
|             PrevSitOffset = cAgent.SitOffset; |             PrevSitOffset = cAgent.SitOffset; | ||||||
| 
 | 
 | ||||||
|  | @ -4883,7 +4841,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 ControllingClient.SendAgentAlertMessage("Physics is having a problem with your avatar.  You may not be able to move until you relog.", true); |                 ControllingClient.SendAgentAlertMessage("Physics is having a problem with your avatar.  You may not be able to move until you relog.", true); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Event called by the physics plugin to tell the avatar about a collision. |         /// Event called by the physics plugin to tell the avatar about a collision. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|  | @ -4952,7 +4909,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             RaiseCollisionScriptEvents(coldata); |             RaiseCollisionScriptEvents(coldata); | ||||||
| 
 | 
 | ||||||
|             // Gods do not take damage and Invulnerable is set depending on parcel/region flags |             // Gods do not take damage and Invulnerable is set depending on parcel/region flags | ||||||
|             if (Invulnerable || GodController.GodLevel > 0) |             if (Invulnerable || isLegacyGod) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             // The following may be better in the ICombatModule |             // The following may be better in the ICombatModule | ||||||
|  | @ -5237,7 +5194,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                         if (p != this && sog.HasPrivateAttachmentPoint) |                         if (p != this && sog.HasPrivateAttachmentPoint) | ||||||
|                             return; |                             return; | ||||||
| 
 | 
 | ||||||
|                         if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                         if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                             return; |                             return; | ||||||
| 
 | 
 | ||||||
|                         SendTerseUpdateToAgentNF(p); |                         SendTerseUpdateToAgentNF(p); | ||||||
|  | @ -5351,7 +5308,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 if (p == this) |                 if (p == this) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 p.ControllingClient.SendEntityUpdate(rootpart, rootflag); |                 p.ControllingClient.SendEntityUpdate(rootpart, rootflag); | ||||||
|  | @ -5403,14 +5360,13 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             if (sog.HasPrivateAttachmentPoint) |             if (sog.HasPrivateAttachmentPoint) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|             List<ScenePresence> allPresences = m_scene.GetScenePresences(); |             List<ScenePresence> allPresences = m_scene.GetScenePresences(); | ||||||
|             foreach (ScenePresence p in allPresences) |             foreach (ScenePresence p in allPresences) | ||||||
|             { |             { | ||||||
|                 if (p == this) |                 if (p == this) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 p.ControllingClient.SendEntityUpdate(rootpart, flag); |                 p.ControllingClient.SendEntityUpdate(rootpart, flag); | ||||||
|  | @ -5460,7 +5416,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 if (p == this) |                 if (p == this) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 p.ControllingClient.SendEntityUpdate(part, flag); |                 p.ControllingClient.SendEntityUpdate(part, flag); | ||||||
|  | @ -5501,7 +5457,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             { |             { | ||||||
|                 if (p == this) |                 if (p == this) | ||||||
|                     continue; |                     continue; | ||||||
|                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                 if (ParcelHideThisAvatar && currentParcelUUID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                     continue; |                     continue; | ||||||
| 
 | 
 | ||||||
|                 p.ControllingClient.SendEntityUpdate(part, flag); |                 p.ControllingClient.SendEntityUpdate(part, flag); | ||||||
|  | @ -6139,7 +6095,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     // the TP point. This behaviour mimics agni. |                     // the TP point. This behaviour mimics agni. | ||||||
|                     if (land.LandData.LandingType == (byte)LandingType.LandingPoint && |                     if (land.LandData.LandingType == (byte)LandingType.LandingPoint && | ||||||
|                         land.LandData.UserLocation != Vector3.Zero && |                         land.LandData.UserLocation != Vector3.Zero && | ||||||
|                         GodController.GodLevel < 200 && |                         !isLegacyGod && | ||||||
|                         ((land.LandData.OwnerID != m_uuid && |                         ((land.LandData.OwnerID != m_uuid && | ||||||
|                           !m_scene.Permissions.IsGod(m_uuid) && |                           !m_scene.Permissions.IsGod(m_uuid) && | ||||||
|                           !m_scene.RegionInfo.EstateSettings.IsEstateManagerOrOwner(m_uuid)) || |                           !m_scene.RegionInfo.EstateSettings.IsEstateManagerOrOwner(m_uuid)) || | ||||||
|  | @ -6164,7 +6120,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             string reason; |             string reason; | ||||||
| 
 | 
 | ||||||
|             // dont mess with gods |             // dont mess with gods | ||||||
|             if(GodController.GodLevel >=  200 || m_scene.Permissions.IsGod(m_uuid)) |             if(isLegacyGod || m_scene.Permissions.IsGod(m_uuid)) | ||||||
|                 return true; |                 return true; | ||||||
| 
 | 
 | ||||||
|             // respect region owner and managers |             // respect region owner and managers | ||||||
|  | @ -6450,7 +6406,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void parcelGodCheck(UUID currentParcelID, bool isGod) |         private void parcelGodCheck(UUID currentParcelID) | ||||||
|         { |         { | ||||||
|             List<ScenePresence> allpresences = m_scene.GetScenePresences(); |             List<ScenePresence> allpresences = m_scene.GetScenePresences(); | ||||||
| 
 | 
 | ||||||
|  | @ -6461,7 +6417,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|                 if (p.ParcelHideThisAvatar && p.currentParcelUUID != currentParcelID) |                 if (p.ParcelHideThisAvatar && p.currentParcelUUID != currentParcelID) | ||||||
|                 { |                 { | ||||||
|                     if (isGod) |                     if (isLegacyGod) | ||||||
|                         p.SendViewTo(this); |                         p.SendViewTo(this); | ||||||
|                     else |                     else | ||||||
|                         p.SendKillTo(this); |                         p.SendKillTo(this); | ||||||
|  | @ -6470,7 +6426,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void ParcelCrossCheck(UUID currentParcelID,UUID previusParcelID, |         private void ParcelCrossCheck(UUID currentParcelID,UUID previusParcelID, | ||||||
|                             bool currentParcelHide, bool previusParcelHide, bool oldhide,bool check) |                             bool currentParcelHide, bool previusParcelHide, bool oldhide, bool check) | ||||||
|         { |         { | ||||||
|             List<ScenePresence> killsToSendto = new List<ScenePresence>(); |             List<ScenePresence> killsToSendto = new List<ScenePresence>(); | ||||||
|             List<ScenePresence> killsToSendme = new List<ScenePresence>(); |             List<ScenePresence> killsToSendme = new List<ScenePresence>(); | ||||||
|  | @ -6512,7 +6468,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                             continue; |                             continue; | ||||||
| 
 | 
 | ||||||
|                         // those not on parcel dont see me |                         // those not on parcel dont see me | ||||||
|                         if (currentParcelID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                         if (currentParcelID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                         { |                         { | ||||||
|                             killsToSendto.Add(p); // they dont see me |                             killsToSendto.Add(p); // they dont see me | ||||||
|                         } |                         } | ||||||
|  | @ -6538,9 +6494,9 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                             // only those on previus parcel need receive kills |                             // only those on previus parcel need receive kills | ||||||
|                             if (previusParcelID == p.currentParcelUUID) |                             if (previusParcelID == p.currentParcelUUID) | ||||||
|                             { |                             { | ||||||
|                                 if(p.GodController.GodLevel < 200) |                                 if(!p.isLegacyGod) | ||||||
|                                     killsToSendto.Add(p); // they dont see me |                                     killsToSendto.Add(p); // they dont see me | ||||||
|                                 if(GodController.GodLevel < 200) |                                 if(!isLegacyGod) | ||||||
|                                     killsToSendme.Add(p);  // i dont see them |                                     killsToSendme.Add(p);  // i dont see them | ||||||
|                             } |                             } | ||||||
|                             // only those on new parcel need see |                             // only those on new parcel need see | ||||||
|  | @ -6562,7 +6518,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                                 continue; |                                 continue; | ||||||
| 
 | 
 | ||||||
|                             // those not on new parcel dont see me |                             // those not on new parcel dont see me | ||||||
|                             if (currentParcelID != p.currentParcelUUID && p.GodController.GodLevel < 200) |                             if (currentParcelID != p.currentParcelUUID && !p.isLegacyGod) | ||||||
|                             { |                             { | ||||||
|                                 killsToSendto.Add(p); // they dont see me |                                 killsToSendto.Add(p); // they dont see me | ||||||
|                             } |                             } | ||||||
|  | @ -6588,7 +6544,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                             if (p.IsDeleted || p == this || p.ControllingClient == null || !p.ControllingClient.IsActive) |                             if (p.IsDeleted || p == this || p.ControllingClient == null || !p.ControllingClient.IsActive) | ||||||
|                                 continue; |                                 continue; | ||||||
|                             // only those old parcel need kills |                             // only those old parcel need kills | ||||||
|                             if (previusParcelID == p.currentParcelUUID && GodController.GodLevel < 200) |                             if (previusParcelID == p.currentParcelUUID && !isLegacyGod) | ||||||
|                             { |                             { | ||||||
|                                 killsToSendme.Add(p);  // i dont see them |                                 killsToSendme.Add(p);  // i dont see them | ||||||
|                             } |                             } | ||||||
|  | @ -6645,13 +6601,12 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         public void HasMovedAway(bool nearRegion) |         public void HasMovedAway(bool nearRegion) | ||||||
|         { |         { | ||||||
| 
 |  | ||||||
|             if (nearRegion) |             if (nearRegion) | ||||||
|             { |             { | ||||||
|                 if (Scene.AttachmentsModule != null) |                 if (Scene.AttachmentsModule != null) | ||||||
|                     Scene.AttachmentsModule.DeleteAttachmentsFromScene(this, true); |                     Scene.AttachmentsModule.DeleteAttachmentsFromScene(this, true); | ||||||
| 
 | 
 | ||||||
|                 if (!ParcelHideThisAvatar || GodController.GodLevel >= 200) |                 if (!ParcelHideThisAvatar || isLegacyGod) | ||||||
|                     return; |                     return; | ||||||
| 
 | 
 | ||||||
|                 List<ScenePresence> allpresences = m_scene.GetScenePresences(); |                 List<ScenePresence> allpresences = m_scene.GetScenePresences(); | ||||||
|  | @ -6668,6 +6623,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|  |                 GodController.HasMovedAway(); | ||||||
|                 List<ScenePresence> allpresences = m_scene.GetScenePresences(); |                 List<ScenePresence> allpresences = m_scene.GetScenePresences(); | ||||||
|                 foreach (ScenePresence p in allpresences) |                 foreach (ScenePresence p in allpresences) | ||||||
|                 { |                 { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 UbitUmarov
						UbitUmarov