Enumerator bugfix, added BlockRef, interface improvements.

This commit is contained in:
Justin Aquadro 2011-03-28 02:28:25 +00:00
parent 77f0764013
commit fb25567713
13 changed files with 583 additions and 258 deletions

View file

@ -36,6 +36,18 @@ namespace NBToolkit
{ {
_chunkMan = bm._chunkMan; _chunkMan = bm._chunkMan;
} }
public virtual BlockRef GetBlockRef (int x, int y, int z)
{
if (x < MIN_X || x >= MAX_X)
return null;
if (y < MIN_Y || y >= MAX_Y)
return null;
if (z < MIN_Z || z >= MAX_Z)
return null;
return new BlockRef(this, x, y, z);
}
public virtual int GetBlockID (int x, int y, int z) public virtual int GetBlockID (int x, int y, int z)
{ {

View file

@ -0,0 +1,131 @@
using System;
using System.Collections.Generic;
using System.Text;
namespace NBToolkit
{
public class BlockRef
{
protected Chunk _chunk;
protected int _lx;
protected int _ly;
protected int _lz;
public int X
{
get
{
return _lx + (_chunk.X * BlockManager.CHUNK_XLEN);
}
}
public int Y
{
get
{
return _ly;
}
}
public int Z
{
get
{
return _lz + (_chunk.Z * BlockManager.CHUNK_ZLEN);
}
}
public int LocalX
{
get
{
return _lx;
}
}
public int LocalY
{
get
{
return _ly;
}
}
public int LocalZ
{
get
{
return _lz;
}
}
public int ID
{
get
{
return _chunk.GetBlockID(_lx, _ly, _lz);
}
set
{
_chunk.SetBlockID(_lx, _ly, _lz, value);
}
}
public int Data
{
get
{
return _chunk.GetBlockData(_lx, _ly, _lz);
}
set
{
_chunk.SetBlockData(_lx, _ly, _lz, value);
}
}
public int BlockLight
{
get
{
return _chunk.GetBlockLight(_lx, _ly, _lz);
}
set
{
_chunk.SetBlockLight(_lx, _ly, _lz, value);
}
}
public int SkyLight
{
get
{
return _chunk.GetSkyLight(_lx, _ly, _lz);
}
set
{
_chunk.SetSkyLight(_lx, _ly, _lz, value);
}
}
public BlockRef (BlockManager bm, int x, int y, int z)
{
_chunk = bm.GetChunk(x, y, z);
_lx = x - _chunk.X * BlockManager.CHUNK_XLEN;
_ly = y;
_lz = z - _chunk.Z * BlockManager.CHUNK_ZLEN;
}
public BlockRef (Chunk c, int lx, int ly, int lz)
{
_chunk = c;
_lx = lx;
_ly = ly;
_lz = lz;
}
}
}

View file

@ -13,23 +13,13 @@ namespace NBToolkit
protected NBT_Tree _nbt = null; protected NBT_Tree _nbt = null;
protected NBT_ByteArray _blocks = null; protected NBT_ByteArray _blocks = null;
protected NibbleArray _data = null; protected NibbleArray _data = null;
protected NibbleArray _blockLight = null;
protected NibbleArray _skyLight = null;
protected bool _dirty = false; protected bool _dirty = false;
protected ChunkManager _chunkMan; protected ChunkManager _chunkMan;
public Chunk (ChunkManager cm, int cx, int cz)
{
_chunkMan = cm;
_cx = cx;
_cz = cz;
Region r = cm.GetRegion(cx, cz);
if (r == null || !r.ChunkExists(LocalX, LocalZ)) {
throw new MissingChunkException();
}
}
public int X public int X
{ {
get get
@ -62,6 +52,18 @@ namespace NBToolkit
} }
} }
public Chunk (ChunkManager cm, int cx, int cz)
{
_chunkMan = cm;
_cx = cx;
_cz = cz;
Region r = cm.GetRegion(cx, cz);
if (r == null || !r.ChunkExists(LocalX, LocalZ)) {
throw new MissingChunkException();
}
}
public bool Save () public bool Save ()
{ {
if (_dirty) { if (_dirty) {
@ -108,27 +110,32 @@ namespace NBToolkit
return false; return false;
} }
public BlockRef GetBlockRef (int lx, int ly, int lz)
{
return new BlockRef(this, lx, ly, lz);
}
public int GetBlockID (int x, int y, int z) public int GetBlockID (int x, int y, int z)
{ {
if (_blocks == null) { if (_blocks == null) {
_blocks = GetTree().getRoot().findTagByName("Level").findTagByName("Blocks").value.toByteArray(); _blocks = GetTree().Root.FindTagByName("Level").FindTagByName("Blocks").value.toByteArray();
} }
return _blocks.data[x << 11 | z << 7 | y]; return _blocks.Data[x << 11 | z << 7 | y];
} }
public bool SetBlockID (int x, int y, int z, int id) public bool SetBlockID (int x, int y, int z, int id)
{ {
if (_blocks == null) { if (_blocks == null) {
_blocks = GetTree().getRoot().findTagByName("Level").findTagByName("Blocks").value.toByteArray(); _blocks = GetTree().Root.FindTagByName("Level").FindTagByName("Blocks").value.toByteArray();
} }
int index = x << 11 | z << 7 | y; int index = x << 11 | z << 7 | y;
if (_blocks.data[index] == id) { if (_blocks.Data[index] == id) {
return false; return false;
} }
_blocks.data[index] = (byte)id; _blocks.Data[index] = (byte)id;
MarkDirty(); MarkDirty();
return true; return true;
@ -137,12 +144,12 @@ namespace NBToolkit
public int CountBlockID (int id) public int CountBlockID (int id)
{ {
if (_blocks == null) { if (_blocks == null) {
_blocks = GetTree().getRoot().findTagByName("Level").findTagByName("Blocks").value.toByteArray(); _blocks = GetTree().Root.FindTagByName("Level").FindTagByName("Blocks").value.toByteArray();
} }
int c = 0; int c = 0;
for (int i = 0; i < _blocks.length; i++) { for (int i = 0; i < _blocks.Length; i++) {
if (_blocks.data[i] == id) { if (_blocks.Data[i] == id) {
c++; c++;
} }
} }
@ -153,7 +160,7 @@ namespace NBToolkit
public int GetBlockData (int x, int y, int z) public int GetBlockData (int x, int y, int z)
{ {
if (_data == null) { if (_data == null) {
_data = new NibbleArray(GetTree().getRoot().findTagByName("Level").findTagByName("Data").value.toByteArray().data); _data = new NibbleArray(GetTree().Root.FindTagByName("Level").FindTagByName("Data").value.toByteArray().Data);
} }
return _data[x << 11 | z << 7 | y]; return _data[x << 11 | z << 7 | y];
@ -162,7 +169,7 @@ namespace NBToolkit
public bool SetBlockData (int x, int y, int z, int data) public bool SetBlockData (int x, int y, int z, int data)
{ {
if (_data == null) { if (_data == null) {
_data = new NibbleArray(GetTree().getRoot().findTagByName("Level").findTagByName("Data").value.toByteArray().data); _data = new NibbleArray(GetTree().Root.FindTagByName("Level").FindTagByName("Data").value.toByteArray().Data);
} }
int index = x << 11 | z << 7 | y; int index = x << 11 | z << 7 | y;
@ -176,9 +183,61 @@ namespace NBToolkit
return true; return true;
} }
public int GetBlockLight (int x, int y, int z)
{
if (_blockLight == null) {
_blockLight = new NibbleArray(GetTree().Root.FindTagByName("Level").FindTagByName("BlockLight").value.toByteArray().Data);
}
return _blockLight[x << 11 | z << 7 | y];
}
public bool SetBlockLight (int x, int y, int z, int light)
{
if (_blockLight == null) {
_blockLight = new NibbleArray(GetTree().Root.FindTagByName("Level").FindTagByName("BlockLight").value.toByteArray().Data);
}
int index = x << 11 | z << 7 | y;
if (_blockLight[index] == light) {
return false;
}
_blockLight[index] = light;
MarkDirty();
return true;
}
public int GetSkyLight (int x, int y, int z)
{
if (_skyLight == null) {
_skyLight = new NibbleArray(GetTree().Root.FindTagByName("Level").FindTagByName("SkyLight").value.toByteArray().Data);
}
return _skyLight[x << 11 | z << 7 | y];
}
public bool SetSkyLight (int x, int y, int z, int light)
{
if (_skyLight == null) {
_skyLight = new NibbleArray(GetTree().Root.FindTagByName("Level").FindTagByName("SkyLight").value.toByteArray().Data);
}
int index = x << 11 | z << 7 | y;
if (_skyLight[index] == light) {
return false;
}
_skyLight[index] = light;
MarkDirty();
return true;
}
public bool IsPopulated () public bool IsPopulated ()
{ {
return GetTree().getRoot().findTagByName("Level").findTagByName("TerrainPopulated").value.toByte().data == 1; return GetTree().Root.FindTagByName("Level").FindTagByName("TerrainPopulated").value.toByte().Data == 1;
} }
protected bool MarkDirty () protected bool MarkDirty ()
@ -191,5 +250,25 @@ namespace NBToolkit
_chunkMan.MarkChunkDirty(this); _chunkMan.MarkChunkDirty(this);
return true; return true;
} }
public Chunk GetNorthNeighbor ()
{
return _chunkMan.GetChunk(_cx - 1, _cz);
}
public Chunk GetSouthNeighbor ()
{
return _chunkMan.GetChunk(_cx + 1, _cz);
}
public Chunk GetEastNeighbor ()
{
return _chunkMan.GetChunk(_cx, _cz - 1);
}
public Chunk GetWestNeighbor ()
{
return _chunkMan.GetChunk(_cx, _cz + 1);
}
} }
} }

View file

@ -48,6 +48,8 @@ namespace NBToolkit
protected Region _region; protected Region _region;
protected ChunkManager _cm; protected ChunkManager _cm;
protected Chunk _chunk;
protected RegionEnumerator _enum = null; protected RegionEnumerator _enum = null;
protected int _x = 0; protected int _x = 0;
protected int _z = -1; protected int _z = -1;
@ -88,6 +90,7 @@ namespace NBToolkit
_region = _enum.Current; _region = _enum.Current;
} }
if (MoveNextInRegion()) { if (MoveNextInRegion()) {
_chunk = _cm.GetChunkInRegion(_region, _x, _z);
return true; return true;
} }
} }
@ -146,8 +149,7 @@ namespace NBToolkit
if (_x >= ChunkManager.REGION_XLEN) { if (_x >= ChunkManager.REGION_XLEN) {
throw new InvalidOperationException(); throw new InvalidOperationException();
} }
return _chunk;
return _cm.GetChunkInRegion(_region, _x, _z);
} }
} }
} }

