diff --git a/pom.xml b/pom.xml index 860e1323..358796a7 100644 --- a/pom.xml +++ b/pom.xml @@ -48,10 +48,15 @@ io.github.dre2n.commons io.github.dre2n.dungeonsxl + + io.github.dre2n.caliburn + io.github.dre2n.dungeonsxl.util.caliburn + io.github.dre2n:commons + io.github.dre2n:caliburn @@ -78,6 +83,16 @@ commons 1.0-SNAPSHOT + + io.github.dre2n + caliburn + 0.1.4 + + + io.github.dre2n + itemsxl + 0.1.4 + io.github.dre2n commandsxl @@ -86,7 +101,7 @@ net.citizensnpcs citizensapi - 2.0.17-SNAPSHOT + 2.0.18-SNAPSHOT provided diff --git a/src/main/java/io/github/dre2n/dungeonsxl/DungeonsXL.java b/src/main/java/io/github/dre2n/dungeonsxl/DungeonsXL.java index 9a1ebf64..eb33550c 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/DungeonsXL.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/DungeonsXL.java @@ -16,6 +16,7 @@ */ package io.github.dre2n.dungeonsxl; +import io.github.dre2n.caliburn.CaliburnAPI; import io.github.dre2n.commons.command.BRCommands; import io.github.dre2n.commons.compatibility.Internals; import io.github.dre2n.commons.config.MessageConfig; @@ -53,6 +54,7 @@ import io.github.dre2n.dungeonsxl.trigger.TriggerTypes; import io.github.dre2n.dungeonsxl.world.EditWorld; import io.github.dre2n.dungeonsxl.world.GameWorld; +import io.github.dre2n.itemsxl.ItemsXL; import java.io.File; import java.util.List; import java.util.concurrent.CopyOnWriteArrayList; @@ -77,6 +79,8 @@ public class DungeonsXL extends BRPlugin { public static File MOBS; public static File SIGNS; + private CaliburnAPI caliburn; + private GlobalData globalData; private MainConfig mainConfig; private MessageConfig messageConfig; @@ -304,6 +308,24 @@ public static DungeonsXL getInstance() { return instance; } + /** + * @return the loaded instance of CaliburnAPI + */ + public CaliburnAPI getCaliburnAPI() { + return caliburn; + } + + /** + * load / reload a new instance of CaliburnAPI + */ + public void loadCaliburnAPI() { + if (manager.isPluginEnabled("ItemsXL")) { + this.caliburn = ItemsXL.getInstance().getAPI(); + } else { + this.caliburn = new CaliburnAPI(this); + } + } + /** * @return the loaded instance of GlobalData */ diff --git a/src/main/java/io/github/dre2n/dungeonsxl/config/PlayerData.java b/src/main/java/io/github/dre2n/dungeonsxl/config/PlayerData.java index 30ef52bf..9d238163 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/config/PlayerData.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/config/PlayerData.java @@ -23,8 +23,6 @@ import java.io.IOException; import java.util.HashMap; import java.util.Map; -import java.util.logging.Level; -import java.util.logging.Logger; /** * @author Daniel Saukel diff --git a/src/main/java/io/github/dre2n/dungeonsxl/config/WorldConfig.java b/src/main/java/io/github/dre2n/dungeonsxl/config/WorldConfig.java index 0f3c9eb9..aa19fe9c 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/config/WorldConfig.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/config/WorldConfig.java @@ -16,6 +16,8 @@ */ package io.github.dre2n.dungeonsxl.config; +import io.github.dre2n.commons.compatibility.CompatibilityHandler; +import io.github.dre2n.commons.compatibility.Version; import io.github.dre2n.commons.util.EnumUtil; import io.github.dre2n.commons.util.NumberUtil; import io.github.dre2n.dungeonsxl.DungeonsXL; @@ -25,6 +27,7 @@ import io.github.dre2n.dungeonsxl.requirement.FeeMoneyRequirement; import io.github.dre2n.dungeonsxl.requirement.GroupSizeRequirement; import io.github.dre2n.dungeonsxl.requirement.Requirement; +import io.github.dre2n.dungeonsxl.util.DeserialisazionUtil; import java.io.File; import java.io.IOException; import java.util.ArrayList; @@ -32,10 +35,10 @@ import java.util.Set; import java.util.concurrent.CopyOnWriteArrayList; import org.bukkit.GameMode; -import org.bukkit.Material; import org.bukkit.configuration.ConfigurationSection; import org.bukkit.configuration.file.FileConfiguration; import org.bukkit.configuration.file.YamlConfiguration; +import org.bukkit.inventory.ItemStack; /** * @author Frank Baumann, Milan Albrecht, Daniel Saukel @@ -43,6 +46,7 @@ public class WorldConfig extends GameRules { DungeonsXL plugin = DungeonsXL.getInstance(); + CompatibilityHandler compat = CompatibilityHandler.getInstance(); private File file; @@ -79,13 +83,10 @@ public void load(ConfigurationSection configFile) { /* Secure Objects */ if (configFile.contains("secureObjects")) { List secureObjectList = configFile.getStringList("secureObjects"); - for (String id : secureObjectList) { - if (Material.getMaterial(NumberUtil.parseInt(id)) != null) { - secureObjects.add(Material.getMaterial(NumberUtil.parseInt(id))); - - } else if (Material.getMaterial(id) != null) { - secureObjects.add(Material.getMaterial(id)); - } + if (Version.andHigher(Version.MC1_9).contains(compat.getVersion())) { + secureObjects = plugin.getCaliburnAPI().getItems().deserializeStackList(secureObjectList); + } else { + secureObjects = DeserialisazionUtil.deserializeStackList(secureObjectList); } } @@ -244,14 +245,13 @@ public void save() { configFile.set("message." + msgs, this.msgs.get(msgs)); } - // Secure Objects - CopyOnWriteArrayList secureObjectsids = new CopyOnWriteArrayList<>(); + List secureObjectIds = new ArrayList<>(); - for (Material mat : secureObjects) { - secureObjectsids.add(mat.getId()); + for (ItemStack item : secureObjects) { + secureObjectIds.add(plugin.getCaliburnAPI().getItems().getCustomItemId(item)); } - configFile.set("secureObjects", secureObjectsids); + configFile.set("secureObjects", secureObjectIds); // Invited Players configFile.set("invitedPlayers", invitedPlayers); diff --git a/src/main/java/io/github/dre2n/dungeonsxl/game/GameRules.java b/src/main/java/io/github/dre2n/dungeonsxl/game/GameRules.java index b79c2917..686bf150 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/game/GameRules.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/game/GameRules.java @@ -16,6 +16,7 @@ */ package io.github.dre2n.dungeonsxl.game; +import io.github.dre2n.caliburn.item.UniversalItem; import io.github.dre2n.dungeonsxl.DungeonsXL; import io.github.dre2n.dungeonsxl.requirement.Requirement; import io.github.dre2n.dungeonsxl.reward.Reward; @@ -24,7 +25,7 @@ import java.util.List; import java.util.Map; import org.bukkit.GameMode; -import org.bukkit.Material; +import org.bukkit.inventory.ItemStack; /** * @author Daniel Saukel @@ -109,7 +110,7 @@ public class GameRules { /* Misc */ protected Map msgs; - protected List secureObjects; + protected List secureObjects; /* Getters and setters */ // keepInventory @@ -315,7 +316,7 @@ public void setMsg(String msg, int id) { /** * @return the objects to get passed to another player of the group when this player leaves */ - public List getSecureObjects() { + public List getSecureObjects() { return secureObjects; } diff --git a/src/main/java/io/github/dre2n/dungeonsxl/listener/PlayerListener.java b/src/main/java/io/github/dre2n/dungeonsxl/listener/PlayerListener.java index 8683ec54..e01b5965 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/listener/PlayerListener.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/listener/PlayerListener.java @@ -350,8 +350,8 @@ public void onDropItem(PlayerDropItemEvent event) { Game game = Game.getByWorld(gamePlayer.getWorld()); - for (Material material : game.getRules().getSecureObjects()) { - if (material == event.getItemDrop().getItemStack().getType()) { + for (ItemStack item : game.getRules().getSecureObjects()) { + if (event.getItemDrop().getItemStack().isSimilar(item)) { event.setCancelled(true); MessageUtil.sendMessage(player, DMessages.ERROR_DROP.getMessage()); return; diff --git a/src/main/java/io/github/dre2n/dungeonsxl/listener/WorldListener.java b/src/main/java/io/github/dre2n/dungeonsxl/listener/WorldListener.java index 8804bfef..e902336e 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/listener/WorldListener.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/listener/WorldListener.java @@ -18,7 +18,6 @@ import io.github.dre2n.dungeonsxl.world.EditWorld; import io.github.dre2n.dungeonsxl.world.GameWorld; -import org.bukkit.World; import org.bukkit.event.EventHandler; import org.bukkit.event.EventPriority; import org.bukkit.event.Listener; diff --git a/src/main/java/io/github/dre2n/dungeonsxl/mob/DMobType.java b/src/main/java/io/github/dre2n/dungeonsxl/mob/DMobType.java index 3cc21341..3b4a837d 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/mob/DMobType.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/mob/DMobType.java @@ -19,7 +19,6 @@ import io.github.dre2n.commons.util.EnumUtil; import io.github.dre2n.commons.util.NumberUtil; import io.github.dre2n.commons.util.messageutil.MessageUtil; -import io.github.dre2n.dungeonsxl.DungeonsXL; import io.github.dre2n.dungeonsxl.config.DMessages; import io.github.dre2n.dungeonsxl.world.GameWorld; import java.io.File; @@ -46,8 +45,6 @@ */ public class DMobType { - static DungeonsXL plugin = DungeonsXL.getInstance(); - private String name; private EntityType type; @@ -75,7 +72,7 @@ public DMobType(File file) { /** * @param name - * the name of the Announcer + * the name of the DMobType * @param config * the config that stores the information */ @@ -178,7 +175,7 @@ public DMobType(String name, FileConfiguration config) { /* Add Item to the drops map */ item.setItemMeta(itemMeta); - getDrops().put(item, chance); + drops.put(item, chance); } } } diff --git a/src/main/java/io/github/dre2n/dungeonsxl/player/DClass.java b/src/main/java/io/github/dre2n/dungeonsxl/player/DClass.java index 176671ec..aec84025 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/player/DClass.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/player/DClass.java @@ -16,7 +16,10 @@ */ package io.github.dre2n.dungeonsxl.player; -import io.github.dre2n.dungeonsxl.util.ItemUtil; +import io.github.dre2n.commons.compatibility.CompatibilityHandler; +import io.github.dre2n.commons.compatibility.Version; +import io.github.dre2n.dungeonsxl.DungeonsXL; +import io.github.dre2n.dungeonsxl.util.DeserialisazionUtil; import java.io.File; import java.util.ArrayList; import java.util.List; @@ -29,6 +32,9 @@ */ public class DClass { + DungeonsXL plugin = DungeonsXL.getInstance(); + CompatibilityHandler compat = CompatibilityHandler.getInstance(); + private String name; private List items = new ArrayList<>(); @@ -42,7 +48,13 @@ public DClass(String name, FileConfiguration config) { this.name = name; if (config.contains("items")) { - items = ItemUtil.fromConfig(config); + List itemList = config.getStringList("items"); + + if (Version.andHigher(Version.MC1_9).contains(compat.getVersion())) { + items = plugin.getCaliburnAPI().getItems().deserializeStackList(itemList); + } else { + items = DeserialisazionUtil.deserializeStackList(itemList); + } } if (config.contains("dog")) { diff --git a/src/main/java/io/github/dre2n/dungeonsxl/sign/ClassesSign.java b/src/main/java/io/github/dre2n/dungeonsxl/sign/ClassesSign.java index dbd9c3d3..b8f886d8 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/sign/ClassesSign.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/sign/ClassesSign.java @@ -19,7 +19,6 @@ import io.github.dre2n.dungeonsxl.player.DClass; import io.github.dre2n.dungeonsxl.world.GameWorld; import org.bukkit.ChatColor; -import org.bukkit.Material; import org.bukkit.block.Sign; /** diff --git a/src/main/java/io/github/dre2n/dungeonsxl/util/ItemUtil.java b/src/main/java/io/github/dre2n/dungeonsxl/util/DeserialisazionUtil.java similarity index 86% rename from src/main/java/io/github/dre2n/dungeonsxl/util/ItemUtil.java rename to src/main/java/io/github/dre2n/dungeonsxl/util/DeserialisazionUtil.java index 8e7bb4d2..95215d00 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/util/ItemUtil.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/util/DeserialisazionUtil.java @@ -17,21 +17,21 @@ package io.github.dre2n.dungeonsxl.util; import io.github.dre2n.commons.util.NumberUtil; +import java.util.ArrayList; import java.util.List; -import java.util.concurrent.CopyOnWriteArrayList; -import org.bukkit.configuration.ConfigurationSection; import org.bukkit.enchantments.Enchantment; import org.bukkit.inventory.ItemStack; /** + * Deprecated deserialization methods for compatibility with 1.7.8-1.8.x + * * @author Frank Baumann, Daniel Saukel */ @Deprecated -public class ItemUtil { +public class DeserialisazionUtil { - public static List fromConfig(ConfigurationSection configSectionClasses) { - List items = configSectionClasses.getStringList("items"); - CopyOnWriteArrayList itemStacks = new CopyOnWriteArrayList<>(); + public static List deserializeStackList(List items) { + List itemStacks = new ArrayList<>(); for (String item : items) { String[] itemSplit = item.split(","); diff --git a/src/main/java/io/github/dre2n/dungeonsxl/world/GameWorld.java b/src/main/java/io/github/dre2n/dungeonsxl/world/GameWorld.java index 0906da81..a5d9b0f1 100644 --- a/src/main/java/io/github/dre2n/dungeonsxl/world/GameWorld.java +++ b/src/main/java/io/github/dre2n/dungeonsxl/world/GameWorld.java @@ -44,7 +44,6 @@ import org.bukkit.Bukkit; import org.bukkit.Chunk; import org.bukkit.Location; -import org.bukkit.Material; import org.bukkit.World; import org.bukkit.WorldCreator; import org.bukkit.block.Block; @@ -53,6 +52,7 @@ import org.bukkit.entity.EntityType; import org.bukkit.entity.LivingEntity; import org.bukkit.entity.Spider; +import org.bukkit.inventory.ItemStack; /** * @author Frank Baumann, Milan Albrecht, Daniel Saukel @@ -71,7 +71,7 @@ public class GameWorld { private Location locStart; private boolean isPlaying = false; private int id; - private List secureObjects = new ArrayList<>(); + private List secureObjects = new ArrayList<>(); private CopyOnWriteArrayList loadedChunks = new CopyOnWriteArrayList<>(); private CopyOnWriteArrayList signClass = new CopyOnWriteArrayList<>(); @@ -244,7 +244,7 @@ public void setId(int id) { /** * @return the secureObjects */ - public List getSecureObjects() { + public List getSecureObjects() { return secureObjects; } @@ -252,7 +252,7 @@ public List getSecureObjects() { * @param secureObjects * the secureObjects to set */ - public void setSecureObjects(List secureObjects) { + public void setSecureObjects(List secureObjects) { this.secureObjects = secureObjects; } @@ -539,10 +539,7 @@ public void load(String name) { /* Statics */ public static GameWorld getByWorld(World world) { for (GameWorld gameWorld : plugin.getGameWorlds()) { - if (gameWorld.getWorld() == null) { - continue; - - } else if (gameWorld.getWorld().equals(world)) { + if (gameWorld.getWorld() != null && gameWorld.getWorld().equals(world)) { return gameWorld; } } diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml index 04f8c93f..83bb3d74 100644 --- a/src/main/resources/plugin.yml +++ b/src/main/resources/plugin.yml @@ -4,7 +4,7 @@ version: ${project.version} authors: [Frank Baumann, Milan Albrecht, Tobias Schmitz, Daniel Saukel] description: ${project.description} website: ${project.url} -softdepend: [BlueRoseCommons, CommandsXL, Vault, CustomMobs, InsaneMobs, MythicMobs] +softdepend: [BlueRoseCommons, CommandsXL, ItemsXL, Vault, CustomMobs, InsaneMobs, MythicMobs] commands: dungeonsxl: description: Reference command for DungeonsXL.