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