aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Framework')
-rw-r--r--OpenSim/Framework/TerrainData.cs177
-rw-r--r--OpenSim/Framework/WebUtil.cs4
2 files changed, 61 insertions, 120 deletions
diff --git a/OpenSim/Framework/TerrainData.cs b/OpenSim/Framework/TerrainData.cs
index 7b99427..233c39b 100644
--- a/OpenSim/Framework/TerrainData.cs
+++ b/OpenSim/Framework/TerrainData.cs
@@ -37,56 +37,6 @@ using log4net;
37 37
38namespace OpenSim.Framework 38namespace OpenSim.Framework
39{ 39{
40 public abstract class TerrainData
41 {
42 // Terrain always is a square
43 public int SizeX { get; protected set; }
44 public int SizeY { get; protected set; }
45 public int SizeZ { get; protected set; }
46
47 // A height used when the user doesn't specify anything
48 public const float DefaultTerrainHeight = 21f;
49
50 public abstract float this[int x, int y] { get; set; }
51 // Someday terrain will have caves
52 // at most holes :p
53 public abstract float this[int x, int y, int z] { get; set; }
54
55 public abstract bool IsTaintedAt(int xx, int yy);
56 public abstract bool IsTaintedAt(int xx, int yy, bool clearOnTest);
57 public abstract void TaintAllTerrain();
58 public abstract void ClearTaint();
59
60 public abstract void ClearLand();
61 public abstract void ClearLand(float height);
62
63 // Return a representation of this terrain for storing as a blob in the database.
64 // Returns 'true' to say blob was stored in the 'out' locations.
65 public abstract bool GetDatabaseBlob(out int DBFormatRevisionCode, out Array blob);
66
67 // Given a revision code and a blob from the database, create and return the right type of TerrainData.
68 // The sizes passed are the expected size of the region. The database info will be used to
69 // initialize the heightmap of that sized region with as much data is in the blob.
70 // Return created TerrainData or 'null' if unsuccessful.
71 public static TerrainData CreateFromDatabaseBlobFactory(int pSizeX, int pSizeY, int pSizeZ, int pFormatCode, byte[] pBlob)
72 {
73 // For the moment, there is only one implementation class
74 return new HeightmapTerrainData(pSizeX, pSizeY, pSizeZ, pFormatCode, pBlob);
75 }
76
77 // return a special compressed representation of the heightmap in ushort
78 public abstract float[] GetCompressedMap();
79 public abstract float CompressionFactor { get; }
80
81 public abstract float[] GetFloatsSerialized();
82 public abstract double[,] GetDoubles();
83
84 public abstract void GetPatchMinMax(int px, int py, out float zmin, out float zmax);
85 public abstract void GetPatchBlock(float[] block, int px, int py, float sub, float premult);
86
87 public abstract TerrainData Clone();
88 }
89
90 // The terrain is stored in the database as a blob with a 'revision' field. 40 // The terrain is stored in the database as a blob with a 'revision' field.
91 // Some implementations of terrain storage would fill the revision field with 41 // Some implementations of terrain storage would fill the revision field with
92 // the time the terrain was stored. When real revisions were added and this 42 // the time the terrain was stored. When real revisions were added and this
@@ -116,18 +66,37 @@ namespace OpenSim.Framework
116 RevisionHigh = 1234 66 RevisionHigh = 1234
117 } 67 }
118 68
119 // Version of terrain that is a heightmap. 69 public class TerrainData
120 // This should really be 'LLOptimizedHeightmapTerrainData' as it includes knowledge
121 // of 'patches' which are 16x16 terrain areas which can be sent separately to the viewer.
122 // The heighmap is kept as an array of ushorts. The ushort values are converted to
123 // and from floats by TerrainCompressionFactor.
124 public class HeightmapTerrainData : TerrainData
125 { 70 {
126 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 71 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
127 private static string LogHeader = "[HEIGHTMAP TERRAIN DATA]"; 72 private static string LogHeader = "[TERRAIN DATA]";
73
74 private float[,] m_heightmap;
75 // Remember subregions of the heightmap that has changed.
76 private bool[,] m_taint;
77
78 // legacy CompressionFactor
79 public float CompressionFactor { get; private set; }
128 80
129 // TerrainData.this[x, y] 81 // Terrain always is a square
130 public override float this[int x, int y] 82 public int SizeX { get; protected set; }
83 public int SizeY { get; protected set; }
84 public int SizeZ { get; protected set; }
85
86 // A height used when the user doesn't specify anything
87 public const float DefaultTerrainHeight = 21f;
88
89 // Given a revision code and a blob from the database, create and return the right type of TerrainData.
90 // The sizes passed are the expected size of the region. The database info will be used to
91 // initialize the heightmap of that sized region with as much data is in the blob.
92 // Return created TerrainData or 'null' if unsuccessful.
93 public static TerrainData CreateFromDatabaseBlobFactory(int pSizeX, int pSizeY, int pSizeZ, int pFormatCode, byte[] pBlob)
94 {
95 // For the moment, there is only one implementation class
96 return new TerrainData(pSizeX, pSizeY, pSizeZ, pFormatCode, pBlob);
97 }
98
99 public float this[int x, int y]
131 { 100 {
132 get { return m_heightmap[x, y]; } 101 get { return m_heightmap[x, y]; }
133 set 102 set
@@ -140,21 +109,18 @@ namespace OpenSim.Framework
140 } 109 }
141 } 110 }
142 111
143 // TerrainData.this[x, y, z] 112 public float this[int x, int y, int z]
144 public override float this[int x, int y, int z]
145 { 113 {
146 get { return this[x, y]; } 114 get { return this[x, y]; }
147 set { this[x, y] = value; } 115 set { this[x, y] = value; }
148 } 116 }
149 117
150 // TerrainData.ClearTaint 118 public void ClearTaint()
151 public override void ClearTaint()
152 { 119 {
153 SetAllTaint(false); 120 SetAllTaint(false);
154 } 121 }
155 122
156 // TerrainData.TaintAllTerrain 123 public void TaintAllTerrain()
157 public override void TaintAllTerrain()
158 { 124 {
159 SetAllTaint(true); 125 SetAllTaint(true);
160 } 126 }
@@ -166,13 +132,12 @@ namespace OpenSim.Framework
166 m_taint[ii, jj] = setting; 132 m_taint[ii, jj] = setting;
167 } 133 }
168 134
169 // TerrainData.ClearLand 135 public void ClearLand()
170 public override void ClearLand()
171 { 136 {
172 ClearLand(DefaultTerrainHeight); 137 ClearLand(DefaultTerrainHeight);
173 } 138 }
174 // TerrainData.ClearLand(float) 139
175 public override void ClearLand(float pHeight) 140 public void ClearLand(float pHeight)
176 { 141 {
177 for (int xx = 0; xx < SizeX; xx++) 142 for (int xx = 0; xx < SizeX; xx++)
178 for (int yy = 0; yy < SizeY; yy++) 143 for (int yy = 0; yy < SizeY; yy++)
@@ -182,7 +147,7 @@ namespace OpenSim.Framework
182 // Return 'true' of the patch that contains these region coordinates has been modified. 147 // Return 'true' of the patch that contains these region coordinates has been modified.
183 // Note that checking the taint clears it. 148 // Note that checking the taint clears it.
184 // There is existing code that relies on this feature. 149 // There is existing code that relies on this feature.
185 public override bool IsTaintedAt(int xx, int yy, bool clearOnTest) 150 public bool IsTaintedAt(int xx, int yy, bool clearOnTest)
186 { 151 {
187 int tx = xx / Constants.TerrainPatchSize; 152 int tx = xx / Constants.TerrainPatchSize;
188 int ty = yy / Constants.TerrainPatchSize; 153 int ty = yy / Constants.TerrainPatchSize;
@@ -195,41 +160,22 @@ namespace OpenSim.Framework
195 // Old form that clears the taint flag when we check it. 160 // Old form that clears the taint flag when we check it.
196 // ubit: this dangerus naming should be only check without clear 161 // ubit: this dangerus naming should be only check without clear
197 // keeping for old modules outthere 162 // keeping for old modules outthere
198 public override bool IsTaintedAt(int xx, int yy) 163 public bool IsTaintedAt(int xx, int yy)
199 { 164 {
200 return IsTaintedAt(xx, yy, true /* clearOnTest */); 165 return IsTaintedAt(xx, yy, true /* clearOnTest */);
201 } 166 }
202 167
203 // TerrainData.GetDatabaseBlob 168 // TerrainData.GetDatabaseBlob
204 // The user wants something to store in the database. 169 // The user wants something to store in the database.
205 public override bool GetDatabaseBlob(out int DBRevisionCode, out Array blob) 170 public bool GetDatabaseBlob(out int DBRevisionCode, out Array blob)
206 { 171 {
207 bool ret = false; 172 DBRevisionCode = (int)DBTerrainRevision.Variable2DGzip;
208/* save all as Variable2DGzip 173 blob = ToCompressedTerrainSerializationV2DGzip();
209 if (SizeX == Constants.RegionSize && SizeY == Constants.RegionSize) 174 return true;
210 {
211 DBRevisionCode = (int)DBTerrainRevision.Legacy256;
212 blob = ToLegacyTerrainSerialization();
213 ret = true;
214 }
215 else
216 {
217*/
218 DBRevisionCode = (int)DBTerrainRevision.Variable2DGzip;
219// DBRevisionCode = (int)DBTerrainRevision.Variable2D;
220 blob = ToCompressedTerrainSerializationV2DGzip();
221// blob = ToCompressedTerrainSerializationV2D();
222 ret = true;
223// }
224 return ret;
225 } 175 }
226 176
227 // TerrainData.CompressionFactor
228 private float m_compressionFactor = 100.0f;
229 public override float CompressionFactor { get { return m_compressionFactor; } }
230
231 // TerrainData.GetCompressedMap 177 // TerrainData.GetCompressedMap
232 public override float[] GetCompressedMap() 178 public float[] GetCompressedMap()
233 { 179 {
234 float[] newMap = new float[SizeX * SizeY]; 180 float[] newMap = new float[SizeX * SizeY];
235 181
@@ -241,19 +187,18 @@ namespace OpenSim.Framework
241 return newMap; 187 return newMap;
242 188
243 } 189 }
244 // TerrainData.Clone 190
245 public override TerrainData Clone() 191 public TerrainData Clone()
246 { 192 {
247 HeightmapTerrainData ret = new HeightmapTerrainData(SizeX, SizeY, SizeZ); 193 TerrainData ret = new TerrainData(SizeX, SizeY, SizeZ);
248 ret.m_heightmap = (float[,])this.m_heightmap.Clone(); 194 ret.m_heightmap = (float[,])this.m_heightmap.Clone();
249 return ret; 195 return ret;
250 } 196 }
251 197
252 // TerrainData.GetFloatsSerialized
253 // This one dimensional version is ordered so height = map[y*sizeX+x]; 198 // This one dimensional version is ordered so height = map[y*sizeX+x];
254 // DEPRECATED: don't use this function as it does not retain the dimensions of the terrain 199 // DEPRECATED: don't use this function as it does not retain the dimensions of the terrain
255 // and the caller will probably do the wrong thing if the terrain is not the legacy 256x256. 200 // and the caller will probably do the wrong thing if the terrain is not the legacy 256x256.
256 public override float[] GetFloatsSerialized() 201 public float[] GetFloatsSerialized()
257 { 202 {
258 int points = SizeX * SizeY; 203 int points = SizeX * SizeY;
259 float[] heights = new float[points]; 204 float[] heights = new float[points];
@@ -269,7 +214,7 @@ namespace OpenSim.Framework
269 } 214 }
270 215
271 // TerrainData.GetDoubles 216 // TerrainData.GetDoubles
272 public override double[,] GetDoubles() 217 public double[,] GetDoubles()
273 { 218 {
274 double[,] ret = new double[SizeX, SizeY]; 219 double[,] ret = new double[SizeX, SizeY];
275 for (int xx = 0; xx < SizeX; xx++) 220 for (int xx = 0; xx < SizeX; xx++)
@@ -279,7 +224,7 @@ namespace OpenSim.Framework
279 return ret; 224 return ret;
280 } 225 }
281 226
282 public override unsafe void GetPatchMinMax(int px, int py, out float zmin, out float zmax) 227 public unsafe void GetPatchMinMax(int px, int py, out float zmin, out float zmax)
283 { 228 {
284 zmax = float.MinValue; 229 zmax = float.MinValue;
285 zmin = float.MaxValue; 230 zmin = float.MaxValue;
@@ -304,7 +249,7 @@ namespace OpenSim.Framework
304 } 249 }
305 } 250 }
306 251
307 public override unsafe void GetPatchBlock(float[] _block, int px, int py, float sub, float premult) 252 public unsafe void GetPatchBlock(float[] _block, int px, int py, float sub, float premult)
308 { 253 {
309 int k = 0; 254 int k = 0;
310 int stride = m_heightmap.GetLength(1); 255 int stride = m_heightmap.GetLength(1);
@@ -324,13 +269,8 @@ namespace OpenSim.Framework
324 } 269 }
325 } 270 }
326 271
327 // ============================================================= 272/*
328 273 // that is coded as the float height times the compression factor (usually '100'
329 private float[,] m_heightmap;
330 // Remember subregions of the heightmap that has changed.
331 private bool[,] m_taint;
332
333 // that is coded as the float height times the compression factor (usually '100'
334 // to make for two decimal points). 274 // to make for two decimal points).
335 public short ToCompressedHeightshort(float pHeight) 275 public short ToCompressedHeightshort(float pHeight)
336 { 276 {
@@ -353,6 +293,7 @@ namespace OpenSim.Framework
353 return ushort.MaxValue; 293 return ushort.MaxValue;
354 return (ushort)pHeight; 294 return (ushort)pHeight;
355 } 295 }
296*/
356 297
357 public float FromCompressedHeight(short pHeight) 298 public float FromCompressedHeight(short pHeight)
358 { 299 {
@@ -366,12 +307,12 @@ namespace OpenSim.Framework
366 307
367 // To keep with the legacy theme, create an instance of this class based on the 308 // To keep with the legacy theme, create an instance of this class based on the
368 // way terrain used to be passed around. 309 // way terrain used to be passed around.
369 public HeightmapTerrainData(double[,] pTerrain) 310 public TerrainData(double[,] pTerrain)
370 { 311 {
371 SizeX = pTerrain.GetLength(0); 312 SizeX = pTerrain.GetLength(0);
372 SizeY = pTerrain.GetLength(1); 313 SizeY = pTerrain.GetLength(1);
373 SizeZ = (int)Constants.RegionHeight; 314 SizeZ = (int)Constants.RegionHeight;
374 m_compressionFactor = 100.0f; 315 CompressionFactor = 100.0f;
375 316
376 m_heightmap = new float[SizeX, SizeY]; 317 m_heightmap = new float[SizeX, SizeY];
377 for (int ii = 0; ii < SizeX; ii++) 318 for (int ii = 0; ii < SizeX; ii++)
@@ -389,12 +330,12 @@ namespace OpenSim.Framework
389 } 330 }
390 331
391 // Create underlying structures but don't initialize the heightmap assuming the caller will immediately do that 332 // Create underlying structures but don't initialize the heightmap assuming the caller will immediately do that
392 public HeightmapTerrainData(int pX, int pY, int pZ) 333 public TerrainData(int pX, int pY, int pZ)
393 { 334 {
394 SizeX = pX; 335 SizeX = pX;
395 SizeY = pY; 336 SizeY = pY;
396 SizeZ = pZ; 337 SizeZ = pZ;
397 m_compressionFactor = 100.0f; 338 CompressionFactor = 100.0f;
398 m_heightmap = new float[SizeX, SizeY]; 339 m_heightmap = new float[SizeX, SizeY];
399 m_taint = new bool[SizeX / Constants.TerrainPatchSize, SizeY / Constants.TerrainPatchSize]; 340 m_taint = new bool[SizeX / Constants.TerrainPatchSize, SizeY / Constants.TerrainPatchSize];
400 // m_log.DebugFormat("{0} new by dimensions. sizeX={1}, sizeY={2}, sizeZ={3}", LogHeader, SizeX, SizeY, SizeZ); 341 // m_log.DebugFormat("{0} new by dimensions. sizeX={1}, sizeY={2}, sizeZ={3}", LogHeader, SizeX, SizeY, SizeZ);
@@ -402,10 +343,10 @@ namespace OpenSim.Framework
402 ClearLand(0f); 343 ClearLand(0f);
403 } 344 }
404 345
405 public HeightmapTerrainData(float[] cmap, float pCompressionFactor, int pX, int pY, int pZ) 346 public TerrainData(float[] cmap, float pCompressionFactor, int pX, int pY, int pZ)
406 : this(pX, pY, pZ) 347 : this(pX, pY, pZ)
407 { 348 {
408 m_compressionFactor = pCompressionFactor; 349 CompressionFactor = pCompressionFactor;
409 int ind = 0; 350 int ind = 0;
410 for (int xx = 0; xx < SizeX; xx++) 351 for (int xx = 0; xx < SizeX; xx++)
411 for (int yy = 0; yy < SizeY; yy++) 352 for (int yy = 0; yy < SizeY; yy++)
@@ -414,7 +355,7 @@ namespace OpenSim.Framework
414 } 355 }
415 356
416 // Create a heighmap from a database blob 357 // Create a heighmap from a database blob
417 public HeightmapTerrainData(int pSizeX, int pSizeY, int pSizeZ, int pFormatCode, byte[] pBlob) 358 public TerrainData(int pSizeX, int pSizeY, int pSizeZ, int pFormatCode, byte[] pBlob)
418 : this(pSizeX, pSizeY, pSizeZ) 359 : this(pSizeX, pSizeY, pSizeZ)
419 { 360 {
420 switch ((DBTerrainRevision)pFormatCode) 361 switch ((DBTerrainRevision)pFormatCode)
@@ -589,7 +530,7 @@ namespace OpenSim.Framework
589 hmSizeY = br.ReadInt32(); 530 hmSizeY = br.ReadInt32();
590 hmCompressionFactor = br.ReadInt32(); 531 hmCompressionFactor = br.ReadInt32();
591 532
592 m_compressionFactor = hmCompressionFactor; 533 CompressionFactor = hmCompressionFactor;
593 534
594 // In case database info doesn't match real terrain size, initialize the whole terrain. 535 // In case database info doesn't match real terrain size, initialize the whole terrain.
595 ClearLand(); 536 ClearLand();
diff --git a/OpenSim/Framework/WebUtil.cs b/OpenSim/Framework/WebUtil.cs
index 417e1cf..131ae50 100644
--- a/OpenSim/Framework/WebUtil.cs
+++ b/OpenSim/Framework/WebUtil.cs
@@ -176,7 +176,7 @@ namespace OpenSim.Framework
176 LogOutgoingDetail(string.Format("RESPONSE {0}: ", reqnum), input); 176 LogOutgoingDetail(string.Format("RESPONSE {0}: ", reqnum), input);
177 } 177 }
178 178
179 public static OSDMap ServiceOSDRequest(string url, OSDMap data, string method, int timeout, bool compressed, bool rpc) 179 public static OSDMap ServiceOSDRequest(string url, OSDMap data, string method, int timeout, bool compressed, bool rpc, bool keepalive = false)
180 { 180 {
181 int reqnum = RequestNumber++; 181 int reqnum = RequestNumber++;
182 182
@@ -197,7 +197,7 @@ namespace OpenSim.Framework
197 HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); 197 HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
198 request.Method = method; 198 request.Method = method;
199 request.Timeout = timeout; 199 request.Timeout = timeout;
200 request.KeepAlive = false; 200 request.KeepAlive = keepalive;
201 request.MaximumAutomaticRedirections = 10; 201 request.MaximumAutomaticRedirections = 10;
202 request.ReadWriteTimeout = timeout / 2; 202 request.ReadWriteTimeout = timeout / 2;
203 request.Headers[OSHeaderRequestID] = reqnum.ToString(); 203 request.Headers[OSHeaderRequestID] = reqnum.ToString();