mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-23 16:41:35 +01:00
Add documentation to Block
This commit is contained in:
parent
aa2347bf9c
commit
af9e102ec1
@ -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
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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<>();
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user