From 6c62985fd524cf502f8468b4aa303e558aff3b1c Mon Sep 17 00:00:00 2001 From: Justin Clarke Casey Date: Sun, 4 May 2008 01:04:49 +0000 Subject: * Refactor: Do the root case removal thing again, this time in ItemReceive() --- .../Communications/Cache/CachedUserInfo.cs | 47 ++++++---------------- 1 file changed, 13 insertions(+), 34 deletions(-) (limited to 'OpenSim/Framework/Communications/Cache') diff --git a/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs b/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs index 18bd994..03ba1db 100644 --- a/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs +++ b/OpenSim/Framework/Communications/Cache/CachedUserInfo.cs @@ -258,7 +258,7 @@ namespace OpenSim.Framework.Communications.Cache /// /// Callback invoked when an item is received from an async request to the inventory service. /// - /// We're assuming here that items are always received after all the folders have been + /// We're assuming here that items are always received after all the folders /// received. /// /// @@ -267,41 +267,20 @@ 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); - if (RootFolder != null) + if (null == folder) { - if (itemInfo.Folder == RootFolder.ID) - { - lock (RootFolder.Items) - { - if (!RootFolder.Items.ContainsKey(itemInfo.ID)) - { - RootFolder.Items.Add(itemInfo.ID, itemInfo); - } - else - { - RootFolder.Items[itemInfo.ID] = itemInfo; - } - } - } - else - { - InventoryFolderImpl folder = RootFolder.FindFolder(itemInfo.Folder); - if (folder != null) - { - lock (folder.Items) - { - if (!folder.Items.ContainsKey(itemInfo.ID)) - { - folder.Items.Add(itemInfo.ID, itemInfo); - } - else - { - folder.Items[itemInfo.ID] = itemInfo; - } - } - } - } + m_log.WarnFormat( + "Received item {0} {1} but its folder {2} does not exist", + itemInfo.Name, itemInfo.ID, itemInfo.Folder); + + return; + } + + lock (folder.Items) + { + folder.Items[itemInfo.ID] = itemInfo; } } -- cgit v1.1