mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-04 07:28:19 +01:00
Fix attribute nbt
Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
parent
9a28e6ba87
commit
4a40805ca0
@ -12,6 +12,7 @@ import org.jetbrains.annotations.ApiStatus;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@ApiStatus.Internal
|
@ApiStatus.Internal
|
||||||
@ -42,7 +43,7 @@ public final class ItemSerializers {
|
|||||||
static final TagSerializer<ItemAttribute> ATTRIBUTE_SERIALIZER = new TagSerializer<>() {
|
static final TagSerializer<ItemAttribute> ATTRIBUTE_SERIALIZER = new TagSerializer<>() {
|
||||||
static final Tag<UUID> ID = Tag.UUID("UUID");
|
static final Tag<UUID> ID = Tag.UUID("UUID");
|
||||||
static final Tag<Double> AMOUNT = Tag.Double("Amount");
|
static final Tag<Double> AMOUNT = Tag.Double("Amount");
|
||||||
static final Tag<String> SLOT = Tag.String("Slot").defaultValue("MAINHAND");
|
static final Tag<String> SLOT = Tag.String("Slot").defaultValue("mainhand");
|
||||||
static final Tag<String> ATTRIBUTE_NAME = Tag.String("AttributeName");
|
static final Tag<String> ATTRIBUTE_NAME = Tag.String("AttributeName");
|
||||||
static final Tag<Integer> OPERATION = Tag.Integer("Operation");
|
static final Tag<Integer> OPERATION = Tag.Integer("Operation");
|
||||||
static final Tag<String> NAME = Tag.String("Name");
|
static final Tag<String> NAME = Tag.String("Name");
|
||||||
@ -56,7 +57,7 @@ public final class ItemSerializers {
|
|||||||
final int operation = reader.getTag(OPERATION);
|
final int operation = reader.getTag(OPERATION);
|
||||||
final String name = reader.getTag(NAME);
|
final String name = reader.getTag(NAME);
|
||||||
|
|
||||||
final Attribute attribute = Attribute.fromKey(attributeName);
|
final Attribute attribute = Attribute.fromKey(attributeName.toUpperCase(Locale.ROOT));
|
||||||
// Wrong attribute name, stop here
|
// Wrong attribute name, stop here
|
||||||
if (attribute == null) return null;
|
if (attribute == null) return null;
|
||||||
final AttributeOperation attributeOperation = AttributeOperation.fromId(operation);
|
final AttributeOperation attributeOperation = AttributeOperation.fromId(operation);
|
||||||
@ -77,7 +78,7 @@ public final class ItemSerializers {
|
|||||||
public void write(@NotNull TagWritable writer, @NotNull ItemAttribute value) {
|
public void write(@NotNull TagWritable writer, @NotNull ItemAttribute value) {
|
||||||
writer.setTag(ID, value.uuid());
|
writer.setTag(ID, value.uuid());
|
||||||
writer.setTag(AMOUNT, value.amount());
|
writer.setTag(AMOUNT, value.amount());
|
||||||
writer.setTag(SLOT, value.slot().name());
|
writer.setTag(SLOT, value.slot().name().toLowerCase(Locale.ROOT));
|
||||||
writer.setTag(ATTRIBUTE_NAME, value.attribute().key());
|
writer.setTag(ATTRIBUTE_NAME, value.attribute().key());
|
||||||
writer.setTag(OPERATION, value.operation().getId());
|
writer.setTag(OPERATION, value.operation().getId());
|
||||||
writer.setTag(NAME, value.name());
|
writer.setTag(NAME, value.name());
|
||||||
|
@ -0,0 +1,49 @@
|
|||||||
|
package net.minestom.server.item;
|
||||||
|
|
||||||
|
import net.minestom.server.attribute.Attribute;
|
||||||
|
import net.minestom.server.attribute.AttributeOperation;
|
||||||
|
import net.minestom.server.item.attribute.AttributeSlot;
|
||||||
|
import net.minestom.server.item.attribute.ItemAttribute;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import static net.minestom.server.api.TestUtils.assertEqualsSNBT;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
|
public class ItemAttributeTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void attribute() {
|
||||||
|
var attributes = List.of(new ItemAttribute(
|
||||||
|
new UUID(0, 0), "generic.attack_damage", Attribute.ATTACK_DAMAGE,
|
||||||
|
AttributeOperation.ADDITION, 2, AttributeSlot.MAINHAND));
|
||||||
|
var item = ItemStack.builder(Material.STICK)
|
||||||
|
.meta(builder -> builder.attributes(attributes))
|
||||||
|
.build();
|
||||||
|
assertEquals(attributes, item.meta().getAttributes());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void attributeNbt() {
|
||||||
|
var item = ItemStack.builder(Material.STICK)
|
||||||
|
.meta(builder -> builder.attributes(
|
||||||
|
List.of(new ItemAttribute(
|
||||||
|
new UUID(0, 0), "generic.attack_damage", Attribute.ATTACK_DAMAGE,
|
||||||
|
AttributeOperation.ADDITION, 2, AttributeSlot.MAINHAND))))
|
||||||
|
.build();
|
||||||
|
assertEqualsSNBT("""
|
||||||
|
{"AttributeModifiers":[
|
||||||
|
{
|
||||||
|
"Amount":2.0D,
|
||||||
|
"UUID":[I;0,0,0,0],
|
||||||
|
"Slot":"mainhand",
|
||||||
|
"Operation":0,
|
||||||
|
"AttributeName":"generic.attack_damage",
|
||||||
|
"Name":"generic.attack_damage"
|
||||||
|
}
|
||||||
|
]}
|
||||||
|
""", item.meta().toNBT());
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user