From c7d8f7c896148a046b298ad0acb7e314aa0f6c51 Mon Sep 17 00:00:00 2001 From: Erik Zimmermann Date: Sat, 17 Aug 2024 13:19:03 +0200 Subject: [PATCH] Fix AnvilGUI for 1.21.1 (spigot, paper) --- pom.xml | 12 +++++------ .../codingapi/player/gui/anvil/AnvilGUI.java | 20 ++++++++++--------- 2 files changed, 17 insertions(+), 15 deletions(-) diff --git a/pom.xml b/pom.xml index 5b4c50f..dada910 100644 --- a/pom.xml +++ b/pom.xml @@ -31,6 +31,12 @@ + + org.jetbrains + annotations + 22.0.0 + compile + net.md-5 bungeecord-api @@ -57,12 +63,6 @@ 1.20.3-R0.1-SNAPSHOT provided - - org.jetbrains - annotations - 23.0.0 - compile - com.mojang authlib diff --git a/src/main/java/de/codingair/codingapi/player/gui/anvil/AnvilGUI.java b/src/main/java/de/codingair/codingapi/player/gui/anvil/AnvilGUI.java index aba6739..67d4376 100644 --- a/src/main/java/de/codingair/codingapi/player/gui/anvil/AnvilGUI.java +++ b/src/main/java/de/codingair/codingapi/player/gui/anvil/AnvilGUI.java @@ -56,7 +56,7 @@ public class AnvilGUI implements Removable { ENTITY_PLAYER_CLASS = PacketUtils.EntityPlayerClass; assert ENTITY_PLAYER_CLASS != null; - Class craftInventoryViewClass = IReflection.getClass(IReflection.ServerPacket.CRAFTBUKKIT_PACKAGE, "inventory.CraftInventoryView"); + Class craftInventoryViewClass = IReflection.getClass(IReflection.ServerPacket.CRAFTBUKKIT_PACKAGE, Version.choose("inventory.CraftInventoryView", 21.1, "inventory.view.CraftAnvilView")); PACKET_PLAY_OUT_OPEN_WINDOW_CLASS = IReflection.getClass(IReflection.ServerPacket.PACKETS, "PacketPlayOutOpenWindow"); CONTAINER_CLASS = IReflection.getClass(IReflection.ServerPacket.INVENTORY, "Container"); @@ -124,7 +124,8 @@ public AnvilGUI(JavaPlugin plugin, Player player, AnvilListener listener, String this.title = title == null ? "Repair & Name" : title; registerBukkitListener(); - if (Version.get().isBiggerThan(8)) Bukkit.getPluginManager().registerEvents(prepareListener = new PrepareAnvilEventHelp(), this.plugin); + if (Version.get().isBiggerThan(8)) + Bukkit.getPluginManager().registerEvents(prepareListener = new PrepareAnvilEventHelp(), this.plugin); } public AnvilGUI(JavaPlugin plugin, Player player, AnvilListener listener) { @@ -169,7 +170,7 @@ private void registerBukkitListener() { this.bukkitListener = new Listener() { private final Map slotType = new HashMap<>(); - @EventHandler (priority = EventPriority.LOWEST) + @EventHandler(priority = EventPriority.LOWEST) public void onInventoryClickBefore(InventoryClickEvent e) { if (e.getWhoClicked() instanceof Player) { Player p = (Player) e.getWhoClicked(); @@ -182,7 +183,7 @@ public void onInventoryClickBefore(InventoryClickEvent e) { } } - @EventHandler (priority = EventPriority.HIGHEST) + @EventHandler(priority = EventPriority.HIGHEST) public void onInventoryClick(InventoryClickEvent e) { if (e.getWhoClicked() instanceof Player) { Player p = (Player) e.getWhoClicked(); @@ -196,7 +197,8 @@ public void onInventoryClick(InventoryClickEvent e) { ItemStack item = inv.getItem(AnvilSlot.OUTPUT.getSlot()); int slot = e.getRawSlot(); - if (AnvilSlot.bySlot(slot) == AnvilSlot.OUTPUT && (item == null || item.getType() == Material.AIR) && onlyWithChanges) return; + if (AnvilSlot.bySlot(slot) == AnvilSlot.OUTPUT && (item == null || item.getType() == Material.AIR) && onlyWithChanges) + return; AnvilClickEvent clickEvent = new AnvilClickEvent(p, e.getClick(), AnvilSlot.bySlot(slot), item, AnvilGUI.this); if (listener != null) listener.onClick(clickEvent); @@ -265,7 +267,7 @@ public AnvilGUI open() { Object container; if (Version.get().isBiggerThan(Version.v1_13)) { Class containerAccessClass = IReflection.getClass(IReflection.ServerPacket.INVENTORY, "ContainerAccess"); - IReflection.MethodAccessor at = IReflection.getMethod(containerAccessClass, containerAccessClass, new Class[] {WORLD_CLASS, BLOCK_POSITION_CLASS}); + IReflection.MethodAccessor at = IReflection.getMethod(containerAccessClass, containerAccessClass, new Class[]{WORLD_CLASS, BLOCK_POSITION_CLASS}); Object containerAccess = at.invoke(null, world, blockPosition); container = ANVIL_CONTAINER_CON.newInstance(c, inventory, containerAccess); @@ -296,7 +298,7 @@ public AnvilGUI open() { } else { IReflection.ConstructorAccessor packetPlayOutOpenWindowCon = IReflection.getConstructor(PACKET_PLAY_OUT_OPEN_WINDOW_CLASS, Integer.class, String.class, CHAT_MESSAGE_CLASS, int.class); assert packetPlayOutOpenWindowCon != null; - PacketUtils.sendPacket(this.player, packetPlayOutOpenWindowCon.newInstance(c, "minecraft:anvil", CHAT_MESSAGE_CON.newInstance("AnvilGUI", new Object[] {}), 0)); + PacketUtils.sendPacket(this.player, packetPlayOutOpenWindowCon.newInstance(c, "minecraft:anvil", CHAT_MESSAGE_CON.newInstance("AnvilGUI", new Object[]{}), 0)); } } catch (Exception e) { plugin.getLogger().log(Level.SEVERE, "Error: Cannot open the AnvilGUI in " + Version.get().name() + "!", e); @@ -306,10 +308,10 @@ public AnvilGUI open() { InventoryUtils.setWindowId(container, c); if (Version.atLeast(17)) { - IReflection.MethodAccessor initMenu = IReflection.getMethod(ENTITY_PLAYER_CLASS, (Class) null, new Class[] {CONTAINER_CLASS}); + IReflection.MethodAccessor initMenu = IReflection.getMethod(ENTITY_PLAYER_CLASS, (Class) null, new Class[]{CONTAINER_CLASS}); initMenu.invoke(entityPlayer, container); } else { - IReflection.MethodAccessor addSlotListener = IReflection.getMethod(CONTAINER_CLASS, "addSlotListener", new Class[] {ENTITY_PLAYER_CLASS}); + IReflection.MethodAccessor addSlotListener = IReflection.getMethod(CONTAINER_CLASS, "addSlotListener", new Class[]{ENTITY_PLAYER_CLASS}); addSlotListener.invoke(InventoryUtils.getActiveContainer(entityPlayer), entityPlayer); }