aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/ClientStack/Linden
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/ClientStack/Linden')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs126
1 files changed, 37 insertions, 89 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index bd0f5ca..bfdb24f 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -11848,7 +11848,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
11848 /// <returns></returns> 11848 /// <returns></returns>
11849 protected bool HandleAgentTextureCached(IClientAPI simclient, Packet packet) 11849 protected bool HandleAgentTextureCached(IClientAPI simclient, Packet packet)
11850 { 11850 {
11851 //m_log.Debug("texture cached: " + packet.ToString());
11852 AgentCachedTexturePacket cachedtex = (AgentCachedTexturePacket)packet; 11851 AgentCachedTexturePacket cachedtex = (AgentCachedTexturePacket)packet;
11853 AgentCachedTextureResponsePacket cachedresp = (AgentCachedTextureResponsePacket)PacketPool.Instance.GetPacket(PacketType.AgentCachedTextureResponse); 11852 AgentCachedTextureResponsePacket cachedresp = (AgentCachedTextureResponsePacket)PacketPool.Instance.GetPacket(PacketType.AgentCachedTextureResponse);
11854 11853
@@ -11864,24 +11863,22 @@ namespace OpenSim.Region.ClientStack.LindenUDP
11864 cachedresp.WearableData = 11863 cachedresp.WearableData =
11865 new AgentCachedTextureResponsePacket.WearableDataBlock[cachedtex.WearableData.Length]; 11864 new AgentCachedTextureResponsePacket.WearableDataBlock[cachedtex.WearableData.Length];
11866 11865
11867 //IAvatarFactoryModule fac = m_scene.RequestModuleInterface<IAvatarFactoryModule>();
11868 // var item = fac.GetBakedTextureFaces(AgentId);
11869 //WearableCacheItem[] items = fac.GetCachedItems(AgentId);
11870
11871 IAssetService cache = m_scene.AssetService;
11872 IBakedTextureModule bakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
11873 //bakedTextureModule = null;
11874 int maxWearablesLoop = cachedtex.WearableData.Length; 11866 int maxWearablesLoop = cachedtex.WearableData.Length;
11875 if (maxWearablesLoop > AvatarWearable.MAX_WEARABLES) 11867 if (maxWearablesLoop > AvatarWearable.MAX_WEARABLES)
11876 maxWearablesLoop = AvatarWearable.MAX_WEARABLES; 11868 maxWearablesLoop = AvatarWearable.MAX_WEARABLES;
11877 11869
11870 // Find the cached baked textures for this user, if they're available
11871
11872 IAssetService cache = m_scene.AssetService;
11873 IBakedTextureModule bakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
11874
11875 WearableCacheItem[] cacheItems = null;
11876
11878 if (bakedTextureModule != null && cache != null) 11877 if (bakedTextureModule != null && cache != null)
11879 { 11878 {
11880 // 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
11881
11882 WearableCacheItem[] cacheItems = null;
11883 ScenePresence p = m_scene.GetScenePresence(AgentId); 11879 ScenePresence p = m_scene.GetScenePresence(AgentId);
11884 if (p.Appearance != null) 11880 if (p.Appearance != null)
11881 {
11885 if (p.Appearance.WearableCacheItems == null || p.Appearance.WearableCacheItemsDirty) 11882 if (p.Appearance.WearableCacheItems == null || p.Appearance.WearableCacheItemsDirty)
11886 { 11883 {
11887 try 11884 try
@@ -11890,22 +11887,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
11890 p.Appearance.WearableCacheItems = cacheItems; 11887 p.Appearance.WearableCacheItems = cacheItems;
11891 p.Appearance.WearableCacheItemsDirty = false; 11888 p.Appearance.WearableCacheItemsDirty = false;
11892 } 11889 }
11893
11894 /*
11895 * The following Catch types DO NOT WORK, it jumps to the General Packet Exception Handler if you don't catch Exception!
11896 *
11897 catch (System.Net.Sockets.SocketException)
11898 {
11899 cacheItems = null;
11900 }
11901 catch (WebException)
11902 {
11903 cacheItems = null;
11904 }
11905 catch (InvalidOperationException)
11906 {
11907 cacheItems = null;
11908 } */
11909 catch (Exception) 11890 catch (Exception)
11910 { 11891 {
11911 cacheItems = null; 11892 cacheItems = null;
@@ -11916,87 +11897,54 @@ namespace OpenSim.Region.ClientStack.LindenUDP
11916 { 11897 {
11917 cacheItems = p.Appearance.WearableCacheItems; 11898 cacheItems = p.Appearance.WearableCacheItems;
11918 } 11899 }
11900 }
11901 }
11919 11902
11920 if (cache != null && cacheItems != null) 11903 if (cacheItems != null)
11904 {
11905 // We need to make sure the asset stored in the bake is available on this server also by its assetid before we map it to a Cacheid.
11906 // Copy the baked textures to the sim's assets cache (local only).
11907 foreach (WearableCacheItem item in cacheItems)
11921 { 11908 {
11922 foreach (WearableCacheItem item in cacheItems) 11909 if (cache.GetCached(item.TextureID.ToString()) == null)
11923 { 11910 {
11924 11911 item.TextureAsset.Temporary = true;
11925 if (cache.GetCached(item.TextureID.ToString()) == null) 11912 item.TextureAsset.Local = true;
11926 { 11913 cache.Store(item.TextureAsset);
11927 item.TextureAsset.Temporary = true;
11928 cache.Store(item.TextureAsset);
11929 }
11930
11931
11932 } 11914 }
11933 } 11915 }
11934 if (cacheItems != null) 11916
11917 // Return the cached textures
11918 for (int i = 0; i < maxWearablesLoop; i++)
11935 { 11919 {
11920 WearableCacheItem item =
11921 WearableCacheItem.SearchTextureIndex(cachedtex.WearableData[i].TextureIndex, cacheItems);
11936 11922
11937 for (int i = 0; i < maxWearablesLoop; i++) 11923 cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
11924 cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
11925 cachedresp.WearableData[i].HostName = new byte[0];
11926 if (item != null && cachedtex.WearableData[i].ID == item.CacheId)
11938 { 11927 {
11939 WearableCacheItem item = 11928 cachedresp.WearableData[i].TextureID = item.TextureID;
11940 WearableCacheItem.SearchTextureIndex(cachedtex.WearableData[i].TextureIndex,cacheItems);
11941
11942 cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
11943 cachedresp.WearableData[i].TextureIndex= cachedtex.WearableData[i].TextureIndex;
11944 cachedresp.WearableData[i].HostName = new byte[0];
11945 if (item != null && cachedtex.WearableData[i].ID == item.CacheId)
11946 {
11947
11948 cachedresp.WearableData[i].TextureID = item.TextureID;
11949 }
11950 else
11951 {
11952 cachedresp.WearableData[i].TextureID = UUID.Zero;
11953 }
11954 } 11929 }
11955 } 11930 else
11956 else
11957 {
11958 for (int i = 0; i < maxWearablesLoop; i++)
11959 { 11931 {
11960 cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
11961 cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
11962 cachedresp.WearableData[i].TextureID = UUID.Zero; 11932 cachedresp.WearableData[i].TextureID = UUID.Zero;
11963 //UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
11964 cachedresp.WearableData[i].HostName = new byte[0];
11965 } 11933 }
11966 } 11934 }
11967 } 11935 }
11968 else 11936 else
11969 { 11937 {
11970 if (cache == null) 11938 // Cached textures not available
11939 for (int i = 0; i < maxWearablesLoop; i++)
11971 { 11940 {
11972 for (int i = 0; i < maxWearablesLoop; i++) 11941 cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
11973 { 11942 cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
11974 cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock(); 11943 cachedresp.WearableData[i].TextureID = UUID.Zero;
11975 cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex; 11944 cachedresp.WearableData[i].HostName = new byte[0];
11976 cachedresp.WearableData[i].TextureID = UUID.Zero;
11977 //UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
11978 cachedresp.WearableData[i].HostName = new byte[0];
11979 }
11980 }
11981 else
11982 {
11983 for (int i = 0; i < maxWearablesLoop; i++)
11984 {
11985 cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
11986 cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
11987
11988
11989
11990 if (cache.GetCached(cachedresp.WearableData[i].TextureID.ToString()) == null)
11991 cachedresp.WearableData[i].TextureID = UUID.Zero;
11992 //UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
11993 else
11994 cachedresp.WearableData[i].TextureID = UUID.Zero;
11995 // UUID.Parse("8334fb6e-c2f5-46ee-807d-a435f61a8d46");
11996 cachedresp.WearableData[i].HostName = new byte[0];
11997 }
11998 } 11945 }
11999 } 11946 }
11947
12000 cachedresp.Header.Zerocoded = true; 11948 cachedresp.Header.Zerocoded = true;
12001 OutPacket(cachedresp, ThrottleOutPacketType.Task); 11949 OutPacket(cachedresp, ThrottleOutPacketType.Task);
12002 11950