aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorJustin Clarke Casey2009-05-14 18:24:52 +0000
committerJustin Clarke Casey2009-05-14 18:24:52 +0000
commitb2433d2b99cc7f610ad03fc2ad8ce76494940d35 (patch)
tree482b492b85c950612a8068c810aa6a32c603de71
parent* refactor: move bottom part of 'xml2' serializaton to separate class (diff)
downloadopensim-SC-b2433d2b99cc7f610ad03fc2ad8ce76494940d35.zip
opensim-SC-b2433d2b99cc7f610ad03fc2ad8ce76494940d35.tar.gz
opensim-SC-b2433d2b99cc7f610ad03fc2ad8ce76494940d35.tar.bz2
opensim-SC-b2433d2b99cc7f610ad03fc2ad8ce76494940d35.tar.xz
* Improve loadregions so that all region configs are checked for clashes (e.g. same uuid) rather than just one
Diffstat (limited to '')
-rw-r--r--OpenSim/ApplicationPlugins/LoadRegions/LoadRegionsPlugin.cs35
1 files changed, 15 insertions, 20 deletions
diff --git a/OpenSim/ApplicationPlugins/LoadRegions/LoadRegionsPlugin.cs b/OpenSim/ApplicationPlugins/LoadRegions/LoadRegionsPlugin.cs
index 9416fe5..c37c2e8 100644
--- a/OpenSim/ApplicationPlugins/LoadRegions/LoadRegionsPlugin.cs
+++ b/OpenSim/ApplicationPlugins/LoadRegions/LoadRegionsPlugin.cs
@@ -68,7 +68,7 @@ namespace OpenSim.ApplicationPlugins.LoadRegions
68 68
69 public void Initialise() 69 public void Initialise()
70 { 70 {
71 m_log.Info("[LOADREGIONS]: " + Name + " cannot be default-initialized!"); 71 m_log.Error("[LOADREGIONS]: " + Name + " cannot be default-initialized!");
72 throw new PluginNotInitialisedException(Name); 72 throw new PluginNotInitialisedException(Name);
73 } 73 }
74 74
@@ -80,17 +80,17 @@ namespace OpenSim.ApplicationPlugins.LoadRegions
80 80
81 public void PostInitialise() 81 public void PostInitialise()
82 { 82 {
83 m_log.Info("[LOADREGIONS]: Load Regions addin being initialised"); 83 //m_log.Info("[LOADREGIONS]: Load Regions addin being initialised");
84 84
85 IRegionLoader regionLoader; 85 IRegionLoader regionLoader;
86 if (m_openSim.ConfigSource.Source.Configs["Startup"].GetString("region_info_source", "filesystem") == "filesystem") 86 if (m_openSim.ConfigSource.Source.Configs["Startup"].GetString("region_info_source", "filesystem") == "filesystem")
87 { 87 {
88 m_log.Info("[LOADREGIONS]: Loading Region Info from filesystem"); 88 m_log.Info("[LOADREGIONS]: Loading region configurations from filesystem");
89 regionLoader = new RegionLoaderFileSystem(); 89 regionLoader = new RegionLoaderFileSystem();
90 } 90 }
91 else 91 else
92 { 92 {
93 m_log.Info("[LOADREGIONSPLUGIN]: Loading Region Info from web"); 93 m_log.Info("[LOADREGIONSPLUGIN]: Loading region configurations from web");
94 regionLoader = new RegionLoaderWebServer(); 94 regionLoader = new RegionLoaderWebServer();
95 } 95 }
96 96
@@ -142,38 +142,33 @@ namespace OpenSim.ApplicationPlugins.LoadRegions
142 /// <returns>True if we're sane, false if we're insane</returns> 142 /// <returns>True if we're sane, false if we're insane</returns>
143 private bool CheckRegionsForSanity(RegionInfo[] regions) 143 private bool CheckRegionsForSanity(RegionInfo[] regions)
144 { 144 {
145 if (regions.Length <= 0) 145 if (regions.Length <= 1)
146 return true; 146 return true;
147 147
148 List<RegionInfo> checkedRegions = new List<RegionInfo>(); 148 for (int i = 0; i < regions.Length - 1; i++)
149 checkedRegions.Add(regions[0]);
150
151 for (int i = 1; i < regions.Length; i++)
152 { 149 {
153 RegionInfo region = regions[i]; 150 for (int j = i + 1; j < regions.Length; j++)
154
155 foreach (RegionInfo checkedRegion in checkedRegions)
156 { 151 {
157 if (region.RegionID == checkedRegion.RegionID) 152 if (regions[i].RegionID == regions[j].RegionID)
158 { 153 {
159 m_log.ErrorFormat( 154 m_log.ErrorFormat(
160 "[LOADREGIONS]: Regions {0} and {1} have the same UUID {2}", 155 "[LOADREGIONS]: Regions {0} and {1} have the same UUID {2}",
161 region.RegionName, checkedRegion.RegionName, region.RegionID); 156 regions[i].RegionName, regions[j].RegionName, regions[i].RegionID);
162 return false; 157 return false;
163 } 158 }
164 else if (region.RegionLocX == checkedRegion.RegionLocX && 159 else if (
165 region.RegionLocY == checkedRegion.RegionLocY) 160 regions[i].RegionLocX == regions[j].RegionLocX && regions[i].RegionLocY == regions[j].RegionLocY)
166 { 161 {
167 m_log.ErrorFormat( 162 m_log.ErrorFormat(
168 "[LOADREGIONS]: Regions {0} and {1} have the same location {2} {3}", 163 "[LOADREGIONS]: Regions {0} and {1} have the same grid location ({2}, {3})",
169 region.RegionName, checkedRegion.RegionName, region.RegionLocX, region.RegionLocY); 164 regions[i].RegionName, regions[j].RegionName, regions[i].RegionLocX, regions[i].RegionLocY);
170 return false; 165 return false;
171 } 166 }
172 else if (region.InternalEndPoint.Port == checkedRegion.InternalEndPoint.Port) 167 else if (regions[i].InternalEndPoint.Port == regions[j].InternalEndPoint.Port)
173 { 168 {
174 m_log.ErrorFormat( 169 m_log.ErrorFormat(
175 "[LOADREGIONS]: Regions {0} and {1} have the same internal IP port {2}", 170 "[LOADREGIONS]: Regions {0} and {1} have the same internal IP port {2}",
176 region.RegionName, checkedRegion.RegionName, region.InternalEndPoint.Port); 171 regions[i].RegionName, regions[j].RegionName, regions[i].InternalEndPoint.Port);
177 return false; 172 return false;
178 } 173 }
179 } 174 }