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 791d2e1428..0c92e7fbff 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 @@ -14,35 +14,65 @@ import com.google.common.collect.ImmutableList; public class ExpCommand extends VanillaCommand { public ExpCommand() { super("xp"); - this.description = "Gives the specified player a certain amount of experience"; - this.usageMessage = "/xp [player]"; + this.description = "Gives the specified player a certain amount of experience. Specify L to give levels instead, with a negative amount resulting in taking levels."; + this.usageMessage = "/xp [player] OR /xp L [player]"; this.setPermission("bukkit.command.xp"); } @Override public boolean execute(CommandSender sender, String currentAlias, String[] args) { if (!testPermission(sender)) return true; - if (args.length < 1) { - sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); - return false; - } - int exp = getInteger(sender, args[0], 0, 5000); - Player player = null; - if (args.length > 1) { - player = Bukkit.getPlayer(args[1]); - } else if (sender instanceof Player) { - player = (Player) sender; + if (args.length > 0) { + String inputAmount = args[0]; + Player player = null; + + boolean isLevel = inputAmount.endsWith("l") || inputAmount.endsWith("L"); + if (isLevel && inputAmount.length() > 1) { + inputAmount = inputAmount.substring(0, inputAmount.length() - 1); + } + + int amount = getInteger(sender, inputAmount, Integer.MIN_VALUE, Integer.MAX_VALUE); + boolean isTaking = amount < 0; + + if (isTaking) { + amount *= -1; + } + + if (args.length > 1) { + player = Bukkit.getPlayer(args[1]); + } else if (sender instanceof Player) { + player = (Player) sender; + } + + if (player != null) { + if (isLevel) { + if (isTaking) { + player.giveExpLevels(-amount); + sender.sendMessage("Taken " + amount + " level(s) from " + player.getName()); + } else { + player.giveExpLevels(amount); + sender.sendMessage("Given " + amount + " level(s) to " + player.getName()); + } + } else { + if (isTaking) { + sender.sendMessage(ChatColor.RED + "Taking experience can only be done by levels, cannot give players negative experience points"); + return false; + } else { + player.giveExp(amount); + sender.sendMessage("Given " + amount + " experience to " + player.getName()); + } + } + } else { + sender.sendMessage("Can't find user, was one provided?\n" + ChatColor.RED + "Usage: " + usageMessage); + return false; + } + + return true; } - if (player != null) { - player.giveExp(exp); - Command.broadcastCommandMessage(sender, "Given " + exp + " exp to " + player.getName()); - } else { - sender.sendMessage("Can't find user, was one provided?\n" + ChatColor.RED + "Usage: " + usageMessage); - } - - return true; + sender.sendMessage(ChatColor.RED + "Usage: " + usageMessage); + return false; } @Override diff --git a/paper-api/src/main/java/org/bukkit/entity/Player.java b/paper-api/src/main/java/org/bukkit/entity/Player.java index 7f667f6cb6..73a9ea4eb7 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Player.java +++ b/paper-api/src/main/java/org/bukkit/entity/Player.java @@ -370,6 +370,13 @@ public interface Player extends HumanEntity, Conversable, CommandSender, Offline */ public void giveExp(int amount); + /** + * Gives the player the amount of experience levels specified. Levels can be taken by specifying a negative amount. + * + * @param amount amount of experience levels to give or take + */ + public void giveExpLevels(int amount); + /** * Gets the players current experience points towards the next level. *