summaryrefslogtreewikicommitdiff
path: root/src/main/java/net/tylermurphy/hideAndSeek/command/SetBounds.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/net/tylermurphy/hideAndSeek/command/SetBounds.java')
-rw-r--r--src/main/java/net/tylermurphy/hideAndSeek/command/SetBounds.java79
1 files changed, 79 insertions, 0 deletions
diff --git a/src/main/java/net/tylermurphy/hideAndSeek/command/SetBounds.java b/src/main/java/net/tylermurphy/hideAndSeek/command/SetBounds.java
new file mode 100644
index 0000000..c94a0d1
--- /dev/null
+++ b/src/main/java/net/tylermurphy/hideAndSeek/command/SetBounds.java
@@ -0,0 +1,79 @@
+package net.tylermurphy.hideAndSeek.command;
+
+import static net.tylermurphy.hideAndSeek.configuration.Config.*;
+
+import org.bukkit.command.CommandSender;
+import org.bukkit.entity.Player;
+
+import net.tylermurphy.hideAndSeek.Main;
+import static net.tylermurphy.hideAndSeek.configuration.Localization.*;
+
+public class SetBounds implements ICommand {
+
+ public void execute(CommandSender sender, String[] args) {
+ if(!Main.plugin.status.equals("Standby")) {
+ sender.sendMessage(errorPrefix + message("GAME_INPROGRESS"));
+ return;
+ }
+ if(spawnPosition == null) {
+ sender.sendMessage(errorPrefix + message("ERROR_GAME_SPAWN"));
+ return;
+ }
+ Player player = (Player) sender;
+ if(!player.getWorld().getName().equals(spawnWorld)){
+ sender.sendMessage(errorPrefix + message("BOUNDS_WRONG_WORLD"));
+ return;
+ }
+ if(player.getLocation().getBlockX() == 0 || player.getLocation().getBlockZ() == 0){
+ sender.sendMessage(errorPrefix + message("NOT_AT_ZERO"));
+ return;
+ }
+ boolean first = true;
+ if(saveMinX != 0 && saveMinZ != 0 && saveMaxX != 0 && saveMaxZ != 0) {
+ saveMinX = 0; saveMinZ= 0; saveMaxX = 0; saveMaxZ = 0;
+ }
+ if(saveMaxX == 0) {
+ addToConfig("bounds.max.x", player.getLocation().getBlockX());
+ saveMaxX = player.getLocation().getBlockX();
+ } else if(saveMaxX < player.getLocation().getBlockX()) {
+ first = false;
+ addToConfig("bounds.max.x", player.getLocation().getBlockX());
+ addToConfig("bounds.min.x", saveMaxX);
+ saveMinX = saveMaxX;
+ saveMaxX = player.getLocation().getBlockX();
+ } else {
+ first = false;
+ addToConfig("bounds.min.x", player.getLocation().getBlockX());
+ saveMinX = player.getLocation().getBlockX();
+ }
+ if(saveMaxZ == 0) {
+ addToConfig("bounds.max.z", player.getLocation().getBlockZ());
+ saveMaxZ = player.getLocation().getBlockZ();
+ } else if(saveMaxZ < player.getLocation().getBlockZ()) {
+ first = false;
+ addToConfig("bounds.max.z", player.getLocation().getBlockZ());
+ addToConfig("bounds.min.z", saveMaxZ);
+ saveMinZ = saveMaxZ;
+ saveMaxZ = player.getLocation().getBlockZ();
+ } else {
+ first = false;
+ addToConfig("bounds.min.z", player.getLocation().getBlockZ());
+ saveMinZ = player.getLocation().getBlockZ();
+ }
+ sender.sendMessage(messagePrefix + message("BOUNDS").addAmount(first ? 1 : 2));
+ saveConfig();
+ }
+
+ public String getLabel() {
+ return "setBounds";
+ }
+
+ public String getUsage() {
+ return "";
+ }
+
+ public String getDescription() {
+ return "Sets the map bounds for the game.";
+ }
+
+}