* Refactor GetUsersInventory()

0.6.0-stable
Justin Clarke Casey 2008-04-10 16:04:19 +00:00
parent f565f44d89
commit 5ad4c79a4e
3 changed files with 36 additions and 12 deletions

View File

@ -85,8 +85,8 @@ namespace OpenSim.Framework.Communications
/// Returns a list of all the folders in a given user's inventory. /// Returns a list of all the folders in a given user's inventory.
/// </summary> /// </summary>
/// <param name="userId"></param> /// <param name="userId"></param>
/// <returns>A flat list of the user's inventory folder tree. /// <returns>A flat list of the user's inventory folder tree,
/// Null if there is no inventory for this user</returns> /// null if there is no inventory for this user</returns>
List<InventoryFolderBase> GetInventorySkeleton(LLUUID userId); List<InventoryFolderBase> GetInventorySkeleton(LLUUID userId);
} }
} }

View File

@ -141,7 +141,7 @@ namespace OpenSim.Framework.Communications
if (null != existingRootFolder) if (null != existingRootFolder)
{ {
m_log.ErrorFormat( m_log.WarnFormat(
"[AGENT INVENTORY]: Did not create a new inventory for user {0} since they already have " "[AGENT INVENTORY]: Did not create a new inventory for user {0} since they already have "
+ "a root inventory folder with id {1}", + "a root inventory folder with id {1}",
user, existingRootFolder.ID); user, existingRootFolder.ID);

View File

@ -43,7 +43,14 @@ namespace OpenSim.Grid.InventoryServer
{ {
} }
private bool TryGetUsersInventory(LLUUID userID, out List<InventoryFolderBase> folderList, /// <summary>
/// Get a user's inventory.
/// </summary>
/// <param name="userID"></param>
/// <param name="folderList"></param>
/// <param name="itemsList"></param>
/// <returns>true if the inventory was retrieved, false otherwise</returns>
private bool GetUsersInventory(LLUUID userID, out List<InventoryFolderBase> folderList,
out List<InventoryItemBase> itemsList) out List<InventoryItemBase> itemsList)
{ {
List<InventoryFolderBase> allFolders = GetInventorySkeleton(userID); List<InventoryFolderBase> allFolders = GetInventorySkeleton(userID);
@ -93,23 +100,40 @@ namespace OpenSim.Grid.InventoryServer
/// Return a user's entire inventory /// Return a user's entire inventory
/// </summary> /// </summary>
/// <param name="rawUserID"></param> /// <param name="rawUserID"></param>
/// <returns></returns> /// <returns>The user's inventory. If an inventory cannot be found then an empty collection is returned.</returns>
public InventoryCollection GetUserInventory(Guid rawUserID) public InventoryCollection GetUserInventory(Guid rawUserID)
{ {
LLUUID userID = new LLUUID(rawUserID); LLUUID userID = new LLUUID(rawUserID);
m_log.Info("[AGENT INVENTORY]: Processing request for inventory of " + userID.ToString()); m_log.InfoFormat("[AGENT INVENTORY]: Processing request for inventory of {0}", userID);
InventoryCollection invCollection = new InventoryCollection(); InventoryCollection invCollection = new InventoryCollection();
List<InventoryFolderBase> folders;
List<InventoryItemBase> allItems; List<InventoryFolderBase> allFolders = GetInventorySkeleton(userID);
if (TryGetUsersInventory(userID, out folders, out allItems))
if (null == allFolders)
{ {
invCollection.AllItems = allItems; m_log.WarnFormat("[AGENT INVENTORY]: No inventory found for user {0}", rawUserID);
invCollection.Folders = folders;
invCollection.UserID = userID; return invCollection;
} }
List<InventoryItemBase> allItems = new List<InventoryItemBase>();
foreach (InventoryFolderBase folder in allFolders)
{
List<InventoryItemBase> items = RequestFolderItems(folder.ID);
if (items != null)
{
allItems.InsertRange(0, items);
}
}
invCollection.AllItems = allItems;
invCollection.Folders = allFolders;
invCollection.UserID = userID;
// foreach (InventoryFolderBase folder in folders) // foreach (InventoryFolderBase folder in folders)
// { // {
// m_log.DebugFormat( // m_log.DebugFormat(