mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-28 23:38:25 +01:00
Fix a few issues with ItemMeta (#10740)
This commit is contained in:
parent
10c04efb2a
commit
f5963e84a3
12 changed files with 872 additions and 60 deletions
|
@ -15,8 +15,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ // Paper start - Expose #hasColor to leather armor
|
+ // Paper start - Expose #hasColor to leather armor
|
||||||
+ /**
|
+ /**
|
||||||
+ * Checks whether this leather armor is dyed
|
+ * Checks whether this leather armor is dyed.
|
||||||
+ * (i.e. has a color different from {@link ItemFactory#getDefaultLeatherColor()})
|
|
||||||
+ *
|
+ *
|
||||||
+ * @return whether this leather armor is dyed
|
+ * @return whether this leather armor is dyed
|
||||||
+ */
|
+ */
|
||||||
|
|
|
@ -1498,6 +1498,45 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
*/
|
*/
|
||||||
void setBlockState(@NotNull BlockState blockState);
|
void setBlockState(@NotNull BlockState blockState);
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/inventory/meta/CrossbowMeta.java b/src/main/java/org/bukkit/inventory/meta/CrossbowMeta.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/inventory/meta/CrossbowMeta.java
|
||||||
|
+++ b/src/main/java/org/bukkit/inventory/meta/CrossbowMeta.java
|
||||||
|
@@ -0,0 +0,0 @@ public interface CrossbowMeta extends ItemMeta {
|
||||||
|
* Removes all projectiles when given null.
|
||||||
|
*
|
||||||
|
* @param projectiles the projectiles to set
|
||||||
|
- * @throws IllegalArgumentException if one of the projectiles is not an
|
||||||
|
- * arrow or firework rocket
|
||||||
|
+ * @throws IllegalArgumentException if one of the projectiles is empty
|
||||||
|
*/
|
||||||
|
void setChargedProjectiles(@Nullable List<ItemStack> projectiles);
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public interface CrossbowMeta extends ItemMeta {
|
||||||
|
* Adds a charged projectile to this item.
|
||||||
|
*
|
||||||
|
* @param item projectile
|
||||||
|
- * @throws IllegalArgumentException if the projectile is not an arrow or
|
||||||
|
- * firework rocket
|
||||||
|
+ * @throws IllegalArgumentException if the projectile is empty
|
||||||
|
*/
|
||||||
|
void addChargedProjectile(@NotNull ItemStack item);
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/inventory/meta/FireworkMeta.java b/src/main/java/org/bukkit/inventory/meta/FireworkMeta.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/inventory/meta/FireworkMeta.java
|
||||||
|
+++ b/src/main/java/org/bukkit/inventory/meta/FireworkMeta.java
|
||||||
|
@@ -0,0 +0,0 @@ public interface FireworkMeta extends ItemMeta {
|
||||||
|
* Sets the approximate power of the firework. Each level of power is half
|
||||||
|
* a second of flight time.
|
||||||
|
*
|
||||||
|
- * @param power the power of the firework, from 0-127
|
||||||
|
- * @throws IllegalArgumentException if {@literal height<0 or height>127}
|
||||||
|
+ * @param power the power of the firework, from 0-255
|
||||||
|
+ * @throws IllegalArgumentException if {@literal power < 0 or power > 255}
|
||||||
|
*/
|
||||||
|
void setPower(int power) throws IllegalArgumentException;
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/inventory/meta/ItemMeta.java b/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
diff --git a/src/main/java/org/bukkit/inventory/meta/ItemMeta.java b/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
--- a/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
||||||
|
@ -1522,10 +1561,44 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- * Material#LEATHER_CHESTPLATE}, {@link Material#LEATHER_HELMET}, or {@link
|
- * Material#LEATHER_CHESTPLATE}, {@link Material#LEATHER_HELMET}, or {@link
|
||||||
- * Material#LEATHER_LEGGINGS}) that can be colored.
|
- * Material#LEATHER_LEGGINGS}) that can be colored.
|
||||||
+ * Material#LEATHER_LEGGINGS}, {@link Material#LEATHER_CHESTPLATE}, {@link
|
+ * Material#LEATHER_LEGGINGS}, {@link Material#LEATHER_CHESTPLATE}, {@link
|
||||||
+ * Material#LEATHER_HELMET}, or {@link Material#LEATHER_HORSE_ARMOR}) that can be colored.
|
+ * Material#LEATHER_HELMET}, {@link Material#LEATHER_HORSE_ARMOR}, {@link
|
||||||
|
+ * Material#WOLF_ARMOR}) that can be colored.
|
||||||
*/
|
*/
|
||||||
public interface LeatherArmorMeta extends ItemMeta {
|
public interface LeatherArmorMeta extends ItemMeta {
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public interface LeatherArmorMeta extends ItemMeta {
|
||||||
|
* be {@link ItemFactory#getDefaultLeatherColor()}.
|
||||||
|
*
|
||||||
|
* @return the color of the armor, never null
|
||||||
|
+ * @apiNote The method yielding {@link ItemFactory#getDefaultLeatherColor()} is incorrect
|
||||||
|
+ * for {@link Material#WOLF_ARMOR} as its default color differs. Generally, it is recommended to check
|
||||||
|
+ * {@link #isDyed()} to determined if this leather armor is dyed than to compare this colour to the default.
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
Color getColor();
|
||||||
|
@@ -0,0 +0,0 @@ public interface LeatherArmorMeta extends ItemMeta {
|
||||||
|
/**
|
||||||
|
* Sets the color of the armor.
|
||||||
|
*
|
||||||
|
- * @param color the color to set. Setting it to null is equivalent to
|
||||||
|
- * setting it to {@link ItemFactory#getDefaultLeatherColor()}.
|
||||||
|
+ * @param color the color to set.
|
||||||
|
*/
|
||||||
|
void setColor(@Nullable Color color);
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java b/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java
|
||||||
|
+++ b/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java
|
||||||
|
@@ -0,0 +0,0 @@ package org.bukkit.inventory.meta;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
- * Represents a map that can be scalable.
|
||||||
|
+ * Represents an ominous bottle with an amplifier of the bad omen effect.
|
||||||
|
*/
|
||||||
|
public interface OminousBottleMeta extends ItemMeta {
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/plugin/messaging/PluginMessageRecipient.java b/src/main/java/org/bukkit/plugin/messaging/PluginMessageRecipient.java
|
diff --git a/src/main/java/org/bukkit/plugin/messaging/PluginMessageRecipient.java b/src/main/java/org/bukkit/plugin/messaging/PluginMessageRecipient.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/plugin/messaging/PluginMessageRecipient.java
|
--- a/src/main/java/org/bukkit/plugin/messaging/PluginMessageRecipient.java
|
||||||
|
|
|
@ -973,6 +973,31 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public static final Structure TRIAL_CHAMBERS = getStructure("trial_chambers");
|
public static final Structure TRIAL_CHAMBERS = getStructure("trial_chambers");
|
||||||
|
|
||||||
private static Structure getStructure(String name) {
|
private static Structure getStructure(String name) {
|
||||||
|
diff --git a/src/main/java/org/bukkit/inventory/meta/BundleMeta.java b/src/main/java/org/bukkit/inventory/meta/BundleMeta.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/inventory/meta/BundleMeta.java
|
||||||
|
+++ b/src/main/java/org/bukkit/inventory/meta/BundleMeta.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.jetbrains.annotations.ApiStatus;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
+@org.bukkit.MinecraftExperimental(org.bukkit.MinecraftExperimental.Requires.BUNDLE) // Paper - add missing annotation
|
||||||
|
@ApiStatus.Experimental
|
||||||
|
public interface BundleMeta extends ItemMeta {
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java b/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java
|
||||||
|
+++ b/src/main/java/org/bukkit/inventory/meta/OminousBottleMeta.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.jetbrains.annotations.NotNull;
|
||||||
|
/**
|
||||||
|
* Represents an ominous bottle with an amplifier of the bad omen effect.
|
||||||
|
*/
|
||||||
|
+@org.bukkit.MinecraftExperimental(org.bukkit.MinecraftExperimental.Requires.UPDATE_1_21) // Paper - add missing annotation
|
||||||
|
+@org.jetbrains.annotations.ApiStatus.Experimental // Paper - add missing annotation
|
||||||
|
public interface OminousBottleMeta extends ItemMeta {
|
||||||
|
|
||||||
|
/**
|
||||||
diff --git a/src/main/java/org/bukkit/inventory/meta/trim/TrimPattern.java b/src/main/java/org/bukkit/inventory/meta/trim/TrimPattern.java
|
diff --git a/src/main/java/org/bukkit/inventory/meta/trim/TrimPattern.java b/src/main/java/org/bukkit/inventory/meta/trim/TrimPattern.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/inventory/meta/trim/TrimPattern.java
|
--- a/src/main/java/org/bukkit/inventory/meta/trim/TrimPattern.java
|
||||||
|
|
|
@ -154,7 +154,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
- return this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : this.entityTag == null;
|
- return this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : this.entityTag == null;
|
||||||
+ // Paper start
|
+ // Paper start
|
||||||
+ return this.invisible == that.invisible &&
|
+ return java.util.Objects.equals(this.entityTag, that.entityTag) &&
|
||||||
|
+ this.invisible == that.invisible &&
|
||||||
+ this.noBasePlate == that.noBasePlate &&
|
+ this.noBasePlate == that.noBasePlate &&
|
||||||
+ this.showArms == that.showArms &&
|
+ this.showArms == that.showArms &&
|
||||||
+ this.small == that.small &&
|
+ this.small == that.small &&
|
||||||
|
@ -164,19 +165,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -0,0 +0,0 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
@@ -0,0 +0,0 @@ public class CraftMetaArmorStand extends CraftMetaItem {
|
||||||
final int original;
|
if (this.entityTag != null) {
|
||||||
int hash = original = super.applyHash();
|
hash = 73 * hash + this.entityTag.hashCode();
|
||||||
|
}
|
||||||
- if (this.entityTag != null) {
|
|
||||||
- hash = 73 * hash + this.entityTag.hashCode();
|
|
||||||
- }
|
|
||||||
+ // Paper start
|
+ // Paper start
|
||||||
+ hash += this.entityTag != null ? 73 * hash + this.entityTag.hashCode() : 0;
|
+ hash = 61 * hash + (this.invisible != null ? Boolean.hashCode(this.isInvisible()) : 0);
|
||||||
+ hash += this.isInvisible() ? 61 * hash + 1231 : 0;
|
+ hash = 61 * hash + (this.noBasePlate != null ? Boolean.hashCode(this.hasNoBasePlate()) : 0);
|
||||||
+ hash += this.hasNoBasePlate() ? 61 * hash + 1231 : 0;
|
+ hash = 61 * hash + (this.showArms != null ? Boolean.hashCode(this.shouldShowArms()) : 0);
|
||||||
+ hash += this.shouldShowArms() ? 61 * hash + 1231 : 0;
|
+ hash = 61 * hash + (this.small != null ? Boolean.hashCode(this.isSmall()) : 0);
|
||||||
+ hash += this.isSmall() ? 61 * hash + 1231 : 0;
|
+ hash = 61 * hash + (this.marker != null ? Boolean.hashCode(this.isMarker()) : 0);
|
||||||
+ hash += this.isMarker() ? 61 * hash + 1231 : 0;
|
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
|
||||||
return original != hash ? CraftMetaArmorStand.class.hashCode() ^ hash : hash;
|
return original != hash ? CraftMetaArmorStand.class.hashCode() ^ hash : hash;
|
||||||
|
|
|
@ -98,18 +98,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
this.acceptsAll(Main.asList("nogui"), "Disables the graphical console");
|
this.acceptsAll(Main.asList("nogui"), "Disables the graphical console");
|
||||||
|
|
||||||
this.acceptsAll(Main.asList("nojline"), "Disables jline and emulates the vanilla console");
|
this.acceptsAll(Main.asList("nojline"), "Disables jline and emulates the vanilla console");
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaMap extends CraftMetaItem implements MapMeta {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getMapId() {
|
|
||||||
+ Preconditions.checkState(this.hasMapView(), "Item does not have map associated - check hasMapView() first!"); // Paper - more friendly message
|
|
||||||
return this.mapId;
|
|
||||||
}
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/scheduler/CraftScheduler.java b/src/main/java/org/bukkit/craftbukkit/scheduler/CraftScheduler.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/scheduler/CraftScheduler.java b/src/main/java/org/bukkit/craftbukkit/scheduler/CraftScheduler.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/scheduler/CraftScheduler.java
|
--- a/src/main/java/org/bukkit/craftbukkit/scheduler/CraftScheduler.java
|
||||||
|
|
|
@ -10,7 +10,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
this.checkAttributeList();
|
if (this.attributeModifiers == null) return LinkedHashMultimap.create(); // Paper - don't change the components
|
||||||
SetMultimap<Attribute, AttributeModifier> result = LinkedHashMultimap.create();
|
SetMultimap<Attribute, AttributeModifier> result = LinkedHashMultimap.create();
|
||||||
for (Map.Entry<Attribute, AttributeModifier> entry : this.attributeModifiers.entries()) {
|
for (Map.Entry<Attribute, AttributeModifier> entry : this.attributeModifiers.entries()) {
|
||||||
- if (entry.getValue().getSlot() == null || entry.getValue().getSlot() == slot) {
|
- if (entry.getValue().getSlot() == null || entry.getValue().getSlot() == slot) {
|
||||||
|
|
|
@ -30,6 +30,61 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/inventory/LoomMenu.java b/src/main/java/net/minecraft/world/inventory/LoomMenu.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/inventory/LoomMenu.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/inventory/LoomMenu.java
|
||||||
|
@@ -0,0 +0,0 @@ public class LoomMenu extends AbstractContainerMenu {
|
||||||
|
return stillValid(this.access, player, Blocks.LOOM);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ private static final org.slf4j.Logger LOGGER = com.mojang.logging.LogUtils.getLogger(); // Paper - handle custom banner pattern, skip the event
|
||||||
|
+ private static boolean PRINTED_PATTERN_TYPE_NAG = false; // Paper - handle custom banner pattern, skip the event
|
||||||
|
+
|
||||||
|
@Override
|
||||||
|
public boolean clickMenuButton(net.minecraft.world.entity.player.Player player, int id) {
|
||||||
|
if (id >= 0 && id < this.selectablePatterns.size()) {
|
||||||
|
+ // Paper start - handle custom banner pattern, skip the event (todo remove once this is supported)
|
||||||
|
+ java.util.Optional<org.bukkit.block.banner.PatternType> patternType = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.BANNER_PATTERN, this.selectablePatterns.get(id));
|
||||||
|
+ if (patternType.isEmpty()) {
|
||||||
|
+ if (!PRINTED_PATTERN_TYPE_NAG) {
|
||||||
|
+ LOGGER.warn("A datapack added a custom banner pattern, those are not supported yet in the API, skipping the PlayerLoomPatternSelectEvent for {}.", player.getScoreboardName());
|
||||||
|
+ PRINTED_PATTERN_TYPE_NAG = true;
|
||||||
|
+ }
|
||||||
|
+ this.selectedBannerPatternIndex.set(id);
|
||||||
|
+ this.setupResultSlot((Holder) this.selectablePatterns.get(id));
|
||||||
|
+ return true;
|
||||||
|
+ }
|
||||||
|
+ // Paper end - handle custom banner pattern
|
||||||
|
+
|
||||||
|
// Paper start - Add PlayerLoomPatternSelectEvent
|
||||||
|
int selectablePatternIndex = id;
|
||||||
|
- io.papermc.paper.event.player.PlayerLoomPatternSelectEvent event = new io.papermc.paper.event.player.PlayerLoomPatternSelectEvent((Player) player.getBukkitEntity(), ((CraftInventoryLoom) getBukkitView().getTopInventory()), org.bukkit.craftbukkit.block.banner.CraftPatternType.minecraftHolderToBukkit((this.selectablePatterns.get(selectablePatternIndex))));
|
||||||
|
+ io.papermc.paper.event.player.PlayerLoomPatternSelectEvent event = new io.papermc.paper.event.player.PlayerLoomPatternSelectEvent((Player) player.getBukkitEntity(), ((CraftInventoryLoom) getBukkitView().getTopInventory()), patternType.get());
|
||||||
|
if (!event.callEvent()) {
|
||||||
|
player.containerMenu.sendAllDataToRemote();
|
||||||
|
return false;
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
|
+ ", this can happen if a plugin creates its own registry entry with out properly registering it.");
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start - fixup upstream being dum
|
||||||
|
+ public static <T extends org.bukkit.Keyed, M> java.util.Optional<T> unwrapAndConvertHolder(final io.papermc.paper.registry.RegistryKey<T> registryKey, final Holder<M> value) {
|
||||||
|
+ return unwrapAndConvertHolder(io.papermc.paper.registry.RegistryAccess.registryAccess().getRegistry(registryKey), value);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public static <T extends org.bukkit.Keyed, M> java.util.Optional<T> unwrapAndConvertHolder(final Registry<T> registry, final Holder<M> value) {
|
||||||
|
+ return value.unwrapKey().map(key -> registry.get(CraftNamespacedKey.fromMinecraft(key.location())));
|
||||||
|
+ }
|
||||||
|
+ // Paper end - fixup upstream being dum
|
||||||
|
+
|
||||||
|
// Paper - move to PaperRegistries
|
||||||
|
|
||||||
|
// Paper - NOTE: As long as all uses of the method below relate to *serialization* via ConfigurationSerializable, it's fine
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java b/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java b/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
--- a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
||||||
|
@ -42,6 +97,23 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
// Now also convert from when keys where saved
|
// Now also convert from when keys where saved
|
||||||
return CraftRegistry.get(Registry.ATTRIBUTE, key, ApiVersion.CURRENT);
|
return CraftRegistry.get(Registry.ATTRIBUTE, key, ApiVersion.CURRENT);
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftBanner extends CraftBlockEntityState<BannerBlockEntity> implem
|
||||||
|
if (banner.getPatterns() != null) {
|
||||||
|
for (int i = 0; i < banner.getPatterns().layers().size(); i++) {
|
||||||
|
BannerPatternLayers.Layer p = banner.getPatterns().layers().get(i);
|
||||||
|
- this.patterns.add(new Pattern(DyeColor.getByWoolData((byte) p.color().getId()), CraftPatternType.minecraftHolderToBukkit(p.pattern())));
|
||||||
|
+ // Paper start - fix upstream not handling custom banner pattern
|
||||||
|
+ java.util.Optional<org.bukkit.block.banner.PatternType> type = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.BANNER_PATTERN, p.pattern());
|
||||||
|
+ if (type.isEmpty()) continue;
|
||||||
|
+ this.patterns.add(new Pattern(DyeColor.getByWoolData((byte) p.color().getId()), type.get()));
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
||||||
|
@ -52,24 +124,25 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
||||||
- TrimMaterial trimMaterial = CraftTrimMaterial.minecraftHolderToBukkit(trimCompound.material());
|
- TrimMaterial trimMaterial = CraftTrimMaterial.minecraftHolderToBukkit(trimCompound.material());
|
||||||
- TrimPattern trimPattern = CraftTrimPattern.minecraftHolderToBukkit(trimCompound.pattern());
|
- TrimPattern trimPattern = CraftTrimPattern.minecraftHolderToBukkit(trimCompound.pattern());
|
||||||
+ TrimMaterial trimMaterial = this.unwrapAndConvertHolder(Registry.TRIM_MATERIAL, trimCompound.material()); // Paper - fix upstream not being correct
|
+ TrimMaterial trimMaterial = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(io.papermc.paper.registry.RegistryKey.TRIM_MATERIAL, trimCompound.material()).orElse(null); // Paper - fix upstream not being correct
|
||||||
+ TrimPattern trimPattern = this.unwrapAndConvertHolder(Registry.TRIM_PATTERN, trimCompound.pattern()); // Paper - fix upstream not being correct
|
+ TrimPattern trimPattern = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(io.papermc.paper.registry.RegistryKey.TRIM_PATTERN, trimCompound.pattern()).orElse(null); // Paper - fix upstream not being correct
|
||||||
+ if (trimMaterial == null || trimPattern == null) return; // Paper - just delete the trim because upstream is not doing this right
|
+ if (trimMaterial == null || trimPattern == null) return; // Paper - just delete the trim because upstream is not doing this right
|
||||||
|
|
||||||
this.trim = new ArmorTrim(trimMaterial, trimPattern);
|
this.trim = new ArmorTrim(trimMaterial, trimPattern);
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftMetaArmor extends CraftMetaItem implements ArmorMeta {
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
}
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
});
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
}
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
+ // Paper start - fixup upstream being dum
|
@@ -0,0 +0,0 @@ public class CraftMetaBanner extends CraftMetaItem implements BannerMeta {
|
||||||
+ private <T extends org.bukkit.Keyed, M> T unwrapAndConvertHolder(final Registry<T> registry, final net.minecraft.core.Holder<M> value) {
|
for (int i = 0; i < Math.min(patterns.size(), 20); i++) {
|
||||||
+ return value.unwrap().map(key -> registry.get(org.bukkit.craftbukkit.util.CraftNamespacedKey.fromMinecraft(key.location())), v -> null);
|
BannerPatternLayers.Layer p = patterns.get(i);
|
||||||
+ }
|
DyeColor color = DyeColor.getByWoolData((byte) p.color().getId());
|
||||||
+ // Paper end - fixup upstream being dum
|
- PatternType pattern = CraftPatternType.minecraftHolderToBukkit(p.pattern());
|
||||||
|
+ PatternType pattern = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.BANNER_PATTERN, p.pattern()).orElse(null); // Paper - fix upstream not handling custom banner pattern
|
||||||
|
|
||||||
CraftMetaArmor(Map<String, Object> map) {
|
if (color != null && pattern != null) {
|
||||||
super(map);
|
this.patterns.add(new Pattern(color, pattern));
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
||||||
|
@ -79,17 +152,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
||||||
- this.instrument = CraftMusicInstrument.minecraftHolderToBukkit(instrument);
|
- this.instrument = CraftMusicInstrument.minecraftHolderToBukkit(instrument);
|
||||||
+ this.instrument = this.unwrapAndConvertHolder(org.bukkit.Registry.INSTRUMENT, instrument); // Paper - fix upstream not handling custom instruments
|
+ this.instrument = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.INSTRUMENT, instrument).orElse(null); // Paper - fix upstream not handling custom instruments
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
+ // Paper start - fixup upstream being dum
|
|
||||||
+ private <T extends org.bukkit.Keyed, M> T unwrapAndConvertHolder(final org.bukkit.Registry<T> registry, final net.minecraft.core.Holder<M> value) {
|
|
||||||
+ return value.unwrap().map(key -> registry.get(org.bukkit.craftbukkit.util.CraftNamespacedKey.fromMinecraft(key.location())), v -> null);
|
|
||||||
+ }
|
|
||||||
+ // Paper end - fixup upstream being dum
|
|
||||||
|
|
||||||
CraftMetaMusicInstrument(Map<String, Object> map) {
|
|
||||||
super(map);
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java b/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java b/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
--- a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
||||||
|
|
|
@ -5,6 +5,7 @@ Subject: [PATCH] General ItemMeta fixes
|
||||||
|
|
||||||
== AT ==
|
== AT ==
|
||||||
private-f net/minecraft/world/item/ItemStack components
|
private-f net/minecraft/world/item/ItemStack components
|
||||||
|
public net/minecraft/world/food/FoodProperties DEFAULT_EAT_SECONDS
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
@ -103,6 +104,36 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
((CraftMetaItem) itemMeta).applyToItem(tag);
|
((CraftMetaItem) itemMeta).applyToItem(tag);
|
||||||
item.restorePatch(tag.build());
|
item.restorePatch(tag.build());
|
||||||
|
}
|
||||||
|
- // SpigotCraft#463 this is required now by the Vanilla client, so mimic ItemStack constructor in ensuring it
|
||||||
|
- if (item.getItem() != null && item.getMaxDamage() > 0) {
|
||||||
|
- item.setDamageValue(item.getDamageValue());
|
||||||
|
- }
|
||||||
|
+ // Paper - this is no longer needed
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaAxolotlBucket.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaAxolotlBucket.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaAxolotlBucket.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaAxolotlBucket.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaAxolotlBucket extends CraftMetaItem implements AxolotlBuck
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Axolotl.Variant getVariant() {
|
||||||
|
+ com.google.common.base.Preconditions.checkState(this.hasVariant(), "Variant is absent, check hasVariant first!"); // Paper - fix NPE
|
||||||
|
return Axolotl.Variant.values()[this.variant];
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setVariant(Axolotl.Variant variant) {
|
||||||
|
- if (variant == null) {
|
||||||
|
- variant = Axolotl.Variant.LUCY;
|
||||||
|
- }
|
||||||
|
+ com.google.common.base.Preconditions.checkArgument(variant != null, "Variant cannot be null!"); // Paper
|
||||||
|
this.variant = variant.ordinal();
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
|
@ -155,6 +186,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Material shieldToBannerHack() {
|
private static Material shieldToBannerHack() {
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaBook extends CraftMetaItem implements BookMeta, WritableBo
|
||||||
|
@ItemMetaKey.Specific(ItemMetaKey.Specific.To.NBT)
|
||||||
|
static final ItemMetaKeyType<WritableBookContent> BOOK_CONTENT = new ItemMetaKeyType<>(DataComponents.WRITABLE_BOOK_CONTENT);
|
||||||
|
static final ItemMetaKey BOOK_PAGES = new ItemMetaKey("pages");
|
||||||
|
- static final int MAX_PAGES = Integer.MAX_VALUE; // SPIGOT-6911: Use Minecraft limits
|
||||||
|
+ static final int MAX_PAGES = WritableBookContent.MAX_PAGES; // SPIGOT-6911: Use Minecraft limits // Paper
|
||||||
|
static final int MAX_PAGE_LENGTH = WritableBookContent.PAGE_EDIT_LENGTH; // SPIGOT-6911: Use Minecraft limits
|
||||||
|
|
||||||
|
// We store the pages in their raw original text representation. See SPIGOT-5063, SPIGOT-5350, SPIGOT-3206
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
||||||
|
@ -194,6 +238,108 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.resolved) {
|
if (this.resolved) {
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBundle.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBundle.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBundle.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBundle.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaBundle extends CraftMetaItem implements BundleMeta {
|
||||||
|
bundle.items().forEach((item) -> {
|
||||||
|
ItemStack itemStack = CraftItemStack.asCraftMirror(item);
|
||||||
|
|
||||||
|
- if (!itemStack.getType().isAir()) { // SPIGOT-7174 - Avoid adding air
|
||||||
|
+ if (!itemStack.isEmpty()) { // SPIGOT-7174 - Avoid adding air // Paper
|
||||||
|
this.addItem(itemStack);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaBundle extends CraftMetaItem implements BundleMeta {
|
||||||
|
Iterable<?> items = SerializableMeta.getObject(Iterable.class, map, CraftMetaBundle.ITEMS.BUKKIT, true);
|
||||||
|
if (items != null) {
|
||||||
|
for (Object stack : items) {
|
||||||
|
- if (stack instanceof ItemStack itemStack && !itemStack.getType().isAir()) { // SPIGOT-7174 - Avoid adding air
|
||||||
|
+ if (stack instanceof ItemStack itemStack && !itemStack.isEmpty()) { // SPIGOT-7174 - Avoid adding air // Paper
|
||||||
|
this.addItem(itemStack);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaBundle extends CraftMetaItem implements BundleMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addItem(ItemStack item) {
|
||||||
|
- Preconditions.checkArgument(item != null && !item.getType().isAir(), "item is null or air");
|
||||||
|
+ Preconditions.checkArgument(item != null && !item.isEmpty(), "item is null or empty"); // Paper
|
||||||
|
|
||||||
|
if (this.items == null) {
|
||||||
|
this.items = new ArrayList<>();
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaColorableArmor.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaColorableArmor.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaColorableArmor.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaColorableArmor.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaColorableArmor extends CraftMetaArmor implements Colorable
|
||||||
|
Material.WOLF_ARMOR
|
||||||
|
);
|
||||||
|
|
||||||
|
- private Color color = DEFAULT_LEATHER_COLOR;
|
||||||
|
+ private Integer color; // Paper - keep color component consistent with vanilla (top bytes are ignored)
|
||||||
|
|
||||||
|
CraftMetaColorableArmor(CraftMetaItem meta) {
|
||||||
|
super(meta);
|
||||||
|
- CraftMetaLeatherArmor.readColor(this, meta);
|
||||||
|
+ // Paper start
|
||||||
|
+ if (!(meta instanceof CraftMetaColorableArmor armorMeta)) {
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.color = armorMeta.color;
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
|
||||||
|
CraftMetaColorableArmor(DataComponentPatch tag, java.util.Set<net.minecraft.core.component.DataComponentType<?>> extraHandledDcts) { // Paper
|
||||||
|
super(tag, extraHandledDcts); // Paper
|
||||||
|
- CraftMetaLeatherArmor.readColor(this, tag);
|
||||||
|
+ // Paper start
|
||||||
|
+ getOrEmpty(tag, CraftMetaLeatherArmor.COLOR).ifPresent((dyedItemColor) -> {
|
||||||
|
+ if (!dyedItemColor.showInTooltip()) {
|
||||||
|
+ this.addItemFlags(org.bukkit.inventory.ItemFlag.HIDE_DYE);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.color = dyedItemColor.rgb();
|
||||||
|
+ });
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
|
||||||
|
CraftMetaColorableArmor(Map<String, Object> map) {
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaColorableArmor extends CraftMetaArmor implements Colorable
|
||||||
|
@Override
|
||||||
|
void applyToItem(CraftMetaItem.Applicator itemTag) {
|
||||||
|
super.applyToItem(itemTag);
|
||||||
|
- CraftMetaLeatherArmor.applyColor(this, itemTag);
|
||||||
|
+ // Paper start
|
||||||
|
+ if (this.hasColor()) {
|
||||||
|
+ itemTag.put(CraftMetaLeatherArmor.COLOR, new net.minecraft.world.item.component.DyedItemColor(this.color, !this.hasItemFlag(org.bukkit.inventory.ItemFlag.HIDE_DYE)));
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaColorableArmor extends CraftMetaArmor implements Colorable
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Color getColor() {
|
||||||
|
- return this.color;
|
||||||
|
+ return this.color == null ? DEFAULT_LEATHER_COLOR : Color.fromRGB(this.color & 0xFFFFFF); // Paper - this should really be nullable
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setColor(Color color) {
|
||||||
|
- this.color = color == null ? DEFAULT_LEATHER_COLOR : color;
|
||||||
|
+ this.color = color == null ? null : color.asRGB(); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean hasColor() {
|
||||||
|
- return CraftMetaLeatherArmor.hasColor(this);
|
||||||
|
+ return this.color != null; // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCompass.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCompass.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCompass.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCompass.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCompass.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCompass.java
|
||||||
|
@ -231,10 +377,68 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCrossbow.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCrossbow.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCrossbow.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaCrossbow.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaCrossbow extends CraftMetaItem implements CrossbowMeta {
|
||||||
|
@Override
|
||||||
|
public void addChargedProjectile(ItemStack item) {
|
||||||
|
Preconditions.checkArgument(item != null, "item");
|
||||||
|
- Preconditions.checkArgument(item.getType() == Material.FIREWORK_ROCKET || CraftItemType.bukkitToMinecraft(item.getType()) instanceof ArrowItem, "Item %s is not an arrow or firework rocket", item);
|
||||||
|
+ Preconditions.checkArgument(!item.isEmpty(), "Item cannot be empty"); // Paper
|
||||||
|
|
||||||
|
if (this.chargedProjectiles == null) {
|
||||||
|
this.chargedProjectiles = new ArrayList<>();
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaEntityTag.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaEntityTag.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaEntityTag.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaEntityTag.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaEntityTag extends CraftMetaItem {
|
||||||
|
if (meta instanceof CraftMetaEntityTag) {
|
||||||
|
CraftMetaEntityTag that = (CraftMetaEntityTag) meta;
|
||||||
|
|
||||||
|
- return this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : this.entityTag == null;
|
||||||
|
+ return this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : that.entityTag == null; // Paper
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
|
||||||
|
this.power = that.power;
|
||||||
|
|
||||||
|
- if (that.hasEffects()) {
|
||||||
|
+ if (that.effects != null) { // Paper
|
||||||
|
this.effects = new ArrayList<>(that.effects);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
.with(CraftMetaFirework.getEffectType(explosion.shape()));
|
||||||
|
|
||||||
|
IntList colors = explosion.colors();
|
||||||
|
- // People using buggy command generators specify a list rather than an int here, so recover with dummy data.
|
||||||
|
- // Wrong: Colors: [1234]
|
||||||
|
- // Right: Colors: [I;1234]
|
||||||
|
- if (colors.isEmpty()) {
|
||||||
|
- effect.withColor(Color.WHITE);
|
||||||
|
- }
|
||||||
|
+ // Paper - this is no longer needed
|
||||||
|
|
||||||
|
for (int color : colors) {
|
||||||
|
- effect.withColor(Color.fromRGB(color));
|
||||||
|
+ effect.withColor(Color.fromRGB(color & 0xFFFFFF)); // Paper - try to keep color component consistent with vanilla (top bytes are ignored), this will however change the color component for out of bound color
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int color : explosion.fadeColors()) {
|
||||||
|
- effect.withFade(Color.fromRGB(color));
|
||||||
|
+ effect.withFade(Color.fromRGB(color & 0xFFFFFF)); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
return effect.build();
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -285,6 +489,42 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
itemTag.put(CraftMetaFirework.FIREWORKS, new Fireworks(this.power, effects));
|
itemTag.put(CraftMetaFirework.FIREWORKS, new Fireworks(this.power, effects));
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean isFireworkEmpty() {
|
||||||
|
- return !(this.hasEffects() || this.hasPower());
|
||||||
|
+ return !(this.effects != null || this.hasPower()); // Paper - empty effects list should stay on the item
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean hasPower() {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
if (meta instanceof CraftMetaFirework that) {
|
||||||
|
|
||||||
|
return (this.hasPower() ? that.hasPower() && this.power == that.power : !that.hasPower())
|
||||||
|
- && (this.hasEffects() ? that.hasEffects() && this.effects.equals(that.effects) : !that.hasEffects());
|
||||||
|
+ && (this.effects != null ? that.effects != null && this.effects.equals(that.effects) : that.effects == null); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
if (this.hasPower()) {
|
||||||
|
hash = 61 * hash + this.power;
|
||||||
|
}
|
||||||
|
- if (this.hasEffects()) {
|
||||||
|
+ if (this.effects != null) { // Paper
|
||||||
|
hash = 61 * hash + 13 * this.effects.hashCode();
|
||||||
|
}
|
||||||
|
return hash != original ? CraftMetaFirework.class.hashCode() ^ hash : hash;
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
Builder<String, Object> serialize(Builder<String, Object> builder) {
|
||||||
|
super.serialize(builder);
|
||||||
|
|
||||||
|
- if (this.hasEffects()) {
|
||||||
|
+ if (this.effects != null) { // Paper
|
||||||
|
builder.put(CraftMetaFirework.EXPLOSIONS.BUKKIT, ImmutableList.copyOf(this.effects));
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
@Override
|
@Override
|
||||||
public void addEffect(FireworkEffect effect) {
|
public void addEffect(FireworkEffect effect) {
|
||||||
|
@ -313,6 +553,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaFirework extends CraftMetaItem implements FireworkMeta {
|
||||||
|
@Override
|
||||||
|
public void setPower(int power) {
|
||||||
|
Preconditions.checkArgument(power >= 0, "power cannot be less than zero: %s", power);
|
||||||
|
- Preconditions.checkArgument(power < 0x80, "power cannot be more than 127: %s", power);
|
||||||
|
+ Preconditions.checkArgument(power <= 0xFF, "power cannot be more than 255: %s", power); // Paper - set correct limit
|
||||||
|
this.power = power;
|
||||||
|
}
|
||||||
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
@ -406,6 +655,93 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (lore == null) {
|
if (lore == null) {
|
||||||
this.lore = null;
|
this.lore = null;
|
||||||
} else {
|
} else {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FoodComponent getFood() {
|
||||||
|
- return (this.hasFood()) ? new CraftFoodComponent(this.food) : new CraftFoodComponent(new FoodProperties(0, 0, false, 0, Collections.emptyList()));
|
||||||
|
+ return (this.hasFood()) ? new CraftFoodComponent(this.food) : new CraftFoodComponent(new FoodProperties(0, 0, false, FoodProperties.DEFAULT_EAT_SECONDS, Collections.emptyList())); // Paper - create a valid food properties
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Multimap<Attribute, AttributeModifier> getAttributeModifiers(@Nullable EquipmentSlot slot) {
|
||||||
|
- this.checkAttributeList();
|
||||||
|
+ if (this.attributeModifiers == null) return LinkedHashMultimap.create(); // Paper - don't change the components
|
||||||
|
SetMultimap<Attribute, AttributeModifier> result = LinkedHashMultimap.create();
|
||||||
|
for (Map.Entry<Attribute, AttributeModifier> entry : this.attributeModifiers.entries()) {
|
||||||
|
if (entry.getValue().getSlot() == null || entry.getValue().getSlot() == slot) {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
@Override
|
||||||
|
public Collection<AttributeModifier> getAttributeModifiers(@Nonnull Attribute attribute) {
|
||||||
|
Preconditions.checkNotNull(attribute, "Attribute cannot be null");
|
||||||
|
+ if (this.attributeModifiers == null) return null; // Paper - fix NPE
|
||||||
|
return this.attributeModifiers.containsKey(attribute) ? ImmutableList.copyOf(this.attributeModifiers.get(attribute)) : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
public boolean addAttributeModifier(@Nonnull Attribute attribute, @Nonnull AttributeModifier modifier) {
|
||||||
|
Preconditions.checkNotNull(attribute, "Attribute cannot be null");
|
||||||
|
Preconditions.checkNotNull(modifier, "AttributeModifier cannot be null");
|
||||||
|
- this.checkAttributeList();
|
||||||
|
+ if (this.attributeModifiers != null) { // Paper
|
||||||
|
for (Map.Entry<Attribute, AttributeModifier> entry : this.attributeModifiers.entries()) {
|
||||||
|
Preconditions.checkArgument(!(entry.getValue().getUniqueId().equals(modifier.getUniqueId()) && entry.getKey() == attribute), "Cannot register AttributeModifier. Modifier is already applied! %s", modifier); // Paper
|
||||||
|
}
|
||||||
|
+ } // Paper
|
||||||
|
+ this.checkAttributeList(); // Paper - moved down
|
||||||
|
return this.attributeModifiers.put(attribute, modifier);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
- this.checkAttributeList();
|
||||||
|
- this.attributeModifiers.clear();
|
||||||
|
+ // Paper start - fix modifiers meta
|
||||||
|
+ if (this.attributeModifiers != null) {
|
||||||
|
+ this.attributeModifiers.clear();
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
|
||||||
|
Iterator<Map.Entry<Attribute, AttributeModifier>> iterator = attributeModifiers.entries().iterator();
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
iterator.remove();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
+ this.checkAttributeList(); // Paper - moved down
|
||||||
|
this.attributeModifiers.put(next.getKey(), next.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
@Override
|
||||||
|
public boolean removeAttributeModifier(@Nonnull Attribute attribute) {
|
||||||
|
Preconditions.checkNotNull(attribute, "Attribute cannot be null");
|
||||||
|
- this.checkAttributeList();
|
||||||
|
+ if (this.attributeModifiers == null) return false; // Paper
|
||||||
|
return !this.attributeModifiers.removeAll(attribute).isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean removeAttributeModifier(@Nullable EquipmentSlot slot) {
|
||||||
|
- this.checkAttributeList();
|
||||||
|
+ if (this.attributeModifiers == null) return false; // Paper
|
||||||
|
int removed = 0;
|
||||||
|
Iterator<Map.Entry<Attribute, AttributeModifier>> iter = this.attributeModifiers.entries().iterator();
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
public boolean removeAttributeModifier(@Nonnull Attribute attribute, @Nonnull AttributeModifier modifier) {
|
||||||
|
Preconditions.checkNotNull(attribute, "Attribute cannot be null");
|
||||||
|
Preconditions.checkNotNull(modifier, "AttributeModifier cannot be null");
|
||||||
|
- this.checkAttributeList();
|
||||||
|
+ if (this.attributeModifiers == null) return false; // Paper
|
||||||
|
int removed = 0;
|
||||||
|
Iterator<Map.Entry<Attribute, AttributeModifier>> iter = this.attributeModifiers.entries().iterator();
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -432,6 +768,23 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
for (Map.Entry<Attribute, AttributeModifier> entry : first.entries()) {
|
for (Map.Entry<Attribute, AttributeModifier> entry : first.entries()) {
|
||||||
if (!second.containsEntry(entry.getKey(), entry.getValue())) {
|
if (!second.containsEntry(entry.getKey(), entry.getValue())) {
|
||||||
return false;
|
return false;
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setDamage(int damage) {
|
||||||
|
+ Preconditions.checkArgument(damage >= 0, "Damage cannot be negative"); // Paper
|
||||||
|
+ Preconditions.checkArgument(!this.hasMaxDamage() || damage <= this.maxDamage, "Damage cannot exceed max damage"); // Paper
|
||||||
|
this.damage = damage;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setMaxDamage(Integer maxDamage) {
|
||||||
|
+ Preconditions.checkArgument(maxDamage == null || maxDamage > 0, "Max damage should be positive"); // Paper
|
||||||
|
this.maxDamage = maxDamage;
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
&& (this.hasCustomModelData() ? that.hasCustomModelData() && this.customModelData.equals(that.customModelData) : !that.hasCustomModelData())
|
&& (this.hasCustomModelData() ? that.hasCustomModelData() && this.customModelData.equals(that.customModelData) : !that.hasCustomModelData())
|
||||||
&& (this.hasBlockData() ? that.hasBlockData() && this.blockData.equals(that.blockData) : !that.hasBlockData())
|
&& (this.hasBlockData() ? that.hasBlockData() && this.blockData.equals(that.blockData) : !that.hasBlockData())
|
||||||
|
@ -442,10 +795,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
&& (Objects.equals(this.customTag, that.customTag))
|
&& (Objects.equals(this.customTag, that.customTag))
|
||||||
&& (this.persistentDataContainer.equals(that.persistentDataContainer))
|
&& (this.persistentDataContainer.equals(that.persistentDataContainer))
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
hash = 61 * hash + (this.hasRarity() ? this.rarity.hashCode() : 0);
|
||||||
hash = 61 * hash + (this.hasFood() ? this.food.hashCode() : 0);
|
hash = 61 * hash + (this.hasFood() ? this.food.hashCode() : 0);
|
||||||
hash = 61 * hash + (this.hasDamage() ? this.damage : 0);
|
hash = 61 * hash + (this.hasDamage() ? this.damage : 0);
|
||||||
hash = 61 * hash + (this.hasMaxDamage() ? 1231 : 1237);
|
- hash = 61 * hash + (this.hasMaxDamage() ? 1231 : 1237);
|
||||||
- hash = 61 * hash + (this.hasAttributeModifiers() ? this.attributeModifiers.hashCode() : 0);
|
- hash = 61 * hash + (this.hasAttributeModifiers() ? this.attributeModifiers.hashCode() : 0);
|
||||||
|
+ hash = 61 * hash + (this.hasMaxDamage() ? this.maxDamage.hashCode() : 0); // Paper - max damage is not a boolean
|
||||||
+ hash = 61 * hash + (this.attributeModifiers != null ? this.attributeModifiers.hashCode() : 0); // Paper - track only null attributes
|
+ hash = 61 * hash + (this.attributeModifiers != null ? this.attributeModifiers.hashCode() : 0); // Paper - track only null attributes
|
||||||
hash = 61 * hash + (this.canPlaceOnPredicates != null ? this.canPlaceOnPredicates.hashCode() : 0); // Paper
|
hash = 61 * hash + (this.canPlaceOnPredicates != null ? this.canPlaceOnPredicates.hashCode() : 0); // Paper
|
||||||
hash = 61 * hash + (this.canBreakPredicates != null ? this.canBreakPredicates.hashCode() : 0); // Paper
|
hash = 61 * hash + (this.canBreakPredicates != null ? this.canBreakPredicates.hashCode() : 0); // Paper
|
||||||
|
@ -477,6 +832,215 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
CraftMetaItem.NAME.TYPE,
|
CraftMetaItem.NAME.TYPE,
|
||||||
CraftMetaItem.ITEM_NAME.TYPE,
|
CraftMetaItem.ITEM_NAME.TYPE,
|
||||||
CraftMetaItem.LORE.TYPE,
|
CraftMetaItem.LORE.TYPE,
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaLeatherArmor.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaLeatherArmor.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaLeatherArmor.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaLeatherArmor.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaLeatherArmor extends CraftMetaItem implements LeatherArmorMeta {
|
||||||
|
|
||||||
|
static final ItemMetaKeyType<DyedItemColor> COLOR = new ItemMetaKeyType<>(DataComponents.DYED_COLOR, "color");
|
||||||
|
|
||||||
|
- private Color color = DEFAULT_LEATHER_COLOR;
|
||||||
|
+ private Integer color; // Paper - keep color component consistent with vanilla (top bytes are ignored)
|
||||||
|
|
||||||
|
CraftMetaLeatherArmor(CraftMetaItem meta) {
|
||||||
|
super(meta);
|
||||||
|
- CraftMetaLeatherArmor.readColor(this, meta);
|
||||||
|
+ // Paper start
|
||||||
|
+ if (!(meta instanceof CraftMetaLeatherArmor leatherMeta)) {
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.color = leatherMeta.color;
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
|
||||||
|
CraftMetaLeatherArmor(DataComponentPatch tag, java.util.Set<net.minecraft.core.component.DataComponentType<?>> extraHandledDcts) { // Paper
|
||||||
|
super(tag, extraHandledDcts); // Paper
|
||||||
|
- CraftMetaLeatherArmor.readColor(this, tag);
|
||||||
|
+ // Paper start
|
||||||
|
+ getOrEmpty(tag, CraftMetaLeatherArmor.COLOR).ifPresent((dyedItemColor) -> {
|
||||||
|
+ if (!dyedItemColor.showInTooltip()) {
|
||||||
|
+ this.addItemFlags(ItemFlag.HIDE_DYE);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.color = dyedItemColor.rgb();
|
||||||
|
+ });
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
|
||||||
|
CraftMetaLeatherArmor(Map<String, Object> map) {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaLeatherArmor extends CraftMetaItem implements LeatherArmorMeta {
|
||||||
|
@Override
|
||||||
|
void applyToItem(CraftMetaItem.Applicator itemTag) {
|
||||||
|
super.applyToItem(itemTag);
|
||||||
|
- CraftMetaLeatherArmor.applyColor(this, itemTag);
|
||||||
|
+ // Paper start
|
||||||
|
+ if (this.hasColor()) {
|
||||||
|
+ itemTag.put(CraftMetaLeatherArmor.COLOR, new DyedItemColor(this.color, !this.hasItemFlag(ItemFlag.HIDE_DYE)));
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaLeatherArmor extends CraftMetaItem implements LeatherArmorMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Color getColor() {
|
||||||
|
- return this.color;
|
||||||
|
+ return this.color == null ? DEFAULT_LEATHER_COLOR : Color.fromRGB(this.color & 0xFFFFFF); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setColor(Color color) {
|
||||||
|
- this.color = color == null ? DEFAULT_LEATHER_COLOR : color;
|
||||||
|
+ this.color = color == null ? null : color.asRGB(); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean hasColor() {
|
||||||
|
- return CraftMetaLeatherArmor.hasColor(this);
|
||||||
|
+ return this.color != null; // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaLeatherArmor extends CraftMetaItem implements LeatherArmorMeta {
|
||||||
|
return original != hash ? CraftMetaLeatherArmor.class.hashCode() ^ hash : hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @io.papermc.paper.annotation.DoNotUse // Paper
|
||||||
|
static void readColor(LeatherArmorMeta meta, CraftMetaItem other) {
|
||||||
|
if (!(other instanceof CraftMetaLeatherArmor armorMeta)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
- meta.setColor(armorMeta.color);
|
||||||
|
+ // meta.setColor(armorMeta.color); // Paper - commented out, color is now an integer and cannot be passed to setColor
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @io.papermc.paper.annotation.DoNotUse // Paper
|
||||||
|
static void readColor(LeatherArmorMeta meta, DataComponentPatch tag) {
|
||||||
|
getOrEmpty(tag, CraftMetaLeatherArmor.COLOR).ifPresent((dyedItemColor) -> {
|
||||||
|
if (!dyedItemColor.showInTooltip()) {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaLeatherArmor extends CraftMetaItem implements LeatherArmorMeta {
|
||||||
|
return !DEFAULT_LEATHER_COLOR.equals(meta.getColor());
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @io.papermc.paper.annotation.DoNotUse // Paper
|
||||||
|
static void applyColor(LeatherArmorMeta meta, CraftMetaItem.Applicator tag) {
|
||||||
|
if (CraftMetaLeatherArmor.hasColor(meta)) {
|
||||||
|
tag.put(CraftMetaLeatherArmor.COLOR, new DyedItemColor(meta.getColor().asRGB(), !meta.hasItemFlag(ItemFlag.HIDE_DYE)));
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMap.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaMap extends CraftMetaItem implements MapMeta {
|
||||||
|
|
||||||
|
private Integer mapId;
|
||||||
|
private byte scaling = CraftMetaMap.SCALING_EMPTY;
|
||||||
|
- private Color color;
|
||||||
|
+ private Integer color; // Paper - keep color component consistent with vanilla (top bytes are ignored)
|
||||||
|
|
||||||
|
CraftMetaMap(CraftMetaItem meta) {
|
||||||
|
super(meta);
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaMap extends CraftMetaItem implements MapMeta {
|
||||||
|
|
||||||
|
getOrEmpty(tag, CraftMetaMap.MAP_COLOR).ifPresent((mapColor) -> {
|
||||||
|
try {
|
||||||
|
- this.color = Color.fromRGB(mapColor.rgb());
|
||||||
|
+ this.color = mapColor.rgb(); // Paper
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// Invalid colour
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaMap extends CraftMetaItem implements MapMeta {
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.hasColor()) {
|
||||||
|
- tag.put(CraftMetaMap.MAP_COLOR, new MapItemColor(this.color.asRGB()));
|
||||||
|
+ tag.put(CraftMetaMap.MAP_COLOR, new MapItemColor(this.color)); // Paper
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaMap extends CraftMetaItem implements MapMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMapId() {
|
||||||
|
+ Preconditions.checkState(this.hasMapId(), "Item does not have map associated - check hasMapId() first!"); // Paper - fix NPE
|
||||||
|
return this.mapId;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaMap extends CraftMetaItem implements MapMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Color getColor() {
|
||||||
|
- return this.color;
|
||||||
|
+ return this.color == null ? null : Color.fromRGB(this.color & 0xFFFFFF); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setColor(Color color) {
|
||||||
|
- this.color = color;
|
||||||
|
+ this.color = color == null ? null : color.asRGB(); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaOminousBottle extends CraftMetaItem implements OminousBott
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAmplifier() {
|
||||||
|
+ Preconditions.checkState(this.hasAmplifier(), "'ominous_bottle_amplifier' data component is absent. Check hasAmplifier first!"); // Paper - fix NPE
|
||||||
|
return this.ominousBottleAmplifier;
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaPotion.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaPotion.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaPotion.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaPotion.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaPotion extends CraftMetaItem implements PotionMeta {
|
||||||
|
|
||||||
|
private PotionType type;
|
||||||
|
private List<PotionEffect> customEffects;
|
||||||
|
- private Color color;
|
||||||
|
+ private Integer color; // Paper - keep color component consistent with vanilla (top bytes are ignored)
|
||||||
|
|
||||||
|
CraftMetaPotion(CraftMetaItem meta) {
|
||||||
|
super(meta);
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaPotion extends CraftMetaItem implements PotionMeta {
|
||||||
|
|
||||||
|
potionContents.customColor().ifPresent((customColor) -> {
|
||||||
|
try {
|
||||||
|
- this.color = Color.fromRGB(customColor);
|
||||||
|
+ this.color = customColor; // Paper
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// Invalid colour
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaPotion extends CraftMetaItem implements PotionMeta {
|
||||||
|
super.applyToItem(tag);
|
||||||
|
|
||||||
|
Optional<Holder<Potion>> defaultPotion = (this.hasBasePotionType()) ? Optional.of(CraftPotionType.bukkitToMinecraftHolder(this.type)) : Optional.empty();
|
||||||
|
- Optional<Integer> potionColor = (this.hasColor()) ? Optional.of(this.color.asRGB()) : Optional.empty();
|
||||||
|
+ Optional<Integer> potionColor = (this.hasColor()) ? Optional.of(this.color) : Optional.empty(); // Paper
|
||||||
|
|
||||||
|
List<MobEffectInstance> effectList = new ArrayList<>();
|
||||||
|
if (this.customEffects != null) {
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaPotion extends CraftMetaItem implements PotionMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Color getColor() {
|
||||||
|
- return this.color;
|
||||||
|
+ return this.color == null ? null : Color.fromRGB(this.color & 0xFFFFFF); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setColor(Color color) {
|
||||||
|
- this.color = color;
|
||||||
|
+ this.color = color == null ? null : color.asRGB(); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
||||||
|
@ -495,6 +1059,57 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaSpawnEgg extends CraftMetaItem implements SpawnEggMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntitySnapshot getSpawnedEntity() {
|
||||||
|
+ if (this.entityTag == null) return null; // Paper - fix NPE
|
||||||
|
return CraftEntitySnapshot.create(this.entityTag);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaSpawnEgg extends CraftMetaItem implements SpawnEggMeta {
|
||||||
|
if (meta instanceof CraftMetaSpawnEgg) {
|
||||||
|
CraftMetaSpawnEgg that = (CraftMetaSpawnEgg) meta;
|
||||||
|
|
||||||
|
- return this.hasSpawnedType() ? that.hasSpawnedType() && this.spawnedType.equals(that.spawnedType) : !that.hasSpawnedType()
|
||||||
|
- && this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : this.entityTag == null;
|
||||||
|
+ return (this.hasSpawnedType() ? that.hasSpawnedType() && this.spawnedType.equals(that.spawnedType) : !that.hasSpawnedType()) // Paper
|
||||||
|
+ && (this.entityTag != null ? that.entityTag != null && this.entityTag.equals(that.entityTag) : that.entityTag == null); // Paper
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaTropicalFishBucket.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaTropicalFishBucket.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaTropicalFishBucket.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaTropicalFishBucket.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaTropicalFishBucket extends CraftMetaItem implements TropicalFishB
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DyeColor getPatternColor() {
|
||||||
|
+ com.google.common.base.Preconditions.checkState(this.hasVariant(), "This bucket doesn't have variant, check hasVariant first!"); // Paper - fix NPE
|
||||||
|
return CraftTropicalFish.getPatternColor(this.variant);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaTropicalFishBucket extends CraftMetaItem implements TropicalFishB
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DyeColor getBodyColor() {
|
||||||
|
+ com.google.common.base.Preconditions.checkState(this.hasVariant(), "This bucket doesn't have variant, check hasVariant first!"); // Paper - fix NPE
|
||||||
|
return CraftTropicalFish.getBodyColor(this.variant);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaTropicalFishBucket extends CraftMetaItem implements TropicalFishB
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TropicalFish.Pattern getPattern() {
|
||||||
|
+ com.google.common.base.Preconditions.checkState(this.hasVariant(), "This bucket doesn't have variant, check hasVariant first!"); // Paper - fix NPE
|
||||||
|
return CraftTropicalFish.getPattern(this.variant);
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/SerializableMeta.java b/src/main/java/org/bukkit/craftbukkit/inventory/SerializableMeta.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/SerializableMeta.java b/src/main/java/org/bukkit/craftbukkit/inventory/SerializableMeta.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/SerializableMeta.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/SerializableMeta.java
|
||||||
|
@ -533,6 +1148,14 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
this.handle = new FoodProperties(this.handle.nutrition(), this.handle.saturation(), this.handle.canAlwaysEat(), eatSeconds, this.handle.effects());
|
this.handle = new FoodProperties(this.handle.nutrition(), this.handle.saturation(), this.handle.canAlwaysEat(), eatSeconds, this.handle.effects());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public final class CraftFoodComponent implements FoodComponent {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FoodEffect addEffect(PotionEffect effect, float probability) {
|
||||||
|
+ Preconditions.checkArgument(0 <= probability && probability <= 1, "Probability cannot be outside range [0,1]"); // Paper
|
||||||
|
List<FoodProperties.PossibleEffect> effects = new ArrayList<>(this.handle.effects());
|
||||||
|
|
||||||
|
FoodProperties.PossibleEffect newEffect = new net.minecraft.world.food.FoodProperties.PossibleEffect(CraftPotionUtil.fromBukkit(effect), probability);
|
||||||
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/DeprecatedItemMetaCustomValueTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/DeprecatedItemMetaCustomValueTest.java
|
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/DeprecatedItemMetaCustomValueTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/DeprecatedItemMetaCustomValueTest.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/test/java/org/bukkit/craftbukkit/inventory/DeprecatedItemMetaCustomValueTest.java
|
--- a/src/test/java/org/bukkit/craftbukkit/inventory/DeprecatedItemMetaCustomValueTest.java
|
||||||
|
@ -546,6 +1169,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
itemMeta.applyToItem(compound);
|
itemMeta.applyToItem(compound);
|
||||||
|
|
||||||
assertEquals(itemMeta, new CraftMetaItem(compound.build(), null)); // Paper
|
assertEquals(itemMeta, new CraftMetaItem(compound.build(), null)); // Paper
|
||||||
|
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
||||||
|
+++ b/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
public class ItemMetaTest extends AbstractTestingBase {
|
||||||
|
|
||||||
|
- static final int MAX_FIREWORK_POWER = 127; // Please update ItemStackFireworkTest if/when this gets changed.
|
||||||
|
+ static final int MAX_FIREWORK_POWER = 255; // Please update ItemStackFireworkTest if/when this gets changed. // Paper - it changed
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testPowerLimitExact() {
|
||||||
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/PersistentDataContainerTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/PersistentDataContainerTest.java
|
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/PersistentDataContainerTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/PersistentDataContainerTest.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/test/java/org/bukkit/craftbukkit/inventory/PersistentDataContainerTest.java
|
--- a/src/test/java/org/bukkit/craftbukkit/inventory/PersistentDataContainerTest.java
|
||||||
|
|
|
@ -95,14 +95,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- ItemEnchantments list = CraftItemStack.getEnchantmentList(this.handle);
|
- ItemEnchantments list = CraftItemStack.getEnchantmentList(this.handle);
|
||||||
- if (list == null) {
|
- if (list == null) {
|
||||||
- list = ItemEnchantments.EMPTY;
|
- list = ItemEnchantments.EMPTY;
|
||||||
- }
|
+ // Paper start - Replace whole method
|
||||||
|
+ final ItemMeta itemMeta = this.getItemMeta();
|
||||||
|
+ if (itemMeta != null) {
|
||||||
|
+ itemMeta.addEnchant(ench, level, true);
|
||||||
|
+ this.setItemMeta(itemMeta);
|
||||||
|
}
|
||||||
- ItemEnchantments.Mutable listCopy = new ItemEnchantments.Mutable(list);
|
- ItemEnchantments.Mutable listCopy = new ItemEnchantments.Mutable(list);
|
||||||
- listCopy.set(CraftEnchantment.bukkitToMinecraft(ench), level);
|
- listCopy.set(CraftEnchantment.bukkitToMinecraft(ench), level);
|
||||||
- this.handle.set(DataComponents.ENCHANTMENTS, listCopy.toImmutable());
|
- this.handle.set(DataComponents.ENCHANTMENTS, listCopy.toImmutable());
|
||||||
+ // Paper start - Replace whole method
|
|
||||||
+ final ItemMeta itemMeta = this.getItemMeta();
|
|
||||||
+ itemMeta.addEnchant(ench, level, true);
|
|
||||||
+ this.setItemMeta(itemMeta);
|
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@ public net.minecraft.world.entity.projectile.Projectile hasBeenShot
|
||||||
public net.minecraft.world.entity.projectile.Projectile leftOwner
|
public net.minecraft.world.entity.projectile.Projectile leftOwner
|
||||||
public net.minecraft.world.entity.projectile.Projectile preOnHit(Lnet/minecraft/world/phys/HitResult;)V
|
public net.minecraft.world.entity.projectile.Projectile preOnHit(Lnet/minecraft/world/phys/HitResult;)V
|
||||||
public net.minecraft.world.entity.projectile.Projectile canHitEntity(Lnet/minecraft/world/entity/Entity;)Z
|
public net.minecraft.world.entity.projectile.Projectile canHitEntity(Lnet/minecraft/world/entity/Entity;)Z
|
||||||
|
public net.minecraft.world.entity.projectile.FireworkRocketEntity getDefaultItem()Lnet/minecraft/world/item/ItemStack;
|
||||||
|
|
||||||
Co-authored-by: Nassim Jahnke <nassim@njahnke.dev>
|
Co-authored-by: Nassim Jahnke <nassim@njahnke.dev>
|
||||||
|
|
||||||
|
@ -203,6 +204,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntityTypes.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntityTypes.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntityTypes.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntityTypes.java
|
||||||
|
@@ -0,0 +0,0 @@ public final class CraftEntityTypes {
|
||||||
|
BlockPos pos = BlockPos.containing(spawnData.x(), spawnData.y(), spawnData.z());
|
||||||
|
return new FallingBlockEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), spawnData.world().getBlockState(pos)); // Paper - create falling block entities correctly
|
||||||
|
}));
|
||||||
|
- register(new EntityTypeData<>(EntityType.FIREWORK_ROCKET, Firework.class, CraftFirework::new, spawnData -> new FireworkRocketEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), net.minecraft.world.item.ItemStack.EMPTY)));
|
||||||
|
+ register(new EntityTypeData<>(EntityType.FIREWORK_ROCKET, Firework.class, CraftFirework::new, spawnData -> new FireworkRocketEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), FireworkRocketEntity.getDefaultItem()))); // Paper - pass correct default to rocket for data storage
|
||||||
|
register(new EntityTypeData<>(EntityType.EVOKER_FANGS, EvokerFangs.class, CraftEvokerFangs::new, spawnData -> new net.minecraft.world.entity.projectile.EvokerFangs(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), (float) Math.toRadians(spawnData.yaw()), 0, null)));
|
||||||
|
register(new EntityTypeData<>(EntityType.COMMAND_BLOCK_MINECART, CommandMinecart.class, CraftMinecartCommand::new, spawnData -> new MinecartCommandBlock(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z())));
|
||||||
|
register(new EntityTypeData<>(EntityType.MINECART, RideableMinecart.class, CraftMinecartRideable::new, spawnData -> new Minecart(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z())));
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftFireball.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftFireball.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftFireball.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftFireball.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftFireball.java
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftFireball.java
|
||||||
|
@ -356,6 +370,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity {
|
||||||
|
} else if (Firework.class.isAssignableFrom(projectile)) {
|
||||||
|
Location location = this.getEyeLocation();
|
||||||
|
|
||||||
|
- launch = new FireworkRocketEntity(world, net.minecraft.world.item.ItemStack.EMPTY, this.getHandle());
|
||||||
|
+ launch = new FireworkRocketEntity(world, FireworkRocketEntity.getDefaultItem(), this.getHandle()); // Paper - pass correct default to rocket for data storage
|
||||||
|
launch.moveTo(location.getX(), location.getY(), location.getZ(), location.getYaw(), location.getPitch());
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLlamaSpit.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLlamaSpit.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLlamaSpit.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLlamaSpit.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLlamaSpit.java
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLlamaSpit.java
|
||||||
|
|
|
@ -50,10 +50,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
BlockPos pos = BlockPos.containing(spawnData.x(), spawnData.y(), spawnData.z());
|
BlockPos pos = BlockPos.containing(spawnData.x(), spawnData.y(), spawnData.z());
|
||||||
return new FallingBlockEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), spawnData.world().getBlockState(pos)); // Paper - create falling block entities correctly
|
return new FallingBlockEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), spawnData.world().getBlockState(pos)); // Paper - create falling block entities correctly
|
||||||
}));
|
}));
|
||||||
- register(new EntityTypeData<>(EntityType.FIREWORK_ROCKET, Firework.class, CraftFirework::new, spawnData -> new FireworkRocketEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), net.minecraft.world.item.ItemStack.EMPTY)));
|
- register(new EntityTypeData<>(EntityType.FIREWORK_ROCKET, Firework.class, CraftFirework::new, spawnData -> new FireworkRocketEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), FireworkRocketEntity.getDefaultItem()))); // Paper - pass correct default to rocket for data storage
|
||||||
+ // Paper start - respect randomizeData
|
+ // Paper start - respect randomizeData
|
||||||
+ register(new EntityTypeData<>(EntityType.FIREWORK_ROCKET, Firework.class, CraftFirework::new, spawnData -> {
|
+ register(new EntityTypeData<>(EntityType.FIREWORK_ROCKET, Firework.class, CraftFirework::new, spawnData -> {
|
||||||
+ FireworkRocketEntity entity = new FireworkRocketEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), net.minecraft.world.item.ItemStack.EMPTY);
|
+ FireworkRocketEntity entity = new FireworkRocketEntity(spawnData.minecraftWorld(), spawnData.x(), spawnData.y(), spawnData.z(), FireworkRocketEntity.getDefaultItem()); // Paper - pass correct default to rocket for data storage
|
||||||
+ if (!spawnData.randomizeData()) {
|
+ if (!spawnData.randomizeData()) {
|
||||||
+ // logic below was taken from FireworkRocketEntity constructor
|
+ // logic below was taken from FireworkRocketEntity constructor
|
||||||
+ entity.setDeltaMovement(0, 0.05, 0);
|
+ entity.setDeltaMovement(0, 0.05, 0);
|
||||||
|
|
|
@ -192,7 +192,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ super(tag, extraHandledDcts); // Paper
|
+ super(tag, extraHandledDcts); // Paper
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
||||||
TrimMaterial trimMaterial = this.unwrapAndConvertHolder(Registry.TRIM_MATERIAL, trimCompound.material()); // Paper - fix upstream not being correct
|
TrimMaterial trimMaterial = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(io.papermc.paper.registry.RegistryKey.TRIM_MATERIAL, trimCompound.material()).orElse(null); // Paper - fix upstream not being correct
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
||||||
|
@ -626,7 +626,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ super(tag, extraHandledDcts); // Paper
|
+ super(tag, extraHandledDcts); // Paper
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
||||||
this.instrument = this.unwrapAndConvertHolder(org.bukkit.Registry.INSTRUMENT, instrument); // Paper - fix upstream not handling custom instruments
|
this.instrument = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.INSTRUMENT, instrument).orElse(null); // Paper - fix upstream not handling custom instruments
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
|
|
Loading…
Reference in a new issue