aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Framework/AvatarAppearance.cs72
-rw-r--r--OpenSim/Framework/ChildAgentDataUpdate.cs2
-rw-r--r--OpenSim/Framework/Util.cs42
3 files changed, 96 insertions, 20 deletions
diff --git a/OpenSim/Framework/AvatarAppearance.cs b/OpenSim/Framework/AvatarAppearance.cs
index a68de57..21e2233 100644
--- a/OpenSim/Framework/AvatarAppearance.cs
+++ b/OpenSim/Framework/AvatarAppearance.cs
@@ -405,31 +405,40 @@ namespace OpenSim.Framework
405 /// </remarks> 405 /// </remarks>
406 public List<AvatarAttachment> GetAttachments() 406 public List<AvatarAttachment> GetAttachments()
407 { 407 {
408
409
408 lock (m_attachments) 410 lock (m_attachments)
409 { 411 {
410 List<AvatarAttachment> alist = new List<AvatarAttachment>(); 412 List<AvatarAttachment> alist = new List<AvatarAttachment>();
411 foreach (KeyValuePair<int, List<AvatarAttachment>> kvp in m_attachments) 413 foreach (KeyValuePair<int, List<AvatarAttachment>> kvp in m_attachments)
412 { 414 {
413 foreach (AvatarAttachment attach in kvp.Value) 415 foreach (AvatarAttachment attach in kvp.Value)
414 alist.Add(new AvatarAttachment(attach)); 416 alist.Add(new AvatarAttachment(attach));
415 } 417 }
416 418 return alist;
417 return alist; 419 } }
418 }
419 }
420 420
421 internal void AppendAttachment(AvatarAttachment attach) 421 internal void AppendAttachment(AvatarAttachment attach)
422 { 422 {
423// m_log.DebugFormat(
424// "[AVATAR APPEARNCE]: Appending itemID={0}, assetID={1} at {2}",
425// attach.ItemID, attach.AssetID, attach.AttachPoint);
426
423 lock (m_attachments) 427 lock (m_attachments)
424 { 428 {
425 if (!m_attachments.ContainsKey(attach.AttachPoint)) 429 if (!m_attachments.ContainsKey(attach.AttachPoint))
426 m_attachments[attach.AttachPoint] = new List<AvatarAttachment>(); 430 m_attachments[attach.AttachPoint] = new List<AvatarAttachment>();
431
427 m_attachments[attach.AttachPoint].Add(attach); 432 m_attachments[attach.AttachPoint].Add(attach);
428 } 433 }
429 } 434 }
430 435
431 internal void ReplaceAttachment(AvatarAttachment attach) 436 internal void ReplaceAttachment(AvatarAttachment attach)
432 { 437 {
438// m_log.DebugFormat(
439// "[AVATAR APPEARANCE]: Replacing itemID={0}, assetID={1} at {2}",
440// attach.ItemID, attach.AssetID, attach.AttachPoint);
441
433 lock (m_attachments) 442 lock (m_attachments)
434 { 443 {
435 m_attachments[attach.AttachPoint] = new List<AvatarAttachment>(); 444 m_attachments[attach.AttachPoint] = new List<AvatarAttachment>();
@@ -438,7 +447,7 @@ namespace OpenSim.Framework
438 } 447 }
439 448
440 /// <summary> 449 /// <summary>
441 /// Add an attachment 450 /// Set an attachment
442 /// </summary> 451 /// </summary>
443 /// <remarks> 452 /// <remarks>
444 /// If the attachpoint has the 453 /// If the attachpoint has the
@@ -454,13 +463,13 @@ namespace OpenSim.Framework
454 /// </returns> 463 /// </returns>
455 public bool SetAttachment(int attachpoint, UUID item, UUID asset) 464 public bool SetAttachment(int attachpoint, UUID item, UUID asset)
456 { 465 {
457 if (attachpoint == 0)
458 return false;
459
460// m_log.DebugFormat( 466// m_log.DebugFormat(
461// "[AVATAR APPEARANCE]: Setting attachment at {0} with item ID {1}, asset ID {2}", 467// "[AVATAR APPEARANCE]: Setting attachment at {0} with item ID {1}, asset ID {2}",
462// attachpoint, item, asset); 468// attachpoint, item, asset);
463 469
470 if (attachpoint == 0)
471 return false;
472
464 if (item == UUID.Zero) 473 if (item == UUID.Zero)
465 { 474 {
466 lock (m_attachments) 475 lock (m_attachments)
@@ -470,12 +479,21 @@ namespace OpenSim.Framework
470 m_attachments.Remove(attachpoint); 479 m_attachments.Remove(attachpoint);
471 return true; 480 return true;
472 } 481 }
473 return false;
474 } 482 }
483
484 return false;
475 } 485 }
476 486
477 // check if the item is already attached at this point 487 // When a user logs in, the attachment item ids are pulled from persistence in the Avatars table. However,
478 if (GetAttachpoint(item) == (attachpoint & 0x7F)) 488 // the asset ids are not saved. When the avatar enters a simulator the attachments are set again. If
489 // we simply perform an item check here then the asset ids (which are now present) are never set, and NPC attachments
490 // later fail unless the attachment is detached and reattached.
491 //
492 // Therefore, we will carry on with the set if the existing attachment has no asset id.
493 AvatarAttachment existingAttachment = GetAttachmentForItem(item);
494 if (existingAttachment != null
495 && existingAttachment.AssetID != UUID.Zero
496 && existingAttachment.AttachPoint == (attachpoint & 0x7F))
479 { 497 {
480 // m_log.DebugFormat("[AVATAR APPEARANCE] attempt to attach an already attached item {0}",item); 498 // m_log.DebugFormat("[AVATAR APPEARANCE] attempt to attach an already attached item {0}",item);
481 return false; 499 return false;
@@ -492,9 +510,30 @@ namespace OpenSim.Framework
492 { 510 {
493 ReplaceAttachment(new AvatarAttachment(attachpoint,item, asset)); 511 ReplaceAttachment(new AvatarAttachment(attachpoint,item, asset));
494 } 512 }
513
495 return true; 514 return true;
496 } 515 }
497 516
517 /// <summary>
518 /// If the item is already attached, return it.
519 /// </summary>
520 /// <param name="itemID"></param>
521 /// <returns>Returns null if this item is not attached.</returns>
522 public AvatarAttachment GetAttachmentForItem(UUID itemID)
523 {
524 lock (m_attachments)
525 {
526 foreach (KeyValuePair<int, List<AvatarAttachment>> kvp in m_attachments)
527 {
528 int index = kvp.Value.FindIndex(delegate(AvatarAttachment a) { return a.ItemID == itemID; });
529 if (index >= 0)
530 return kvp.Value[index];
531 }
532 }
533
534 return null;
535 }
536
498 public int GetAttachpoint(UUID itemID) 537 public int GetAttachpoint(UUID itemID)
499 { 538 {
500 lock (m_attachments) 539 lock (m_attachments)
@@ -505,9 +544,8 @@ namespace OpenSim.Framework
505 if (index >= 0) 544 if (index >= 0)
506 return kvp.Key; 545 return kvp.Key;
507 } 546 }
508
509 return 0;
510 } 547 }
548 return 0;
511 } 549 }
512 550
513 public bool DetachAttachment(UUID itemID) 551 public bool DetachAttachment(UUID itemID)
@@ -521,23 +559,23 @@ namespace OpenSim.Framework
521 { 559 {
522 // Remove it from the list of attachments at that attach point 560 // Remove it from the list of attachments at that attach point
523 m_attachments[kvp.Key].RemoveAt(index); 561 m_attachments[kvp.Key].RemoveAt(index);
524 562
525 // And remove the list if there are no more attachments here 563 // And remove the list if there are no more attachments here
526 if (m_attachments[kvp.Key].Count == 0) 564 if (m_attachments[kvp.Key].Count == 0)
527 m_attachments.Remove(kvp.Key); 565 m_attachments.Remove(kvp.Key);
566
528 return true; 567 return true;
529 } 568 }
530 } 569 }
531 } 570 }
571
532 return false; 572 return false;
533 } 573 }
534 574
535 public void ClearAttachments() 575 public void ClearAttachments()
536 { 576 {
537 lock (m_attachments) 577 lock (m_attachments)
538 {
539 m_attachments.Clear(); 578 m_attachments.Clear();
540 }
541 } 579 }
542 580
543 #region Packing Functions 581 #region Packing Functions
diff --git a/OpenSim/Framework/ChildAgentDataUpdate.cs b/OpenSim/Framework/ChildAgentDataUpdate.cs
index 613db1c..5a4811e 100644
--- a/OpenSim/Framework/ChildAgentDataUpdate.cs
+++ b/OpenSim/Framework/ChildAgentDataUpdate.cs
@@ -441,7 +441,6 @@ namespace OpenSim.Framework
441 args["controllers"] = controls; 441 args["controllers"] = controls;
442 } 442 }
443 443
444
445 if ((CallbackURI != null) && (!CallbackURI.Equals(""))) 444 if ((CallbackURI != null) && (!CallbackURI.Equals("")))
446 args["callback_uri"] = OSD.FromString(CallbackURI); 445 args["callback_uri"] = OSD.FromString(CallbackURI);
447 446
@@ -628,6 +627,7 @@ namespace OpenSim.Framework
628 // We know all of these must end up as attachments so we 627 // We know all of these must end up as attachments so we
629 // append rather than replace to ensure multiple attachments 628 // append rather than replace to ensure multiple attachments
630 // per point continues to work 629 // per point continues to work
630// m_log.DebugFormat("[CHILDAGENTDATAUPDATE]: Appending attachments for {0}", AgentID);
631 Appearance.AppendAttachment(new AvatarAttachment((OSDMap)o)); 631 Appearance.AppendAttachment(new AvatarAttachment((OSDMap)o));
632 } 632 }
633 } 633 }
diff --git a/OpenSim/Framework/Util.cs b/OpenSim/Framework/Util.cs
index 2d58807..1cbb53f 100644
--- a/OpenSim/Framework/Util.cs
+++ b/OpenSim/Framework/Util.cs
@@ -1384,11 +1384,30 @@ namespace OpenSim.Framework
1384 return (ipaddr1 != null) ? "http://" + ipaddr1.ToString() + ":" + port1 : uri; 1384 return (ipaddr1 != null) ? "http://" + ipaddr1.ToString() + ":" + port1 : uri;
1385 } 1385 }
1386 1386
1387 /// <summary>
1388 /// Convert a string to a byte format suitable for transport in an LLUDP packet. The output is truncated to 256 bytes if necessary.
1389 /// </summary>
1390 /// <param name="str">
1391 /// If null or empty, then an bytes[0] is returned.
1392 /// Using "\0" will return a conversion of the null character to a byte. This is not the same as bytes[0]
1393 /// </param>
1394 /// <param name="args">
1395 /// Arguments to substitute into the string via the {} mechanism.
1396 /// </param>
1397 /// <returns></returns>
1387 public static byte[] StringToBytes256(string str, params object[] args) 1398 public static byte[] StringToBytes256(string str, params object[] args)
1388 { 1399 {
1389 return StringToBytes256(string.Format(str, args)); 1400 return StringToBytes256(string.Format(str, args));
1390 } 1401 }
1391 1402
1403 /// <summary>
1404 /// Convert a string to a byte format suitable for transport in an LLUDP packet. The output is truncated to 256 bytes if necessary.
1405 /// </summary>
1406 /// <param name="str">
1407 /// If null or empty, then an bytes[0] is returned.
1408 /// Using "\0" will return a conversion of the null character to a byte. This is not the same as bytes[0]
1409 /// </param>
1410 /// <returns></returns>
1392 public static byte[] StringToBytes256(string str) 1411 public static byte[] StringToBytes256(string str)
1393 { 1412 {
1394 if (String.IsNullOrEmpty(str)) { return Utils.EmptyBytes; } 1413 if (String.IsNullOrEmpty(str)) { return Utils.EmptyBytes; }
@@ -1407,11 +1426,30 @@ namespace OpenSim.Framework
1407 return data; 1426 return data;
1408 } 1427 }
1409 1428
1429 /// <summary>
1430 /// Convert a string to a byte format suitable for transport in an LLUDP packet. The output is truncated to 1024 bytes if necessary.
1431 /// </summary>
1432 /// <param name="str">
1433 /// If null or empty, then an bytes[0] is returned.
1434 /// Using "\0" will return a conversion of the null character to a byte. This is not the same as bytes[0]
1435 /// </param>
1436 /// <param name="args">
1437 /// Arguments to substitute into the string via the {} mechanism.
1438 /// </param>
1439 /// <returns></returns>
1410 public static byte[] StringToBytes1024(string str, params object[] args) 1440 public static byte[] StringToBytes1024(string str, params object[] args)
1411 { 1441 {
1412 return StringToBytes1024(string.Format(str, args)); 1442 return StringToBytes1024(string.Format(str, args));
1413 } 1443 }
1414 1444
1445 /// <summary>
1446 /// Convert a string to a byte format suitable for transport in an LLUDP packet. The output is truncated to 1024 bytes if necessary.
1447 /// </summary>
1448 /// <param name="str">
1449 /// If null or empty, then an bytes[0] is returned.
1450 /// Using "\0" will return a conversion of the null character to a byte. This is not the same as bytes[0]
1451 /// </param>
1452 /// <returns></returns>
1415 public static byte[] StringToBytes1024(string str) 1453 public static byte[] StringToBytes1024(string str)
1416 { 1454 {
1417 if (String.IsNullOrEmpty(str)) { return Utils.EmptyBytes; } 1455 if (String.IsNullOrEmpty(str)) { return Utils.EmptyBytes; }