From ca7b87f466ecd86892bd6db3854b2a543d81a208 Mon Sep 17 00:00:00 2001 From: Chaoscaot Date: Wed, 24 Mar 2021 21:45:35 +0100 Subject: [PATCH 1/8] Minor DT Rework --- .../steamwar/bausystem/world/Detonator.java | 67 ++++++++++++++++--- .../bausystem/world/DetonatorListener.java | 55 +++++++-------- 2 files changed, 84 insertions(+), 38 deletions(-) diff --git a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java index b3918e8..bc89942 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java @@ -28,6 +28,7 @@ import org.bukkit.Bukkit; import org.bukkit.Location; import org.bukkit.Material; import org.bukkit.NamespacedKey; +import org.bukkit.craftbukkit.v1_15_R1.inventory.CraftItemStack; import org.bukkit.entity.Player; import org.bukkit.event.Listener; import org.bukkit.inventory.ItemStack; @@ -50,7 +51,11 @@ public class Detonator implements Listener { im.setDisplayName("§eFernzünder"); - VersionedRunnable.call(new VersionedRunnable(() -> im.getPersistentDataContainer().set(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE, (byte) 1), 15)); + VersionedRunnable.call( + new VersionedRunnable(() -> { + im.getPersistentDataContainer().set(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE, (byte) 1); + im.getPersistentDataContainer().set(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER, 0); + }, 15)); List lorelist = Arrays.asList("§eLinks Klick §8- §7Setzte einen Punkt zum Aktivieren", "§eLinks Klick + Shift §8- §7Füge einen Punkt hinzu", "§eRechts Klick §8- §7Löse alle Punkte aus"); @@ -65,8 +70,9 @@ public class Detonator implements Listener { }, 12), new VersionedCallable<>(() -> { ItemMeta meta = item.getItemMeta(); PersistentDataContainer container = meta.getPersistentDataContainer(); + player.sendMessage(CraftItemStack.asNMSCopy(item).getTag().toString()); List locs = new ArrayList<>(); - for (int i = 0; i < 128; i++) { + for (int i = 0; i < getDetoLocs(container); i++) { NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i); if (container.has(key, PersistentDataType.INTEGER_ARRAY)) locs.add(container.get(key, PersistentDataType.INTEGER_ARRAY)); @@ -94,7 +100,7 @@ public class Detonator implements Listener { }, 12), new VersionedCallable<>(() -> removeLocation(item, location), 15)); } else { DetonatorListener.print(player, detoloader.addBack ? "§e" + detoloader.getBlock() + " hinzugefügt" : - detoloader.getBlock(), Math.min(Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() + 1, 128)); + detoloader.getBlock(), Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() + 1); if (detoloader.getActivation() == 0) return VersionedCallable.call(new VersionedCallable<>(() -> { PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).add(new Detoloader.DetonatorActivation(location)); @@ -110,11 +116,32 @@ public class Detonator implements Listener { public static void execute(Player player) { VersionedRunnable.call(new VersionedRunnable(() -> execute(player, PLAYER_LOCS.get(player)), 12), new VersionedRunnable(() -> { - Detonator detonator = getDetonator(player, player.getInventory().getItemInMainHand()); + ItemStack item = getNextBestDetonator(player); + if(item == null) + return; + Detonator detonator = getDetonator(player, item); execute(player, detonator.getLocs()); }, 15)); } + private static ItemStack getNextBestDetonator(Player player) { + if(player.getInventory().getItemInMainHand().getItemMeta() != null && player.getInventory().getItemInMainHand().getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + return player.getInventory().getItemInMainHand(); + } + + for (ItemStack item : player.getInventory().getContents()) { + if(item == null) + continue; + + if(item.getItemMeta() != null && + item.getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + return item; + } + } + player.sendMessage(BauSystem.PREFIX + "§cDu hast keinen Detonator im Inventar"); + return null; + } + private static void execute(Player player, Set locs) { for (Detoloader.DetonatorActivation activation : locs) { @@ -141,22 +168,45 @@ public class Detonator implements Listener { private static int getFreeSlot(ItemStack item) { ItemMeta meta = item.getItemMeta(); + if(meta == null) { + throw new SecurityException("Das Item ist kein Detonator"); + } PersistentDataContainer container = meta.getPersistentDataContainer(); - for (int i = 0; i < 128; i++) { + if(!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + throw new SecurityException("Das Item ist kein Detonator"); + } + for (int i = 0; i < getDetoLocs(container) + 1; i++) { if (!container.has(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i), PersistentDataType.INTEGER_ARRAY)) return i; } return -1; } + private static int getDetoLocs(PersistentDataContainer container) { + if(!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + throw new SecurityException("Das Item ist kein Detonator"); + } + return container.get(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER); + } + + private static void increaseLocsSize(PersistentDataContainer container, int to) { + if(!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + throw new SecurityException("Das Item ist kein Detonator"); + } + if(container.get(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER) < to) { + container.set(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER, to); + } + } + public static ItemStack pushLocToDetonator(ItemStack item, Detoloader.DetonatorActivation detoloader) { int slot = getFreeSlot(item); if (slot == -1) - throw new SecurityException("Der Detonator ist auf 128 Positionen Limitiert"); + throw new SecurityException("Ein Fehler ist aufgetreten"); ItemMeta meta = item.getItemMeta(); Location block = detoloader.location; meta.getPersistentDataContainer().set(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + slot), PersistentDataType.INTEGER_ARRAY, new int[] {block.getBlockX(), block.getBlockY(), block.getBlockZ(), detoloader.activation}); + increaseLocsSize(meta.getPersistentDataContainer(), slot + 1); item.setItemMeta(meta); return item; } @@ -164,7 +214,8 @@ public class Detonator implements Listener { public static ItemStack clearDetonator(ItemStack item) { ItemMeta meta = item.getItemMeta(); PersistentDataContainer container = meta.getPersistentDataContainer(); - for (int i = 0; i < 128; i++) { + container.set(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER, 0); + for (int i = 0; i < getDetoLocs(container); i++) { NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i); container.remove(key); } @@ -179,7 +230,7 @@ public class Detonator implements Listener { private static int getSlotOfLocation(ItemStack item, Location location) { ItemMeta meta = item.getItemMeta(); PersistentDataContainer container = meta.getPersistentDataContainer(); - for (int i = 0; i < 128; i++) { + for (int i = 0; i < getDetoLocs(container); i++) { NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i); if (container.has(key, PersistentDataType.INTEGER_ARRAY)) { int[] locs = container.get(key, PersistentDataType.INTEGER_ARRAY); diff --git a/BauSystem_Main/src/de/steamwar/bausystem/world/DetonatorListener.java b/BauSystem_Main/src/de/steamwar/bausystem/world/DetonatorListener.java index fb0b1c6..dced125 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/world/DetonatorListener.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/world/DetonatorListener.java @@ -27,40 +27,35 @@ public class DetonatorListener implements Listener { } ItemStack item = event.getItem(); event.setCancelled(true); - try { - switch (event.getAction()) { - case LEFT_CLICK_BLOCK: - Detoloader detoloader = VersionedCallable.call( - new VersionedCallable<>(() -> AutoLoader_12.onPlayerInteractLoader(event), 12), - new VersionedCallable<>(() -> AutoLoader_15.onPlayerInteractLoader(event), 15)); + switch (event.getAction()) { + case LEFT_CLICK_BLOCK: + Detoloader detoloader = VersionedCallable.call( + new VersionedCallable<>(() -> AutoLoader_12.onPlayerInteractLoader(event), 12), + new VersionedCallable<>(() -> AutoLoader_15.onPlayerInteractLoader(event), 15)); - if (detoloader == null) { - return; - } else if (detoloader.activation == -1) { - print(player, detoloader.getBlock(), detoloader.addBack ? Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() : 0); - return; - } + if (detoloader == null) { + return; + } else if (detoloader.activation == -1) { + print(player, detoloader.getBlock(), detoloader.addBack ? Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() : 0); + return; + } - if (event.getPlayer().isSneaking()) { - player.getInventory().setItemInMainHand(Detonator.toggleLocation(item, player, detoloader, event.getClickedBlock().getLocation())); + if (event.getPlayer().isSneaking()) { + player.getInventory().setItemInMainHand(Detonator.toggleLocation(item, player, detoloader, event.getClickedBlock().getLocation())); + } else { + if (detoloader.getActivation() == 0) { + player.getInventory().setItemInMainHand(Detonator.setLocation(player, item, new Detoloader.DetonatorActivation(event.getClickedBlock().getLocation()))); } else { - if (detoloader.getActivation() == 0) { - player.getInventory().setItemInMainHand(Detonator.setLocation(player, item, new Detoloader.DetonatorActivation(event.getClickedBlock().getLocation()))); - } else { - player.getInventory().setItemInMainHand(Detonator.setLocation(player, item, new Detoloader.DetonatorActivation(detoloader.activation, event.getClickedBlock().getLocation()))); - } - print(player, detoloader.addBack ? "§e" + detoloader.getBlock() + " gesetzt" : - detoloader.getBlock(), detoloader.addBack ? Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() : 0); + player.getInventory().setItemInMainHand(Detonator.setLocation(player, item, new Detoloader.DetonatorActivation(detoloader.activation, event.getClickedBlock().getLocation()))); } - break; - case RIGHT_CLICK_AIR: - case RIGHT_CLICK_BLOCK: - Detonator.execute(player); - break; - } - } catch (RuntimeException e) { - player.sendMessage(BauSystem.PREFIX + "§c" + e.getMessage()); - player.getInventory().setItemInMainHand(item); + print(player, detoloader.addBack ? "§e" + detoloader.getBlock() + " gesetzt" : + detoloader.getBlock(), detoloader.addBack ? Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() : 0); + } + break; + case RIGHT_CLICK_AIR: + case RIGHT_CLICK_BLOCK: + Detonator.execute(player); + break; } } } From b533e27b854328f7015c0832bf07b3cbb86d6f90 Mon Sep 17 00:00:00 2001 From: Chaoscaot Date: Thu, 25 Mar 2021 07:54:43 +0100 Subject: [PATCH 2/8] Removing Debug Messages --- .../de/steamwar/bausystem/world/Detonator.java | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java index bc89942..fe445c3 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java @@ -28,7 +28,6 @@ import org.bukkit.Bukkit; import org.bukkit.Location; import org.bukkit.Material; import org.bukkit.NamespacedKey; -import org.bukkit.craftbukkit.v1_15_R1.inventory.CraftItemStack; import org.bukkit.entity.Player; import org.bukkit.event.Listener; import org.bukkit.inventory.ItemStack; @@ -70,7 +69,6 @@ public class Detonator implements Listener { }, 12), new VersionedCallable<>(() -> { ItemMeta meta = item.getItemMeta(); PersistentDataContainer container = meta.getPersistentDataContainer(); - player.sendMessage(CraftItemStack.asNMSCopy(item).getTag().toString()); List locs = new ArrayList<>(); for (int i = 0; i < getDetoLocs(container); i++) { NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i); @@ -116,11 +114,15 @@ public class Detonator implements Listener { public static void execute(Player player) { VersionedRunnable.call(new VersionedRunnable(() -> execute(player, PLAYER_LOCS.get(player)), 12), new VersionedRunnable(() -> { - ItemStack item = getNextBestDetonator(player); - if(item == null) - return; - Detonator detonator = getDetonator(player, item); - execute(player, detonator.getLocs()); + try { + ItemStack item = getNextBestDetonator(player); + if(item == null) + return; + Detonator detonator = getDetonator(player, item); + execute(player, detonator.getLocs()); + }catch (SecurityException e) { + player.sendMessage(BauSystem.PREFIX + "§c" + e.getMessage()); + } }, 15)); } From 0f970e3a4926565a83b652d3b105ee7e8cc2383a Mon Sep 17 00:00:00 2001 From: yoyosource Date: Thu, 25 Mar 2021 08:47:21 +0100 Subject: [PATCH 3/8] Reformat Detonator --- .../steamwar/bausystem/world/Detonator.java | 20 +++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java index fe445c3..bc2cd42 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java @@ -116,26 +116,26 @@ public class Detonator implements Listener { VersionedRunnable.call(new VersionedRunnable(() -> execute(player, PLAYER_LOCS.get(player)), 12), new VersionedRunnable(() -> { try { ItemStack item = getNextBestDetonator(player); - if(item == null) + if (item == null) return; Detonator detonator = getDetonator(player, item); execute(player, detonator.getLocs()); - }catch (SecurityException e) { + } catch (SecurityException e) { player.sendMessage(BauSystem.PREFIX + "§c" + e.getMessage()); } }, 15)); } private static ItemStack getNextBestDetonator(Player player) { - if(player.getInventory().getItemInMainHand().getItemMeta() != null && player.getInventory().getItemInMainHand().getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + if (player.getInventory().getItemInMainHand().getItemMeta() != null && player.getInventory().getItemInMainHand().getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { return player.getInventory().getItemInMainHand(); } for (ItemStack item : player.getInventory().getContents()) { - if(item == null) + if (item == null) continue; - if(item.getItemMeta() != null && + if (item.getItemMeta() != null && item.getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { return item; } @@ -170,11 +170,11 @@ public class Detonator implements Listener { private static int getFreeSlot(ItemStack item) { ItemMeta meta = item.getItemMeta(); - if(meta == null) { + if (meta == null) { throw new SecurityException("Das Item ist kein Detonator"); } PersistentDataContainer container = meta.getPersistentDataContainer(); - if(!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + if (!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { throw new SecurityException("Das Item ist kein Detonator"); } for (int i = 0; i < getDetoLocs(container) + 1; i++) { @@ -185,17 +185,17 @@ public class Detonator implements Listener { } private static int getDetoLocs(PersistentDataContainer container) { - if(!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + if (!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { throw new SecurityException("Das Item ist kein Detonator"); } return container.get(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER); } private static void increaseLocsSize(PersistentDataContainer container, int to) { - if(!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + if (!container.has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { throw new SecurityException("Das Item ist kein Detonator"); } - if(container.get(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER) < to) { + if (container.get(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER) < to) { container.set(new NamespacedKey(BauSystem.getPlugin(), "deto-locs"), PersistentDataType.INTEGER, to); } } From af87505532cb67d3a2395c67672ee0840f1ed5dd Mon Sep 17 00:00:00 2001 From: Chaoscaot Date: Thu, 25 Mar 2021 13:47:53 +0100 Subject: [PATCH 4/8] Add Offhand --- BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java index fe445c3..36dd6e9 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java @@ -131,6 +131,10 @@ public class Detonator implements Listener { return player.getInventory().getItemInMainHand(); } + if(player.getInventory().getItemInOffHand().getItemMeta() != null && player.getInventory().getItemInOffHand().getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) { + return player.getInventory().getItemInOffHand(); + } + for (ItemStack item : player.getInventory().getContents()) { if(item == null) continue; From 139bf287644c76addab5ac96e8d3120571e1435f Mon Sep 17 00:00:00 2001 From: yoyosource Date: Sat, 27 Mar 2021 08:23:46 +0100 Subject: [PATCH 5/8] Add TPSLimit to any Entity except Player --- .../src/de/steamwar/bausystem/commands/TPSLimit_12.java | 4 ++-- .../src/de/steamwar/bausystem/commands/TPSLimit_15.java | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/BauSystem_12/src/de/steamwar/bausystem/commands/TPSLimit_12.java b/BauSystem_12/src/de/steamwar/bausystem/commands/TPSLimit_12.java index b7e5272..cfe3928 100644 --- a/BauSystem_12/src/de/steamwar/bausystem/commands/TPSLimit_12.java +++ b/BauSystem_12/src/de/steamwar/bausystem/commands/TPSLimit_12.java @@ -24,7 +24,7 @@ import org.bukkit.Bukkit; import org.bukkit.World; import org.bukkit.craftbukkit.v1_12_R1.entity.CraftEntity; import org.bukkit.craftbukkit.v1_12_R1.entity.CraftPlayer; -import org.bukkit.entity.FallingBlock; +import org.bukkit.entity.Player; import org.bukkit.entity.TNTPrimed; import java.util.ArrayList; @@ -36,7 +36,7 @@ class TPSLimit_12 { static void createTickCache(World world) { packets.clear(); - world.getEntitiesByClasses(TNTPrimed.class, FallingBlock.class).forEach(entity -> { + world.getEntities().stream().filter(entity -> !(entity instanceof Player)).forEach(entity -> { packets.add(new PacketPlayOutEntityVelocity(entity.getEntityId(), 0, 0, 0)); packets.add(new PacketPlayOutEntityTeleport(((CraftEntity) entity).getHandle())); diff --git a/BauSystem_15/src/de/steamwar/bausystem/commands/TPSLimit_15.java b/BauSystem_15/src/de/steamwar/bausystem/commands/TPSLimit_15.java index 04cd25c..344bcf9 100644 --- a/BauSystem_15/src/de/steamwar/bausystem/commands/TPSLimit_15.java +++ b/BauSystem_15/src/de/steamwar/bausystem/commands/TPSLimit_15.java @@ -24,7 +24,7 @@ import org.bukkit.Bukkit; import org.bukkit.World; import org.bukkit.craftbukkit.v1_15_R1.entity.CraftEntity; import org.bukkit.craftbukkit.v1_15_R1.entity.CraftPlayer; -import org.bukkit.entity.FallingBlock; +import org.bukkit.entity.Player; import org.bukkit.entity.TNTPrimed; import java.util.ArrayList; @@ -37,7 +37,7 @@ class TPSLimit_15 { static void createTickCache(World world) { packets.clear(); - world.getEntitiesByClasses(TNTPrimed.class, FallingBlock.class).forEach(entity -> { + world.getEntities().stream().filter(entity -> !(entity instanceof Player)).forEach(entity -> { packets.add(new PacketPlayOutEntityVelocity(entity.getEntityId(), noMotion)); packets.add(new PacketPlayOutEntityTeleport(((CraftEntity) entity).getHandle())); From f3511e784174e988a426c81b6a161772c764d6cd Mon Sep 17 00:00:00 2001 From: Chaoscaot Date: Sat, 27 Mar 2021 12:54:57 +0100 Subject: [PATCH 6/8] ._. --- .../src/de/steamwar/bausystem/commands/CommandDetonator.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/BauSystem_Main/src/de/steamwar/bausystem/commands/CommandDetonator.java b/BauSystem_Main/src/de/steamwar/bausystem/commands/CommandDetonator.java index 0785385..1528920 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/commands/CommandDetonator.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/commands/CommandDetonator.java @@ -33,7 +33,7 @@ public class CommandDetonator implements CommandExecutor { private void help(Player player) { player.sendMessage("§8/§edetonator wand §8- §7Legt den Fernzünder ins Inventar"); - player.sendMessage("§8/§edetonator detonate §8- §7Benutzt den Fernzünder"); + player.sendMessage("§8/§edetonator detonate §8- §7Benutzt den nächst besten Fernzünder"); player.sendMessage("§8/§edetonator reset §8- §7Löscht alle markierten Positionen"); player.sendMessage("§8/§edetonator remove §8- §7Entfernt den Fernzünder"); } From 59ff3a9529fbbc7cda31cbec2b582b562ccc5302 Mon Sep 17 00:00:00 2001 From: Chaoscaot Date: Sat, 27 Mar 2021 13:39:14 +0100 Subject: [PATCH 7/8] ._. --- BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java index ec70b4c..4f98875 100644 --- a/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java +++ b/BauSystem_Main/src/de/steamwar/bausystem/world/Detonator.java @@ -182,8 +182,9 @@ public class Detonator implements Listener { throw new SecurityException("Das Item ist kein Detonator"); } for (int i = 0; i < getDetoLocs(container) + 1; i++) { - if (!container.has(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i), PersistentDataType.INTEGER_ARRAY)) + if (!container.has(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i), PersistentDataType.INTEGER_ARRAY)) { return i; + } } return -1; } From 2c2022ec8f4b003d559c1208b4f55bc82c2ec689 Mon Sep 17 00:00:00 2001 From: Lixfel Date: Tue, 30 Mar 2021 21:01:32 +0200 Subject: [PATCH 8/8] Fix 1.12 tracer you idiot --- .../src/de/steamwar/bausystem/tracer/TraceEntity_12.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/BauSystem_12/src/de/steamwar/bausystem/tracer/TraceEntity_12.java b/BauSystem_12/src/de/steamwar/bausystem/tracer/TraceEntity_12.java index c42cf23..d39c62f 100644 --- a/BauSystem_12/src/de/steamwar/bausystem/tracer/TraceEntity_12.java +++ b/BauSystem_12/src/de/steamwar/bausystem/tracer/TraceEntity_12.java @@ -49,7 +49,7 @@ class TraceEntity_12 extends EntityFallingBlock implements AbstractTraceEntity { } else if (references++ > 0) return; - PacketPlayOutSpawnEntity packetPlayOutSpawnEntity = new PacketPlayOutSpawnEntity(this, 0, 0); + PacketPlayOutSpawnEntity packetPlayOutSpawnEntity = new PacketPlayOutSpawnEntity(this, 70, Block.getCombinedId(getBlock())); PlayerConnection playerConnection = ((CraftPlayer) player).getHandle().playerConnection; playerConnection.sendPacket(packetPlayOutSpawnEntity);