From ac137edbc70818f89cb4e8ae2a042a750aef0be7 Mon Sep 17 00:00:00 2001 From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com> Date: Sat, 12 Mar 2022 15:34:03 -0500 Subject: [PATCH] Ensure the item sent isn't air (#7584) --- patches/server/More-Projectile-API.patch | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/patches/server/More-Projectile-API.patch b/patches/server/More-Projectile-API.patch index df4cc40547..ac56713421 100644 --- a/patches/server/More-Projectile-API.patch +++ b/patches/server/More-Projectile-API.patch @@ -60,11 +60,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 @Override public void setFireworkMeta(FireworkMeta meta) { - this.item.setItemMeta(meta); - + applyFireworkEffect(meta); // Paper - Expose firework item directly + // Copied from EntityFireworks constructor, update firework lifetime/power this.getHandle().lifetime = 10 * (1 + meta.getPower()) + this.random.nextInt(6) + this.random.nextInt(7); - @@ -0,0 +0,0 @@ public class CraftFirework extends CraftProjectile implements Firework { return boostedEntity != null ? (org.bukkit.entity.LivingEntity) boostedEntity.getBukkitEntity() : null; } @@ -78,7 +77,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + @Override + public void setItem(org.bukkit.inventory.ItemStack itemStack) { + FireworkMeta meta = getFireworkMeta(); -+ var nmsItem = itemStack == null ? ItemStack.EMPTY : CraftItemStack.asNMSCopy(itemStack); ++ ItemStack nmsItem = itemStack == null ? ItemStack.EMPTY : CraftItemStack.asNMSCopy(itemStack); + this.getHandle().getEntityData().set(FireworkRocketEntity.DATA_ID_FIREWORKS_ITEM, nmsItem); + + applyFireworkEffect(meta); @@ -105,7 +104,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + } + + void applyFireworkEffect(FireworkMeta meta) { -+ CraftItemStack.applyMetaToItem(this.getHandle().getEntityData().get(FireworkRocketEntity.DATA_ID_FIREWORKS_ITEM), meta); ++ ItemStack item = this.getHandle().getItem(); ++ CraftItemStack.applyMetaToItem(item, meta); ++ ++ this.getHandle().getEntityData().set(FireworkRocketEntity.DATA_ID_FIREWORKS_ITEM, item); + } + // Paper end - Expose firework item directly + manually setting flight } @@ -133,8 +135,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + + @Override + public void setPotionMeta(org.bukkit.inventory.meta.PotionMeta meta) { -+ CraftItemStack.applyMetaToItem(this.getHandle().getItemRaw(), meta); -+ this.getHandle().setItem(this.getHandle().getItemRaw()); // Reset item ++ net.minecraft.world.item.ItemStack item = this.getHandle().getItem(); ++ CraftItemStack.applyMetaToItem(item, meta); ++ this.getHandle().setItem(item); // Reset item + } + // Paper end @Override