aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs410
1 files changed, 147 insertions, 263 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index 969ddaf..d419710 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -122,6 +122,11 @@ namespace OpenSim.Region.Framework.Scenes
122 /// Denote all sides of the prim 122 /// Denote all sides of the prim
123 /// </value> 123 /// </value>
124 public const int ALL_SIDES = -1; 124 public const int ALL_SIDES = -1;
125
126 private const scriptEvents PhyscicsNeededSubsEvents = (
127 scriptEvents.collision | scriptEvents.collision_start | scriptEvents.collision_end |
128 scriptEvents.land_collision | scriptEvents.land_collision_start | scriptEvents.land_collision_end
129 );
125 130
126 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 131 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
127 132
@@ -1821,18 +1826,20 @@ namespace OpenSim.Region.Framework.Scenes
1821 /// </summary> 1826 /// </summary>
1822 /// <param name="rootObjectFlags"></param> 1827 /// <param name="rootObjectFlags"></param>
1823 /// <param name="VolumeDetectActive"></param> 1828 /// <param name="VolumeDetectActive"></param>
1829 /// <param name="building"></param>
1824 1830
1825 public void ApplyPhysics(uint rootObjectFlags, bool VolumeDetectActive, bool building) 1831 public void ApplyPhysics(uint _ObjectFlags, bool _VolumeDetectActive, bool building)
1826 { 1832 {
1833 VolumeDetectActive = _VolumeDetectActive; //?? as is used this is redundante
1834
1827 if (!ParentGroup.Scene.CollidablePrims) 1835 if (!ParentGroup.Scene.CollidablePrims)
1828 return; 1836 return;
1829 1837
1830 if (PhysicsShapeType == (byte)PhysShapeType.none) 1838 if (PhysicsShapeType == (byte)PhysShapeType.none)
1831 return; 1839 return;
1832 1840
1833 bool isPhysical = (rootObjectFlags & (uint) PrimFlags.Physics) != 0; 1841 bool isPhysical = (_ObjectFlags & (uint) PrimFlags.Physics) != 0;
1834 bool isPhantom = (rootObjectFlags & (uint) PrimFlags.Phantom) != 0; 1842 bool isPhantom = (_ObjectFlags & (uint) PrimFlags.Phantom) != 0;
1835
1836 1843
1837 if (IsJoint()) 1844 if (IsJoint())
1838 { 1845 {
@@ -1840,68 +1847,11 @@ namespace OpenSim.Region.Framework.Scenes
1840 } 1847 }
1841 else 1848 else
1842 { 1849 {
1843 // Special case for VolumeDetection: If VolumeDetection is set, the phantom flag is locally ignored 1850 if ((!isPhantom || isPhysical || _VolumeDetectActive) && !ParentGroup.IsAttachment
1844// if (VolumeDetectActive) 1851 && !(Shape.PathCurve == (byte)Extrusion.Flexible))
1845// isPhantom = false; 1852 AddToPhysics(isPhysical, isPhantom, building, true);
1846 1853 else
1847 // The only time the physics scene shouldn't know about the prim is if it's phantom or an attachment, which is phantom by definition 1854 PhysActor = null; // just to be sure
1848 // or flexible
1849 // if (!isPhantom && !ParentGroup.IsAttachment && !(Shape.PathCurve == (byte)Extrusion.Flexible))
1850 if ((!isPhantom || isPhysical || VolumeDetectActive) && !ParentGroup.IsAttachment && !(Shape.PathCurve == (byte)Extrusion.Flexible))
1851 {
1852 Vector3 velocity = Velocity;
1853 Vector3 rotationalVelocity = AngularVelocity;
1854 try
1855 {
1856 PhysActor = ParentGroup.Scene.PhysicsScene.AddPrimShape(
1857 string.Format("{0}/{1}", Name, UUID),
1858 Shape,
1859 AbsolutePosition,
1860 Scale,
1861 GetWorldRotation(),
1862 isPhysical,
1863 isPhantom,
1864 PhysicsShapeType,
1865 m_localId);
1866 }
1867 catch
1868 {
1869 m_log.ErrorFormat("[SCENE]: caught exception meshing object {0}. Object set to phantom.", m_uuid);
1870 PhysActor = null;
1871 }
1872
1873 PhysicsActor pa = PhysActor;
1874
1875 if (pa != null)
1876 {
1877 pa.SOPName = this.Name; // save object into the PhysActor so ODE internals know the joint/body info
1878 pa.SetMaterial(Material);
1879
1880 // if root part apply vehicle
1881 if (m_vehicle != null && LocalId == ParentGroup.RootPart.LocalId)
1882 m_vehicle.SetVehicle(pa);
1883
1884 DoPhysicsPropertyUpdate(isPhysical, true);
1885 if(VolumeDetectActive) // change if not the default only
1886 pa.SetVolumeDetect(1);
1887
1888 if (!building)
1889 pa.Building = false;
1890
1891 Velocity = velocity;
1892 AngularVelocity = rotationalVelocity;
1893 pa.Velocity = velocity;
1894 pa.RotationalVelocity = rotationalVelocity;
1895
1896 // if not vehicle and root part apply force and torque
1897 if ((m_vehicle == null || m_vehicle.Type == Vehicle.TYPE_NONE)
1898 && LocalId == ParentGroup.RootPart.LocalId)
1899 {
1900 pa.Force = Force;
1901 pa.Torque = Torque;
1902 }
1903 }
1904 }
1905 } 1855 }
1906 } 1856 }
1907 1857
@@ -4628,7 +4578,6 @@ namespace OpenSim.Region.Framework.Scenes
4628 /// <param name="SetTemporary"></param> 4578 /// <param name="SetTemporary"></param>
4629 /// <param name="SetPhantom"></param> 4579 /// <param name="SetPhantom"></param>
4630 /// <param name="SetVD"></param> 4580 /// <param name="SetVD"></param>
4631// public void UpdatePrimFlags(bool UsePhysics, bool SetTemporary, bool SetPhantom, bool SetVD)
4632 public void UpdatePrimFlags(bool UsePhysics, bool SetTemporary, bool SetPhantom, bool SetVD, bool building) 4581 public void UpdatePrimFlags(bool UsePhysics, bool SetTemporary, bool SetPhantom, bool SetVD, bool building)
4633 { 4582 {
4634 bool wasUsingPhysics = ((Flags & PrimFlags.Physics) != 0); 4583 bool wasUsingPhysics = ((Flags & PrimFlags.Physics) != 0);
@@ -4639,209 +4588,92 @@ namespace OpenSim.Region.Framework.Scenes
4639 if ((UsePhysics == wasUsingPhysics) && (wasTemporary == SetTemporary) && (wasPhantom == SetPhantom) && (SetVD == wasVD)) 4588 if ((UsePhysics == wasUsingPhysics) && (wasTemporary == SetTemporary) && (wasPhantom == SetPhantom) && (SetVD == wasVD))
4640 return; 4589 return;
4641 4590
4642 // do this first
4643 if (building && PhysActor != null && PhysActor.Building != building)
4644 PhysActor.Building = building;
4645
4646 // Special cases for VD. VD can only be called from a script
4647 // and can't be combined with changes to other states. So we can rely
4648 // that...
4649 // ... if VD is changed, all others are not.
4650 // ... if one of the others is changed, VD is not.
4651
4652/*
4653 if (SetVD) // VD is active, special logic applies
4654
4655 volume detection is now independent of phantom in sl
4656
4657 {
4658 // State machine logic for VolumeDetect
4659 // More logic below
4660
4661
4662 bool phanReset = (SetPhantom != wasPhantom) && !SetPhantom;
4663
4664 if (phanReset) // Phantom changes from on to off switch VD off too
4665 {
4666 SetVD = false; // Switch it of for the course of this routine
4667 VolumeDetectActive = false; // and also permanently
4668 if (PhysActor != null)
4669 PhysActor.SetVolumeDetect(0); // Let physics know about it too
4670 }
4671 else
4672 {
4673 // If volumedetect is active we don't want phantom to be applied.
4674 // If this is a new call to VD out of the state "phantom"
4675 // this will also cause the prim to be visible to physics
4676 SetPhantom = false;
4677 }
4678 }
4679 else if (wasVD)
4680 {
4681 // Correspondingly, if VD is turned off, also turn off phantom
4682 SetPhantom = false;
4683 }
4684
4685 if (UsePhysics && IsJoint())
4686 {
4687 SetPhantom = true;
4688 }
4689*/
4690 if (UsePhysics) 4591 if (UsePhysics)
4691 {
4692 AddFlag(PrimFlags.Physics); 4592 AddFlag(PrimFlags.Physics);
4693/*
4694 if (!wasUsingPhysics)
4695 {
4696 DoPhysicsPropertyUpdate(UsePhysics, false);
4697
4698 if (!ParentGroup.IsDeleted)
4699 {
4700 if (LocalId == ParentGroup.RootPart.LocalId)
4701 {
4702 ParentGroup.CheckSculptAndLoad();
4703 }
4704 }
4705 }
4706 */
4707 }
4708 else 4593 else
4709 {
4710 RemFlag(PrimFlags.Physics); 4594 RemFlag(PrimFlags.Physics);
4711/*
4712 if (wasUsingPhysics)
4713 {
4714 DoPhysicsPropertyUpdate(UsePhysics, false);
4715 }
4716*/
4717 }
4718 4595
4719 if (SetPhantom) 4596 if (SetPhantom)
4720 AddFlag(PrimFlags.Phantom); 4597 AddFlag(PrimFlags.Phantom);
4721 else 4598 else
4722 RemFlag(PrimFlags.Phantom); 4599 RemFlag(PrimFlags.Phantom);
4723 4600
4601 if (SetTemporary)
4602 AddFlag(PrimFlags.TemporaryOnRez);
4603 else
4604 RemFlag(PrimFlags.TemporaryOnRez);
4605
4606 VolumeDetectActive = SetVD;
4607
4608 if (ParentGroup.Scene == null)
4609 return;
4610
4611 PhysicsActor pa = PhysActor;
4612
4613 if (pa != null && building && pa.Building != building)
4614 pa.Building = building;
4615
4724 if ((SetPhantom && !UsePhysics) || ParentGroup.IsAttachment || PhysicsShapeType == (byte)PhysShapeType.none 4616 if ((SetPhantom && !UsePhysics) || ParentGroup.IsAttachment || PhysicsShapeType == (byte)PhysShapeType.none
4725 || (Shape.PathCurve == (byte)Extrusion.Flexible)) // note: this may have been changed above in the case of joints 4617 || (Shape.PathCurve == (byte)Extrusion.Flexible))
4726 { 4618 {
4727// AddFlag(PrimFlags.Phantom); 4619 if (pa != null)
4620 {
4621 ParentGroup.Scene.RemovePhysicalPrim(1);
4622 RemoveFromPhysics();
4623 }
4728 4624
4729 Velocity = new Vector3(0, 0, 0); 4625 Velocity = new Vector3(0, 0, 0);
4730 Acceleration = new Vector3(0, 0, 0); 4626 Acceleration = new Vector3(0, 0, 0);
4731 if (ParentGroup.RootPart == this) 4627 if (ParentGroup.RootPart == this)
4732 AngularVelocity = new Vector3(0, 0, 0); 4628 AngularVelocity = new Vector3(0, 0, 0);
4733
4734 if (PhysActor != null)
4735 {
4736 ParentGroup.Scene.RemovePhysicalPrim(1);
4737 RemoveFromPhysics();
4738 }
4739 } 4629 }
4740 else 4630 else
4741 { 4631 {
4742 if (ParentGroup.Scene == null)
4743 return;
4744
4745 if (ParentGroup.Scene.CollidablePrims) 4632 if (ParentGroup.Scene.CollidablePrims)
4746 { 4633 {
4747 if (PhysActor == null) 4634 if (pa == null)
4748 { 4635 {
4749 PhysActor = ParentGroup.Scene.PhysicsScene.AddPrimShape( 4636 AddToPhysics(UsePhysics, SetPhantom, building , false);
4750 string.Format("{0}/{1}", Name, UUID), 4637 pa = PhysActor;
4751 Shape, 4638
4752 AbsolutePosition, 4639 if (pa != null)
4753 Scale,
4754 GetWorldRotation(), //physics wants world rotation like all other functions send
4755 UsePhysics,
4756 SetPhantom,
4757 PhysicsShapeType,
4758 m_localId);
4759
4760 PhysActor.SetMaterial(Material);
4761
4762 // if root part apply vehicle
4763 if (m_vehicle != null && LocalId == ParentGroup.RootPart.LocalId)
4764 m_vehicle.SetVehicle(PhysActor);
4765
4766 DoPhysicsPropertyUpdate(UsePhysics, true);
4767
4768 if (!ParentGroup.IsDeleted)
4769 { 4640 {
4770 if (LocalId == ParentGroup.RootPart.LocalId) 4641 if (
4642// ((AggregateScriptEvents & scriptEvents.collision) != 0) ||
4643// ((AggregateScriptEvents & scriptEvents.collision_end) != 0) ||
4644// ((AggregateScriptEvents & scriptEvents.collision_start) != 0) ||
4645// ((AggregateScriptEvents & scriptEvents.land_collision_start) != 0) ||
4646// ((AggregateScriptEvents & scriptEvents.land_collision) != 0) ||
4647// ((AggregateScriptEvents & scriptEvents.land_collision_end) != 0) ||
4648 ((AggregateScriptEvents & PhyscicsNeededSubsEvents) != 0) || (CollisionSound != UUID.Zero)
4649// (CollisionSound != UUID.Zero)
4650 )
4771 { 4651 {
4772 ParentGroup.CheckSculptAndLoad(); 4652 pa.OnCollisionUpdate += PhysicsCollision;
4653 pa.SubscribeEvents(1000);
4773 } 4654 }
4774 } 4655 }
4775
4776 if (
4777 ((AggregateScriptEvents & scriptEvents.collision) != 0) ||
4778 ((AggregateScriptEvents & scriptEvents.collision_end) != 0) ||
4779 ((AggregateScriptEvents & scriptEvents.collision_start) != 0) ||
4780 ((AggregateScriptEvents & scriptEvents.land_collision_start) != 0) ||
4781 ((AggregateScriptEvents & scriptEvents.land_collision) != 0) ||
4782 ((AggregateScriptEvents & scriptEvents.land_collision_end) != 0) ||
4783 (CollisionSound != UUID.Zero)
4784 )
4785 {
4786 PhysActor.OnCollisionUpdate += PhysicsCollision;
4787 PhysActor.SubscribeEvents(1000);
4788 }
4789 } 4656 }
4657
4790 else // it already has a physical representation 4658 else // it already has a physical representation
4791 { 4659 {
4792 DoPhysicsPropertyUpdate(UsePhysics, false); // Update physical status. 4660 DoPhysicsPropertyUpdate(UsePhysics, false); // Update physical status.
4793 4661
4794 if (!ParentGroup.IsDeleted) 4662 if(VolumeDetectActive)
4795 { 4663 pa.SetVolumeDetect(1);
4796 if (LocalId == ParentGroup.RootPart.LocalId) 4664 else
4797 { 4665 pa.SetVolumeDetect(0);
4798 ParentGroup.CheckSculptAndLoad();
4799 }
4800 }
4801 }
4802 }
4803 }
4804 4666
4805 PhysicsActor pa = PhysActor; 4667 if (pa.Building != building)
4806 if (SetVD) 4668 pa.Building = building;
4807 { 4669 }
4808 // If the above logic worked (this is urgent candidate to unit tests!)
4809 // we now have a physicsactor.
4810 // Defensive programming calls for a check here.
4811 // Better would be throwing an exception that could be catched by a unit test as the internal
4812 // logic should make sure, this Physactor is always here.
4813 if (pa != null)
4814 {
4815 pa.SetVolumeDetect(1);
4816// AddFlag(PrimFlags.Phantom); // We set this flag also if VD is active
4817 this.VolumeDetectActive = true;
4818 }
4819 }
4820 else
4821 {
4822 // Remove VolumeDetect in any case. Note, it's safe to call SetVolumeDetect as often as you like
4823 // (mumbles, well, at least if you have infinte CPU powers :-))
4824 if (pa != null)
4825 {
4826 pa.SetVolumeDetect(0);
4827 this.VolumeDetectActive = false;
4828 } 4670 }
4829 } 4671 }
4830
4831 if (SetTemporary)
4832 {
4833 AddFlag(PrimFlags.TemporaryOnRez);
4834 }
4835 else
4836 {
4837 RemFlag(PrimFlags.TemporaryOnRez);
4838 }
4839 4672
4840 // m_log.Debug("Update: PHY:" + UsePhysics.ToString() + ", T:" + IsTemporary.ToString() + ", PHA:" + IsPhantom.ToString() + " S:" + CastsShadows.ToString()); 4673 // m_log.Debug("Update: PHY:" + UsePhysics.ToString() + ", T:" + IsTemporary.ToString() + ", PHA:" + IsPhantom.ToString() + " S:" + CastsShadows.ToString());
4841 4674
4842 // and last in case we have a new actor and not building 4675 // and last in case we have a new actor and not building
4843 if (pa != null && pa.Building != building) 4676
4844 pa.Building = building;
4845 if (ParentGroup != null) 4677 if (ParentGroup != null)
4846 { 4678 {
4847 ParentGroup.HasGroupChanged = true; 4679 ParentGroup.HasGroupChanged = true;
@@ -4853,48 +4685,104 @@ namespace OpenSim.Region.Framework.Scenes
4853 4685
4854 /// <summary> 4686 /// <summary>
4855 /// Adds this part to the physics scene. 4687 /// Adds this part to the physics scene.
4688 /// and sets the PhysActor property
4856 /// </summary> 4689 /// </summary>
4857 /// <remarks>This method also sets the PhysActor property.</remarks> 4690 /// <param name="isPhysical">Add this prim as physical.</param>
4858 /// <param name="rigidBody">Add this prim with a rigid body.</param> 4691 /// <param name="isPhantom">Add this prim as phantom.</param>
4859 /// <returns> 4692 /// <param name="building">tells physics to delay full construction of object</param>
4860 /// The physics actor. null if there was a failure. 4693 /// <param name="applyDynamics">applies velocities, force and torque</param>
4861 /// </returns> 4694 private void AddToPhysics(bool isPhysical, bool isPhantom, bool building, bool applyDynamics)
4862 private PhysicsActor AddToPhysics(bool rigidBody) 4695 {
4863 {
4864 PhysicsActor pa; 4696 PhysicsActor pa;
4865 4697
4698 Vector3 velocity = Velocity;
4699 Vector3 rotationalVelocity = AngularVelocity;;
4700
4866 try 4701 try
4867 { 4702 {
4868 pa = ParentGroup.Scene.PhysicsScene.AddPrimShape( 4703 pa = ParentGroup.Scene.PhysicsScene.AddPrimShape(
4869 string.Format("{0}/{1}", Name, UUID), 4704 string.Format("{0}/{1}", Name, UUID),
4870 Shape, 4705 Shape,
4871 AbsolutePosition, 4706 AbsolutePosition,
4872 Scale, 4707 Scale,
4873 RotationOffset, 4708 GetWorldRotation(),
4874 rigidBody, 4709 isPhysical,
4875 m_localId); 4710 isPhantom,
4711 PhysicsShapeType,
4712 m_localId);
4876 } 4713 }
4877 catch 4714 catch (Exception ex)
4878 { 4715 {
4879 m_log.ErrorFormat("[SCENE]: caught exception meshing object {0}. Object set to phantom.", m_uuid); 4716 m_log.ErrorFormat("[SCENE]: AddToPhysics object {0} failed: {1}", m_uuid, ex.Message);
4880 pa = null; 4717 pa = null;
4881 } 4718 }
4882 4719
4883 // FIXME: Ideally we wouldn't set the property here to reduce situations where threads changing physical
4884 // properties can stop on each other. However, DoPhysicsPropertyUpdate() currently relies on PhysActor
4885 // being set.
4886 PhysActor = pa;
4887
4888 // Basic Physics can also return null as well as an exception catch.
4889 if (pa != null) 4720 if (pa != null)
4890 { 4721 {
4891 pa.SOPName = this.Name; // save object into the PhysActor so ODE internals know the joint/body info 4722 pa.SOPName = this.Name; // save object into the PhysActor so ODE internals know the joint/body info
4892 pa.SetMaterial(Material); 4723 pa.SetMaterial(Material);
4893 DoPhysicsPropertyUpdate(rigidBody, true); 4724
4725 if (VolumeDetectActive) // change if not the default only
4726 pa.SetVolumeDetect(1);
4727
4728 if (m_vehicle != null && LocalId == ParentGroup.RootPart.LocalId)
4729 m_vehicle.SetVehicle(pa);
4730
4731 // we are going to tell rest of code about physics so better have this here
4732 PhysActor = pa;
4733
4734 // DoPhysicsPropertyUpdate(isPhysical, true);
4735 // lets expand it here just with what it really needs to do
4736
4737 if (isPhysical)
4738 {
4739 if (ParentGroup.RootPart.KeyframeMotion != null)
4740 ParentGroup.RootPart.KeyframeMotion.Stop();
4741 ParentGroup.RootPart.KeyframeMotion = null;
4742 ParentGroup.Scene.AddPhysicalPrim(1);
4743
4744 pa.OnRequestTerseUpdate += PhysicsRequestingTerseUpdate;
4745 pa.OnOutOfBounds += PhysicsOutOfBounds;
4746
4747 if (ParentID != 0 && ParentID != LocalId)
4748 {
4749 PhysicsActor parentPa = ParentGroup.RootPart.PhysActor;
4750
4751 if (parentPa != null)
4752 {
4753 pa.link(parentPa);
4754 }
4755 }
4756 }
4757
4758 if (applyDynamics)
4759 // do independent of isphysical so parameters get setted (at least some)
4760 {
4761 Velocity = velocity;
4762 AngularVelocity = rotationalVelocity;
4763 pa.Velocity = velocity;
4764 pa.RotationalVelocity = rotationalVelocity;
4765
4766 // if not vehicle and root part apply force and torque
4767 if ((m_vehicle == null || m_vehicle.Type == Vehicle.TYPE_NONE)
4768 && LocalId == ParentGroup.RootPart.LocalId)
4769 {
4770 pa.Force = Force;
4771 pa.Torque = Torque;
4772 }
4773 }
4774
4775 if (Shape.SculptEntry)
4776 CheckSculptAndLoad();
4777 else
4778 ParentGroup.Scene.PhysicsScene.AddPhysicsActorTaint(pa);
4779
4780 if (!building)
4781 pa.Building = false;
4894 } 4782 }
4895 4783
4896 return pa; 4784 PhysActor = pa;
4897 } 4785 }
4898 4786
4899 /// <summary> 4787 /// <summary>
4900 /// This removes the part from the physics scene. 4788 /// This removes the part from the physics scene.
@@ -5103,10 +4991,6 @@ namespace OpenSim.Region.Framework.Scenes
5103 PhysicsActor pa = PhysActor; 4991 PhysicsActor pa = PhysActor;
5104 if (pa != null) 4992 if (pa != null)
5105 { 4993 {
5106 const scriptEvents NeededSubsEvents = (
5107 scriptEvents.collision | scriptEvents.collision_start| scriptEvents.collision_end |
5108 scriptEvents.land_collision | scriptEvents.land_collision_start | scriptEvents.land_collision_end
5109 );
5110 if ( 4994 if (
5111// ((AggregateScriptEvents & scriptEvents.collision) != 0) || 4995// ((AggregateScriptEvents & scriptEvents.collision) != 0) ||
5112// ((AggregateScriptEvents & scriptEvents.collision_end) != 0) || 4996// ((AggregateScriptEvents & scriptEvents.collision_end) != 0) ||
@@ -5114,7 +4998,7 @@ namespace OpenSim.Region.Framework.Scenes
5114// ((AggregateScriptEvents & scriptEvents.land_collision_start) != 0) || 4998// ((AggregateScriptEvents & scriptEvents.land_collision_start) != 0) ||
5115// ((AggregateScriptEvents & scriptEvents.land_collision) != 0) || 4999// ((AggregateScriptEvents & scriptEvents.land_collision) != 0) ||
5116// ((AggregateScriptEvents & scriptEvents.land_collision_end) != 0) || 5000// ((AggregateScriptEvents & scriptEvents.land_collision_end) != 0) ||
5117 ((AggregateScriptEvents & NeededSubsEvents) != 0) || (CollisionSound != UUID.Zero) 5001 ((AggregateScriptEvents & PhyscicsNeededSubsEvents) != 0) || (CollisionSound != UUID.Zero)
5118 ) 5002 )
5119 { 5003 {
5120 // subscribe to physics updates. 5004 // subscribe to physics updates.