Added a Cuboid constructor that takes a worldedit selection
Added a debug mode that enables extra logging. MetropolisPlugin.DEBUG should be true for snapshots and false for release builds. Added an occupied Plots list to MetropolisPlugin to keep track of both player homes and reserved plots. Added the Plot class as a parent of PlayerHome and moved relevant code to it. Added a command to reserve plots that aren't tied to a player. This can be used to setup a larger protected area around spawn
This commit is contained in:
		| @@ -17,6 +17,11 @@ Edit the config.yml file.  You can set the height to clear above roads, the road | |||||||
| Changelog: | Changelog: | ||||||
| v0.4.6 | v0.4.6 | ||||||
| 	Added optional generation of a sign identifying owner in plots on creation | 	Added optional generation of a sign identifying owner in plots on creation | ||||||
|  | 	Added a Cuboid constructor that takes a worldedit selection | ||||||
|  | 	Added a debug mode that enables extra logging.  MetropolisPlugin.DEBUG should be true for snapshots and false for release builds. | ||||||
|  | 	Added an occupied Plots list to MetropolisPlugin to keep track of both player homes and reserved plots. | ||||||
|  | 	Added the Plot class as a parent of PlayerHome and moved relevant code to it.  | ||||||
|  | 	Added a command to reserve plots that aren't tied to a player.  This can be used to setup a larger protected area around spawn | ||||||
| v0.4.5 | v0.4.5 | ||||||
| v0.4.4 | v0.4.4 | ||||||
| 	Added a welcome message telling players where their home is. | 	Added a welcome message telling players where their home is. | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ import java.util.logging.Logger; | |||||||
|  |  | ||||||
|  |  | ||||||
| import com.sk89q.worldedit.BlockVector; | import com.sk89q.worldedit.BlockVector; | ||||||
|  | import com.sk89q.worldedit.bukkit.selections.Selection; | ||||||
|  |  | ||||||
| public class Cuboid implements Comparable<Cuboid> { | public class Cuboid implements Comparable<Cuboid> { | ||||||
| 	private int id; | 	private int id; | ||||||
| @@ -51,6 +52,15 @@ public class Cuboid implements Comparable<Cuboid> { | |||||||
| 		this.maxZ = 0; | 		this.maxZ = 0; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public Cuboid(Selection selection) { | ||||||
|  | 		this.minX = selection.getMinimumPoint().getBlockX(); | ||||||
|  | 		this.minY = selection.getMinimumPoint().getBlockY(); | ||||||
|  | 		this.minZ = selection.getMinimumPoint().getBlockZ(); | ||||||
|  | 		this.maxX = selection.getMaximumPoint().getBlockX(); | ||||||
|  | 		this.maxY = selection.getMaximumPoint().getBlockY(); | ||||||
|  | 		this.maxZ = selection.getMaximumPoint().getBlockZ(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	public BlockVector getMin(){ | 	public BlockVector getMin(){ | ||||||
| 		return new BlockVector(minX, minY, minZ); | 		return new BlockVector(minX, minY, minZ); | ||||||
| 	} | 	} | ||||||
| @@ -170,4 +180,28 @@ public class Cuboid implements Comparable<Cuboid> { | |||||||
| 		return (this.minZ + this.maxZ)/2; | 		return (this.minZ + this.maxZ)/2; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public boolean intersects(Cuboid other) { | ||||||
|  | 		if (this.maxX >= other.minX && this.minX <= other.maxX) | ||||||
|  |         { | ||||||
|  |             if (this.maxZ >= other.minZ && this.minZ <= other.maxZ) | ||||||
|  |             { | ||||||
|  |                 if (this.maxY >= other.minY && this.minY <= other.maxY) | ||||||
|  |                 { | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     return false; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -19,8 +19,10 @@ import org.bukkit.plugin.java.JavaPlugin; | |||||||
| import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisFlagResetCommand; | import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisFlagResetCommand; | ||||||
| import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisHomeGenerateCommand; | import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisHomeGenerateCommand; | ||||||
| import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisHomeListCommand; | import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisHomeListCommand; | ||||||
|  | import com.majinnaibu.bukkitplugins.metropolis.commands.MetropolisPlotReserveCommand; | ||||||
| import com.majinnaibu.bukkitplugins.metropolis.eventlisteners.PlayerJoinListener; | import com.majinnaibu.bukkitplugins.metropolis.eventlisteners.PlayerJoinListener; | ||||||
| import com.sk89q.worldedit.BlockVector; | import com.sk89q.worldedit.BlockVector; | ||||||
|  | import com.sk89q.worldedit.bukkit.WorldEditPlugin; | ||||||
| import com.sk89q.worldguard.bukkit.WorldGuardPlugin; | import com.sk89q.worldguard.bukkit.WorldGuardPlugin; | ||||||
| import com.sk89q.worldguard.domains.DefaultDomain; | import com.sk89q.worldguard.domains.DefaultDomain; | ||||||
| import com.sk89q.worldguard.protection.flags.DefaultFlag; | import com.sk89q.worldguard.protection.flags.DefaultFlag; | ||||||
| @@ -30,14 +32,17 @@ import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion; | |||||||
| import com.sk89q.worldguard.protection.regions.ProtectedRegion; | import com.sk89q.worldguard.protection.regions.ProtectedRegion; | ||||||
|  |  | ||||||
| public class MetropolisPlugin extends JavaPlugin { | public class MetropolisPlugin extends JavaPlugin { | ||||||
|  | 	public static final boolean DEBUG = true; | ||||||
| 	public static final Logger log=Logger.getLogger("Minecraft"); | 	public static final Logger log=Logger.getLogger("Minecraft"); | ||||||
| 	 | 	 | ||||||
| 	public PluginDescriptionFile pdf = null; | 	public PluginDescriptionFile pdf = null; | ||||||
| 	public WorldGuardPlugin worldGuard = null; | 	public WorldGuardPlugin worldGuard = null; | ||||||
|  | 	public WorldEditPlugin worldEdit = null; | ||||||
| 	public World world = null; | 	public World world = null; | ||||||
| 	public RegionManager regionManager = null; | 	public RegionManager regionManager = null; | ||||||
|  |  | ||||||
| 	private List<PlayerHome> _occupiedHomes; | 	private List<PlayerHome> _occupiedHomes; | ||||||
|  | 	private List<Plot> _occupiedPlots; | ||||||
| 	 | 	 | ||||||
| 	private PlayerJoinListener _playerJoinListener = null; | 	private PlayerJoinListener _playerJoinListener = null; | ||||||
| 	 | 	 | ||||||
| @@ -87,6 +92,12 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		 | 		 | ||||||
| 		worldGuard = (WorldGuardPlugin) plugin; | 		worldGuard = (WorldGuardPlugin) plugin; | ||||||
| 		 | 		 | ||||||
|  | 		plugin = getServer().getPluginManager().getPlugin("WorldEdit"); | ||||||
|  | 		if(plugin == null || !(plugin instanceof WorldEditPlugin)){ | ||||||
|  | 			throw new RuntimeException("WorldEdit must be loaded first"); | ||||||
|  | 		} | ||||||
|  | 		worldEdit = (WorldEditPlugin) plugin; | ||||||
|  | 		 | ||||||
| 		world = getServer().getWorld(worldName); | 		world = getServer().getWorld(worldName); | ||||||
|  |  | ||||||
| 		regionManager = worldGuard.getRegionManager(world); | 		regionManager = worldGuard.getRegionManager(world); | ||||||
| @@ -108,7 +119,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		_occupiedHomes = new ArrayList<PlayerHome>(); | 		_occupiedHomes = new ArrayList<PlayerHome>(); | ||||||
| 		fillOccupiedHomes(); | 		fillOccupiedPlots(); | ||||||
| 		resizeCityRegion(); | 		resizeCityRegion(); | ||||||
|  |  | ||||||
| 		if(_playerJoinListener == null){ | 		if(_playerJoinListener == null){ | ||||||
| @@ -120,17 +131,23 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		getCommand("metropolis-home-generate").setExecutor(new MetropolisHomeGenerateCommand(this)); | 		getCommand("metropolis-home-generate").setExecutor(new MetropolisHomeGenerateCommand(this)); | ||||||
| 		getCommand("metropolis-home-list").setExecutor(new MetropolisHomeListCommand(this)); | 		getCommand("metropolis-home-list").setExecutor(new MetropolisHomeListCommand(this)); | ||||||
| 		getCommand("metropolis-flag-reset").setExecutor(new MetropolisFlagResetCommand(this)); | 		getCommand("metropolis-flag-reset").setExecutor(new MetropolisFlagResetCommand(this)); | ||||||
|  | 		getCommand("metropolis-plot-reserve").setExecutor(new MetropolisPlotReserveCommand(this)); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	private void fillOccupiedHomes() { | 	private void fillOccupiedPlots(){ | ||||||
|  | 		_occupiedPlots = new ArrayList<Plot>(); | ||||||
| 		_occupiedHomes = new ArrayList<PlayerHome>(); | 		_occupiedHomes = new ArrayList<PlayerHome>(); | ||||||
| 		 | 		 | ||||||
| 		for(ProtectedRegion region: regionManager.getRegions().values()){ | 		for(ProtectedRegion region: regionManager.getRegions().values()){ | ||||||
| 			if(region instanceof ProtectedCuboidRegion && region.getId().startsWith("h_")){ | 			if(region instanceof ProtectedCuboidRegion){ | ||||||
| 				ProtectedCuboidRegion cuboidRegion = (ProtectedCuboidRegion) region; | 				ProtectedCuboidRegion cuboidRegion = (ProtectedCuboidRegion) region; | ||||||
| 				PlayerHome home = new PlayerHome(cuboidRegion); | 				if(cuboidRegion.getId().startsWith("h_")){ | ||||||
| 				 | 					PlayerHome home = PlayerHome.get(cuboidRegion); | ||||||
|  | 					_occupiedPlots.add(home); | ||||||
| 					_occupiedHomes.add(home); | 					_occupiedHomes.add(home); | ||||||
|  | 				}else if(cuboidRegion.getId().startsWith("r_")){ | ||||||
|  | 					_occupiedPlots.add(Plot.get(cuboidRegion)); | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| @@ -144,7 +161,9 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		ProtectedRegion homeRegion = regionManager.getRegion(regionName); | 		ProtectedRegion homeRegion = regionManager.getRegion(regionName); | ||||||
|  |  | ||||||
| 		if(homeRegion == null){ | 		if(homeRegion == null){ | ||||||
|  | 			if(DEBUG){ | ||||||
| 				log.info(String.format("Creating home for player %s", player.getName())); | 				log.info(String.format("Creating home for player %s", player.getName())); | ||||||
|  | 			} | ||||||
| 			home = generateHome(player.getName()); | 			home = generateHome(player.getName()); | ||||||
| 		}else{ | 		}else{ | ||||||
| 			home = new PlayerHome(homeRegion); | 			home = new PlayerHome(homeRegion); | ||||||
| @@ -178,7 +197,9 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			int z=0; | 			int z=0; | ||||||
| 			 | 			 | ||||||
| 			if(plotCuboid == null){ | 			if(plotCuboid == null){ | ||||||
|  | 				if(DEBUG){ | ||||||
| 					log.warning("plotCuboid is null"); | 					log.warning("plotCuboid is null"); | ||||||
|  | 				} | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 			 | 			 | ||||||
| @@ -229,8 +250,9 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	public boolean isBlockOccupied(int row, int col){ | 	public boolean isBlockOccupied(int row, int col){ | ||||||
| 		for(PlayerHome home : _occupiedHomes){ | 		Cuboid cuboid = new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | ||||||
| 			if(home.getRow(roadWidth, plotSizeZ) == row && home.getCol(roadWidth, plotSizeX) == col){ | 		for(Plot plot: _occupiedPlots){ | ||||||
|  | 			if(plot.getCuboid().intersects(cuboid)){ | ||||||
| 				return true; | 				return true; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -251,7 +273,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			for(col = -ring; col <= ring; col++){ | 			for(col = -ring; col <= ring; col++){ | ||||||
| 				if(!isBlockOccupied(row, col)){ | 				if(!isBlockOccupied(row, col)){ | ||||||
| 					if(row != 0 || col != 0){ | 					if(row != 0 || col != 0){ | ||||||
| 						log.info(String.format("row: %d, col: %d", row, col)); | 						if(DEBUG){log.info(String.format("row: %d, col: %d", row, col));} | ||||||
| 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col));  | 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col));  | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -261,7 +283,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			for(row=-ring + 1; row < ring; row++){ | 			for(row=-ring + 1; row < ring; row++){ | ||||||
| 				if(!isBlockOccupied(row, col)){ | 				if(!isBlockOccupied(row, col)){ | ||||||
| 					if(row != 0 || col != 0){ | 					if(row != 0 || col != 0){ | ||||||
| 						log.info(String.format("row: %d, col: %d", row, col)); | 						if(DEBUG){log.info(String.format("row: %d, col: %d", row, col));} | ||||||
| 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -271,7 +293,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			for(col = ring; col >= -ring; col--){ | 			for(col = ring; col >= -ring; col--){ | ||||||
| 				if(!isBlockOccupied(row, col)){ | 				if(!isBlockOccupied(row, col)){ | ||||||
| 					if(row != 0 || col != 0){ | 					if(row != 0 || col != 0){ | ||||||
| 						log.info(String.format("row: %d, col: %d", row, col)); | 						if(DEBUG){log.info(String.format("row: %d, col: %d", row, col));} | ||||||
| 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -281,7 +303,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			for(row = ring; row > -ring; row--){ | 			for(row = ring; row > -ring; row--){ | ||||||
| 				if(!isBlockOccupied(row, col)){ | 				if(!isBlockOccupied(row, col)){ | ||||||
| 					if(row != 0 || col != 0){ | 					if(row != 0 || col != 0){ | ||||||
| 						log.info(String.format("row: %d, col: %d", row, col)); | 						if(DEBUG){log.info(String.format("row: %d, col: %d", row, col));} | ||||||
| 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | 						return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -290,7 +312,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			ring++; | 			ring++; | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		log.info(String.format("row: %d, col: %d", row, col)); | 		if(DEBUG){log.info(String.format("row: %d, col: %d", row, col));} | ||||||
| 		return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | 		return new Cuboid(getPlotMin(row, col), getPlotMax(row, col)); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| @@ -317,11 +339,11 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		for(PlayerHome home: _occupiedHomes){ | 		for(PlayerHome home: _occupiedHomes){ | ||||||
| 			int plotCol=Math.abs(getPlotXFromMin(home.getCuboid())); | 			int plotCol=Math.abs(getPlotXFromMin(home.getCuboid())); | ||||||
| 			int plotRow=Math.abs(getPlotZFromMin(home.getCuboid())); | 			int plotRow=Math.abs(getPlotZFromMin(home.getCuboid())); | ||||||
| 			log.info(String.format("col: %d, row: %d, iSize: %d", plotCol, plotRow, iSize)); | 			if(DEBUG){log.info(String.format("col: %d, row: %d, iSize: %d", plotCol, plotRow, iSize));} | ||||||
| 			iSize = Math.max(Math.max(plotRow*2+1, plotCol*2+1), iSize); | 			iSize = Math.max(Math.max(plotRow*2+1, plotCol*2+1), iSize); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		log.info(String.format("City size is %d", iSize)); | 		if(DEBUG){log.info(String.format("City size is %d", iSize));} | ||||||
| 		return iSize; | 		return iSize; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -356,7 +378,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
|  |  | ||||||
| 	 | 	 | ||||||
| 	public PlayerHome generateHome(String playerName) { | 	public PlayerHome generateHome(String playerName) { | ||||||
| 		log.info(String.format("Generating home for %s", playerName)); | 		if(DEBUG){log.info(String.format("Generating home for %s", playerName));} | ||||||
| 		Cuboid plotCuboid = null; | 		Cuboid plotCuboid = null; | ||||||
| 		Cuboid homeCuboid = null; | 		Cuboid homeCuboid = null; | ||||||
| 		ProtectedRegion homeRegion = null; | 		ProtectedRegion homeRegion = null; | ||||||
| @@ -391,12 +413,12 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			generateFloor(plotCuboid); | 			generateFloor(plotCuboid); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		log.info(String.format("generateSign: %s", String.valueOf(generateSign))); | 		if(DEBUG){log.info(String.format("generateSign: %s", String.valueOf(generateSign)));} | ||||||
| 		if(generateSign){ | 		if(generateSign){ | ||||||
| 			generateSign(plotCuboid, playerName); | 			generateSign(plotCuboid, playerName); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		log.info(String.format("Done generating home for %s", playerName)); | 		if(DEBUG){log.info(String.format("Done generating home for %s", playerName));} | ||||||
| 		 | 		 | ||||||
| 		return new PlayerHome(homeRegion); | 		return new PlayerHome(homeRegion); | ||||||
| 	} | 	} | ||||||
| @@ -419,4 +441,24 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 	public List<PlayerHome> getCityBlocks() { | 	public List<PlayerHome> getCityBlocks() { | ||||||
| 		return Collections.unmodifiableList(_occupiedHomes); | 		return Collections.unmodifiableList(_occupiedHomes); | ||||||
| 	} | 	} | ||||||
|  | 	 | ||||||
|  | 	public World getWorld(){ | ||||||
|  | 		return world; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public void reserveCuboid(String regionName, Cuboid cuboid) { | ||||||
|  | 		ProtectedCuboidRegion reservedRegion = new ProtectedCuboidRegion(regionName, cuboid.getMin(), cuboid.getMax()); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.MOB_SPAWNING, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.CREEPER_EXPLOSION, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.ENDER_BUILD, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.GHAST_FIREBALL, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.TNT, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.LAVA_FLOW, StateFlag.State.DENY); | ||||||
|  | 		reservedRegion.setFlag(DefaultFlag.SNOW_FALL, StateFlag.State.DENY); | ||||||
|  | 		regionManager.addRegion(reservedRegion); | ||||||
|  | 		 | ||||||
|  | 		_occupiedPlots.add(Plot.get(reservedRegion)); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package com.majinnaibu.bukkitplugins.metropolis; | package com.majinnaibu.bukkitplugins.metropolis; | ||||||
|  |  | ||||||
| import javax.persistence.Entity; | import javax.persistence.Entity; | ||||||
| import javax.persistence.Id; |  | ||||||
| import javax.persistence.Table; | import javax.persistence.Table; | ||||||
|  |  | ||||||
| import com.avaje.ebean.validation.NotNull; | import com.avaje.ebean.validation.NotNull; | ||||||
| @@ -11,30 +10,20 @@ import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion; | |||||||
| import com.sk89q.worldguard.protection.regions.ProtectedRegion; | import com.sk89q.worldguard.protection.regions.ProtectedRegion; | ||||||
|  |  | ||||||
| @Entity() | @Entity() | ||||||
| @Table(name="met_home") | @Table(name="Metropolis_PlayerHome") | ||||||
| public class PlayerHome implements Comparable<PlayerHome>{ | public class PlayerHome extends Plot{ | ||||||
| 	@Id |  | ||||||
| 	private int id; |  | ||||||
| 	 |  | ||||||
| 	@NotNull | 	@NotNull | ||||||
| 	private String playerName; | 	private String playerName; | ||||||
| 	 | 	public String getPlayerName(){return this.playerName;} | ||||||
| 	@NotNull | 	public void setPlayerName(String playerName){this.playerName = playerName;} | ||||||
| 	private Cuboid cuboid; |  | ||||||
|  |  | ||||||
| 	@NotNull |  | ||||||
| 	private String regionName; |  | ||||||
| 		 | 		 | ||||||
| 	public PlayerHome(String owner, BlockVector min, BlockVector max) { | 	public PlayerHome(String owner, BlockVector min, BlockVector max) { | ||||||
| 		this.cuboid = new Cuboid(min, max); | 		super("h_" + owner, min, max); | ||||||
| 		this.playerName = owner; | 		this.playerName = owner; | ||||||
| 		this.regionName = "h_" + owner; |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	public PlayerHome() { | 	public PlayerHome() { | ||||||
| 		this.cuboid = new Cuboid(); |  | ||||||
| 		this.playerName = ""; | 		this.playerName = ""; | ||||||
| 		this.regionName = ""; |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	public PlayerHome(ProtectedRegion homeRegion){ | 	public PlayerHome(ProtectedRegion homeRegion){ | ||||||
| @@ -46,7 +35,7 @@ public class PlayerHome implements Comparable<PlayerHome>{ | |||||||
| 				this.playerName = cuboidRegion.getId(); | 				this.playerName = cuboidRegion.getId(); | ||||||
| 			} | 			} | ||||||
| 			 | 			 | ||||||
| 			this.cuboid = new Cuboid(cuboidRegion.getMinimumPoint(), cuboidRegion.getMaximumPoint()); | 			setCuboid(new Cuboid(cuboidRegion.getMinimumPoint(), cuboidRegion.getMaximumPoint())); | ||||||
| 		}else if(homeRegion instanceof ProtectedPolygonalRegion){ | 		}else if(homeRegion instanceof ProtectedPolygonalRegion){ | ||||||
| 			ProtectedPolygonalRegion polygonalRegion = (ProtectedPolygonalRegion)homeRegion; | 			ProtectedPolygonalRegion polygonalRegion = (ProtectedPolygonalRegion)homeRegion; | ||||||
| 			if(polygonalRegion.getId().startsWith("h_") && polygonalRegion.getId().length() > 2){ | 			if(polygonalRegion.getId().startsWith("h_") && polygonalRegion.getId().length() > 2){ | ||||||
| @@ -55,22 +44,10 @@ public class PlayerHome implements Comparable<PlayerHome>{ | |||||||
| 				this.playerName = polygonalRegion.getId(); | 				this.playerName = polygonalRegion.getId(); | ||||||
| 			} | 			} | ||||||
| 			 | 			 | ||||||
| 			this.cuboid = new Cuboid(polygonalRegion.getMinimumPoint(), polygonalRegion.getMaximumPoint()); | 			setCuboid(new Cuboid(polygonalRegion.getMinimumPoint(), polygonalRegion.getMaximumPoint())); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public int getId(){return this.id;} |  | ||||||
| 	public void setId(int id){this.id = id;} |  | ||||||
| 	 |  | ||||||
| 	public String getPlayerName(){return this.playerName;} |  | ||||||
| 	public void setPlayerName(String playerName){this.playerName = playerName;} |  | ||||||
| 	 |  | ||||||
| 	public Cuboid getCuboid(){return this.cuboid;} |  | ||||||
| 	public void setCuboid(Cuboid cuboid){this.cuboid = cuboid;} |  | ||||||
|  |  | ||||||
| 	public String getRegionName(){return this.regionName;} |  | ||||||
| 	public void setRegionName(String regionName){this.regionName = regionName;} |  | ||||||
| 	 |  | ||||||
| 	@Override | 	@Override | ||||||
| 	public boolean equals(Object other) { | 	public boolean equals(Object other) { | ||||||
| 		if(!(other instanceof PlayerHome)){ | 		if(!(other instanceof PlayerHome)){ | ||||||
| @@ -83,31 +60,13 @@ public class PlayerHome implements Comparable<PlayerHome>{ | |||||||
| 			return false; | 			return false; | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		if(!this.cuboid.equals(otherPlayerHome.cuboid)){ | 		if(!getCuboid().equals(otherPlayerHome.getCuboid())){ | ||||||
| 			return false; | 			return false; | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	@Override |  | ||||||
| 	public int compareTo(PlayerHome another) { |  | ||||||
| 		return cuboid.compareTo(another.cuboid); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public BlockVector getPlotMin(int roadWidth) { |  | ||||||
| 		return new BlockVector(this.cuboid.minX - roadWidth/2, this.cuboid.minY, this.cuboid.minZ - roadWidth/2); |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	@Override |  | ||||||
| 	public String toString(){ |  | ||||||
| 		StringBuilder sb = new StringBuilder(); |  | ||||||
| 		 |  | ||||||
| 		sb.append(String.format("{PlayerHome }")); |  | ||||||
| 		 |  | ||||||
| 		return sb.toString(); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	public String toFriendlyString() { | 	public String toFriendlyString() { | ||||||
| 		StringBuilder sb = new StringBuilder(); | 		StringBuilder sb = new StringBuilder(); | ||||||
| 		 | 		 | ||||||
| @@ -116,12 +75,7 @@ public class PlayerHome implements Comparable<PlayerHome>{ | |||||||
| 		return sb.toString(); | 		return sb.toString(); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	public int getRow(int roadWidth, int plotSizeZ){ | 	public static PlayerHome get(ProtectedCuboidRegion cuboidRegion){ | ||||||
| 		BlockVector min = getPlotMin(roadWidth); | 		return new PlayerHome(cuboidRegion); | ||||||
| 		return min.getBlockZ() / plotSizeZ; |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	public int getCol(int roadWidth, int plotSizeX){ |  | ||||||
| 		return getPlotMin(roadWidth).getBlockX() / plotSizeX; |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,89 @@ | |||||||
|  | package com.majinnaibu.bukkitplugins.metropolis; | ||||||
|  |  | ||||||
|  | import javax.persistence.Entity; | ||||||
|  | import javax.persistence.Id; | ||||||
|  | import javax.persistence.Table; | ||||||
|  |  | ||||||
|  | import com.avaje.ebean.validation.NotNull; | ||||||
|  | import com.sk89q.worldedit.BlockVector; | ||||||
|  | import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion; | ||||||
|  |  | ||||||
|  | @Entity() | ||||||
|  | @Table(name="Metropolis_Plot") | ||||||
|  | public class Plot implements Comparable<PlayerHome>{ | ||||||
|  | 	@Id | ||||||
|  | 	private int _id; | ||||||
|  | 	public int getId(){return _id;} | ||||||
|  | 	public void setId(int id){_id = id;} | ||||||
|  | 	 | ||||||
|  | 	@NotNull | ||||||
|  | 	private Cuboid _cuboid; | ||||||
|  | 	public Cuboid getCuboid(){return _cuboid;} | ||||||
|  | 	public void setCuboid(Cuboid cuboid){_cuboid = cuboid;} | ||||||
|  |  | ||||||
|  | 	@NotNull | ||||||
|  | 	private String _regionName; | ||||||
|  | 	public String getRegionName(){return _regionName;} | ||||||
|  | 	public void setRegionName(String regionName){_regionName = regionName;} | ||||||
|  | 	 | ||||||
|  | 	public Plot(String regionName, BlockVector min, BlockVector max){ | ||||||
|  | 		_cuboid = new Cuboid(min, max); | ||||||
|  | 		_regionName = regionName; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	public Plot(ProtectedCuboidRegion cuboid){ | ||||||
|  | 		_cuboid = new Cuboid(cuboid.getMinimumPoint(), cuboid.getMaximumPoint()); | ||||||
|  | 		_regionName = cuboid.getId(); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	public Plot(){ | ||||||
|  | 		_cuboid = new Cuboid(); | ||||||
|  | 		_regionName = ""; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public BlockVector getPlotMin(int roadWidth) { | ||||||
|  | 		return new BlockVector(_cuboid.minX - roadWidth/2, _cuboid.minY, _cuboid.minZ - roadWidth/2); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	public int getRow(int roadWidth, int plotSizeZ){ | ||||||
|  | 		BlockVector min = getPlotMin(roadWidth); | ||||||
|  | 		return min.getBlockZ() / plotSizeZ; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	public int getCol(int roadWidth, int plotSizeX){ | ||||||
|  | 		return getPlotMin(roadWidth).getBlockX() / plotSizeX; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	@Override | ||||||
|  | 	public boolean equals(Object other) { | ||||||
|  | 		if(!(other instanceof Plot)){ | ||||||
|  | 			return super.equals(other); | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		Plot otherPlayerHome = (Plot)other; | ||||||
|  | 		 | ||||||
|  | 		if(!getCuboid().equals(otherPlayerHome.getCuboid())){ | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		return true; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@Override | ||||||
|  | 	public int compareTo(PlayerHome another) { | ||||||
|  | 		return getCuboid().compareTo(another.getCuboid()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@Override | ||||||
|  | 	public String toString(){ | ||||||
|  | 		StringBuilder sb = new StringBuilder(); | ||||||
|  | 		 | ||||||
|  | 		sb.append(String.format("{PlayerHome }")); | ||||||
|  | 		 | ||||||
|  | 		return sb.toString(); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	public static Plot get(ProtectedCuboidRegion cuboidRegion){ | ||||||
|  | 		return new Plot(cuboidRegion); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -0,0 +1,53 @@ | |||||||
|  | package com.majinnaibu.bukkitplugins.metropolis.commands; | ||||||
|  |  | ||||||
|  | import org.bukkit.command.Command; | ||||||
|  | import org.bukkit.command.CommandExecutor; | ||||||
|  | import org.bukkit.command.CommandSender; | ||||||
|  | import org.bukkit.entity.Player; | ||||||
|  |  | ||||||
|  | import com.majinnaibu.bukkitplugins.metropolis.Cuboid; | ||||||
|  | import com.majinnaibu.bukkitplugins.metropolis.MetropolisPlugin; | ||||||
|  | import com.sk89q.worldedit.bukkit.selections.Selection; | ||||||
|  |  | ||||||
|  | public class MetropolisPlotReserveCommand implements CommandExecutor { | ||||||
|  | 	MetropolisPlugin _plugin; | ||||||
|  |  | ||||||
|  | 	public MetropolisPlotReserveCommand(MetropolisPlugin metropolisPlugin) { | ||||||
|  | 		_plugin = metropolisPlugin; | ||||||
|  | 		 | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	@Override | ||||||
|  | 	public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) { | ||||||
|  | 		Cuboid cuboid = new Cuboid(); | ||||||
|  | 		if(sender instanceof Player && args.length == 1){ | ||||||
|  | 			Selection selection = _plugin.worldEdit.getSelection((Player) sender); | ||||||
|  | 			cuboid = new Cuboid(selection); | ||||||
|  | 		}else if(args.length == 6){ | ||||||
|  | 			int minX = Integer.parseInt(args[1]); | ||||||
|  | 			int minY = Integer.parseInt(args[2]); | ||||||
|  | 			int minZ = Integer.parseInt(args[3]); | ||||||
|  | 			int maxX = Integer.parseInt(args[4]); | ||||||
|  | 			int maxY = Integer.parseInt(args[5]); | ||||||
|  | 			int maxZ = Integer.parseInt(args[6]); | ||||||
|  | 			cuboid = new Cuboid(minX, minY, minZ, maxX, maxY, maxZ); | ||||||
|  | 		}else if(args.length == 4){ | ||||||
|  | 			int minX = Integer.parseInt(args[1]); | ||||||
|  | 			int minY = 0; | ||||||
|  | 			int minZ = Integer.parseInt(args[2]); | ||||||
|  | 			int maxX = Integer.parseInt(args[3]); | ||||||
|  | 			int maxY = _plugin.getWorld().getMaxHeight(); | ||||||
|  | 			int maxZ = Integer.parseInt(args[4]); | ||||||
|  | 			cuboid = new Cuboid(minX, minY, minZ, maxX, maxY, maxZ); | ||||||
|  | 		}else{ | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		String regionName = args[0]; | ||||||
|  | 		 | ||||||
|  | 		_plugin.reserveCuboid(regionName, cuboid); | ||||||
|  | 		 | ||||||
|  | 		return true; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -17,3 +17,7 @@ commands: | |||||||
|     description: This command resets the WorldGuard flags for all managed regions (city and h_*). |     description: This command resets the WorldGuard flags for all managed regions (city and h_*). | ||||||
|     permission: metropolis.flag.reset |     permission: metropolis.flag.reset | ||||||
|     usage: /metropolis-flag-reset |     usage: /metropolis-flag-reset | ||||||
|  |   metropolis-plot-reserve: | ||||||
|  |     description: This command reserves a plot so it won't be assigned as a home. | ||||||
|  |     permission: metropolis.plot.reserve | ||||||
|  |     usage: /metropolis-plot-reserve <minX> <minY> <minZ> <maxX> <maxY> <maxZ> | ||||||
		Reference in New Issue
	
	Block a user