fixed plot generation for even numbered plot sized and road widths
This commit is contained in:
		| @@ -221,4 +221,11 @@ public class Cuboid implements Comparable<Cuboid> { | |||||||
| 		 | 		 | ||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	@Override | ||||||
|  | 	public String toString() { | ||||||
|  | 		return String.format("{Cuboid minX=%d, minY=%d, minZ=%d, maxX=%d, maxY=%d, maxZ=%d}", minX, minY, minZ, maxX, maxY, maxZ); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	 | ||||||
| } | } | ||||||
|   | |||||||
| @@ -108,22 +108,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		if(DEBUG){log.info("Checking config");} | 		if(DEBUG){log.info("Checking config");} | ||||||
| 		Configuration config = getConfig(); | 		Configuration config = getConfig(); | ||||||
| 		if(!config.contains("version")){ | 		if(!config.contains("version")){ | ||||||
| 			//new or upgrading from ancient | 			//new | ||||||
| 			if(config.contains("plot.sizeX")){ | 			if(DEBUG){log.info("No config exists.  Assuming new installation.");} | ||||||
| 				if(DEBUG){log.info("Upgrading from a 0.4.6 config or newer.");} |  | ||||||
| 				//upgrading from ancient |  | ||||||
| 				int oldSizeX = safeGetIntFromConfig(config, "plot.sizeX"); |  | ||||||
| 				int oldSizeZ = safeGetIntFromConfig(config, "plot.sizeZ"); |  | ||||||
| 				int oldRoadWidth = safeGetIntFromConfig(config, "road.width"); |  | ||||||
| 				oldSizeX -= oldRoadWidth; |  | ||||||
| 				oldSizeZ -= oldRoadWidth; |  | ||||||
| 				config.set("plot.sizeX", oldSizeX); |  | ||||||
| 				config.set("plot.sizeZ", oldSizeZ); |  | ||||||
| 				saveConfig(); |  | ||||||
| 				if(DEBUG){log.info("Plot size updated");} |  | ||||||
| 			}else{ |  | ||||||
| 				if(DEBUG){log.info("No config exists.  Assuming new installation.");} |  | ||||||
| 			} |  | ||||||
| 		}else{ | 		}else{ | ||||||
| 			int configVersion = safeGetIntFromConfig(config, "version"); | 			int configVersion = safeGetIntFromConfig(config, "version"); | ||||||
| 			if(DEBUG){log.info(String.format("Updating config from version v%s to v%s.", configVersion, version));} | 			if(DEBUG){log.info(String.format("Updating config from version v%s to v%s.", configVersion, version));} | ||||||
| @@ -135,6 +121,9 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			if(DEBUG){log.info("Config updated");} | 			if(DEBUG){log.info("Config updated");} | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
|  | 		config.set("version", version); | ||||||
|  | 		saveConfig(); | ||||||
|  | 		 | ||||||
| 		config.options().copyDefaults(true); | 		config.options().copyDefaults(true); | ||||||
| 		 | 		 | ||||||
| 		if(DEBUG){log.info("Reading configuration from file.");} | 		if(DEBUG){log.info("Reading configuration from file.");} | ||||||
| @@ -220,7 +209,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		 | 		 | ||||||
| 		_spawnRegion = regionManager.getRegion("Spawn"); | 		_spawnRegion = regionManager.getRegion("Spawn"); | ||||||
| 		if(_spawnRegion == null){ | 		if(_spawnRegion == null){ | ||||||
| 			_spawnRegion = new ProtectedCuboidRegion("Spawn", getPlotMin(0, 0), this.getPlotMax(0,  0)); | 			_spawnRegion = new ProtectedCuboidRegion("Spawn", getPlotMin(0, 0), getPlotMax(0, 0)); | ||||||
| 			_spawnRegion.setPriority(1); | 			_spawnRegion.setPriority(1); | ||||||
| 			_spawnRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | 			_spawnRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | ||||||
| 			_spawnRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | 			_spawnRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | ||||||
| @@ -232,11 +221,27 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			_spawnRegion.setFlag(DefaultFlag.LAVA_FLOW, StateFlag.State.DENY); | 			_spawnRegion.setFlag(DefaultFlag.LAVA_FLOW, StateFlag.State.DENY); | ||||||
| 			_spawnRegion.setFlag(DefaultFlag.SNOW_FALL, StateFlag.State.DENY); | 			_spawnRegion.setFlag(DefaultFlag.SNOW_FALL, StateFlag.State.DENY); | ||||||
| 			regionManager.addRegion(_spawnRegion); | 			regionManager.addRegion(_spawnRegion); | ||||||
|  | 			 | ||||||
|  | 			_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | ||||||
|  | 			 | ||||||
| 			setupSpawn(); | 			setupSpawn(); | ||||||
|  | 		}else{ | ||||||
|  | 			_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | 		_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | ||||||
| 		 | 		 | ||||||
|  | 		if(DEBUG){ | ||||||
|  | 			log.info("Metropolis: first 9 plots"); | ||||||
|  | 			 | ||||||
|  | 			for (int ix=-1; ix<=1;ix++){ | ||||||
|  | 				for (int iz=-1; iz<=1; iz++){ | ||||||
|  | 					log.info(getCuboid(iz, ix).toString());				 | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
| 		_occupiedPlots = new ArrayList<Plot>(); | 		_occupiedPlots = new ArrayList<Plot>(); | ||||||
| 		fillOccupiedPlots(); | 		fillOccupiedPlots(); | ||||||
| 		resizeCityRegion(); | 		resizeCityRegion(); | ||||||
| @@ -266,6 +271,12 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		RegisterCommandHandler("metropolis-plot-reserve", new MetropolisPlotReserveCommand(this)); | 		RegisterCommandHandler("metropolis-plot-reserve", new MetropolisPlotReserveCommand(this)); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|  | 	private Cuboid getCuboid(int row, int col) { | ||||||
|  | 		BlockVector min = getPlotMin(row, col); | ||||||
|  | 		BlockVector max = getPlotMax(row, col); | ||||||
|  | 		return new Cuboid(min, max); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	private void RegisterCommandHandler(String commandName, CommandExecutor executor){ | 	private void RegisterCommandHandler(String commandName, CommandExecutor executor){ | ||||||
| 		PluginCommand command = getCommand(commandName); | 		PluginCommand command = getCommand(commandName); | ||||||
| 		if(command == null){ | 		if(command == null){ | ||||||
| @@ -322,16 +333,16 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	private void setupSpawn() { | 	private void setupSpawn() { | ||||||
| 		BlockVector min = getPlotMin(0, 0); | 		log.info("Metropolis: Spawn Cuboid is " + _spawnCuboid.toString()); | ||||||
| 		BlockVector max = getPlotMax(0, 0); |  | ||||||
| 		 | 		 | ||||||
| 		if(generateSpawn){ | 		if(generateSpawn){ | ||||||
| 			int x= 0; | 			int x= 0; | ||||||
| 			int y=roadLevel; | 			int y=roadLevel; | ||||||
| 			int z=0; | 			int z=0; | ||||||
| 			 | 			 | ||||||
| 			for(x=min.getBlockX(); x<= max.getBlockX(); x++){ | 			//floor | ||||||
| 				for(z=min.getBlockZ(); z<= max.getBlockZ(); z++){ | 			for(x=_spawnCuboid.getMinX(); x<= _spawnCuboid.getMaxX(); x++){ | ||||||
|  | 				for(z=_spawnCuboid.getMinZ(); z<=_spawnCuboid.getMaxZ(); z++){ | ||||||
| 					for(y=roadLevel+1; y<world.getMaxHeight(); y++){ | 					for(y=roadLevel+1; y<world.getMaxHeight(); y++){ | ||||||
| 						Block block = world.getBlockAt(x, y, z); | 						Block block = world.getBlockAt(x, y, z); | ||||||
| 						block.setType(Material.AIR); | 						block.setType(Material.AIR); | ||||||
| @@ -342,11 +353,13 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 					block.setType(spawnFloorMaterial); | 					block.setType(spawnFloorMaterial); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  | 			 | ||||||
|  | 			//roads | ||||||
|  | 			createRoads(_spawnCuboid); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		if(setWorldSpawn){ | 		if(setWorldSpawn){ | ||||||
| 			Cuboid spawnCuboid = new Cuboid(min, max); | 			world.setSpawnLocation(_spawnCuboid.getCenterX(), roadLevel+1, _spawnCuboid.getCenterZ()); | ||||||
| 			world.setSpawnLocation(spawnCuboid.getCenterX(), roadLevel+1, spawnCuboid.getCenterZ()); |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -396,8 +409,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		int y=roadLevel; | 		int y=roadLevel; | ||||||
| 		int z=0; | 		int z=0; | ||||||
| 		 | 		 | ||||||
| 		for(x = plotCuboid.minX + roadWidth/2; x <= plotCuboid.maxX - roadWidth/2; x++){ | 		for(x = plotCuboid.minX; x <= plotCuboid.maxX; x++){ | ||||||
| 			for(z=plotCuboid.minZ + roadWidth/2; z<=plotCuboid.maxZ - roadWidth/2; z++){ | 			for(z=plotCuboid.minZ; z<=plotCuboid.maxZ; z++){ | ||||||
| 				Block block = world.getBlockAt(x, y, z); | 				Block block = world.getBlockAt(x, y, z); | ||||||
| 				//Set the floor block | 				//Set the floor block | ||||||
| 				block.setType(floorMaterial); | 				block.setType(floorMaterial); | ||||||
| @@ -442,7 +455,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			 | 			 | ||||||
| 			//North Strip | 			//North Strip | ||||||
| 			if((roadMask & ROAD_NORTH) != 0){ | 			if((roadMask & ROAD_NORTH) != 0){ | ||||||
| 				for(x=plotCuboid.minX; x<plotCuboid.maxX; x++){ | 				for(x=plotCuboid.minX; x<=plotCuboid.maxX; x++){ | ||||||
| 					for(z=plotCuboid.minZ - roadWidth; z<plotCuboid.minZ; z++){ | 					for(z=plotCuboid.minZ - roadWidth; z<plotCuboid.minZ; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| @@ -451,8 +464,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			 | 			 | ||||||
| 			//North East Corner | 			//North East Corner | ||||||
| 			if((roadMask & (ROAD_NORTH | ROAD_EAST)) != 0){ | 			if((roadMask & (ROAD_NORTH | ROAD_EAST)) != 0){ | ||||||
| 				for(x=plotCuboid.maxX; x<plotCuboid.maxX + roadWidth;x++){ | 				for(x=plotCuboid.maxX+1; x<=plotCuboid.maxX + roadWidth; x++){ | ||||||
| 					for(z=plotCuboid.minZ-roadWidth; z<plotCuboid.minZ; z++){ | 					for(z=plotCuboid.minZ - roadWidth; z<plotCuboid.minZ; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -460,8 +473,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			 | 			 | ||||||
| 			//East Strip | 			//East Strip | ||||||
| 			if((roadMask & ROAD_EAST) != 0){ | 			if((roadMask & ROAD_EAST) != 0){ | ||||||
| 				for(x=plotCuboid.maxX; x<plotCuboid.maxX + roadWidth; x++){ | 				for(x=plotCuboid.maxX+1; x<=plotCuboid.maxX + roadWidth; x++){ | ||||||
| 					for(z=plotCuboid.minZ; z<plotCuboid.maxZ; z++){ | 					for(z=plotCuboid.minZ; z<=plotCuboid.maxZ; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -469,8 +482,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			 | 			 | ||||||
| 			//South East Corner | 			//South East Corner | ||||||
| 			if((roadMask & (ROAD_SOUTH | ROAD_EAST)) != 0){ | 			if((roadMask & (ROAD_SOUTH | ROAD_EAST)) != 0){ | ||||||
| 				for(x=plotCuboid.maxX; x<plotCuboid.maxX + roadWidth; x++){ | 				for(x=plotCuboid.maxX+1; x<=plotCuboid.maxX + roadWidth; x++){ | ||||||
| 					for(z=plotCuboid.maxZ; z<plotCuboid.maxZ + roadWidth; z++){ | 					for(z=plotCuboid.maxZ+1; z<=plotCuboid.maxZ + roadWidth; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -478,8 +491,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			 | 			 | ||||||
| 			//South Strip | 			//South Strip | ||||||
| 			if((roadMask & ROAD_SOUTH) != 0){ | 			if((roadMask & ROAD_SOUTH) != 0){ | ||||||
| 				for(x=plotCuboid.minX; x<plotCuboid.maxX; x++){ | 				for(x=plotCuboid.minX; x<=plotCuboid.maxX; x++){ | ||||||
| 					for(z=plotCuboid.maxZ; z<plotCuboid.maxZ+roadWidth; z++){ | 					for(z=plotCuboid.maxZ+1; z<=plotCuboid.maxZ + roadWidth; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -488,7 +501,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			//South West Corner | 			//South West Corner | ||||||
| 			if((roadMask & (ROAD_SOUTH | ROAD_WEST)) != 0){ | 			if((roadMask & (ROAD_SOUTH | ROAD_WEST)) != 0){ | ||||||
| 				for(x=plotCuboid.minX - roadWidth; x<plotCuboid.minX; x++){ | 				for(x=plotCuboid.minX - roadWidth; x<plotCuboid.minX; x++){ | ||||||
| 					for(z=plotCuboid.maxZ; z<plotCuboid.maxZ + roadWidth; z++){ | 					for(z=plotCuboid.maxZ+1; z<=plotCuboid.maxZ + roadWidth; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -497,7 +510,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			//West Strip | 			//West Strip | ||||||
| 			if((roadMask & ROAD_WEST) != 0){ | 			if((roadMask & ROAD_WEST) != 0){ | ||||||
| 				for(x=plotCuboid.minX - roadWidth; x<plotCuboid.minX; x++){ | 				for(x=plotCuboid.minX - roadWidth; x<plotCuboid.minX; x++){ | ||||||
| 					for(z=plotCuboid.minZ; z<plotCuboid.maxZ; z++){ | 					for(z=plotCuboid.minZ; z<=plotCuboid.maxZ; z++){ | ||||||
| 						setRoad(x, y, z); | 						setRoad(x, y, z); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| @@ -513,6 +526,7 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		Block block = world.getBlockAt(x, y, z); | 		Block block = world.getBlockAt(x, y, z); | ||||||
| 		//Set the road block | 		//Set the road block | ||||||
| 		block.setType(roadMaterial); | 		block.setType(roadMaterial); | ||||||
|  | 		 | ||||||
| 		//Set the support | 		//Set the support | ||||||
| 		if(generateRoadSupports && isPhysicsMaterial(block.getType())){ | 		if(generateRoadSupports && isPhysicsMaterial(block.getType())){ | ||||||
| 			Block blockUnder = world.getBlockAt(x, y-1, z); | 			Block blockUnder = world.getBlockAt(x, y-1, z); | ||||||
| @@ -670,15 +684,11 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	private int getPlotXFromMin(Cuboid cuboid) { | 	private int getPlotXFromMin(Cuboid cuboid) { | ||||||
| 		int minX = cuboid.getMin().getBlockX() - roadWidth/2; | 		return (cuboid.minX - roadWidth/2)/gridSizeX; | ||||||
| 		 |  | ||||||
| 		return minX/gridSizeX; |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	private int getPlotZFromMin(Cuboid cuboid) { | 	private int getPlotZFromMin(Cuboid cuboid) { | ||||||
| 		int minZ = cuboid.getMin().getBlockZ() - roadWidth/2; | 		return (cuboid.minZ - roadWidth/2)/gridSizeZ; | ||||||
| 		 |  | ||||||
| 		return minZ/gridSizeZ; |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	private void setHomeOccupied(String owner, BlockVector minimumPoint, BlockVector maximumPoint) { | 	private void setHomeOccupied(String owner, BlockVector minimumPoint, BlockVector maximumPoint) { | ||||||
| @@ -689,10 +699,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	 |  | ||||||
| 	public PlayerHome generateHome(String playerName) { | 	public PlayerHome generateHome(String playerName) { | ||||||
| 		if(DEBUG){log.info(String.format("Generating home for %s", playerName));} | 		if(DEBUG){log.info(String.format("Generating home for %s", playerName));} | ||||||
| 		Cuboid plotCuboid = null; |  | ||||||
| 		Cuboid homeCuboid = null; | 		Cuboid homeCuboid = null; | ||||||
| 		ProtectedRegion homeRegion = null; | 		ProtectedRegion homeRegion = null; | ||||||
| 		String regionName = "h_" + playerName; | 		String regionName = "h_" + playerName; | ||||||
| @@ -701,8 +709,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 			return PlayerHome.get(homeRegion); | 			return PlayerHome.get(homeRegion); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		plotCuboid = findNextUnownedHomeRegion(); | 		homeCuboid = findNextUnownedHomeRegion(); | ||||||
| 		homeCuboid = plotCuboid.inset(roadWidth/2, roadWidth/2); | 		log.info("Metropolis Generating home in " + homeCuboid.toString()); | ||||||
| 		homeRegion = new ProtectedCuboidRegion(regionName, homeCuboid.getMin(), homeCuboid.getMax()); | 		homeRegion = new ProtectedCuboidRegion(regionName, homeCuboid.getMin(), homeCuboid.getMax()); | ||||||
| 		homeRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | 		homeRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | ||||||
| 		homeRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | 		homeRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | ||||||
| @@ -725,15 +733,15 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 	 | 	 | ||||||
| 		setHomeOccupied(playerName, homeRegion.getMinimumPoint(), homeRegion.getMaximumPoint()); | 		setHomeOccupied(playerName, homeRegion.getMinimumPoint(), homeRegion.getMaximumPoint()); | ||||||
| 		 | 		 | ||||||
| 		createRoads(plotCuboid); | 		createRoads(homeCuboid); | ||||||
| 		 | 		 | ||||||
| 		if(generateFloor){ | 		if(generateFloor){ | ||||||
| 			generateFloor(plotCuboid); | 			generateFloor(homeCuboid); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		if(DEBUG){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(homeCuboid, playerName); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		if(DEBUG){log.info(String.format("Done generating home for %s", playerName));} | 		if(DEBUG){log.info(String.format("Done generating home for %s", playerName));} | ||||||
| @@ -754,6 +762,8 @@ public class MetropolisPlugin extends JavaPlugin { | |||||||
| 				sign.setLine(3, playerName.substring(31, Math.min(45, playerName.length()))); | 				sign.setLine(3, playerName.substring(31, Math.min(45, playerName.length()))); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  | 		 | ||||||
|  | 		sign.update(true); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public List<Plot> getCityBlocks() { | 	public List<Plot> getCityBlocks() { | ||||||
|   | |||||||
| @@ -3,6 +3,7 @@ plot: | |||||||
|   sizeZ: 24 |   sizeZ: 24 | ||||||
|   floor: |   floor: | ||||||
|     generate: true |     generate: true | ||||||
|  |     clearSpaceAbove: 66 | ||||||
|     material: 2 |     material: 2 | ||||||
|     supports: |     supports: | ||||||
|       generate: true |       generate: true | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user