aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules')
-rw-r--r--OpenSim/Region/CoreModules/World/WorldMap/MapSearchModule.cs54
-rw-r--r--OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs2
2 files changed, 39 insertions, 17 deletions
diff --git a/OpenSim/Region/CoreModules/World/WorldMap/MapSearchModule.cs b/OpenSim/Region/CoreModules/World/WorldMap/MapSearchModule.cs
index 14deeb6..1e5af1b 100644
--- a/OpenSim/Region/CoreModules/World/WorldMap/MapSearchModule.cs
+++ b/OpenSim/Region/CoreModules/World/WorldMap/MapSearchModule.cs
@@ -49,6 +49,18 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
49 List<Scene> m_scenes = new List<Scene>(); 49 List<Scene> m_scenes = new List<Scene>();
50 List<UUID> m_Clients; 50 List<UUID> m_Clients;
51 51
52 IWorldMapModule m_WorldMap;
53 IWorldMapModule WorldMap
54 {
55 get
56 {
57 if (m_WorldMap == null)
58 m_WorldMap = m_scene.RequestModuleInterface<IWorldMapModule>();
59 return m_WorldMap;
60 }
61
62 }
63
52 #region ISharedRegionModule Members 64 #region ISharedRegionModule Members
53 public void Initialise(IConfigSource source) 65 public void Initialise(IConfigSource source)
54 { 66 {
@@ -130,9 +142,16 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
130 { 142 {
131 Util.FireAndForget(x => 143 Util.FireAndForget(x =>
132 { 144 {
133 if (mapName.Length < 2) 145 List<MapBlockData> blocks = new List<MapBlockData>();
146 if (mapName.Length < 3 || (mapName.EndsWith("#") && mapName.Length < 4))
134 { 147 {
135 remoteClient.SendAlertMessage("Use a search string with at least 2 characters"); 148 // final block, closing the search result
149 AddFinalBlock(blocks);
150
151 // flags are agent flags sent from the viewer.
152 // they have different values depending on different viewers, apparently
153 remoteClient.SendMapBlock(blocks, flags);
154 remoteClient.SendAlertMessage("Use a search string with at least 3 characters");
136 return; 155 return;
137 } 156 }
138 157
@@ -160,8 +179,7 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
160 // remoteClient.SendAlertMessage("Hyperlink could not be established."); 179 // remoteClient.SendAlertMessage("Hyperlink could not be established.");
161 180
162 //m_log.DebugFormat("[MAPSEARCHMODULE]: search {0} returned {1} regions", mapName, regionInfos.Count); 181 //m_log.DebugFormat("[MAPSEARCHMODULE]: search {0} returned {1} regions", mapName, regionInfos.Count);
163 List<MapBlockData> blocks = new List<MapBlockData>(); 182
164
165 MapBlockData data; 183 MapBlockData data;
166 if (regionInfos.Count > 0) 184 if (regionInfos.Count > 0)
167 { 185 {
@@ -171,9 +189,22 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
171 data.Agents = 0; 189 data.Agents = 0;
172 data.Access = info.Access; 190 data.Access = info.Access;
173 if (flags == 2) // V2 sends this 191 if (flags == 2) // V2 sends this
174 data.MapImageId = UUID.Zero; 192 {
193 List<MapBlockData> datas = WorldMap.Map2BlockFromGridRegion(info, flags);
194 // ugh! V2-3 is very sensitive about the result being
195 // exactly the same as the requested name
196
197 if (regionInfos.Count == 1 && (mapName != mapNameOrig))
198 datas.ForEach(d => d.Name = mapNameOrig);
199
200 blocks.AddRange(datas);
201 }
175 else 202 else
176 data.MapImageId = info.TerrainImage; 203 {
204 MapBlockData block = new MapBlockData();
205 WorldMap.MapBlockFromGridRegion(block,info, flags);
206 blocks.Add(block);
207 }
177 // ugh! V2-3 is very sensitive about the result being 208 // ugh! V2-3 is very sensitive about the result being
178 // exactly the same as the requested name 209 // exactly the same as the requested name
179 if (regionInfos.Count == 1 && mapNameOrig.Contains("|") || mapNameOrig.Contains("+")) 210 if (regionInfos.Count == 1 && mapNameOrig.Contains("|") || mapNameOrig.Contains("+"))
@@ -189,16 +220,7 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
189 } 220 }
190 221
191 // final block, closing the search result 222 // final block, closing the search result
192 data = new MapBlockData(); 223 AddFinalBlock(blocks);
193 data.Agents = 0;
194 data.Access = 255;
195 data.MapImageId = UUID.Zero;
196 data.Name = mapName;
197 data.RegionFlags = 0;
198 data.WaterHeight = 0; // not used
199 data.X = 0;
200 data.Y = 0;
201 blocks.Add(data);
202 224
203 // flags are agent flags sent from the viewer. 225 // flags are agent flags sent from the viewer.
204 // they have different values depending on different viewers, apparently 226 // they have different values depending on different viewers, apparently
diff --git a/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs b/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs
index 59529d8..31b1c35 100644
--- a/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs
+++ b/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs
@@ -1143,7 +1143,7 @@ namespace OpenSim.Region.CoreModules.World.WorldMap
1143 return allBlocks; 1143 return allBlocks;
1144 } 1144 }
1145 1145
1146 protected void MapBlockFromGridRegion(MapBlockData block, GridRegion r, uint flag) 1146 public void MapBlockFromGridRegion(MapBlockData block, GridRegion r, uint flag)
1147 { 1147 {
1148 block.Access = r.Access; 1148 block.Access = r.Access;
1149 switch (flag & 0xffff) 1149 switch (flag & 0xffff)