diff options
Diffstat (limited to 'OpenSim/Region/Framework/Scenes/Scene.cs')
-rwxr-xr-x | OpenSim/Region/Framework/Scenes/Scene.cs | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs index a0a2882..0c5007a 100755 --- a/OpenSim/Region/Framework/Scenes/Scene.cs +++ b/OpenSim/Region/Framework/Scenes/Scene.cs | |||
@@ -410,7 +410,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
410 | private readonly Timer m_restartTimer = new Timer(15000); // Wait before firing | 410 | private readonly Timer m_restartTimer = new Timer(15000); // Wait before firing |
411 | private volatile bool m_backingup; | 411 | private volatile bool m_backingup; |
412 | private Dictionary<UUID, ReturnInfo> m_returns = new Dictionary<UUID, ReturnInfo>(); | 412 | private Dictionary<UUID, ReturnInfo> m_returns = new Dictionary<UUID, ReturnInfo>(); |
413 | private Dictionary<UUID, int> m_groupsWithTargets = new Dictionary<UUID, int>(); | 413 | private HashSet<UUID> m_groupsWithTargets = new HashSet<UUID>(); |
414 | 414 | ||
415 | private string m_defaultScriptEngine; | 415 | private string m_defaultScriptEngine; |
416 | 416 | ||
@@ -837,7 +837,8 @@ namespace OpenSim.Region.Framework.Scenes | |||
837 | 837 | ||
838 | Random random = new Random(); | 838 | Random random = new Random(); |
839 | 839 | ||
840 | m_lastAllocatedLocalId = (uint)(random.NextDouble() * (double)(uint.MaxValue / 2)) + (uint)(uint.MaxValue / 4); | 840 | m_lastAllocatedLocalId = (int)(random.NextDouble() * (uint.MaxValue / 4)); |
841 | m_lastAllocatedIntId = (int)(random.NextDouble() * (int.MaxValue / 4)); | ||
841 | m_authenticateHandler = authen; | 842 | m_authenticateHandler = authen; |
842 | m_sceneGridService = new SceneCommunicationService(); | 843 | m_sceneGridService = new SceneCommunicationService(); |
843 | m_SimulationDataService = simDataService; | 844 | m_SimulationDataService = simDataService; |
@@ -1633,7 +1634,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
1633 | 1634 | ||
1634 | // m_log.DebugFormat("[SCENE]: Processing frame {0} in {1}", Frame, RegionInfo.RegionName); | 1635 | // m_log.DebugFormat("[SCENE]: Processing frame {0} in {1}", Frame, RegionInfo.RegionName); |
1635 | 1636 | ||
1636 | agentMS = tempOnRezMS = eventMS = backupMS = terrainMS = landMS = 0f; | 1637 | otherMS = agentMS = tempOnRezMS = eventMS = backupMS = terrainMS = landMS = 0f; |
1637 | 1638 | ||
1638 | try | 1639 | try |
1639 | { | 1640 | { |
@@ -1713,6 +1714,10 @@ namespace OpenSim.Region.Framework.Scenes | |||
1713 | if (Frame % m_update_objects == 0) | 1714 | if (Frame % m_update_objects == 0) |
1714 | m_sceneGraph.UpdateObjectGroups(); | 1715 | m_sceneGraph.UpdateObjectGroups(); |
1715 | 1716 | ||
1717 | tmpMS2 = Util.GetTimeStampMS(); | ||
1718 | otherMS = (float)(tmpMS2 - tmpMS); | ||
1719 | tmpMS = tmpMS2; | ||
1720 | |||
1716 | // Run through all ScenePresences looking for updates | 1721 | // Run through all ScenePresences looking for updates |
1717 | // Presence updates and queued object updates for each presence are sent to clients | 1722 | // Presence updates and queued object updates for each presence are sent to clients |
1718 | if (Frame % m_update_presences == 0) | 1723 | if (Frame % m_update_presences == 0) |
@@ -1828,7 +1833,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
1828 | m_firstHeartbeat = false; | 1833 | m_firstHeartbeat = false; |
1829 | Watchdog.UpdateThread(); | 1834 | Watchdog.UpdateThread(); |
1830 | 1835 | ||
1831 | otherMS = tempOnRezMS + eventMS + backupMS + terrainMS + landMS; | 1836 | otherMS += tempOnRezMS + eventMS + backupMS + terrainMS + landMS; |
1832 | 1837 | ||
1833 | tmpMS = Util.GetTimeStampMS(); | 1838 | tmpMS = Util.GetTimeStampMS(); |
1834 | 1839 | ||
@@ -1912,7 +1917,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
1912 | public void AddGroupTarget(SceneObjectGroup grp) | 1917 | public void AddGroupTarget(SceneObjectGroup grp) |
1913 | { | 1918 | { |
1914 | lock (m_groupsWithTargets) | 1919 | lock (m_groupsWithTargets) |
1915 | m_groupsWithTargets[grp.UUID] = 0; | 1920 | m_groupsWithTargets.Add(grp.UUID); |
1916 | } | 1921 | } |
1917 | 1922 | ||
1918 | public void RemoveGroupTarget(SceneObjectGroup grp) | 1923 | public void RemoveGroupTarget(SceneObjectGroup grp) |
@@ -1928,13 +1933,14 @@ namespace OpenSim.Region.Framework.Scenes | |||
1928 | lock (m_groupsWithTargets) | 1933 | lock (m_groupsWithTargets) |
1929 | { | 1934 | { |
1930 | if (m_groupsWithTargets.Count != 0) | 1935 | if (m_groupsWithTargets.Count != 0) |
1931 | objs = new List<UUID>(m_groupsWithTargets.Keys); | 1936 | objs = new List<UUID>(m_groupsWithTargets); |
1932 | } | 1937 | } |
1933 | 1938 | ||
1934 | if (objs != null) | 1939 | if (objs != null) |
1935 | { | 1940 | { |
1936 | foreach (UUID entry in objs) | 1941 | for(int i = 0; i< objs.Count; ++i) |
1937 | { | 1942 | { |
1943 | UUID entry = objs[i]; | ||
1938 | SceneObjectGroup grp = GetSceneObjectGroup(entry); | 1944 | SceneObjectGroup grp = GetSceneObjectGroup(entry); |
1939 | if (grp == null) | 1945 | if (grp == null) |
1940 | m_groupsWithTargets.Remove(entry); | 1946 | m_groupsWithTargets.Remove(entry); |