forked from mirrors/NBTExplorer
If biome data is absent, default data will be created instead of failing.
This commit is contained in:
parent
1b7858d3e3
commit
f65238abde
2 changed files with 13 additions and 4 deletions
|
@ -30,8 +30,8 @@ using System.Runtime.InteropServices;
|
||||||
// Build Number
|
// Build Number
|
||||||
// Revision
|
// Revision
|
||||||
//
|
//
|
||||||
[assembly: AssemblyVersion("1.2.0.0")]
|
[assembly: AssemblyVersion("1.2.1.0")]
|
||||||
[assembly: AssemblyFileVersion("1.2.0.0")]
|
[assembly: AssemblyFileVersion("1.2.1.0")]
|
||||||
|
|
||||||
// This library is compatible with all CLS-compliant .NET programming languages.
|
// This library is compatible with all CLS-compliant .NET programming languages.
|
||||||
[assembly: CLSCompliant(true)]
|
[assembly: CLSCompliant(true)]
|
|
@ -427,7 +427,7 @@ namespace Substrate
|
||||||
new SchemaNodeScaler("Y", TagType.TAG_BYTE),
|
new SchemaNodeScaler("Y", TagType.TAG_BYTE),
|
||||||
new SchemaNodeArray("AddBlocks", 2048, SchemaOptions.OPTIONAL),
|
new SchemaNodeArray("AddBlocks", 2048, SchemaOptions.OPTIONAL),
|
||||||
}),
|
}),
|
||||||
new SchemaNodeArray("Biomes", 256),
|
new SchemaNodeArray("Biomes", 256, SchemaOptions.OPTIONAL),
|
||||||
new SchemaNodeIntArray("HeightMap", 256),
|
new SchemaNodeIntArray("HeightMap", 256),
|
||||||
new SchemaNodeList("Entities", TagType.TAG_COMPOUND, SchemaOptions.CREATE_ON_MISSING),
|
new SchemaNodeList("Entities", TagType.TAG_COMPOUND, SchemaOptions.CREATE_ON_MISSING),
|
||||||
new SchemaNodeList("TileEntities", TagType.TAG_COMPOUND, TileEntity.Schema, SchemaOptions.CREATE_ON_MISSING),
|
new SchemaNodeList("TileEntities", TagType.TAG_COMPOUND, TileEntity.Schema, SchemaOptions.CREATE_ON_MISSING),
|
||||||
|
@ -657,7 +657,16 @@ namespace Substrate
|
||||||
_blockLight = new CompositeYZXNibbleArray(blockLightBA);
|
_blockLight = new CompositeYZXNibbleArray(blockLightBA);
|
||||||
|
|
||||||
_heightMap = new ZXIntArray(XDIM, ZDIM, level["HeightMap"] as TagNodeIntArray);
|
_heightMap = new ZXIntArray(XDIM, ZDIM, level["HeightMap"] as TagNodeIntArray);
|
||||||
|
|
||||||
|
if (level.ContainsKey("Biomes"))
|
||||||
_biomes = new ZXByteArray(XDIM, ZDIM, level["Biomes"] as TagNodeByteArray);
|
_biomes = new ZXByteArray(XDIM, ZDIM, level["Biomes"] as TagNodeByteArray);
|
||||||
|
else {
|
||||||
|
level["Biomes"] = new TagNodeByteArray(new byte[256]);
|
||||||
|
_biomes = new ZXByteArray(XDIM, ZDIM, level["Biomes"] as TagNodeByteArray);
|
||||||
|
for (int x = 0; x < XDIM; x++)
|
||||||
|
for (int z = 0; z < ZDIM; z++)
|
||||||
|
_biomes[x, z] = BiomeType.Default;
|
||||||
|
}
|
||||||
|
|
||||||
_entities = level["Entities"] as TagNodeList;
|
_entities = level["Entities"] as TagNodeList;
|
||||||
_tileEntities = level["TileEntities"] as TagNodeList;
|
_tileEntities = level["TileEntities"] as TagNodeList;
|
||||||
|
|
Loading…
Reference in a new issue