commit | 7088bf9351ea6c3971eea46c696c8a2df8cd76ee | [log] [download] |
---|---|---|
author | Querz <info@querz.net> | Mon Apr 10 17:41:47 2017 +0200 |
committer | Querz <info@querz.net> | Mon Apr 10 17:41:47 2017 +0200 |
tree | cff22e0df53320407c594b6f1534a4daefac4592 | |
parent | 2db7fabf400fde65ee90be059213c8ebdb790eb2 [diff] |
add custom ObjectTag
According to the specification, there are currently 12 different types of tags:
Tag class | Superclass | ID | Payload |
---|---|---|---|
EndTag | Tag | 0 | None |
ByteTag | NumberTag | 1 | 1 byte / 8 bits, signed |
ShortTag | NumberTag | 2 | 2 bytes / 16 bits, signed, big endian |
IntTag | NumberTag | 3 | 4 bytes / 32 bits, signed, big endian |
LongTag | NumberTag | 4 | 8 bytes / 64 bits, signed, big endian |
FloatTag | NumberTag | 5 | 4 bytes / 32 bits, signed, big endian, IEEE 754-2008, binary32 |
DoubleTag | NumberTag | 6 | 8 bytes / 64 bits, signed, big endian, IEEE 754-2008, binary64 |
ByteArrayTag | ArrayTag | 7 | IntTag‘s payload size, then size ByteTag’s payloads |
StringTag | Tag | 8 | ShortTag's payload length, then a UTF-8 string with size length |
ListTag | Tag | 9 | ByteTag‘s payload tagId, then IntTag’s payload size, then size tags' payloads, all of type tagId |
CompoundTag | Tag | 10 | Fully formed tags, followed by an EndTag |
IntArrayTag | ArrayTag | 11 | IntTag‘s payload size, then size IntTag’s payloads |
The EndTag is only used to mark the end of a CompoundTag in its serialized state or an empty ListTag.
The maximum depth of the NBT structure is 512. If the depth exceeds this restriction during serialization, deserialization or String conversion, a MaxDepthReachedException is thrown. This usually happens when a circular reference exists in the NBT structure. The NBT specification does not allow circular references, as there is no tag to represent this.
ByteTag bt = new ByteTag("8bitNumber", (byte) 1); DoubleTag dt = new DoubleTag("64bitFloatingPointNumber", 1.234); CompoundTag ct = new CompoundTag("compound"); ct.set(bt); ct.set(dt);
There are several utility classes that make your life easier using this library.
The NBTFileWriter lets you write a Tag into a gzip compressed or uncompressed file in one line. Files are gzip compressed by default. Example usage:
new NBTFileWriter("filename.dat").write(tag);
The NBTFileReader reads any file containing NBT data. No worry about compression, it will automatically uncompress gzip compressed files. Example usage:
Tag tag = new NBTFileReader("filename.dat").read();
Each tag can be converted into a JSON-like NBT String used in Minecraft commands. Example usage:
CompoundTag c = new CompoundTag("compound"); c.setByte("byte", (byte) 5); c.setString("string", "test"); String s = c.toTagString(); //output: compound:{byte:5b,string:"test"}
Interested in more advanced features, and the default NBT protocol just isn't enough? Simply create your own tags! There are 3 example classes in net.querz.nbt.custom that show how to implement custom tags:
Class | ID | Description |
---|---|---|
ShortArrayTag | 100 | In addition to the already existing ByteArrayTag and IntArrayTag. |
CharTag | 110 | Character (char) tag. |
StructTag | 120 | Similar to the ListTag, but with the ability to store multiple types. |
To be able to use a custom tag, it must be registered during runtime with TagType#registerCustomTag(int, Class).