Some work on cleanly removing Regions.
							parent
							
								
									7f8a69f181
								
							
						
					
					
						commit
						297cc7ef4f
					
				|  | @ -439,6 +439,7 @@ namespace OpenSim.Framework | ||||||
|         void SetDebug(int newDebug); |         void SetDebug(int newDebug); | ||||||
|         void InPacket(Packet NewPack); |         void InPacket(Packet NewPack); | ||||||
|         void Close(); |         void Close(); | ||||||
|  |         void Stop(); | ||||||
|         event ViewerEffectEventHandler OnViewerEffect; |         event ViewerEffectEventHandler OnViewerEffect; | ||||||
|         event Action<IClientAPI> OnLogout; |         event Action<IClientAPI> OnLogout; | ||||||
|         event Action<IClientAPI> OnConnectionClosed; |         event Action<IClientAPI> OnConnectionClosed; | ||||||
|  |  | ||||||
|  | @ -435,10 +435,6 @@ namespace OpenSim | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected void ConnectToRemoteGridServer() |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         #endregion |         #endregion | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|  |  | ||||||
|  | @ -158,6 +158,16 @@ namespace OpenSim.Region.ClientStack | ||||||
|             ClientThread.Abort(); |             ClientThread.Abort(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public void Stop() | ||||||
|  |         { | ||||||
|  |             clientPingTimer.Stop(); | ||||||
|  | 
 | ||||||
|  |             libsecondlife.Packets.DisableSimulatorPacket disable = new libsecondlife.Packets.DisableSimulatorPacket(); | ||||||
|  |             OutPacket(disable); | ||||||
|  | 
 | ||||||
|  |             ClientThread.Abort(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         #endregion |         #endregion | ||||||
| 
 | 
 | ||||||
|         # region Packet Handling |         # region Packet Handling | ||||||
|  |  | ||||||
|  | @ -47,7 +47,7 @@ using OpenSim.Region.Environment.Scenes.Scripting; | ||||||
| using OpenSim.Region.Environment.Types; | using OpenSim.Region.Environment.Types; | ||||||
| using OpenSim.Region.Physics.Manager; | using OpenSim.Region.Physics.Manager; | ||||||
| using OpenSim.Region.Terrain; | using OpenSim.Region.Terrain; | ||||||
| using Timer=System.Timers.Timer; | using Timer = System.Timers.Timer; | ||||||
| 
 | 
 | ||||||
| namespace OpenSim.Region.Environment.Scenes | namespace OpenSim.Region.Environment.Scenes | ||||||
| { | { | ||||||
|  | @ -228,7 +228,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             m_sceneObjects = new Dictionary<LLUUID, SceneObjectGroup>(); |             m_sceneObjects = new Dictionary<LLUUID, SceneObjectGroup>(); | ||||||
| 
 | 
 | ||||||
|             MainLog.Instance.Verbose("Creating LandMap"); |             MainLog.Instance.Verbose("Creating LandMap"); | ||||||
|             Terrain = new TerrainEngine((int) RegionInfo.RegionLocX, (int) RegionInfo.RegionLocY); |             Terrain = new TerrainEngine((int)RegionInfo.RegionLocX, (int)RegionInfo.RegionLocY); | ||||||
| 
 | 
 | ||||||
|             ScenePresence.LoadAnims(); |             ScenePresence.LoadAnims(); | ||||||
| 
 | 
 | ||||||
|  | @ -241,11 +241,26 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|         #region Startup / Close Methods |         #region Startup / Close Methods | ||||||
|         public override void Close() |         public override void Close() | ||||||
|         { |         { | ||||||
|  |             ForEachScenePresence(delegate(ScenePresence avatar) | ||||||
|  |                                 { | ||||||
|  |                                     avatar.ControllingClient.Stop(); | ||||||
|  |                                 }); | ||||||
|  | 
 | ||||||
|             m_heartbeatTimer.Close(); |             m_heartbeatTimer.Close(); | ||||||
|             m_innerScene.Close(); |             m_innerScene.Close(); | ||||||
|             m_sceneGridService.Close(); |             m_sceneGridService.Close(); | ||||||
| 
 | 
 | ||||||
|  |             foreach (IRegionModule module in this.Modules.Values) | ||||||
|  |             { | ||||||
|  |                 if (!module.IsSharedModule) | ||||||
|  |                 { | ||||||
|  |                     module.Close(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             Modules.Clear(); | ||||||
|  | 
 | ||||||
|             base.Close(); |             base.Close(); | ||||||
|  | 
 | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|  | @ -299,30 +314,30 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|                 if (m_frame == Int32.MaxValue) |                 if (m_frame == Int32.MaxValue) | ||||||
|                     m_frame = 0; |                     m_frame = 0; | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_physics == 0) |                 if (m_frame % m_update_physics == 0) | ||||||
|                     m_innerScene.UpdatePreparePhysics(); |                     m_innerScene.UpdatePreparePhysics(); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_entitymovement == 0) |                 if (m_frame % m_update_entitymovement == 0) | ||||||
|                     m_innerScene.UpdateEntityMovement(); |                     m_innerScene.UpdateEntityMovement(); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_physics == 0) |                 if (m_frame % m_update_physics == 0) | ||||||
|                     m_innerScene.UpdatePhysics( |                     m_innerScene.UpdatePhysics( | ||||||
|                         Math.Max(SinceLastFrame.TotalSeconds, m_timespan) |                         Math.Max(SinceLastFrame.TotalSeconds, m_timespan) | ||||||
|                         ); |                         ); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_entities == 0) |                 if (m_frame % m_update_entities == 0) | ||||||
|                     m_innerScene.UpdateEntities(); |                     m_innerScene.UpdateEntities(); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_events == 0) |                 if (m_frame % m_update_events == 0) | ||||||
|                     UpdateEvents(); |                     UpdateEvents(); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_backup == 0) |                 if (m_frame % m_update_backup == 0) | ||||||
|                     UpdateStorageBackup(); |                     UpdateStorageBackup(); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_terrain == 0) |                 if (m_frame % m_update_terrain == 0) | ||||||
|                     UpdateTerrain(); |                     UpdateTerrain(); | ||||||
| 
 | 
 | ||||||
|                 if (m_frame%m_update_land == 0) |                 if (m_frame % m_update_land == 0) | ||||||
|                     UpdateLand(); |                     UpdateLand(); | ||||||
| 
 | 
 | ||||||
|                 // if (m_frame%m_update_avatars == 0) |                 // if (m_frame%m_update_avatars == 0) | ||||||
|  | @ -340,7 +355,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             { |             { | ||||||
|                 updateLock.ReleaseMutex(); |                 updateLock.ReleaseMutex(); | ||||||
| 
 | 
 | ||||||
|                 m_timedilation = m_timespan/(float) SinceLastFrame.TotalSeconds; |                 m_timedilation = m_timespan / (float)SinceLastFrame.TotalSeconds; | ||||||
|                 m_lastupdate = DateTime.Now; |                 m_lastupdate = DateTime.Now; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -397,7 +412,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|                                       { |                                       { | ||||||
|                                           for (int y = 0; y < 16; y++) |                                           for (int y = 0; y < 16; y++) | ||||||
|                                           { |                                           { | ||||||
|                                               if (Terrain.Tainted(x*16, y*16)) |                                               if (Terrain.Tainted(x * 16, y * 16)) | ||||||
|                                               { |                                               { | ||||||
|                                                   client.SendLayerData(x, y, terData); |                                                   client.SendLayerData(x, y, terData); | ||||||
|                                               } |                                               } | ||||||
|  | @ -524,7 +539,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|                 AddEntityFromStorage(prim); |                 AddEntityFromStorage(prim); | ||||||
|                 SceneObjectPart rootPart = prim.GetChildPart(prim.UUID); |                 SceneObjectPart rootPart = prim.GetChildPart(prim.UUID); | ||||||
|                 bool UsePhysics = (((rootPart.ObjectFlags & (uint)LLObject.ObjectFlags.Physics) > 0) && m_physicalPrim); |                 bool UsePhysics = (((rootPart.ObjectFlags & (uint)LLObject.ObjectFlags.Physics) > 0) && m_physicalPrim); | ||||||
|                 if ((rootPart.ObjectFlags & (uint) LLObject.ObjectFlags.Phantom) == 0) |                 if ((rootPart.ObjectFlags & (uint)LLObject.ObjectFlags.Phantom) == 0) | ||||||
|                     rootPart.PhysActor = phyScene.AddPrimShape( |                     rootPart.PhysActor = phyScene.AddPrimShape( | ||||||
|                         rootPart.Name, |                         rootPart.Name, | ||||||
|                         rootPart.Shape, |                         rootPart.Shape, | ||||||
|  | @ -570,11 +585,11 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|                 // if grass or tree, make phantom |                 // if grass or tree, make phantom | ||||||
|                 if ((rootPart.Shape.PCode == 95) || (rootPart.Shape.PCode == 255)) |                 if ((rootPart.Shape.PCode == 95) || (rootPart.Shape.PCode == 255)) | ||||||
|                 { |                 { | ||||||
|                     rootPart.ObjectFlags += (uint) LLObject.ObjectFlags.Phantom; |                     rootPart.ObjectFlags += (uint)LLObject.ObjectFlags.Phantom; | ||||||
|                 } |                 } | ||||||
|                 // if not phantom, add to physics |                 // if not phantom, add to physics | ||||||
|                 bool UsePhysics = (((rootPart.ObjectFlags & (uint)LLObject.ObjectFlags.Physics) > 0) && m_physicalPrim); |                 bool UsePhysics = (((rootPart.ObjectFlags & (uint)LLObject.ObjectFlags.Physics) > 0) && m_physicalPrim); | ||||||
|                 if ((rootPart.ObjectFlags & (uint) LLObject.ObjectFlags.Phantom) == 0) |                 if ((rootPart.ObjectFlags & (uint)LLObject.ObjectFlags.Phantom) == 0) | ||||||
|                     rootPart.PhysActor = |                     rootPart.PhysActor = | ||||||
|                         phyScene.AddPrimShape( |                         phyScene.AddPrimShape( | ||||||
|                             rootPart.Name, |                             rootPart.Name, | ||||||
|  | @ -668,7 +683,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             client.OnRegionHandShakeReply += SendLayerData; |             client.OnRegionHandShakeReply += SendLayerData; | ||||||
|             //remoteClient.OnRequestWearables += new GenericCall(this.GetInitialPrims); |             //remoteClient.OnRequestWearables += new GenericCall(this.GetInitialPrims); | ||||||
|             client.OnModifyTerrain += ModifyTerrain; |             client.OnModifyTerrain += ModifyTerrain; | ||||||
|            // client.OnRequestWearables += InformClientOfNeighbours; |             // client.OnRequestWearables += InformClientOfNeighbours; | ||||||
|             client.OnAddPrim += AddNewPrim; |             client.OnAddPrim += AddNewPrim; | ||||||
|             client.OnUpdatePrimGroupPosition += m_innerScene.UpdatePrimPosition; |             client.OnUpdatePrimGroupPosition += m_innerScene.UpdatePrimPosition; | ||||||
|             client.OnUpdatePrimSinglePosition += m_innerScene.UpdatePrimSinglePosition; |             client.OnUpdatePrimSinglePosition += m_innerScene.UpdatePrimSinglePosition; | ||||||
|  | @ -843,7 +858,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|                     if (m_capsHandlers.ContainsKey(agent.AgentID)) |                     if (m_capsHandlers.ContainsKey(agent.AgentID)) | ||||||
|                     { |                     { | ||||||
|                         //MainLog.Instance.Warn("client", "Adding duplicate CAPS entry for user " + |                         //MainLog.Instance.Warn("client", "Adding duplicate CAPS entry for user " + | ||||||
|                                                     //    agent.AgentID.ToStringHyphenated()); |                         //    agent.AgentID.ToStringHyphenated()); | ||||||
|                         m_capsHandlers[agent.AgentID] = cap; |                         m_capsHandlers[agent.AgentID] = cap; | ||||||
|                     } |                     } | ||||||
|                     else |                     else | ||||||
|  | @ -871,7 +886,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             if (regionHandle == m_regionHandle) |             if (regionHandle == m_regionHandle) | ||||||
|             { |             { | ||||||
|                 ScenePresence presence = m_innerScene.GetScenePresence(agentID); |                 ScenePresence presence = m_innerScene.GetScenePresence(agentID); | ||||||
|                 if(presence != null) |                 if (presence != null) | ||||||
|                 { |                 { | ||||||
|                     libsecondlife.Packets.DisableSimulatorPacket disable = new libsecondlife.Packets.DisableSimulatorPacket(); |                     libsecondlife.Packets.DisableSimulatorPacket disable = new libsecondlife.Packets.DisableSimulatorPacket(); | ||||||
|                     presence.ControllingClient.OutPacket(disable); |                     presence.ControllingClient.OutPacket(disable); | ||||||
|  | @ -951,17 +966,17 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
| 
 | 
 | ||||||
|         public void RegisterModuleInterface<M>(M mod) |         public void RegisterModuleInterface<M>(M mod) | ||||||
|         { |         { | ||||||
|             if (!ModuleInterfaces.ContainsKey(typeof (M))) |             if (!ModuleInterfaces.ContainsKey(typeof(M))) | ||||||
|             { |             { | ||||||
|                 ModuleInterfaces.Add(typeof (M), mod); |                 ModuleInterfaces.Add(typeof(M), mod); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public T RequestModuleInterface<T>() |         public T RequestModuleInterface<T>() | ||||||
|         { |         { | ||||||
|             if (ModuleInterfaces.ContainsKey(typeof (T))) |             if (ModuleInterfaces.ContainsKey(typeof(T))) | ||||||
|             { |             { | ||||||
|                 return (T) ModuleInterfaces[typeof (T)]; |                 return (T)ModuleInterfaces[typeof(T)]; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|  | @ -1073,7 +1088,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             { |             { | ||||||
|                 if (ent is SceneObjectGroup) |                 if (ent is SceneObjectGroup) | ||||||
|                 { |                 { | ||||||
|                     ((SceneObjectGroup) ent).ScheduleGroupForFullUpdate(); |                     ((SceneObjectGroup)ent).ScheduleGroupForFullUpdate(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -1085,7 +1100,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             { |             { | ||||||
|                 if (ent is SceneObjectGroup) |                 if (ent is SceneObjectGroup) | ||||||
|                 { |                 { | ||||||
|                     SceneObjectPart part = ((SceneObjectGroup) ent).GetChildPart(((SceneObjectGroup) ent).UUID); |                     SceneObjectPart part = ((SceneObjectGroup)ent).GetChildPart(((SceneObjectGroup)ent).UUID); | ||||||
|                     if (part != null) |                     if (part != null) | ||||||
|                     { |                     { | ||||||
|                         if (part.Name == cmmdparams[0]) |                         if (part.Name == cmmdparams[0]) | ||||||
|  |  | ||||||
|  | @ -179,6 +179,35 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public bool TryGetScene(string regionName, out Scene scene) | ||||||
|  |         { | ||||||
|  |             foreach (Scene mscene in m_localScenes) | ||||||
|  |             { | ||||||
|  |                 if (String.Compare(mscene.RegionInfo.RegionName, regionName, true) == 0) | ||||||
|  |                 { | ||||||
|  |                     scene = mscene; | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             scene = null; | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public bool TryGetScene(LLUUID regionID, out Scene scene) | ||||||
|  |         { | ||||||
|  |             foreach (Scene mscene in m_localScenes) | ||||||
|  |             { | ||||||
|  |                 if (mscene.RegionInfo.RegionID == regionID) | ||||||
|  |                 { | ||||||
|  |                     scene = mscene; | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             scene = null; | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|         public void SetDebugPacketOnCurrentScene(LogBase log, int newDebug) |         public void SetDebugPacketOnCurrentScene(LogBase log, int newDebug) | ||||||
|         { |         { | ||||||
|             ForEachCurrentScene(delegate(Scene scene) |             ForEachCurrentScene(delegate(Scene scene) | ||||||
|  |  | ||||||
|  | @ -1197,6 +1197,7 @@ namespace OpenSim.Region.Environment.Scenes | ||||||
|         { |         { | ||||||
|             m_wearables[wearableId] = wearable; |             m_wearables[wearableId] = wearable; | ||||||
|             SendOwnWearables(); |             SendOwnWearables(); | ||||||
|  |              | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void SendOwnWearables() |         private void SendOwnWearables() | ||||||
|  |  | ||||||
|  | @ -427,6 +427,11 @@ namespace SimpleApp | ||||||
|         { |         { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public void Stop() | ||||||
|  |         { | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         private uint m_circuitCode; |         private uint m_circuitCode; | ||||||
| 
 | 
 | ||||||
|         public uint CircuitCode |         public uint CircuitCode | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 MW
						MW