From 7a9c85526cb99495bdd436150679941ef021b782 Mon Sep 17 00:00:00 2001 From: diva Date: Sun, 14 Jun 2009 15:35:09 +0000 Subject: Pulled out HelloNeighbour into its own service, INeighbourService, which may get more functions as we go along. It's a very simple service and service connectors, and it served primarily to establish the design of services that dependent on Scenes and that must always have a local connector. More refactoring coming, as this showed how to do it right. --- OpenSim/Region/Framework/Interfaces/IInterregionComms.cs | 5 ----- OpenSim/Region/Framework/Scenes/Scene.cs | 2 +- .../Region/Framework/Scenes/SceneCommunicationService.cs | 16 +++++++++++----- 3 files changed, 12 insertions(+), 11 deletions(-) (limited to 'OpenSim/Region/Framework') diff --git a/OpenSim/Region/Framework/Interfaces/IInterregionComms.cs b/OpenSim/Region/Framework/Interfaces/IInterregionComms.cs index d239ef4..8f4d3d5 100644 --- a/OpenSim/Region/Framework/Interfaces/IInterregionComms.cs +++ b/OpenSim/Region/Framework/Interfaces/IInterregionComms.cs @@ -100,11 +100,6 @@ namespace OpenSim.Region.Framework.Interfaces #endregion Objects - #region Regions - - bool SendHelloNeighbour(ulong regionHandle, RegionInfo thisRegion); - - #endregion Regions } // This may not be needed, but having it here for now. diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs index 5349d87..d3437b9 100644 --- a/OpenSim/Region/Framework/Scenes/Scene.cs +++ b/OpenSim/Region/Framework/Scenes/Scene.cs @@ -1198,7 +1198,7 @@ namespace OpenSim.Region.Framework.Scenes // These two 'commands' *must be* next to each other or sim rebooting fails. m_sceneGridService.RegisterRegion(m_interregionCommsOut, RegionInfo); - m_sceneGridService.InformNeighborsThatRegionisUp(RegionInfo); + m_sceneGridService.InformNeighborsThatRegionisUp(RequestModuleInterface(), RegionInfo); Dictionary dGridSettings = m_sceneGridService.GetGridSettings(); diff --git a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs index 8cc5cd8..833f804 100644 --- a/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs +++ b/OpenSim/Region/Framework/Scenes/SceneCommunicationService.cs @@ -39,6 +39,7 @@ using OpenSim.Framework.Communications; using OpenSim.Framework.Communications.Cache; using OpenSim.Framework.Communications.Capabilities; using OpenSim.Region.Framework.Interfaces; +using OpenSim.Services.Interfaces; using OSD = OpenMetaverse.StructuredData.OSD; namespace OpenSim.Region.Framework.Scenes @@ -485,7 +486,7 @@ namespace OpenSim.Region.Framework.Scenes #endregion - public delegate void InformNeighbourThatRegionUpDelegate(RegionInfo region, ulong regionhandle); + public delegate void InformNeighbourThatRegionUpDelegate(INeighbourService nService, RegionInfo region, ulong regionhandle); private void InformNeighborsThatRegionisUpCompleted(IAsyncResult iar) { @@ -498,7 +499,7 @@ namespace OpenSim.Region.Framework.Scenes /// /// /// - private void InformNeighboursThatRegionIsUpAsync(RegionInfo region, ulong regionhandle) + private void InformNeighboursThatRegionIsUpAsync(INeighbourService neighbourService, RegionInfo region, ulong regionhandle) { m_log.Info("[INTERGRID]: Starting to inform neighbors that I'm here"); //RegionUpData regiondata = new RegionUpData(region.RegionLocX, region.RegionLocY, region.ExternalHostName, region.InternalEndPoint.Port); @@ -506,7 +507,12 @@ namespace OpenSim.Region.Framework.Scenes //bool regionAccepted = // m_commsProvider.InterRegion.RegionUp(new SerializableRegionInfo(region), regionhandle); - bool regionAccepted = m_interregionCommsOut.SendHelloNeighbour(regionhandle, region); + //bool regionAccepted = m_interregionCommsOut.SendHelloNeighbour(regionhandle, region); + bool regionAccepted = false; + if (neighbourService != null) + regionAccepted = neighbourService.HelloNeighbour(regionhandle, region); + else + m_log.DebugFormat("[SCS]: No neighbour service provided for informing neigbhours of this region"); if (regionAccepted) { @@ -527,7 +533,7 @@ namespace OpenSim.Region.Framework.Scenes /// Called by scene when region is initialized (not always when it's listening for agents) /// This is an inter-region message that informs the surrounding neighbors that the sim is up. /// - public void InformNeighborsThatRegionisUp(RegionInfo region) + public void InformNeighborsThatRegionisUp(INeighbourService neighbourService, RegionInfo region) { //m_log.Info("[INTER]: " + debugRegionName + ": SceneCommunicationService: Sending InterRegion Notification that region is up " + region.RegionName); @@ -541,7 +547,7 @@ namespace OpenSim.Region.Framework.Scenes { InformNeighbourThatRegionUpDelegate d = InformNeighboursThatRegionIsUpAsync; - d.BeginInvoke(region, neighbours[i].RegionHandle, + d.BeginInvoke(neighbourService, region, neighbours[i].RegionHandle, InformNeighborsThatRegionisUpCompleted, d); } -- cgit v1.1