Build against Bukkit API for Minecraft 1.13.

This very likely introduces a few bugs and breaks some functionality, but at least we're compiling...
This commit is contained in:
Andreas Troelsen 2018-07-05 12:28:23 +02:00
parent 754eb156d1
commit 934eb2d8cc
22 changed files with 85 additions and 206 deletions

View File

@ -100,7 +100,7 @@
<dependency>
<groupId>org.bukkit</groupId>
<artifactId>bukkit</artifactId>
<version>1.11-R0.1-SNAPSHOT</version>
<version>1.13-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency>

View File

@ -220,12 +220,12 @@ public class ArenaClass
* Used by isWeapon() to determine if an ItemStack is a weapon type.
*/
private static EnumSet<Material> weaponTypes = EnumSet.of(
WOOD_SWORD, GOLD_SWORD, STONE_SWORD, IRON_SWORD, DIAMOND_SWORD,
WOOD_AXE, GOLD_AXE, STONE_AXE, IRON_AXE, DIAMOND_AXE,
WOOD_PICKAXE, GOLD_PICKAXE, STONE_PICKAXE, IRON_PICKAXE, DIAMOND_PICKAXE,
WOOD_SPADE, GOLD_SPADE, STONE_SPADE, IRON_SPADE, DIAMOND_SPADE,
WOOD_HOE, GOLD_HOE, STONE_HOE, IRON_HOE, DIAMOND_HOE,
BOW, FISHING_ROD, FLINT_AND_STEEL, SHEARS, CARROT_STICK, SHIELD
WOODEN_SWORD, GOLDEN_SWORD, STONE_SWORD, IRON_SWORD, DIAMOND_SWORD,
WOODEN_AXE, GOLDEN_AXE, STONE_AXE, IRON_AXE, DIAMOND_AXE,
WOODEN_PICKAXE, GOLDEN_PICKAXE, STONE_PICKAXE, IRON_PICKAXE, DIAMOND_PICKAXE,
WOODEN_SHOVEL, GOLDEN_SHOVEL, STONE_SHOVEL, IRON_SHOVEL, DIAMOND_SHOVEL,
WOODEN_HOE, GOLDEN_HOE, STONE_HOE, IRON_HOE, DIAMOND_HOE,
BOW, FISHING_ROD, FLINT_AND_STEEL, SHEARS, CARROT_ON_A_STICK, SHIELD
);
/**
@ -258,28 +258,28 @@ public class ArenaClass
case CHAINMAIL_HELMET:
case IRON_HELMET:
case DIAMOND_HELMET:
case GOLD_HELMET:
case GOLDEN_HELMET:
return HELMET;
case LEATHER_CHESTPLATE:
case CHAINMAIL_CHESTPLATE:
case IRON_CHESTPLATE:
case DIAMOND_CHESTPLATE:
case GOLD_CHESTPLATE:
case GOLDEN_CHESTPLATE:
return CHESTPLATE;
case LEATHER_LEGGINGS:
case CHAINMAIL_LEGGINGS:
case IRON_LEGGINGS:
case DIAMOND_LEGGINGS:
case GOLD_LEGGINGS:
case GOLDEN_LEGGINGS:
return LEGGINGS;
case LEATHER_BOOTS:
case CHAINMAIL_BOOTS:
case IRON_BOOTS:
case DIAMOND_BOOTS:
case GOLD_BOOTS:
case GOLDEN_BOOTS:
return BOOTS;
default:

View File

@ -989,9 +989,9 @@ public class ArenaImpl implements Arena
private Material bardingFromAmount(int amount) {
switch ((amount >> 3) % 4) {
case 1: return Material.IRON_BARDING;
case 2: return Material.GOLD_BARDING;
case 3: return Material.DIAMOND_BARDING;
case 1: return Material.IRON_HORSE_ARMOR;
case 2: return Material.GOLDEN_HORSE_ARMOR;
case 3: return Material.DIAMOND_HORSE_ARMOR;
default: return null;
}
}

View File

@ -307,7 +307,7 @@ public class ArenaListener
// Otherwise, block was placed during a session.
arena.addBlock(b);
if (b.getType() == Material.WOODEN_DOOR || b.getType() == Material.IRON_DOOR_BLOCK) {
if (b.getType().name().endsWith("_DOOR")) {
// For doors, add the block just above (so we get both halves)
arena.addBlock(b.getRelative(0, 1, 0));
}
@ -393,7 +393,6 @@ public class ArenaListener
private boolean isWater(Block block) {
switch (block.getType()) {
case WATER:
case STATIONARY_WATER:
return true;
default:
return false;
@ -534,7 +533,7 @@ public class ArenaListener
// Cakes and liquids should just get removed. If player-placed block, drop as item.
Material mat = state.getType();
if (mat == Material.CAKE_BLOCK || mat == Material.WATER || mat == Material.LAVA)
if (mat == Material.CAKE || mat == Material.WATER || mat == Material.LAVA)
arena.removeBlock(b);
else if (arena.removeBlock(b))
arena.getWorld().dropItemNaturally(b.getLocation(), new ItemStack(state.getType(), 1));
@ -852,19 +851,19 @@ public class ArenaListener
private static final EnumSet<Material> REPAIRABLE_TYPES = EnumSet.of(
// Tools and swords
Material.GOLD_AXE, Material.GOLD_HOE, Material.GOLD_PICKAXE, Material.GOLD_SPADE, Material.GOLD_SWORD,
Material.WOOD_AXE, Material.WOOD_HOE, Material.WOOD_PICKAXE, Material.WOOD_SPADE, Material.WOOD_SWORD,
Material.STONE_AXE, Material.STONE_HOE, Material.STONE_PICKAXE, Material.STONE_SPADE, Material.STONE_SWORD,
Material.IRON_AXE, Material.IRON_HOE, Material.IRON_PICKAXE, Material.IRON_SPADE, Material.IRON_SWORD,
Material.DIAMOND_AXE, Material.DIAMOND_HOE, Material.DIAMOND_PICKAXE, Material.DIAMOND_SPADE, Material.DIAMOND_SWORD,
Material.GOLDEN_AXE, Material.GOLDEN_HOE, Material.GOLDEN_PICKAXE, Material.GOLDEN_SHOVEL, Material.GOLDEN_SWORD,
Material.WOODEN_AXE, Material.WOODEN_HOE, Material.WOODEN_PICKAXE, Material.WOODEN_SHOVEL, Material.WOODEN_SWORD,
Material.STONE_AXE, Material.STONE_HOE, Material.STONE_PICKAXE, Material.STONE_SHOVEL, Material.STONE_SWORD,
Material.IRON_AXE, Material.IRON_HOE, Material.IRON_PICKAXE, Material.IRON_SHOVEL, Material.IRON_SWORD,
Material.DIAMOND_AXE, Material.DIAMOND_HOE, Material.DIAMOND_PICKAXE, Material.DIAMOND_SHOVEL, Material.DIAMOND_SWORD,
// Armor
Material.LEATHER_HELMET, Material.LEATHER_CHESTPLATE, Material.LEATHER_LEGGINGS, Material.LEATHER_BOOTS,
Material.GOLD_HELMET, Material.GOLD_CHESTPLATE, Material.GOLD_LEGGINGS, Material.GOLD_BOOTS,
Material.GOLDEN_HELMET, Material.GOLDEN_CHESTPLATE, Material.GOLDEN_LEGGINGS, Material.GOLDEN_BOOTS,
Material.CHAINMAIL_HELMET, Material.CHAINMAIL_CHESTPLATE, Material.CHAINMAIL_LEGGINGS, Material.CHAINMAIL_BOOTS,
Material.IRON_HELMET, Material.IRON_CHESTPLATE, Material.IRON_LEGGINGS, Material.IRON_BOOTS,
Material.DIAMOND_HELMET, Material.DIAMOND_CHESTPLATE, Material.DIAMOND_LEGGINGS, Material.DIAMOND_BOOTS,
// Misc
Material.BOW, Material.FLINT_AND_STEEL, Material.FISHING_ROD, Material.SHEARS, Material.CARROT_STICK, Material.SHIELD
Material.BOW, Material.FLINT_AND_STEEL, Material.FISHING_ROD, Material.SHEARS, Material.CARROT_ON_A_STICK, Material.SHIELD
);
private void repairWeapon(Player p) {

View File

@ -57,7 +57,7 @@ public class ArenaMasterImpl implements ArenaMaster
this.classes = new HashMap<>();
this.allowedCommands = new HashSet<>();
this.spawnsPets = new SpawnsPets(Material.BONE, Material.RAW_FISH);
this.spawnsPets = new SpawnsPets(Material.BONE, Material.SALMON);
this.joinInterruptTimer = new JoinInterruptTimer();
}

View File

@ -10,7 +10,9 @@ import com.garbagemule.MobArena.util.TextUtils;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.block.BlockFace;
import org.bukkit.block.Sign;
import org.bukkit.block.data.Rotatable;
import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.entity.Entity;
import org.bukkit.entity.Ocelot;
@ -359,9 +361,11 @@ public class MAUtils
// Place the hippie signs
//Iterator<String> iterator = am.getClasses().iterator();
Iterator<String> iterator = am.getClasses().keySet().iterator();
Rotatable signData = (Rotatable) Material.SIGN.createBlockData();
signData.setRotation(BlockFace.NORTH);
for (int i = lx1+2; i <= lx2-2; i++) // Signs
{
world.getBlockAt(i,ly1+1,lz2-1).setTypeIdAndData(63, (byte)0x8, false);
world.getBlockAt(i,ly1+1,lz2-1).setBlockData(signData);
Sign sign = (Sign) world.getBlockAt(i,ly1+1,lz2-1).getState();
sign.setLine(0, TextUtils.camelCase(iterator.next()));
sign.update();

View File

@ -7,8 +7,8 @@ import java.util.StringJoiner;
class ServerVersionCheck {
private static final String[] EXACTS = {"1.11", "1.12"};
private static final String[] PREFIXES = {"1.11.", "1.12."};
private static final String[] EXACTS = {"1.13"};
private static final String[] PREFIXES = {"1.13."};
static void check(Server server) {
String version = getMinecraftVersion(server);

View File

@ -161,31 +161,31 @@ public class SetupCommand implements Command, Listener {
private ItemStack[] getToolbox() {
// Arena region tool
ItemStack areg = makeTool(
Material.GOLD_AXE, AREG_NAME,
Material.GOLDEN_AXE, AREG_NAME,
color("Set &ep1"),
color("Set &ep2")
);
// Warps tool
ItemStack warps = makeTool(
Material.GOLD_HOE, WARPS_NAME,
Material.GOLDEN_HOE, WARPS_NAME,
color("&eSet &rselected warp"),
color("&eCycle &rbetween warps")
);
// Spawns tool
ItemStack spawns = makeTool(
Material.GOLD_SWORD, SPAWNS_NAME,
Material.GOLDEN_SWORD, SPAWNS_NAME,
color("&eAdd &rspawnpoint on block"),
color("&eRemove &rspawnpoint on block")
);
// Chests tool
ItemStack chests = makeTool(
Material.GOLD_SPADE, CHESTS_NAME,
Material.GOLDEN_SHOVEL, CHESTS_NAME,
color("&eAdd &rcontainer"),
color("&eRemove &rcontainer")
);
// Lobby region tool
ItemStack lreg = makeTool(
Material.GOLD_AXE, LREG_NAME,
Material.GOLDEN_AXE, LREG_NAME,
color("Set &el1"),
color("Set &el2")
);
@ -640,7 +640,7 @@ public class SetupCommand implements Command, Listener {
toShow.equals("spec") ? region.getSpecWarp() :
toShow.equals("spectator") ? region.getSpecWarp() :
toShow.equals("exit") ? region.getExitWarp() : null;
region.showBlock(player, loc, 35, (byte) 14);
region.showBlock(player, loc);
return this;
}

View File

@ -11,9 +11,11 @@ import com.garbagemule.MobArena.util.Enums;
import org.bukkit.ChatColor;
import org.bukkit.Chunk;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.block.Block;
import org.bukkit.block.BlockState;
import org.bukkit.block.data.BlockData;
import org.bukkit.command.CommandSender;
import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.entity.Player;
@ -650,18 +652,19 @@ public class ArenaRegion
showBlocks(p, map.values());
}
public void showBlock(final Player p, final Location loc, final int id, final byte data) {
public void showBlock(final Player p, final Location loc) {
BlockData wool = Material.RED_WOOL.createBlockData();
arena.scheduleTask(new Runnable() {
@Override
public void run() {
p.sendBlockChange(loc, id, data);
p.sendBlockChange(loc, wool);
arena.scheduleTask(new Runnable() {
@Override
public void run() {
if (!p.isOnline()) return;
Block b = loc.getBlock();
p.sendBlockChange(loc, b.getTypeId(), b.getData());
p.sendBlockChange(loc, b.getBlockData());
}
}, 100);
}
@ -669,6 +672,7 @@ public class ArenaRegion
}
private void showBlocks(final Player p, final Collection<Location> points) {
BlockData wool = Material.RED_WOOL.createBlockData();
arena.scheduleTask(new Runnable() {
@Override
public void run() {
@ -677,7 +681,7 @@ public class ArenaRegion
for (Location l : points) {
Block b = l.getBlock();
blocks.put(l, b.getState());
p.sendBlockChange(l, 35, (byte) 14);
p.sendBlockChange(l, wool);
}
arena.scheduleTask(new Runnable() {
public void run() {
@ -690,10 +694,9 @@ public class ArenaRegion
for (Map.Entry<Location,BlockState> entry : blocks.entrySet()) {
Location l = entry.getKey();
BlockState b = entry.getValue();
int id = b.getTypeId();
byte data = b.getRawData();
BlockData data = b.getBlockData();
p.sendBlockChange(l, id, data);
p.sendBlockChange(l, data);
}
}
}, 100);

View File

@ -3,6 +3,7 @@ package com.garbagemule.MobArena.repairable;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.block.BlockState;
import org.bukkit.block.data.BlockData;
public interface Repairable
{
@ -11,8 +12,7 @@ public interface Repairable
BlockState getState();
Material getType();
int getId();
byte getData();
BlockData getData();
World getWorld();
int getX();

View File

@ -1,5 +1,6 @@
package com.garbagemule.MobArena.repairable;
import org.bukkit.Material;
import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
import org.bukkit.block.BlockState;
@ -23,14 +24,14 @@ public class RepairableAttachable extends RepairableBlock
y = attached.getY();
z = attached.getZ();
state.getBlock().setTypeId(1);
state.getBlock().setType(Material.STONE);
}
public void repair()
{
Block b = getWorld().getBlockAt(x,y,z);
if (b.getTypeId() == 0)
b.setTypeId(1);
if (b.getType() == Material.AIR)
b.setType(Material.STONE);
super.repair();
}

View File

@ -19,6 +19,6 @@ public class RepairableBed extends RepairableBlock
return;
super.repair();
other.getBlock().setTypeIdAndData(getId(), (byte) (getData() + 8), false);
other.getBlock().setBlockData(other.getBlockData());
}
}

View File

@ -3,14 +3,15 @@ package com.garbagemule.MobArena.repairable;
import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.block.BlockState;
import org.bukkit.block.data.BlockData;
public class RepairableBlock implements Repairable
{
private BlockState state;
private World world;
private int id, x, y, z;
private BlockData data;
private int x, y, z;
private Material type;
private byte data;
public RepairableBlock(BlockState state)
{
@ -22,9 +23,8 @@ public class RepairableBlock implements Repairable
y = state.getY();
z = state.getZ();
id = state.getTypeId();
data = state.getBlockData();
type = state.getType();
data = state.getRawData();
}
/**
@ -32,7 +32,7 @@ public class RepairableBlock implements Repairable
*/
public void repair()
{
world.getBlockAt(x,y,z).setTypeIdAndData(id, data, false);
world.getBlockAt(x,y,z).setBlockData(data);
}
public BlockState getState()
@ -50,12 +50,7 @@ public class RepairableBlock implements Repairable
return type;
}
public int getId()
{
return id;
}
public byte getData()
public BlockData getData()
{
return data;
}

