--- miscJava/bukkit-minecraft-plugins/HoerupUtils/src/dk/thoerup/bukkit/hoeruputils/secretdoor/DoorBlockListener.java 2011/06/27 18:10:05 1532 +++ miscJava/bukkit-minecraft-plugins/HoerupUtils/src/dk/thoerup/bukkit/hoeruputils/secretdoor/DoorBlockListener.java 2011/06/29 18:16:51 1538 @@ -1,7 +1,11 @@ package dk.thoerup.bukkit.hoeruputils.secretdoor; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + import org.bukkit.block.Block; +import org.bukkit.entity.Player; import org.bukkit.event.block.BlockBreakEvent; import org.bukkit.event.block.BlockListener; import org.bukkit.event.block.SignChangeEvent; @@ -12,10 +16,10 @@ public class DoorBlockListener extends BlockListener { - DoorStorage store; + private DoorStorage store; private DoorOpenListener handler; - Plugin plugin; + private Plugin plugin; public DoorBlockListener(Plugin plugin) { this.plugin = plugin; @@ -35,7 +39,16 @@ public void onBlockBreak(BlockBreakEvent event) { Door door = store.findDoor(event.getBlock().getLocation() ); if (door != null) { - event.getPlayer().sendMessage("Secret door broken"); + Player player = event.getPlayer(); + if ( ! door.getOwner().equals( player.getName() )) { + + Player owner = player.getServer().getPlayer( door.getOwner() ); + + if (owner != null) { + owner.sendMessage("" + player.getName() + " broke one of your secret doors"); + } + } + player.sendMessage("Secret door broken"); store.removeDoor(door); } } @@ -49,15 +62,47 @@ // don't react on floor signs return; } + + String line0 = event.getLine(0).trim().toLowerCase(); + String line1 = event.getLine(1).trim().toLowerCase(); + + int width = 2; + int height = 2; - if (event.getLine(0).toLowerCase().equals("secretdoor") ) { - Door door = new Door(sign); + if (line0.equals("secretdoor") ) { + if ( ! line1.equals("")) { + Pattern p = Pattern.compile("^[0-9]x[0-9]$"); + Matcher m = p.matcher(line1); + + if ( !m.matches() ) { + event.getPlayer().sendMessage("The second line must be of the format [width]x[height]"); + return; + } + + String parts[] = line1.split("x"); + width = Integer.parseInt( parts[0] ); + height = Integer.parseInt( parts[0] ); + + if (width <1 || width>5) { + event.getPlayer().sendMessage("width must be between 1 and 5 (inclusive)"); + return; + } + if (height <2 || height>5) { + event.getPlayer().sendMessage("height must be between 2 and 5 (inclusive)"); + return; + } + } + try { + Door door = new Door(sign, width, height, store, event.getPlayer().getName() ); - store.addDoor(door); + store.addDoor(door); - event.getPlayer().sendMessage("Secret door created"); + event.getPlayer().sendMessage("Secret door created"); - sign.setTypeId(0); + sign.setTypeId(0); + } catch (ConflictingDoorException e) { + event.getPlayer().sendMessage("Door conflicts whith another secretdoor"); + } }