2011-04-06 04:43:54 +00:00
|
|
|
|
using System;
|
|
|
|
|
|
2011-04-06 22:01:22 +00:00
|
|
|
|
namespace Substrate
|
2011-04-06 04:43:54 +00:00
|
|
|
|
{
|
|
|
|
|
using NBT;
|
|
|
|
|
using Utility;
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Represents a Tile Entity record, which provides additional data to a block.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <remarks>Generally, this class should be subtyped into new concrete Tile Entity types, as this generic type is unable to
|
|
|
|
|
/// capture any of the custom data fields that make Tile Entities useful in the first place. It is however still possible to
|
|
|
|
|
/// create instances of <see cref="TileEntity"/> objects, which may allow for graceful handling of unknown Tile Entities.</remarks>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public class TileEntity : INBTObject<TileEntity>, ICopyable<TileEntity>
|
|
|
|
|
{
|
2011-06-28 03:41:44 +00:00
|
|
|
|
private static readonly SchemaNodeCompound _schema = new SchemaNodeCompound("")
|
2011-04-06 04:43:54 +00:00
|
|
|
|
{
|
2011-06-20 03:51:40 +00:00
|
|
|
|
new SchemaNodeScaler("id", TagType.TAG_STRING),
|
|
|
|
|
new SchemaNodeScaler("x", TagType.TAG_INT),
|
|
|
|
|
new SchemaNodeScaler("y", TagType.TAG_INT),
|
|
|
|
|
new SchemaNodeScaler("z", TagType.TAG_INT),
|
2011-04-06 04:43:54 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
private string _id;
|
|
|
|
|
private int _x;
|
|
|
|
|
private int _y;
|
|
|
|
|
private int _z;
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the id (name) of the Tile Entity.
|
|
|
|
|
/// </summary>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public string ID
|
|
|
|
|
{
|
|
|
|
|
get { return _id; }
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the global X-coordinate of the block that this Tile Entity is associated with.
|
|
|
|
|
/// </summary>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public int X
|
|
|
|
|
{
|
|
|
|
|
get { return _x; }
|
|
|
|
|
set { _x = value; }
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the global Y-coordinate of the block that this Tile Entity is associated with.
|
|
|
|
|
/// </summary>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public int Y
|
|
|
|
|
{
|
|
|
|
|
get { return _y; }
|
|
|
|
|
set { _y = value; }
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the global Z-coordinate of the block that this Tile Entity is associated with.
|
|
|
|
|
/// </summary>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public int Z
|
|
|
|
|
{
|
|
|
|
|
get { return _z; }
|
|
|
|
|
set { _z = value; }
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Constructs a nonspecific <see cref="TileEntity"/> with a given ID.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="id">The id (name) of the Tile Entity.</param>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public TileEntity (string id)
|
|
|
|
|
{
|
|
|
|
|
_id = id;
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Constructs a <see cref="TileEntity"/> by copying an existing one.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="te">The <see cref="TileEntity"/> to copy.</param>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public TileEntity (TileEntity te)
|
|
|
|
|
{
|
|
|
|
|
_id = te._id;
|
|
|
|
|
_x = te._x;
|
|
|
|
|
_y = te._y;
|
|
|
|
|
_z = te._z;
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Checks whether the Tile Entity is located (associated with a block) at the specific global coordinates.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="x">The global X-coordinate to test.</param>
|
|
|
|
|
/// <param name="y">The global Y-coordinate to test.</param>
|
|
|
|
|
/// <param name="z">The global Z-coordinate to test.</param>
|
|
|
|
|
/// <returns>Status indicating whether the Tile Entity is located at the specified global coordinates.</returns>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public bool LocatedAt (int x, int y, int z)
|
|
|
|
|
{
|
|
|
|
|
return _x == x && _y == y && _z == z;
|
|
|
|
|
}
|
|
|
|
|
|
2011-04-06 19:41:57 +00:00
|
|
|
|
|
2011-04-06 04:43:54 +00:00
|
|
|
|
#region ICopyable<TileEntity> Members
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Creates a deep-copy of the <see cref="TileEntity"/> including any data defined in a subtype.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns>A deep-copy of the <see cref="TileEntity"/>.</returns>
|
2011-04-06 04:43:54 +00:00
|
|
|
|
public virtual TileEntity Copy ()
|
|
|
|
|
{
|
|
|
|
|
return new TileEntity(this);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
2011-04-06 19:41:57 +00:00
|
|
|
|
|
2011-04-06 04:43:54 +00:00
|
|
|
|
#region INBTObject<TileEntity> Members
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets a <see cref="SchemaNode"/> representing the basic schema of a Tile Entity.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static SchemaNodeCompound Schema
|
|
|
|
|
{
|
|
|
|
|
get { return _schema; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Attempt to load a Tile Entity subtree into the <see cref="TileEntity"/> without validation.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="tree">The root node of a Tile Entity subtree.</param>
|
|
|
|
|
/// <returns>The <see cref="TileEntity"/> returns itself on success, or null if the tree was unparsable.</returns>
|
2011-06-20 03:51:40 +00:00
|
|
|
|
public virtual TileEntity LoadTree (TagNode tree)
|
2011-04-06 04:43:54 +00:00
|
|
|
|
{
|
2011-06-20 03:51:40 +00:00
|
|
|
|
TagNodeCompound ctree = tree as TagNodeCompound;
|
2011-04-06 04:43:54 +00:00
|
|
|
|
if (ctree == null) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2011-04-09 02:50:42 +00:00
|
|
|
|
_id = ctree["id"].ToTagString();
|
|
|
|
|
_x = ctree["x"].ToTagInt();
|
|
|
|
|
_y = ctree["y"].ToTagInt();
|
|
|
|
|
_z = ctree["z"].ToTagInt();
|
2011-04-06 04:43:54 +00:00
|
|
|
|
|
|
|
|
|
return this;
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Attempt to load a Tile Entity subtree into the <see cref="TileEntity"/> with validation.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="tree">The root node of a Tile Entity subtree.</param>
|
|
|
|
|
/// <returns>The <see cref="TileEntity"/> returns itself on success, or null if the tree failed validation.</returns>
|
2011-06-20 03:51:40 +00:00
|
|
|
|
public virtual TileEntity LoadTreeSafe (TagNode tree)
|
2011-04-06 04:43:54 +00:00
|
|
|
|
{
|
|
|
|
|
if (!ValidateTree(tree)) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return LoadTree(tree);
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Builds a Tile Entity subtree from the current data.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns>The root node of a Tile Entity subtree representing the current data.</returns>
|
2011-06-20 03:51:40 +00:00
|
|
|
|
public virtual TagNode BuildTree ()
|
2011-04-06 04:43:54 +00:00
|
|
|
|
{
|
2011-06-20 03:51:40 +00:00
|
|
|
|
TagNodeCompound tree = new TagNodeCompound();
|
|
|
|
|
tree["id"] = new TagNodeString(_id);
|
|
|
|
|
tree["x"] = new TagNodeInt(_x);
|
|
|
|
|
tree["y"] = new TagNodeInt(_y);
|
|
|
|
|
tree["z"] = new TagNodeInt(_z);
|
2011-04-06 04:43:54 +00:00
|
|
|
|
|
|
|
|
|
return tree;
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 03:41:44 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Validate a Tile Entity subtree against a basic schema.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="tree">The root node of a Tile Entity subtree.</param>
|
|
|
|
|
/// <returns>Status indicating whether the tree was valid against the internal schema.</returns>
|
2011-06-20 03:51:40 +00:00
|
|
|
|
public virtual bool ValidateTree (TagNode tree)
|
2011-04-06 04:43:54 +00:00
|
|
|
|
{
|
2011-06-28 03:41:44 +00:00
|
|
|
|
return new NBTVerifier(tree, _schema).Verify();
|
2011-04-06 04:43:54 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|