aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules/Avatar
diff options
context:
space:
mode:
authorJustin Clarke Casey2009-05-14 20:37:54 +0000
committerJustin Clarke Casey2009-05-14 20:37:54 +0000
commit62771560448edbc2112d427acd4b37780dfe2154 (patch)
treeba07c1ae1d8de5e24e24a013fcaa39ade898f039 /OpenSim/Region/CoreModules/Avatar
parent* refactor: move SceneXmlLoader into subpackage (diff)
downloadopensim-SC-62771560448edbc2112d427acd4b37780dfe2154.zip
opensim-SC-62771560448edbc2112d427acd4b37780dfe2154.tar.gz
opensim-SC-62771560448edbc2112d427acd4b37780dfe2154.tar.bz2
opensim-SC-62771560448edbc2112d427acd4b37780dfe2154.tar.xz
* When saving an oar, save assets when immediately received rather than storing them all up in memory
* Hopefully this will remove out of memory problems when saving large oars on machines without much memory * It may also speed up saving of large oars
Diffstat (limited to 'OpenSim/Region/CoreModules/Avatar')
-rw-r--r--OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiveWriteRequest.cs21
1 files changed, 10 insertions, 11 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiveWriteRequest.cs b/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiveWriteRequest.cs
index b5c0d86..fec2425 100644
--- a/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiveWriteRequest.cs
+++ b/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiveWriteRequest.cs
@@ -56,7 +56,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
56 private InventoryArchiverModule m_module; 56 private InventoryArchiverModule m_module;
57 private CachedUserInfo m_userInfo; 57 private CachedUserInfo m_userInfo;
58 private string m_invPath; 58 private string m_invPath;
59 protected TarArchiveWriter m_archive; 59 protected TarArchiveWriter m_archiveWriter;
60 protected UuidGatherer m_assetGatherer; 60 protected UuidGatherer m_assetGatherer;
61 61
62 /// <value> 62 /// <value>
@@ -100,17 +100,14 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
100 m_assetGatherer = new UuidGatherer(m_module.CommsManager.AssetCache); 100 m_assetGatherer = new UuidGatherer(m_module.CommsManager.AssetCache);
101 } 101 }
102 102
103 protected void ReceivedAllAssets(IDictionary<UUID, AssetBase> assetsFound, ICollection<UUID> assetsNotFoundUuids) 103 protected void ReceivedAllAssets(ICollection<UUID> assetsFoundUuids, ICollection<UUID> assetsNotFoundUuids)
104 { 104 {
105 AssetsArchiver assetsArchiver = new AssetsArchiver(assetsFound);
106 assetsArchiver.Archive(m_archive);
107
108 Exception reportedException = null; 105 Exception reportedException = null;
109 bool succeeded = true; 106 bool succeeded = true;
110 107
111 try 108 try
112 { 109 {
113 m_archive.Close(); 110 m_archiveWriter.Close();
114 } 111 }
115 catch (IOException e) 112 catch (IOException e)
116 { 113 {
@@ -133,7 +130,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
133 saveItem.CreatorId = OspResolver.MakeOspa(saveItem.CreatorIdAsUuid, m_module.CommsManager); 130 saveItem.CreatorId = OspResolver.MakeOspa(saveItem.CreatorIdAsUuid, m_module.CommsManager);
134 131
135 string serialization = UserInventoryItemSerializer.Serialize(saveItem); 132 string serialization = UserInventoryItemSerializer.Serialize(saveItem);
136 m_archive.WriteFile(filename, serialization); 133 m_archiveWriter.WriteFile(filename, serialization);
137 134
138 m_assetGatherer.GatherAssetUuids(saveItem.AssetID, (AssetType)saveItem.AssetType, m_assetUuids); 135 m_assetGatherer.GatherAssetUuids(saveItem.AssetID, (AssetType)saveItem.AssetType, m_assetUuids);
139 } 136 }
@@ -156,7 +153,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
156 inventoryFolder.ID); 153 inventoryFolder.ID);
157 154
158 // We need to make sure that we record empty folders 155 // We need to make sure that we record empty folders
159 m_archive.WriteDir(path); 156 m_archiveWriter.WriteDir(path);
160 } 157 }
161 158
162 List<InventoryFolderImpl> childFolders = inventoryFolder.RequestListOfFolderImpls(); 159 List<InventoryFolderImpl> childFolders = inventoryFolder.RequestListOfFolderImpls();
@@ -265,7 +262,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
265 inventoryItem = m_userInfo.RootFolder.FindItemByPath(m_invPath); 262 inventoryItem = m_userInfo.RootFolder.FindItemByPath(m_invPath);
266 } 263 }
267 264
268 m_archive = new TarArchiveWriter(m_saveStream); 265 m_archiveWriter = new TarArchiveWriter(m_saveStream);
269 266
270 if (null == inventoryFolder) 267 if (null == inventoryFolder)
271 { 268 {
@@ -298,7 +295,9 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
298 } 295 }
299 296
300 SaveUsers(); 297 SaveUsers();
301 new AssetsRequest(m_assetUuids.Keys, m_module.CommsManager.AssetCache, ReceivedAllAssets).Execute(); 298 new AssetsRequest(
299 new AssetsArchiver(m_archiveWriter), m_assetUuids.Keys,
300 m_module.CommsManager.AssetCache, ReceivedAllAssets).Execute();
302 } 301 }
303 302
304 /// <summary> 303 /// <summary>
@@ -316,7 +315,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
316 315
317 if (creator != null) 316 if (creator != null)
318 { 317 {
319 m_archive.WriteFile( 318 m_archiveWriter.WriteFile(
320 ArchiveConstants.USERS_PATH + creator.UserProfile.Name + ".xml", 319 ArchiveConstants.USERS_PATH + creator.UserProfile.Name + ".xml",
321 UserProfileSerializer.Serialize(creator.UserProfile)); 320 UserProfileSerializer.Serialize(creator.UserProfile));
322 } 321 }