aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/CoreModules/Avatar/AvatarFactory/AvatarFactoryModule.cs23
1 files changed, 13 insertions, 10 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/AvatarFactory/AvatarFactoryModule.cs b/OpenSim/Region/CoreModules/Avatar/AvatarFactory/AvatarFactoryModule.cs
index 877231a..a19790d 100644
--- a/OpenSim/Region/CoreModules/Avatar/AvatarFactory/AvatarFactoryModule.cs
+++ b/OpenSim/Region/CoreModules/Avatar/AvatarFactory/AvatarFactoryModule.cs
@@ -422,7 +422,6 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
422 } 422 }
423 continue; 423 continue;
424 } 424 }
425
426 425
427 wearableCache[idx].TextureAsset = null; 426 wearableCache[idx].TextureAsset = null;
428 if (cache != null) 427 if (cache != null)
@@ -456,7 +455,16 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
456 { 455 {
457 m_log.Debug("[UpdateBakedCache] uploading to bakedModule cache"); 456 m_log.Debug("[UpdateBakedCache] uploading to bakedModule cache");
458 457
459 m_BakedTextureModule.Store(sp.UUID, wearableCache); 458 WearableCacheItem[] toBakedModule = new WearableCacheItem[AvatarAppearance.BAKE_INDICES.Length];
459
460 for (int i = 0; i < cacheItems.Length; i++)
461 {
462 int idx = (int)cacheItems[i].TextureIndex;
463 cacheItems[i].CacheId = wearableCache[idx].CacheId;
464 cacheItems[i].TextureID = wearableCache[idx].TextureID;
465 cacheItems[i].TextureAsset = wearableCache[idx].TextureAsset;
466 }
467 m_BakedTextureModule.Store(sp.UUID, cacheItems);
460 } 468 }
461 } 469 }
462 470
@@ -513,22 +521,17 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
513 521
514 if (bakedModuleCache != null) 522 if (bakedModuleCache != null)
515 { 523 {
516 m_log.Debug("[ValidateBakedCache] got bakedModule cache " + wearableCache.Length); 524 m_log.Debug("[ValidateBakedCache] got bakedModule cache " + bakedModuleCache.Length);
517
518 // old store have diferent sizes and index starts at 1
519 int offset = 0;
520 if (bakedModuleCache[0].TextureIndex == 1)
521 offset = -1;
522 int j;
523 525
524 for (int i = 0; i < bakedModuleCache.Length; i++) 526 for (int i = 0; i < bakedModuleCache.Length; i++)
525 { 527 {
526 j = (int)bakedModuleCache[i].TextureIndex + offset; 528 int j = (int)bakedModuleCache[i].TextureIndex;
527 529
528 if (bakedModuleCache[i].TextureAsset != null) 530 if (bakedModuleCache[i].TextureAsset != null)
529 { 531 {
530 wearableCache[j].TextureID = bakedModuleCache[i].TextureID; 532 wearableCache[j].TextureID = bakedModuleCache[i].TextureID;
531 wearableCache[j].CacheId = bakedModuleCache[i].TextureID; 533 wearableCache[j].CacheId = bakedModuleCache[i].TextureID;
534 wearableCache[j].TextureAsset = bakedModuleCache[i].TextureAsset;
532 bakedModuleCache[i].TextureAsset.Temporary = true; 535 bakedModuleCache[i].TextureAsset.Temporary = true;
533 bakedModuleCache[i].TextureAsset.Local = true; 536 bakedModuleCache[i].TextureAsset.Local = true;
534 cache.Store(bakedModuleCache[i].TextureAsset); 537 cache.Store(bakedModuleCache[i].TextureAsset);