View File

@ -1,11 +1,11 @@
package com.garbagemule.MobArena.repairable;
import org.bukkit.Material;
import org.bukkit.material.Attachable;
import org.bukkit.material.Bed;
import org.bukkit.material.Door;
import org.bukkit.material.MaterialData;
import org.bukkit.material.Redstone;
import org.bukkit.block.data.Attachable;
import org.bukkit.block.data.BlockData;
import org.bukkit.block.data.type.Bed;
import org.bukkit.block.data.type.Door;
import org.bukkit.block.data.type.RedstoneWire;
import java.util.Comparator;
@ -28,8 +28,8 @@ public class RepairableComparator implements Comparator<Repairable>
private boolean restoreLast(Repairable r)
{
Material t = r.getType();
MaterialData m = r.getState().getData();
BlockData data = r.getData();
return (m instanceof Attachable || m instanceof Redstone || m instanceof Door || m instanceof Bed || t == Material.STATIONARY_LAVA || t == Material.STATIONARY_WATER || t == Material.FIRE);
return (data instanceof Attachable || data instanceof RedstoneWire || data instanceof Door || data instanceof Bed || t == Material.LAVA || t == Material.WATER || t == Material.FIRE);
}
}

View File

@ -1,5 +1,6 @@
package com.garbagemule.MobArena.repairable;
import org.bukkit.Material;
import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
import org.bukkit.block.BlockState;
@ -27,10 +28,10 @@ public class RepairableDoor extends RepairableAttachable//RepairableBlock
return;
Block b = getWorld().getBlockAt(x,y,z);
if (b.getTypeId() == 0)
b.setTypeId(1);
if (b.getType() == Material.AIR)
b.setType(Material.STONE);
super.repair();
other.getBlock().setTypeIdAndData(getId(), (byte) (getData() + 8), false);
other.getBlock().setBlockData(other.getBlockData());
}
}

