From 7c8819bb35af057e33a0eebe0e904d7514071df5 Mon Sep 17 00:00:00 2001 From: Mykyta Date: Sun, 19 Apr 2020 06:53:23 -0700 Subject: [PATCH] =?UTF-8?q?=E2=9A=A1=20Thunderstorm=20looping=20fix=20Also?= =?UTF-8?q?=20some=20small=20cleanup=20and=20vanish=20checking=20for=20bed?= =?UTF-8?q?=20messages.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../nkomarn/Harbor/command/HarborCommand.java | 21 +++++++++---------- .../nkomarn/Harbor/listener/BedListener.java | 2 ++ .../Harbor/task/AccelerateNightTask.java | 19 +++++++++-------- 3 files changed, 22 insertions(+), 20 deletions(-) diff --git a/src/main/java/xyz/nkomarn/Harbor/command/HarborCommand.java b/src/main/java/xyz/nkomarn/Harbor/command/HarborCommand.java index 00a5f57..b5d7dd2 100644 --- a/src/main/java/xyz/nkomarn/Harbor/command/HarborCommand.java +++ b/src/main/java/xyz/nkomarn/Harbor/command/HarborCommand.java @@ -20,17 +20,17 @@ public class HarborCommand implements TabExecutor { final String prefix = Config.getString("messages.miscellaneous.chat-prefix"); if (args.length < 1 || !sender.hasPermission("harbor.admin")) { - sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix + "&7Harbor version " - + Harbor.version + " by TechToolbox (@nkomarn).")); + sender.sendMessage(ChatColor.translateAlternateColorCodes('&', String.format( + "%sHarbor version %s by TechToolbox (@nkomarn).", prefix, Harbor.version))); } else if (args[0].equalsIgnoreCase("reload")) { Harbor.getHarbor().reloadConfig(); sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix - + "&7Reloaded configuration.")); + + "Reloaded configuration.")); } else if (args[0].equalsIgnoreCase("forceskip")) { if (!(sender instanceof Player)) { sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix - + "&7This command requires you to be a player.")); + + "This command requires you to be a player.")); return true; } @@ -39,14 +39,13 @@ public class HarborCommand implements TabExecutor { if (Checker.skippingWorlds.contains(world)) { sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix - + "&7This world's time is already being accelerated.")); - return true; + + "This world's time is already being accelerated.")); + } else { + Checker.skippingWorlds.add(world); + new AccelerateNightTask(world).runTaskTimer(Harbor.getHarbor(), 0L, 1); + sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix + + "Forcing night skip in your world.")); } - - Checker.skippingWorlds.add(world); - new AccelerateNightTask(world).runTaskTimer(Harbor.getHarbor(), 0L, 1); - sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix - + "&7Forcing night skip in your world.")); } else { sender.sendMessage(ChatColor.translateAlternateColorCodes('&', prefix + Config.getString("messages.miscellaneous.unrecognized-command"))); diff --git a/src/main/java/xyz/nkomarn/Harbor/listener/BedListener.java b/src/main/java/xyz/nkomarn/Harbor/listener/BedListener.java index 477a96d..0f19ad8 100644 --- a/src/main/java/xyz/nkomarn/Harbor/listener/BedListener.java +++ b/src/main/java/xyz/nkomarn/Harbor/listener/BedListener.java @@ -22,6 +22,7 @@ public class BedListener implements Listener { public void onBedEnter(final PlayerBedEnterEvent event) { if (event.getBedEnterResult() != PlayerBedEnterEvent.BedEnterResult.OK) return; if (Checker.skippingWorlds.contains(event.getPlayer().getWorld())) return; + if (Checker.isVanished(event.getPlayer())) return; Bukkit.getScheduler().runTaskLater(Harbor.getHarbor(), () -> { final UUID playerUuid = event.getPlayer().getUniqueId(); @@ -39,6 +40,7 @@ public class BedListener implements Listener { @EventHandler(ignoreCancelled = true) public void onBedLeave(final PlayerBedLeaveEvent event) { if (Checker.skippingWorlds.contains(event.getPlayer().getWorld())) return; + if (Checker.isVanished(event.getPlayer())) return; Bukkit.getScheduler().runTaskLater(Harbor.getHarbor(), () -> { final UUID playerUuid = event.getPlayer().getUniqueId(); diff --git a/src/main/java/xyz/nkomarn/Harbor/task/AccelerateNightTask.java b/src/main/java/xyz/nkomarn/Harbor/task/AccelerateNightTask.java index 4869753..ddeebff 100644 --- a/src/main/java/xyz/nkomarn/Harbor/task/AccelerateNightTask.java +++ b/src/main/java/xyz/nkomarn/Harbor/task/AccelerateNightTask.java @@ -14,6 +14,14 @@ public class AccelerateNightTask extends BukkitRunnable { public AccelerateNightTask(final World world) { this.world = world; Messages.sendRandomChatMessage(world, "messages.chat.night-skipping"); + + if (Config.getBoolean("night-skip.clear-rain")) { + world.setStorm(false); + } + + if (Config.getBoolean("night-skip.clear-thunder")) { + world.setThundering(false); + } } @Override @@ -29,19 +37,12 @@ public class AccelerateNightTask extends BukkitRunnable { } if (time >= (dayTime - timeRate * 1.5) && time <= dayTime) { - if (Config.getBoolean("night-skip.clear-rain")) { - world.setStorm(false); - } - - if (Config.getBoolean("night-skip.clear-thunder")) { - world.setThundering(false); - } - if (Config.getBoolean("night-skip.reset-phantom-statistic")) { world.getPlayers().forEach(player -> player.setStatistic(Statistic.TIME_SINCE_REST, 0)); } - Bukkit.getScheduler().runTaskLaterAsynchronously(Harbor.getHarbor(), () -> Checker.skippingWorlds.remove(world), 20); + Bukkit.getScheduler().runTaskLaterAsynchronously(Harbor.getHarbor(), + () -> Checker.skippingWorlds.remove(world), 20); Messages.sendRandomChatMessage(world, "messages.chat.night-skipped"); this.cancel(); } else {