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/Caps/ServerReleaseNotesModule.cs2
-rw-r--r--OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs5
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs84
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs14
4 files changed, 87 insertions, 18 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/ServerReleaseNotesModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/ServerReleaseNotesModule.cs
index e172db7..cf79982 100644
--- a/OpenSim/Region/ClientStack/Linden/Caps/ServerReleaseNotesModule.cs
+++ b/OpenSim/Region/ClientStack/Linden/Caps/ServerReleaseNotesModule.cs
@@ -126,8 +126,6 @@ namespace OpenSim.Region.ClientStack.LindenCaps
126 Hashtable responsedata = new Hashtable(); 126 Hashtable responsedata = new Hashtable();
127 responsedata["int_response_code"] = 301; 127 responsedata["int_response_code"] = 301;
128 responsedata["str_redirect_location"] = m_ServerReleaseNotesURL; 128 responsedata["str_redirect_location"] = m_ServerReleaseNotesURL;
129 responsedata["content_type"] = "text/plain";
130
131 return responsedata; 129 return responsedata;
132 } 130 }
133 } 131 }
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs
index b06e93c..b52f2fd 100644
--- a/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs
+++ b/OpenSim/Region/ClientStack/Linden/Caps/SimulatorFeaturesModule.cs
@@ -172,6 +172,11 @@ namespace OpenSim.Region.ClientStack.Linden
172 if(m_doScriptSyntax && m_scriptSyntaxID != UUID.Zero) 172 if(m_doScriptSyntax && m_scriptSyntaxID != UUID.Zero)
173 m_features["LSLSyntaxId"] = OSD.FromUUID(m_scriptSyntaxID); 173 m_features["LSLSyntaxId"] = OSD.FromUUID(m_scriptSyntaxID);
174 174
175 OSDMap meshAnim = new OSDMap();
176 meshAnim["AnimatedObjectMaxTris"] = OSD.FromInteger(10000);
177 meshAnim["MaxAgentAnimatedObjectAttachments"] = OSD.FromInteger(2);
178 m_features["AnimatedObjects"] = meshAnim;
179
175 // Extra information for viewers that want to use it 180 // Extra information for viewers that want to use it
176 // TODO: Take these out of here into their respective modules, like map-server-url 181 // TODO: Take these out of here into their respective modules, like map-server-url
177 OSDMap extrasMap; 182 OSDMap extrasMap;
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index c42446c..882f22f 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -454,9 +454,24 @@ namespace OpenSim.Region.ClientStack.LindenUDP
454 public string Name { get { return FirstName + " " + LastName; } } 454 public string Name { get { return FirstName + " " + LastName; } }
455 455
456 public uint CircuitCode { get { return m_circuitCode; } } 456 public uint CircuitCode { get { return m_circuitCode; } }
457
458 protected int m_animationSequenceNumber = (int)(Util.GetTimeStampTicks() & 0x5fffafL);
457 public int NextAnimationSequenceNumber 459 public int NextAnimationSequenceNumber
458 { 460 {
459 get { return m_udpServer.NextAnimationSequenceNumber; } 461 get
462 {
463 int ret = Interlocked.Increment(ref m_animationSequenceNumber);
464 if (ret <= 0)
465 {
466 m_animationSequenceNumber = (int)(Util.GetTimeStampTicks() & 0xafff5fL);
467 ret = Interlocked.Increment(ref m_animationSequenceNumber);
468 }
469 return ret;
470 }
471 set
472 {
473 m_animationSequenceNumber = value;
474 }
460 } 475 }
461 476
462 /// <summary> 477 /// <summary>
@@ -3904,6 +3919,25 @@ namespace OpenSim.Region.ClientStack.LindenUDP
3904 OutPacket(ani, ThrottleOutPacketType.Task | ThrottleOutPacketType.HighPriority); 3919 OutPacket(ani, ThrottleOutPacketType.Task | ThrottleOutPacketType.HighPriority);
3905 } 3920 }
3906 3921
3922 public void SendObjectAnimations(UUID[] animations, int[] seqs, UUID senderId)
3923 {
3924 // m_log.DebugFormat("[LLCLIENTVIEW]: Sending Object animations for {0} to {1}", sourceAgentId, Name);
3925
3926 ObjectAnimationPacket ani = (ObjectAnimationPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAnimation);
3927 // TODO: don't create new blocks if recycling an old packet
3928 ani.Sender = new ObjectAnimationPacket.SenderBlock();
3929 ani.Sender.ID = senderId;
3930 ani.AnimationList = new ObjectAnimationPacket.AnimationListBlock[animations.Length];
3931
3932 for (int i = 0; i < animations.Length; ++i)
3933 {
3934 ani.AnimationList[i] = new ObjectAnimationPacket.AnimationListBlock();
3935 ani.AnimationList[i].AnimID = animations[i];
3936 ani.AnimationList[i].AnimSequenceID = seqs[i];
3937 }
3938 OutPacket(ani, ThrottleOutPacketType.Task);
3939 }
3940
3907 #endregion 3941 #endregion
3908 3942
3909 #region Avatar Packet/Data Sending Methods 3943 #region Avatar Packet/Data Sending Methods
@@ -4127,6 +4161,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4127 OpenSim.Framework.Lazy<List<EntityUpdate>> compressedUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4161 OpenSim.Framework.Lazy<List<EntityUpdate>> compressedUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>();
4128 OpenSim.Framework.Lazy<List<EntityUpdate>> terseUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4162 OpenSim.Framework.Lazy<List<EntityUpdate>> terseUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>();
4129 OpenSim.Framework.Lazy<List<EntityUpdate>> terseAgentUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>(); 4163 OpenSim.Framework.Lazy<List<EntityUpdate>> terseAgentUpdates = new OpenSim.Framework.Lazy<List<EntityUpdate>>();
4164 OpenSim.Framework.Lazy<List<SceneObjectPart>> ObjectAnimationUpdates = new OpenSim.Framework.Lazy<List<SceneObjectPart>>();
4130 4165
4131 // Check to see if this is a flush 4166 // Check to see if this is a flush
4132 if (maxUpdatesBytes <= 0) 4167 if (maxUpdatesBytes <= 0)
@@ -4297,12 +4332,24 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4297 bool canUseCompressed = true; 4332 bool canUseCompressed = true;
4298 bool canUseImproved = true; 4333 bool canUseImproved = true;
4299 4334
4300
4301 // Compressed object updates only make sense for LL primitives 4335 // Compressed object updates only make sense for LL primitives
4302 if (!(update.Entity is SceneObjectPart)) 4336 if (!(update.Entity is SceneObjectPart))
4303 { 4337 {
4304 canUseCompressed = false; 4338 canUseCompressed = false;
4305 } 4339 }
4340 else
4341 {
4342 if(updateFlags.HasFlag(PrimUpdateFlags.Animations))
4343 {
4344 updateFlags &= ~PrimUpdateFlags.Animations;
4345 SceneObjectPart sop = (SceneObjectPart)update.Entity;
4346 if(sop.Animations != null)
4347 {
4348 ObjectAnimationUpdates.Value.Add(sop);
4349 maxUpdatesBytes -= 32 * sop.Animations.Count + 16;
4350 }
4351 }
4352 }
4306 4353
4307 if (updateFlags.HasFlag(PrimUpdateFlags.FullUpdate)) 4354 if (updateFlags.HasFlag(PrimUpdateFlags.FullUpdate))
4308 { 4355 {
@@ -4443,6 +4490,38 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4443 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseUpdates.Value, oPacket); }); 4490 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseUpdates.Value, oPacket); });
4444 } 4491 }
4445 4492
4493 foreach (SceneObjectPart sop in ObjectAnimationUpdates.Value)
4494 {
4495 if (sop.Animations == null)
4496 continue;
4497 SceneObjectGroup sog = sop.ParentGroup;
4498 if (sog == null || sog.IsDeleted)
4499 continue;
4500
4501 SceneObjectPart root = sog.RootPart;
4502 if (root == null || root.Shape == null || !root.Shape.MeshFlagEntry)
4503 continue;
4504
4505 UUID[] ids = null;
4506 int[] seqs = null;
4507 int count = sop.GetAnimations(out ids, out seqs);
4508 if(count < 0)
4509 continue;
4510
4511 ObjectAnimationPacket ani = (ObjectAnimationPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAnimation);
4512 ani.Sender = new ObjectAnimationPacket.SenderBlock();
4513 ani.Sender.ID = sop.UUID;
4514 ani.AnimationList = new ObjectAnimationPacket.AnimationListBlock[sop.Animations.Count];
4515
4516 for(int i = 0; i< count; i++)
4517 {
4518 ani.AnimationList[i] = new ObjectAnimationPacket.AnimationListBlock();
4519 ani.AnimationList[i].AnimID = ids[i];
4520 ani.AnimationList[i].AnimSequenceID = seqs[i];
4521 }
4522 OutPacket(ani, ThrottleOutPacketType.Task);
4523 }
4524
4446 #endregion Packet Sending 4525 #endregion Packet Sending
4447 4526
4448 #region Handle deleted objects 4527 #region Handle deleted objects
@@ -4462,6 +4541,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4462 GroupsInView.Add(grp); 4541 GroupsInView.Add(grp);
4463 } 4542 }
4464 } 4543 }
4544
4465 #endregion 4545 #endregion
4466 } 4546 }
4467 4547
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs
index 567bbb5..70cca51 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs
@@ -341,19 +341,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
341 /// <summary>Flag to signal when clients should send pings</summary> 341 /// <summary>Flag to signal when clients should send pings</summary>
342 protected bool m_sendPing; 342 protected bool m_sendPing;
343 343
344 protected int m_animationSequenceNumber;
345
346 public int NextAnimationSequenceNumber
347 {
348 get
349 {
350 m_animationSequenceNumber++;
351 if (m_animationSequenceNumber > 2147482624)
352 m_animationSequenceNumber = 1;
353 return m_animationSequenceNumber;
354 }
355 }
356
357 protected ExpiringCache<IPEndPoint, Queue<UDPPacketBuffer>> m_pendingCache = new ExpiringCache<IPEndPoint, Queue<UDPPacketBuffer>>(); 344 protected ExpiringCache<IPEndPoint, Queue<UDPPacketBuffer>> m_pendingCache = new ExpiringCache<IPEndPoint, Queue<UDPPacketBuffer>>();
358 345
359 protected Pool<IncomingPacket> m_incomingPacketPool; 346 protected Pool<IncomingPacket> m_incomingPacketPool;
@@ -507,7 +494,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
507 ThrottleRates = new ThrottleRates(configSource); 494 ThrottleRates = new ThrottleRates(configSource);
508 495
509 Random rnd = new Random(Util.EnvironmentTickCount()); 496 Random rnd = new Random(Util.EnvironmentTickCount());
510 m_animationSequenceNumber = rnd.Next(11474826);
511 497
512// if (usePools) 498// if (usePools)
513// EnablePools(); 499// EnablePools();