diff options
Diffstat (limited to 'OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs')
-rw-r--r-- | OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs index 67fa13d..1ba1953 100644 --- a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs +++ b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs | |||
@@ -711,6 +711,33 @@ namespace OpenSim.Region.Framework.Scenes | |||
711 | position = emergencyPos; | 711 | position = emergencyPos; |
712 | } | 712 | } |
713 | 713 | ||
714 | Vector3 currentPos = avatar.AbsolutePosition; | ||
715 | ILandObject srcLand = m_scene.LandChannel.GetLandObject(currentPos.X, currentPos.Y); | ||
716 | ILandObject destLand = m_scene.LandChannel.GetLandObject(position.X, position.Y); | ||
717 | if (srcLand != null && destLand != null && (teleportFlags & (uint)TeleportFlags.ViaLure) == 0 && (teleportFlags & (uint)TeleportFlags.ViaGodlikeLure) == 0) | ||
718 | { | ||
719 | if (srcLand.LandData.LocalID == destLand.LandData.LocalID) | ||
720 | { | ||
721 | //TPing within the same parcel. If the landing point is restricted, block the TP. | ||
722 | //Don't restrict gods, estate managers, or land owners to the TP point. This behaviour mimics agni. | ||
723 | if (destLand.LandData.LandingType == (byte)1 && destLand.LandData.UserLocation != Vector3.Zero && avatar.GodLevel < 200 && !m_scene.RegionInfo.EstateSettings.IsEstateManager(avatar.UUID) && destLand.LandData.OwnerID != avatar.UUID) | ||
724 | { | ||
725 | //Disabling this behaviour for now pending review. ~CasperW | ||
726 | |||
727 | //avatar.ControllingClient.SendAgentAlertMessage("Can't TP to the destination; landing point set.", false); | ||
728 | //position = currentPos; | ||
729 | } | ||
730 | } | ||
731 | else | ||
732 | { | ||
733 | //Tping to a different parcel. Respect the landing point on the destination parcel. | ||
734 | if (destLand.LandData.LandingType == (byte)1 && destLand.LandData.UserLocation != Vector3.Zero && avatar.GodLevel < 200 && !m_scene.RegionInfo.EstateSettings.IsEstateManager(avatar.UUID) && destLand.LandData.OwnerID != avatar.UUID) | ||
735 | { | ||
736 | position = destLand.LandData.UserLocation; | ||
737 | } | ||
738 | } | ||
739 | } | ||
740 | |||
714 | // TODO: Get proper AVG Height | 741 | // TODO: Get proper AVG Height |
715 | float localAVHeight = 1.56f; | 742 | float localAVHeight = 1.56f; |
716 | float posZLimit = 22; | 743 | float posZLimit = 22; |
@@ -1005,7 +1032,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
1005 | 1032 | ||
1006 | public bool WaitForCallback(UUID id) | 1033 | public bool WaitForCallback(UUID id) |
1007 | { | 1034 | { |
1008 | int count = 200; | 1035 | int count = 400; |
1009 | while (m_agentsInTransit.Contains(id) && count-- > 0) | 1036 | while (m_agentsInTransit.Contains(id) && count-- > 0) |
1010 | { | 1037 | { |
1011 | //m_log.Debug(" >>> Waiting... " + count); | 1038 | //m_log.Debug(" >>> Waiting... " + count); |