Added code to prevent setting homes in enemy territory, changed commandpreprocess event priority to highest, implemented #5

This commit is contained in:
Norbi Peti 2016-01-09 22:52:44 +01:00
parent 5bbe8e12d5
commit 47419c0925
5 changed files with 41 additions and 5 deletions

Binary file not shown.

View file

@ -7,6 +7,7 @@ import org.bukkit.configuration.InvalidConfigurationException;
import org.bukkit.configuration.file.YamlConfiguration; import org.bukkit.configuration.file.YamlConfiguration;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.entity.PlayerDeathEvent; import org.bukkit.event.entity.PlayerDeathEvent;
import org.bukkit.event.player.AsyncPlayerChatEvent; import org.bukkit.event.player.AsyncPlayerChatEvent;
@ -25,6 +26,9 @@ import com.palmergames.bukkit.towny.exceptions.NotRegisteredException;
import com.palmergames.bukkit.towny.object.Nation; import com.palmergames.bukkit.towny.object.Nation;
import com.palmergames.bukkit.towny.object.Resident; import com.palmergames.bukkit.towny.object.Resident;
import com.palmergames.bukkit.towny.object.Town; import com.palmergames.bukkit.towny.object.Town;
import com.palmergames.bukkit.towny.object.TownBlock;
import com.palmergames.bukkit.towny.object.TownyUniverse;
import com.palmergames.bukkit.towny.object.WorldCoord;
import au.com.mineauz.minigames.MinigamePlayer; import au.com.mineauz.minigames.MinigamePlayer;
import au.com.mineauz.minigames.Minigames; import au.com.mineauz.minigames.Minigames;
@ -291,11 +295,13 @@ public class PlayerListener implements Listener { // 2015.07.16.
.format("\"color\":\"aqua\"},{\"text\":\"World: %s\n\",\"color\":\"white\"},", .format("\"color\":\"aqua\"},{\"text\":\"World: %s\n\",\"color\":\"white\"},",
event.getPlayer().getWorld().getName())); event.getPlayer().getWorld().getName()));
json.append(String.format( json.append(String.format(
"{\"text\":\"Respect: %s%s\",\"color\":\"white\"}]}}},", "{\"text\":\"Respect: %s%s%s\",\"color\":\"white\"}]}}},",
(player.FCount == Integer.MAX_VALUE - 1 ? player.FCount + "+" (player.FCount == Integer.MAX_VALUE - 1 ? player.FCount + "+"
: player.FCount), (player.UserName != null : player.FCount), (player.UserName != null
&& !player.UserName.isEmpty() ? "\nUserName: " && !player.UserName.isEmpty() ? "\nUserName: "
+ player.UserName : ""))); + player.UserName : ""), (player.PlayerName
.equals("\nAlpha_Bacca44") ? "\nDeaths: " + AlphaDeaths
: "")));
json.append("{\"text\":\"> \",\"color\":\"white\"},"); json.append("{\"text\":\"> \",\"color\":\"white\"},");
int index = -1; int index = -1;
@ -544,15 +550,16 @@ public class PlayerListener implements Listener { // 2015.07.16.
.getMessage())); .getMessage()));
} }
@EventHandler @EventHandler(priority = EventPriority.HIGHEST)
public void PlayerCommandPreprocess(PlayerCommandPreprocessEvent event) { public void PlayerCommandPreprocess(PlayerCommandPreprocessEvent event) {
if (event.getMessage().length() < 2) if (event.getMessage().length() < 2)
return; return;
int index = event.getMessage().indexOf(" "); int index = event.getMessage().indexOf(" ");
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(event MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(event
.getPlayer().getUniqueId()); .getPlayer().getUniqueId());
String cmd = "";
if (index == -1) { if (index == -1) {
String cmd = event.getMessage().substring(1); cmd = event.getMessage().substring(1);
// System.out.println("cmd: " + cmd); // System.out.println("cmd: " + cmd);
if (cmd.equalsIgnoreCase(Channel.GlobalChat.Command)) { if (cmd.equalsIgnoreCase(Channel.GlobalChat.Command)) {
mp.CurrentChannel = Channel.GlobalChat; mp.CurrentChannel = Channel.GlobalChat;
@ -598,7 +605,7 @@ public class PlayerListener implements Listener { // 2015.07.16.
event.setCancelled(true); event.setCancelled(true);
} }
} else { } else {
String cmd = event.getMessage().substring(1, index); cmd = event.getMessage().substring(1, index);
// System.out.println("cmd: " + cmd); // System.out.println("cmd: " + cmd);
if (cmd.equalsIgnoreCase(Channel.GlobalChat.Command)) { if (cmd.equalsIgnoreCase(Channel.GlobalChat.Command)) {
event.setCancelled(true); event.setCancelled(true);
@ -648,6 +655,35 @@ public class PlayerListener implements Listener { // 2015.07.16.
} }
} }
} }
if (cmd.equalsIgnoreCase("sethome")) {
TownyUniverse tu = PluginMain.Instance.TU;
try {
TownBlock tb = WorldCoord.parseWorldCoord(event.getPlayer())
.getTownBlock();
if (tb.hasTown()) {
Town town = tb.getTown();
if (town.hasNation()) {
Resident res = tu.getResidentMap().get(
event.getPlayer().getName());
if (res.hasTown()) {
Town town2 = res.getTown();
if (town2.hasNation()) {
if (town.getNation().getEnemies()
.contains(town2.getNation())) {
event.getPlayer()
.sendMessage(
"§cYou cannot set homes in enemy territory.");
event.setCancelled(true);
return;
}
}
}
}
}
} catch (NotRegisteredException e) {
return;
}
}
} }
@EventHandler @EventHandler