View file

@ -31,15 +31,22 @@ namespace NBToolkit
{ {
ChunkKey k = new ChunkKey(cx, cz); ChunkKey k = new ChunkKey(cx, cz);
Chunk c = null;
WeakReference chunkref = null; WeakReference chunkref = null;
if (_cache.TryGetValue(k, out chunkref)) { if (_cache.TryGetValue(k, out chunkref)) {
return chunkref.Target as Chunk; c = chunkref.Target as Chunk;
}
else {
_cache.Add(k, new WeakReference(null));
} }
_cache.Add(k, new WeakReference(null)); if (c != null) {
return c;
}
try { try {
Chunk c = new Chunk(this, cx, cz); c = new Chunk(this, cx, cz);
_cache[k].Target = c; _cache[k].Target = c;
return c; return c;
} }

View file

@ -99,8 +99,11 @@ namespace NBToolkit
for (int iz = zStart; iz <= zEnd; iz++) { for (int iz = zStart; iz <= zEnd; iz++) {
double zThresh = (iz + 0.5D - zPos) / (fuzzXZ / 2.0D); double zThresh = (iz + 0.5D - zPos) / (fuzzXZ / 2.0D);
if (xThresh * xThresh + yThresh * yThresh + zThresh * zThresh < 1.0D) { if (xThresh * xThresh + yThresh * yThresh + zThresh * zThresh < 1.0D) {
blockMan.SetBlockID(ix, iy, iz, _blockId); BlockRef block = blockMan.GetBlockRef(ix, iy, iz);
blockMan.SetBlockData(ix, iy, iz, _blockData); if (block != null) {
block.ID = _blockId;
block.Data = _blockData;
}
} }
} }
} }

