Add tag comments

This commit is contained in:
TheMode 2021-05-17 15:14:16 +02:00
parent 1ec631fa5b
commit 429a14e220
5 changed files with 72 additions and 1 deletions

View File

@ -9,7 +9,14 @@ import java.util.function.BiConsumer;
import java.util.function.Function; import java.util.function.Function;
import java.util.function.Supplier; import java.util.function.Supplier;
public class Tag<T> { /**
* Represents a key to retrieve or change a value.
* <p>
* All tags are serializable.
*
* @param <T> the tag type
*/
public final class Tag<T> {
private final String key; private final String key;
private final Function<NBTCompound, T> readFunction; private final Function<NBTCompound, T> readFunction;

View File

@ -0,0 +1,7 @@
package net.minestom.server.tag;
/**
* Represents an element which can read and write {@link Tag tags}.
*/
public interface TagHandler extends TagReader, TagWriter {
}

View File

@ -4,11 +4,34 @@ import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import org.jglrxavpok.hephaistos.nbt.NBTCompound; import org.jglrxavpok.hephaistos.nbt.NBTCompound;
/**
* Represents an element which can read {@link Tag tags}.
*/
public interface TagReader { public interface TagReader {
/**
* Reads the specified tag.
*
* @param tag the tag to read
* @param <T> the tag type
* @return the read tag, null if not present
*/
<T> @Nullable T getTag(@NotNull Tag<T> tag); <T> @Nullable T getTag(@NotNull Tag<T> tag);
/**
* Returns if a tag is present.
*
* @param tag the tag to check
* @return true if the tag is present, false otherwise
*/
boolean hasTag(@NotNull Tag<?> tag); boolean hasTag(@NotNull Tag<?> tag);
/**
* Converts an nbt compound to a tag reader.
*
* @param compound the compound to convert
* @return a {@link TagReader} capable of reading {@code compound}
*/
static @NotNull TagReader fromCompound(@NotNull NBTCompound compound) { static @NotNull TagReader fromCompound(@NotNull NBTCompound compound) {
return new TagReader() { return new TagReader() {
@Override @Override

View File

@ -3,9 +3,26 @@ package net.minestom.server.tag;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
/**
* Interface used to create custom types compatible with {@link Tag#Custom(String, TagSerializer)}.
*
* @param <T> the type to serialize
*/
public interface TagSerializer<T> { public interface TagSerializer<T> {
/**
* Reads the custom tag from a {@link TagReader}.
*
* @param reader the reader
* @return the deserialized value
*/
@Nullable T read(@NotNull TagReader reader); @Nullable T read(@NotNull TagReader reader);
/**
* Writes the custom tag to a {@link TagWriter}.
*
* @param writer the writer
* @param value the value to serialize
*/
void write(@NotNull TagWriter writer, @NotNull T value); void write(@NotNull TagWriter writer, @NotNull T value);
} }

View File

@ -4,9 +4,26 @@ import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import org.jglrxavpok.hephaistos.nbt.NBTCompound; import org.jglrxavpok.hephaistos.nbt.NBTCompound;
/**
* Represents an element which can write {@link Tag tags}.
*/
public interface TagWriter { public interface TagWriter {
/**
* Writes the specified type.
*
* @param tag the tag to write
* @param value the tag value, null to remove
* @param <T> the tag type
*/
<T> void setTag(@NotNull Tag<T> tag, @Nullable T value); <T> void setTag(@NotNull Tag<T> tag, @Nullable T value);
/**
* Converts an nbt compound to a tag writer.
*
* @param compound the compound to convert
* @return a {@link TagWriter} capable of writing {@code compound}
*/
static @NotNull TagWriter fromCompound(@NotNull NBTCompound compound) { static @NotNull TagWriter fromCompound(@NotNull NBTCompound compound) {
return new TagWriter() { return new TagWriter() {
@Override @Override