aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs50
-rw-r--r--OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs51
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs2
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs324
-rw-r--r--OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs1
-rw-r--r--OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs13
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs4
7 files changed, 236 insertions, 209 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index c1b5781..258683d 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -3761,24 +3761,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
3761 { 3761 {
3762 SceneObjectPart part = (SceneObjectPart)update.Entity; 3762 SceneObjectPart part = (SceneObjectPart)update.Entity;
3763 3763
3764 // Please do not remove this unless you can demonstrate on the OpenSim mailing list that a client
3765 // will never receive an update after a prim kill. Even then, keeping the kill record may be a good
3766 // safety measure.
3767 //
3768 // If a Linden Lab 1.23.5 client (and possibly later and earlier) receives an object update
3769 // after a kill, it will keep displaying the deleted object until relog. OpenSim currently performs
3770 // updates and kills on different threads with different scheduling strategies, hence this protection.
3771 //
3772 // This doesn't appear to apply to child prims - a client will happily ignore these updates
3773 // after the root prim has been deleted.
3774 lock (m_killRecord)
3775 {
3776 if (m_killRecord.Contains(part.LocalId))
3777 continue;
3778 if (m_killRecord.Contains(part.ParentGroup.RootPart.LocalId))
3779 continue;
3780 }
3781
3782 if (part.ParentGroup.IsDeleted) 3764 if (part.ParentGroup.IsDeleted)
3783 continue; 3765 continue;
3784 3766
@@ -3816,7 +3798,39 @@ namespace OpenSim.Region.ClientStack.LindenUDP
3816 // attachments until the avatar becomes root. 3798 // attachments until the avatar becomes root.
3817 if (sp.IsChildAgent) 3799 if (sp.IsChildAgent)
3818 continue; 3800 continue;
3801
3802 // If the object is an attachment we don't want it to be in the kill
3803 // record. Else attaching from inworld and subsequently dropping
3804 // it will no longer work.
3805 lock (m_killRecord)
3806 {
3807 m_killRecord.Remove(part.LocalId);
3808 m_killRecord.Remove(part.ParentGroup.RootPart.LocalId);
3809 }
3819 } 3810 }
3811 else
3812 {
3813 // Please do not remove this unless you can demonstrate on the OpenSim mailing list that a client
3814 // will never receive an update after a prim kill. Even then, keeping the kill record may be a good
3815 // safety measure.
3816 //
3817 // If a Linden Lab 1.23.5 client (and possibly later and earlier) receives an object update
3818 // after a kill, it will keep displaying the deleted object until relog. OpenSim currently performs
3819 // updates and kills on different threads with different scheduling strategies, hence this protection.
3820 //
3821 // This doesn't appear to apply to child prims - a client will happily ignore these updates
3822 // after the root prim has been deleted.
3823 //
3824 // We ignore this for attachments because attaching something from inworld breaks unless we do.
3825 lock (m_killRecord)
3826 {
3827 if (m_killRecord.Contains(part.LocalId))
3828 continue;
3829 if (m_killRecord.Contains(part.ParentGroup.RootPart.LocalId))
3830 continue;
3831 }
3832 }
3833
3820 if (part.ParentGroup.IsAttachment && m_disableFacelights) 3834 if (part.ParentGroup.IsAttachment && m_disableFacelights)
3821 { 3835 {
3822 if (part.ParentGroup.RootPart.Shape.State != (byte)AttachmentPoint.LeftHand && 3836 if (part.ParentGroup.RootPart.Shape.State != (byte)AttachmentPoint.LeftHand &&
diff --git a/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs b/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs
index 7a91481..de40e59 100644
--- a/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs
+++ b/OpenSim/Region/CoreModules/Avatar/Attachments/AttachmentsModule.cs
@@ -638,19 +638,19 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments
638 // "[ATTACHMENTS MODULE]: Called AddSceneObjectAsAttachment for object {0} {1} for {2}", 638 // "[ATTACHMENTS MODULE]: Called AddSceneObjectAsAttachment for object {0} {1} for {2}",
639 // grp.Name, grp.LocalId, remoteClient.Name); 639 // grp.Name, grp.LocalId, remoteClient.Name);
640 640
641 Vector3 inventoryStoredPosition = new Vector3 641// Vector3 inventoryStoredPosition = new Vector3
642 (((grp.AbsolutePosition.X > (int)Constants.RegionSize) 642// (((grp.AbsolutePosition.X > (int)Constants.RegionSize)
643 ? (float)Constants.RegionSize - 6 643// ? (float)Constants.RegionSize - 6
644 : grp.AbsolutePosition.X) 644// : grp.AbsolutePosition.X)
645 , 645// ,
646 (grp.AbsolutePosition.Y > (int)Constants.RegionSize) 646// (grp.AbsolutePosition.Y > (int)Constants.RegionSize)
647 ? (float)Constants.RegionSize - 6 647// ? (float)Constants.RegionSize - 6
648 : grp.AbsolutePosition.Y, 648// : grp.AbsolutePosition.Y,
649 grp.AbsolutePosition.Z); 649// grp.AbsolutePosition.Z);
650 650//
651 Vector3 originalPosition = grp.AbsolutePosition; 651// Vector3 originalPosition = grp.AbsolutePosition;
652 652//
653 grp.AbsolutePosition = inventoryStoredPosition; 653// grp.AbsolutePosition = inventoryStoredPosition;
654 654
655 // If we're being called from a script, then trying to serialize that same script's state will not complete 655 // If we're being called from a script, then trying to serialize that same script's state will not complete
656 // in any reasonable time period. Therefore, we'll avoid it. The worst that can happen is that if 656 // in any reasonable time period. Therefore, we'll avoid it. The worst that can happen is that if
@@ -658,7 +658,7 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments
658 // without state on relog. Arguably, this is what we want anyway. 658 // without state on relog. Arguably, this is what we want anyway.
659 string sceneObjectXml = SceneObjectSerializer.ToOriginalXmlFormat(grp, false); 659 string sceneObjectXml = SceneObjectSerializer.ToOriginalXmlFormat(grp, false);
660 660
661 grp.AbsolutePosition = originalPosition; 661// grp.AbsolutePosition = originalPosition;
662 662
663 AssetBase asset = m_scene.CreateAsset( 663 AssetBase asset = m_scene.CreateAsset(
664 grp.GetPartName(grp.LocalId), 664 grp.GetPartName(grp.LocalId),
@@ -686,21 +686,24 @@ namespace OpenSim.Region.CoreModules.Avatar.Attachments
686 else // oopsies 686 else // oopsies
687 item.Folder = UUID.Zero; 687 item.Folder = UUID.Zero;
688 688
689 // Nix the special bits we used to use for slam and the folded perms
690 uint allowablePermissionsMask = (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify | PermissionMask.Move);
691
689 if ((sp.UUID != grp.RootPart.OwnerID) && m_scene.Permissions.PropagatePermissions()) 692 if ((sp.UUID != grp.RootPart.OwnerID) && m_scene.Permissions.PropagatePermissions())
690 { 693 {
691 item.BasePermissions = grp.RootPart.NextOwnerMask; 694 item.BasePermissions = grp.RootPart.BaseMask & grp.RootPart.NextOwnerMask & allowablePermissionsMask;
692 item.CurrentPermissions = grp.RootPart.NextOwnerMask; 695 item.CurrentPermissions = grp.RootPart.BaseMask & grp.RootPart.NextOwnerMask & allowablePermissionsMask;
693 item.NextPermissions = grp.RootPart.NextOwnerMask; 696 item.NextPermissions = grp.RootPart.NextOwnerMask & allowablePermissionsMask;
694 item.EveryOnePermissions = grp.RootPart.EveryoneMask & grp.RootPart.NextOwnerMask; 697 item.EveryOnePermissions = grp.RootPart.EveryoneMask & grp.RootPart.NextOwnerMask & allowablePermissionsMask;
695 item.GroupPermissions = grp.RootPart.GroupMask & grp.RootPart.NextOwnerMask; 698 item.GroupPermissions = grp.RootPart.GroupMask & grp.RootPart.NextOwnerMask & allowablePermissionsMask;
696 } 699 }
697 else 700 else
698 { 701 {
699 item.BasePermissions = grp.RootPart.BaseMask; 702 item.BasePermissions = grp.RootPart.BaseMask & allowablePermissionsMask;
700 item.CurrentPermissions = grp.RootPart.OwnerMask; 703 item.CurrentPermissions = grp.RootPart.OwnerMask & allowablePermissionsMask;
701 item.NextPermissions = grp.RootPart.NextOwnerMask; 704 item.NextPermissions = grp.RootPart.NextOwnerMask & allowablePermissionsMask;
702 item.EveryOnePermissions = grp.RootPart.EveryoneMask; 705 item.EveryOnePermissions = grp.RootPart.EveryoneMask & allowablePermissionsMask;
703 item.GroupPermissions = grp.RootPart.GroupMask; 706 item.GroupPermissions = grp.RootPart.GroupMask & allowablePermissionsMask;
704 } 707 }
705 item.CreationDate = Util.UnixTimeSinceEpoch(); 708 item.CreationDate = Util.UnixTimeSinceEpoch();
706 709
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index f7c6413..bb8d065 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -2738,7 +2738,7 @@ namespace OpenSim.Region.Framework.Scenes
2738 2738
2739 SendCollisionEvent(scriptEvents.collision_start, startedColliders, ParentGroup.Scene.EventManager.TriggerScriptCollidingStart); 2739 SendCollisionEvent(scriptEvents.collision_start, startedColliders, ParentGroup.Scene.EventManager.TriggerScriptCollidingStart);
2740 if (!VolumeDetectActive) 2740 if (!VolumeDetectActive)
2741 SendCollisionEvent(scriptEvents.collision , m_lastColliders , ParentGroup.Scene.EventManager.TriggerScriptColliding); 2741 SendCollisionEvent(scriptEvents.collision , m_lastColliders , ParentGroup.Scene.EventManager.TriggerScriptColliding);
2742 SendCollisionEvent(scriptEvents.collision_end , endedColliders , ParentGroup.Scene.EventManager.TriggerScriptCollidingEnd); 2742 SendCollisionEvent(scriptEvents.collision_end , endedColliders , ParentGroup.Scene.EventManager.TriggerScriptCollidingEnd);
2743 2743
2744 if (startedColliders.Contains(0)) 2744 if (startedColliders.Contains(0))
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index 1adf13e..07b36b3 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -4287,199 +4287,199 @@ namespace OpenSim.Region.Framework.Scenes
4287 } 4287 }
4288 } 4288 }
4289 4289
4290 private void RaiseCollisionScriptEvents(Dictionary<uint, ContactPoint> coldata) 4290 private DetectedObject CreateDetObject(SceneObjectPart obj)
4291 { 4291 {
4292 /* 4292 DetectedObject detobj = new DetectedObject();
4293 lock(m_collisionEventLock) 4293 detobj.keyUUID = obj.UUID;
4294 { 4294 detobj.nameStr = obj.Name;
4295 if (m_collisionEventFlag) 4295 detobj.ownerUUID = obj.OwnerID;
4296 return; 4296 detobj.posVector = obj.AbsolutePosition;
4297 m_collisionEventFlag = true; 4297 detobj.rotQuat = obj.GetWorldRotation();
4298 } 4298 detobj.velVector = obj.Velocity;
4299 detobj.colliderType = 0;
4300 detobj.groupUUID = obj.GroupID;
4299 4301
4300 Util.FireAndForget(delegate(object x) 4302 return detobj;
4303 }
4304
4305 private DetectedObject CreateDetObject(ScenePresence av)
4306 {
4307 DetectedObject detobj = new DetectedObject();
4308 detobj.keyUUID = av.UUID;
4309 detobj.nameStr = av.ControllingClient.Name;
4310 detobj.ownerUUID = av.UUID;
4311 detobj.posVector = av.AbsolutePosition;
4312 detobj.rotQuat = av.Rotation;
4313 detobj.velVector = av.Velocity;
4314 detobj.colliderType = 0;
4315 detobj.groupUUID = av.ControllingClient.ActiveGroupId;
4316
4317 return detobj;
4318 }
4319
4320 private DetectedObject CreateDetObjectForGround()
4321 {
4322 DetectedObject detobj = new DetectedObject();
4323 detobj.keyUUID = UUID.Zero;
4324 detobj.nameStr = "";
4325 detobj.ownerUUID = UUID.Zero;
4326 detobj.posVector = AbsolutePosition;
4327 detobj.rotQuat = Quaternion.Identity;
4328 detobj.velVector = Vector3.Zero;
4329 detobj.colliderType = 0;
4330 detobj.groupUUID = UUID.Zero;
4331
4332 return detobj;
4333 }
4334
4335 private ColliderArgs CreateColliderArgs(SceneObjectPart dest, List<uint> colliders)
4336 {
4337 ColliderArgs colliderArgs = new ColliderArgs();
4338 List<DetectedObject> colliding = new List<DetectedObject>();
4339 foreach (uint localId in colliders)
4301 { 4340 {
4302 */ 4341 if (localId == 0)
4303 try 4342 continue;
4343
4344 SceneObjectPart obj = m_scene.GetSceneObjectPart(localId);
4345 if (obj != null)
4304 { 4346 {
4305 List<uint> thisHitColliders = new List<uint>(); 4347 if (!dest.CollisionFilteredOut(obj.UUID, obj.Name))
4306 List<uint> endedColliders = new List<uint>(); 4348 colliding.Add(CreateDetObject(obj));
4307 List<uint> startedColliders = new List<uint>(); 4349 }
4308 List<CollisionForSoundInfo> soundinfolist = new List<CollisionForSoundInfo>(); 4350 else
4309 CollisionForSoundInfo soundinfo; 4351 {
4310 ContactPoint curcontact; 4352 ScenePresence av = m_scene.GetScenePresence(localId);
4311 4353 if (av != null && (!av.IsChildAgent))
4312 if (coldata.Count == 0)
4313 { 4354 {
4314 if (m_lastColliders.Count == 0) 4355 if (!dest.CollisionFilteredOut(av.UUID, av.Name))
4315 return; // nothing to do 4356 colliding.Add(CreateDetObject(av));
4316
4317 foreach (uint localID in m_lastColliders)
4318 {
4319 endedColliders.Add(localID);
4320 }
4321 m_lastColliders.Clear();
4322 } 4357 }
4358 }
4359 }
4323 4360
4324 else 4361 colliderArgs.Colliders = colliding;
4325 {
4326 foreach (uint id in coldata.Keys)
4327 {
4328 thisHitColliders.Add(id);
4329 if (!m_lastColliders.Contains(id))
4330 {
4331 startedColliders.Add(id);
4332 curcontact = coldata[id];
4333 if (Math.Abs(curcontact.RelativeSpeed) > 0.2)
4334 {
4335 soundinfo = new CollisionForSoundInfo();
4336 soundinfo.colliderID = id;
4337 soundinfo.position = curcontact.Position;
4338 soundinfo.relativeVel = curcontact.RelativeSpeed;
4339 soundinfolist.Add(soundinfo);
4340 }
4341 }
4342 //m_log.Debug("[SCENE PRESENCE]: Collided with:" + localid.ToString() + " at depth of: " + collissionswith[localid].ToString());
4343 }
4344 4362
4345 // calculate things that ended colliding 4363 return colliderArgs;
4346 foreach (uint localID in m_lastColliders) 4364 }
4347 {
4348 if (!thisHitColliders.Contains(localID))
4349 {
4350 endedColliders.Add(localID);
4351 }
4352 }
4353 //add the items that started colliding this time to the last colliders list.
4354 foreach (uint localID in startedColliders)
4355 {
4356 m_lastColliders.Add(localID);
4357 }
4358 // remove things that ended colliding from the last colliders list
4359 foreach (uint localID in endedColliders)
4360 {
4361 m_lastColliders.Remove(localID);
4362 }
4363
4364 if (soundinfolist.Count > 0)
4365 CollisionSounds.AvatarCollisionSound(this, soundinfolist);
4366 4365
4367 // do event notification 4366 private delegate void ScriptCollidingNotification(uint localID, ColliderArgs message);
4368 if (startedColliders.Count > 0)
4369 {
4370 4367
4371 ColliderArgs StartCollidingMessage = new ColliderArgs(); 4368 private void SendCollisionEvent(SceneObjectGroup dest, scriptEvents ev, List<uint> colliders, ScriptCollidingNotification notify)
4372 List<DetectedObject> colliding = new List<DetectedObject>(); 4369 {
4373 foreach (uint localId in startedColliders) 4370 ColliderArgs CollidingMessage;
4374 {
4375 if (localId == 0)
4376 continue;
4377 4371
4378 SceneObjectPart obj = Scene.GetSceneObjectPart(localId); 4372 if (colliders.Count > 0)
4379 string data = ""; 4373 {
4380 if (obj != null) 4374 if ((dest.RootPart.ScriptEvents & ev) != 0)
4381 { 4375 {
4382 DetectedObject detobj = new DetectedObject(); 4376 CollidingMessage = CreateColliderArgs(dest.RootPart, colliders);
4383 detobj.keyUUID = obj.UUID;
4384 detobj.nameStr = obj.Name;
4385 detobj.ownerUUID = obj.OwnerID;
4386 detobj.posVector = obj.AbsolutePosition;
4387 detobj.rotQuat = obj.GetWorldRotation();
4388 detobj.velVector = obj.Velocity;
4389 detobj.colliderType = 0;
4390 detobj.groupUUID = obj.GroupID;
4391 colliding.Add(detobj);
4392 }
4393 }
4394 4377
4395 if (colliding.Count > 0) 4378 if (CollidingMessage.Colliders.Count > 0)
4396 { 4379 notify(dest.RootPart.LocalId, CollidingMessage);
4397 StartCollidingMessage.Colliders = colliding; 4380 }
4381 }
4382 }
4398 4383
4399 foreach (SceneObjectGroup att in GetAttachments()) 4384 private void SendLandCollisionEvent(SceneObjectGroup dest, scriptEvents ev, ScriptCollidingNotification notify)
4400 Scene.EventManager.TriggerScriptCollidingStart(att.LocalId, StartCollidingMessage); 4385 {
4401 } 4386 if ((dest.RootPart.ScriptEvents & ev) != 0)
4402 } 4387 {
4403 } 4388 ColliderArgs LandCollidingMessage = new ColliderArgs();
4389 List<DetectedObject> colliding = new List<DetectedObject>();
4404 4390
4405 if (endedColliders.Count > 0) 4391 colliding.Add(CreateDetObjectForGround());
4406 { 4392 LandCollidingMessage.Colliders = colliding;
4407 ColliderArgs EndCollidingMessage = new ColliderArgs();
4408 List<DetectedObject> colliding = new List<DetectedObject>();
4409 foreach (uint localId in endedColliders)
4410 {
4411 if (localId == 0)
4412 continue;
4413 4393
4414 SceneObjectPart obj = Scene.GetSceneObjectPart(localId); 4394 notify(dest.RootPart.LocalId, LandCollidingMessage);
4415 string data = ""; 4395 }
4416 if (obj != null) 4396 }
4417 {
4418 DetectedObject detobj = new DetectedObject();
4419 detobj.keyUUID = obj.UUID;
4420 detobj.nameStr = obj.Name;
4421 detobj.ownerUUID = obj.OwnerID;
4422 detobj.posVector = obj.AbsolutePosition;
4423 detobj.rotQuat = obj.GetWorldRotation();
4424 detobj.velVector = obj.Velocity;
4425 detobj.colliderType = 0;
4426 detobj.groupUUID = obj.GroupID;
4427 colliding.Add(detobj);
4428 }
4429 }
4430 4397
4431 if (colliding.Count > 0) 4398 private void RaiseCollisionScriptEvents(Dictionary<uint, ContactPoint> coldata)
4432 { 4399 {
4433 EndCollidingMessage.Colliders = colliding; 4400 try
4401 {
4402 List<uint> thisHitColliders = new List<uint>();
4403 List<uint> endedColliders = new List<uint>();
4404 List<uint> startedColliders = new List<uint>();
4405 List<CollisionForSoundInfo> soundinfolist = new List<CollisionForSoundInfo>();
4406 CollisionForSoundInfo soundinfo;
4407 ContactPoint curcontact;
4408
4409 if (coldata.Count == 0)
4410 {
4411 if (m_lastColliders.Count == 0)
4412 return; // nothing to do
4434 4413
4435 foreach (SceneObjectGroup att in GetAttachments()) 4414 foreach (uint localID in m_lastColliders)
4436 Scene.EventManager.TriggerScriptCollidingEnd(att.LocalId, EndCollidingMessage); 4415 {
4437 } 4416 endedColliders.Add(localID);
4438 } 4417 }
4418 m_lastColliders.Clear();
4419 }
4439 4420
4440 if (thisHitColliders.Count > 0) 4421 else
4422 {
4423 foreach (uint id in coldata.Keys)
4441 { 4424 {
4442 ColliderArgs CollidingMessage = new ColliderArgs(); 4425 thisHitColliders.Add(id);
4443 List<DetectedObject> colliding = new List<DetectedObject>(); 4426 if (!m_lastColliders.Contains(id))
4444 foreach (uint localId in thisHitColliders)
4445 { 4427 {
4446 if (localId == 0) 4428 startedColliders.Add(id);
4447 continue; 4429 curcontact = coldata[id];
4448 4430 if (Math.Abs(curcontact.RelativeSpeed) > 0.2)
4449 SceneObjectPart obj = Scene.GetSceneObjectPart(localId);
4450 string data = "";
4451 if (obj != null)
4452 { 4431 {
4453 DetectedObject detobj = new DetectedObject(); 4432 soundinfo = new CollisionForSoundInfo();
4454 detobj.keyUUID = obj.UUID; 4433 soundinfo.colliderID = id;
4455 detobj.nameStr = obj.Name; 4434 soundinfo.position = curcontact.Position;
4456 detobj.ownerUUID = obj.OwnerID; 4435 soundinfo.relativeVel = curcontact.RelativeSpeed;
4457 detobj.posVector = obj.AbsolutePosition; 4436 soundinfolist.Add(soundinfo);
4458 detobj.rotQuat = obj.GetWorldRotation();
4459 detobj.velVector = obj.Velocity;
4460 detobj.colliderType = 0;
4461 detobj.groupUUID = obj.GroupID;
4462 colliding.Add(detobj);
4463 } 4437 }
4464 } 4438 }
4439 //m_log.Debug("[SCENE PRESENCE]: Collided with:" + localid.ToString() + " at depth of: " + collissionswith[localid].ToString());
4440 }
4465 4441
4466 if (colliding.Count > 0) 4442 // calculate things that ended colliding
4443 foreach (uint localID in m_lastColliders)
4444 {
4445 if (!thisHitColliders.Contains(localID))
4467 { 4446 {
4468 CollidingMessage.Colliders = colliding; 4447 endedColliders.Add(localID);
4469
4470 lock (m_attachments)
4471 {
4472 foreach (SceneObjectGroup att in m_attachments)
4473 Scene.EventManager.TriggerScriptColliding(att.LocalId, CollidingMessage);
4474 }
4475 } 4448 }
4476 } 4449 }
4450 //add the items that started colliding this time to the last colliders list.
4451 foreach (uint localID in startedColliders)
4452 {
4453 m_lastColliders.Add(localID);
4454 }
4455 // remove things that ended colliding from the last colliders list
4456 foreach (uint localID in endedColliders)
4457 {
4458 m_lastColliders.Remove(localID);
4459 }
4460
4461 if (soundinfolist.Count > 0)
4462 CollisionSounds.AvatarCollisionSound(this, soundinfolist);
4477 } 4463 }
4478 finally 4464
4465 foreach (SceneObjectGroup att in GetAttachments())
4479 { 4466 {
4480 m_collisionEventFlag = false; 4467 SendCollisionEvent(att, scriptEvents.collision_start, startedColliders, m_scene.EventManager.TriggerScriptCollidingStart);
4468 SendCollisionEvent(att, scriptEvents.collision , m_lastColliders , m_scene.EventManager.TriggerScriptColliding);
4469 SendCollisionEvent(att, scriptEvents.collision_end , endedColliders , m_scene.EventManager.TriggerScriptCollidingEnd);
4470
4471 if (startedColliders.Contains(0))
4472 SendLandCollisionEvent(att, scriptEvents.land_collision_start, m_scene.EventManager.TriggerScriptLandCollidingStart);
4473 if (m_lastColliders.Contains(0))
4474 SendLandCollisionEvent(att, scriptEvents.land_collision, m_scene.EventManager.TriggerScriptLandColliding);
4475 if (endedColliders.Contains(0))
4476 SendLandCollisionEvent(att, scriptEvents.land_collision_end, m_scene.EventManager.TriggerScriptLandCollidingEnd);
4481 } 4477 }
4482// }); 4478 }
4479 finally
4480 {
4481 m_collisionEventFlag = false;
4482 }
4483 } 4483 }
4484 4484
4485 private void TeleportFlagsDebug() { 4485 private void TeleportFlagsDebug() {
diff --git a/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs b/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs
index 093bc3c..6e4e41f 100644
--- a/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs
+++ b/OpenSim/Region/Physics/UbitOdePlugin/ODECharacter.cs
@@ -1118,6 +1118,7 @@ namespace OpenSim.Region.Physics.OdePlugin
1118 if (CollisionEventsThisFrame == null) 1118 if (CollisionEventsThisFrame == null)
1119 CollisionEventsThisFrame = new CollisionEventUpdate(); 1119 CollisionEventsThisFrame = new CollisionEventUpdate();
1120 CollisionEventsThisFrame.AddCollider(CollidedWith, contact); 1120 CollisionEventsThisFrame.AddCollider(CollidedWith, contact);
1121 _parent_scene.AddCollisionEventReporting(this);
1121 } 1122 }
1122 1123
1123 public void SendCollisions() 1124 public void SendCollisions()
diff --git a/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs b/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
index 5109a6a..9a40ab5 100644
--- a/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
+++ b/OpenSim/Region/Physics/UbitOdePlugin/ODEPrim.cs
@@ -1621,12 +1621,13 @@ namespace OpenSim.Region.Physics.OdePlugin
1621 1621
1622 if (Body != IntPtr.Zero) 1622 if (Body != IntPtr.Zero)
1623 { 1623 {
1624 d.BodyDestroy(Body); 1624// d.BodyDestroy(Body);
1625 Body = IntPtr.Zero; 1625// Body = IntPtr.Zero;
1626 // do a more complet destruction
1627 DestroyBody();
1626 m_log.Warn("[PHYSICS]: MakeBody called having a body"); 1628 m_log.Warn("[PHYSICS]: MakeBody called having a body");
1627 } 1629 }
1628 1630
1629
1630 if (d.GeomGetBody(prim_geom) != IntPtr.Zero) 1631 if (d.GeomGetBody(prim_geom) != IntPtr.Zero)
1631 { 1632 {
1632 d.GeomSetBody(prim_geom, IntPtr.Zero); 1633 d.GeomSetBody(prim_geom, IntPtr.Zero);
@@ -3320,6 +3321,10 @@ namespace OpenSim.Region.Physics.OdePlugin
3320 3321
3321 protected void changeBuilding(bool newbuilding) 3322 protected void changeBuilding(bool newbuilding)
3322 { 3323 {
3324 // Check if we need to do anything
3325 if (newbuilding == m_building)
3326 return;
3327
3323 if ((bool)newbuilding) 3328 if ((bool)newbuilding)
3324 { 3329 {
3325 m_building = true; 3330 m_building = true;
@@ -4066,4 +4071,4 @@ namespace OpenSim.Region.Physics.OdePlugin
4066 public Vector3 value; 4071 public Vector3 value;
4067 } 4072 }
4068 } 4073 }
4069} \ No newline at end of file 4074}
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index 03f4108..2700495 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -1272,6 +1272,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
1272 if (!allow) 1272 if (!allow)
1273 return; 1273 return;
1274 1274
1275 if (m_host.ParentGroup.RootPart.PhysActor != null &&
1276 m_host.ParentGroup.RootPart.PhysActor.IsPhysical)
1277 return;
1278
1275 m_host.ScriptSetPhysicsStatus(true); 1279 m_host.ScriptSetPhysicsStatus(true);
1276 } 1280 }
1277 else 1281 else