avinationmerge
UbitUmarov 2014-08-07 06:09:56 +01:00
parent c3f9c99fb3
commit b7f24bacce
2 changed files with 27 additions and 29 deletions

View File

@ -481,6 +481,9 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
IAssetService cache = m_scene.AssetService; IAssetService cache = m_scene.AssetService;
IBakedTextureModule bakedModule = m_scene.RequestModuleInterface<IBakedTextureModule>(); IBakedTextureModule bakedModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
WearableCacheItem[] wearableCache = null; WearableCacheItem[] wearableCache = null;
WearableCacheItem[] bakedModuleCache = null;
wearableCache = WearableCacheItem.GetDefaultCacheItem();
// debug // debug
for (int iter = 0; iter < AvatarAppearance.BAKE_INDICES.Length; iter++) for (int iter = 0; iter < AvatarAppearance.BAKE_INDICES.Length; iter++)
@ -493,46 +496,47 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
m_log.Debug("[ValidateBakedCache] {" + iter + "/" + j + " t - No texture"); m_log.Debug("[ValidateBakedCache] {" + iter + "/" + j + " t - No texture");
} }
int hits = 0; int hits = 0;
// Cache wearable data for teleport. // Cache wearable data for teleport.
// Only makes sense if there's a bake module and a cache module // Only makes sense if there's a bake module and a cache module
if (bakedModule != null && cache != null) if (bakedModule != null && cache != null)
{ {
m_log.Debug("[ValidateBakedCache] calling bakedModule");
try try
{ {
wearableCache = bakedModule.Get(sp.UUID); bakedModuleCache = bakedModule.Get(sp.UUID);
} }
catch (Exception) catch (Exception)
{ {
wearableCache = null; bakedModuleCache = null;
} }
if (wearableCache != null) if (bakedModuleCache != null)
{ {
for (int i = 0; i < wearableCache.Length; i++) m_log.Debug("[ValidateBakedCache] got bakedModule cache " + wearableCache.Length);
// old store have diferent sizes and index starts at 1
int offset = 0;
if (bakedModuleCache[0].TextureIndex == 1)
offset = -1;
int j;
for (int i = 0; i < bakedModuleCache.Length; i++)
{ {
j = (int)bakedModuleCache[i].TextureIndex + offset;
m_log.Debug("[ValidateBakedCache] got bakedModule cache"); if (bakedModuleCache[i].TextureAsset != null)
if (wearableCache[i].TextureAsset != null)
{ {
wearableCache[i].TextureAsset.Temporary = true; wearableCache[j].TextureID = bakedModuleCache[i].TextureID;
wearableCache[i].TextureAsset.Local = true; wearableCache[j].CacheId = bakedModuleCache[i].TextureID;
cache.Store(wearableCache[i].TextureAsset); bakedModuleCache[i].TextureAsset.Temporary = true;
} bakedModuleCache[i].TextureAsset.Local = true;
else cache.Store(bakedModuleCache[i].TextureAsset);
{
wearableCache[i].TextureID = UUID.Zero;
wearableCache[i].CacheId = UUID.Zero;
} }
} }
} }
} }
if(wearableCache == null)
wearableCache = WearableCacheItem.GetDefaultCacheItem();
// Process the baked textures // Process the baked textures
for (int i = 0; i < AvatarAppearance.BAKE_INDICES.Length; i++) for (int i = 0; i < AvatarAppearance.BAKE_INDICES.Length; i++)
{ {
@ -540,7 +544,7 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
Primitive.TextureEntryFace face = sp.Appearance.Texture.FaceTextures[idx]; Primitive.TextureEntryFace face = sp.Appearance.Texture.FaceTextures[idx];
// No face, so lets check our baked service cache, teleport or login. // No face, so lets check our baked service cache, teleport or login.
if (face == null) if (face == null || face.TextureID == UUID.Zero || face.TextureID == AppearanceManager.DEFAULT_AVATAR_TEXTURE)
{ {
sp.Appearance.Texture.FaceTextures[idx] = sp.Appearance.Texture.CreateFace((uint)idx); sp.Appearance.Texture.FaceTextures[idx] = sp.Appearance.Texture.CreateFace((uint)idx);
if (wearableCache[idx].TextureID != UUID.Zero) if (wearableCache[idx].TextureID != UUID.Zero)
@ -554,24 +558,18 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
sp.Appearance.Texture.FaceTextures[idx].TextureID = AppearanceManager.DEFAULT_AVATAR_TEXTURE; sp.Appearance.Texture.FaceTextures[idx].TextureID = AppearanceManager.DEFAULT_AVATAR_TEXTURE;
face = sp.Appearance.Texture.FaceTextures[idx]; face = sp.Appearance.Texture.FaceTextures[idx];
wearableCache[idx].CacheId = UUID.Zero; wearableCache[idx].CacheId = UUID.Zero;
wearableCache[idx].TextureID = UUID.Zero;
wearableCache[idx].TextureAsset = null; wearableCache[idx].TextureAsset = null;
continue; continue;
} }
} }
if (face.TextureID == UUID.Zero || face.TextureID == AppearanceManager.DEFAULT_AVATAR_TEXTURE) if (face.TextureID == UUID.Zero || face.TextureID == AppearanceManager.DEFAULT_AVATAR_TEXTURE)
{ {
wearableCache[idx].CacheId = UUID.Zero; defonly = false; // found a non-default texture reference
wearableCache[idx].TextureID = UUID.Zero;
wearableCache[idx].TextureAsset = null;
continue; continue;
} }
defonly = false; // found a non-default texture reference if(wearableCache[idx].TextureID != face.TextureID)
if(wearableCache[idx].TextureID != sp.Appearance.Texture.FaceTextures[idx].TextureID)
{ {
wearableCache[idx].CacheId = UUID.Zero; wearableCache[idx].CacheId = UUID.Zero;
wearableCache[idx].TextureID = UUID.Zero; wearableCache[idx].TextureID = UUID.Zero;

View File

@ -3525,7 +3525,7 @@ namespace OpenSim.Region.Framework.Scenes
// send even grays // send even grays
if (cachedappearance) if (cachedappearance)
{ {
m_log.DebugFormat("[SCENE PRESENCE]: Baked textures are in the cache for {0} in {1}", Name, m_scene.Name); // m_log.DebugFormat("[SCENE PRESENCE]: Baked textures are in the cache for {0} in {1}", Name, m_scene.Name);
// If the avatars baked textures are all in the cache, then we have a // If the avatars baked textures are all in the cache, then we have a
// complete appearance... send it out, if not, then we'll send it when // complete appearance... send it out, if not, then we'll send it when
// the avatar finishes updating its appearance // the avatar finishes updating its appearance