From d085c337a9d08788837a2f54a2400e91c807f59f Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Tue, 4 Apr 2017 20:11:11 +0100 Subject: add a little speedup on repeated requests for same name on osGetLinkNumber. --- .../Region/Framework/Scenes/SceneObjectGroup.cs | 35 +++++++++++++++++----- 1 file changed, 28 insertions(+), 7 deletions(-) (limited to 'OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs') diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs index b410b74..d3490c2 100644 --- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs +++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs @@ -5340,7 +5340,9 @@ namespace OpenSim.Region.Framework.Scenes m_partsNameToLinkMap.Clear(); } - Dictionary m_partsNameToLinkMap = new Dictionary(); + private Dictionary m_partsNameToLinkMap = new Dictionary(); + private string GetLinkNumber_lastname; + private int GetLinkNumber_lastnumber; // this scales bad but so does GetLinkNumPart public int GetLinkNumber(string name) @@ -5352,6 +5354,8 @@ namespace OpenSim.Region.Framework.Scenes { if(m_partsNameToLinkMap.Count == 0) { + GetLinkNumber_lastname = String.Empty; + GetLinkNumber_lastnumber = -1; SceneObjectPart[] parts = m_parts.GetArray(); for (int i = 0; i < parts.Length; i++) { @@ -5370,20 +5374,33 @@ namespace OpenSim.Region.Framework.Scenes } } + if(name == GetLinkNumber_lastname) + return GetLinkNumber_lastnumber; + if(m_partsNameToLinkMap.ContainsKey(name)) - return m_partsNameToLinkMap[name]; - } + { + lock(m_partsNameToLinkMap) + { + GetLinkNumber_lastname = name; + GetLinkNumber_lastnumber = m_partsNameToLinkMap[name]; + return GetLinkNumber_lastnumber; + } + } + } if(m_sittingAvatars.Count > 0) { - int j = m_parts.Count; - if(j > 1) - j++; + int j = m_parts.Count + 1; + ScenePresence[] avs = m_sittingAvatars.ToArray(); for (int i = 0; i < avs.Length; i++, j++) { if (avs[i].Name == name) - return j; + { + GetLinkNumber_lastname = name; + GetLinkNumber_lastnumber = j; + return j; + } } } @@ -5393,7 +5410,11 @@ namespace OpenSim.Region.Framework.Scenes public void InvalidatePartsLinkMaps() { lock(m_partsNameToLinkMap) + { m_partsNameToLinkMap.Clear(); + GetLinkNumber_lastname = String.Empty; + GetLinkNumber_lastnumber = -1; + } } #endregion -- cgit v1.1