diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Framework/AvatarAppearance.cs | 72 |
1 files changed, 55 insertions, 17 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 |