From cb002502f858b49503e5a7d9f8bc9ea43f53c623 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Sun, 29 Jul 2012 02:34:09 -0500 Subject: [PATCH] Update Bukkit for 1.3.1 changes By: feildmaster --- paper-api/pom.xml | 2 +- .../src/main/java/org/bukkit/GameMode.java | 9 ++- .../src/main/java/org/bukkit/Material.java | 22 ++++++- .../main/java/org/bukkit/command/Command.java | 18 +++++- .../org/bukkit/command/SimpleCommandMap.java | 4 +- .../bukkit/command/TabCommandExecutor.java | 10 +++ .../bukkit/command/defaults/BanCommand.java | 21 +++++-- .../bukkit/command/defaults/BanIpCommand.java | 36 +++++++++-- .../command/defaults/BanListCommand.java | 28 ++++++--- .../defaults/DefaultGameModeCommand.java | 52 ++++++++++++++++ .../bukkit/command/defaults/DeopCommand.java | 12 ++-- .../bukkit/command/defaults/ExpCommand.java | 26 ++++---- .../command/defaults/GameModeCommand.java | 46 +++++++++----- .../bukkit/command/defaults/GiveCommand.java | 13 ++-- .../bukkit/command/defaults/KickCommand.java | 17 +++-- .../bukkit/command/defaults/KillCommand.java | 1 + .../bukkit/command/defaults/ListCommand.java | 14 +++-- .../bukkit/command/defaults/MeCommand.java | 9 ++- .../bukkit/command/defaults/OpCommand.java | 11 +--- .../command/defaults/PardonCommand.java | 4 +- .../command/defaults/PardonIpCommand.java | 9 ++- .../command/defaults/SaveOffCommand.java | 4 +- .../command/defaults/SaveOnCommand.java | 3 +- .../bukkit/command/defaults/SayCommand.java | 3 +- .../bukkit/command/defaults/SeedCommand.java | 26 ++++++++ .../command/defaults/TeleportCommand.java | 43 +++++++++---- .../bukkit/command/defaults/TimeCommand.java | 62 ++++++++++--------- .../command/defaults/VanillaCommand.java | 41 +++++++++++- .../bukkit/event/inventory/InventoryType.java | 11 +++- .../bukkit/inventory/MerchantInventory.java | 4 ++ .../util/permissions/CommandPermissions.java | 4 +- 31 files changed, 416 insertions(+), 149 deletions(-) create mode 100644 paper-api/src/main/java/org/bukkit/command/TabCommandExecutor.java create mode 100644 paper-api/src/main/java/org/bukkit/command/defaults/DefaultGameModeCommand.java create mode 100644 paper-api/src/main/java/org/bukkit/command/defaults/SeedCommand.java create mode 100644 paper-api/src/main/java/org/bukkit/inventory/MerchantInventory.java diff --git a/paper-api/pom.xml b/paper-api/pom.xml index cec0b8025d..abfedfd6ea 100644 --- a/paper-api/pom.xml +++ b/paper-api/pom.xml @@ -2,7 +2,7 @@ 4.0.0 org.bukkit bukkit - 1.2.5-R5.1-SNAPSHOT + 1.3.1-R0.1-SNAPSHOT Bukkit http://www.bukkit.org diff --git a/paper-api/src/main/java/org/bukkit/GameMode.java b/paper-api/src/main/java/org/bukkit/GameMode.java index b81b069ca4..46ba7f2d0a 100644 --- a/paper-api/src/main/java/org/bukkit/GameMode.java +++ b/paper-api/src/main/java/org/bukkit/GameMode.java @@ -11,14 +11,19 @@ import com.google.common.collect.Maps; */ public enum GameMode { /** - * Creative mode may fly, build instantly, become invulnerable and create free items + * Creative mode may fly, build instantly, become invulnerable and create free items. */ CREATIVE(1), /** * Survival mode is the "normal" gameplay type, with no special features. */ - SURVIVAL(0); + SURVIVAL(0), + + /** + * Adventure mode cannot break blocks, use chat, use buckets, etc. + */ + ADVENTURE(2); private final int value; private final static Map BY_ID = Maps.newHashMap(); diff --git a/paper-api/src/main/java/org/bukkit/Material.java b/paper-api/src/main/java/org/bukkit/Material.java index 74edacf059..7ae6045f72 100644 --- a/paper-api/src/main/java/org/bukkit/Material.java +++ b/paper-api/src/main/java/org/bukkit/Material.java @@ -211,9 +211,9 @@ public enum Material { GRILLED_PORK(320), PAINTING(321), GOLDEN_APPLE(322), - SIGN(323, 1), + SIGN(323, 16), WOOD_DOOR(324, 1), - BUCKET(325, 1), + BUCKET(325, 16), WATER_BUCKET(326, 1), LAVA_BUCKET(327, 1), MINECART(328, 1), @@ -290,7 +290,23 @@ public enum Material { RECORD_8(2263, 1), RECORD_9(2264, 1), RECORD_10(2265, 1), - RECORD_11(2266, 1); + RECORD_11(2266, 1), + WOOD_DOUBLE_STEP(125, Step.class), + WOOD_STEP(126, Step.class), + COCOA(127), + SANDSTONE_STAIRS(128, Stairs.class), + EMERALD_ORE(129), + ENDER_CHEST(130), + TRIPWIRE_HOOK(131, Button.class), + TRIPWIRE(132), + EMERALD_BLOCK(133), + SPRUCE_WOOD_STAIRS(134), + BIRCH_WOOD_STAIRS(135), + JUNGLE_WOOD_STAIRS(136), + BOOK_AND_QUILL(386, 1), + WRITTEN_BOOK(387, 1), + EMERALD(388, 64); + private final int id; private final Class data; diff --git a/paper-api/src/main/java/org/bukkit/command/Command.java b/paper-api/src/main/java/org/bukkit/command/Command.java index 5a7015911c..fca9c91dd7 100644 --- a/paper-api/src/main/java/org/bukkit/command/Command.java +++ b/paper-api/src/main/java/org/bukkit/command/Command.java @@ -47,6 +47,22 @@ public abstract class Command { */ public abstract boolean execute(CommandSender sender, String commandLabel, String[] args); + /** + * Executed on tab completion for this command, returning a list of options + * the player can tab through. + *

