Move firework meta handling into MetaItemStack

Allow firework meta to be applied to item spawning and kit commands.
This commit is contained in:
KHobbits 2013-01-19 23:35:59 +00:00
parent 2b8435342d
commit 73c92bf742
6 changed files with 206 additions and 179 deletions

View File

@ -122,7 +122,7 @@ public class Kit
{ {
for (int i = 2; i < parts.length; i++) for (int i = 2; i < parts.length; i++)
{ {
metaStack.addStringMeta(null, allowUnsafe, parts[i], ess); metaStack.parseStringMeta(user, allowUnsafe, parts, 2, ess);
} }
} }

View File

@ -2,15 +2,13 @@ package com.earth2me.essentials;
import static com.earth2me.essentials.I18n._; import static com.earth2me.essentials.I18n._;
import com.earth2me.essentials.textreader.*; import com.earth2me.essentials.textreader.*;
import java.util.ArrayList; import java.util.*;
import java.util.List;
import java.util.Locale;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.bukkit.Color; import org.bukkit.Color;
import org.bukkit.DyeColor; import org.bukkit.DyeColor;
import org.bukkit.FireworkEffect; import org.bukkit.FireworkEffect;
import org.bukkit.FireworkEffect.Builder;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.command.CommandSender;
import org.bukkit.enchantments.Enchantment; import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.*; import org.bukkit.inventory.meta.*;
@ -20,26 +18,68 @@ public class MetaItemStack
{ {
private final transient Pattern splitPattern = Pattern.compile("[:+',;.]"); private final transient Pattern splitPattern = Pattern.compile("[:+',;.]");
private final ItemStack stack; private final ItemStack stack;
private final static Map<String, DyeColor> colorMap = new HashMap<String, DyeColor>();
private final static Map<String, FireworkEffect.Type> fireworkShape = new HashMap<String, FireworkEffect.Type>();
private FireworkEffect.Builder builder = FireworkEffect.builder();
private boolean validFirework = false;
static
{
for (DyeColor color : DyeColor.values())
{
colorMap.put(color.name(), color);
}
for (FireworkEffect.Type type : FireworkEffect.Type.values())
{
fireworkShape.put(type.name(), type);
}
}
public MetaItemStack(final ItemStack stack) public MetaItemStack(final ItemStack stack)
{ {
this.stack = stack.clone(); this.stack = stack.clone();
} }
public ItemStack getItemStack() public ItemStack getItemStack()
{ {
return stack; return stack;
} }
public boolean isValidFirework()
{
return validFirework;
}
public FireworkEffect.Builder getFireworkBuilder()
{
return builder;
}
public void parseStringMeta(final CommandSender user, final boolean allowUnsafe, String[] string, int fromArg, final IEssentials ess) throws Exception
{
for (int i = fromArg; i < string.length; i++)
{
addStringMeta(user, allowUnsafe, string[i], ess);
}
if (validFirework)
{
FireworkEffect effect = builder.build();
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
fmeta.addEffect(effect);
stack.setItemMeta(fmeta);
}
}
//TODO: TL this //TODO: TL this
public void addStringMeta(final User user, final boolean allowUnsafe, final String string, final IEssentials ess) throws Exception private void addStringMeta(final CommandSender user, final boolean allowUnsafe, final String string, final IEssentials ess) throws Exception
{ {
final String[] split = splitPattern.split(string, 2); final String[] split = splitPattern.split(string, 2);
if (split.length < 1) if (split.length < 1)
{ {
return; return;
} }
if (split.length > 1 && split[0].equalsIgnoreCase("name")) if (split.length > 1 && split[0].equalsIgnoreCase("name"))
{ {
final String displayName = Util.replaceFormat(split[1].replace('_', ' ')); final String displayName = Util.replaceFormat(split[1].replace('_', ' '));
@ -76,11 +116,11 @@ public class MetaItemStack
{ {
final BookMeta meta = (BookMeta)stack.getItemMeta(); final BookMeta meta = (BookMeta)stack.getItemMeta();
final IText input = new BookInput("book", true, ess); final IText input = new BookInput("book", true, ess);
final BookPager pager = new BookPager(input); final BookPager pager = new BookPager(input);
List<String> pages = pager.getPages(split[1]); List<String> pages = pager.getPages(split[1]);
meta.setPages(pages); meta.setPages(pages);
stack.setItemMeta(meta); stack.setItemMeta(meta);
} }
else if (split.length > 1 && split[0].equalsIgnoreCase("author") && stack.getType() == Material.WRITTEN_BOOK) else if (split.length > 1 && split[0].equalsIgnoreCase("author") && stack.getType() == Material.WRITTEN_BOOK)
@ -97,36 +137,10 @@ public class MetaItemStack
meta.setTitle(title); meta.setTitle(title);
stack.setItemMeta(meta); stack.setItemMeta(meta);
} }
else if (split.length > 1 && split[0].equalsIgnoreCase("power") && stack.getType() == Material.FIREWORK) else if (stack.getType() == Material.FIREWORK) //WARNING - Meta for fireworks will be ignored after this point.
{ {
final int power = Integer.parseInt(split[1]); addFireworkMeta(user, false, string, ess);
final FireworkMeta meta = (FireworkMeta)stack.getItemMeta();
meta.setPower(power);
stack.setItemMeta(meta);
} }
// else if (split.length > 1 && split[0].equalsIgnoreCase("effect") && stack.getType() == Material.FIREWORK)
// {
// //TODO: Add validation messages
// final FireworkMeta meta = (FireworkMeta)stack.getItemMeta();
// Builder builder = FireworkEffect.builder();
//
// String[] effectData = split[1].toUpperCase(Locale.ENGLISH).split("\\|");
//
// builder.with(FireworkEffect.Type.valueOf(effectData[0]));
//
// String[] primaryColorStrings = effectData[1].split(",");
// List<Color> primaryColors = new ArrayList<Color>();
//
// for (String primaryColorString : primaryColorStrings) {
// primaryColors.add(DyeColor.valueOf(primaryColorString).getFireworkColor());
// }
//
// builder.withColor(primaryColors);
//
// final FireworkEffect effect = builder.build();
// meta.addEffect(effect);
// stack.setItemMeta(meta);
// }
else if (split.length > 1 && (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour")) else if (split.length > 1 && (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour"))
&& (stack.getType() == Material.LEATHER_BOOTS && (stack.getType() == Material.LEATHER_BOOTS
|| stack.getType() == Material.LEATHER_CHESTPLATE || stack.getType() == Material.LEATHER_CHESTPLATE
@ -153,22 +167,108 @@ public class MetaItemStack
parseEnchantmentStrings(user, allowUnsafe, split); parseEnchantmentStrings(user, allowUnsafe, split);
} }
} }
public void addStringEnchantment(final User user, final boolean allowUnsafe, final String string) throws Exception public void addFireworkMeta(final CommandSender user, final boolean allowShortName, final String string, final IEssentials ess)
{ {
final String[] split = splitPattern.split(string, 2); if (stack.getType() == Material.FIREWORK)
if (split.length < 1)
{ {
return; FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
final String[] split = splitPattern.split(string, 2);
if (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour") || (allowShortName && split[0].equalsIgnoreCase("c")))
{
List<Color> primaryColors = new ArrayList<Color>();
String[] colors = split[1].split(",");
for (String color : colors)
{
if (colorMap.containsKey(color.toUpperCase()))
{
validFirework = true;
primaryColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
builder.withColor(primaryColors);
}
else if (split[0].equalsIgnoreCase("shape") || split[0].equalsIgnoreCase("type") || (allowShortName && (split[0].equalsIgnoreCase("s") || split[0].equalsIgnoreCase("t"))))
{
FireworkEffect.Type finalEffect = null;
split[1] = (split[1].equalsIgnoreCase("large") ? "BALL_LARGE" : split[1]);
if (fireworkShape.containsKey(split[1].toUpperCase()))
{
finalEffect = fireworkShape.get(split[1].toUpperCase());
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
if (finalEffect != null)
{
builder.with(finalEffect);
}
}
else if (split[0].equalsIgnoreCase("fade") || (allowShortName && split[0].equalsIgnoreCase("f")))
{
List<Color> fadeColors = new ArrayList<Color>();
String[] colors = split[1].split(",");
for (String color : colors)
{
if (colorMap.containsKey(color.toUpperCase()))
{
fadeColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
if (!fadeColors.isEmpty())
{
builder.withFade(fadeColors);
}
}
else if (split[0].equalsIgnoreCase("effect") || (allowShortName && split[0].equalsIgnoreCase("e")))
{
String[] effects = split[1].split(",");
for (String effect : effects)
{
if (effect.equalsIgnoreCase("twinkle"))
{
builder.flicker(true);
}
else if (effect.equalsIgnoreCase("trail"))
{
builder.trail(true);
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
}
else if (split[0].equalsIgnoreCase("power") || (allowShortName && split[0].equalsIgnoreCase("p")))
{
try
{
int power = Integer.parseInt(split[1]);
fmeta.setPower(power > 3 ? 4 : power);
}
catch (NumberFormatException e)
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
stack.setItemMeta(fmeta);
}
} }
parseEnchantmentStrings(user, allowUnsafe, split);
} }
private void parseEnchantmentStrings(final User user, final boolean allowUnsafe, final String[] split) throws Exception private void parseEnchantmentStrings(final CommandSender user, final boolean allowUnsafe, final String[] split) throws Exception
{ {
Enchantment enchantment = getEnchantment(user, split[0]); Enchantment enchantment = getEnchantment(null, split[0]);
int level = -1; int level = -1;
if (split.length > 1) if (split.length > 1)
{ {
@ -181,15 +281,15 @@ public class MetaItemStack
level = -1; level = -1;
} }
} }
if (level < 0 || (!allowUnsafe && level > enchantment.getMaxLevel())) if (level < 0 || (!allowUnsafe && level > enchantment.getMaxLevel()))
{ {
level = enchantment.getMaxLevel(); level = enchantment.getMaxLevel();
} }
addEnchantment(user, allowUnsafe, enchantment, level); addEnchantment(user, allowUnsafe, enchantment, level);
} }
public void addEnchantment(final User user, final boolean allowUnsafe, final Enchantment enchantment, final int level) throws Exception public void addEnchantment(final CommandSender user, final boolean allowUnsafe, final Enchantment enchantment, final int level) throws Exception
{ {
try try
{ {

View File

@ -63,9 +63,8 @@ public class Commandenchant extends EssentialsCommand
final MetaItemStack metaStack = new MetaItemStack(stack); final MetaItemStack metaStack = new MetaItemStack(stack);
final Enchantment enchantment = metaStack.getEnchantment(user, args[0]); final Enchantment enchantment = metaStack.getEnchantment(user, args[0]);
metaStack.addEnchantment(user, allowUnsafe, enchantment, level); metaStack.addEnchantment(user, allowUnsafe, enchantment, level);
user.getInventory().setItemInHand(metaStack.getItemStack()); user.getInventory().setItemInHand(metaStack.getItemStack());
user.updateInventory(); user.updateInventory();
final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH); final String enchantmentName = enchantment.getName().toLowerCase(Locale.ENGLISH);
if (level == 0) if (level == 0)

View File

@ -1,13 +1,12 @@
package com.earth2me.essentials.commands; package com.earth2me.essentials.commands;
import com.earth2me.essentials.User;
import static com.earth2me.essentials.I18n._; import static com.earth2me.essentials.I18n._;
import java.util.ArrayList; import com.earth2me.essentials.MetaItemStack;
import com.earth2me.essentials.User;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.bukkit.Color;
import org.bukkit.DyeColor; import org.bukkit.DyeColor;
import org.bukkit.FireworkEffect; import org.bukkit.FireworkEffect;
import org.bukkit.Material; import org.bukkit.Material;
@ -44,116 +43,28 @@ public class Commandfirework extends EssentialsCommand
@Override @Override
protected void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception protected void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception
{ {
if (args.length > 0) if (args.length > 0)
{ {
ItemStack stack = user.getItemInHand(); final ItemStack stack = user.getItemInHand();
if (stack.getType() == Material.FIREWORK) if (stack.getType() == Material.FIREWORK)
{ {
FireworkEffect.Builder builder = FireworkEffect.builder();
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
if (args.length > 0) if (args.length > 0)
{ {
if (args[0].equalsIgnoreCase("clear")) if (args[0].equalsIgnoreCase("clear"))
{ {
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
fmeta.clearEffects(); fmeta.clearEffects();
stack.setItemMeta(fmeta); stack.setItemMeta(fmeta);
} }
else else
{ {
List<Color> primaryColors = new ArrayList<Color>(); final MetaItemStack mStack = new MetaItemStack(stack);
List<Color> fadeColors = new ArrayList<Color>();
FireworkEffect.Type finalEffect = null;
boolean valid = false;
boolean fire = false; boolean fire = false;
int amount = 1; int amount = 1;
for (String arg : args) for (String arg : args)
{ {
final String[] split = splitPattern.split(arg, 2); final String[] split = splitPattern.split(arg, 2);
if (split[0].equalsIgnoreCase("color") || split[0].equalsIgnoreCase("colour") || split[0].equalsIgnoreCase("c")) mStack.addFireworkMeta(user, true, arg, ess);
{
String[] colors = split[1].split(",");
for (String color : colors)
{
if (colorMap.containsKey(color.toUpperCase()))
{
valid = true;
primaryColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
builder.withColor(primaryColors);
}
if (split[0].equalsIgnoreCase("shape") || split[0].equalsIgnoreCase("s") || split[0].equalsIgnoreCase("type") || split[0].equalsIgnoreCase("t"))
{
split[1] = (split[1].equalsIgnoreCase("large") ? "BALL_LARGE" : split[1]);
if (fireworkShape.containsKey(split[1].toUpperCase()))
{
finalEffect = fireworkShape.get(split[1].toUpperCase());
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
if (finalEffect != null)
{
builder.with(finalEffect);
}
}
if (split[0].equalsIgnoreCase("fade") || split[0].equalsIgnoreCase("f"))
{
String[] colors = split[1].split(",");
for (String color : colors)
{
if (colorMap.containsKey(color.toUpperCase()))
{
fadeColors.add(colorMap.get(color.toUpperCase()).getFireworkColor());
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
if (!fadeColors.isEmpty())
{
builder.withFade(fadeColors);
}
}
if (split[0].equalsIgnoreCase("effect") || split[0].equalsIgnoreCase("e"))
{
String[] effects = split[1].split(",");
for (String effect : effects)
{
if (effect.equalsIgnoreCase("twinkle"))
{
builder.flicker(true);
}
else if (effect.equalsIgnoreCase("trail"))
{
builder.trail(true);
}
else
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
}
if (split[0].equalsIgnoreCase("power") || split[0].equalsIgnoreCase("p"))
{
try
{
fmeta.setPower(Integer.parseInt(split[1]));
}
catch (NumberFormatException e)
{
user.sendMessage(_("invalidFireworkFormat", split[1], split[0]));
}
}
if (split[0].equalsIgnoreCase("fire") && user.isAuthorized("essentials.firework.fire")) if (split[0].equalsIgnoreCase("fire") && user.isAuthorized("essentials.firework.fire"))
{ {
fire = true; fire = true;
@ -161,7 +72,7 @@ public class Commandfirework extends EssentialsCommand
{ {
amount = Integer.parseInt(split[1]); amount = Integer.parseInt(split[1]);
int serverLimit = ess.getSettings().getSpawnMobLimit(); int serverLimit = ess.getSettings().getSpawnMobLimit();
if(amount > serverLimit) if (amount > serverLimit)
{ {
amount = serverLimit; amount = serverLimit;
user.sendMessage(_("mobSpawnLimit")); user.sendMessage(_("mobSpawnLimit"));
@ -173,31 +84,32 @@ public class Commandfirework extends EssentialsCommand
} }
} }
} }
if (valid)
if (fire)
{ {
if (fire) for (int i = 0; i < amount; i++)
{ {
for (int i = 0; i < amount; i++ ) Firework firework = (Firework)user.getWorld().spawnEntity(user.getLocation(), EntityType.FIREWORK);
FireworkMeta fmeta = (FireworkMeta)mStack.getItemStack().getItemMeta();
if (mStack.isValidFirework())
{ {
Firework firework = (Firework)user.getWorld().spawnEntity(user.getLocation(), EntityType.FIREWORK); FireworkEffect effect = mStack.getFireworkBuilder().build();
FireworkMeta ffmeta = firework.getFireworkMeta(); fmeta.addEffect(effect);
ffmeta.addEffect(builder.build());
ffmeta.setPower(fmeta.getPower());
firework.setFireworkMeta(ffmeta);
} }
} firework.setFireworkMeta(fmeta);
else
{
final FireworkEffect effect = builder.build();
fmeta.addEffect(effect);
stack.setItemMeta(fmeta);
} }
} }
else else if (!mStack.isValidFirework())
{ {
user.sendMessage(_("fireworkColor")); user.sendMessage(_("fireworkColor"));
} }
else
{
FireworkMeta fmeta = (FireworkMeta)mStack.getItemStack().getItemMeta();
FireworkEffect effect = mStack.getFireworkBuilder().build();
fmeta.addEffect(effect);
stack.setItemMeta(fmeta);
}
} }
} }
} }
@ -208,7 +120,26 @@ public class Commandfirework extends EssentialsCommand
} }
else else
{ {
throw new NotEnoughArgumentsException(); final ItemStack stack = user.getItemInHand();
if (stack.getType() == Material.FIREWORK)
{
FireworkMeta fmeta = (FireworkMeta)stack.getItemMeta();
List<FireworkEffect> effects = fmeta.getEffects();
user.sendMessage("The firework you are holding has the following effects:");
for (FireworkEffect effect : effects)
{
StringBuilder effectDesc = new StringBuilder();
effectDesc.append("Effect: ");
Map<String, Object> desc = effect.serialize();
for (String info : desc.keySet())
{
effectDesc.append(info).append(": ").append(desc.get(info)).append(" ");
}
user.sendMessage(effectDesc.toString());
}
}
} }
} }
} }

View File

@ -77,11 +77,9 @@ public class Commandgive extends EssentialsCommand
{ {
allowUnsafe = false; allowUnsafe = false;
} }
for (int i = Util.isInt(args[3]) ? 4 : 3; i < args.length; i++) metaStack.parseStringMeta(sender, allowUnsafe, args, Util.isInt(args[3]) ? 4 : 3, ess);
{
metaStack.addStringMeta(null, allowUnsafe, args[i], ess);
}
stack = metaStack.getItemStack(); stack = metaStack.getItemStack();
} }

View File

@ -3,6 +3,7 @@ package com.earth2me.essentials.commands;
import static com.earth2me.essentials.I18n._; import static com.earth2me.essentials.I18n._;
import com.earth2me.essentials.MetaItemStack; import com.earth2me.essentials.MetaItemStack;
import com.earth2me.essentials.User; import com.earth2me.essentials.User;
import com.earth2me.essentials.Util;
import com.earth2me.essentials.craftbukkit.InventoryWorkaround; import com.earth2me.essentials.craftbukkit.InventoryWorkaround;
import java.util.Locale; import java.util.Locale;
import org.bukkit.Material; import org.bukkit.Material;
@ -59,11 +60,9 @@ public class Commanditem extends EssentialsCommand
{ {
MetaItemStack metaStack = new MetaItemStack(stack); MetaItemStack metaStack = new MetaItemStack(stack);
final boolean allowUnsafe = ess.getSettings().allowUnsafeEnchantments() && user.isAuthorized("essentials.enchant.allowunsafe"); final boolean allowUnsafe = ess.getSettings().allowUnsafeEnchantments() && user.isAuthorized("essentials.enchant.allowunsafe");
for (int i = 2; i < args.length; i++) metaStack.parseStringMeta(user, allowUnsafe, args, 2, ess);
{
metaStack.addStringMeta(null, allowUnsafe, args[i], ess);
}
stack = metaStack.getItemStack(); stack = metaStack.getItemStack();
} }