diff options
Diffstat (limited to 'OpenSim/Region/Framework/Scenes/Scene.cs')
-rwxr-xr-x | OpenSim/Region/Framework/Scenes/Scene.cs | 31 |
1 files changed, 21 insertions, 10 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs index 55c4fda..8bdf39a 100755 --- a/OpenSim/Region/Framework/Scenes/Scene.cs +++ b/OpenSim/Region/Framework/Scenes/Scene.cs | |||
@@ -174,6 +174,13 @@ namespace OpenSim.Region.Framework.Scenes | |||
174 | 174 | ||
175 | public SynchronizeSceneHandler SynchronizeScene; | 175 | public SynchronizeSceneHandler SynchronizeScene; |
176 | 176 | ||
177 | public bool ClampNegativeZ | ||
178 | { | ||
179 | get { return m_clampNegativeZ; } | ||
180 | } | ||
181 | |||
182 | private bool m_clampNegativeZ = false; | ||
183 | |||
177 | /// <summary> | 184 | /// <summary> |
178 | /// Used to prevent simultaneous calls to code that adds and removes agents. | 185 | /// Used to prevent simultaneous calls to code that adds and removes agents. |
179 | /// </summary> | 186 | /// </summary> |
@@ -524,11 +531,11 @@ namespace OpenSim.Region.Framework.Scenes | |||
524 | // private int m_lastUpdate; | 531 | // private int m_lastUpdate; |
525 | private bool m_firstHeartbeat = true; | 532 | private bool m_firstHeartbeat = true; |
526 | 533 | ||
527 | private UpdatePrioritizationSchemes m_priorityScheme = UpdatePrioritizationSchemes.Time; | 534 | // private UpdatePrioritizationSchemes m_priorityScheme = UpdatePrioritizationSchemes.Time; |
528 | private bool m_reprioritizationEnabled = true; | 535 | // private bool m_reprioritizationEnabled = true; |
529 | private double m_reprioritizationInterval = 5000.0; | 536 | // private double m_reprioritizationInterval = 5000.0; |
530 | private double m_rootReprioritizationDistance = 10.0; | 537 | // private double m_rootReprioritizationDistance = 10.0; |
531 | private double m_childReprioritizationDistance = 20.0; | 538 | // private double m_childReprioritizationDistance = 20.0; |
532 | 539 | ||
533 | 540 | ||
534 | private Timer m_mapGenerationTimer = new Timer(); | 541 | private Timer m_mapGenerationTimer = new Timer(); |
@@ -1029,6 +1036,8 @@ namespace OpenSim.Region.Framework.Scenes | |||
1029 | m_clampPrimSize = true; | 1036 | m_clampPrimSize = true; |
1030 | } | 1037 | } |
1031 | 1038 | ||
1039 | m_clampNegativeZ = startupConfig.GetBoolean("ClampNegativeZ", m_clampNegativeZ); | ||
1040 | |||
1032 | m_useTrashOnDelete = startupConfig.GetBoolean("UseTrashOnDelete",m_useTrashOnDelete); | 1041 | m_useTrashOnDelete = startupConfig.GetBoolean("UseTrashOnDelete",m_useTrashOnDelete); |
1033 | m_trustBinaries = startupConfig.GetBoolean("TrustBinaries", m_trustBinaries); | 1042 | m_trustBinaries = startupConfig.GetBoolean("TrustBinaries", m_trustBinaries); |
1034 | m_allowScriptCrossings = startupConfig.GetBoolean("AllowScriptCrossing", m_allowScriptCrossings); | 1043 | m_allowScriptCrossings = startupConfig.GetBoolean("AllowScriptCrossing", m_allowScriptCrossings); |
@@ -1472,11 +1481,14 @@ namespace OpenSim.Region.Framework.Scenes | |||
1472 | 1481 | ||
1473 | m_log.InfoFormat("[SCENE]: Closing down the single simulator: {0}", RegionInfo.RegionName); | 1482 | m_log.InfoFormat("[SCENE]: Closing down the single simulator: {0}", RegionInfo.RegionName); |
1474 | 1483 | ||
1475 | StatsReporter.Close(); | ||
1476 | 1484 | ||
1485 | StatsReporter.Close(); | ||
1477 | m_restartTimer.Stop(); | 1486 | m_restartTimer.Stop(); |
1478 | m_restartTimer.Close(); | 1487 | m_restartTimer.Close(); |
1479 | 1488 | ||
1489 | if (!GridService.DeregisterRegion(RegionInfo.RegionID)) | ||
1490 | m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", Name); | ||
1491 | |||
1480 | // Kick all ROOT agents with the message, 'The simulator is going down' | 1492 | // Kick all ROOT agents with the message, 'The simulator is going down' |
1481 | ForEachScenePresence(delegate(ScenePresence avatar) | 1493 | ForEachScenePresence(delegate(ScenePresence avatar) |
1482 | { | 1494 | { |
@@ -1503,13 +1515,10 @@ namespace OpenSim.Region.Framework.Scenes | |||
1503 | EventManager.TriggerSceneShuttingDown(this); | 1515 | EventManager.TriggerSceneShuttingDown(this); |
1504 | 1516 | ||
1505 | m_log.Debug("[SCENE]: Persisting changed objects"); | 1517 | m_log.Debug("[SCENE]: Persisting changed objects"); |
1518 | Backup(true); | ||
1506 | 1519 | ||
1507 | Backup(false); | ||
1508 | m_sceneGraph.Close(); | 1520 | m_sceneGraph.Close(); |
1509 | 1521 | ||
1510 | if (!GridService.DeregisterRegion(RegionInfo.RegionID)) | ||
1511 | m_log.WarnFormat("[SCENE]: Deregister from grid failed for region {0}", Name); | ||
1512 | |||
1513 | base.Close(); | 1522 | base.Close(); |
1514 | 1523 | ||
1515 | // XEngine currently listens to the EventManager.OnShutdown event to trigger script stop and persistence. | 1524 | // XEngine currently listens to the EventManager.OnShutdown event to trigger script stop and persistence. |
@@ -1619,6 +1628,8 @@ namespace OpenSim.Region.Framework.Scenes | |||
1619 | Watchdog.GetCurrentThreadInfo().AlarmIfTimeout = true; | 1628 | Watchdog.GetCurrentThreadInfo().AlarmIfTimeout = true; |
1620 | m_lastFrameTick = Util.EnvironmentTickCount(); | 1629 | m_lastFrameTick = Util.EnvironmentTickCount(); |
1621 | Update(-1); | 1630 | Update(-1); |
1631 | |||
1632 | Watchdog.RemoveThread(); | ||
1622 | } | 1633 | } |
1623 | 1634 | ||
1624 | private void Maintenance() | 1635 | private void Maintenance() |