* If an individual scene object throws an exception while storing, deal with this locally rather than letting it propogate up the stack
* This will allow other scene objects to persist and stop the exception taking down the whole region server0.6.0-stable
parent
0b52453762
commit
ec4189b722
|
@ -885,7 +885,6 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
{
|
||||
EventManager.TriggerOnBackup(m_storageManager.DataStore);
|
||||
m_backingup = false;
|
||||
//return true;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
|
|
@ -1124,10 +1124,14 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
#region Events
|
||||
|
||||
/// <summary>
|
||||
/// Processes backup
|
||||
/// Processes backup.
|
||||
/// </summary>
|
||||
/// <param name="datastore"></param>
|
||||
public void ProcessBackup(IRegionDataStore datastore)
|
||||
{
|
||||
// Since this is the top of the section of call stack for backing up a particular scene object, don't let
|
||||
// any exception propogate upwards.
|
||||
try
|
||||
{
|
||||
if (HasGroupChanged)
|
||||
{
|
||||
|
@ -1135,7 +1139,7 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
if ((!IsSelected) && (RootPart != null))
|
||||
{
|
||||
m_log.InfoFormat(
|
||||
"[SCENE]: Storing object {0}, {1} in {2}",
|
||||
"[SCENE]: Storing {0}, {1} in {2}",
|
||||
Name, UUID, m_scene.RegionInfo.RegionName);
|
||||
|
||||
SceneObjectGroup backup_group = Copy(OwnerID, GroupID, false);
|
||||
|
@ -1159,6 +1163,13 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
// }
|
||||
}
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
m_log.ErrorFormat(
|
||||
"[SCENE]: Storing of {0}, {1} in {2} failed with exception {3}",
|
||||
Name, UUID, m_scene.RegionInfo.RegionName, e);
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
|
|
Loading…
Reference in New Issue