From 0428701da746df38ff7621b5c54f88afb0d48786 Mon Sep 17 00:00:00 2001 From: Justin Clarke Casey Date: Mon, 7 Jan 2008 22:32:10 +0000 Subject: Minor prim inventory method refactoring --- .../Scenes/SceneObjectGroup.Inventory.cs | 55 ++++++++-------------- 1 file changed, 20 insertions(+), 35 deletions(-) (limited to 'OpenSim/Region/Environment/Scenes/SceneObjectGroup.Inventory.cs') diff --git a/OpenSim/Region/Environment/Scenes/SceneObjectGroup.Inventory.cs b/OpenSim/Region/Environment/Scenes/SceneObjectGroup.Inventory.cs index fb09932..b72d743 100644 --- a/OpenSim/Region/Environment/Scenes/SceneObjectGroup.Inventory.cs +++ b/OpenSim/Region/Environment/Scenes/SceneObjectGroup.Inventory.cs @@ -109,20 +109,32 @@ namespace OpenSim.Region.Environment.Scenes } } - public bool AddInventoryItem(IClientAPI remoteClient, uint localID, InventoryItemBase item) + /// + /// Add an inventory item to a prim in this group. + /// + /// + /// + /// + /// The item UUID that should be used by the new item. + /// + public bool AddInventoryItem(IClientAPI remoteClient, uint localID, + InventoryItemBase item, LLUUID copyItemID) { + LLUUID newItemId = ((copyItemID != null) ? copyItemID : item.inventoryID); + SceneObjectPart part = GetChildPart(localID); if (part != null) { TaskInventoryItem taskItem = new TaskInventoryItem(); - taskItem.item_id = item.inventoryID; + + taskItem.item_id = newItemId; taskItem.asset_id = item.assetID; taskItem.name = item.inventoryName; taskItem.desc = item.inventoryDescription; taskItem.owner_id = item.avatarID; taskItem.creator_id = item.creatorsID; taskItem.type = TaskInventoryItem.Types[item.assetType]; - taskItem.inv_type = TaskInventoryItem.Types[item.invType]; + taskItem.inv_type = TaskInventoryItem.InvTypes[item.invType]; part.AddInventoryItem(taskItem); // It might seem somewhat crude to update the whole group for a single prim inventory change, @@ -134,41 +146,14 @@ namespace OpenSim.Region.Environment.Scenes return true; } - return false; - } - - public bool AddInventoryItem(IClientAPI remoteClient, uint localID, InventoryItemBase item, LLUUID copyItemID) - { - if (copyItemID != LLUUID.Zero) - { - SceneObjectPart part = GetChildPart(localID); - if (part != null) - { - TaskInventoryItem taskItem = new TaskInventoryItem(); - taskItem.item_id = copyItemID; - taskItem.asset_id = item.assetID; - taskItem.name = item.inventoryName; - taskItem.desc = item.inventoryDescription; - taskItem.owner_id = new LLUUID(item.avatarID.ToString()); - taskItem.creator_id = new LLUUID(item.creatorsID.ToString()); - taskItem.type = TaskInventoryItem.Types[item.assetType]; - taskItem.inv_type = TaskInventoryItem.InvTypes[item.invType]; - part.AddInventoryItem(taskItem); - - // It might seem somewhat crude to update the whole group for a single prim inventory change, - // but it's possible that other prim inventory changes will take place before the region - // persistence thread visits this object. In the future, changes can be signalled at a more - // granular level, or we could let the datastore worry about whether prims have really - // changed since they were last persisted. - HasChanged = true; - - return true; - } - } else { - return AddInventoryItem(remoteClient, localID, item); + MainLog.Instance.Error( + "PRIMINVENTORY", + "Couldn't find prim local ID {0} in group {1}, {2} to add inventory item ID {3}", + localID, Name, UUID, newItemId); } + return false; } -- cgit v1.1