2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Zach Brown <zach.brown@destroystokyo.com>
|
|
|
|
Date: Sat, 27 Jan 2018 17:04:14 -0500
|
|
|
|
Subject: [PATCH] Add ArmorStand Item Meta
|
|
|
|
|
|
|
|
This is adds basic item meta for armor stands. It does not add all
|
|
|
|
possible metadata however.
|
|
|
|
|
|
|
|
There are armor, hand, and equipment types, as well as position data
|
|
|
|
that can also be added here. This initial addition should serve a
|
|
|
|
starting point for future additions in this area.
|
|
|
|
|
|
|
|
Fixes GH-559
|
|
|
|
|
2024-06-15 18:28:18 +02:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemMetas.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemMetas.java
|
|
|
|
index 85aab880fdb2f23d09096f8f2b1ede4f068fa023..4ae9930c2d74e5b1e3ad0c2ecf6556dc59cbf23c 100644
|
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemMetas.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemMetas.java
|
|
|
|
@@ -1,5 +1,6 @@
|
|
|
|
package org.bukkit.craftbukkit.inventory;
|
|
|
|
|
|
|
|
+import com.destroystokyo.paper.inventory.meta.ArmorStandMeta;
|
|
|
|
import java.util.function.BiFunction;
|
|
|
|
import java.util.function.Function;
|
|
|
|
import net.minecraft.world.item.ItemStack;
|
|
|
|
@@ -95,7 +96,7 @@ public final class CraftItemMetas {
|
|
|
|
item -> new CraftMetaSpawnEgg(item.getComponentsPatch()),
|
|
|
|
(type, meta) -> meta instanceof CraftMetaSpawnEgg spawnEgg ? spawnEgg : new CraftMetaSpawnEgg(meta));
|
|
|
|
|
|
|
|
- private static final ItemMetaData<ItemMeta> ARMOR_STAND_META_DATA = new ItemMetaData<>(ItemMeta.class,
|
|
|
|
+ private static final ItemMetaData<ArmorStandMeta> ARMOR_STAND_META_DATA = new ItemMetaData<>(ArmorStandMeta.class, // paper
|
|
|
|
item -> new CraftMetaArmorStand(item.getComponentsPatch()),
|
|
|
|
(type, meta) -> meta instanceof CraftMetaArmorStand armorStand ? armorStand : new CraftMetaArmorStand(meta));
|
|
|
|
|
2021-06-11 14:02:28 +02:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
2024-05-26 00:58:56 +02:00
|
|
|
index c4f12f96e39cb6189799a796b4cb2cb4f0b92392..59bdac414e8205ed608f79ef0d1502acd826d216 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
2024-04-23 19:21:40 -07:00
|
|
|
@@ -11,9 +11,22 @@ import org.bukkit.Material;
|
2022-09-12 13:31:45 +02:00
|
|
|
import org.bukkit.configuration.serialization.DelegateDeserialization;
|
2021-06-11 14:02:28 +02:00
|
|
|
|
2024-04-23 19:21:40 -07:00
|
|
|
@DelegateDeserialization(SerializableMeta.class)
|
2021-06-11 14:02:28 +02:00
|
|
|
-public class CraftMetaArmorStand extends CraftMetaItem {
|
|
|
|
+public class CraftMetaArmorStand extends CraftMetaItem implements com.destroystokyo.paper.inventory.meta.ArmorStandMeta { // Paper
|
|
|
|
|
2024-04-23 19:21:40 -07:00
|
|
|
static final ItemMetaKeyType<CustomData> ENTITY_TAG = new ItemMetaKeyType<>(DataComponents.ENTITY_DATA, "entity-tag");
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start
|
|
|
|
+ static final ItemMetaKey INVISIBLE = new ItemMetaKey("Invisible", "invisible");
|
|
|
|
+ static final ItemMetaKey NO_BASE_PLATE = new ItemMetaKey("NoBasePlate", "no-base-plate");
|
|
|
|
+ static final ItemMetaKey SHOW_ARMS = new ItemMetaKey("ShowArms", "show-arms");
|
|
|
|
+ static final ItemMetaKey SMALL = new ItemMetaKey("Small", "small");
|
|
|
|
+ static final ItemMetaKey MARKER = new ItemMetaKey("Marker", "marker");
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ private Boolean invisible = null;
|
|
|
|
+ private Boolean noBasePlate = null;
|
|
|
|
+ private Boolean showArms = null;
|
|
|
|
+ private Boolean small = null;
|
|
|
|
+ private Boolean marker = null;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper end
|
|
|
|
CompoundTag entityTag;
|
|
|
|
|
|
|
|
CraftMetaArmorStand(CraftMetaItem meta) {
|
2024-04-23 19:21:40 -07:00
|
|
|
@@ -24,6 +37,13 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
CraftMetaArmorStand armorStand = (CraftMetaArmorStand) meta;
|
|
|
|
+ // Paper start
|
|
|
|
+ this.invisible = armorStand.invisible;
|
|
|
|
+ this.noBasePlate = armorStand.noBasePlate;
|
|
|
|
+ this.showArms = armorStand.showArms;
|
|
|
|
+ this.small = armorStand.small;
|
|
|
|
+ this.marker = armorStand.marker;
|
|
|
|
+ // Paper end
|
|
|
|
this.entityTag = armorStand.entityTag;
|
|
|
|
}
|
|
|
|
|
2024-04-23 19:21:40 -07:00
|
|
|
@@ -32,11 +52,39 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
2021-06-11 14:02:28 +02:00
|
|
|
|
2024-04-23 19:21:40 -07:00
|
|
|
getOrEmpty(tag, CraftMetaArmorStand.ENTITY_TAG).ifPresent((nbt) -> {
|
|
|
|
this.entityTag = nbt.copyTag();
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start
|
|
|
|
+ if (entityTag.contains(INVISIBLE.NBT)) {
|
|
|
|
+ invisible = entityTag.getBoolean(INVISIBLE.NBT);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (entityTag.contains(NO_BASE_PLATE.NBT)) {
|
|
|
|
+ noBasePlate = entityTag.getBoolean(NO_BASE_PLATE.NBT);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (entityTag.contains(SHOW_ARMS.NBT)) {
|
|
|
|
+ showArms = entityTag.getBoolean(SHOW_ARMS.NBT);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (entityTag.contains(SMALL.NBT)) {
|
|
|
|
+ small = entityTag.getBoolean(SMALL.NBT);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (entityTag.contains(MARKER.NBT)) {
|
|
|
|
+ marker = entityTag.getBoolean(MARKER.NBT);
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2024-04-23 19:21:40 -07:00
|
|
|
});
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
CraftMetaArmorStand(Map<String, Object> map) {
|
|
|
|
super(map);
|
|
|
|
+ // Paper start
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.invisible = SerializableMeta.getBoolean(map, INVISIBLE.BUKKIT);
|
|
|
|
+ this.noBasePlate = SerializableMeta.getBoolean(map, NO_BASE_PLATE.BUKKIT);
|
|
|
|
+ this.showArms = SerializableMeta.getBoolean(map, SHOW_ARMS.BUKKIT);
|
|
|
|
+ this.small = SerializableMeta.getBoolean(map, SMALL.BUKKIT);
|
|
|
|
+ this.marker = SerializableMeta.getBoolean(map, MARKER.BUKKIT);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2024-04-23 19:21:40 -07:00
|
|
|
@@ -59,6 +107,31 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
|
|
|
void applyToItem(CraftMetaItem.Applicator tag) {
|
2021-06-11 14:02:28 +02:00
|
|
|
super.applyToItem(tag);
|
|
|
|
|
|
|
|
+ // Paper start
|
2021-06-12 09:56:13 -07:00
|
|
|
+ if (!isArmorStandEmpty() && this.entityTag == null) {
|
|
|
|
+ this.entityTag = new CompoundTag();
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (this.invisible != null) {
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.entityTag.putBoolean(INVISIBLE.NBT, this.invisible);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (this.noBasePlate != null) {
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.entityTag.putBoolean(NO_BASE_PLATE.NBT, this.noBasePlate);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (this.showArms != null) {
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.entityTag.putBoolean(SHOW_ARMS.NBT, this.showArms);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (this.small != null) {
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.entityTag.putBoolean(SMALL.NBT, this.small);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (this.marker != null) {
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.entityTag.putBoolean(MARKER.NBT, this.marker);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2021-06-12 09:56:13 -07:00
|
|
|
if (this.entityTag != null) {
|
2024-04-23 19:21:40 -07:00
|
|
|
tag.put(CraftMetaArmorStand.ENTITY_TAG, CustomData.of(this.entityTag));
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
2024-04-23 19:21:40 -07:00
|
|
|
@@ -75,7 +148,7 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
boolean isArmorStandEmpty() {
|
2021-06-12 09:56:13 -07:00
|
|
|
- return !(this.entityTag != null);
|
2022-12-23 12:30:42 -05:00
|
|
|
+ return !(this.invisible != null || this.noBasePlate != null || this.showArms != null || this.small != null || this.marker != null || this.entityTag != null); // Paper
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2024-05-26 00:58:56 +02:00
|
|
|
@@ -86,7 +159,14 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
2021-06-11 14:02:28 +02:00
|
|
|
if (meta instanceof CraftMetaArmorStand) {
|
|
|
|
CraftMetaArmorStand that = (CraftMetaArmorStand) meta;
|
|
|
|
|
2021-06-12 09:56:13 -07:00
|
|
|
- return this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : this.entityTag == null;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start
|
2024-05-26 00:58:56 +02:00
|
|
|
+ return java.util.Objects.equals(this.entityTag, that.entityTag) &&
|
|
|
|
+ this.invisible == that.invisible &&
|
2021-06-12 09:56:13 -07:00
|
|
|
+ this.noBasePlate == that.noBasePlate &&
|
|
|
|
+ this.showArms == that.showArms &&
|
|
|
|
+ this.small == that.small &&
|
|
|
|
+ this.marker == that.marker;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2024-05-26 00:58:56 +02:00
|
|
|
@@ -104,6 +184,13 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
|
|
|
if (this.entityTag != null) {
|
|
|
|
hash = 73 * hash + this.entityTag.hashCode();
|
|
|
|
}
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start
|
2024-05-26 00:58:56 +02:00
|
|
|
+ hash = 61 * hash + (this.invisible != null ? Boolean.hashCode(this.isInvisible()) : 0);
|
|
|
|
+ hash = 61 * hash + (this.noBasePlate != null ? Boolean.hashCode(this.hasNoBasePlate()) : 0);
|
|
|
|
+ hash = 61 * hash + (this.showArms != null ? Boolean.hashCode(this.shouldShowArms()) : 0);
|
|
|
|
+ hash = 61 * hash + (this.small != null ? Boolean.hashCode(this.isSmall()) : 0);
|
|
|
|
+ hash = 61 * hash + (this.marker != null ? Boolean.hashCode(this.isMarker()) : 0);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
return original != hash ? CraftMetaArmorStand.class.hashCode() ^ hash : hash;
|
|
|
|
}
|
2024-05-26 00:58:56 +02:00
|
|
|
@@ -112,6 +199,28 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
2021-06-11 14:02:28 +02:00
|
|
|
Builder<String, Object> serialize(Builder<String, Object> builder) {
|
|
|
|
super.serialize(builder);
|
|
|
|
|
|
|
|
+ // Paper start
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (invisible != null) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ builder.put(INVISIBLE.BUKKIT, invisible);
|
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (noBasePlate != null) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ builder.put(NO_BASE_PLATE.BUKKIT, noBasePlate);
|
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (showArms != null) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ builder.put(SHOW_ARMS.BUKKIT, showArms);
|
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (small != null) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ builder.put(SMALL.BUKKIT, small);
|
|
|
|
+ }
|
|
|
|
+
|
2022-12-23 12:30:42 -05:00
|
|
|
+ if (marker != null) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ builder.put(MARKER.BUKKIT, marker);
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
return builder;
|
|
|
|
}
|
|
|
|
|
2024-05-26 00:58:56 +02:00
|
|
|
@@ -125,4 +234,56 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
2021-06-11 14:02:28 +02:00
|
|
|
|
|
|
|
return clone;
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+ // Paper start
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isInvisible() {
|
2022-12-23 12:30:42 -05:00
|
|
|
+ return invisible != null && invisible;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean hasNoBasePlate() {
|
2022-12-23 12:30:42 -05:00
|
|
|
+ return noBasePlate != null && noBasePlate;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean shouldShowArms() {
|
2022-12-23 12:30:42 -05:00
|
|
|
+ return showArms != null && showArms;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isSmall() {
|
2022-12-23 12:30:42 -05:00
|
|
|
+ return small != null && small;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isMarker() {
|
2022-12-23 12:30:42 -05:00
|
|
|
+ return marker != null && marker;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void setInvisible(boolean invisible) {
|
|
|
|
+ this.invisible = invisible;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void setNoBasePlate(boolean noBasePlate) {
|
|
|
|
+ this.noBasePlate = noBasePlate;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void setShowArms(boolean showArms) {
|
|
|
|
+ this.showArms = showArms;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void setSmall(boolean small) {
|
|
|
|
+ this.small = small;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void setMarker(boolean marker) {
|
|
|
|
+ this.marker = marker;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
2024-05-11 14:48:37 -07:00
|
|
|
index 99a555ca72cd95d760d68072242203deeddd0ce1..a1d8da4e0de3f84194f28d7d18fa795d53714590 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
|
|
|
+++ b/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
2024-05-11 14:48:37 -07:00
|
|
|
@@ -364,6 +364,7 @@ public class ItemMetaTest extends AbstractTestingBase {
|
2021-06-11 14:02:28 +02:00
|
|
|
final CraftMetaArmorStand meta = (CraftMetaArmorStand) cleanStack.getItemMeta();
|
2021-06-12 09:56:13 -07:00
|
|
|
meta.entityTag = new CompoundTag();
|
|
|
|
meta.entityTag.putBoolean("Small", true);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ meta.setInvisible(true); // Paper
|
|
|
|
cleanStack.setItemMeta(meta);
|
|
|
|
return cleanStack;
|
|
|
|
}
|