From 670719cb76cdf2b624ec84d631cc14f507e5840b Mon Sep 17 00:00:00 2001
From: Melanie Thielker
Date: Wed, 27 Aug 2008 00:40:36 +0000
Subject: Mantis #1903 Thank you, cmickeyb, for a patch that prevents the loss
of folders received out of sequence, and the items within.
---
.../Communications/Cache/CachedUserInfo.cs | 31 +++++++++++++++-------
.../Cache/UserProfileCacheService.cs | 8 +++++-
2 files changed, 29 insertions(+), 10 deletions(-)
(limited to 'OpenSim/Framework')
diff --git a/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs b/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs
index a7d6349..17f927d 100644
--- a/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs
+++ b/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs
@@ -150,6 +150,7 @@ namespace OpenSim.Framework.Communications.Cache
}
}
+
///
/// Add any pending folders which were received before the given folder
///
@@ -160,20 +161,24 @@ namespace OpenSim.Framework.Communications.Cache
{
if (pendingCategorizationFolders.ContainsKey(newFolder.ID))
{
+ List resolvedFolders = new List(); // Folders we've resolved with this invocation
foreach (InventoryFolderImpl folder in pendingCategorizationFolders[newFolder.ID])
{
// m_log.DebugFormat(
// "[INVENTORY CACHE]: Resolving pending received folder {0} {1} into {2} {3}",
// folder.name, folder.folderID, parent.name, parent.folderID);
-
lock (newFolder.SubFolders)
{
if (!newFolder.SubFolders.ContainsKey(folder.ID))
{
+ resolvedFolders.Add(folder);
newFolder.SubFolders.Add(folder.ID, folder);
}
}
}
+ pendingCategorizationFolders.Remove(newFolder.ID);
+ foreach (InventoryFolderImpl folder in resolvedFolders)
+ ResolvePendingFolders(folder);
}
}
@@ -201,13 +206,19 @@ namespace OpenSim.Framework.Communications.Cache
{
// FIXME: Exceptions thrown upwards never appear on the console. Could fix further up if these
// are simply being swallowed
+
try
{
foreach (InventoryFolderImpl folder in folders)
{
FolderReceive(folder);
}
-
+ // Generate a warning for folders that are not part of the heirarchy
+ foreach ( KeyValuePair> folderList in pendingCategorizationFolders)
+ {
+ foreach (InventoryFolderImpl folder in folderList.Value)
+ m_log.WarnFormat("[INVENTORY CACHE]: Malformed Database: Unresolved Pending Folder {0}", folder.Name);
+ }
foreach (InventoryItemBase item in items)
{
ItemReceive(item);
@@ -258,7 +269,11 @@ namespace OpenSim.Framework.Communications.Cache
{
InventoryFolderImpl parentFolder = RootFolder.FindFolder(newFolder.ParentID);
- if (parentFolder != null)
+ if (parentFolder == null)
+ {
+ AddPendingFolder(newFolder);
+ }
+ else
{
lock (parentFolder.SubFolders)
{
@@ -274,12 +289,7 @@ namespace OpenSim.Framework.Communications.Cache
}
}
}
- else
- {
- AddPendingFolder(newFolder);
- }
}
-
ResolvePendingFolders(newFolder);
}
@@ -295,7 +305,10 @@ namespace OpenSim.Framework.Communications.Cache
// m_log.DebugFormat(
// "[INVENTORY CACHE]: Received item {0} {1} for user {2}",
// itemInfo.Name, itemInfo.ID, userID);
- InventoryFolderImpl folder = RootFolder.FindFolder(itemInfo.Folder);
+ InventoryFolderImpl folder = null;
+
+ if ( RootFolder != null )
+ folder = RootFolder.FindFolder(itemInfo.Folder);
if (null == folder)
{
diff --git a/OpenSim/Framework/Communications/Cache/UserProfileCacheService.cs b/OpenSim/Framework/Communications/Cache/UserProfileCacheService.cs
index 3b02c88..017cb29 100644
--- a/OpenSim/Framework/Communications/Cache/UserProfileCacheService.cs
+++ b/OpenSim/Framework/Communications/Cache/UserProfileCacheService.cs
@@ -440,7 +440,13 @@ namespace OpenSim.Framework.Communications.Cache
{
if (userProfile.HasReceivedInventory)
{
- InventoryItemBase item = userProfile.RootFolder.FindItem(itemID);
+ InventoryItemBase item = null;
+ if ( userProfile.RootFolder == null )
+ m_log.ErrorFormat(
+ "[AGENT INVENTORY]: User {0} {1} does not have a root folder.",
+ remoteClient.Name, remoteClient.AgentId);
+ else
+ item = userProfile.RootFolder.FindItem(itemID);
if (item != null)
{
remoteClient.SendInventoryItemDetails(ownerID, item);
--
cgit v1.1