From d216f5779c5f03709d718e279420e13472d08aae Mon Sep 17 00:00:00 2001 From: mingchen Date: Mon, 16 Jul 2007 14:56:35 +0000 Subject: *Trunk compiles now *Added "RemoveEntity" and renamed "AddNewEntity" to "AddEntity" --- OpenSim/Region/Environment/Scenes/Scene.cs | 32 +++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) (limited to 'OpenSim/Region/Environment/Scenes') diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs index ba57115..1e69c9e 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.cs @@ -155,7 +155,7 @@ namespace OpenSim.Region.Environment.Scenes List PrimsFromDB = storageManager.DataStore.LoadObjects(); foreach (SceneObject prim in PrimsFromDB) { - Prims.Add(prim.uuid, prim); + AddEntity(prim); } MainLog.Instance.Verbose("World.cs - loaded " + PrimsFromDB.Count.ToString() + " object(s)"); @@ -483,14 +483,40 @@ namespace OpenSim.Region.Environment.Scenes { SceneObject sceneOb = new SceneObject(this, m_eventManager, ownerID, this.PrimIDAllocate(), pos, shape); - AddNewEntity(sceneOb); + AddEntity(sceneOb); } - public void AddNewEntity(SceneObject sceneObject) + public void RemovePrim(uint localID, LLUUID avatar_deleter) + { + foreach (EntityBase obj in Entities.Values) + { + if (obj is SceneObject) + { + if (((SceneObject)obj).LocalId == localID) + { + RemoveEntity((SceneObject)obj); + return; + } + } + } + + } + + public void AddEntity(SceneObject sceneObject) { this.Entities.Add(sceneObject.rootUUID, sceneObject); } + public void RemoveEntity(SceneObject sceneObject) + { + if (this.Entities.ContainsKey(sceneObject.rootUUID)) + { + m_parcelManager.removePrimFromParcelCounts(sceneObject); + this.Entities.Remove(sceneObject.rootUUID); + m_parcelManager.setPrimsTainted(); + } + } + /// /// Called by a prim when it has been created/cloned, so that its events can be subscribed to /// -- cgit v1.1