View File

@ -15,28 +15,28 @@ class Equippable {
Material.LEATHER_HELMET,
Material.IRON_HELMET,
Material.CHAINMAIL_HELMET,
Material.GOLD_HELMET,
Material.GOLDEN_HELMET,
Material.DIAMOND_HELMET
);
private static EnumSet<Material> chestplates = EnumSet.of(
Material.LEATHER_CHESTPLATE,
Material.IRON_CHESTPLATE,
Material.CHAINMAIL_CHESTPLATE,
Material.GOLD_CHESTPLATE,
Material.GOLDEN_CHESTPLATE,
Material.DIAMOND_CHESTPLATE
);
private static EnumSet<Material> leggings = EnumSet.of(
Material.LEATHER_LEGGINGS,
Material.IRON_LEGGINGS,
Material.CHAINMAIL_LEGGINGS,
Material.GOLD_LEGGINGS,
Material.GOLDEN_LEGGINGS,
Material.DIAMOND_LEGGINGS
);
private static EnumSet<Material> boots = EnumSet.of(
Material.LEATHER_BOOTS,
Material.IRON_BOOTS,
Material.CHAINMAIL_BOOTS,
Material.GOLD_BOOTS,
Material.GOLDEN_BOOTS,
Material.DIAMOND_BOOTS
);

