Added enchantment to /give and /item

Updated plugin.yml
This commit is contained in:
snowleo 2011-11-27 08:57:21 +01:00
parent b8f9a4b96f
commit 098072517a
5 changed files with 85 additions and 18 deletions

View File

@ -7,6 +7,7 @@ import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.TreeSet; import java.util.TreeSet;
import java.util.regex.Pattern;
import org.bukkit.Server; import org.bukkit.Server;
import org.bukkit.enchantments.Enchantment; import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
@ -16,6 +17,7 @@ import static com.earth2me.essentials.I18n._;
public class Commandenchant extends EssentialsCommand public class Commandenchant extends EssentialsCommand
{ {
private static final Map<String, Enchantment> ENCHANTMENTS = new HashMap<String, Enchantment>(); private static final Map<String, Enchantment> ENCHANTMENTS = new HashMap<String, Enchantment>();
private static final transient Pattern NUMPATTERN = Pattern.compile("\\d+");
static static
{ {
@ -89,20 +91,7 @@ public class Commandenchant extends EssentialsCommand
level = -1; level = -1;
} }
} }
Enchantment enchantment = Enchantment.getByName(args[0].toUpperCase(Locale.ENGLISH)); Enchantment enchantment = getEnchantment(args[0], user);
if (enchantment == null)
{
enchantment = ENCHANTMENTS.get(args[0].toLowerCase(Locale.ENGLISH));
}
if (enchantment == null)
{
throw new Exception(_("enchantmentNotFound"));
}
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
if (!user.isAuthorized("essentials.enchant." + enchantmentName))
{
throw new Exception(_("enchantmentPerm", enchantmentName));
}
if (level < enchantment.getStartLevel() || level > enchantment.getMaxLevel()) if (level < enchantment.getStartLevel() || level > enchantment.getMaxLevel())
{ {
level = enchantment.getMaxLevel(); level = enchantment.getMaxLevel();
@ -110,6 +99,32 @@ public class Commandenchant extends EssentialsCommand
stack.addEnchantment(enchantment, level); stack.addEnchantment(enchantment, level);
user.setItemInHand(stack); user.setItemInHand(stack);
user.updateInventory(); user.updateInventory();
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
user.sendMessage(_("enchantmentApplied", enchantmentName.replace('_', ' '))); user.sendMessage(_("enchantmentApplied", enchantmentName.replace('_', ' ')));
} }
public static Enchantment getEnchantment(final String name, final User user) throws Exception
{
Enchantment enchantment;
if (NUMPATTERN.matcher(name).matches()) {
enchantment = Enchantment.getById(Integer.parseInt(name));
} else {
enchantment = Enchantment.getByName(name.toUpperCase(Locale.ENGLISH));
}
if (enchantment == null)
{
enchantment = ENCHANTMENTS.get(name.toLowerCase(Locale.ENGLISH));
}
if (enchantment == null)
{
throw new Exception(_("enchantmentNotFound"));
}
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
if (user != null && !user.isAuthorized("essentials.enchant." + enchantmentName))
{
throw new Exception(_("enchantmentPerm", enchantmentName));
}
return enchantment;
}
} }

View File

@ -6,6 +6,7 @@ import org.bukkit.ChatColor;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.Server; import org.bukkit.Server;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
@ -44,6 +45,29 @@ public class Commandgive extends EssentialsCommand
stack.setAmount(Integer.parseInt(args[2])); stack.setAmount(Integer.parseInt(args[2]));
} }
if (args.length > 3)
{
for (int i = 3; i < args.length; i++)
{
final String[] split = args[i].split("[:+',;.]", 2);
if (split.length < 1)
{
continue;
}
final Enchantment enchantment = Commandenchant.getEnchantment(split[0], sender instanceof Player ? ess.getUser(sender) : null);
int level;
if (split.length > 1)
{
level = Integer.parseInt(split[1]);
}
else
{
level = enchantment.getMaxLevel();
}
stack.addEnchantment(enchantment, level);
}
}
if (stack.getType() == Material.AIR) if (stack.getType() == Material.AIR)
{ {
throw new Exception(ChatColor.RED + "You can't give air."); throw new Exception(ChatColor.RED + "You can't give air.");

View File

@ -5,6 +5,7 @@ import com.earth2me.essentials.User;
import java.util.Locale; import java.util.Locale;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.Server; import org.bukkit.Server;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
@ -40,6 +41,29 @@ public class Commanditem extends EssentialsCommand
stack.setAmount(Integer.parseInt(args[1])); stack.setAmount(Integer.parseInt(args[1]));
} }
if (args.length > 2)
{
for (int i = 2; i < args.length; i++)
{
final String[] split = args[i].split("[:+',;.]", 2);
if (split.length < 1)
{
continue;
}
final Enchantment enchantment = Commandenchant.getEnchantment(split[0], user);
int level;
if (split.length > 1)
{
level = Integer.parseInt(split[1]);
}
else
{
level = enchantment.getMaxLevel();
}
stack.addEnchantment(enchantment, level);
}
}
if (stack.getType() == Material.AIR) if (stack.getType() == Material.AIR)
{ {
throw new Exception(_("cantSpawnItem", "Air")); throw new Exception(_("cantSpawnItem", "Air"));

View File

@ -129,7 +129,7 @@ public class BukkitConstructor extends Constructor
for (int i = 2; i < split1.length; i++) for (int i = 2; i < split1.length; i++)
{ {
final String[] split3 = split1[0].split("[:+',;.]", 2); final String[] split3 = split1[0].split("[:+',;.]", 2);
if (split3.length != 2) if (split3.length < 1)
{ {
continue; continue;
} }
@ -148,7 +148,7 @@ public class BukkitConstructor extends Constructor
continue; continue;
} }
int level = enchantment.getStartLevel(); int level = enchantment.getStartLevel();
if (NUMPATTERN.matcher(split3[1]).matches()) if (split3.length == 2 && NUMPATTERN.matcher(split3[1]).matches())
{ {
level = Integer.parseInt(split3[1]); level = Integer.parseInt(split3[1]);
} }

View File

@ -79,6 +79,10 @@ commands:
description: Manages the server economy. description: Manages the server economy.
usage: /<command> <give|take|reset> <player> <amount> usage: /<command> <give|take|reset> <player> <amount>
aliases: [economy,eeco,eeconomy] aliases: [economy,eeco,eeconomy]
enchant:
description: Enchants the item the user is holding.
usage: /<command> <enchantmentname> [level]
aliases: [enchantment]
essentials: essentials:
description: Reloads essentials. description: Reloads essentials.
usage: /<command> usage: /<command>
@ -104,7 +108,7 @@ commands:
aliases: [mem,memory,egc,emem,ememory] aliases: [mem,memory,egc,emem,ememory]
give: give:
description: Give a player an item. description: Give a player an item.
usage: /<command> <player> <item|numeric> [amount] usage: /<command> <player> <item|numeric> [amount <enchantmentname[:level]> ...]
aliases: [egive] aliases: [egive]
god: god:
description: Enables your godly powers. description: Enables your godly powers.
@ -140,7 +144,7 @@ commands:
aliases: [einvsee] aliases: [einvsee]
item: item:
description: Spawn an item. description: Spawn an item.
usage: /<command> <item|numeric> [amount] usage: /<command> <item|numeric> [amount <enchantmentname[:level]> ...]
aliases: [i,eitem] aliases: [i,eitem]
jails: jails:
description: List all jails. description: List all jails.