aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs77
-rw-r--r--OpenSim/Region/CoreModules/ServiceConnectorsOut/Simulation/LocalSimulationConnector.cs4
2 files changed, 29 insertions, 52 deletions
diff --git a/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs b/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs
index c81e5aa..ef9f8df 100644
--- a/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs
+++ b/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs
@@ -209,7 +209,7 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
209 protected virtual void InitialiseCommon(IConfigSource source) 209 protected virtual void InitialiseCommon(IConfigSource source)
210 { 210 {
211 string transferVersionName = "SIMULATION"; 211 string transferVersionName = "SIMULATION";
212 float maxTransferVersion = 0.2f; 212 float maxTransferVersion = 0.3f;
213 213
214 IConfig transferConfig = source.Configs["EntityTransfer"]; 214 IConfig transferConfig = source.Configs["EntityTransfer"];
215 if (transferConfig != null) 215 if (transferConfig != null)
@@ -703,6 +703,8 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
703 return; 703 return;
704 } 704 }
705 705
706 string homeURI = Scene.GetAgentHomeURI(sp.ControllingClient.AgentId);
707
706 m_log.DebugFormat( 708 m_log.DebugFormat(
707 "[ENTITY TRANSFER MODULE]: Teleporting {0} {1} from {2} to {3} ({4}) {5}/{6}", 709 "[ENTITY TRANSFER MODULE]: Teleporting {0} {1} from {2} to {3} ({4}) {5}/{6}",
708 sp.Name, sp.UUID, sp.Scene.RegionInfo.RegionName, 710 sp.Name, sp.UUID, sp.Scene.RegionInfo.RegionName,
@@ -749,6 +751,8 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
749 string myversion = string.Format("{0}/{1}", OutgoingTransferVersionName, MaxOutgoingTransferVersion); 751 string myversion = string.Format("{0}/{1}", OutgoingTransferVersionName, MaxOutgoingTransferVersion);
750 if (!Scene.SimulationService.QueryAccess( 752 if (!Scene.SimulationService.QueryAccess(
751 finalDestination, sp.ControllingClient.AgentId, position, out version, out reason)) 753 finalDestination, sp.ControllingClient.AgentId, position, out version, out reason))
754// if (!Scene.SimulationService.QueryAccess(
755// finalDestination, sp.ControllingClient.AgentId, homeURI, true, position, myversion, out version, out reason))
752 { 756 {
753 sp.ControllingClient.SendTeleportFailed(reason); 757 sp.ControllingClient.SendTeleportFailed(reason);
754 758
@@ -843,7 +847,7 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
843 if (versionComponents.Length >= 2) 847 if (versionComponents.Length >= 2)
844 float.TryParse(versionComponents[1], out versionNumber); 848 float.TryParse(versionComponents[1], out versionNumber);
845 849
846 if (versionNumber == 0.2f && MaxOutgoingTransferVersion >= versionNumber) 850 if (versionNumber >= 0.2f && MaxOutgoingTransferVersion >= versionNumber)
847 TransferAgent_V2(sp, agentCircuit, reg, finalDestination, endPoint, teleportFlags, oldRegionX, newRegionX, oldRegionY, newRegionY, version, out reason); 851 TransferAgent_V2(sp, agentCircuit, reg, finalDestination, endPoint, teleportFlags, oldRegionX, newRegionX, oldRegionY, newRegionY, version, out reason);
848 else 852 else
849 TransferAgent_V1(sp, agentCircuit, reg, finalDestination, endPoint, teleportFlags, oldRegionX, newRegionX, oldRegionY, newRegionY, version, out reason); 853 TransferAgent_V1(sp, agentCircuit, reg, finalDestination, endPoint, teleportFlags, oldRegionX, newRegionX, oldRegionY, newRegionY, version, out reason);
@@ -2270,7 +2274,7 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
2270 #endregion // NotFoundLocationCache class 2274 #endregion // NotFoundLocationCache class
2271 private NotFoundLocationCache m_notFoundLocationCache = new NotFoundLocationCache(); 2275 private NotFoundLocationCache m_notFoundLocationCache = new NotFoundLocationCache();
2272 2276
2273 // Given a world position (fractional meter coordinate), get the GridRegion info for 2277 // Given a world position, get the GridRegion info for
2274 // the region containing that point. 2278 // the region containing that point.
2275 // Someday this should be a method on GridService. 2279 // Someday this should be a method on GridService.
2276 // 'pSizeHint' is the size of the source region but since the destination point can be anywhere 2280 // 'pSizeHint' is the size of the source region but since the destination point can be anywhere
@@ -2471,14 +2475,26 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
2471 { 2475 {
2472 // The area to check is as big as the current region. 2476 // The area to check is as big as the current region.
2473 // We presume all adjacent regions are the same size as this region. 2477 // We presume all adjacent regions are the same size as this region.
2474 uint dd = Math.Max((uint)avatar.Scene.DefaultDrawDistance, 2478 // this needs to be reduced a lot
2475 Math.Max(Scene.RegionInfo.RegionSizeX, Scene.RegionInfo.RegionSizeY)); 2479 // and updated in avatar CheckForSignificantMovement (larger than current 64m?)
2476 2480 // and draw distance changes
2477 uint startX = Util.RegionToWorldLoc(pRegionLocX) - dd + Constants.RegionSize/2; 2481 // sending client the necessary information
2478 uint startY = Util.RegionToWorldLoc(pRegionLocY) - dd + Constants.RegionSize/2; 2482 uint dd = Math.Max((uint)avatar.DrawDistance, Constants.RegionSize);
2479 2483
2480 uint endX = Util.RegionToWorldLoc(pRegionLocX) + dd + Constants.RegionSize/2; 2484 dd--;
2481 uint endY = Util.RegionToWorldLoc(pRegionLocY) + dd + Constants.RegionSize/2; 2485 uint ddX = Math.Max(dd, Scene.RegionInfo.RegionSizeX);
2486 uint ddY = Math.Max(dd, Scene.RegionInfo.RegionSizeY);
2487
2488 // region center. Should be avatar position
2489 uint startX = Util.RegionToWorldLoc(pRegionLocX) + m_regionInfo.RegionSizeX / 2;
2490 uint endX = startX;
2491 uint startY = Util.RegionToWorldLoc(pRegionLocY) + m_regionInfo.RegionSizeY / 2;
2492 uint endY = startY;
2493
2494 startX -= dd;
2495 startY -= dd;
2496 endX += dd;
2497 endY += dd;
2482 2498
2483 neighbours 2499 neighbours
2484 = avatar.Scene.GridService.GetRegionRange( 2500 = avatar.Scene.GridService.GetRegionRange(
@@ -2502,45 +2518,6 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
2502 2518
2503 return neighbours; 2519 return neighbours;
2504 } 2520 }
2505/* not in use
2506 private List<ulong> NewNeighbours(List<ulong> currentNeighbours, List<ulong> previousNeighbours)
2507 {
2508 return currentNeighbours.FindAll(delegate(ulong handle) { return !previousNeighbours.Contains(handle); });
2509 }
2510
2511 // private List<ulong> CommonNeighbours(List<ulong> currentNeighbours, List<ulong> previousNeighbours)
2512 // {
2513 // return currentNeighbours.FindAll(delegate(ulong handle) { return previousNeighbours.Contains(handle); });
2514 // }
2515
2516// private List<ulong> OldNeighbours(List<ulong> currentNeighbours, List<ulong> previousNeighbours)
2517// {
2518// return previousNeighbours.FindAll(delegate(ulong handle) { return !currentNeighbours.Contains(handle); });
2519// }
2520
2521// private List<ulong> NeighbourHandles(List<GridRegion> neighbours)
2522// {
2523// List<ulong> handles = new List<ulong>();
2524// foreach (GridRegion reg in neighbours)
2525// {
2526// handles.Add(reg.RegionHandle);
2527// }
2528// return handles;
2529// }
2530
2531// private void Dump(string msg, List<ulong> handles)
2532// {
2533// m_log.InfoFormat("-------------- HANDLE DUMP ({0}) ---------", msg);
2534// foreach (ulong handle in handles)
2535// {
2536// uint x, y;
2537// Utils.LongToUInts(handle, out x, out y);
2538// x = x / Constants.RegionSize;
2539// y = y / Constants.RegionSize;
2540// m_log.InfoFormat("({0}, {1})", x, y);
2541// }
2542// }
2543*/
2544 #endregion 2521 #endregion
2545 2522
2546 #region Agent Arrived 2523 #region Agent Arrived
diff --git a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Simulation/LocalSimulationConnector.cs b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Simulation/LocalSimulationConnector.cs
index 7a6a174..361bf34 100644
--- a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Simulation/LocalSimulationConnector.cs
+++ b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Simulation/LocalSimulationConnector.cs
@@ -84,13 +84,13 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Simulation
84 84
85 public void InitialiseService(IConfigSource configSource) 85 public void InitialiseService(IConfigSource configSource)
86 { 86 {
87 ServiceVersion = "SIMULATION/0.2"; 87 ServiceVersion = "SIMULATION/0.3";
88 IConfig config = configSource.Configs["SimulationService"]; 88 IConfig config = configSource.Configs["SimulationService"];
89 if (config != null) 89 if (config != null)
90 { 90 {
91 ServiceVersion = config.GetString("ConnectorProtocolVersion", ServiceVersion); 91 ServiceVersion = config.GetString("ConnectorProtocolVersion", ServiceVersion);
92 92
93 if (ServiceVersion != "SIMULATION/0.1" && ServiceVersion != "SIMULATION/0.2") 93 if (ServiceVersion != "SIMULATION/0.1" && ServiceVersion != "SIMULATION/0.2" && ServiceVersion != "SIMULATION/0.3")
94 throw new Exception(string.Format("Invalid ConnectorProtocolVersion {0}", ServiceVersion)); 94 throw new Exception(string.Format("Invalid ConnectorProtocolVersion {0}", ServiceVersion));
95 95
96 m_log.InfoFormat( 96 m_log.InfoFormat(