Merge branch 'master' into careminster-presence-refactor
commit
ccf63a9c63
|
@ -75,6 +75,9 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
if (name == Name)
|
if (name == Name)
|
||||||
{
|
{
|
||||||
m_Enabled = true;
|
m_Enabled = true;
|
||||||
|
|
||||||
|
InitialiseCommon(source);
|
||||||
|
|
||||||
m_log.InfoFormat("[HG INVENTORY ACCESS MODULE]: {0} enabled.", Name);
|
m_log.InfoFormat("[HG INVENTORY ACCESS MODULE]: {0} enabled.", Name);
|
||||||
|
|
||||||
IConfig thisModuleConfig = source.Configs["HGInventoryAccessModule"];
|
IConfig thisModuleConfig = source.Configs["HGInventoryAccessModule"];
|
||||||
|
|
|
@ -64,7 +64,8 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
return m_UserManagement;
|
return m_UserManagement;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool CoalesceMultipleObjectsToInventory { get; set; }
|
||||||
|
|
||||||
#region INonSharedRegionModule
|
#region INonSharedRegionModule
|
||||||
|
|
||||||
|
@ -87,10 +88,28 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
if (name == Name)
|
if (name == Name)
|
||||||
{
|
{
|
||||||
m_Enabled = true;
|
m_Enabled = true;
|
||||||
m_log.InfoFormat("[INVENTORY ACCESS MODULE]: {0} enabled.", Name);
|
|
||||||
|
InitialiseCommon(source);
|
||||||
|
|
||||||
|
m_log.InfoFormat("[INVENTORY ACCESS MODULE]: {0} enabled.", Name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Common module config for both this and descendant classes.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="source"></param>
|
||||||
|
protected virtual void InitialiseCommon(IConfigSource source)
|
||||||
|
{
|
||||||
|
IConfig inventoryConfig = source.Configs["Inventory"];
|
||||||
|
|
||||||
|
if (inventoryConfig != null)
|
||||||
|
CoalesceMultipleObjectsToInventory
|
||||||
|
= inventoryConfig.GetBoolean("CoalesceMultipleObjectsToInventory", true);
|
||||||
|
else
|
||||||
|
CoalesceMultipleObjectsToInventory = true;
|
||||||
|
}
|
||||||
|
|
||||||
public virtual void PostInitialise()
|
public virtual void PostInitialise()
|
||||||
{
|
{
|
||||||
|
@ -206,20 +225,30 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
public virtual UUID DeleteToInventory(DeRezAction action, UUID folderID,
|
public virtual UUID DeleteToInventory(DeRezAction action, UUID folderID,
|
||||||
List<SceneObjectGroup> objectGroups, IClientAPI remoteClient)
|
List<SceneObjectGroup> objectGroups, IClientAPI remoteClient)
|
||||||
{
|
{
|
||||||
UUID ret = UUID.Zero;
|
Dictionary<UUID, List<SceneObjectGroup>> deletes = new Dictionary<UUID, List<SceneObjectGroup>>();
|
||||||
|
|
||||||
// The following code groups the SOG's by owner. No objects
|
if (CoalesceMultipleObjectsToInventory)
|
||||||
// belonging to different people can be coalesced, for obvious
|
|
||||||
// reasons.
|
|
||||||
Dictionary<UUID, List<SceneObjectGroup>> deletes =
|
|
||||||
new Dictionary<UUID, List<SceneObjectGroup>>();
|
|
||||||
|
|
||||||
foreach (SceneObjectGroup g in objectGroups)
|
|
||||||
{
|
{
|
||||||
if (!deletes.ContainsKey(g.OwnerID))
|
// The following code groups the SOG's by owner. No objects
|
||||||
deletes[g.OwnerID] = new List<SceneObjectGroup>();
|
// belonging to different people can be coalesced, for obvious
|
||||||
|
// reasons.
|
||||||
deletes[g.OwnerID].Add(g);
|
foreach (SceneObjectGroup g in objectGroups)
|
||||||
|
{
|
||||||
|
if (!deletes.ContainsKey(g.OwnerID))
|
||||||
|
deletes[g.OwnerID] = new List<SceneObjectGroup>();
|
||||||
|
|
||||||
|
deletes[g.OwnerID].Add(g);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// If we don't want to coalesce then put every object in its own bundle.
|
||||||
|
foreach (SceneObjectGroup g in objectGroups)
|
||||||
|
{
|
||||||
|
List<SceneObjectGroup> bundle = new List<SceneObjectGroup>();
|
||||||
|
bundle.Add(g);
|
||||||
|
deletes[g.UUID] = bundle;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is pethod scoped and will be returned. It will be the
|
// This is pethod scoped and will be returned. It will be the
|
||||||
|
@ -240,9 +269,9 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
? 250
|
? 250
|
||||||
: objectGroup.AbsolutePosition.X)
|
: objectGroup.AbsolutePosition.X)
|
||||||
,
|
,
|
||||||
(objectGroup.AbsolutePosition.X > (int)Constants.RegionSize)
|
(objectGroup.AbsolutePosition.Y > (int)Constants.RegionSize)
|
||||||
? 250
|
? 250
|
||||||
: objectGroup.AbsolutePosition.X,
|
: objectGroup.AbsolutePosition.Y,
|
||||||
objectGroup.AbsolutePosition.Z);
|
objectGroup.AbsolutePosition.Z);
|
||||||
|
|
||||||
Vector3 originalPosition = objectGroup.AbsolutePosition;
|
Vector3 originalPosition = objectGroup.AbsolutePosition;
|
||||||
|
|
|
@ -453,6 +453,13 @@
|
||||||
; ForwardOfflineGroupMessages = true
|
; ForwardOfflineGroupMessages = true
|
||||||
|
|
||||||
|
|
||||||
|
[Inventory]
|
||||||
|
; Control whether multiple objects sent to inventory should be coaleseced into a single item
|
||||||
|
; There are still some issues with coalescence, including the fact that rotation is not restored
|
||||||
|
; and some assets may be missing from archive files.
|
||||||
|
CoalesceMultipleObjectsToInventory = true
|
||||||
|
|
||||||
|
|
||||||
[ODEPhysicsSettings]
|
[ODEPhysicsSettings]
|
||||||
;##
|
;##
|
||||||
;## World Settings
|
;## World Settings
|
||||||
|
|
Loading…
Reference in New Issue