diff --git a/src/main/java/net/countercraft/movecraft/warfare/siege/SiegeProgressTask.java b/src/main/java/net/countercraft/movecraft/warfare/siege/SiegeProgressTask.java index 13c1093..718d3ac 100644 --- a/src/main/java/net/countercraft/movecraft/warfare/siege/SiegeProgressTask.java +++ b/src/main/java/net/countercraft/movecraft/warfare/siege/SiegeProgressTask.java @@ -30,7 +30,7 @@ public void run() { return; } siege.setJustCommenced(false); - @NotNull Player siegeLeader = Movecraft.getInstance().getServer().getPlayer(siege.getPlayerUUID()); + @Nullable Player siegeLeader = Movecraft.getInstance().getServer().getPlayer(siege.getPlayerUUID()); @Nullable Craft siegeCraft = CraftManager.getInstance().getCraftByPlayer(siegeLeader); if(timeLeft > 10) { @@ -47,7 +47,7 @@ public void run() { else { Bukkit.getServer().broadcastMessage(String.format( I18nSupport.getInternationalisedString("Siege - Flagship Not In Box"), - siege.getName(), siegeLeader.getDisplayName()) + siege.getName(), getSiegeLeaderName(siegeLeader)) + formatMinutes(timeLeft)); } } @@ -61,9 +61,9 @@ public void run() { } } - private void endSiege(@Nullable Craft siegeCraft, @NotNull Player siegeLeader) { - if (leaderPilotingShip(siegeCraft)) { - if(MovecraftWorldGuard.getInstance().getWGUtils().craftFullyInRegion(siege.getAttackRegion(), siegeLeader.getWorld(), siegeCraft)) { + private void endSiege(@Nullable Craft siegeCraft, @Nullable Player siegeLeader) { + if (leaderPilotingShip(siegeCraft) && siegeLeader != null) { + if(MovecraftWorldGuard.getInstance().getWGUtils().craftFullyInRegion(siege.getAttackRegion(), siegeCraft.getW(), siegeCraft)) { Bukkit.getServer().broadcastMessage(String.format(I18nSupport.getInternationalisedString("Siege - Siege Success"), siege.getName(), siegeLeader.getDisplayName())); winSiege(siegeLeader); @@ -81,24 +81,25 @@ private void endSiege(@Nullable Craft siegeCraft, @NotNull Player siegeLeader) { private void winSiege(@NotNull Player siegeLeader) { Bukkit.getPluginManager().callEvent(new SiegeWinEvent(siege)); MovecraftWorldGuard.getInstance().getWGUtils().clearAndSetOwnership(siege.getCaptureRegion(), siegeLeader.getWorld(), siege.getPlayerUUID()); - processCommands(siegeLeader, true); + processCommands(siegeLeader.getName(), true); } - private void failSiege(@NotNull Player siegeLeader) { + private void failSiege(@Nullable Player siegeLeader) { Bukkit.getPluginManager().callEvent(new SiegeLoseEvent(siege)); + String name = getSiegeLeaderName(siegeLeader); Bukkit.getServer().broadcastMessage(String.format(I18nSupport.getInternationalisedString("Siege - Siege Failure"), - siege.getName(), siegeLeader.getDisplayName())); + siege.getName(), name)); - processCommands(siegeLeader, false); + processCommands(name, false); } - private void processCommands(@NotNull Player siegeLeader, boolean win) { + private void processCommands(@NotNull String siegeLeader, boolean win) { List commands = win ? siege.getCommandsOnWin() : siege.getCommandsOnLose(); for (String command : commands) { Bukkit.getServer().dispatchCommand(Bukkit.getServer().getConsoleSender(), command .replaceAll("%r", siege.getCaptureRegion()) .replaceAll("%c", "" + siege.getCost()) - .replaceAll("%l", siegeLeader.getName())); + .replaceAll("%l", siegeLeader)); } } @@ -108,4 +109,18 @@ private boolean leaderPilotingShip(@Nullable Craft siegeCraft) { else return siege.getCraftsToWin().contains(siegeCraft.getType().getCraftName()); } + + private String getSiegeLeaderName(@Nullable Player siegeLeader) { + String name; + if(siegeLeader == null) { + name = Bukkit.getOfflinePlayer(siege.getPlayerUUID()).getName(); + + if(name == null) + name = "null"; // Note, there's not a better way to deal with this sadly + } + else + name = siegeLeader.getDisplayName(); + + return name; + } }