Add documentation to Block

This commit is contained in:
TheMode 2021-06-23 18:29:19 +02:00
parent aa2347bf9c
commit af9e102ec1
4 changed files with 78 additions and 8 deletions

View File

@ -24,9 +24,27 @@ import java.util.function.BiPredicate;
*/ */
public interface Block extends ProtocolObject, TagReadable, BlockConstants { public interface Block extends ProtocolObject, TagReadable, BlockConstants {
/**
* Creates a new block with the the property {@code property} sets to {@code value}.
*
* @param property the property name
* @param value the property value
* @return a new block with its property changed
* @throws IllegalArgumentException if the property or value are invalid
*/
@Contract(pure = true) @Contract(pure = true)
@NotNull Block withProperty(@NotNull String property, @NotNull String value); @NotNull Block withProperty(@NotNull String property, @NotNull String value);
/**
* Changes multiple properties at once.
* <p>
* Equivalent to calling {@link #withProperty(String, String)} for each map entry.
*
* @param properties map containing all the properties to change
* @return a new block with its properties changed
* @throws IllegalArgumentException if the property or value are invalid
* @see #withProperty(String, String)
*/
@Contract(pure = true) @Contract(pure = true)
default @NotNull Block withProperties(@NotNull Map<@NotNull String, @NotNull String> properties) { default @NotNull Block withProperties(@NotNull Map<@NotNull String, @NotNull String> properties) {
Block block = this; Block block = this;
@ -36,9 +54,23 @@ public interface Block extends ProtocolObject, TagReadable, BlockConstants {
return block; return block;
} }
/**
* Creates a new block with different nbt data.
*
* @param compound the new block nbt, null to remove
* @return a new block with different nbt
*/
@Contract(pure = true) @Contract(pure = true)
@NotNull Block withNbt(@Nullable NBTCompound compound); @NotNull Block withNbt(@Nullable NBTCompound compound);
/**
* Creates a new block with a tag value modified.
*
* @param tag the tag to modify
* @param value the tag value, null to remove
* @param <T> the tag type
* @return a new block with the modified tag
*/
@Contract(pure = true) @Contract(pure = true)
default <T> @NotNull Block withTag(@NotNull Tag<T> tag, @Nullable T value) { default <T> @NotNull Block withTag(@NotNull Tag<T> tag, @Nullable T value) {
var compound = Objects.requireNonNullElseGet(nbt(), NBTCompound::new); var compound = Objects.requireNonNullElseGet(nbt(), NBTCompound::new);
@ -46,24 +78,58 @@ public interface Block extends ProtocolObject, TagReadable, BlockConstants {
return withNbt(compound); return withNbt(compound);
} }
/**
* Creates a new block with the specified {@link BlockHandler handler}.
*
* @param handler the new block handler, null to remove
* @return a new block with the specified handler
*/
@Contract(pure = true) @Contract(pure = true)
@NotNull Block withHandler(@Nullable BlockHandler handler); @NotNull Block withHandler(@Nullable BlockHandler handler);
/**
* Returns an unmodifiable view to the block nbt.
*
* @return the block nbt, null if not present
*/
@Contract(pure = true) @Contract(pure = true)
@Nullable NBTCompound nbt(); @Nullable NBTCompound nbt();
/**
* Returns the block handler.
*
* @return the block handler, null if not present
*/
@Contract(pure = true) @Contract(pure = true)
@Nullable BlockHandler handler(); @Nullable BlockHandler handler();
/**
* Returns the block properties.
*
* @return the block properties map
*/
@Unmodifiable @Unmodifiable
@Contract(pure = true) @Contract(pure = true)
@NotNull Map<String, String> properties(); @NotNull Map<String, String> properties();
/**
* Returns a property value from {@link #properties()}.
*
* @param property the property name
* @return the property value, null if not present (due to an invalid property name)
*/
@Contract(pure = true) @Contract(pure = true)
default @NotNull String getProperty(@NotNull String property) { default String getProperty(@NotNull String property) {
return properties().get(property); return properties().get(property);
} }
/**
* Returns the block registry.
* <p>
* Registry data is directly linked to {@link #stateId()}.
*
* @return the block registry
*/
@Contract(pure = true) @Contract(pure = true)
@NotNull Registry.BlockEntry registry(); @NotNull Registry.BlockEntry registry();
@ -102,7 +168,7 @@ public interface Block extends ProtocolObject, TagReadable, BlockConstants {
} }
static @Nullable Block fromNamespaceId(@NotNull String namespaceID) { static @Nullable Block fromNamespaceId(@NotNull String namespaceID) {
return BlockRegistry.get(namespaceID); return BlockLoader.get(namespaceID);
} }
static @Nullable Block fromNamespaceId(@NotNull NamespaceID namespaceID) { static @Nullable Block fromNamespaceId(@NotNull NamespaceID namespaceID) {
@ -110,11 +176,11 @@ public interface Block extends ProtocolObject, TagReadable, BlockConstants {
} }
static @Nullable Block fromStateId(short stateId) { static @Nullable Block fromStateId(short stateId) {
return BlockRegistry.getState(stateId); return BlockLoader.getState(stateId);
} }
static @Nullable Block fromBlockId(int blockId) { static @Nullable Block fromBlockId(int blockId) {
return BlockRegistry.getId(blockId); return BlockLoader.getId(blockId);
} }
@FunctionalInterface @FunctionalInterface

View File

@ -44,7 +44,7 @@ class BlockImpl implements Block {
public @NotNull Block withProperty(@NotNull String property, @NotNull String value) { public @NotNull Block withProperty(@NotNull String property, @NotNull String value) {
var properties = new HashMap<>(this.properties); var properties = new HashMap<>(this.properties);
properties.put(property, value); properties.put(property, value);
Block block = BlockRegistry.getProperties(name(), properties); Block block = BlockLoader.getProperties(name(), properties);
if (block == null) if (block == null)
throw new IllegalArgumentException("Invalid property: " + property + ":" + value); throw new IllegalArgumentException("Invalid property: " + property + ":" + value);
if (nbt != null || handler != null) if (nbt != null || handler != null)
@ -54,7 +54,8 @@ class BlockImpl implements Block {
@Override @Override
public @NotNull Block withNbt(@Nullable NBTCompound compound) { public @NotNull Block withNbt(@Nullable NBTCompound compound) {
final var cachedNbt = NBT_CACHE.get(compound, c -> compound); final var clonedNbt = compound != null ? compound.deepClone() : null;
final var cachedNbt = NBT_CACHE.get(clonedNbt, c -> clonedNbt);
return new BlockImpl(registry, properties, cachedNbt, handler); return new BlockImpl(registry, properties, cachedNbt, handler);
} }

View File

@ -9,7 +9,10 @@ import org.jetbrains.annotations.Nullable;
import java.util.Map; import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
class BlockRegistry { /**
* Loads {@link Block blocks} from file.
*/
class BlockLoader {
// Block namespace -> registry data // Block namespace -> registry data
private static final Map<String, Block> NAMESPACE_MAP = new ConcurrentHashMap<>(); private static final Map<String, Block> NAMESPACE_MAP = new ConcurrentHashMap<>();

View File

@ -67,7 +67,7 @@ public class Registry {
this.blockEntity = getBoolean("blockEntity"); this.blockEntity = getBoolean("blockEntity");
} }
public NamespaceID namespace() { public @NotNull NamespaceID namespace() {
return namespace; return namespace;
} }