View file

@ -1,2 +1,2 @@
all: all:
gmcs -out:nbtoolkit.exe Program.cs NBT.cs Harness.cs TKOptions.cs NDesk/Options.cs TKFilter.cs Oregen.cs Replace.cs RegionFile.cs RegionFileCache.cs Zlib/Zlib.cs Zlib/ZlibStream.cs Zlib/ZlibConstants.cs Zlib/ZlibCodec.cs Zlib/ZlibBaseStream.cs Zlib/Tree.cs Zlib/InfTree.cs Zlib/Inflate.cs Zlib/GZipStream.cs Zlib/DeflateStream.cs Zlib/Deflate.cs Zlib/Crc32.cs gmcs -out:nbtoolkit.exe BlockRef.cs BlockManager.cs Chunk.cs ChunkEnumerator.cs ChunkFilter.cs ChunkKey.cs ChunkManager.cs FilteredChunkEnumerator.cs GenOres.cs MathHelper.cs NBT.cs NibbleArray.cs Oregen.cs Program.cs Purge.cs Region.cs RegionEnumerator.cs RegionFile.cs RegionKey.cs RegionManager.cs Replace.cs TKFilter.cs TKOptions.cs World.cs NDesk/Options.cs Zlib/Zlib.cs Zlib/ZlibStream.cs Zlib/ZlibConstants.cs Zlib/ZlibCodec.cs Zlib/ZlibBaseStream.cs Zlib/Tree.cs Zlib/InfTree.cs Zlib/Inflate.cs Zlib/GZipStream.cs Zlib/DeflateStream.cs Zlib/Deflate.cs Zlib/Crc32.cs

View file