View File

@ -48,7 +48,7 @@ public class ClassChests {
Block blockBehind = blockBelow.getRelative(backwards);
// If the block below this sign is a class sign, swap the order
if (blockBelow.getType() == Material.WALL_SIGN || blockBelow.getType() == Material.SIGN_POST) {
if (blockBelow.getType() == Material.WALL_SIGN || blockBelow.getType() == Material.SIGN) {
String className = ChatColor.stripColor(((Sign) blockBelow.getState()).getLine(0)).toLowerCase();
if (arena.getClasses().containsKey(className)) {
blockSign = blockBehind; // Use blockSign as a temp while swapping

View File

@ -1,43 +1,21 @@
package com.garbagemule.MobArena.util;
import org.bukkit.Bukkit;
import org.bukkit.DyeColor;
import org.bukkit.Material;
import org.bukkit.NamespacedKey;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.EnchantmentStorageMeta;
import org.bukkit.inventory.meta.PotionMeta;
import org.bukkit.material.Dye;
import org.bukkit.material.MaterialData;
import org.bukkit.material.Wool;
import org.bukkit.potion.PotionData;
import org.bukkit.potion.PotionType;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
public class ItemParser
{
private static final Map<Short, PotionType> POTION_TYPE_MAP = new HashMap<>();
static {
POTION_TYPE_MAP.put((short) 8193, PotionType.REGEN);
POTION_TYPE_MAP.put((short) 8194, PotionType.SPEED);
POTION_TYPE_MAP.put((short) 8195, PotionType.FIRE_RESISTANCE);
POTION_TYPE_MAP.put((short) 8196, PotionType.POISON);
POTION_TYPE_MAP.put((short) 8197, PotionType.INSTANT_HEAL);
POTION_TYPE_MAP.put((short) 8198, PotionType.NIGHT_VISION);
POTION_TYPE_MAP.put((short) 8200, PotionType.WEAKNESS);
POTION_TYPE_MAP.put((short) 8201, PotionType.STRENGTH);
POTION_TYPE_MAP.put((short) 8202, PotionType.SLOWNESS);
POTION_TYPE_MAP.put((short) 8203, PotionType.JUMP);
POTION_TYPE_MAP.put((short) 8204, PotionType.INSTANT_DAMAGE);
POTION_TYPE_MAP.put((short) 8205, PotionType.WATER_BREATHING);
POTION_TYPE_MAP.put((short) 8206, PotionType.INVISIBILITY);
}
public static List<ItemStack> parseItems(String s) {
if (s == null) {
return new ArrayList<>(1);
@ -118,12 +96,7 @@ public class ItemParser
return withPotionMeta(stack, data);
}
MaterialData md = getData(data, type);
if (md == null) {
return null;
}
return md.toItemStack(stack.getAmount());
return stack;
}
private static ItemStack withPotionMeta(ItemStack stack, String data) {
@ -138,29 +111,6 @@ public class ItemParser
}
private static PotionType getPotionType(String data) {
if (data.matches("[0-9]+")) {
short d = Short.parseShort(data);
// Compensate for splash potions
if (d > (2 * 8192)) {
d -= 8192;
}
boolean extended = (d & 64) > 0;
boolean upgraded = (d & 32) > 0;
if (extended) {
d -= 64;
}
if (upgraded) {
d -= 32;
}
PotionType type = POTION_TYPE_MAP.get(d);
if (type != null) {
warn(type.name(), data);
}
return type;
}
try {
return PotionType.valueOf(data.toUpperCase());
} catch (IllegalArgumentException e) {
@ -169,65 +119,9 @@ public class ItemParser
}
private static Optional<Material> getType(String item) {
if (item.matches("(-)?[1-9][0-9]*")) {
Material type = Material.getMaterial(Integer.parseInt(item));
if (type == null) {
return Optional.empty();
}
warn(type.name(), item);
return Optional.of(type);
}
return Optional.ofNullable(Material.getMaterial(item.toUpperCase()));
}
private static MaterialData getData(String data, Material type) {
if (type == Material.INK_SACK) {
return getDyeData(data);
}
if (type == Material.WOOL) {
return getWoolData(data);
}
return null;
}
private static Wool getWoolData(String data) {
if (data.matches("(-)?[1-9][0-9]*")) {
DyeColor color = DyeColor.getByWoolData(Byte.parseByte(data));
if (color == null) {
return null;
}
warn(color.name(), data);
return new Wool(color);
}
try {
return new Wool(DyeColor.valueOf(data.toUpperCase()));
} catch (IllegalArgumentException e) {
return null;
}
}
private static Dye getDyeData(String data) {
if (data.matches("(-)?[1-9][0-9]*")) {
DyeColor color = DyeColor.getByDyeData(Byte.parseByte(data));
if (color == null) {
return null;
}
warn(color.name(), data);
return new Dye(color);
}
try {
return new Dye(DyeColor.valueOf(data.toUpperCase()));
} catch (IllegalArgumentException e) {
return null;
}
}
private static int getAmount(String amount) {
if (amount.matches("(-)?[1-9][0-9]*")) {
return Integer.parseInt(amount);
@ -246,7 +140,7 @@ public class ItemParser
private static void addEnchantment(ItemStack stack, String ench) {
String[] parts = ench.split(":");
if (parts.length != 2 || !parts[1].matches("[0-9]*")) {
if (parts.length != 2) {
return;
}
@ -266,25 +160,6 @@ public class ItemParser
}
private static Enchantment getEnchantment(String ench) {
if (ench.matches("[1-9][0-9]*")) {
Enchantment enchantment = Enchantment.getById(Integer.parseInt(ench));
if (enchantment == null) {
return null;
}
warn(enchantment.getName(), ench);
return enchantment;
}
return Enchantment.getByName(ench.toUpperCase());
}
private static void warn(String name, String value) {
String msg = String.format(
"Consider using '%s' instead of '%s'",
name.toLowerCase(),
value
);
Bukkit.getLogger().warning("[MobArena] " + msg);
return Enchantment.getByKey(NamespacedKey.minecraft(ench));
}
}

View File

@ -2,6 +2,7 @@ name: ${project.name}
author: garbagemule
main: com.garbagemule.MobArena.MobArena
version: '${project.version}'
api-version: 1.13
softdepend: [Multiverse-Core,Towny,Heroes,MagicSpells,Vault]
commands:
ma:

View File

@ -6,7 +6,7 @@ Tank:
armor: diamond_helmet, diamond_chestplate, diamond_leggings, diamond_boots
effects: slow, health_boost
Archer:
items: wood_sword, bow, arrow:256, potion:instant_heal:3, bone
items: wooden_sword, bow, arrow:256, potion:instant_heal:3, bone
armor: leather_helmet, leather_chestplate, leather_leggings, leather_boots
effects: speed
Chemist:

View File

@ -4,4 +4,4 @@ update-notification: true
prefix: '&a[MobArena] '
pet-items:
wolf: bone
ocelot: raw_fish
ocelot: salmon

View File

@ -4,6 +4,6 @@ waves:
'5': dirt:4, gravel:4, stone:4
'10': iron_ingot:10, gold_ingot:8
after:
'7': minecart, storage_minecart, powered_minecart
'13': iron_sword, iron_pickaxe, iron_spade
'7': minecart, chest_minecart, furnace_minecart
'13': iron_sword, iron_pickaxe, iron_shovel
'16': diamond_sword