2011-11-27 04:36:27 +01:00
|
|
|
package com.earth2me.essentials.commands;
|
|
|
|
|
2011-12-04 22:28:29 +01:00
|
|
|
import com.earth2me.essentials.Enchantments;
|
2013-01-12 15:12:12 +01:00
|
|
|
import com.earth2me.essentials.MetaItemStack;
|
2011-11-27 04:36:27 +01:00
|
|
|
import com.earth2me.essentials.User;
|
2013-06-08 23:31:19 +02:00
|
|
|
import com.earth2me.essentials.utils.StringUtil;
|
2013-03-16 12:01:56 +01:00
|
|
|
import org.bukkit.Material;
|
2011-11-27 04:36:27 +01:00
|
|
|
import org.bukkit.Server;
|
|
|
|
import org.bukkit.enchantments.Enchantment;
|
2013-01-12 18:05:05 +01:00
|
|
|
import org.bukkit.inventory.ItemStack;
|
2011-11-27 04:36:27 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
import java.util.Locale;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.Set;
|
|
|
|
import java.util.TreeSet;
|
|
|
|
|
|
|
|
import static com.earth2me.essentials.I18n.tl;
|
|
|
|
|
|
|
|
|
|
|
|
public class Commandenchant extends EssentialsCommand {
|
|
|
|
public Commandenchant() {
|
|
|
|
super("enchant");
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO: Implement charge costs: final Trade charge = new Trade("enchant-" + enchantmentName, ess);
|
|
|
|
@Override
|
|
|
|
protected void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception {
|
2016-11-20 21:23:01 +01:00
|
|
|
final ItemStack stack = user.getItemInHand();
|
2015-04-15 06:06:16 +02:00
|
|
|
if (stack == null || stack.getType() == Material.AIR) {
|
|
|
|
throw new Exception(tl("nothingInHand"));
|
|
|
|
}
|
|
|
|
if (args.length == 0) {
|
2015-06-03 22:11:56 +02:00
|
|
|
final Set<String> enchantmentslist = new TreeSet<>();
|
2015-04-15 06:06:16 +02:00
|
|
|
for (Map.Entry<String, Enchantment> entry : Enchantments.entrySet()) {
|
|
|
|
final String enchantmentName = entry.getValue().getName().toLowerCase(Locale.ENGLISH);
|
|
|
|
if (enchantmentslist.contains(enchantmentName) || (user.isAuthorized("essentials.enchantments." + enchantmentName) && entry.getValue().canEnchantItem(stack))) {
|
|
|
|
enchantmentslist.add(entry.getKey());
|
|
|
|
//enchantmentslist.add(enchantmentName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
throw new NotEnoughArgumentsException(tl("enchantments", StringUtil.joinList(enchantmentslist.toArray())));
|
|
|
|
}
|
2011-11-27 04:36:27 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
int level = -1;
|
|
|
|
if (args.length > 1) {
|
|
|
|
try {
|
|
|
|
level = Integer.parseInt(args[1]);
|
|
|
|
} catch (NumberFormatException ex) {
|
|
|
|
level = -1;
|
|
|
|
}
|
|
|
|
}
|
2011-11-27 04:36:27 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
final boolean allowUnsafe = ess.getSettings().allowUnsafeEnchantments() && user.isAuthorized("essentials.enchantments.allowunsafe");
|
2013-01-06 19:28:24 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
final MetaItemStack metaStack = new MetaItemStack(stack);
|
|
|
|
final Enchantment enchantment = metaStack.getEnchantment(user, args[0]);
|
|
|
|
metaStack.addEnchantment(user.getSource(), allowUnsafe, enchantment, level);
|
2016-11-20 21:23:01 +01:00
|
|
|
user.getBase().getInventory().setItemInMainHand(metaStack.getItemStack());
|
2013-01-06 19:28:24 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
user.getBase().updateInventory();
|
|
|
|
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
|
|
|
|
if (level == 0) {
|
|
|
|
user.sendMessage(tl("enchantmentRemoved", enchantmentName.replace('_', ' ')));
|
|
|
|
} else {
|
|
|
|
user.sendMessage(tl("enchantmentApplied", enchantmentName.replace('_', ' ')));
|
|
|
|
}
|
|
|
|
}
|
2011-11-27 04:36:27 +01:00
|
|
|
}
|