forked from mirrors/NBTExplorer
More preparation towards refactoring
This commit is contained in:
parent
c8cdf32eb2
commit
0f1c6970c9
6 changed files with 292 additions and 15 deletions
|
@ -653,12 +653,12 @@ namespace Substrate
|
||||||
cc.SetBlockSkyLight(x, y, z, dimStr);
|
cc.SetBlockSkyLight(x, y, z, dimStr);
|
||||||
|
|
||||||
if (info.TransmitsLight) {
|
if (info.TransmitsLight) {
|
||||||
spread.Enqueue(new LightRecord(rec.x - 1, rec.y, rec.z, dimStr - 1));
|
/*spread.Enqueue(new LightRecord(rec.x - 1, rec.y, rec.z, dimStr - 1));
|
||||||
spread.Enqueue(new LightRecord(rec.x + 1, rec.y, rec.z, dimStr - 1));
|
spread.Enqueue(new LightRecord(rec.x + 1, rec.y, rec.z, dimStr - 1));
|
||||||
spread.Enqueue(new LightRecord(rec.x, rec.y - 1, rec.z, dimStr - 1));
|
spread.Enqueue(new LightRecord(rec.x, rec.y - 1, rec.z, dimStr - 1));
|
||||||
spread.Enqueue(new LightRecord(rec.x, rec.y + 1, rec.z, dimStr - 1));
|
spread.Enqueue(new LightRecord(rec.x, rec.y + 1, rec.z, dimStr - 1));
|
||||||
spread.Enqueue(new LightRecord(rec.x, rec.y, rec.z - 1, dimStr - 1));
|
spread.Enqueue(new LightRecord(rec.x, rec.y, rec.z - 1, dimStr - 1));
|
||||||
spread.Enqueue(new LightRecord(rec.x, rec.y, rec.z + 1, dimStr - 1));
|
spread.Enqueue(new LightRecord(rec.x, rec.y, rec.z + 1, dimStr - 1));*/
|
||||||
|
|
||||||
if (heightMap[xi, zi] > rec.y - 1) {
|
if (heightMap[xi, zi] > rec.y - 1) {
|
||||||
spread.Enqueue(new LightRecord(rec.x, rec.y - 1, rec.z, dimStr - 1));
|
spread.Enqueue(new LightRecord(rec.x, rec.y - 1, rec.z, dimStr - 1));
|
||||||
|
|
168
Substrate/SubstrateCS/Source/Utility/ByteArray.cs
Normal file
168
Substrate/SubstrateCS/Source/Utility/ByteArray.cs
Normal file
|
@ -0,0 +1,168 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace Substrate.Utility
|
||||||
|
{
|
||||||
|
public class ByteArray : ICopyable<ByteArray>
|
||||||
|
{
|
||||||
|
protected readonly byte[] _data;
|
||||||
|
|
||||||
|
public ByteArray (byte[] data)
|
||||||
|
{
|
||||||
|
_data = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
public byte this[int i]
|
||||||
|
{
|
||||||
|
get { return _data[i]; }
|
||||||
|
set { _data[i] = value; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public int Length
|
||||||
|
{
|
||||||
|
get { return _data.Length; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Clear ()
|
||||||
|
{
|
||||||
|
for (int i = 0; i < _data.Length; i++)
|
||||||
|
{
|
||||||
|
_data[i] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#region ICopyable<yteArray> Members
|
||||||
|
|
||||||
|
public virtual ByteArray Copy ()
|
||||||
|
{
|
||||||
|
byte[] data = new byte[_data.Length];
|
||||||
|
_data.CopyTo(data, 0);
|
||||||
|
|
||||||
|
return new ByteArray(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
|
||||||
|
public sealed class XZYByteArray : ByteArray
|
||||||
|
{
|
||||||
|
private readonly int _xdim;
|
||||||
|
private readonly int _ydim;
|
||||||
|
private readonly int _zdim;
|
||||||
|
|
||||||
|
private readonly byte[] _data;
|
||||||
|
|
||||||
|
public XZYByteArray (int xdim, int ydim, int zdim, byte[] data)
|
||||||
|
: base(data)
|
||||||
|
{
|
||||||
|
_xdim = xdim;
|
||||||
|
_ydim = ydim;
|
||||||
|
_zdim = zdim;
|
||||||
|
|
||||||
|
if (xdim * ydim * zdim != data.Length)
|
||||||
|
{
|
||||||
|
throw new ArgumentException("Product of dimensions must equal length of data");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public byte this[int x, int y, int z]
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
int index = _ydim * (x * _zdim + z) + y;
|
||||||
|
return _data[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
int index = _ydim * (x * _zdim + z) + y;
|
||||||
|
_data[index] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int XDim
|
||||||
|
{
|
||||||
|
get { return _xdim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public int YDim
|
||||||
|
{
|
||||||
|
get { return _ydim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public int ZDim
|
||||||
|
{
|
||||||
|
get { return _zdim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
#region ICopyable<XZYByteArray> Members
|
||||||
|
|
||||||
|
public override ByteArray Copy ()
|
||||||
|
{
|
||||||
|
byte[] data = new byte[_data.Length];
|
||||||
|
_data.CopyTo(data, 0);
|
||||||
|
|
||||||
|
return new XZYByteArray(_xdim, _ydim, _zdim, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
|
||||||
|
public sealed class ZXByteArray : ByteArray
|
||||||
|
{
|
||||||
|
private readonly int _xdim;
|
||||||
|
private readonly int _zdim;
|
||||||
|
|
||||||
|
private readonly byte[] _data;
|
||||||
|
|
||||||
|
public ZXByteArray (int xdim, int zdim, byte[] data)
|
||||||
|
: base(data)
|
||||||
|
{
|
||||||
|
_xdim = xdim;
|
||||||
|
_zdim = zdim;
|
||||||
|
|
||||||
|
if (xdim * zdim != data.Length)
|
||||||
|
{
|
||||||
|
throw new ArgumentException("Product of dimensions must equal length of data");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public byte this[int x, int z]
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
int index = z * _xdim + x;
|
||||||
|
return _data[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
int index = z * _xdim + x;
|
||||||
|
_data[index] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int XDim
|
||||||
|
{
|
||||||
|
get { return _xdim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public int ZDim
|
||||||
|
{
|
||||||
|
get { return _zdim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
#region ICopyable<ZXByteArray> Members
|
||||||
|
|
||||||
|
public override ByteArray Copy ()
|
||||||
|
{
|
||||||
|
byte[] data = new byte[_data.Length];
|
||||||
|
_data.CopyTo(data, 0);
|
||||||
|
|
||||||
|
return new ZXByteArray(_xdim, _zdim, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,7 +4,7 @@ using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Substrate.Utility
|
namespace Substrate.Utility
|
||||||
{
|
{
|
||||||
class IndexedLinkedList<T> : ICollection<T>, ICollection
|
public class IndexedLinkedList<T> : ICollection<T>, ICollection
|
||||||
{
|
{
|
||||||
private LinkedList<T> _list;
|
private LinkedList<T> _list;
|
||||||
private Dictionary<T, LinkedListNode<T>> _index;
|
private Dictionary<T, LinkedListNode<T>> _index;
|
||||||
|
@ -111,7 +111,7 @@ namespace Substrate.Utility
|
||||||
|
|
||||||
object ICollection.SyncRoot
|
object ICollection.SyncRoot
|
||||||
{
|
{
|
||||||
get { return this; }
|
get { return (_list as ICollection).SyncRoot; }
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
|
@ -4,8 +4,35 @@ using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Substrate.Utility
|
namespace Substrate.Utility
|
||||||
{
|
{
|
||||||
class LRUCache<TKey, TValue> : IDictionary<TKey, TValue>
|
|
||||||
|
public class LRUCache<TKey, TValue> : IDictionary<TKey, TValue>
|
||||||
{
|
{
|
||||||
|
public delegate void RemoveCacheValueHandler (Object o, CacheValueArgs e);
|
||||||
|
|
||||||
|
public class CacheValueArgs : EventArgs
|
||||||
|
{
|
||||||
|
private TKey _key;
|
||||||
|
private TValue _value;
|
||||||
|
|
||||||
|
public TKey Key
|
||||||
|
{
|
||||||
|
get { return _key; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public TValue Value
|
||||||
|
{
|
||||||
|
get { return _value; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public CacheValueArgs (TKey key, TValue value)
|
||||||
|
{
|
||||||
|
_key = key;
|
||||||
|
_value = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public event RemoveCacheValueHandler RemoveCacheValue;
|
||||||
|
|
||||||
private Dictionary<TKey, TValue> _data;
|
private Dictionary<TKey, TValue> _data;
|
||||||
private IndexedLinkedList<TKey> _index;
|
private IndexedLinkedList<TKey> _index;
|
||||||
|
|
||||||
|
@ -38,6 +65,8 @@ namespace Substrate.Utility
|
||||||
|
|
||||||
if (_data.Count > _capacity)
|
if (_data.Count > _capacity)
|
||||||
{
|
{
|
||||||
|
OnRemoveCacheValue(new CacheValueArgs(_index.First, _data[_index.First]));
|
||||||
|
|
||||||
_data.Remove(_index.First);
|
_data.Remove(_index.First);
|
||||||
_index.RemoveFirst();
|
_index.RemoveFirst();
|
||||||
}
|
}
|
||||||
|
@ -99,6 +128,8 @@ namespace Substrate.Utility
|
||||||
|
|
||||||
if (_data.Count > _capacity)
|
if (_data.Count > _capacity)
|
||||||
{
|
{
|
||||||
|
OnRemoveCacheValue(new CacheValueArgs(_index.First, _data[_index.First]));
|
||||||
|
|
||||||
_data.Remove(_index.First);
|
_data.Remove(_index.First);
|
||||||
_index.RemoveFirst();
|
_index.RemoveFirst();
|
||||||
}
|
}
|
||||||
|
@ -170,5 +201,14 @@ namespace Substrate.Utility
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
private void OnRemoveCacheValue (CacheValueArgs e)
|
||||||
|
{
|
||||||
|
if (RemoveCacheValue != null)
|
||||||
|
{
|
||||||
|
RemoveCacheValue(this, e);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Text;
|
|
||||||
|
|
||||||
namespace Substrate.Utility
|
namespace Substrate.Utility
|
||||||
{
|
{
|
||||||
|
|
||||||
public class NibbleArray : ICopyable<NibbleArray>
|
public class NibbleArray : ICopyable<NibbleArray>
|
||||||
{
|
{
|
||||||
protected readonly byte[] _data = null;
|
protected readonly byte[] _data = null;
|
||||||
|
@ -14,26 +14,30 @@ namespace Substrate.Utility
|
||||||
_data = data;
|
_data = data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int this[int index]
|
public byte this[int index]
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
int subs = index >> 1;
|
int subs = index >> 1;
|
||||||
if ((index & 1) == 0) {
|
if ((index & 1) == 0)
|
||||||
return _data[subs] & 0x0F;
|
{
|
||||||
|
return (byte)(_data[subs] & 0x0F);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
return (_data[subs] >> 4) & 0x0F;
|
{
|
||||||
|
return (byte)((_data[subs] >> 4) & 0x0F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
int subs = index >> 1;
|
int subs = index >> 1;
|
||||||
if ((index & 1) == 0) {
|
if ((index & 1) == 0)
|
||||||
|
{
|
||||||
_data[subs] = (byte)((_data[subs] & 0xF0) | (value & 0x0F));
|
_data[subs] = (byte)((_data[subs] & 0xF0) | (value & 0x0F));
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
_data[subs] = (byte)((_data[subs] & 0x0F) | ((value & 0x0F) << 4));
|
_data[subs] = (byte)((_data[subs] & 0x0F) | ((value & 0x0F) << 4));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -49,14 +53,15 @@ namespace Substrate.Utility
|
||||||
|
|
||||||
public void Clear ()
|
public void Clear ()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < _data.Length; i++) {
|
for (int i = 0; i < _data.Length; i++)
|
||||||
|
{
|
||||||
_data[i] = 0;
|
_data[i] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#region ICopyable<NibbleArray> Members
|
#region ICopyable<NibbleArray> Members
|
||||||
|
|
||||||
public NibbleArray Copy ()
|
public virtual NibbleArray Copy ()
|
||||||
{
|
{
|
||||||
byte[] data = new byte[_data.Length];
|
byte[] data = new byte[_data.Length];
|
||||||
_data.CopyTo(data, 0);
|
_data.CopyTo(data, 0);
|
||||||
|
@ -66,4 +71,66 @@ namespace Substrate.Utility
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public sealed class XZYNibbleArray : NibbleArray
|
||||||
|
{
|
||||||
|
private readonly int _xdim;
|
||||||
|
private readonly int _ydim;
|
||||||
|
private readonly int _zdim;
|
||||||
|
|
||||||
|
public XZYNibbleArray (int xdim, int ydim, int zdim, byte[] data)
|
||||||
|
: base(data)
|
||||||
|
{
|
||||||
|
_xdim = xdim;
|
||||||
|
_ydim = ydim;
|
||||||
|
_zdim = zdim;
|
||||||
|
|
||||||
|
if (xdim * ydim * zdim != data.Length / 2)
|
||||||
|
{
|
||||||
|
throw new ArgumentException("Product of dimensions must equal half length of raw data");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public byte this[int x, int y, int z]
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
int index = _ydim * (x * _zdim + z) + y;
|
||||||
|
return this[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
int index = _ydim * (x * _zdim + z) + y;
|
||||||
|
this[index] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int XDim
|
||||||
|
{
|
||||||
|
get { return _xdim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public int YDim
|
||||||
|
{
|
||||||
|
get { return _ydim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public int ZDim
|
||||||
|
{
|
||||||
|
get { return _zdim; }
|
||||||
|
}
|
||||||
|
|
||||||
|
#region ICopyable<NibbleArray> Members
|
||||||
|
|
||||||
|
public override NibbleArray Copy ()
|
||||||
|
{
|
||||||
|
byte[] data = new byte[_data.Length];
|
||||||
|
_data.CopyTo(data, 0);
|
||||||
|
|
||||||
|
return new XZYNibbleArray(_xdim, _ydim, _zdim, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,6 +72,7 @@
|
||||||
<None Include="Source\Experimental\BlockInterface.cs" />
|
<None Include="Source\Experimental\BlockInterface.cs" />
|
||||||
<Compile Include="Source\Entities\EntitySquid.cs" />
|
<Compile Include="Source\Entities\EntitySquid.cs" />
|
||||||
<None Include="Source\Experimental\Interface2.cs" />
|
<None Include="Source\Experimental\Interface2.cs" />
|
||||||
|
<Compile Include="Source\Experimental\BlockLight.cs" />
|
||||||
<Compile Include="Source\Level.cs" />
|
<Compile Include="Source\Level.cs" />
|
||||||
<Compile Include="Source\PlayerManager.cs" />
|
<Compile Include="Source\PlayerManager.cs" />
|
||||||
<Compile Include="Source\PlayerFile.cs" />
|
<Compile Include="Source\PlayerFile.cs" />
|
||||||
|
@ -139,6 +140,7 @@
|
||||||
<Compile Include="Source\TileEntity.cs" />
|
<Compile Include="Source\TileEntity.cs" />
|
||||||
<Compile Include="Source\TileEntityFactory.cs" />
|
<Compile Include="Source\TileEntityFactory.cs" />
|
||||||
<Compile Include="Source\Utility\Base.cs" />
|
<Compile Include="Source\Utility\Base.cs" />
|
||||||
|
<Compile Include="Source\Utility\ByteArray.cs" />
|
||||||
<Compile Include="Source\Utility\IndexedLinkedList.cs" />
|
<Compile Include="Source\Utility\IndexedLinkedList.cs" />
|
||||||
<Compile Include="Source\Utility\Interface.cs" />
|
<Compile Include="Source\Utility\Interface.cs" />
|
||||||
<Compile Include="Source\Utility\LRUCache.cs" />
|
<Compile Include="Source\Utility\LRUCache.cs" />
|
||||||
|
|
Loading…
Reference in a new issue