From b044a0f139784b8075467dc5e9c6b1a45e78d6d5 Mon Sep 17 00:00:00 2001 From: Justin Clarke Casey Date: Mon, 10 Nov 2008 20:54:34 +0000 Subject: * refactor: Make xml (orig format) loading method reuse existing set root part method * miscellaneous doc/log message changes --- .../Region/Environment/Scenes/SceneObjectGroup.cs | 24 ++++++++++++++-------- 1 file changed, 15 insertions(+), 9 deletions(-) (limited to 'OpenSim/Region/Environment/Scenes') diff --git a/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs index ed087a4..9afe8cd 100644 --- a/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs +++ b/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs @@ -398,10 +398,7 @@ namespace OpenSim.Region.Environment.Scenes reader.Read(); reader.ReadStartElement("SceneObjectGroup"); reader.ReadStartElement("RootPart"); - m_rootPart = SceneObjectPart.FromXml(reader); - int linkNum = m_rootPart.LinkNum; - AddPart(m_rootPart); - m_rootPart.LinkNum = linkNum; + SetRootPart(SceneObjectPart.FromXml(reader)); reader.ReadEndElement(); @@ -414,7 +411,9 @@ namespace OpenSim.Region.Environment.Scenes { reader.Read(); SceneObjectPart part = SceneObjectPart.FromXml(reader); - linkNum = part.LinkNum; + + // We reset the link number in order to make sure that the persisted linkset order is + int linkNum = part.LinkNum; AddPart(part); part.LinkNum = linkNum; @@ -428,11 +427,9 @@ namespace OpenSim.Region.Environment.Scenes } } } - catch (XmlException) + catch (XmlException e) { - m_log.ErrorFormat("[SCENE OBJECT GROUP]: Deserialization of following xml failed, {0}", xmlData); - - // Let's see if carrying on does anything for us + m_log.ErrorFormat("[SCENE]: Deserialization of xml failed with {0}. xml was {1}", e, xmlData); } reader.Close(); @@ -885,6 +882,9 @@ namespace OpenSim.Region.Environment.Scenes part.ParentID = 0; part.LinkNum = 0; m_rootPart = part; + + // No locking required since the SOG should not be in the scene yet - one can't change root parts after + // the scene object has been attached to the scene m_parts.Add(m_rootPart.UUID, m_rootPart); } @@ -1460,6 +1460,12 @@ namespace OpenSim.Region.Environment.Scenes } } + /// + /// Set the owner of the root part. + /// + /// + /// + /// public void SetRootPartOwner(SceneObjectPart part, UUID cAgentID, UUID cGroupID) { part.LastOwnerID = part.OwnerID; -- cgit v1.1