aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs124
1 files changed, 67 insertions, 57 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index d197f5c..27524b5 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -44,11 +44,11 @@ using OpenSim.Framework.Monitoring;
44using OpenSim.Region.Framework.Interfaces; 44using OpenSim.Region.Framework.Interfaces;
45using OpenSim.Region.Framework.Scenes; 45using OpenSim.Region.Framework.Scenes;
46using OpenSim.Services.Interfaces; 46using OpenSim.Services.Interfaces;
47using Caps = OpenSim.Framework.Capabilities.Caps;
48 47
49using AssetLandmark = OpenSim.Framework.AssetLandmark; 48using AssetLandmark = OpenSim.Framework.AssetLandmark;
50using RegionFlags = OpenMetaverse.RegionFlags; 49using Caps = OpenSim.Framework.Capabilities.Caps;
51using PermissionMask = OpenSim.Framework.PermissionMask; 50using PermissionMask = OpenSim.Framework.PermissionMask;
51using RegionFlags = OpenMetaverse.RegionFlags;
52 52
53namespace OpenSim.Region.ClientStack.LindenUDP 53namespace OpenSim.Region.ClientStack.LindenUDP
54{ 54{
@@ -1169,7 +1169,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
1169 OutPacket(GATRP, ThrottleOutPacketType.Task); 1169 OutPacket(GATRP, ThrottleOutPacketType.Task);
1170 } 1170 }
1171 1171
1172
1173 public virtual bool CanSendLayerData() 1172 public virtual bool CanSendLayerData()
1174 { 1173 {
1175 int n = m_udpClient.GetPacketsQueuedCount(ThrottleOutPacketType.Land); 1174 int n = m_udpClient.GetPacketsQueuedCount(ThrottleOutPacketType.Land);
@@ -4093,21 +4092,20 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4093 ResendPrimUpdate(update); 4092 ResendPrimUpdate(update);
4094 } 4093 }
4095 4094
4096 private List<ObjectUpdatePacket.ObjectDataBlock> objectUpdateBlocks = new List<ObjectUpdatePacket.ObjectDataBlock>();
4097 private List<ObjectUpdateCompressedPacket.ObjectDataBlock> compressedUpdateBlocks = new List<ObjectUpdateCompressedPacket.ObjectDataBlock>();
4098 private List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock> terseUpdateBlocks = new List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock>();
4099 private List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock> terseAgentUpdateBlocks = new List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock>();
4100
4101 private void ProcessEntityUpdates(int maxUpdatesBytes) 4095 private void ProcessEntityUpdates(int maxUpdatesBytes)
4102 { 4096 {
4103 if (!IsActive) 4097 if (!IsActive)
4104 return; 4098 return;
4105 4099
4106 OpenSim.Framework.Lazy<List<EntityUpdate>> objectUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4100 List<ObjectUpdatePacket.ObjectDataBlock> objectUpdateBlocks = null;
4107 OpenSim.Framework.Lazy<List<EntityUpdate>> compressedUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4101 List<ObjectUpdateCompressedPacket.ObjectDataBlock> compressedUpdateBlocks = null;
4108 OpenSim.Framework.Lazy<List<EntityUpdate>> terseUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4102 List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock> terseUpdateBlocks = null;
4109 OpenSim.Framework.Lazy<List<EntityUpdate>> terseAgentUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4103 List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock> terseAgentUpdateBlocks = null;
4110 OpenSim.Framework.Lazy<List<SceneObjectPart>> ObjectAnimationUpdates = new OpenSim.Framework.Lazy<List<SceneObjectPart>>(); 4104 List<EntityUpdate> objectUpdates = null;
4105 List<EntityUpdate> compressedUpdates = null;
4106 List<EntityUpdate> terseUpdates = null;
4107 List<EntityUpdate> terseAgentUpdates = null;
4108 List<SceneObjectPart> ObjectAnimationUpdates = null;
4111 4109
4112 // Check to see if this is a flush 4110 // Check to see if this is a flush
4113 if (maxUpdatesBytes <= 0) 4111 if (maxUpdatesBytes <= 0)
@@ -4284,7 +4282,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4284 SceneObjectPart sop = (SceneObjectPart)update.Entity; 4282 SceneObjectPart sop = (SceneObjectPart)update.Entity;
4285 if ( sop.Animations != null) 4283 if ( sop.Animations != null)
4286 { 4284 {
4287 ObjectAnimationUpdates.Value.Add(sop); 4285 if(ObjectAnimationUpdates == null)
4286 ObjectAnimationUpdates = new List<SceneObjectPart>();
4287 ObjectAnimationUpdates.Add(sop);
4288 maxUpdatesBytes -= 32 * sop.Animations.Count + 16; 4288 maxUpdatesBytes -= 32 * sop.Animations.Count + 16;
4289 } 4289 }
4290 } 4290 }
@@ -4344,14 +4344,24 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4344 if (update.Entity is ScenePresence) 4344 if (update.Entity is ScenePresence)
4345 { 4345 {
4346 // ALL presence updates go into a special list 4346 // ALL presence updates go into a special list
4347 if (terseAgentUpdateBlocks == null)
4348 {
4349 terseAgentUpdateBlocks = new List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock>();
4350 terseAgentUpdates = new List<EntityUpdate>();
4351 }
4347 terseAgentUpdateBlocks.Add(ablock); 4352 terseAgentUpdateBlocks.Add(ablock);
4348 terseAgentUpdates.Value.Add(update); 4353 terseAgentUpdates.Add(update);
4349 } 4354 }
4350 else 4355 else
4351 { 4356 {
4352 // Everything else goes here 4357 // Everything else goes here
4358 if (terseAgentUpdateBlocks == null)
4359 {
4360 terseAgentUpdateBlocks = new List<ImprovedTerseObjectUpdatePacket.ObjectDataBlock>();
4361 terseAgentUpdates = new List<EntityUpdate>();
4362 }
4353 terseUpdateBlocks.Add(ablock); 4363 terseUpdateBlocks.Add(ablock);
4354 terseUpdates.Value.Add(update); 4364 terseUpdates.Add(update);
4355 } 4365 }
4356 maxUpdatesBytes -= ablock.Length; 4366 maxUpdatesBytes -= ablock.Length;
4357 } 4367 }
@@ -4362,8 +4372,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4362 ablock = CreateAvatarUpdateBlock((ScenePresence)update.Entity); 4372 ablock = CreateAvatarUpdateBlock((ScenePresence)update.Entity);
4363 else 4373 else
4364 ablock = CreatePrimUpdateBlock((SceneObjectPart)update.Entity, mysp); 4374 ablock = CreatePrimUpdateBlock((SceneObjectPart)update.Entity, mysp);
4375 if(objectUpdateBlocks == null)
4376 {
4377 objectUpdateBlocks = new List<ObjectUpdatePacket.ObjectDataBlock>();
4378 objectUpdates = new List<EntityUpdate>();
4379 }
4365 objectUpdateBlocks.Add(ablock); 4380 objectUpdateBlocks.Add(ablock);
4366 objectUpdates.Value.Add(update); 4381 objectUpdates.Add(update);
4367 maxUpdatesBytes -= ablock.Length; 4382 maxUpdatesBytes -= ablock.Length;
4368 } 4383 }
4369 4384
@@ -4379,7 +4394,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4379 4394
4380 timeDilation = Utils.FloatToUInt16(m_scene.TimeDilation, 0.0f, 1.0f); 4395 timeDilation = Utils.FloatToUInt16(m_scene.TimeDilation, 0.0f, 1.0f);
4381 4396
4382 if (terseAgentUpdateBlocks.Count > 0) 4397 if (terseAgentUpdateBlocks!= null)
4383 { 4398 {
4384 ImprovedTerseObjectUpdatePacket packet 4399 ImprovedTerseObjectUpdatePacket packet
4385 = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ImprovedTerseObjectUpdate); 4400 = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ImprovedTerseObjectUpdate);
@@ -4388,10 +4403,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4388 packet.ObjectData = terseAgentUpdateBlocks.ToArray(); 4403 packet.ObjectData = terseAgentUpdateBlocks.ToArray();
4389 terseAgentUpdateBlocks.Clear(); 4404 terseAgentUpdateBlocks.Clear();
4390 4405
4391 OutPacket(packet, ThrottleOutPacketType.Unknown, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseAgentUpdates.Value, oPacket); }); 4406 OutPacket(packet, ThrottleOutPacketType.Unknown, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseAgentUpdates, oPacket); });
4392 } 4407 }
4393 4408
4394 if (objectUpdateBlocks.Count > 0) 4409 if (objectUpdateBlocks != null)
4395 { 4410 {
4396 ObjectUpdatePacket packet = (ObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdate); 4411 ObjectUpdatePacket packet = (ObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdate);
4397 packet.RegionData.RegionHandle = m_scene.RegionInfo.RegionHandle; 4412 packet.RegionData.RegionHandle = m_scene.RegionInfo.RegionHandle;
@@ -4399,10 +4414,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4399 packet.ObjectData = objectUpdateBlocks.ToArray(); 4414 packet.ObjectData = objectUpdateBlocks.ToArray();
4400 objectUpdateBlocks.Clear(); 4415 objectUpdateBlocks.Clear();
4401 4416
4402 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(objectUpdates.Value, oPacket); }); 4417 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(objectUpdates, oPacket); });
4403 } 4418 }
4404 4419
4405 if (compressedUpdateBlocks.Count > 0) 4420 if (compressedUpdateBlocks != null)
4406 { 4421 {
4407 ObjectUpdateCompressedPacket packet = (ObjectUpdateCompressedPacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdateCompressed); 4422 ObjectUpdateCompressedPacket packet = (ObjectUpdateCompressedPacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdateCompressed);
4408 packet.RegionData.RegionHandle = m_scene.RegionInfo.RegionHandle; 4423 packet.RegionData.RegionHandle = m_scene.RegionInfo.RegionHandle;
@@ -4410,10 +4425,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4410 packet.ObjectData = compressedUpdateBlocks.ToArray(); 4425 packet.ObjectData = compressedUpdateBlocks.ToArray();
4411 compressedUpdateBlocks.Clear(); 4426 compressedUpdateBlocks.Clear();
4412 4427
4413 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(compressedUpdates.Value, oPacket); }); 4428 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(compressedUpdates, oPacket); });
4414 } 4429 }
4415 4430
4416 if (terseUpdateBlocks.Count > 0) 4431 if (terseUpdateBlocks != null)
4417 { 4432 {
4418 ImprovedTerseObjectUpdatePacket packet = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket( 4433 ImprovedTerseObjectUpdatePacket packet = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(
4419 PacketType.ImprovedTerseObjectUpdate); 4434 PacketType.ImprovedTerseObjectUpdate);
@@ -4422,39 +4437,42 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4422 packet.ObjectData = terseUpdateBlocks.ToArray(); 4437 packet.ObjectData = terseUpdateBlocks.ToArray();
4423 terseUpdateBlocks.Clear(); 4438 terseUpdateBlocks.Clear();
4424 4439
4425 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseUpdates.Value, oPacket); }); 4440 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseUpdates, oPacket); });
4426 } 4441 }
4427 4442
4428 foreach (SceneObjectPart sop in ObjectAnimationUpdates.Value) 4443 if(ObjectAnimationUpdates != null)
4429 { 4444 {
4430 if (sop.Animations == null) 4445 foreach (SceneObjectPart sop in ObjectAnimationUpdates)
4431 continue; 4446 {
4432 SceneObjectGroup sog = sop.ParentGroup; 4447 if (sop.Animations == null)
4433 if (sog == null || sog.IsDeleted) 4448 continue;
4434 continue; 4449 SceneObjectGroup sog = sop.ParentGroup;
4450 if (sog == null || sog.IsDeleted)
4451 continue;
4435 4452
4436 SceneObjectPart root = sog.RootPart; 4453 SceneObjectPart root = sog.RootPart;
4437 if (root == null || root.Shape == null || !root.Shape.MeshFlagEntry) 4454 if (root == null || root.Shape == null || !root.Shape.MeshFlagEntry)
4438 continue; 4455 continue;
4439 4456
4440 UUID[] ids = null; 4457 UUID[] ids = null;
4441 int[] seqs = null; 4458 int[] seqs = null;
4442 int count = sop.GetAnimations(out ids, out seqs); 4459 int count = sop.GetAnimations(out ids, out seqs);
4443 if(count < 0) 4460 if(count < 0)
4444 continue; 4461 continue;
4445 4462
4446 ObjectAnimationPacket ani = (ObjectAnimationPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAnimation); 4463 ObjectAnimationPacket ani = (ObjectAnimationPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAnimation);
4447 ani.Sender = new ObjectAnimationPacket.SenderBlock(); 4464 ani.Sender = new ObjectAnimationPacket.SenderBlock();
4448 ani.Sender.ID = sop.UUID; 4465 ani.Sender.ID = sop.UUID;
4449 ani.AnimationList = new ObjectAnimationPacket.AnimationListBlock[sop.Animations.Count]; 4466 ani.AnimationList = new ObjectAnimationPacket.AnimationListBlock[sop.Animations.Count];
4450 4467
4451 for(int i = 0; i< count; i++) 4468 for(int i = 0; i< count; i++)
4452 { 4469 {
4453 ani.AnimationList[i] = new ObjectAnimationPacket.AnimationListBlock(); 4470 ani.AnimationList[i] = new ObjectAnimationPacket.AnimationListBlock();
4454 ani.AnimationList[i].AnimID = ids[i]; 4471 ani.AnimationList[i].AnimID = ids[i];
4455 ani.AnimationList[i].AnimSequenceID = seqs[i]; 4472 ani.AnimationList[i].AnimSequenceID = seqs[i];
4473 }
4474 OutPacket(ani, ThrottleOutPacketType.Task, true);
4456 } 4475 }
4457 OutPacket(ani, ThrottleOutPacketType.Task);
4458 } 4476 }
4459 4477
4460 #endregion Packet Sending 4478 #endregion Packet Sending
@@ -5750,14 +5768,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
5750 5768
5751 // Don't send texture entry for avatars here - this is accomplished via the AvatarAppearance packet 5769 // Don't send texture entry for avatars here - this is accomplished via the AvatarAppearance packet
5752 update.TextureEntry = Utils.EmptyBytes; 5770 update.TextureEntry = Utils.EmptyBytes;
5753// update.TextureEntry = (data.Appearance.Texture != null) ? data.Appearance.Texture.GetBytes() : Utils.EmptyBytes;
5754
5755/* all this flags seem related to prims and not avatars. This allow for wrong viewer side move of a avatar in prim edition mode (anv mantis 854)
5756 update.UpdateFlags = (uint)(
5757 PrimFlags.Physics | PrimFlags.ObjectModify | PrimFlags.ObjectCopy | PrimFlags.ObjectAnyOwner |
5758 PrimFlags.ObjectYouOwner | PrimFlags.ObjectMove | PrimFlags.InventoryEmpty | PrimFlags.ObjectTransfer |
5759 PrimFlags.ObjectOwnerModify);
5760*/
5761 update.UpdateFlags = 0; 5771 update.UpdateFlags = 0;
5762 5772
5763 return update; 5773 return update;