Added checking if PhysActor is null or not in passing list of updated properties, especially for code (e.g. ScheduleGroupForTerseUpdate) that
pass SceneObjectPartSyncProperties.Orientation as an updated property.dsg
parent
9f6c0e7622
commit
c979fdd3cb
|
@ -3581,41 +3581,25 @@ namespace OpenSim.Region.CoreModules.RegionSync.RegionSyncModule
|
||||||
if (part.ParentGroup == null || part.ParentGroup.IsDeleted)
|
if (part.ParentGroup == null || part.ParentGroup.IsDeleted)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
//Do some sanity checking of the properties
|
||||||
|
List<SceneObjectPartSyncProperties> checkedUpdatedProperties = new List<SceneObjectPartSyncProperties>();
|
||||||
|
foreach (SceneObjectPartSyncProperties property in updatedProperties)
|
||||||
|
{
|
||||||
|
if (PrimSyncInfo.PrimPhysActorProperties.Contains(property) && part.PhysActor == null)
|
||||||
|
{
|
||||||
|
m_log.WarnFormat("ProcessAndEnqueuePrimUpdatesByLocal: informed that property {0} changed in {1},{2}, which does not have PhysActor yet. Wrong property passed in!!!",
|
||||||
|
property, part.Name, part.UUID);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
checkedUpdatedProperties.Add(property);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//Sync values with SOP's data and update timestamp according, to
|
//Sync values with SOP's data and update timestamp according, to
|
||||||
//obtain the list of properties that really have been updated
|
//obtain the list of properties that really have been updated
|
||||||
//and should be propogated to other sync nodes.
|
//and should be propogated to other sync nodes.
|
||||||
HashSet<SceneObjectPartSyncProperties> propertiesWithSyncInfoUpdated = m_primSyncInfoManager.UpdatePrimSyncInfoByLocal(part, updatedProperties);
|
HashSet<SceneObjectPartSyncProperties> propertiesWithSyncInfoUpdated = m_primSyncInfoManager.UpdatePrimSyncInfoByLocal(part, checkedUpdatedProperties);
|
||||||
|
|
||||||
/* //Below is done at SOG level, not here (TO DOUBLE CHECK)
|
|
||||||
//For group properties, we only need to send it once per SOG,
|
|
||||||
//hence only enqueue it with root part
|
|
||||||
foreach (SceneObjectPartSyncProperties groupProperty in SceneObjectPart.GetGroupProperties())
|
|
||||||
{
|
|
||||||
if (propertiesWithSyncInfoUpdated.Contains(groupProperty))
|
|
||||||
{
|
|
||||||
SceneObjectPart rootpart = part.ParentGroup.RootPart;
|
|
||||||
if (m_primPropertyUpdates.ContainsKey(rootpart.UUID))
|
|
||||||
{
|
|
||||||
m_primPropertyUpdates[rootpart.UUID].Add(groupProperty);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_primPropertyUpdates.Add(rootpart.UUID, new HashSet<SceneObjectPartSyncProperties>() { groupProperty });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
propertiesWithSyncInfoUpdated.Remove(groupProperty);
|
|
||||||
}
|
|
||||||
* */
|
|
||||||
|
|
||||||
/*
|
|
||||||
if(updatedProperties.Contains(SceneObjectPartSyncProperties.Shape))
|
|
||||||
{
|
|
||||||
string hashedShape = Util.Md5Hash((PropertySerializer.SerializeShape(part)));
|
|
||||||
m_log.DebugFormat("ProcessAndEnqueuePrimUpdatesByLocal: Shape of SOP {0}, {1} updated, ProfileShape {2}, hashed value in SOP: {3}, in PrimSyncInfoManager: {4}",
|
|
||||||
part.Name, part.UUID, part.Shape.ProfileShape, hashedShape, m_primSyncInfoManager.GetPrimSyncInfo(part.UUID).PropertiesSyncInfo[SceneObjectPartSyncProperties.Shape].LastUpdateValueHash);
|
|
||||||
}
|
|
||||||
* */
|
|
||||||
|
|
||||||
|
|
||||||
//Enqueue the prim with the set of updated properties, excluding the group properties
|
//Enqueue the prim with the set of updated properties, excluding the group properties
|
||||||
if (propertiesWithSyncInfoUpdated.Count > 0)
|
if (propertiesWithSyncInfoUpdated.Count > 0)
|
||||||
|
@ -4927,10 +4911,10 @@ namespace OpenSim.Region.CoreModules.RegionSync.RegionSyncModule
|
||||||
}
|
}
|
||||||
|
|
||||||
private Object m_primSyncInfoLock = new Object();
|
private Object m_primSyncInfoLock = new Object();
|
||||||
private static HashSet<SceneObjectPartSyncProperties> FullSetPrimProperties = SceneObjectPart.GetAllPrimProperties();
|
public static HashSet<SceneObjectPartSyncProperties> FullSetPrimProperties = SceneObjectPart.GetAllPrimProperties();
|
||||||
private static HashSet<SceneObjectPartSyncProperties> PrimPhysActorProperties = SceneObjectPart.GetAllPhysActorProperties();
|
public static HashSet<SceneObjectPartSyncProperties> PrimPhysActorProperties = SceneObjectPart.GetAllPhysActorProperties();
|
||||||
private static HashSet<SceneObjectPartSyncProperties> PrimNonPhysActorProperties = SceneObjectPart.GetAllPrimNonPhysActorProperties();
|
public static HashSet<SceneObjectPartSyncProperties> PrimNonPhysActorProperties = SceneObjectPart.GetAllPrimNonPhysActorProperties();
|
||||||
private static HashSet<SceneObjectPartSyncProperties> GroupProperties = SceneObjectPart.GetGroupProperties();
|
public static HashSet<SceneObjectPartSyncProperties> GroupProperties = SceneObjectPart.GetGroupProperties();
|
||||||
|
|
||||||
private PrimSyncInfoManager m_syncInfoManager;
|
private PrimSyncInfoManager m_syncInfoManager;
|
||||||
|
|
||||||
|
|
|
@ -3048,7 +3048,17 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
HasGroupChanged = true;
|
HasGroupChanged = true;
|
||||||
//ScheduleGroupForTerseUpdate();
|
//ScheduleGroupForTerseUpdate();
|
||||||
ScheduleGroupForTerseUpdate(new List<SceneObjectPartSyncProperties>(){SceneObjectPartSyncProperties.Orientation}); //Above actions only update m_rootPart's RotationOffset, and m_rootPart.UpdateRotation will taint RotationOffset as updated
|
//DSG SYNC
|
||||||
|
//Above actions only update m_rootPart's RotationOffset, and m_rootPart.UpdateRotation will taint RotationOffset as updated
|
||||||
|
if (actor != null)
|
||||||
|
{
|
||||||
|
ScheduleGroupForTerseUpdate(new List<SceneObjectPartSyncProperties>() {SceneObjectPartSyncProperties.RotationOffset, SceneObjectPartSyncProperties.Orientation });
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ScheduleGroupForTerseUpdate(new List<SceneObjectPartSyncProperties>() { SceneObjectPartSyncProperties.RotationOffset });
|
||||||
|
}
|
||||||
|
//end DSG SYNC
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -3074,8 +3084,17 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
AbsolutePosition = pos;
|
AbsolutePosition = pos;
|
||||||
|
|
||||||
HasGroupChanged = true;
|
HasGroupChanged = true;
|
||||||
|
//DSG SYNC
|
||||||
//ScheduleGroupForTerseUpdate();
|
//ScheduleGroupForTerseUpdate();
|
||||||
ScheduleGroupForTerseUpdate(new List<SceneObjectPartSyncProperties>(){SceneObjectPartSyncProperties.Position, SceneObjectPartSyncProperties.Orientation}); //RotationOffset is only updated for m_rootPart, and m_rootPart.UpdateRotation should already taint RotationOffset as updated
|
if (actor != null)
|
||||||
|
{
|
||||||
|
//RotationOffset is only updated for m_rootPart, and m_rootPart.UpdateRotation should already taint RotationOffset as updated
|
||||||
|
ScheduleGroupForTerseUpdate(new List<SceneObjectPartSyncProperties>() { SceneObjectPartSyncProperties.Position, SceneObjectPartSyncProperties.Orientation });
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ScheduleGroupForTerseUpdate(new List<SceneObjectPartSyncProperties>() { SceneObjectPartSyncProperties.Position });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|
Loading…
Reference in New Issue