* Refactor: Collapses parts of different code paths in scene used when deleting and unlinking an object

0.6.0-stable
Justin Clarke Casey 2008-05-25 00:09:08 +00:00
parent 0ee69707ea
commit bc92d72828
4 changed files with 27 additions and 40 deletions

View File

@ -590,16 +590,6 @@ namespace OpenSim.Region.Environment.Scenes
} }
} }
public void RemoveAPrimCount()
{
m_numPrim--;
}
public void AddAPrimCount()
{
m_numPrim++;
}
public int GetChildAgentCount() public int GetChildAgentCount()
{ {
// some network situations come in where child agents get closed twice. // some network situations come in where child agents get closed twice.

View File

@ -1145,7 +1145,6 @@ namespace OpenSim.Region.Environment.Scenes
if (permissionToTake) if (permissionToTake)
{ {
string sceneObjectXml = objectGroup.ToXmlString(); string sceneObjectXml = objectGroup.ToXmlString();
CachedUserInfo userInfo = CachedUserInfo userInfo =

View File

@ -1344,21 +1344,20 @@ namespace OpenSim.Region.Environment.Scenes
public void DeleteSceneObject(SceneObjectGroup group) public void DeleteSceneObject(SceneObjectGroup group)
{ {
SceneObjectPart rootPart = (group).GetChildPart(group.UUID); SceneObjectPart rootPart = (group).GetChildPart(group.UUID);
if (rootPart.PhysActor != null) if (rootPart.PhysActor != null)
{ {
PhysicsScene.RemovePrim(rootPart.PhysActor); PhysicsScene.RemovePrim(rootPart.PhysActor);
rootPart.PhysActor = null; rootPart.PhysActor = null;
} }
m_storageManager.DataStore.RemoveObject(group.UUID, m_regInfo.RegionID); if (UnlinkSceneObject(group.UUID))
group.DeleteGroup();
if (m_innerScene.DeleteSceneObject(group.UUID))
{ {
EventManager.TriggerObjectBeingRemovedFromScene(group); EventManager.TriggerObjectBeingRemovedFromScene(group);
EventManager.TriggerParcelPrimCountTainted(); EventManager.TriggerParcelPrimCountTainted();
} }
group.DeleteGroup();
group.DeleteParts(); group.DeleteParts();
// In case anybody else retains a reference to this group, signal deletion by changing the name // In case anybody else retains a reference to this group, signal deletion by changing the name
@ -1370,6 +1369,24 @@ namespace OpenSim.Region.Environment.Scenes
group.Name = null; group.Name = null;
} }
/// <summary>
/// Unlink the given object from the scene. Unlike delete, this just removes the record of the object - the
/// object itself is not destroyed.
/// </summary>
/// <param name="uuid"></param>
/// <returns>true if the object was in the scene, false if it was not</returns>
public bool UnlinkSceneObject(LLUUID uuid)
{
if (m_innerScene.DeleteSceneObject(uuid))
{
m_storageManager.DataStore.RemoveObject(uuid, m_regInfo.RegionID);
return true;
}
return false;
}
public void LoadPrimsFromXml(string fileName, bool newIdsFlag, LLVector3 loadOffset) public void LoadPrimsFromXml(string fileName, bool newIdsFlag, LLVector3 loadOffset)
{ {
m_sceneXmlLoader.LoadPrimsFromXml(fileName, newIdsFlag, loadOffset); m_sceneXmlLoader.LoadPrimsFromXml(fileName, newIdsFlag, loadOffset);
@ -1971,23 +1988,6 @@ namespace OpenSim.Region.Environment.Scenes
#region Entities #region Entities
/// <summary>
///
/// </summary>
/// <param name="entID"></param>
/// <returns></returns>
public bool DeleteEntity(LLUUID entID)
{
if (Entities.ContainsKey(entID))
{
Entities.Remove(entID);
m_storageManager.DataStore.RemoveObject(entID, m_regInfo.RegionID);
m_innerScene.RemoveAPrimCount();
return true;
}
return false;
}
public void SendKillObject(uint localID) public void SendKillObject(uint localID)
{ {
Broadcast(delegate(IClientAPI client) { client.SendKillObject(m_regionHandle, localID); }); Broadcast(delegate(IClientAPI client) { client.SendKillObject(m_regionHandle, localID); });

View File

@ -1744,9 +1744,7 @@ namespace OpenSim.Region.Environment.Scenes
part.ClearUndoState(); part.ClearUndoState();
} }
DetachFromBackup(objectGroup); m_scene.UnlinkSceneObject(objectGroup.UUID);
m_scene.DeleteEntity(objectGroup.UUID);
// TODO Deleting the parts may cause problems later on if they have already // TODO Deleting the parts may cause problems later on if they have already
// made it into the update queue. However, sending out updates for those parts is now // made it into the update queue. However, sending out updates for those parts is now