DANGER... changed bakedtextures caching. Assuming grid baking is cache
only, reduced number of accesses to it. TESTINGavinationmerge
parent
552b4e45e8
commit
c3f9c99fb3
|
@ -46,7 +46,7 @@ namespace OpenSim.Framework
|
||||||
int itemmax = 21;
|
int itemmax = 21;
|
||||||
WearableCacheItem[] retitems = new WearableCacheItem[itemmax];
|
WearableCacheItem[] retitems = new WearableCacheItem[itemmax];
|
||||||
for (uint i=0;i<itemmax;i++)
|
for (uint i=0;i<itemmax;i++)
|
||||||
retitems[i] = new WearableCacheItem() {CacheId = UUID.Zero, TextureID = UUID.Zero, TextureIndex = i + 1};
|
retitems[i] = new WearableCacheItem() {CacheId = UUID.Zero, TextureID = UUID.Zero, TextureIndex = i};
|
||||||
return retitems;
|
return retitems;
|
||||||
}
|
}
|
||||||
public static WearableCacheItem[] FromOSD(OSD pInput, IImprovedAssetCache dataCache)
|
public static WearableCacheItem[] FromOSD(OSD pInput, IImprovedAssetCache dataCache)
|
||||||
|
|
|
@ -98,8 +98,6 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
m_scene = null;
|
m_scene = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void RegionLoaded(Scene s)
|
public void RegionLoaded(Scene s)
|
||||||
{
|
{
|
||||||
m_scene.EventManager.OnRegisterCaps += RegisterCaps;
|
m_scene.EventManager.OnRegisterCaps += RegisterCaps;
|
||||||
|
@ -110,32 +108,47 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
|
|
||||||
private void DeRegisterPresence(UUID agentId)
|
private void DeRegisterPresence(UUID agentId)
|
||||||
{
|
{
|
||||||
ScenePresence presence = null;
|
// ScenePresence presence = null;
|
||||||
if (m_scene.TryGetScenePresence(agentId, out presence))
|
// if (m_scene.TryGetScenePresence(agentId, out presence))
|
||||||
{
|
{
|
||||||
presence.ControllingClient.OnSetAppearance -= CaptureAppearanceSettings;
|
// presence.ControllingClient.OnSetAppearance -= CaptureAppearanceSettings;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RegisterNewPresence(ScenePresence presence)
|
private void RegisterNewPresence(ScenePresence presence)
|
||||||
{
|
{
|
||||||
presence.ControllingClient.OnSetAppearance += CaptureAppearanceSettings;
|
// presence.ControllingClient.OnSetAppearance += CaptureAppearanceSettings;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* not in use. work done in AvatarFactoryModule ValidateBakedTextureCache() and UpdateBakedTextureCache()
|
||||||
private void CaptureAppearanceSettings(IClientAPI remoteClient, Primitive.TextureEntry textureEntry, byte[] visualParams, Vector3 avSize, WearableCacheItem[] cacheItems)
|
private void CaptureAppearanceSettings(IClientAPI remoteClient, Primitive.TextureEntry textureEntry, byte[] visualParams, Vector3 avSize, WearableCacheItem[] cacheItems)
|
||||||
{
|
{
|
||||||
|
// if cacheItems.Length > 0 viewer is giving us current textures information.
|
||||||
|
// baked ones should had been uploaded and in assets cache as local itens
|
||||||
|
|
||||||
|
|
||||||
|
if (cacheItems.Length == 0)
|
||||||
|
return; // no textures information, nothing to do
|
||||||
|
|
||||||
|
ScenePresence p = null;
|
||||||
|
if (!m_scene.TryGetScenePresence(remoteClient.AgentId, out p))
|
||||||
|
return; // what are we doing if there is no presence to cache for?
|
||||||
|
|
||||||
|
if (p.IsDeleted)
|
||||||
|
return; // does this really work?
|
||||||
|
|
||||||
int maxCacheitemsLoop = cacheItems.Length;
|
int maxCacheitemsLoop = cacheItems.Length;
|
||||||
if (maxCacheitemsLoop > AvatarWearable.MAX_WEARABLES)
|
if (maxCacheitemsLoop > 20)
|
||||||
{
|
{
|
||||||
maxCacheitemsLoop = AvatarWearable.MAX_WEARABLES;
|
maxCacheitemsLoop = AvatarWearable.MAX_WEARABLES;
|
||||||
m_log.WarnFormat("[CACHEDBAKES]: Too Many Cache items Provided {0}, the max is {1}. Truncating!", cacheItems.Length, AvatarWearable.MAX_WEARABLES);
|
m_log.WarnFormat("[CACHEDBAKES]: Too Many Cache items Provided {0}, the max is {1}. Truncating!", cacheItems.Length, AvatarWearable.MAX_WEARABLES);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_BakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
m_BakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
||||||
if (cacheItems.Length > 0)
|
|
||||||
{
|
|
||||||
|
// some nice debug
|
||||||
m_log.Debug("[Cacheitems]: " + cacheItems.Length);
|
m_log.Debug("[Cacheitems]: " + cacheItems.Length);
|
||||||
for (int iter = 0; iter < maxCacheitemsLoop; iter++)
|
for (int iter = 0; iter < maxCacheitemsLoop; iter++)
|
||||||
{
|
{
|
||||||
|
@ -143,11 +156,10 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
cacheItems[iter].TextureID);
|
cacheItems[iter].TextureID);
|
||||||
}
|
}
|
||||||
|
|
||||||
ScenePresence p = null;
|
// p.Appearance.WearableCacheItems is in memory primary cashID to textures mapper
|
||||||
if (m_scene.TryGetScenePresence(remoteClient.AgentId, out p))
|
|
||||||
{
|
|
||||||
|
|
||||||
WearableCacheItem[] existingitems = p.Appearance.WearableCacheItems;
|
WearableCacheItem[] existingitems = p.Appearance.WearableCacheItems;
|
||||||
|
|
||||||
if (existingitems == null)
|
if (existingitems == null)
|
||||||
{
|
{
|
||||||
if (m_BakedTextureModule != null)
|
if (m_BakedTextureModule != null)
|
||||||
|
@ -161,24 +173,8 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
p.Appearance.WearableCacheItems = savedcache;
|
p.Appearance.WearableCacheItems = savedcache;
|
||||||
p.Appearance.WearableCacheItemsDirty = false;
|
p.Appearance.WearableCacheItemsDirty = false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
* The following Catch types DO NOT WORK with m_BakedTextureModule.Get
|
|
||||||
* it jumps to the General Packet Exception Handler if you don't catch Exception!
|
|
||||||
*
|
|
||||||
catch (System.Net.Sockets.SocketException)
|
|
||||||
{
|
|
||||||
cacheItems = null;
|
|
||||||
}
|
|
||||||
catch (WebException)
|
|
||||||
{
|
|
||||||
cacheItems = null;
|
|
||||||
}
|
|
||||||
catch (InvalidOperationException)
|
|
||||||
{
|
|
||||||
cacheItems = null;
|
|
||||||
} */
|
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
// The service logs a sufficient error message.
|
// The service logs a sufficient error message.
|
||||||
|
@ -189,10 +185,10 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
existingitems = savedcache;
|
existingitems = savedcache;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Existing items null means it's a fully new appearance
|
// Existing items null means it's a fully new appearance
|
||||||
if (existingitems == null)
|
if (existingitems == null)
|
||||||
{
|
{
|
||||||
|
|
||||||
for (int i = 0; i < maxCacheitemsLoop; i++)
|
for (int i = 0; i < maxCacheitemsLoop; i++)
|
||||||
{
|
{
|
||||||
if (textureEntry.FaceTextures.Length > cacheItems[i].TextureIndex)
|
if (textureEntry.FaceTextures.Length > cacheItems[i].TextureIndex)
|
||||||
|
@ -214,15 +210,10 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
{
|
{
|
||||||
m_log.WarnFormat("[CACHEDBAKES]: Invalid Texture Index Provided, Texture doesn't exist or hasn't been uploaded yet {0}, the max is {1}. Skipping!", cacheItems[i].TextureIndex, textureEntry.FaceTextures.Length);
|
m_log.WarnFormat("[CACHEDBAKES]: Invalid Texture Index Provided, Texture doesn't exist or hasn't been uploaded yet {0}, the max is {1}. Skipping!", cacheItems[i].TextureIndex, textureEntry.FaceTextures.Length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
// for each uploaded baked texture
|
|
||||||
for (int i = 0; i < maxCacheitemsLoop; i++)
|
for (int i = 0; i < maxCacheitemsLoop; i++)
|
||||||
{
|
{
|
||||||
if (textureEntry.FaceTextures.Length > cacheItems[i].TextureIndex)
|
if (textureEntry.FaceTextures.Length > cacheItems[i].TextureIndex)
|
||||||
|
@ -253,7 +244,6 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p.Appearance.WearableCacheItems = cacheItems;
|
p.Appearance.WearableCacheItems = cacheItems;
|
||||||
|
|
||||||
if (m_BakedTextureModule != null)
|
if (m_BakedTextureModule != null)
|
||||||
|
@ -264,8 +254,6 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
p.Appearance.WearableCacheItemsDirty = false;
|
p.Appearance.WearableCacheItemsDirty = false;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int iter = 0; iter < maxCacheitemsLoop; iter++)
|
for (int iter = 0; iter < maxCacheitemsLoop; iter++)
|
||||||
{
|
{
|
||||||
|
@ -273,7 +261,7 @@ namespace OpenSim.Region.ClientStack.Linden
|
||||||
cacheItems[iter].TextureID);
|
cacheItems[iter].TextureID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
public void PostInitialise()
|
public void PostInitialise()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
|
@ -3684,6 +3684,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
avp.Sender.IsTrial = false;
|
avp.Sender.IsTrial = false;
|
||||||
avp.Sender.ID = agentID;
|
avp.Sender.ID = agentID;
|
||||||
avp.AppearanceData = new AvatarAppearancePacket.AppearanceDataBlock[0];
|
avp.AppearanceData = new AvatarAppearancePacket.AppearanceDataBlock[0];
|
||||||
|
|
||||||
|
// this need be use in future
|
||||||
|
// avp.AppearanceData[0].AppearanceVersion = 0;
|
||||||
|
// avp.AppearanceData[0].CofVersion = 0;
|
||||||
|
|
||||||
//m_log.DebugFormat("[CLIENT]: Sending appearance for {0} to {1}", agentID.ToString(), AgentId.ToString());
|
//m_log.DebugFormat("[CLIENT]: Sending appearance for {0} to {1}", agentID.ToString(), AgentId.ToString());
|
||||||
OutPacket(avp, ThrottleOutPacketType.Task);
|
OutPacket(avp, ThrottleOutPacketType.Task);
|
||||||
}
|
}
|
||||||
|
@ -12008,7 +12013,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
if (cachedtex.AgentData.SessionID != SessionId)
|
if (cachedtex.AgentData.SessionID != SessionId)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
||||||
// TODO: don't create new blocks if recycling an old packet
|
// TODO: don't create new blocks if recycling an old packet
|
||||||
cachedresp.AgentData.AgentID = AgentId;
|
cachedresp.AgentData.AgentID = AgentId;
|
||||||
cachedresp.AgentData.SessionID = m_sessionId;
|
cachedresp.AgentData.SessionID = m_sessionId;
|
||||||
|
@ -12022,23 +12026,27 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
//WearableCacheItem[] items = fac.GetCachedItems(AgentId);
|
//WearableCacheItem[] items = fac.GetCachedItems(AgentId);
|
||||||
|
|
||||||
IAssetService cache = m_scene.AssetService;
|
IAssetService cache = m_scene.AssetService;
|
||||||
IBakedTextureModule bakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
|
||||||
//bakedTextureModule = null;
|
//bakedTextureModule = null;
|
||||||
int maxWearablesLoop = cachedtex.WearableData.Length;
|
int maxWearablesLoop = cachedtex.WearableData.Length;
|
||||||
if (maxWearablesLoop > AvatarWearable.MAX_WEARABLES)
|
if (maxWearablesLoop > AvatarWearable.MAX_WEARABLES)
|
||||||
maxWearablesLoop = AvatarWearable.MAX_WEARABLES;
|
maxWearablesLoop = AvatarWearable.MAX_WEARABLES;
|
||||||
|
|
||||||
// if (bakedTextureModule != null && cache != null)
|
int cacheHits = 0;
|
||||||
|
|
||||||
if (cache != null)
|
if (cache != null)
|
||||||
{
|
{
|
||||||
// We need to make sure the asset stored in the bake is available on this server also by it's assetid before we map it to a Cacheid
|
// We need to make sure the asset stored in the bake is available on this server also by it's assetid before we map it to a Cacheid
|
||||||
|
|
||||||
WearableCacheItem[] cacheItems = null;
|
WearableCacheItem[] cacheItems = null;
|
||||||
|
|
||||||
ScenePresence p = m_scene.GetScenePresence(AgentId);
|
ScenePresence p = m_scene.GetScenePresence(AgentId);
|
||||||
if (p.Appearance != null)
|
|
||||||
|
if (p!= null && p.Appearance != null)
|
||||||
{
|
{
|
||||||
if (p.Appearance.WearableCacheItems == null || p.Appearance.WearableCacheItemsDirty)
|
/* we should only check bakedTextureModule at login or when appearance changes
|
||||||
|
if (p.Appearance.WearableCacheItems == null) // currently with a caching only bakemodule Appearance.Wearables.dirty as no use
|
||||||
{
|
{
|
||||||
|
IBakedTextureModule bakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
||||||
if (bakedTextureModule != null)
|
if (bakedTextureModule != null)
|
||||||
{
|
{
|
||||||
m_log.Debug("[ HandleAgentTextureCached] bakedTextureModule");
|
m_log.Debug("[ HandleAgentTextureCached] bakedTextureModule");
|
||||||
|
@ -12047,23 +12055,21 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
cacheItems = bakedTextureModule.Get(AgentId);
|
cacheItems = bakedTextureModule.Get(AgentId);
|
||||||
p.Appearance.WearableCacheItems = cacheItems;
|
p.Appearance.WearableCacheItems = cacheItems;
|
||||||
p.Appearance.WearableCacheItemsDirty = false;
|
p.Appearance.WearableCacheItemsDirty = false;
|
||||||
|
|
||||||
|
if (cacheItems != null)
|
||||||
|
{
|
||||||
|
foreach (WearableCacheItem item in cacheItems)
|
||||||
|
{
|
||||||
|
if (item.TextureAsset != null)
|
||||||
|
{
|
||||||
|
item.TextureAsset.Temporary = true;
|
||||||
|
item.TextureAsset.Local = true;
|
||||||
|
cache.Store(item.TextureAsset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* The following Catch types DO NOT WORK, it jumps to the General Packet Exception Handler if you don't catch Exception!
|
|
||||||
*
|
|
||||||
catch (System.Net.Sockets.SocketException)
|
|
||||||
{
|
|
||||||
cacheItems = null;
|
|
||||||
}
|
|
||||||
catch (WebException)
|
|
||||||
{
|
|
||||||
cacheItems = null;
|
|
||||||
}
|
|
||||||
catch (InvalidOperationException)
|
|
||||||
{
|
|
||||||
cacheItems = null;
|
|
||||||
} */
|
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
cacheItems = null;
|
cacheItems = null;
|
||||||
|
@ -12075,36 +12081,23 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
{
|
{
|
||||||
cacheItems = p.Appearance.WearableCacheItems;
|
cacheItems = p.Appearance.WearableCacheItems;
|
||||||
}
|
}
|
||||||
}
|
*/
|
||||||
|
cacheItems = p.Appearance.WearableCacheItems;
|
||||||
if (cache != null && cacheItems != null)
|
|
||||||
{
|
|
||||||
foreach (WearableCacheItem item in cacheItems)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (cache.GetCached(item.TextureID.ToString()) == null)
|
|
||||||
{
|
|
||||||
item.TextureAsset.Temporary = true;
|
|
||||||
cache.Store(item.TextureAsset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cacheItems != null)
|
if (cacheItems != null)
|
||||||
{
|
{
|
||||||
|
|
||||||
for (int i = 0; i < maxWearablesLoop; i++)
|
for (int i = 0; i < maxWearablesLoop; i++)
|
||||||
{
|
{
|
||||||
WearableCacheItem item =
|
int idx = cachedtex.WearableData[i].TextureIndex;
|
||||||
WearableCacheItem.SearchTextureIndex(cachedtex.WearableData[i].TextureIndex,cacheItems);
|
|
||||||
|
|
||||||
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
||||||
cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
|
cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
|
||||||
cachedresp.WearableData[i].HostName = new byte[0];
|
cachedresp.WearableData[i].HostName = new byte[0];
|
||||||
if (item != null && cachedtex.WearableData[i].ID == item.CacheId)
|
if (cachedtex.WearableData[i].ID == cacheItems[idx].CacheId)
|
||||||
{
|
{
|
||||||
|
cachedresp.WearableData[i].TextureID = cacheItems[idx].TextureID;
|
||||||
cachedresp.WearableData[i].TextureID = item.TextureID;
|
cacheHits++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -12124,36 +12117,19 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else // no cache
|
||||||
{
|
|
||||||
if (cache == null)
|
|
||||||
{
|
{
|
||||||
for (int i = 0; i < maxWearablesLoop; i++)
|
for (int i = 0; i < maxWearablesLoop; i++)
|
||||||
{
|
{
|
||||||
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
||||||
cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
|
cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
|
||||||
cachedresp.WearableData[i].TextureID = UUID.Zero;
|
cachedresp.WearableData[i].TextureID = UUID.Zero;
|
||||||
//UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
|
|
||||||
cachedresp.WearableData[i].HostName = new byte[0];
|
cachedresp.WearableData[i].HostName = new byte[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
for (int i = 0; i < maxWearablesLoop; i++)
|
|
||||||
{
|
|
||||||
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
|
||||||
cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
|
|
||||||
|
|
||||||
if (cache.GetCached(cachedresp.WearableData[i].TextureID.ToString()) == null)
|
m_log.DebugFormat("texture cached: hits {0}", cacheHits);
|
||||||
cachedresp.WearableData[i].TextureID = UUID.Zero;
|
|
||||||
//UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
|
|
||||||
// else
|
|
||||||
// cachedresp.WearableData[i].TextureID = UUID.Zero;
|
|
||||||
// UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
|
|
||||||
cachedresp.WearableData[i].HostName = new byte[0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cachedresp.Header.Zerocoded = true;
|
cachedresp.Header.Zerocoded = true;
|
||||||
OutPacket(cachedresp, ThrottleOutPacketType.Task);
|
OutPacket(cachedresp, ThrottleOutPacketType.Task);
|
||||||
|
|
||||||
|
|
|
@ -188,27 +188,7 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
// Process the visual params, this may change height as well
|
// Process the visual params, this may change height as well
|
||||||
if (visualParams != null)
|
if (visualParams != null)
|
||||||
{
|
{
|
||||||
// string[] visualParamsStrings = new string[visualParams.Length];
|
|
||||||
// for (int i = 0; i < visualParams.Length; i++)
|
|
||||||
// visualParamsStrings[i] = visualParams[i].ToString();
|
|
||||||
// m_log.DebugFormat(
|
|
||||||
// "[AVFACTORY]: Setting visual params for {0} to {1}",
|
|
||||||
// client.Name, string.Join(", ", visualParamsStrings));
|
|
||||||
/*
|
|
||||||
float oldHeight = sp.Appearance.AvatarHeight;
|
|
||||||
changed = sp.Appearance.SetVisualParams(visualParams);
|
changed = sp.Appearance.SetVisualParams(visualParams);
|
||||||
|
|
||||||
if (sp.Appearance.AvatarHeight != oldHeight && sp.Appearance.AvatarHeight > 0)
|
|
||||||
((ScenePresence)sp).SetHeight(sp.Appearance.AvatarHeight);
|
|
||||||
*/
|
|
||||||
// float oldoff = sp.Appearance.AvatarFeetOffset;
|
|
||||||
// Vector3 oldbox = sp.Appearance.AvatarBoxSize;
|
|
||||||
changed = sp.Appearance.SetVisualParams(visualParams);
|
|
||||||
// float off = sp.Appearance.AvatarFeetOffset;
|
|
||||||
// Vector3 box = sp.Appearance.AvatarBoxSize;
|
|
||||||
// if(oldoff != off || oldbox != box)
|
|
||||||
// ((ScenePresence)sp).SetSize(box,off);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Process the baked texture array
|
// Process the baked texture array
|
||||||
|
@ -222,9 +202,15 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
|
|
||||||
// WriteBakedTexturesReport(sp, m_log.DebugFormat);
|
// WriteBakedTexturesReport(sp, m_log.DebugFormat);
|
||||||
|
|
||||||
|
|
||||||
// If bake textures are missing and this is not an NPC, request a rebake from client
|
// If bake textures are missing and this is not an NPC, request a rebake from client
|
||||||
if (!ValidateBakedTextureCache(sp) && (((ScenePresence)sp).PresenceType != PresenceType.Npc))
|
// rebake may messup caching, and should not be needed
|
||||||
RequestRebake(sp, true);
|
|
||||||
|
|
||||||
|
// if (!UpdateBakedTextureCache(sp,cacheItems) && (((ScenePresence)sp).PresenceType != PresenceType.Npc))
|
||||||
|
// RequestRebake(sp, true);
|
||||||
|
|
||||||
|
UpdateBakedTextureCache(sp, cacheItems);
|
||||||
|
|
||||||
// This appears to be set only in the final stage of the appearance
|
// This appears to be set only in the final stage of the appearance
|
||||||
// update transaction. In theory, we should be able to do an immediate
|
// update transaction. In theory, we should be able to do an immediate
|
||||||
|
@ -377,13 +363,138 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// called on textures update
|
||||||
|
public bool UpdateBakedTextureCache(IScenePresence sp, WearableCacheItem[] cacheItems)
|
||||||
|
{
|
||||||
|
bool defonly = true; // are we only using default textures
|
||||||
|
|
||||||
|
// uploaded baked textures will be in assets local cache
|
||||||
|
IAssetService cache = m_scene.AssetService;
|
||||||
|
|
||||||
|
int validDirtyBakes = 0;
|
||||||
|
int hits = 0;
|
||||||
|
|
||||||
|
// our main cacheIDs mapper is p.Appearance.WearableCacheItems
|
||||||
|
WearableCacheItem[] wearableCache = sp.Appearance.WearableCacheItems;
|
||||||
|
|
||||||
|
if (wearableCache == null)
|
||||||
|
{
|
||||||
|
wearableCache = WearableCacheItem.GetDefaultCacheItem();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Process received baked textures
|
||||||
|
for (int i = 0; i < cacheItems.Length; i++)
|
||||||
|
{
|
||||||
|
int idx = (int)cacheItems[i].TextureIndex;
|
||||||
|
Primitive.TextureEntryFace face = sp.Appearance.Texture.FaceTextures[idx];
|
||||||
|
|
||||||
|
// No face
|
||||||
|
if (face == null)
|
||||||
|
{
|
||||||
|
// for some reason viewer is cleaning this
|
||||||
|
sp.Appearance.Texture.FaceTextures[idx] = sp.Appearance.Texture.CreateFace((uint) idx);
|
||||||
|
sp.Appearance.Texture.FaceTextures[idx].TextureID = AppearanceManager.DEFAULT_AVATAR_TEXTURE;
|
||||||
|
wearableCache[idx].CacheId = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (face.TextureID == UUID.Zero || face.TextureID == AppearanceManager.DEFAULT_AVATAR_TEXTURE)
|
||||||
|
{
|
||||||
|
wearableCache[idx].CacheId = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
defonly = false; // found a non-default texture reference
|
||||||
|
|
||||||
|
if(sp.Appearance.Texture.FaceTextures[idx].TextureID == wearableCache[idx].TextureID)
|
||||||
|
{
|
||||||
|
if(wearableCache[idx].CacheId != cacheItems[i].CacheId)
|
||||||
|
{
|
||||||
|
wearableCache[idx].CacheId = cacheItems[i].CacheId;
|
||||||
|
validDirtyBakes++;
|
||||||
|
hits++;
|
||||||
|
//assuming this can only happen if asset is in cache
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
|
if (cache != null)
|
||||||
|
wearableCache[idx].TextureAsset = cache.GetCached(face.TextureID.ToString());
|
||||||
|
|
||||||
|
if (wearableCache[idx].TextureAsset != null)
|
||||||
|
{
|
||||||
|
wearableCache[idx].CacheId = cacheItems[i].CacheId;
|
||||||
|
wearableCache[idx].TextureID = sp.Appearance.Texture.FaceTextures[idx].TextureID;
|
||||||
|
validDirtyBakes++;
|
||||||
|
hits++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wearableCache[idx].CacheId = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sp.Appearance.WearableCacheItems = wearableCache;
|
||||||
|
|
||||||
|
// if we got a full set of baked textures save all in BakedTextureModule
|
||||||
|
|
||||||
|
if (validDirtyBakes == cacheItems.Length)
|
||||||
|
{
|
||||||
|
IBakedTextureModule m_BakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
||||||
|
if (m_BakedTextureModule != null)
|
||||||
|
{
|
||||||
|
m_log.Debug("[UpdateBakedCache] uploading to bakedModule cache");
|
||||||
|
|
||||||
|
m_BakedTextureModule.Store(sp.UUID, wearableCache);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// debug
|
||||||
|
for (int iter = 0; iter < AvatarAppearance.BAKE_INDICES.Length; iter++)
|
||||||
|
{
|
||||||
|
int j = AvatarAppearance.BAKE_INDICES[iter];
|
||||||
|
m_log.Debug("[UpdateBCache] {" + iter + "/" +
|
||||||
|
sp.Appearance.WearableCacheItems[j].TextureIndex + "}: c-" +
|
||||||
|
sp.Appearance.WearableCacheItems[j].CacheId + ", t-" +
|
||||||
|
sp.Appearance.WearableCacheItems[j].TextureID);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we only found default textures, then the appearance is not cached
|
||||||
|
return (defonly ? false : true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// called when we get a new root avatar
|
||||||
public bool ValidateBakedTextureCache(IScenePresence sp)
|
public bool ValidateBakedTextureCache(IScenePresence sp)
|
||||||
{
|
{
|
||||||
bool defonly = true; // are we only using default textures
|
bool defonly = true; // are we only using default textures
|
||||||
IImprovedAssetCache cache = m_scene.RequestModuleInterface<IImprovedAssetCache>();
|
IAssetService cache = m_scene.AssetService;
|
||||||
IBakedTextureModule bakedModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
IBakedTextureModule bakedModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
||||||
WearableCacheItem[] wearableCache = null;
|
WearableCacheItem[] wearableCache = null;
|
||||||
|
|
||||||
|
// debug
|
||||||
|
for (int iter = 0; iter < AvatarAppearance.BAKE_INDICES.Length; iter++)
|
||||||
|
{
|
||||||
|
int j = AvatarAppearance.BAKE_INDICES[iter];
|
||||||
|
Primitive.TextureEntryFace face = sp.Appearance.Texture.FaceTextures[iter];
|
||||||
|
if(face != null)
|
||||||
|
m_log.Debug("[ValidateBakedCache] {" + iter + "/" + j + " t - " + face.TextureID);
|
||||||
|
else
|
||||||
|
m_log.Debug("[ValidateBakedCache] {" + iter + "/" + j + " t - No texture");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
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)
|
||||||
|
@ -394,41 +505,35 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
}
|
}
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
|
wearableCache = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wearableCache != null)
|
if (wearableCache != null)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < wearableCache.Length; i++)
|
for (int i = 0; i < wearableCache.Length; i++)
|
||||||
{
|
|
||||||
cache.Cache(wearableCache[i].TextureAsset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
IBakedTextureModule bakedModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
|
|
||||||
if (invService.GetRootFolder(userID) != null)
|
|
||||||
{
|
|
||||||
WearableCacheItem[] wearableCache = null;
|
|
||||||
if (bakedModule != null)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
wearableCache = bakedModule.Get(userID);
|
|
||||||
appearance.WearableCacheItems = wearableCache;
|
|
||||||
appearance.WearableCacheItemsDirty = false;
|
|
||||||
foreach (WearableCacheItem item in wearableCache)
|
|
||||||
{
|
|
||||||
appearance.Texture.FaceTextures[item.TextureIndex].TextureID = item.TextureID;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception)
|
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
m_log.Debug("[ValidateBakedCache] got bakedModule cache");
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Process the texture entry
|
if (wearableCache[i].TextureAsset != null)
|
||||||
|
{
|
||||||
|
wearableCache[i].TextureAsset.Temporary = true;
|
||||||
|
wearableCache[i].TextureAsset.Local = true;
|
||||||
|
cache.Store(wearableCache[i].TextureAsset);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wearableCache[i].TextureID = UUID.Zero;
|
||||||
|
wearableCache[i].CacheId = UUID.Zero;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(wearableCache == null)
|
||||||
|
wearableCache = WearableCacheItem.GetDefaultCacheItem();
|
||||||
|
|
||||||
|
// Process the baked textures
|
||||||
for (int i = 0; i < AvatarAppearance.BAKE_INDICES.Length; i++)
|
for (int i = 0; i < AvatarAppearance.BAKE_INDICES.Length; i++)
|
||||||
{
|
{
|
||||||
int idx = AvatarAppearance.BAKE_INDICES[i];
|
int idx = AvatarAppearance.BAKE_INDICES[i];
|
||||||
|
@ -436,62 +541,74 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
|
|
||||||
// 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)
|
||||||
{
|
|
||||||
if (wearableCache != null)
|
|
||||||
{
|
|
||||||
// If we find the an appearance item, set it as the textureentry and the face
|
|
||||||
WearableCacheItem searchitem = WearableCacheItem.SearchTextureIndex((uint) idx, wearableCache);
|
|
||||||
if (searchitem != null)
|
|
||||||
{
|
{
|
||||||
sp.Appearance.Texture.FaceTextures[idx] = sp.Appearance.Texture.CreateFace((uint)idx);
|
sp.Appearance.Texture.FaceTextures[idx] = sp.Appearance.Texture.CreateFace((uint)idx);
|
||||||
sp.Appearance.Texture.FaceTextures[idx].TextureID = searchitem.TextureID;
|
if (wearableCache[idx].TextureID != UUID.Zero)
|
||||||
|
{
|
||||||
|
sp.Appearance.Texture.FaceTextures[idx].TextureID = wearableCache[idx].TextureID;
|
||||||
face = sp.Appearance.Texture.FaceTextures[idx];
|
face = sp.Appearance.Texture.FaceTextures[idx];
|
||||||
|
// let run to end of loop to check cache
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// if there is no texture entry and no baked cache, skip it
|
sp.Appearance.Texture.FaceTextures[idx].TextureID = AppearanceManager.DEFAULT_AVATAR_TEXTURE;
|
||||||
continue;
|
face = sp.Appearance.Texture.FaceTextures[idx];
|
||||||
}
|
wearableCache[idx].CacheId = UUID.Zero;
|
||||||
}
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
else
|
wearableCache[idx].TextureAsset = null;
|
||||||
{
|
|
||||||
//No texture entry face and no cache. Skip this face.
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// m_log.DebugFormat(
|
|
||||||
// "[AVFACTORY]: Looking for texture {0}, id {1} for {2} {3}",
|
|
||||||
// face.TextureID, idx, client.Name, client.AgentId);
|
|
||||||
|
|
||||||
// if the texture is one of the "defaults" then skip it
|
|
||||||
// this should probably be more intelligent (skirt texture doesnt matter
|
|
||||||
// if the avatar isnt wearing a skirt) but if any of the main baked
|
|
||||||
// textures is default then the rest should be as well
|
|
||||||
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;
|
||||||
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
defonly = false; // found a non-default texture reference
|
defonly = false; // found a non-default texture reference
|
||||||
|
|
||||||
|
if(wearableCache[idx].TextureID != sp.Appearance.Texture.FaceTextures[idx].TextureID)
|
||||||
|
{
|
||||||
|
wearableCache[idx].CacheId = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
wearableCache[idx].TextureAsset = null;
|
||||||
if (cache != null)
|
if (cache != null)
|
||||||
{
|
{
|
||||||
if (!cache.Check(face.TextureID.ToString()))
|
wearableCache[idx].TextureAsset = m_scene.AssetService.Get(face.TextureID.ToString());
|
||||||
return false;
|
if (wearableCache[idx].TextureAsset == null)
|
||||||
|
{
|
||||||
|
wearableCache[idx].CacheId = UUID.Zero;
|
||||||
|
wearableCache[idx].TextureID = UUID.Zero;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
hits++;
|
||||||
if (m_scene.AssetService.Get(face.TextureID.ToString()) == null)
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// m_log.DebugFormat("[AVFACTORY]: Completed texture check for {0} {1}", sp.Name, sp.UUID);
|
sp.Appearance.WearableCacheItems = wearableCache;
|
||||||
|
|
||||||
|
m_log.DebugFormat("[AVFACTORY]: Completed texture check for {0} {1} {2} {3}", sp.Name, sp.UUID, hits, defonly.ToString());
|
||||||
|
// debug
|
||||||
|
for (int iter = 0; iter < AvatarAppearance.BAKE_INDICES.Length; iter++)
|
||||||
|
{
|
||||||
|
int j = AvatarAppearance.BAKE_INDICES[iter];
|
||||||
|
m_log.Debug("[ValidateBakedCache] {" + iter + "/" +
|
||||||
|
sp.Appearance.WearableCacheItems[j].TextureIndex + "}: c-" +
|
||||||
|
sp.Appearance.WearableCacheItems[j].CacheId + ", t-" +
|
||||||
|
sp.Appearance.WearableCacheItems[j].TextureID);
|
||||||
|
}
|
||||||
|
|
||||||
// If we only found default textures, then the appearance is not cached
|
// If we only found default textures, then the appearance is not cached
|
||||||
return (defonly ? false : true);
|
return (defonly ? false : true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int RequestRebake(IScenePresence sp, bool missingTexturesOnly)
|
public int RequestRebake(IScenePresence sp, bool missingTexturesOnly)
|
||||||
{
|
{
|
||||||
int texturesRebaked = 0;
|
int texturesRebaked = 0;
|
||||||
|
|
|
@ -3502,7 +3502,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
// If we aren't using a cached appearance, then clear out the baked textures
|
// If we aren't using a cached appearance, then clear out the baked textures
|
||||||
if (!cachedappearance)
|
if (!cachedappearance)
|
||||||
{
|
{
|
||||||
Appearance.ResetAppearance();
|
// Appearance.ResetAppearance();
|
||||||
// save what ????
|
// save what ????
|
||||||
// maybe needed so the tryretry repair works?
|
// maybe needed so the tryretry repair works?
|
||||||
if (m_scene.AvatarFactory != null)
|
if (m_scene.AvatarFactory != null)
|
||||||
|
|
Loading…
Reference in New Issue