+ * By returning null, you tell Bukkit to generate a list of players to send + * to the sender. + * By returning an empty list, no options will be sent. + * + * @param sender Source object which is executing this command + * @param args All arguments passed to the command, split via ' ' + * @return null to generate a Player list, otherwise a list of options + */ + public List tabComplete(CommandSender sender, String[] args) { + return null; + } + /** * Returns the name of this command * @@ -110,7 +126,7 @@ public abstract class Command { if ((permission == null) || (permission.length() == 0)) { return true; } - + for (String p : permission.split(";")) { if (target.hasPermission(p)) { return true; diff --git a/paper-api/src/main/java/org/bukkit/command/SimpleCommandMap.java b/paper-api/src/main/java/org/bukkit/command/SimpleCommandMap.java index e4a7ba3e7a..384a01ec25 100644 --- a/paper-api/src/main/java/org/bukkit/command/SimpleCommandMap.java +++ b/paper-api/src/main/java/org/bukkit/command/SimpleCommandMap.java @@ -39,6 +39,8 @@ public class SimpleCommandMap implements CommandMap { fallbackCommands.add(new ExpCommand()); fallbackCommands.add(new ToggleDownfallCommand()); fallbackCommands.add(new BanListCommand()); + fallbackCommands.add(new DefaultGameModeCommand()); + fallbackCommands.add(new SeedCommand()); } public SimpleCommandMap(final Server server) { @@ -139,7 +141,7 @@ public class SimpleCommandMap implements CommandMap { return null; } - + public Set getFallbackCommands() { return Collections.unmodifiableSet(fallbackCommands); } diff --git a/paper-api/src/main/java/org/bukkit/command/TabCommandExecutor.java b/paper-api/src/main/java/org/bukkit/command/TabCommandExecutor.java new file mode 100644 index 0000000000..b2ee58c525 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/command/TabCommandExecutor.java @@ -0,0 +1,10 @@ +package org.bukkit.command; + +import java.util.List; + +/** + * Represents a class which can handle command tab completion and commands + */ +public interface TabCommandExecutor extends CommandExecutor { + public List onTabComplete(); +} diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/BanCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/BanCommand.java index aa7f353434..76d4cf6fd8 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/BanCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/BanCommand.java @@ -1,33 +1,44 @@ package org.bukkit.command.defaults; +import java.util.List; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; +import org.bukkit.entity.Player; public class BanCommand extends VanillaCommand { public BanCommand() { super("ban"); this.description = "Prevents the specified player from using this server"; - this.usageMessage = "/ban "; + this.usageMessage = "/ban [reason ...]"; this.setPermission("bukkit.command.ban.player"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 1) { + if (args.length == 0) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } + // TODO: Ban Reason support Bukkit.getOfflinePlayer(args[0]).setBanned(true); - if (Bukkit.getPlayer(args[0]) != null) Bukkit.getPlayer(args[0]).kickPlayer("Banned by admin."); - Command.broadcastCommandMessage(sender, "Banning " + args[0]); + Player player = Bukkit.getPlayer(args[0]); + if (player != null) { + player.kickPlayer("Banned by admin."); + } + + sender.sendMessage("Banned player " + args[0]); return true; } + @Override + public List tabComplete(CommandSender sender, String[] args) { + return args.length >= 1 ? null : EMPTY_LIST; + } + @Override public boolean matches(String input) { return input.equalsIgnoreCase("ban"); diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/BanIpCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/BanIpCommand.java index bb08989069..1bb6b0c511 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/BanIpCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/BanIpCommand.java @@ -1,32 +1,58 @@ package org.bukkit.command.defaults; +import java.util.List; +import java.util.regex.Pattern; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; +import org.bukkit.entity.Player; public class BanIpCommand extends VanillaCommand { + public static final Pattern ipValidity = Pattern.compile("^([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\.([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\.([01]?\\d\\d?|2[0-4]\\d|25[0-5])\\.([01]?\\d\\d?|2[0-4]\\d|25[0-5])$"); + public BanIpCommand() { super("ban-ip"); this.description = "Prevents the specified IP address from using this server"; - this.usageMessage = "/ban-ip

"; + this.usageMessage = "/ban-ip [reason ...]"; this.setPermission("bukkit.command.ban.ip"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 1) { + if (args.length < 1) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } - Bukkit.banIP(args[0]); - Command.broadcastCommandMessage(sender, "Banning ip " + args[0]); + // TODO: Ban Reason support + if (ipValidity.matcher(args[0]).matches()) { + processIPBan(args[0], sender); + } else { + Player player = Bukkit.getPlayer(args[0]); + + if (player == null) { + sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); + return false; + } + processIPBan(player.getAddress().getAddress().getHostAddress(), sender); + } return true; } + @Override + public List tabComplete(CommandSender sender, String[] args) { + return args.length >= 1 ? null : EMPTY_LIST; + } + + private void processIPBan(String ip, CommandSender sender) { + // TODO: Kick on ban + Bukkit.banIP(ip); + + sender.sendMessage("Banned IP Address " + ip); + } + @Override public boolean matches(String input) { return input.equalsIgnoreCase("ban-ip"); diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/BanListCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/BanListCommand.java index 57c37c44d3..668a487737 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/BanListCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/BanListCommand.java @@ -1,7 +1,7 @@ package org.bukkit.command.defaults; +import java.util.List; import org.bukkit.Bukkit; -import org.bukkit.ChatColor; import org.bukkit.OfflinePlayer; import org.bukkit.command.CommandSender; @@ -9,7 +9,7 @@ public class BanListCommand extends VanillaCommand { public BanListCommand() { super("banlist"); this.description = "View all players banned from this server"; - this.usageMessage = "/banlist"; + this.usageMessage = "/banlist [ips|players]"; this.setPermission("bukkit.command.ban.list"); } @@ -17,19 +17,31 @@ public class BanListCommand extends VanillaCommand { public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - StringBuilder message = new StringBuilder().append(ChatColor.GRAY).append("Ban list: "); + // TODO: ips support + StringBuilder message = new StringBuilder(); + OfflinePlayer[] banlist = Bukkit.getServer().getBannedPlayers().toArray(new OfflinePlayer[0]); - int count = 0; - for (OfflinePlayer p : Bukkit.getServer().getBannedPlayers()) { - if (count++ > 0) { - message.append(", "); + for (int x = 0; x < banlist.length; x++) { + if (x != 0) { + if (x == banlist.length - 1) { + message.append(" and "); + } else { + message.append(", "); + } } - message.append(p.getName()); + message.append(banlist[x].getName()); } + + sender.sendMessage("There are " + banlist.length + " total banned players:"); sender.sendMessage(message.toString()); return true; } + @Override + public List tabComplete(CommandSender sender, String[] args) { + return args.length >= 1 ? null : EMPTY_LIST; + } + @Override public boolean matches(String input) { return input.equalsIgnoreCase("banlist"); diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/DefaultGameModeCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/DefaultGameModeCommand.java new file mode 100644 index 0000000000..d323bee601 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/command/defaults/DefaultGameModeCommand.java @@ -0,0 +1,52 @@ +package org.bukkit.command.defaults; + +import org.bukkit.Bukkit; +import org.bukkit.GameMode; +import org.bukkit.command.CommandSender; + +public class DefaultGameModeCommand extends VanillaCommand { + public DefaultGameModeCommand() { + super("defaultgamemode"); + this.description = "Set the default gamemode"; + this.usageMessage = "/defaultgamemode "; + this.setPermission("bukkit.command.defaultgamemode"); + } + + @Override + public boolean matches(String input) { + return input.equalsIgnoreCase(this.getName()); + } + + @Override + public boolean execute(CommandSender sender, String commandLabel, String[] args) { + if (args.length == 0) { + sender.sendMessage("Useage: " + usageMessage); + return false; + } + + String modeArg = args[0]; + int value = -1; + + try { + value = Integer.parseInt(modeArg); + } catch (NumberFormatException ex) {} + + GameMode mode = GameMode.getByValue(value); + + if (mode == null) { + if (modeArg.equalsIgnoreCase("creative") || modeArg.equalsIgnoreCase("c")) { + mode = GameMode.CREATIVE; + } else if (modeArg.equalsIgnoreCase("adventure") || modeArg.equalsIgnoreCase("a")) { + mode = GameMode.ADVENTURE; + } else { + mode = GameMode.SURVIVAL; + } + } + + Bukkit.getServer().setDefaultGameMode(mode); + sender.sendMessage("Default game mode set to " + mode.toString().toLowerCase()); + + return true; + } + +} diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/DeopCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/DeopCommand.java index e5c9a1ec65..291c049772 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/DeopCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/DeopCommand.java @@ -1,9 +1,9 @@ package org.bukkit.command.defaults; +import java.util.List; import org.bukkit.Bukkit; import org.bukkit.ChatColor; import org.bukkit.OfflinePlayer; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; @@ -18,13 +18,11 @@ public class DeopCommand extends VanillaCommand { @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 1) { + if (args.length != 1 || args[0].length() == 0) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } - Command.broadcastCommandMessage(sender, "De-opping " + args[0]); - OfflinePlayer player = Bukkit.getOfflinePlayer(args[0]); player.setOp(false); @@ -32,9 +30,15 @@ public class DeopCommand extends VanillaCommand { ((Player) player).sendMessage(ChatColor.YELLOW + "You are no longer op!"); } + sender.sendMessage("De-opped " + args[0]); return true; } + @Override + public List tabComplete(CommandSender sender, String[] args) { + return args.length >= 1 ? null : EMPTY_LIST; + } + @Override public boolean matches(String input) { return input.equalsIgnoreCase("deop"); diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/ExpCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/ExpCommand.java index 674e6e009d..478100212a 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/ExpCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/ExpCommand.java @@ -2,7 +2,6 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; @@ -10,32 +9,31 @@ public class ExpCommand extends VanillaCommand { public ExpCommand() { super("xp"); this.description = "Gives the specified player a certain amount of experience"; - this.usageMessage = "/xp "; + this.usageMessage = "/xp [player]"; this.setPermission("bukkit.command.xp"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 2) { + if (args.length < 1) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } + int exp = getInteger(sender, args[0], 0, 5000); + Player player = null; - Player player = Bukkit.getPlayerExact(args[0]); + if (args.length > 1) { + player = Bukkit.getPlayer(args[1]); + } else if (sender instanceof Player) { + player = (Player) sender; + } if (player != null) { - try { - int exp = Integer.parseInt(args[1]); - - Command.broadcastCommandMessage(sender, "Giving " + exp + " exp to " + player.getName()); - - player.giveExp(exp); - } catch (NumberFormatException ex) { - sender.sendMessage("Invalid exp count: " + args[1]); - } + player.giveExp(exp); + sender.sendMessage("Giving " + exp + " exp to " + player.getName()); } else { - sender.sendMessage("Can't find user " + args[0]); + sender.sendMessage("Can't find user, was one provided?\n" + ChatColor.RED + "Usage: " + usageMessage); } return true; diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/GameModeCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/GameModeCommand.java index c1694219e0..90f3ea533e 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/GameModeCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/GameModeCommand.java @@ -2,7 +2,6 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; import org.bukkit.GameMode; @@ -11,46 +10,59 @@ public class GameModeCommand extends VanillaCommand { public GameModeCommand() { super("gamemode"); this.description = "Changes the player to a specific game mode"; - this.usageMessage = "/gamemode "; + this.usageMessage = "/gamemode [player]"; this.setPermission("bukkit.command.gamemode"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 2) { + if (args.length == 0) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } - Player player = Bukkit.getPlayerExact(args[0]); + String modeArg = args[0]; + String playerArg = sender.getName(); + + if (args.length == 2) { + playerArg = args[1]; + } + + Player player = Bukkit.getPlayerExact(playerArg); if (player != null) { int value = -1; try { - value = Integer.parseInt(args[1]); + value = Integer.parseInt(modeArg); } catch (NumberFormatException ex) {} GameMode mode = GameMode.getByValue(value); - if (mode != null) { - if (mode != player.getGameMode()) { - Command.broadcastCommandMessage(sender, "Setting " + player.getName() + " to game mode " + mode.getValue()); - - player.setGameMode(mode); - - if (mode != player.getGameMode()) { - Command.broadcastCommandMessage(sender, "The game mode change for " + player.getName() + " was cancelled!"); - } + if (mode == null) { + if (modeArg.equalsIgnoreCase("creative") || modeArg.equalsIgnoreCase("c")) { + mode = GameMode.CREATIVE; + } else if (modeArg.equalsIgnoreCase("adventure") || modeArg.equalsIgnoreCase("a")) { + mode = GameMode.ADVENTURE; } else { - sender.sendMessage(player.getName() + " already has game mode " + mode.getValue()); + mode = GameMode.SURVIVAL; + } + } + + if (mode != player.getGameMode()) { + player.setGameMode(mode); + + if (mode != player.getGameMode()) { + sender.sendMessage("Game mode change for " + player.getName() + " failed!"); + } else { + sender.sendMessage("Game mode set to " + mode.toString() + " for " + player.getName()); } } else { - sender.sendMessage("There is no game mode with id " + args[1]); + sender.sendMessage(player.getName() + " already has game mode " + mode.getValue()); } } else { - sender.sendMessage("Can't find user " + args[0]); + sender.sendMessage("Can't find user " + playerArg); } return true; diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/GiveCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/GiveCommand.java index fffed0c9a3..a970d39232 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/GiveCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/GiveCommand.java @@ -3,7 +3,6 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; import org.bukkit.Material; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; import org.bukkit.inventory.ItemStack; @@ -19,7 +18,7 @@ public class GiveCommand extends VanillaCommand { @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if ((args.length < 2) || (args.length > 4)) { + if ((args.length < 2)) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } @@ -30,18 +29,12 @@ public class GiveCommand extends VanillaCommand { Material material = Material.matchMaterial(args[1]); if (material != null) { - Command.broadcastCommandMessage(sender, "Giving " + player.getName() + " some " + material.getId() + " (" + material + ")"); - int amount = 1; short data = 0; if (args.length >= 3) { - try { - amount = Integer.parseInt(args[2]); - } catch (NumberFormatException ex) {} + amount = this.getInteger(sender, args[2], 1, 64); - if (amount < 1) amount = 1; - if (amount > 64) amount = 64; if (args.length >= 4) { try { data = Short.parseShort(args[3]); @@ -50,6 +43,8 @@ public class GiveCommand extends VanillaCommand { } player.getInventory().addItem(new ItemStack(material, amount, data)); + + sender.sendMessage("Gave " + player.getName() + " some " + material.getId() + " (" + material + ")"); } else { sender.sendMessage("There's no item called " + args[1]); } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/KickCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/KickCommand.java index e30a28e7b5..c82935fb40 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/KickCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/KickCommand.java @@ -2,7 +2,6 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; @@ -10,14 +9,14 @@ public class KickCommand extends VanillaCommand { public KickCommand() { super("kick"); this.description = "Removes the specified player from the server"; - this.usageMessage = "/kick "; + this.usageMessage = "/kick [reason ...]"; this.setPermission("bukkit.command.kick"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length < 1) { + if (args.length < 1 || args[0].length() == 0) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } @@ -25,10 +24,16 @@ public class KickCommand extends VanillaCommand { Player player = Bukkit.getPlayerExact(args[0]); if (player != null) { - Command.broadcastCommandMessage(sender, "Kicking " + player.getName()); - player.kickPlayer("Kicked by admin"); + String reason = "Kicked by an operator."; + + if (args.length > 1) { + reason = createString(args, 1); + } + + player.kickPlayer(reason); + sender.sendMessage("Kicked player " + player.getName() + ". With reason:\n" + reason); } else { - sender.sendMessage("Can't find user " + args[0] + ". No kick."); + sender.sendMessage( args[0] + " not found."); } return true; diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/KillCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/KillCommand.java index 0deff08cc2..d3049f7122 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/KillCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/KillCommand.java @@ -26,6 +26,7 @@ public class KillCommand extends VanillaCommand { ede.getEntity().setLastDamageCause(ede); player.damage(ede.getDamage()); + sender.sendMessage("Ouch. That look like it hurt."); } else { sender.sendMessage("You can only perform this command as a player"); } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/ListCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/ListCommand.java index 009e4421e9..489edd2889 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/ListCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/ListCommand.java @@ -16,21 +16,23 @@ public class ListCommand extends VanillaCommand { public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - StringBuilder players = new StringBuilder(); + StringBuilder online = new StringBuilder(); - for (Player player : Bukkit.getOnlinePlayers()) { + Player[] players = Bukkit.getOnlinePlayers(); + + for (Player player : players) { // If a player is hidden from the sender don't show them in the list if (sender instanceof Player && !((Player) sender).canSee(player)) continue; - if (players.length() > 0) { - players.append(", "); + if (online.length() > 0) { + online.append(", "); } - players.append(player.getDisplayName()); + online.append(player.getDisplayName()); } - sender.sendMessage("Connected players: " + players.toString()); + sender.sendMessage("There are " + players.length + "/" + Bukkit.getMaxPlayers() + " players online:\n" + online.toString()); return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/MeCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/MeCommand.java index d76b84fe30..4ec16baf53 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/MeCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/MeCommand.java @@ -22,11 +22,10 @@ public class MeCommand extends VanillaCommand { StringBuilder message = new StringBuilder(); message.append(sender.getName()); - if (args.length > 0) { - for (String arg : args) { - message.append(" "); - message.append(arg); - } + + for (String arg : args) { + message.append(" "); + message.append(arg); } Bukkit.broadcastMessage("* " + message.toString()); diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/OpCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/OpCommand.java index 1878507af4..7806a7691b 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/OpCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/OpCommand.java @@ -3,9 +3,7 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; import org.bukkit.OfflinePlayer; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; -import org.bukkit.entity.Player; public class OpCommand extends VanillaCommand { public OpCommand() { @@ -18,20 +16,15 @@ public class OpCommand extends VanillaCommand { @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 1) { + if (args.length != 1 || args[0].length() == 0) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } - Command.broadcastCommandMessage(sender, "Opping " + args[0]); - OfflinePlayer player = Bukkit.getOfflinePlayer(args[0]); player.setOp(true); - if (player instanceof Player) { - ((Player) player).sendMessage(ChatColor.YELLOW + "You are now op!"); - } - + sender.sendMessage("Opped " + args[0]); return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/PardonCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/PardonCommand.java index 76e409bf67..b085b6a879 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/PardonCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/PardonCommand.java @@ -2,7 +2,6 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; public class PardonCommand extends VanillaCommand { @@ -22,8 +21,7 @@ public class PardonCommand extends VanillaCommand { } Bukkit.getOfflinePlayer(args[0]).setBanned(false); - Command.broadcastCommandMessage(sender, "Pardoning " + args[0]); - + sender.sendMessage("Pardoned " + args[0]); return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/PardonIpCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/PardonIpCommand.java index 4cc4e6520f..6dc91bd968 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/PardonIpCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/PardonIpCommand.java @@ -2,7 +2,6 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; import org.bukkit.command.CommandSender; public class PardonIpCommand extends VanillaCommand { @@ -21,8 +20,12 @@ public class PardonIpCommand extends VanillaCommand { return false; } - Bukkit.unbanIP(args[0]); - Command.broadcastCommandMessage(sender, "Pardoning ip " + args[0]); + if (BanIpCommand.ipValidity.matcher(args[0]).matches()) { + Bukkit.unbanIP(args[0]); + sender.sendMessage("Pardoned ip " + args[0]); + } else { + sender.sendMessage("Invalid ip"); + } return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/SaveOffCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/SaveOffCommand.java index 628b88c1c1..a7a52c5f85 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/SaveOffCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/SaveOffCommand.java @@ -17,12 +17,12 @@ public class SaveOffCommand extends VanillaCommand { public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - Command.broadcastCommandMessage(sender, "Disabling level saving.."); - for (World world : Bukkit.getWorlds()) { world.setAutoSave(false); } + + Command.broadcastCommandMessage(sender, "Disabled level saving.."); return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/SaveOnCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/SaveOnCommand.java index 7e90252cce..4c1bfec633 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/SaveOnCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/SaveOnCommand.java @@ -17,12 +17,11 @@ public class SaveOnCommand extends VanillaCommand { public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - Command.broadcastCommandMessage(sender, "Enabling level saving.."); - for (World world : Bukkit.getWorlds()) { world.setAutoSave(true); } + Command.broadcastCommandMessage(sender, "Enabled level saving.."); return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/SayCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/SayCommand.java index 9048528707..7fcf581d52 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/SayCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/SayCommand.java @@ -4,6 +4,7 @@ import org.bukkit.Bukkit; import org.bukkit.ChatColor; import org.bukkit.command.CommandSender; import org.bukkit.command.ConsoleCommandSender; +import org.bukkit.entity.Player; public class SayCommand extends VanillaCommand { public SayCommand() { @@ -30,7 +31,7 @@ public class SayCommand extends VanillaCommand { } } - if (!(sender instanceof ConsoleCommandSender)) { + if (sender instanceof Player) { Bukkit.getLogger().info("[" + sender.getName() + "] " + message); } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/SeedCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/SeedCommand.java new file mode 100644 index 0000000000..08258e5a1d --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/command/defaults/SeedCommand.java @@ -0,0 +1,26 @@ +package org.bukkit.command.defaults; + +import org.bukkit.Bukkit; +import org.bukkit.command.CommandSender; +import org.bukkit.entity.Player; + +public class SeedCommand extends VanillaCommand { + public SeedCommand() { + super("seed"); + this.description = "Shows the world seed"; + this.usageMessage = "/seed"; + this.setPermission("bukkit.command.seed"); + } + + @Override + public boolean execute(CommandSender sender, String commandLabel, String[] args) { + long seed; + if (sender instanceof Player) { + seed = ((Player) sender).getWorld().getSeed(); + } else { + seed = Bukkit.getWorlds().get(0).getSeed(); + } + sender.sendMessage("Seed: " + seed); + return true; + } +} diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/TeleportCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/TeleportCommand.java index 79ae480c32..f5dac7857f 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/TeleportCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/TeleportCommand.java @@ -2,7 +2,7 @@ package org.bukkit.command.defaults; import org.bukkit.Bukkit; import org.bukkit.ChatColor; -import org.bukkit.command.Command; +import org.bukkit.Location; import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause; @@ -11,30 +11,51 @@ public class TeleportCommand extends VanillaCommand { public TeleportCommand() { super("tp"); this.description = "Teleports the given player to another player"; - this.usageMessage = "/tp "; + this.usageMessage = "/tp [player] \n/tp [player] "; this.setPermission("bukkit.command.teleport"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length != 2) { + if (args.length < 1 || args.length > 4) { sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); return false; } - Player victim = Bukkit.getPlayerExact(args[0]); - Player target = Bukkit.getPlayerExact(args[1]); + Player player; - if (victim == null) { - sender.sendMessage("Can't find user " + args[0] + ". No tp."); - } else if (target == null) { - sender.sendMessage("Can't find user " + args[1] + ". No tp."); + if (args.length == 1 || args.length == 3) { + if (sender instanceof Player) { + player = (Player) sender; + } else { + sender.sendMessage("Please provide a player!"); + return true; + } } else { - Command.broadcastCommandMessage(sender, "Teleporting " + victim.getName() + " to " + target.getName()); - victim.teleport(target, TeleportCause.COMMAND); + player = Bukkit.getPlayerExact(args[0]); } + if (player == null) { + sender.sendMessage("Player not found: " + args[0]); + } + + if (args.length < 3) { + Player target = Bukkit.getPlayerExact(args[args.length - 1]); + if (target == null) { + sender.sendMessage("Can't find user " + args[args.length - 1] + ". No tp."); + } + player.teleport(target, TeleportCause.COMMAND); + sender.sendMessage("Teleported " + player.getName() + " to " + target.getName()); + } else if (player.getWorld() != null) { + int x = getInteger(sender, args[args.length - 3], -30000000, 30000000); + int y = getInteger(sender, args[args.length - 2], 0, 256); + int z = getInteger(sender, args[args.length - 1], -30000000, 30000000); + + Location location = new Location(player.getWorld(), x, y, z); + player.teleport(location); + sender.sendMessage("Teleported " + player.getName() + " to " + x + "," + y + "," + z); + } return true; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/TimeCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/TimeCommand.java index 81c6014869..9cc160ecec 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/TimeCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/TimeCommand.java @@ -16,43 +16,49 @@ public class TimeCommand extends VanillaCommand { @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { - if (args.length != 2) { + if (args.length < 2) { sender.sendMessage(ChatColor.RED + "Incorrect usage. Correct usage:\n" + usageMessage); return false; } - int value = 0; + int value; - try { - value = Integer.parseInt(args[1]); - } catch (NumberFormatException ex) { - sender.sendMessage("Unable to convert time value, " + args[1]); - return true; - } - - if (args[0].equalsIgnoreCase("add")) { - if (!sender.hasPermission("bukkit.command.time.add")) { - sender.sendMessage(ChatColor.RED + "You don't have permission to add to the time"); - } else { - for (World world : Bukkit.getWorlds()) { - world.setFullTime(world.getFullTime() + value); - } - - Command.broadcastCommandMessage(sender, "Added " + value + " to time"); - } - } else if (args[0].equalsIgnoreCase("set")) { + if (args[0].equals("set")) { if (!sender.hasPermission("bukkit.command.time.set")) { sender.sendMessage(ChatColor.RED + "You don't have permission to set the time"); - } else { - for (World world : Bukkit.getWorlds()) { - world.setTime(value); - } - - Command.broadcastCommandMessage(sender, "Set time to " + value); + return true; } + + if (args[1].equals("day")) { + value = 0; + } else if (args[1].equals("night")) { + value = 12500; + } else { + value = getInteger(sender, args[1], 0); + } + + for (World world : Bukkit.getWorlds()) { + world.setTime(value); + } + + Command.broadcastCommandMessage(sender, "Set time to " + value); + sender.sendMessage("Set time to " + value); + } else if (args[0].equals("add")) { + if (!sender.hasPermission("bukkit.command.time.add")) { + sender.sendMessage(ChatColor.RED + "You don't have permission to set the time"); + return true; + } + + value = getInteger(sender, args[1], 0); + + for (World world : Bukkit.getWorlds()) { + world.setFullTime(world.getFullTime() + value); + } + + Command.broadcastCommandMessage(sender, "Added " + value + " to time"); + sender.sendMessage("Added " + value + " to time"); } else { - sender.sendMessage("Unknown method, use either \"add\" or \"set\""); - return true; + sender.sendMessage("Unknown method. Usage: " + usageMessage); } return true; diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/VanillaCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/VanillaCommand.java index cfb0769a35..8a76ebed47 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/VanillaCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/VanillaCommand.java @@ -1,9 +1,13 @@ package org.bukkit.command.defaults; +import java.util.ArrayList; import java.util.List; import org.bukkit.command.Command; +import org.bukkit.command.CommandSender; public abstract class VanillaCommand extends Command { + static final List EMPTY_LIST = new ArrayList(0); + protected VanillaCommand(String name) { super(name); } @@ -12,5 +16,40 @@ public abstract class VanillaCommand extends Command { super(name, description, usageMessage, aliases); } - public abstract boolean matches(String input); + public boolean matches(String input) { + return input.equalsIgnoreCase(this.getName()); + } + + protected int getInteger(CommandSender sender, String value, int min) { + return getInteger(sender, value, min, Integer.MAX_VALUE); + } + + protected int getInteger(CommandSender sender, String value, int min, int max) { + int i = min; + try { + i = Integer.valueOf(value); + } catch (NumberFormatException ex) { + sender.sendMessage("Invalid exp count: " + value); + } + if (i < min) { + i = min; + } else if (i > max) { + i = max; + } + + return i; + } + + protected String createString(String[] args, int start) { + StringBuilder string = new StringBuilder(); + + for (int x = start; x < args.length; x++) { + string.append(args[x]); + if (x != args.length - 1) { + string.append(" "); + } + } + + return string.toString(); + } } diff --git a/paper-api/src/main/java/org/bukkit/event/inventory/InventoryType.java b/paper-api/src/main/java/org/bukkit/event/inventory/InventoryType.java index 4a343c9048..c23908b942 100644 --- a/paper-api/src/main/java/org/bukkit/event/inventory/InventoryType.java +++ b/paper-api/src/main/java/org/bukkit/event/inventory/InventoryType.java @@ -39,7 +39,16 @@ public enum InventoryType { * The creative mode inventory, with only 9 QUICKBAR slots and nothing else. (The actual * creative interface with the items is client-side and cannot be altered by the server.) */ - CREATIVE(9,"Creative"); + CREATIVE(9,"Creative"), + /** + * The merchant inventory, with 2 TRADE-IN slots, and 1 RESULT slot. + */ + MERCHANT(3,"Villager"), + /** + * The ender chest inventory, with 27 slots. + */ + ENDER_CHEST(27,"Ender Chest"); + private final int size; private final String title; diff --git a/paper-api/src/main/java/org/bukkit/inventory/MerchantInventory.java b/paper-api/src/main/java/org/bukkit/inventory/MerchantInventory.java new file mode 100644 index 0000000000..163f45977c --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/inventory/MerchantInventory.java @@ -0,0 +1,4 @@ +package org.bukkit.inventory; + +public interface MerchantInventory extends Inventory { +} diff --git a/paper-api/src/main/java/org/bukkit/util/permissions/CommandPermissions.java b/paper-api/src/main/java/org/bukkit/util/permissions/CommandPermissions.java index b6b505bd4b..33c38ac38f 100644 --- a/paper-api/src/main/java/org/bukkit/util/permissions/CommandPermissions.java +++ b/paper-api/src/main/java/org/bukkit/util/permissions/CommandPermissions.java @@ -105,7 +105,9 @@ public final class CommandPermissions { DefaultPermissions.registerPermission(PREFIX + "version", "Allows the user to view the version of the server", PermissionDefault.TRUE, commands); DefaultPermissions.registerPermission(PREFIX + "gamemode", "Allows the user to change the gamemode of another player", PermissionDefault.OP, commands); DefaultPermissions.registerPermission(PREFIX + "xp", "Allows the user to give themselves or others arbitrary values of experience", PermissionDefault.OP, commands); - DefaultPermissions.registerPermission(PREFIX + "toggledownfall", "Allows the user to toggle rain on/off for a given world", PermissionDefault.OP, commands); + DefaultPermissions.registerPermission(PREFIX + "defaultgamemode", "Allows the user to toggle rain on/off for a given world", PermissionDefault.OP, commands); + DefaultPermissions.registerPermission(PREFIX + "seed", "Allows the user to toggle rain on/off for a given world", PermissionDefault.OP, commands); + commands.recalculatePermissibles();