diff options
author | snowleo <schneeleo@gmail.com> | 2011-12-04 12:49:52 -0800 |
---|---|---|
committer | snowleo <schneeleo@gmail.com> | 2011-12-04 12:49:52 -0800 |
commit | dd84f5c33101892098749c4b0e44c18257b54eb5 (patch) | |
tree | 54d2b79137644d11777ac168f1550a1ff0d2c220 | |
parent | 90f87804b1d26b7f57ad22b2b3ffd75e2862d827 (diff) | |
parent | 2c2f956068fae54f20ccd750ddd48173fcc80c64 (diff) | |
download | Essentials-dd84f5c33101892098749c4b0e44c18257b54eb5.tar Essentials-dd84f5c33101892098749c4b0e44c18257b54eb5.tar.gz Essentials-dd84f5c33101892098749c4b0e44c18257b54eb5.tar.lz Essentials-dd84f5c33101892098749c4b0e44c18257b54eb5.tar.xz Essentials-dd84f5c33101892098749c4b0e44c18257b54eb5.zip |
Merge pull request #35 from khyperia/master
Multiple commits from khyperia
3 files changed, 170 insertions, 2 deletions
diff --git a/Essentials/src/com/earth2me/essentials/signs/SignEnchant.java b/Essentials/src/com/earth2me/essentials/signs/SignEnchant.java new file mode 100644 index 000000000..6561c0628 --- /dev/null +++ b/Essentials/src/com/earth2me/essentials/signs/SignEnchant.java @@ -0,0 +1,138 @@ +package com.earth2me.essentials.signs; + +import com.earth2me.essentials.ChargeException; +import com.earth2me.essentials.IEssentials; +import com.earth2me.essentials.User; +import static com.earth2me.essentials.I18n._; +import com.earth2me.essentials.Trade; +import java.util.HashMap; +import java.util.Map; +import org.bukkit.Material; +import org.bukkit.enchantments.Enchantment; +import org.bukkit.inventory.ItemStack; + + +public class SignEnchant extends EssentialsSign +{ + public SignEnchant() + { + super("Enchant"); + } + + @Override + protected boolean onSignCreate(final ISign sign, final User player, final String username, final IEssentials ess) throws SignException, ChargeException + { + getItemStack(sign.getLine(1), 1, ess); + String[] enchantLevel = sign.getLine(2).split(":"); + if (enchantLevel.length != 2) + { + throw new SignException(_("invalidSignLine", 2)); + } + if (!ENCHANTMENTS.containsKey(enchantLevel[0])) + { + throw new SignException(_("enchantmentNotFound")); + } + int level; + try + { + level = Integer.parseInt(enchantLevel[1]); + } + catch (NumberFormatException ex) + { + throw new SignException(ex.getMessage()); + } + if (level < 1 || level > ENCHANTMENTS.get(enchantLevel[0]).getMaxLevel()) + { + sign.setLine(2, enchantLevel[0] + ":" + ENCHANTMENTS.get(enchantLevel[0]).getMaxLevel()); + } + getTrade(sign, 3, ess); + return true; + } + + @Override + protected boolean onSignInteract(ISign sign, User player, String username, IEssentials ess) throws SignException, ChargeException + { + Material search = getItemStack(sign.getLine(1), 1, ess).getType(); + int slot; + Trade charge = getTrade(sign, 3, ess); + charge.isAffordableFor(player); + if (player.getInventory().contains(search)) + { + slot = player.getInventory().first(search); + } + else + { + player.sendMessage(_("missingItems", 1, search.toString())); + return true; + } + ItemStack toEnchant = player.getInventory().getItem(slot); + String[] enchantLevel = sign.getLine(2).split(":"); + if (enchantLevel.length != 2) + { + player.sendMessage(_("invalidSignLine", 2)); + return true; + } + if (ENCHANTMENTS.containsKey(enchantLevel[0])) + { + try + { + toEnchant.addEnchantment(ENCHANTMENTS.get(enchantLevel[0]), Integer.parseInt(enchantLevel[1])); + } + catch (NumberFormatException ex) + { + toEnchant.addEnchantment(ENCHANTMENTS.get(enchantLevel[0]), 1); + } + } + else + { + player.sendMessage(_("enchantmentNotFound")); + return true; + } + charge.charge(player); + Trade.log("Sign", "Enchant", "Interact", username, charge, username, charge, sign.getBlock().getLocation(), ess); + return true; + } + private static final Map<String, Enchantment> ENCHANTMENTS = new HashMap<String, Enchantment>(); + + static + { + ENCHANTMENTS.put("alldamage", Enchantment.DAMAGE_ALL); + ENCHANTMENTS.put("alldmg", Enchantment.DAMAGE_ALL); + ENCHANTMENTS.put("sharpness", Enchantment.DAMAGE_ALL); + ENCHANTMENTS.put("arthropodsdamage", Enchantment.DAMAGE_ARTHROPODS); + ENCHANTMENTS.put("ardmg", Enchantment.DAMAGE_ARTHROPODS); + ENCHANTMENTS.put("baneofarthropods", Enchantment.DAMAGE_ARTHROPODS); + ENCHANTMENTS.put("undeaddamage", Enchantment.DAMAGE_UNDEAD); + ENCHANTMENTS.put("smite", Enchantment.DAMAGE_UNDEAD); + ENCHANTMENTS.put("digspeed", Enchantment.DIG_SPEED); + ENCHANTMENTS.put("efficiency", Enchantment.DIG_SPEED); + ENCHANTMENTS.put("durability", Enchantment.DURABILITY); + ENCHANTMENTS.put("dura", Enchantment.DURABILITY); + ENCHANTMENTS.put("unbreaking", Enchantment.DURABILITY); + ENCHANTMENTS.put("fireaspect", Enchantment.FIRE_ASPECT); + ENCHANTMENTS.put("fire", Enchantment.FIRE_ASPECT); + ENCHANTMENTS.put("knockback", Enchantment.KNOCKBACK); + ENCHANTMENTS.put("blockslootbonus", Enchantment.LOOT_BONUS_BLOCKS); + ENCHANTMENTS.put("fortune", Enchantment.LOOT_BONUS_BLOCKS); + ENCHANTMENTS.put("mobslootbonus", Enchantment.LOOT_BONUS_MOBS); + ENCHANTMENTS.put("mobloot", Enchantment.LOOT_BONUS_MOBS); + ENCHANTMENTS.put("looting", Enchantment.LOOT_BONUS_MOBS); + ENCHANTMENTS.put("oxygen", Enchantment.OXYGEN); + ENCHANTMENTS.put("respiration", Enchantment.OXYGEN); + ENCHANTMENTS.put("protection", Enchantment.PROTECTION_ENVIRONMENTAL); + ENCHANTMENTS.put("prot", Enchantment.PROTECTION_ENVIRONMENTAL); + ENCHANTMENTS.put("explosionsprotection", Enchantment.PROTECTION_EXPLOSIONS); + ENCHANTMENTS.put("expprot", Enchantment.PROTECTION_EXPLOSIONS); + ENCHANTMENTS.put("blastprotection", Enchantment.PROTECTION_EXPLOSIONS); + ENCHANTMENTS.put("fallprotection", Enchantment.PROTECTION_FALL); + ENCHANTMENTS.put("fallprot", Enchantment.PROTECTION_FALL); + ENCHANTMENTS.put("featherfalling", Enchantment.PROTECTION_FALL); + ENCHANTMENTS.put("fireprotection", Enchantment.PROTECTION_FIRE); + ENCHANTMENTS.put("fireprot", Enchantment.PROTECTION_FIRE); + ENCHANTMENTS.put("projectileprotection", Enchantment.PROTECTION_PROJECTILE); + ENCHANTMENTS.put("projprot", Enchantment.PROTECTION_PROJECTILE); + ENCHANTMENTS.put("silktouch", Enchantment.SILK_TOUCH); + ENCHANTMENTS.put("waterworker", Enchantment.WATER_WORKER); + ENCHANTMENTS.put("aquaaffinity", Enchantment.WATER_WORKER); + } +} diff --git a/Essentials/src/com/earth2me/essentials/signs/Signs.java b/Essentials/src/com/earth2me/essentials/signs/Signs.java index d7c0d2086..83a0ee828 100644 --- a/Essentials/src/com/earth2me/essentials/signs/Signs.java +++ b/Essentials/src/com/earth2me/essentials/signs/Signs.java @@ -6,6 +6,7 @@ public enum Signs BALANCE(new SignBalance()), BUY(new SignBuy()), DISPOSAL(new SignDisposal()), + ENCHANT(new SignEnchant()), FREE(new SignFree()), GAMEMODE(new SignGameMode()), HEAL(new SignHeal()), diff --git a/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java b/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java index f9ea9fa36..e38de76cc 100644 --- a/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java +++ b/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java @@ -3,7 +3,10 @@ package com.earth2me.essentials.spawn; import com.earth2me.essentials.Trade; import com.earth2me.essentials.User; import com.earth2me.essentials.commands.EssentialsCommand; +import com.earth2me.essentials.commands.NotEnoughArgumentsException; +import static com.earth2me.essentials.I18n._; import org.bukkit.Server; +import org.bukkit.command.CommandSender; public class Commandspawn extends EssentialsCommand @@ -14,10 +17,36 @@ public class Commandspawn extends EssentialsCommand } @Override - public void run(Server server, User user, String commandLabel, String[] args) throws Exception + public void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception { final Trade charge = new Trade(this.getName(), ess); charge.isAffordableFor(user); - user.getTeleport().respawn(ess.getSpawn(), charge); + if (args.length > 0 && user.isAuthorized("essentials.spawn.other")) + { + User otherUser = getPlayer(server, args, 0); + otherUser.getTeleport().respawn(ess.getSpawn(), charge); + if (otherUser != user) + { + otherUser.sendMessage(_("teleportAtoB", user.getDisplayName(), "spawn")); + user.sendMessage(_("teleporting")); + } + } + else + { + user.getTeleport().respawn(ess.getSpawn(), charge); + } + } + + @Override + protected void run(final Server server, final CommandSender sender, final String commandLabel, final String[] args) throws Exception + { + if (args.length < 1) + { + throw new NotEnoughArgumentsException(); + } + User user = getPlayer(server, args, 0); + user.getTeleport().respawn(ess.getSpawn(), null); + user.sendMessage(_("teleportAtoB", user.getDisplayName(), "spawn")); + sender.sendMessage(_("teleporting")); } } |