diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs | 199 |
1 files changed, 145 insertions, 54 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs b/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs index 2556845..207c900 100644 --- a/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs +++ b/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs | |||
@@ -49,6 +49,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
49 | { | 49 | { |
50 | #region INonSharedRegionModule | 50 | #region INonSharedRegionModule |
51 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | 51 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |
52 | |||
53 | public int DebugLevel { get; set; } | ||
52 | 54 | ||
53 | private Scene m_scene; | 55 | private Scene m_scene; |
54 | private IInventoryAccessModule m_invAccessModule; | 56 | private IInventoryAccessModule m_invAccessModule; |
@@ -76,10 +78,66 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
76 | m_scene.RegisterModuleInterface<IAttachmentsModule>(this); | 78 | m_scene.RegisterModuleInterface<IAttachmentsModule>(this); |
77 | 79 | ||
78 | if (Enabled) | 80 | if (Enabled) |
81 | { | ||
79 | m_scene.EventManager.OnNewClient += SubscribeToClientEvents; | 82 | m_scene.EventManager.OnNewClient += SubscribeToClientEvents; |
83 | m_scene.EventManager.OnStartScript += (localID, itemID) => HandleScriptStateChange(localID, true); | ||
84 | m_scene.EventManager.OnStopScript += (localID, itemID) => HandleScriptStateChange(localID, false); | ||
85 | |||
86 | MainConsole.Instance.Commands.AddCommand( | ||
87 | "Debug", | ||
88 | false, | ||
89 | "debug attachments", | ||
90 | "debug attachments [0|1]", | ||
91 | "Turn on attachments debugging\n" | ||
92 | + " <= 0 - turns off debugging\n" | ||
93 | + " >= 1 - turns on attachment message logging\n", | ||
94 | HandleDebugAttachments); | ||
95 | } | ||
80 | 96 | ||
81 | // TODO: Should probably be subscribing to CloseClient too, but this doesn't yet give us IClientAPI | 97 | // TODO: Should probably be subscribing to CloseClient too, but this doesn't yet give us IClientAPI |
82 | } | 98 | } |
99 | |||
100 | private void HandleDebugAttachments(string module, string[] args) | ||
101 | { | ||
102 | int debugLevel; | ||
103 | |||
104 | if (!(args.Length == 3 && int.TryParse(args[2], out debugLevel))) | ||
105 | { | ||
106 | MainConsole.Instance.OutputFormat("Usage: debug attachments [0|1]"); | ||
107 | } | ||
108 | else | ||
109 | { | ||
110 | DebugLevel = debugLevel; | ||
111 | MainConsole.Instance.OutputFormat( | ||
112 | "Set event queue debug level to {0} in {1}", DebugLevel, m_scene.Name); | ||
113 | } | ||
114 | } | ||
115 | |||
116 | /// <summary> | ||
117 | /// Listen for client triggered running state changes so that we can persist the script's object if necessary. | ||
118 | /// </summary> | ||
119 | /// <param name='localID'></param> | ||
120 | /// <param name='itemID'></param> | ||
121 | private void HandleScriptStateChange(uint localID, bool started) | ||
122 | { | ||
123 | SceneObjectGroup sog = m_scene.GetGroupByPrim(localID); | ||
124 | if (sog != null && sog.IsAttachment) | ||
125 | { | ||
126 | if (!started) | ||
127 | { | ||
128 | // FIXME: This is a convoluted way for working out whether the script state has changed to stop | ||
129 | // because it has been manually stopped or because the stop was called in UpdateDetachedObject() below | ||
130 | // This needs to be handled in a less tangled way. | ||
131 | ScenePresence sp = m_scene.GetScenePresence(sog.AttachedAvatar); | ||
132 | if (sp.ControllingClient.IsActive) | ||
133 | sog.HasGroupChanged = true; | ||
134 | } | ||
135 | else | ||
136 | { | ||
137 | sog.HasGroupChanged = true; | ||
138 | } | ||
139 | } | ||
140 | } | ||
83 | 141 | ||
84 | public void RemoveRegion(Scene scene) | 142 | public void RemoveRegion(Scene scene) |
85 | { | 143 | { |
@@ -167,14 +225,16 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
167 | 225 | ||
168 | if (sp.GetAttachments().Count > 0) | 226 | if (sp.GetAttachments().Count > 0) |
169 | { | 227 | { |
170 | // m_log.DebugFormat( | 228 | if (DebugLevel > 0) |
171 | // "[ATTACHMENTS MODULE]: Not doing simulator-side attachment rez for {0} in {1} as their viewer has already rezzed attachments", | 229 | m_log.DebugFormat( |
172 | // m_scene.Name, sp.Name); | 230 | "[ATTACHMENTS MODULE]: Not doing simulator-side attachment rez for {0} in {1} as their viewer has already rezzed attachments", |
231 | m_scene.Name, sp.Name); | ||
173 | 232 | ||
174 | return; | 233 | return; |
175 | } | 234 | } |
176 | 235 | ||
177 | // m_log.DebugFormat("[ATTACHMENTS MODULE]: Rezzing any attachments for {0} from simulator-side", sp.Name); | 236 | if (DebugLevel > 0) |
237 | m_log.DebugFormat("[ATTACHMENTS MODULE]: Rezzing any attachments for {0} from simulator-side", sp.Name); | ||
178 | 238 | ||
179 | XmlDocument doc = new XmlDocument(); | 239 | XmlDocument doc = new XmlDocument(); |
180 | string stateData = String.Empty; | 240 | string stateData = String.Empty; |
@@ -260,7 +320,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
260 | if (!Enabled) | 320 | if (!Enabled) |
261 | return; | 321 | return; |
262 | 322 | ||
263 | // m_log.DebugFormat("[ATTACHMENTS MODULE]: Saving changed attachments for {0}", sp.Name); | 323 | if (DebugLevel > 0) |
324 | m_log.DebugFormat("[ATTACHMENTS MODULE]: Saving changed attachments for {0}", sp.Name); | ||
264 | 325 | ||
265 | List<SceneObjectGroup> attachments = sp.GetAttachments(); | 326 | List<SceneObjectGroup> attachments = sp.GetAttachments(); |
266 | 327 | ||
@@ -293,9 +354,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
293 | if (!Enabled) | 354 | if (!Enabled) |
294 | return; | 355 | return; |
295 | 356 | ||
296 | // m_log.DebugFormat( | 357 | if (DebugLevel > 0) |
297 | // "[ATTACHMENTS MODULE]: Deleting attachments from scene {0} for {1}, silent = {2}", | 358 | m_log.DebugFormat( |
298 | // m_scene.RegionInfo.RegionName, sp.Name, silent); | 359 | "[ATTACHMENTS MODULE]: Deleting attachments from scene {0} for {1}, silent = {2}", |
360 | m_scene.RegionInfo.RegionName, sp.Name, silent); | ||
299 | 361 | ||
300 | foreach (SceneObjectGroup sop in sp.GetAttachments()) | 362 | foreach (SceneObjectGroup sop in sp.GetAttachments()) |
301 | { | 363 | { |
@@ -340,9 +402,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
340 | 402 | ||
341 | if (group.GetSittingAvatarsCount() != 0) | 403 | if (group.GetSittingAvatarsCount() != 0) |
342 | { | 404 | { |
343 | // m_log.WarnFormat( | 405 | if (DebugLevel > 0) |
344 | // "[ATTACHMENTS MODULE]: Ignoring request to attach {0} {1} to {2} on {3} since {4} avatars are still sitting on it", | 406 | m_log.WarnFormat( |
345 | // group.Name, group.LocalId, sp.Name, attachmentPt, group.GetSittingAvatarsCount()); | 407 | "[ATTACHMENTS MODULE]: Ignoring request to attach {0} {1} to {2} on {3} since {4} avatars are still sitting on it", |
408 | group.Name, group.LocalId, sp.Name, attachmentPt, group.GetSittingAvatarsCount()); | ||
346 | 409 | ||
347 | return false; | 410 | return false; |
348 | } | 411 | } |
@@ -378,6 +441,16 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
378 | 441 | ||
379 | List<SceneObjectGroup> attachments = sp.GetAttachments(attachmentPt); | 442 | List<SceneObjectGroup> attachments = sp.GetAttachments(attachmentPt); |
380 | 443 | ||
444 | if (attachments.Contains(group)) | ||
445 | { | ||
446 | if (DebugLevel > 0) | ||
447 | m_log.WarnFormat( | ||
448 | "[ATTACHMENTS MODULE]: Ignoring request to attach {0} {1} to {2} on {3} since it's already attached", | ||
449 | group.Name, group.LocalId, sp.Name, attachmentPt); | ||
450 | |||
451 | return false; | ||
452 | } | ||
453 | |||
381 | // If we already have 5, remove the oldest until only 4 are left. Skip over temp ones | 454 | // If we already have 5, remove the oldest until only 4 are left. Skip over temp ones |
382 | while (attachments.Count >= 5) | 455 | while (attachments.Count >= 5) |
383 | { | 456 | { |
@@ -444,9 +517,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
444 | if (!Enabled) | 517 | if (!Enabled) |
445 | return null; | 518 | return null; |
446 | 519 | ||
447 | // m_log.DebugFormat( | 520 | if (DebugLevel > 0) |
448 | // "[ATTACHMENTS MODULE]: RezSingleAttachmentFromInventory to point {0} from item {1} for {2} in {3}", | 521 | m_log.DebugFormat( |
449 | // (AttachmentPoint)AttachmentPt, itemID, sp.Name, m_scene.Name); | 522 | "[ATTACHMENTS MODULE]: RezSingleAttachmentFromInventory to point {0} from item {1} for {2} in {3}", |
523 | (AttachmentPoint)AttachmentPt, itemID, sp.Name, m_scene.Name); | ||
450 | 524 | ||
451 | bool append = (AttachmentPt & 0x80) != 0; | 525 | bool append = (AttachmentPt & 0x80) != 0; |
452 | AttachmentPt &= 0x7f; | 526 | AttachmentPt &= 0x7f; |
@@ -470,9 +544,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
470 | // if (sp.Appearance.GetAttachmentForItem(itemID) != null) | 544 | // if (sp.Appearance.GetAttachmentForItem(itemID) != null) |
471 | if (alreadyOn) | 545 | if (alreadyOn) |
472 | { | 546 | { |
473 | // m_log.WarnFormat( | 547 | if (DebugLevel > 0) |
474 | // "[ATTACHMENTS MODULE]: Ignoring request by {0} to wear item {1} at {2} since it is already worn", | 548 | m_log.DebugFormat( |
475 | // sp.Name, itemID, AttachmentPt); | 549 | "[ATTACHMENTS MODULE]: Ignoring request by {0} to wear item {1} at {2} since it is already worn", |
550 | sp.Name, itemID, AttachmentPt); | ||
476 | 551 | ||
477 | return null; | 552 | return null; |
478 | } | 553 | } |
@@ -485,7 +560,8 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
485 | if (!Enabled) | 560 | if (!Enabled) |
486 | return; | 561 | return; |
487 | 562 | ||
488 | // m_log.DebugFormat("[ATTACHMENTS MODULE]: Rezzing multiple attachments from inventory for {0}", sp.Name); | 563 | if (DebugLevel > 0) |
564 | m_log.DebugFormat("[ATTACHMENTS MODULE]: Rezzing multiple attachments from inventory for {0}", sp.Name); | ||
489 | 565 | ||
490 | foreach (KeyValuePair<UUID, uint> rez in rezlist) | 566 | foreach (KeyValuePair<UUID, uint> rez in rezlist) |
491 | { | 567 | { |
@@ -503,9 +579,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
503 | if (!Enabled) | 579 | if (!Enabled) |
504 | return; | 580 | return; |
505 | 581 | ||
506 | // m_log.DebugFormat( | 582 | if (DebugLevel > 0) |
507 | // "[ATTACHMENTS MODULE]: DetachSingleAttachmentToGround() for {0}, object {1}", | 583 | m_log.DebugFormat( |
508 | // sp.UUID, soLocalId); | 584 | "[ATTACHMENTS MODULE]: DetachSingleAttachmentToGround() for {0}, object {1}", |
585 | sp.UUID, soLocalId); | ||
509 | 586 | ||
510 | SceneObjectGroup so = m_scene.GetGroupByPrim(soLocalId); | 587 | SceneObjectGroup so = m_scene.GetGroupByPrim(soLocalId); |
511 | 588 | ||
@@ -521,9 +598,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
521 | if (inventoryID == UUID.Zero) | 598 | if (inventoryID == UUID.Zero) |
522 | return; | 599 | return; |
523 | 600 | ||
524 | // m_log.DebugFormat( | 601 | if (DebugLevel > 0) |
525 | // "[ATTACHMENTS MODULE]: In DetachSingleAttachmentToGround(), object is {0} {1}, associated item is {2}", | 602 | m_log.DebugFormat( |
526 | // so.Name, so.LocalId, inventoryID); | 603 | "[ATTACHMENTS MODULE]: In DetachSingleAttachmentToGround(), object is {0} {1}, associated item is {2}", |
604 | so.Name, so.LocalId, inventoryID); | ||
527 | 605 | ||
528 | lock (sp.AttachmentsSyncLock) | 606 | lock (sp.AttachmentsSyncLock) |
529 | { | 607 | { |
@@ -578,9 +656,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
578 | return; | 656 | return; |
579 | } | 657 | } |
580 | 658 | ||
581 | // m_log.DebugFormat( | 659 | if (DebugLevel > 0) |
582 | // "[ATTACHMENTS MODULE]: Detaching object {0} {1} (FromItemID {2}) for {3} in {4}", | 660 | m_log.DebugFormat( |
583 | // so.Name, so.LocalId, so.FromItemID, sp.Name, m_scene.Name); | 661 | "[ATTACHMENTS MODULE]: Detaching object {0} {1} (FromItemID {2}) for {3} in {4}", |
662 | so.Name, so.LocalId, so.FromItemID, sp.Name, m_scene.Name); | ||
584 | 663 | ||
585 | // Scripts MUST be snapshotted before the object is | 664 | // Scripts MUST be snapshotted before the object is |
586 | // removed from the scene because doing otherwise will | 665 | // removed from the scene because doing otherwise will |
@@ -706,12 +785,12 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
706 | 785 | ||
707 | grp.HasGroupChanged = false; // Prevent it being saved over and over | 786 | grp.HasGroupChanged = false; // Prevent it being saved over and over |
708 | } | 787 | } |
709 | // else | 788 | else if (DebugLevel > 0) |
710 | // { | 789 | { |
711 | // m_log.DebugFormat( | 790 | m_log.DebugFormat( |
712 | // "[ATTACHMENTS MODULE]: Don't need to update asset for unchanged attachment {0}, attachpoint {1}", | 791 | "[ATTACHMENTS MODULE]: Don't need to update asset for unchanged attachment {0}, attachpoint {1}", |
713 | // grp.UUID, grp.AttachmentPoint); | 792 | grp.UUID, grp.AttachmentPoint); |
714 | // } | 793 | } |
715 | } | 794 | } |
716 | 795 | ||
717 | /// <summary> | 796 | /// <summary> |
@@ -729,9 +808,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
729 | private void AttachToAgent( | 808 | private void AttachToAgent( |
730 | IScenePresence sp, SceneObjectGroup so, uint attachmentpoint, Vector3 attachOffset, bool silent) | 809 | IScenePresence sp, SceneObjectGroup so, uint attachmentpoint, Vector3 attachOffset, bool silent) |
731 | { | 810 | { |
732 | // m_log.DebugFormat( | 811 | if (DebugLevel > 0) |
733 | // "[ATTACHMENTS MODULE]: Adding attachment {0} to avatar {1} in pt {2} pos {3} {4}", | 812 | m_log.DebugFormat( |
734 | // so.Name, sp.Name, attachmentpoint, attachOffset, so.RootPart.AttachedPos); | 813 | "[ATTACHMENTS MODULE]: Adding attachment {0} to avatar {1} in pt {2} pos {3} {4}", |
814 | so.Name, sp.Name, attachmentpoint, attachOffset, so.RootPart.AttachedPos); | ||
735 | 815 | ||
736 | so.DetachFromBackup(); | 816 | so.DetachFromBackup(); |
737 | 817 | ||
@@ -756,9 +836,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
756 | { | 836 | { |
757 | if (so.HasPrivateAttachmentPoint) | 837 | if (so.HasPrivateAttachmentPoint) |
758 | { | 838 | { |
759 | // m_log.DebugFormat( | 839 | if (DebugLevel > 0) |
760 | // "[ATTACHMENTS MODULE]: Killing private HUD {0} for avatars other than {1} at attachment point {2}", | 840 | m_log.DebugFormat( |
761 | // so.Name, sp.Name, so.AttachmentPoint); | 841 | "[ATTACHMENTS MODULE]: Killing private HUD {0} for avatars other than {1} at attachment point {2}", |
842 | so.Name, sp.Name, so.AttachmentPoint); | ||
762 | 843 | ||
763 | // As this scene object can now only be seen by the attaching avatar, tell everybody else in the | 844 | // As this scene object can now only be seen by the attaching avatar, tell everybody else in the |
764 | // scene that it's no longer in their awareness. | 845 | // scene that it's no longer in their awareness. |
@@ -792,9 +873,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
792 | if (m_invAccessModule == null) | 873 | if (m_invAccessModule == null) |
793 | return null; | 874 | return null; |
794 | 875 | ||
795 | // m_log.DebugFormat( | 876 | if (DebugLevel > 0) |
796 | // "[ATTACHMENTS MODULE]: Called AddSceneObjectAsAttachment for object {0} {1} for {2}", | 877 | m_log.DebugFormat( |
797 | // grp.Name, grp.LocalId, remoteClient.Name); | 878 | "[ATTACHMENTS MODULE]: Called AddSceneObjectAsAttachment for object {0} {1} for {2}", |
879 | grp.Name, grp.LocalId, sp.Name); | ||
798 | 880 | ||
799 | InventoryItemBase newItem | 881 | InventoryItemBase newItem |
800 | = m_invAccessModule.CopyToInventory( | 882 | = m_invAccessModule.CopyToInventory( |
@@ -903,6 +985,11 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
903 | return null; | 985 | return null; |
904 | } | 986 | } |
905 | 987 | ||
988 | if (DebugLevel > 0) | ||
989 | m_log.DebugFormat( | ||
990 | "[ATTACHMENTS MODULE]: Rezzed single object {0} for attachment to {1} on point {2} in {3}", | ||
991 | objatt.Name, sp.Name, attachmentPt, m_scene.Name); | ||
992 | |||
906 | // HasGroupChanged is being set from within RezObject. Ideally it would be set by the caller. | 993 | // HasGroupChanged is being set from within RezObject. Ideally it would be set by the caller. |
907 | objatt.HasGroupChanged = false; | 994 | objatt.HasGroupChanged = false; |
908 | bool tainted = false; | 995 | bool tainted = false; |
@@ -977,9 +1064,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
977 | bool changed = sp.Appearance.SetAttachment((int)AttachmentPt | attFlag, itemID, item.AssetID); | 1064 | bool changed = sp.Appearance.SetAttachment((int)AttachmentPt | attFlag, itemID, item.AssetID); |
978 | if (changed && m_scene.AvatarFactory != null) | 1065 | if (changed && m_scene.AvatarFactory != null) |
979 | { | 1066 | { |
980 | // m_log.DebugFormat( | 1067 | if (DebugLevel > 0) |
981 | // "[ATTACHMENTS MODULE]: Queueing appearance save for {0}, attachment {1} point {2} in ShowAttachInUserInventory()", | 1068 | m_log.DebugFormat( |
982 | // sp.Name, att.Name, AttachmentPt); | 1069 | "[ATTACHMENTS MODULE]: Queueing appearance save for {0}, attachment {1} point {2} in ShowAttachInUserInventory()", |
1070 | sp.Name, att.Name, AttachmentPt); | ||
983 | 1071 | ||
984 | m_scene.AvatarFactory.QueueAppearanceSave(sp.UUID); | 1072 | m_scene.AvatarFactory.QueueAppearanceSave(sp.UUID); |
985 | } | 1073 | } |
@@ -994,9 +1082,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
994 | if (!Enabled) | 1082 | if (!Enabled) |
995 | return null; | 1083 | return null; |
996 | 1084 | ||
997 | // m_log.DebugFormat( | 1085 | if (DebugLevel > 0) |
998 | // "[ATTACHMENTS MODULE]: Rezzing attachment to point {0} from item {1} for {2}", | 1086 | m_log.DebugFormat( |
999 | // (AttachmentPoint)AttachmentPt, itemID, remoteClient.Name); | 1087 | "[ATTACHMENTS MODULE]: Rezzing attachment to point {0} from item {1} for {2}", |
1088 | (AttachmentPoint)AttachmentPt, itemID, remoteClient.Name); | ||
1000 | 1089 | ||
1001 | ScenePresence sp = m_scene.GetScenePresence(remoteClient.AgentId); | 1090 | ScenePresence sp = m_scene.GetScenePresence(remoteClient.AgentId); |
1002 | 1091 | ||
@@ -1027,9 +1116,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
1027 | 1116 | ||
1028 | private void Client_OnObjectAttach(IClientAPI remoteClient, uint objectLocalID, uint AttachmentPt, bool silent) | 1117 | private void Client_OnObjectAttach(IClientAPI remoteClient, uint objectLocalID, uint AttachmentPt, bool silent) |
1029 | { | 1118 | { |
1030 | // m_log.DebugFormat( | 1119 | if (DebugLevel > 0) |
1031 | // "[ATTACHMENTS MODULE]: Attaching object local id {0} to {1} point {2} from ground (silent = {3})", | 1120 | m_log.DebugFormat( |
1032 | // objectLocalID, remoteClient.Name, AttachmentPt, silent); | 1121 | "[ATTACHMENTS MODULE]: Attaching object local id {0} to {1} point {2} from ground (silent = {3})", |
1122 | objectLocalID, remoteClient.Name, AttachmentPt, silent); | ||
1033 | 1123 | ||
1034 | if (!Enabled) | 1124 | if (!Enabled) |
1035 | return; | 1125 | return; |
@@ -1064,9 +1154,10 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments | |||
1064 | // Calls attach with a Zero position | 1154 | // Calls attach with a Zero position |
1065 | if (AttachObject(sp, part.ParentGroup, AttachmentPt, false, true, false, append)) | 1155 | if (AttachObject(sp, part.ParentGroup, AttachmentPt, false, true, false, append)) |
1066 | { | 1156 | { |
1067 | // m_log.Debug( | 1157 | if (DebugLevel > 0) |
1068 | // "[ATTACHMENTS MODULE]: Saving avatar attachment. AgentID: " + remoteClient.AgentId | 1158 | m_log.Debug( |
1069 | // + ", AttachmentPoint: " + AttachmentPt); | 1159 | "[ATTACHMENTS MODULE]: Saving avatar attachment. AgentID: " + remoteClient.AgentId |
1160 | + ", AttachmentPoint: " + AttachmentPt); | ||
1070 | 1161 | ||
1071 | // Save avatar attachment information | 1162 | // Save avatar attachment information |
1072 | m_scene.EventManager.TriggerOnAttach(objectLocalID, part.ParentGroup.FromItemID, remoteClient.AgentId); | 1163 | m_scene.EventManager.TriggerOnAttach(objectLocalID, part.ParentGroup.FromItemID, remoteClient.AgentId); |