@ -22,99 +22,301 @@ namespace NBT
TAG_COMPOUND = 10 TAG_COMPOUND = 10
} }
public class NBT_Value public abstract class NBT_Value
{ {
virtual public NBT_Byte toByte () { return null; } virtual public NBT_Byte toByte () { throw new InvalidCastException(); }
virtual public NBT_Short toShort () { return null; } virtual public NBT_Short toShort () { throw new InvalidCastException(); }
virtual public NBT_Int toInt () { return null; } virtual public NBT_Int toInt () { throw new InvalidCastException(); }
virtual public NBT_Long toLong () { return null; } virtual public NBT_Long toLong () { throw new InvalidCastException(); }
virtual public NBT_Float toFloat () { return null; } virtual public NBT_Float toFloat () { throw new InvalidCastException(); }
virtual public NBT_Double toDouble () { return null; } virtual public NBT_Double toDouble () { throw new InvalidCastException(); }
virtual public NBT_ByteArray toByteArray () { return null; } virtual public NBT_ByteArray toByteArray () { throw new InvalidCastException(); }
virtual public NBT_String toString () { return null; } virtual public NBT_String toString () { throw new InvalidCastException(); }
virtual public NBT_List toList () { return null; } virtual public NBT_List toList () { throw new InvalidCastException(); }
virtual public NBT_Compound toCompound () { return null; } virtual public NBT_Compound toCompound () { throw new InvalidCastException(); }
virtual public NBT_Type getType () { return NBT_Type.TAG_END; } virtual public NBT_Type getType () { return NBT_Type.TAG_END; }
} }
public abstract class NBT_NumericValue : NBT_Value
{
}
public class NBT_Byte : NBT_Value public class NBT_Byte : NBT_Value
{ {
public byte data = 0; protected byte _data = 0;
override public NBT_Byte toByte () { return this; } override public NBT_Byte toByte () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_BYTE; } override public NBT_Type getType () { return NBT_Type.TAG_BYTE; }
public byte Data
{
get { return _data; }
set { _data = value; }
}
public NBT_Byte () { }
public NBT_Byte (byte d)
{
_data = d;
}
} }
public class NBT_Short : NBT_Value public class NBT_Short : NBT_Value
{ {
public short data = 0; protected short _data = 0;
override public NBT_Short toShort () { return this; } override public NBT_Short toShort () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_SHORT; } override public NBT_Type getType () { return NBT_Type.TAG_SHORT; }
public short Data
{
get { return _data; }
set { _data = value; }
}
public NBT_Short () { }
public NBT_Short (short d)
{
_data = d;
}
} }
public class NBT_Int : NBT_Value public class NBT_Int : NBT_Value
{ {
public int data = 0; protected int _data = 0;
override public NBT_Int toInt () { return this; } override public NBT_Int toInt () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_INT; } override public NBT_Type getType () { return NBT_Type.TAG_INT; }
public int Data
{
get { return _data; }
set { _data = value; }
}
public NBT_Int () { }
public NBT_Int (int d)
{
_data = d;
}
} }
public class NBT_Long : NBT_Value public class NBT_Long : NBT_Value
{ {
public long data = 0; protected long _data = 0;
override public NBT_Long toLong () { return this; } override public NBT_Long toLong () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_LONG; } override public NBT_Type getType () { return NBT_Type.TAG_LONG; }
public long Data
{
get { return _data; }
set { _data = value; }
}
public NBT_Long () { }
public NBT_Long (long d)
{
_data = d;
}
} }
public class NBT_Float : NBT_Value public class NBT_Float : NBT_Value
{ {
public float data = 0; protected float _data = 0;
override public NBT_Float toFloat () { return this; } override public NBT_Float toFloat () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_FLOAT; } override public NBT_Type getType () { return NBT_Type.TAG_FLOAT; }
public float Data
{
get { return _data; }
set { _data = value; }
}
public NBT_Float () { }
public NBT_Float (float d)
{
_data = d;
}
} }
public class NBT_Double : NBT_Value public class NBT_Double : NBT_Value
{ {
public double data = 0; protected double _data = 0;
override public NBT_Double toDouble () { return this; } override public NBT_Double toDouble () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_DOUBLE; } override public NBT_Type getType () { return NBT_Type.TAG_DOUBLE; }
public double Data
{
get { return _data; }
set { _data = value; }
}
public NBT_Double () { }
public NBT_Double (double d)
{
_data = d;
}
} }
public class NBT_ByteArray : NBT_Value public class NBT_ByteArray : NBT_Value
{ {
public int length = 0; protected byte[] _data = null;
public byte[] data = null;
override public NBT_ByteArray toByteArray () { return this; } override public NBT_ByteArray toByteArray () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_BYTE_ARRAY; } override public NBT_Type getType () { return NBT_Type.TAG_BYTE_ARRAY; }
public byte[] Data
{
get { return _data; }
set { _data = value; }
}
public int Length
{
get { return _data.Length; }
}
public NBT_ByteArray () { }
public NBT_ByteArray (byte[] d)
{
_data = d;
}
} }
public class NBT_String : NBT_Value public class NBT_String : NBT_Value
{ {
public String data = null; protected string _data = null;
override public NBT_String toString () { return this; } override public NBT_String toString () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_STRING; } override public NBT_Type getType () { return NBT_Type.TAG_STRING; }
public string Data
{
get { return _data; }
set { _data = value; }
}
public int Length
{
get { return _data.Length; }
}
public NBT_String () { }
public NBT_String (string d)
{
_data = d;
}
} }
public class NBT_List : NBT_Value public class NBT_List : NBT_Value
{ {
public int length = 0; protected NBT_Type _type = NBT_Type.TAG_END;
public NBT_Type type = NBT_Type.TAG_END;
public List<NBT_Value> items = null; protected List<NBT_Value> _items = null;
override public NBT_List toList () { return this; } override public NBT_List toList () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_LIST; } override public NBT_Type getType () { return NBT_Type.TAG_LIST; }
public int Count
{
get { return _items.Count; }
}
public List<NBT_Value> Items
{
get { return _items; }
}
public NBT_Type ValueType
{
get { return _type; }
}
public NBT_List (NBT_Type type) {
_type = type;
_items = new List<NBT_Value>();
}
public NBT_List (NBT_Type type, List<NBT_Value> items)
{
_type = type;
_items = items;
}
public void AddItem (NBT_Value val)
{
if (_type != val.getType()) {
throw new InvalidValueException();
}
_items.Add(val);
}
public bool RemoveItem (NBT_Value val)
{
return _items.Remove(val);
}
} }
public class NBT_Compound : NBT_Value public class NBT_Compound : NBT_Value
{ {
public int length = 0; protected List<NBT_Tag> _tags = null;
public List<NBT_Tag> tags = null;
override public NBT_Compound toCompound () { return this; } override public NBT_Compound toCompound () { return this; }
override public NBT_Type getType () { return NBT_Type.TAG_COMPOUND; } override public NBT_Type getType () { return NBT_Type.TAG_COMPOUND; }
public int Count
{
get { return _tags.Count; }
}
public List<NBT_Tag> Tags
{
get { return _tags; }
}
public NBT_Compound () {
_tags = new List<NBT_Tag>();
}
public NBT_Compound (List<NBT_Tag> tags)
{
_tags = tags;
}
public void AddTag (NBT_Tag sub)
{
_tags.Add(sub);
}
public bool RemoveTag (NBT_Tag sub)
{
return _tags.Remove(sub);
}
public NBT_Tag FindTagByName (string name)
{
foreach (NBT_Tag tag in _tags) {
if (tag.name.Data == name) {
return tag;
}
}
return null;
}
} }
public class NBT_Tag public class NBT_Tag
@ -124,19 +326,13 @@ namespace NBT
public NBT_Value value; public NBT_Value value;
public NBT_Tag findTagByName (String name) public NBT_Tag FindTagByName (string name)
{ {
if (type != NBT_Type.TAG_COMPOUND) { if (type != NBT_Type.TAG_COMPOUND) {
return null; throw new InvalidTagException();
} }
foreach (NBT_Tag tag in value.toCompound().tags) { return value.toCompound().FindTagByName(name);
if (tag.name.data.Equals(name)) {
return tag;
}
}
return null;
} }
} }
@ -144,9 +340,7 @@ namespace NBT
{ {
private Stream stream = null; private Stream stream = null;
//String path = null; protected NBT_Tag _root = null;
NBT_Tag root = null;
public NBT_Tree (Stream s) public NBT_Tree (Stream s)
{ {
@ -157,7 +351,7 @@ namespace NBT
{ {
if (s != null) { if (s != null) {
stream = s; stream = s;
root = ReadTag(); _root = ReadTag();
stream = null; stream = null;
} }
} }
@ -167,76 +361,19 @@ namespace NBT
if (s != null) { if (s != null) {
stream = s; stream = s;
if (root != null) { if (_root != null) {
WriteTag(root); WriteTag(_root);
} }
stream = null; stream = null;
} }
} }
/*public void activate () public NBT_Tag Root
{ {
if (root == null) { get { return _root; }
read();
}
} }
public void deactivate ()
{
if (root != null) {
root = null;
}
}
public void save ()
{
if (root != null) {
write();
}
}*/
public NBT_Tag getRoot ()
{
return root;
}
/*public void addListItem (NBT_Tag tag, NBT_Value val)
{
if (tag.type != NBT_Type.TAG_LIST) {
throw new Exception();
}
if (tag.value.toList().type != val.getType()) {
throw new Exception();
}
val.toList().length++;
val.toList().items.Add(val);
}
public void addTag (NBT_Tag tag, NBT_Tag sub)
{
if (tag.type != NBT_Type.TAG_COMPOUND) {
throw new Exception();
}
tag.value.toCompound().length++;
tag.value.toCompound().tags.Add(sub);
}*/
/*private void read ()
{
FileStream fStream = new FileStream(path, System.IO.FileMode.Open);
gzStream = new GZipStream(fStream, CompressionMode.Decompress);
root = readTag();
gzStream.Close();
gzStream = null;
}*/
private NBT_Value ReadValue (NBT_Type type) private NBT_Value ReadValue (NBT_Type type)
{ {
switch (type) { switch (type) {
@ -279,25 +416,18 @@ namespace NBT
private NBT_Value ReadByte () private NBT_Value ReadByte ()
{ {
//Console.Write("NBT_File.readByte()");
int gzByte = stream.ReadByte(); int gzByte = stream.ReadByte();
if (gzByte == -1) { if (gzByte == -1) {
throw new NBTException(NBTException.MSG_GZIP_ENDOFSTREAM); throw new NBTException(NBTException.MSG_GZIP_ENDOFSTREAM);
} }
NBT_Byte val = new NBT_Byte(); NBT_Byte val = new NBT_Byte((byte)gzByte);
val.data = (byte)gzByte;
//Console.WriteLine(" [" + val.data + "]");
return val; return val;
} }
private NBT_Value ReadShort () private NBT_Value ReadShort ()
{ {
//Console.Write("NBT_File.readShort");
byte[] gzBytes = new byte[2]; byte[] gzBytes = new byte[2];
stream.Read(gzBytes, 0, 2); stream.Read(gzBytes, 0, 2);
@ -305,18 +435,13 @@ namespace NBT
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
NBT_Short val = new NBT_Short(); NBT_Short val = new NBT_Short(BitConverter.ToInt16(gzBytes, 0));
val.data = BitConverter.ToInt16(gzBytes, 0);
//Console.WriteLine(" [" + val.data + "]");
return val; return val;
} }
private NBT_Value ReadInt () private NBT_Value ReadInt ()
{ {
//Console.Write("NBT_File.readInt");
byte[] gzBytes = new byte[4]; byte[] gzBytes = new byte[4];
stream.Read(gzBytes, 0, 4); stream.Read(gzBytes, 0, 4);
@ -324,18 +449,13 @@ namespace NBT
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
NBT_Int val = new NBT_Int(); NBT_Int val = new NBT_Int(BitConverter.ToInt32(gzBytes, 0));
val.data = BitConverter.ToInt32(gzBytes, 0);
//Console.WriteLine(" [" + val.data + "]");
return val; return val;
} }
private NBT_Value ReadLong () private NBT_Value ReadLong ()
{ {
//Console.Write("NBT_File.readLong");
byte[] gzBytes = new byte[8]; byte[] gzBytes = new byte[8];
stream.Read(gzBytes, 0, 8); stream.Read(gzBytes, 0, 8);
@ -343,18 +463,13 @@ namespace NBT
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
NBT_Long val = new NBT_Long(); NBT_Long val = new NBT_Long(BitConverter.ToInt64(gzBytes, 0));
val.data = BitConverter.ToInt64(gzBytes, 0);
//Console.WriteLine(" [" + val.data + "]");
return val; return val;
} }
private NBT_Value ReadFloat () private NBT_Value ReadFloat ()
{ {
//Console.Write("NBT_File.readFloat()");
byte[] gzBytes = new byte[4]; byte[] gzBytes = new byte[4];
stream.Read(gzBytes, 0, 4); stream.Read(gzBytes, 0, 4);
@ -362,18 +477,13 @@ namespace NBT
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
NBT_Float val = new NBT_Float(); NBT_Float val = new NBT_Float(BitConverter.ToSingle(gzBytes, 0));
val.data = BitConverter.ToSingle(gzBytes, 0);
//Console.WriteLine(" [" + val.data + "]");
return val; return val;
} }
private NBT_Value ReadDouble () private NBT_Value ReadDouble ()
{ {
//Console.Write("NBT_File.readDouble()");
byte[] gzBytes = new byte[8]; byte[] gzBytes = new byte[8];
stream.Read(gzBytes, 0, 8); stream.Read(gzBytes, 0, 8);
@ -381,18 +491,13 @@ namespace NBT
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
NBT_Double val = new NBT_Double(); NBT_Double val = new NBT_Double(BitConverter.ToDouble(gzBytes, 0));
val.data = BitConverter.ToDouble(gzBytes, 0);
//Console.WriteLine(" [" + val.data + "]");
return val; return val;
} }
private NBT_Value ReadByteArray () private NBT_Value ReadByteArray ()
{ {
//Console.Write("NBT_File.readByteArray()");
byte[] lenBytes = new byte[4]; byte[] lenBytes = new byte[4];
stream.Read(lenBytes, 0, 4); stream.Read(lenBytes, 0, 4);
@ -400,25 +505,21 @@ namespace NBT
Array.Reverse(lenBytes); Array.Reverse(lenBytes);
} }
NBT_ByteArray val = new NBT_ByteArray(); int length = BitConverter.ToInt32(lenBytes, 0);
val.length = BitConverter.ToInt32(lenBytes, 0); if (length < 0) {
if (val.length < 0) {
throw new NBTException(NBTException.MSG_READ_NEG); throw new NBTException(NBTException.MSG_READ_NEG);
} }
//Console.WriteLine(" [" + val.length + "]"); byte[] data = new byte[length];
stream.Read(data, 0, length);
val.data = new byte[val.length]; NBT_ByteArray val = new NBT_ByteArray(data);
stream.Read(val.data, 0, val.length);
return val; return val;
} }
private NBT_Value ReadString () private NBT_Value ReadString ()
{ {
//Console.Write("NBT_File.readString()");
byte[] lenBytes = new byte[2]; byte[] lenBytes = new byte[2];
stream.Read(lenBytes, 0, 2); stream.Read(lenBytes, 0, 2);
@ -436,26 +537,20 @@ namespace NBT
System.Text.Encoding str = Encoding.GetEncoding(28591); System.Text.Encoding str = Encoding.GetEncoding(28591);
NBT_String val = new NBT_String(); NBT_String val = new NBT_String(str.GetString(strBytes));
val.data = str.GetString(strBytes);
//Console.WriteLine(" [" + val.data.ToString() + "]");
return val; return val;
} }
private NBT_Value ReadList () private NBT_Value ReadList ()
{ {
//Console.Write("NBT_File.readList()");
int gzByte = stream.ReadByte(); int gzByte = stream.ReadByte();
if (gzByte == -1) { if (gzByte == -1) {
throw new NBTException(NBTException.MSG_GZIP_ENDOFSTREAM); throw new NBTException(NBTException.MSG_GZIP_ENDOFSTREAM);
} }
NBT_List val = new NBT_List(); NBT_List val = new NBT_List((NBT_Type)gzByte);
val.type = (NBT_Type)gzByte; if (val.ValueType > (NBT_Type)Enum.GetValues(typeof(NBT_Type)).GetUpperBound(0)) {
if (val.type > (NBT_Type)Enum.GetValues(typeof(NBT_Type)).GetUpperBound(0)) {
throw new NBTException(NBTException.MSG_READ_TYPE); throw new NBTException(NBTException.MSG_READ_TYPE);
} }
@ -466,17 +561,13 @@ namespace NBT
Array.Reverse(lenBytes); Array.Reverse(lenBytes);
} }
val.length = BitConverter.ToInt32(lenBytes, 0); int length = BitConverter.ToInt32(lenBytes, 0);
if (val.length < 0) { if (length < 0) {
throw new NBTException(NBTException.MSG_READ_NEG); throw new NBTException(NBTException.MSG_READ_NEG);
} }
//Console.WriteLine(" [" + val.type + ", " + val.length + "]"); for (int i = 0; i < length; i++) {
val.AddItem(ReadValue(val.ValueType));
val.items = new List<NBT_Value>();
for (int i = 0; i < val.length; i++) {
val.items.Add(ReadValue(val.type));
} }
return val; return val;
@ -484,10 +575,7 @@ namespace NBT
private NBT_Value ReadCompound () private NBT_Value ReadCompound ()
{ {
//Console.WriteLine("NBT_File.readCompound()");
NBT_Compound val = new NBT_Compound(); NBT_Compound val = new NBT_Compound();
val.tags = new List<NBT_Tag>();
while (true) { while (true) {
NBT_Tag tag = ReadTag(); NBT_Tag tag = ReadTag();
@ -495,8 +583,7 @@ namespace NBT
break; break;
} }
val.length++; val.AddTag(tag);
val.tags.Add(tag);
} }
return val; return val;
@ -504,16 +591,12 @@ namespace NBT
private NBT_Tag ReadTag () private NBT_Tag ReadTag ()
{ {
//Console.Write("NBT_File.readTag()");
NBT_Tag tag = new NBT_Tag(); NBT_Tag tag = new NBT_Tag();
tag.type = (NBT_Type)stream.ReadByte(); tag.type = (NBT_Type)stream.ReadByte();
tag.name = null; tag.name = null;
tag.value = null; tag.value = null;
//Console.WriteLine(" [" + tag.type + "]");
if (tag.type != NBT_Type.TAG_END) { if (tag.type != NBT_Type.TAG_END) {
tag.name = ReadString().toString(); tag.name = ReadString().toString();
} }
@ -523,20 +606,6 @@ namespace NBT
return tag; return tag;
} }
/*private void write ()
{
if (root != null) {
FileStream fStream = new FileStream(path, System.IO.FileMode.Truncate);
stream = new GZipStream(fStream, CompressionMode.Compress);
writeTag(root);
stream.Close();
}
stream = null;
}*/
private void WriteValue (NBT_Value val) private void WriteValue (NBT_Value val)
{ {
switch (val.getType()) { switch (val.getType()) {
@ -587,15 +656,14 @@ namespace NBT
private void WriteByte (NBT_Byte val) private void WriteByte (NBT_Byte val)
{ {
stream.WriteByte(val.data); stream.WriteByte(val.Data);
} }
private void WriteShort (NBT_Short val) private void WriteShort (NBT_Short val)
{ {
byte[] gzBytes = BitConverter.GetBytes(val.data); byte[] gzBytes = BitConverter.GetBytes(val.Data);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//gzBytes.Reverse();
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
@ -604,10 +672,9 @@ namespace NBT
private void WriteInt (NBT_Int val) private void WriteInt (NBT_Int val)
{ {
byte[] gzBytes = BitConverter.GetBytes(val.data); byte[] gzBytes = BitConverter.GetBytes(val.Data);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//gzBytes.Reverse();
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
@ -616,10 +683,9 @@ namespace NBT
private void WriteLong (NBT_Long val) private void WriteLong (NBT_Long val)
{ {
byte[] gzBytes = BitConverter.GetBytes(val.data); byte[] gzBytes = BitConverter.GetBytes(val.Data);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//gzBytes.Reverse();
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
@ -628,10 +694,9 @@ namespace NBT
private void WriteFloat (NBT_Float val) private void WriteFloat (NBT_Float val)
{ {
byte[] gzBytes = BitConverter.GetBytes(val.data); byte[] gzBytes = BitConverter.GetBytes(val.Data);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//gzBytes.Reverse();
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
@ -640,10 +705,9 @@ namespace NBT
private void WriteDouble (NBT_Double val) private void WriteDouble (NBT_Double val)
{ {
byte[] gzBytes = BitConverter.GetBytes(val.data); byte[] gzBytes = BitConverter.GetBytes(val.Data);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//gzBytes.Reverse();
Array.Reverse(gzBytes); Array.Reverse(gzBytes);
} }
@ -652,54 +716,51 @@ namespace NBT
private void WriteByteArray (NBT_ByteArray val) private void WriteByteArray (NBT_ByteArray val)
{ {
byte[] lenBytes = BitConverter.GetBytes(val.length); byte[] lenBytes = BitConverter.GetBytes(val.Length);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//lenBytes.Reverse();
Array.Reverse(lenBytes); Array.Reverse(lenBytes);
} }
stream.Write(lenBytes, 0, 4); stream.Write(lenBytes, 0, 4);
stream.Write(val.data, 0, val.length); stream.Write(val.Data, 0, val.Length);
} }
private void WriteString (NBT_String val) private void WriteString (NBT_String val)
{ {
byte[] lenBytes = BitConverter.GetBytes((short)val.data.Length); byte[] lenBytes = BitConverter.GetBytes((short)val.Length);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//lenBytes.Reverse();
Array.Reverse(lenBytes); Array.Reverse(lenBytes);
} }
stream.Write(lenBytes, 0, 2); stream.Write(lenBytes, 0, 2);
System.Text.Encoding str = Encoding.GetEncoding(28591); System.Text.Encoding str = Encoding.GetEncoding(28591);
byte[] gzBytes = str.GetBytes(val.data); byte[] gzBytes = str.GetBytes(val.Data);
stream.Write(gzBytes, 0, gzBytes.Length); stream.Write(gzBytes, 0, gzBytes.Length);
} }
private void WriteList (NBT_List val) private void WriteList (NBT_List val)
{ {
byte[] lenBytes = BitConverter.GetBytes(val.length); byte[] lenBytes = BitConverter.GetBytes(val.Count);
if (BitConverter.IsLittleEndian) { if (BitConverter.IsLittleEndian) {
//lenBytes.Reverse();
Array.Reverse(lenBytes); Array.Reverse(lenBytes);
} }
stream.WriteByte((byte)val.type); stream.WriteByte((byte)val.ValueType);
stream.Write(lenBytes, 0, 4); stream.Write(lenBytes, 0, 4);
foreach (NBT_Value v in val.items) { foreach (NBT_Value v in val.Items) {
WriteValue(v); WriteValue(v);
} }
} }
private void WriteCompound (NBT_Compound val) private void WriteCompound (NBT_Compound val)
{ {
foreach (NBT_Tag t in val.tags) { foreach (NBT_Tag t in val.Tags) {
WriteTag(t); WriteTag(t);
} }
@ -720,7 +781,7 @@ namespace NBT
} }
} }
class NBTException : Exception public class NBTException : Exception
{ {
public const String MSG_GZIP_ENDOFSTREAM = "Gzip Error: Unexpected end of stream"; public const String MSG_GZIP_ENDOFSTREAM = "Gzip Error: Unexpected end of stream";
@ -733,4 +794,8 @@ namespace NBT
public NBTException (String msg, Exception innerException) : base(msg, innerException) { } public NBTException (String msg, Exception innerException) : base(msg, innerException) { }
} }
public class InvalidTagException : Exception { }
public class InvalidValueException : Exception { }
} }

View file

@ -54,6 +54,7 @@
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Compile Include="BlockManager.cs" /> <Compile Include="BlockManager.cs" />
<Compile Include="BlockRef.cs" />
<Compile Include="Chunk.cs" /> <Compile Include="Chunk.cs" />
<Compile Include="ChunkEnumerator.cs" /> <Compile Include="ChunkEnumerator.cs" />
<Compile Include="ChunkFilter.cs" /> <Compile Include="ChunkFilter.cs" />

View file

@ -1,9 +1,9 @@
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> <Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
<StartArguments>oregen -w "E:\temp\worlds\testsave2" -b 112 -r 5 -s 5 -mindepth 1 -maxdepth 127 -oi 1 -d 2 -v</StartArguments> <StartArguments>oregen -w "F:\Minecraft\tps - Copy" -b 15 --chunkinclude=35 -vv --MaxDepth=75 --MinDepth=67</StartArguments>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
<StartArguments>oregen -w "E:\temp\worlds\testsave2" -b 112 -r 5 -s 5 -mindepth 1 -maxdepth 127 -oi 1 -d 2 -v</StartArguments> <StartArguments>oregen -w "F:\Minecraft\tps - Copy" -b 15 --chunkinclude=35 -vv --MaxDepth=75 --MinDepth=67</StartArguments>
</PropertyGroup> </PropertyGroup>
<PropertyGroup> <PropertyGroup>
<PublishUrlHistory>publish\</PublishUrlHistory> <PublishUrlHistory>publish\</PublishUrlHistory>

View file

@ -196,7 +196,7 @@ namespace NBToolkit
affectedChunks++; affectedChunks++;
ApplyChunk(world, chunk); ApplyChunk(world, chunk);
//chunk.Save();
world.GetChunkManager().SaveDirtyChunks(); world.GetChunkManager().SaveDirtyChunks();
} }
@ -256,6 +256,45 @@ namespace NBToolkit
opt = o; opt = o;
} }
public override BlockRef GetBlockRef (int x, int y, int z)
{
BlockRef block;
try {
block = base.GetBlockRef(x, y, z);
}
catch {
return null;
}
int blockID = block.ID;
if (
((opt.OPT_OA) && (blockID != opt.OPT_ID)) ||
((opt.OPT_OO) && (
blockID == BLOCK_COAL || blockID == BLOCK_IRON ||
blockID == BLOCK_GOLD || blockID == BLOCK_REDSTONE ||
blockID == BLOCK_DIAMOND || blockID == BLOCK_LAPIS ||
blockID == BLOCK_DIRT || blockID == BLOCK_GRAVEL) && (blockID != opt.OPT_ID)) ||
(opt.OPT_OB_INCLUDE.Count > 0) ||
(blockID == BLOCK_STONE)
) {
// If overriding list of ores, check membership
if (opt.OPT_OB_INCLUDE.Count > 0 && !opt.OPT_OB_INCLUDE.Contains(blockID)) {
return null;
}
// Check for any excluded block
if (opt.OPT_OB_EXCLUDE.Contains(blockID)) {
return null;
}
// We're allowed to update the block
return block;
}
return null;
}
public override bool SetBlockID (int x, int y, int z, int id) public override bool SetBlockID (int x, int y, int z, int id)
{ {
int blockID = 0; int blockID = 0;

View file

@ -62,8 +62,6 @@ namespace NBToolkit
{ {
private PurgeOptions opt; private PurgeOptions opt;
private static Random rand = new Random();
public Purge (PurgeOptions o) public Purge (PurgeOptions o)
{ {
opt = o; opt = o;

View file

@ -50,28 +50,16 @@ namespace NBToolkit
v => { OPT_PROB = Convert.ToDouble(v); v => { OPT_PROB = Convert.ToDouble(v);
OPT_PROB = Math.Max((double)OPT_PROB, 0.0); OPT_PROB = Math.Max((double)OPT_PROB, 0.0);
OPT_PROB = Math.Min((double)OPT_PROB, 1.0); } }, OPT_PROB = Math.Min((double)OPT_PROB, 1.0); } },
/*{ "bxa=", "Update blocks with X-coord equal to or above {VAL}",
v => BL_X_GE = Convert.ToInt32(v) },
{ "bxb=", "Update blocks with X-coord equal to or below {VAL}",
v => BL_X_LE = Convert.ToInt32(v) },*/
{ "bxr|BlockXRange=", "Update blocks with X-coord between {0:V1} and {1:V2}, inclusive. V1 or V2 may be left blank.", { "bxr|BlockXRange=", "Update blocks with X-coord between {0:V1} and {1:V2}, inclusive. V1 or V2 may be left blank.",
(v1, v2) => { (v1, v2) => {
try { BL_X_GE = Convert.ToInt32(v1); } catch (FormatException) { } try { BL_X_GE = Convert.ToInt32(v1); } catch (FormatException) { }
try { BL_X_LE = Convert.ToInt32(v2); } catch (FormatException) { } try { BL_X_LE = Convert.ToInt32(v2); } catch (FormatException) { }
} }, } },
/*{ "bya=", "Update blocks with Y-coord equal to or above {VAL}",
v => BL_Y_GE = Convert.ToInt32(v) },
{ "byb=", "Update blocks with Y-coord equal to or below {VAL}",
v => BL_Y_LE = Convert.ToInt32(v) },*/
{ "byr|BlockYRange=", "Update blocks with Y-coord between {0:V1} and {1:V2}, inclusive. V1 or V2 may be left blank", { "byr|BlockYRange=", "Update blocks with Y-coord between {0:V1} and {1:V2}, inclusive. V1 or V2 may be left blank",
(v1, v2) => { (v1, v2) => {
try { BL_Y_GE = Convert.ToInt32(v1); } catch (FormatException) { } try { BL_Y_GE = Convert.ToInt32(v1); } catch (FormatException) { }
try { BL_Y_LE = Convert.ToInt32(v2); } catch (FormatException) { } try { BL_Y_LE = Convert.ToInt32(v2); } catch (FormatException) { }
} }, } },
/*{ "bza=", "Update blocks with Z-coord equal to or above {VAL}",
v => BL_Z_GE = Convert.ToInt32(v) },
{ "bzb=", "Update blocks with Z-coord equal to or below {VAL}",
v => BL_Z_LE = Convert.ToInt32(v) },*/
{ "bzr|BlockZRange=", "Update blocks with Z-coord between {0:V1} and {1:V2}, inclusive. V1 or V2 may be left blank", { "bzr|BlockZRange=", "Update blocks with Z-coord between {0:V1} and {1:V2}, inclusive. V1 or V2 may be left blank",
(v1, v2) => { (v1, v2) => {
try { BL_Z_GE = Convert.ToInt32(v1); } catch (FormatException) { } try { BL_Z_GE = Convert.ToInt32(v1); } catch (FormatException) { }