diff options
Diffstat (limited to 'OpenSim/Region/Framework/Scenes/Scene.cs')
-rw-r--r-- | OpenSim/Region/Framework/Scenes/Scene.cs | 44 |
1 files changed, 38 insertions, 6 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs index 41fd1e1..ab0d397 100644 --- a/OpenSim/Region/Framework/Scenes/Scene.cs +++ b/OpenSim/Region/Framework/Scenes/Scene.cs | |||
@@ -539,6 +539,8 @@ namespace OpenSim.Region.Framework.Scenes | |||
539 | 539 | ||
540 | // Load region settings | 540 | // Load region settings |
541 | m_regInfo.RegionSettings = m_storageManager.DataStore.LoadRegionSettings(m_regInfo.RegionID); | 541 | m_regInfo.RegionSettings = m_storageManager.DataStore.LoadRegionSettings(m_regInfo.RegionID); |
542 | m_regInfo.WindlightSettings = m_storageManager.DataStore.LoadRegionWindlightSettings(m_regInfo.RegionID); | ||
543 | |||
542 | if (m_storageManager.EstateDataStore != null) | 544 | if (m_storageManager.EstateDataStore != null) |
543 | { | 545 | { |
544 | m_regInfo.EstateSettings = m_storageManager.EstateDataStore.LoadEstateSettings(m_regInfo.RegionID); | 546 | m_regInfo.EstateSettings = m_storageManager.EstateDataStore.LoadEstateSettings(m_regInfo.RegionID); |
@@ -886,6 +888,15 @@ namespace OpenSim.Region.Framework.Scenes | |||
886 | /// <param name="seconds">float indicating duration before restart.</param> | 888 | /// <param name="seconds">float indicating duration before restart.</param> |
887 | public virtual void Restart(float seconds) | 889 | public virtual void Restart(float seconds) |
888 | { | 890 | { |
891 | Restart(seconds, true); | ||
892 | } | ||
893 | |||
894 | /// <summary> | ||
895 | /// Given float seconds, this will restart the region. showDialog will optionally alert the users. | ||
896 | /// </summary> | ||
897 | /// <param name="seconds">float indicating duration before restart.</param> | ||
898 | public virtual void Restart(float seconds, bool showDialog) | ||
899 | { | ||
889 | // notifications are done in 15 second increments | 900 | // notifications are done in 15 second increments |
890 | // so .. if the number of seconds is less then 15 seconds, it's not really a restart request | 901 | // so .. if the number of seconds is less then 15 seconds, it's not really a restart request |
891 | // It's a 'Cancel restart' request. | 902 | // It's a 'Cancel restart' request. |
@@ -906,8 +917,11 @@ namespace OpenSim.Region.Framework.Scenes | |||
906 | m_restartTimer.Elapsed += new ElapsedEventHandler(RestartTimer_Elapsed); | 917 | m_restartTimer.Elapsed += new ElapsedEventHandler(RestartTimer_Elapsed); |
907 | m_log.Info("[REGION]: Restarting Region in " + (seconds / 60) + " minutes"); | 918 | m_log.Info("[REGION]: Restarting Region in " + (seconds / 60) + " minutes"); |
908 | m_restartTimer.Start(); | 919 | m_restartTimer.Start(); |
909 | m_dialogModule.SendNotificationToUsersInRegion( | 920 | if (showDialog) |
921 | { | ||
922 | m_dialogModule.SendNotificationToUsersInRegion( | ||
910 | UUID.Random(), String.Empty, RegionInfo.RegionName + String.Format(": Restarting in {0} Minutes", (int)(seconds / 60.0))); | 923 | UUID.Random(), String.Empty, RegionInfo.RegionName + String.Format(": Restarting in {0} Minutes", (int)(seconds / 60.0))); |
924 | } | ||
911 | } | 925 | } |
912 | } | 926 | } |
913 | 927 | ||
@@ -1189,16 +1203,16 @@ namespace OpenSim.Region.Framework.Scenes | |||
1189 | // Check if any objects have reached their targets | 1203 | // Check if any objects have reached their targets |
1190 | CheckAtTargets(); | 1204 | CheckAtTargets(); |
1191 | 1205 | ||
1192 | // Update SceneObjectGroups that have scheduled themselves for updates | ||
1193 | // Objects queue their updates onto all scene presences | ||
1194 | if (m_frame % m_update_objects == 0) | ||
1195 | m_sceneGraph.UpdateObjectGroups(); | ||
1196 | |||
1197 | // Run through all ScenePresences looking for updates | 1206 | // Run through all ScenePresences looking for updates |
1198 | // Presence updates and queued object updates for each presence are sent to clients | 1207 | // Presence updates and queued object updates for each presence are sent to clients |
1199 | if (m_frame % m_update_presences == 0) | 1208 | if (m_frame % m_update_presences == 0) |
1200 | m_sceneGraph.UpdatePresences(); | 1209 | m_sceneGraph.UpdatePresences(); |
1201 | 1210 | ||
1211 | // Update SceneObjectGroups that have scheduled themselves for updates | ||
1212 | // Objects queue their updates onto all scene presences | ||
1213 | if (m_frame % m_update_objects == 0) | ||
1214 | m_sceneGraph.UpdateObjectGroups(); | ||
1215 | |||
1202 | int tmpPhysicsMS2 = Util.EnvironmentTickCount(); | 1216 | int tmpPhysicsMS2 = Util.EnvironmentTickCount(); |
1203 | if ((m_frame % m_update_physics == 0) && m_physics_enabled) | 1217 | if ((m_frame % m_update_physics == 0) && m_physics_enabled) |
1204 | m_sceneGraph.UpdatePreparePhysics(); | 1218 | m_sceneGraph.UpdatePreparePhysics(); |
@@ -1509,6 +1523,19 @@ namespace OpenSim.Region.Framework.Scenes | |||
1509 | public void SaveTerrain() | 1523 | public void SaveTerrain() |
1510 | { | 1524 | { |
1511 | m_storageManager.DataStore.StoreTerrain(Heightmap.GetDoubles(), RegionInfo.RegionID); | 1525 | m_storageManager.DataStore.StoreTerrain(Heightmap.GetDoubles(), RegionInfo.RegionID); |
1526 | } | ||
1527 | |||
1528 | public void StoreWindlightProfile(RegionMeta7WindlightData wl) | ||
1529 | { | ||
1530 | m_regInfo.WindlightSettings = wl; | ||
1531 | m_storageManager.DataStore.StoreRegionWindlightSettings(wl); | ||
1532 | m_eventManager.TriggerOnSaveNewWindlightProfile(); | ||
1533 | } | ||
1534 | |||
1535 | public void LoadWindlightProfile() | ||
1536 | { | ||
1537 | m_regInfo.WindlightSettings = m_storageManager.DataStore.LoadRegionWindlightSettings(RegionInfo.RegionID); | ||
1538 | m_eventManager.TriggerOnSaveNewWindlightProfile(); | ||
1512 | } | 1539 | } |
1513 | 1540 | ||
1514 | /// <summary> | 1541 | /// <summary> |
@@ -3426,6 +3453,9 @@ namespace OpenSim.Region.Framework.Scenes | |||
3426 | 3453 | ||
3427 | CapsModule.AddCapsHandler(agent.AgentID); | 3454 | CapsModule.AddCapsHandler(agent.AgentID); |
3428 | 3455 | ||
3456 | if ((teleportFlags & ((uint)TeleportFlags.ViaLandmark | (uint)TeleportFlags.ViaLocation | (uint)TeleportFlags.ViaLandmark | (uint)TeleportFlags.Default)) != 0) | ||
3457 | System.Threading.Thread.Sleep(2000); | ||
3458 | |||
3429 | if (!agent.child) | 3459 | if (!agent.child) |
3430 | { | 3460 | { |
3431 | if (TestBorderCross(agent.startpos,Cardinals.E)) | 3461 | if (TestBorderCross(agent.startpos,Cardinals.E)) |
@@ -3484,6 +3514,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
3484 | } | 3514 | } |
3485 | } | 3515 | } |
3486 | // Honor parcel landing type and position. | 3516 | // Honor parcel landing type and position. |
3517 | /* | ||
3487 | ILandObject land = LandChannel.GetLandObject(agent.startpos.X, agent.startpos.Y); | 3518 | ILandObject land = LandChannel.GetLandObject(agent.startpos.X, agent.startpos.Y); |
3488 | if (land != null) | 3519 | if (land != null) |
3489 | { | 3520 | { |
@@ -3492,6 +3523,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
3492 | agent.startpos = land.LandData.UserLocation; | 3523 | agent.startpos = land.LandData.UserLocation; |
3493 | } | 3524 | } |
3494 | } | 3525 | } |
3526 | */// This is now handled properly in ScenePresence.MakeRootAgent | ||
3495 | } | 3527 | } |
3496 | 3528 | ||
3497 | m_authenticateHandler.AddNewCircuit(agent.circuitcode, agent); | 3529 | m_authenticateHandler.AddNewCircuit(agent.circuitcode, agent); |