(Ability to disable border definitions per world) some bug fixes
This commit is contained in:
		| @@ -4,20 +4,29 @@ import org.bukkit.Location; | |||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.configuration.file.FileConfiguration; | import org.bukkit.configuration.file.FileConfiguration; | ||||||
| import org.bukkit.configuration.file.YamlConfiguration; | import org.bukkit.configuration.file.YamlConfiguration; | ||||||
|  | import org.bukkit.configuration.serialization.ConfigurationSerializable; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.util.ArrayList; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| public class Border | public class Border implements ConfigurationSerializable | ||||||
| { | { | ||||||
|     private static final String dataFileName = "borders.json"; |     private static final String dataFileName = "borders.yml"; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     private Boolean isActive; | ||||||
|  |     private static String isActiveKey = "enabled"; | ||||||
|  |  | ||||||
|     private Location rectPoint1; |     private Location rectPoint1; | ||||||
|     private Location rectPoint2; |  | ||||||
|  |  | ||||||
|     private static String rectPoint1Name = "p1"; |     private static String rectPoint1Name = "p1"; | ||||||
|  |  | ||||||
|  |     private Location rectPoint2; | ||||||
|     private static String rectPoint2Name = "p2"; |     private static String rectPoint2Name = "p2"; | ||||||
|  |  | ||||||
|  |  | ||||||
|     private static String rectBordersKey = "rectBorders"; |     private static String rectBordersKey = "rectBorders"; | ||||||
|  |  | ||||||
|     private static final HashMap<World, Border> borders = new HashMap<World, Border>(); |     private static final HashMap<World, Border> borders = new HashMap<World, Border>(); | ||||||
| @@ -40,7 +49,12 @@ public class Border | |||||||
|         return rectPoint2; |         return rectPoint2; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings("unchecked") |     public Boolean isActive() | ||||||
|  |     { | ||||||
|  |         return isActive; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("unchecked unused") | ||||||
|     public Border( Map<String, Object> map ) |     public Border( Map<String, Object> map ) | ||||||
|     { |     { | ||||||
|         try |         try | ||||||
| @@ -48,6 +62,8 @@ public class Border | |||||||
|             rectPoint1 = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(rectPoint1Name)); |             rectPoint1 = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(rectPoint1Name)); | ||||||
|             rectPoint2 = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(rectPoint2Name)); |             rectPoint2 = LocationSerializer.deserializeLocation((Map<String, Object>) map.get(rectPoint2Name)); | ||||||
|  |  | ||||||
|  |             isActive = (Boolean) map.get(isActiveKey); | ||||||
|  |  | ||||||
|             if ( rectPoint1.getWorld().equals(rectPoint2.getWorld()) ) |             if ( rectPoint1.getWorld().equals(rectPoint2.getWorld()) ) | ||||||
|             { |             { | ||||||
|                 borders.put(rectPoint1.getWorld(), this); |                 borders.put(rectPoint1.getWorld(), this); | ||||||
| @@ -67,6 +83,10 @@ public class Border | |||||||
|     { |     { | ||||||
|         rectPoint1 = p1; |         rectPoint1 = p1; | ||||||
|         rectPoint2 = p2; |         rectPoint2 = p2; | ||||||
|  |  | ||||||
|  |         // new border is active by default | ||||||
|  |         isActive = true; | ||||||
|  |  | ||||||
|         if ( rectPoint1.getWorld().equals(rectPoint2.getWorld()) ) |         if ( rectPoint1.getWorld().equals(rectPoint2.getWorld()) ) | ||||||
|         { |         { | ||||||
|             borders.put(rectPoint1.getWorld(), this); |             borders.put(rectPoint1.getWorld(), this); | ||||||
| @@ -78,11 +98,15 @@ public class Border | |||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("unused") | ||||||
|     public Map<String, Object> serialize() |     public Map<String, Object> serialize() | ||||||
|     { |     { | ||||||
|         HashMap<String, Object> map = new HashMap<String, Object>(); |         Map<String, Object> map = new HashMap<String, Object>(); | ||||||
|         map.put(rectPoint1Name, LocationSerializer.serializeLocation(rectPoint1)); |         map.put(rectPoint1Name, LocationSerializer.serializeLocation(rectPoint1)); | ||||||
|         map.put(rectPoint2Name, LocationSerializer.serializeLocation(rectPoint2)); |         map.put(rectPoint2Name, LocationSerializer.serializeLocation(rectPoint2)); | ||||||
|  |         map.put(isActiveKey, isActive); | ||||||
|  |  | ||||||
|  |         System.out.println(map); | ||||||
|  |  | ||||||
|         return map; |         return map; | ||||||
|     } |     } | ||||||
| @@ -92,13 +116,24 @@ public class Border | |||||||
|         bordersFileConf.getList(rectBordersKey); |         bordersFileConf.getList(rectBordersKey); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static void saveBorders() |     public static void saveBorders() throws IOException | ||||||
|     { |     { | ||||||
|         bordersFileConf.set(rectBordersKey, borders.values()); |         bordersFileConf.set(rectBordersKey, new ArrayList<Object>(borders.values())); | ||||||
|  |         bordersFileConf.save(bordersFile); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public String toString() |     public String toString() | ||||||
|     { |     { | ||||||
|         return rectPoint1.getX() + "," + rectPoint1.getZ() + " " + rectPoint2.getX() + "," + rectPoint2.getZ(); |         return rectPoint1.getX() + "," + rectPoint1.getZ() + " " + rectPoint2.getX() + "," + rectPoint2.getZ(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public void enable() | ||||||
|  |     { | ||||||
|  |         isActive = true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void disable() | ||||||
|  |     { | ||||||
|  |         isActive = false; | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -22,6 +22,8 @@ import org.bukkit.command.CommandExecutor; | |||||||
| import org.bukkit.command.CommandSender; | import org.bukkit.command.CommandSender; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
|  |  | ||||||
|  | import java.io.IOException; | ||||||
|  |  | ||||||
| public class Commands implements CommandExecutor | public class Commands implements CommandExecutor | ||||||
| { | { | ||||||
|     private BorderManager borderManager; |     private BorderManager borderManager; | ||||||
| @@ -54,22 +56,25 @@ public class Commands implements CommandExecutor | |||||||
|             // set |             // set | ||||||
|             if ( ( args.length == 2 || args.length == 3 ) && args[0].equalsIgnoreCase("set") ) |             if ( ( args.length == 2 || args.length == 3 ) && args[0].equalsIgnoreCase("set") ) | ||||||
|             { |             { | ||||||
|                 if ( ! sender.hasPermission("craftinc.borderprotection.set") ) |                 if ( !sender.hasPermission("craftinc.borderprotection.set") ) | ||||||
|                 { |                 { | ||||||
|                     sender.sendMessage(Messages.noPermissionSet); |                     sender.sendMessage(Messages.noPermissionSet); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|  |                 // set <distance> | ||||||
|                 if ( args.length == 2 ) |                 if ( args.length == 2 ) | ||||||
|                 { |                 { | ||||||
|                     try |                     try | ||||||
|                     { |                     { | ||||||
|                         borderManager.setBorder(( (Player) sender ).getWorld(), Double.parseDouble(args[1])); |                         borderManager.setBorder(( (Player) sender ).getWorld(), Double.parseDouble(args[1])); | ||||||
|  |                         sender.sendMessage(Messages.borderCreationSuccessful); | ||||||
|                     } |                     } | ||||||
|                     catch ( Exception e ) |                     catch ( Exception e ) | ||||||
|                     { |                     { | ||||||
|                         sender.sendMessage(e.getMessage()); |                         sender.sendMessage(e.getMessage()); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |                 // set <point1> <point2> | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
|                     try |                     try | ||||||
| @@ -83,7 +88,14 @@ public class Commands implements CommandExecutor | |||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 // save the new border |                 // save the new border | ||||||
|                 Border.saveBorders(); |                 try | ||||||
|  |                 { | ||||||
|  |                     Border.saveBorders(); | ||||||
|  |                 } | ||||||
|  |                 catch ( IOException e ) | ||||||
|  |                 { | ||||||
|  |                     sender.sendMessage(Messages.borderSaveException); | ||||||
|  |                 } | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @@ -93,7 +105,7 @@ public class Commands implements CommandExecutor | |||||||
|                 World world = ( (Player) sender ).getWorld(); |                 World world = ( (Player) sender ).getWorld(); | ||||||
|  |  | ||||||
|                 // exit and send the player a message if no border is set |                 // exit and send the player a message if no border is set | ||||||
|                 if ( ! Border.getBorders().containsKey(world) ) |                 if ( !Border.getBorders().containsKey(world) ) | ||||||
|                 { |                 { | ||||||
|                     sender.sendMessage(Messages.borderInfoNoBorderSet); |                     sender.sendMessage(Messages.borderInfoNoBorderSet); | ||||||
|                     return true; |                     return true; | ||||||
| @@ -104,7 +116,33 @@ public class Commands implements CommandExecutor | |||||||
|                 sender.sendMessage(Messages.borderInfo(world.getName(), border.toString())); |                 sender.sendMessage(Messages.borderInfo(world.getName(), border.toString())); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             // on | ||||||
|  |             if ( args.length == 1 && ( args[0].equalsIgnoreCase("on") || args[0].equalsIgnoreCase("off") ) ) | ||||||
|  |             { | ||||||
|  |                 World world = ( (Player) sender ).getWorld(); | ||||||
|  |                 if (args[0].equalsIgnoreCase("on")) { | ||||||
|  |                     Border.getBorders().get(world).enable(); | ||||||
|  |                     sender.sendMessage(Messages.borderEnabled); | ||||||
|  |                 } else { | ||||||
|  |                     Border.getBorders().get(world).disable(); | ||||||
|  |                     sender.sendMessage(Messages.borderDisabled); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 // save the new border | ||||||
|  |                 try | ||||||
|  |                 { | ||||||
|  |                     Border.saveBorders(); | ||||||
|  |                 } | ||||||
|  |                 catch ( IOException e ) | ||||||
|  |                 { | ||||||
|  |                     sender.sendMessage(Messages.borderEnableDisableException); | ||||||
|  |                 } | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         sender.sendMessage(Messages.helpGeneral); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -73,6 +73,11 @@ public class Messages | |||||||
|             makeCmd("set", "Border rectangle is defined by the two points. A point is specified as: x,z", |             makeCmd("set", "Border rectangle is defined by the two points. A point is specified as: x,z", | ||||||
|                     "<point1>", "<point2>"); |                     "<point1>", "<point2>"); | ||||||
|  |  | ||||||
|  |     public static String borderCreationSuccessful | ||||||
|  |             = ChatColor.YELLOW + "New border was set " + | ||||||
|  |               ChatColor.GREEN + "successfully" + | ||||||
|  |               ChatColor.YELLOW + "!"; | ||||||
|  |  | ||||||
|     public static String commandIssuedByNonPlayer |     public static String commandIssuedByNonPlayer | ||||||
|             = ChatColor.RED + "Only a player can use CraftInc BorderProtection commands!"; |             = ChatColor.RED + "Only a player can use CraftInc BorderProtection commands!"; | ||||||
|  |  | ||||||
| @@ -90,4 +95,16 @@ public class Messages | |||||||
|  |  | ||||||
|     public static String noPermissionSet = |     public static String noPermissionSet = | ||||||
|             ChatColor.RED + "Sorry, you don't have permission to set the border."; |             ChatColor.RED + "Sorry, you don't have permission to set the border."; | ||||||
|  |  | ||||||
|  |     public static String borderEnabled = | ||||||
|  |             ChatColor.YELLOW + "Border enabled."; | ||||||
|  |  | ||||||
|  |     public static String borderDisabled = | ||||||
|  |             ChatColor.YELLOW + "Border disabled."; | ||||||
|  |  | ||||||
|  |     public static String borderSaveException = | ||||||
|  |             ChatColor.RED + "Error: Could not save border on server. After the next reload this border will be lost!"; | ||||||
|  |  | ||||||
|  |     public static String borderEnableDisableException = | ||||||
|  |             ChatColor.RED + "Error: Could not save border state on server. After the next reload this border state will be lost!"; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -74,14 +74,21 @@ public class PlayerMoveListener implements Listener | |||||||
|         Location playerLocation = e.getPlayer().getLocation(); |         Location playerLocation = e.getPlayer().getLocation(); | ||||||
|  |  | ||||||
|         // world where the player is in |         // world where the player is in | ||||||
|         World world= e.getPlayer().getWorld(); |         World world = e.getPlayer().getWorld(); | ||||||
|  |  | ||||||
|         // border of this world |         // border of this world | ||||||
|         Border border = Border.getBorders().get(world); |         Border border = Border.getBorders().get(world); | ||||||
|  |  | ||||||
|         // do nothing if there are no borders for this specific world |         // do nothing if there are no borders for this specific world | ||||||
|         if ( border == null ) |         if ( border == null ) | ||||||
|  |         { | ||||||
|             return; |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if ( !border.isActive() ) | ||||||
|  |         { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         // change x or z. default: do not change |         // change x or z. default: do not change | ||||||
|         Double[] newXZ; |         Double[] newXZ; | ||||||
|   | |||||||
| @@ -62,6 +62,11 @@ public class PlayerTeleportListener implements Listener | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if ( !border.isActive() ) | ||||||
|  |         { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         // change x or z. default: do not change |         // change x or z. default: do not change | ||||||
|         Double[] newXZ; |         Double[] newXZ; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,6 +16,7 @@ | |||||||
| */ | */ | ||||||
| package de.craftinc.borderprotection; | package de.craftinc.borderprotection; | ||||||
|  |  | ||||||
|  | import org.bukkit.configuration.serialization.ConfigurationSerialization; | ||||||
| import org.bukkit.plugin.PluginManager; | import org.bukkit.plugin.PluginManager; | ||||||
| import org.bukkit.plugin.java.JavaPlugin; | import org.bukkit.plugin.java.JavaPlugin; | ||||||
|  |  | ||||||
| @@ -28,6 +29,12 @@ public class Plugin extends JavaPlugin | |||||||
|         return cibpPlugin; |         return cibpPlugin; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void onLoad() | ||||||
|  |     { | ||||||
|  |         ConfigurationSerialization.registerClass(Border.class); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onDisable() |     public void onDisable() | ||||||
|     { |     { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Paul Schulze
					Paul Schulze