mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-20 07:02:32 +01:00
Cleanup
This commit is contained in:
parent
11b2426629
commit
d146aacd36
@ -9,6 +9,7 @@ import org.jetbrains.annotations.Nullable;
|
||||
import org.jglrxavpok.hephaistos.nbt.NBTCompound;
|
||||
|
||||
import java.time.Duration;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.Objects;
|
||||
@ -41,10 +42,7 @@ final class BlockImpl implements Block {
|
||||
public @NotNull Block withProperty(@NotNull String property, @NotNull String value) {
|
||||
var properties = new HashMap<>(this.properties);
|
||||
properties.replace(property, value);
|
||||
Block block = propertyEntry.getProperties(properties);
|
||||
if (block == null)
|
||||
throw new IllegalArgumentException("Invalid property: " + property + ":" + value);
|
||||
return compute(block);
|
||||
return compute(properties);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -52,18 +50,12 @@ final class BlockImpl implements Block {
|
||||
if (properties.isEmpty()) {
|
||||
return this;
|
||||
}
|
||||
Block block;
|
||||
if (this.properties.size() == properties.size()) {
|
||||
// Map should be complete
|
||||
block = propertyEntry.getProperties(properties);
|
||||
} else {
|
||||
return compute(properties); // Map should be complete
|
||||
}
|
||||
var newProperties = new HashMap<>(this.properties);
|
||||
newProperties.replaceAll((key, value) -> Objects.requireNonNullElse(properties.get(key), value));
|
||||
block = propertyEntry.getProperties(newProperties);
|
||||
}
|
||||
if (block == null)
|
||||
throw new IllegalArgumentException("Invalid properties: " + properties);
|
||||
return compute(block);
|
||||
return compute(newProperties);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -91,7 +83,7 @@ final class BlockImpl implements Block {
|
||||
|
||||
@Override
|
||||
public @NotNull Map<String, String> properties() {
|
||||
return properties;
|
||||
return Collections.unmodifiableMap(properties);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -104,8 +96,11 @@ final class BlockImpl implements Block {
|
||||
return nbt != null ? tag.read(nbt) : null;
|
||||
}
|
||||
|
||||
private Block compute(Block original) {
|
||||
return nbt == null && handler == null ? original :
|
||||
new BlockImpl(original.registry(), propertyEntry, original.properties(), nbt, handler);
|
||||
private Block compute(Map<String, String> properties) {
|
||||
Block block = propertyEntry.getProperties(properties);
|
||||
if (block == null)
|
||||
throw new IllegalArgumentException("Invalid properties: " + properties);
|
||||
return nbt == null && handler == null ? block :
|
||||
new BlockImpl(block.registry(), propertyEntry, block.properties(), nbt, handler);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user