Simplify the design of Repairable

This commit is contained in:
nossr50 2019-06-21 15:10:43 -07:00
parent 0050a73be8
commit d782d64750
12 changed files with 186 additions and 145 deletions

View File

@ -7,7 +7,7 @@ import ninja.leaping.configurate.objectmapping.serialize.ConfigSerializable;
public class ConfigAdmin { public class ConfigAdmin {
@Setting(value = "Admin-Notifications", comment = "Settings related to admin alerts in mcMMO.") @Setting(value = "Admin-Notifications", comment = "Settings related to admin alerts in mcMMO.")
public ConfigAdminNotifications configAdminNotifications = new ConfigAdminNotifications(); private ConfigAdminNotifications configAdminNotifications = new ConfigAdminNotifications();
public boolean isSendAdminNotifications() { public boolean isSendAdminNotifications() {
return configAdminNotifications.isSendAdminNotifications(); return configAdminNotifications.isSendAdminNotifications();

View File

@ -1,5 +1,6 @@
package com.gmail.nossr50.config.hocon.serializers; package com.gmail.nossr50.config.hocon.serializers;
import com.gmail.nossr50.datatypes.items.CustomItemTarget;
import com.gmail.nossr50.datatypes.permissions.PermissionWrapper; import com.gmail.nossr50.datatypes.permissions.PermissionWrapper;
import com.gmail.nossr50.skills.repair.RepairTransaction; import com.gmail.nossr50.skills.repair.RepairTransaction;
import com.gmail.nossr50.skills.repair.repairables.Repairable; import com.gmail.nossr50.skills.repair.repairables.Repairable;
@ -7,63 +8,75 @@ import com.gmail.nossr50.skills.repair.repairables.RepairableBuilder;
import com.google.common.reflect.TypeToken; import com.google.common.reflect.TypeToken;
import ninja.leaping.configurate.ConfigurationNode; import ninja.leaping.configurate.ConfigurationNode;
import ninja.leaping.configurate.ValueType; import ninja.leaping.configurate.ValueType;
import ninja.leaping.configurate.commented.CommentedConfigurationNode;
import ninja.leaping.configurate.commented.SimpleCommentedConfigurationNode;
import ninja.leaping.configurate.objectmapping.ObjectMappingException; import ninja.leaping.configurate.objectmapping.ObjectMappingException;
import ninja.leaping.configurate.objectmapping.serialize.TypeSerializer; import ninja.leaping.configurate.objectmapping.serialize.TypeSerializer;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
public class RepairableSerializer implements TypeSerializer<Repairable> { public class RepairableSerializer implements TypeSerializer<Repairable> {
private static final String ITEM = "Item"; public static final String REPAIRABLE_ITEM = "Repairable-Item";
private static final String BASE_XP = "XP-Per-Repair"; public static final String MAXIMUM_DURABILITY = "Maximum-Durability";
private static final String REPAIR_TRANSACTION = "Repair-Transaction"; public static final String ITEMS_REQUIRED_TO_REPAIR = "Items-Required-To-Repair";
private static final String STRICT_MATCH_ITEM = "Strict-Match-Item"; public static final String SKILL_LEVEL_REQUIRED_TO_REPAIR = "Skill-Level-Required-To-Repair";
private static final String STRICT_MATCHING_REPAIR_TRANSACTION = "Strict-Matching-Repair-Transaction"; public static final String BASE_XP_REWARD = "Base-XP-Reward";
private static final String REPAIR_COUNT = "Repair-Count"; public static final String BASE_REPAIR_COUNT = "Base-Repair-Count";
// private static final String NBT = "NBT"; public static final String REQUIRED_PERMISSION_NODE = "Required-Permission-Node";
private static final String PERMISSION = "Permission";
private static final String MINIMUM_LEVEL = "Minimum-Level";
@Override @Override
public Repairable deserialize(TypeToken<?> type, ConfigurationNode value) throws ObjectMappingException { public Repairable deserialize(TypeToken<?> type, ConfigurationNode value) throws ObjectMappingException {
ItemStack itemStack = value.getNode(ITEM).getValue(TypeToken.of(ItemStack.class)); /* Necessary fields */
RepairableBuilder builder = new RepairableBuilder(itemStack) CustomItemTarget customItemTarget = value.getNode(REPAIRABLE_ITEM).getValue(TypeToken.of(CustomItemTarget.class));
.repairTransaction(value.getNode(REPAIR_TRANSACTION).getValue(TypeToken.of(RepairTransaction.class))) Short maximumDurability = value.getNode(MAXIMUM_DURABILITY).getValue(TypeToken.of(Short.class));
.strictMatchingItem(value.getNode(STRICT_MATCH_ITEM).getValue(TypeToken.of(Boolean.class))) RepairTransaction repairTransaction = value.getNode(ITEMS_REQUIRED_TO_REPAIR).getValue(TypeToken.of(RepairTransaction.class));
// .strictMatchingRepairTransaction(value.getNode(STRICT_MATCHING_REPAIR_TRANSACTION).getValue(TypeToken.of(Boolean.class)))
.baseXP(value.getNode(BASE_XP).getValue(TypeToken.of(Integer.class)))
.repairCount(value.getNode(REPAIR_COUNT).getValue(TypeToken.of(Integer.class)));
if(value.getNode(MINIMUM_LEVEL).getValueType() != ValueType.NULL) { RepairableBuilder repairableBuilder = new RepairableBuilder(customItemTarget, maximumDurability, repairTransaction);
builder = builder.minLevel(value.getNode(MINIMUM_LEVEL).getValue(TypeToken.of(Integer.class)));
if(value.getNode(SKILL_LEVEL_REQUIRED_TO_REPAIR).getValueType() != ValueType.NULL) {
repairableBuilder.addMinLevel(value.getNode(SKILL_LEVEL_REQUIRED_TO_REPAIR).getInt());
} }
// if(value.getNode(NBT).getValueType() != ValueType.NULL) { if(value.getNode(BASE_XP_REWARD).getValueType() != ValueType.NULL) {
// builder = builder.rawNBT(value.getNode(NBT).getValue(TypeToken.of(RawNBT.class))); repairableBuilder.setBaseXP(value.getNode(BASE_XP_REWARD).getInt());
// }
if(value.getNode(PERMISSION).getValueType() != ValueType.NULL) {
builder = builder.permissionWrapper(value.getNode(PERMISSION).getValue(TypeToken.of(PermissionWrapper.class)));
} }
return builder.build(); if(value.getNode(BASE_REPAIR_COUNT).getValueType() != ValueType.NULL) {
repairableBuilder.setRepairCount(value.getNode(BASE_REPAIR_COUNT).getInt());
}
if(value.getNode(REQUIRED_PERMISSION_NODE).getValueType() != ValueType.NULL) {
repairableBuilder.addPermissionWrapper(value.getNode(REQUIRED_PERMISSION_NODE).getValue(TypeToken.of(PermissionWrapper.class)));
}
return repairableBuilder.build();
} }
@Override @Override
public void serialize(TypeToken<?> type, Repairable obj, ConfigurationNode value) { public void serialize(TypeToken<?> type, Repairable obj, ConfigurationNode value) {
value.getNode(ITEM).setValue(obj.getItem()); value.getNode(REPAIRABLE_ITEM).setValue(obj.getCustomItemTarget());
value.getNode(REPAIR_TRANSACTION).setValue(obj.getRepairTransaction()); value.getNode(MAXIMUM_DURABILITY).setValue(obj.getMaximumDurability());
value.getNode(STRICT_MATCH_ITEM).setValue(obj.isStrictMatchingItem()); value.getNode(ITEMS_REQUIRED_TO_REPAIR).setValue(obj.getRepairTransaction());
// value.getNode(STRICT_MATCHING_REPAIR_TRANSACTION).setValue(obj.isStrictMatchingRepairTransaction());
value.getNode(BASE_XP).setValue(obj.getBaseXP());
value.getNode(REPAIR_COUNT).setValue(obj.getRepairCount());
if(obj.getMinimumLevel() > 0) if(obj.getMinimumLevel() > 0) {
value.getNode(MINIMUM_LEVEL).setValue(obj.getMinimumLevel()); value.getNode(SKILL_LEVEL_REQUIRED_TO_REPAIR).setValue(obj.getMinimumLevel());
}
// if(obj.hasNBT()) if(obj.getBaseXP() != 0) {
// value.getNode(NBT).setValue(obj.getRawNBT()); value.getNode(BASE_XP_REWARD).setValue(obj.getBaseXP());
SerializerUtil.addCommentIfCompatible(value.getNode(BASE_XP_REWARD), "The minimum amount of XP to reward a player when they repair this item.");
}
if(obj.hasPermission()) if(obj.getRepairCount() != 0) {
value.getNode(PERMISSION).setValue(obj.getPermissionWrapper()); value.getNode(BASE_REPAIR_COUNT).setValue(obj.getRepairCount());
SerializerUtil.addCommentIfCompatible(value.getNode(BASE_REPAIR_COUNT), "How many times it should take a player to repair this item from fully damaged to brand new without any skill in Repair." +
"\nThis value is used in calculating how much damage to remove from an item, typically you want this to be at least equal to the number of mats used to craft the item.");
}
if(obj.getPermissionWrapper() != null) {
value.getNode(REQUIRED_PERMISSION_NODE).setValue(obj.getPermissionWrapper());
SerializerUtil.addCommentIfCompatible(value.getNode(REQUIRED_PERMISSION_NODE), "A custom permission node required to repair this item." +
"\nThis setting is optional.");
}
} }
} }

View File

@ -0,0 +1,19 @@
package com.gmail.nossr50.config.hocon.serializers;
import ninja.leaping.configurate.ConfigurationNode;
import ninja.leaping.configurate.commented.CommentedConfigurationNode;
public class SerializerUtil {
/**
* Adds a comment to a Configuration node if its possible
* @param configurationNode target configuration node
* @param comment desired comment
*/
public static void addCommentIfCompatible(ConfigurationNode configurationNode, String comment) {
if(configurationNode instanceof CommentedConfigurationNode) {
CommentedConfigurationNode node = (CommentedConfigurationNode) configurationNode;
node.setComment(comment);
}
}
}

View File

@ -1,6 +1,9 @@
package com.gmail.nossr50.datatypes.items; package com.gmail.nossr50.datatypes.items;
import com.gmail.nossr50.mcMMO;
import java.util.HashSet; import java.util.HashSet;
import java.util.Objects;
/** /**
* This type contains data and rules which govern equating equivalency between one item and another in Minecraft. * This type contains data and rules which govern equating equivalency between one item and another in Minecraft.
@ -56,7 +59,26 @@ public class CustomItemTarget implements CustomItemMatching {
public boolean isMatch(MMOItem otherItem) { public boolean isMatch(MMOItem otherItem) {
//First compare the basic things that need to match between each item //First compare the basic things that need to match between each item
if(item.equals(otherItem)) { if(item.equals(otherItem)) {
for(ItemMatchProperty itemMatchProperty : itemMatchProperties) {
if(!mcMMO.getNbtManager().hasNBT(otherItem.getRawNBT().getNbtData(), itemMatchProperty.getNbtData()))
return false;
}
return true;
} }
return false;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof CustomItemTarget)) return false;
CustomItemTarget that = (CustomItemTarget) o;
return getItem().equals(that.getItem()) &&
getItemMatchProperties().equals(that.getItemMatchProperties());
}
@Override
public int hashCode() {
return Objects.hash(getItem(), getItemMatchProperties());
} }
} }

View File

@ -1,5 +1,9 @@
package com.gmail.nossr50.datatypes.items; package com.gmail.nossr50.datatypes.items;
import net.minecraft.server.v1_13_R2.NBTTagCompound;
import java.util.Objects;
/** /**
* Represents a property of an item which is used in strict matching * Represents a property of an item which is used in strict matching
* Typically this represents and NBT field and its value * Typically this represents and NBT field and its value
@ -7,20 +11,20 @@ package com.gmail.nossr50.datatypes.items;
*/ */
public class ItemMatchProperty { public class ItemMatchProperty {
final private Object propertyValue; final private NBTTagCompound nbtData;
final private String nbtID; final private String nbtID;
public ItemMatchProperty(Object propertyValue, String nbtID) { public ItemMatchProperty(String nbtID, NBTTagCompound nbtData) {
this.propertyValue = propertyValue; this.nbtData = nbtData;
this.nbtID = nbtID; this.nbtID = nbtID;
} }
/** /**
* The expected value for this NBT entry * The expected value for this NBT
* @return the expected value for this NBT entry * @return the expected value for this NBT entry
*/ */
public Object getPropertyValue() { public NBTTagCompound getNbtData() {
return propertyValue; return nbtData;
} }
/** /**
@ -30,4 +34,18 @@ public class ItemMatchProperty {
public String getID() { public String getID() {
return nbtID; return nbtID;
} }
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof ItemMatchProperty)) return false;
ItemMatchProperty that = (ItemMatchProperty) o;
return getNbtData().equals(that.getNbtData()) &&
nbtID.equals(that.nbtID);
}
@Override
public int hashCode() {
return Objects.hash(getNbtData(), nbtID);
}
} }

View File

@ -33,7 +33,7 @@ public class ItemWildcards {
return itemTargets.size(); return itemTargets.size();
} }
public HashSet<ItemStack> getItemTargets() { public HashSet<CustomItemTarget> getItemTargets() {
return itemTargets; return itemTargets;
} }

View File

@ -31,6 +31,7 @@ import com.gmail.nossr50.util.blockmeta.chunkmeta.ChunkManager;
import com.gmail.nossr50.util.blockmeta.chunkmeta.ChunkManagerFactory; import com.gmail.nossr50.util.blockmeta.chunkmeta.ChunkManagerFactory;
import com.gmail.nossr50.util.commands.CommandRegistrationManager; import com.gmail.nossr50.util.commands.CommandRegistrationManager;
import com.gmail.nossr50.util.experience.FormulaManager; import com.gmail.nossr50.util.experience.FormulaManager;
import com.gmail.nossr50.util.nbt.NBTManager;
import com.gmail.nossr50.util.player.NotificationManager; import com.gmail.nossr50.util.player.NotificationManager;
import com.gmail.nossr50.util.player.PlayerLevelUtils; import com.gmail.nossr50.util.player.PlayerLevelUtils;
import com.gmail.nossr50.util.player.UserManager; import com.gmail.nossr50.util.player.UserManager;
@ -65,6 +66,7 @@ public class mcMMO extends JavaPlugin {
private static PlayerLevelUtils playerLevelUtils; private static PlayerLevelUtils playerLevelUtils;
private static NotificationManager notificationManager; private static NotificationManager notificationManager;
private static CommandRegistrationManager commandRegistrationManager; private static CommandRegistrationManager commandRegistrationManager;
private static NBTManager nbtManager;
/* File Paths */ /* File Paths */
private static String mainDirectory; private static String mainDirectory;
@ -153,6 +155,8 @@ public class mcMMO extends JavaPlugin {
commandRegistrationManager = new CommandRegistrationManager(this); commandRegistrationManager = new CommandRegistrationManager(this);
commandRegistrationManager.registerCommands(); commandRegistrationManager.registerCommands();
nbtManager = new NBTManager();
placeStore = ChunkManagerFactory.getChunkManager(); // Get our ChunkletManager placeStore = ChunkManagerFactory.getChunkManager(); // Get our ChunkletManager
if (getConfigManager().getConfigParty().getPTP().isPtpWorldBasedPermissions()) { if (getConfigManager().getConfigParty().getPTP().isPtpWorldBasedPermissions()) {
@ -318,6 +322,10 @@ public class mcMMO extends JavaPlugin {
return databaseManager; return databaseManager;
} }
public static NBTManager getNbtManager() {
return nbtManager;
}
@Deprecated @Deprecated
public static void setDatabaseManager(DatabaseManager newDatabaseManager) { public static void setDatabaseManager(DatabaseManager newDatabaseManager) {
databaseManager = newDatabaseManager; databaseManager = newDatabaseManager;

View File

@ -1,6 +1,8 @@
package com.gmail.nossr50.skills.repair; package com.gmail.nossr50.skills.repair;
import org.bukkit.inventory.PlayerInventory;
import java.util.HashSet; import java.util.HashSet;
/** /**
@ -18,21 +20,25 @@ import java.util.HashSet;
* to pay that part of the RepairTransaction * to pay that part of the RepairTransaction
*/ */
public class RepairTransaction { public class RepairTransaction {
private HashSet<RepairCost> repairItems; private HashSet<RepairCost> repairCosts;
public RepairTransaction() { public RepairTransaction() {
repairItems = new HashSet<>(); repairCosts = new HashSet<>();
} }
public void addRepairCost(RepairCost repairCost) { public void addRepairCost(RepairCost repairCost) {
repairItems.add(repairCost); repairCosts.add(repairCost);
} }
public HashSet<RepairCost> getRepairItems() { public HashSet<RepairCost> getRepairCosts() {
return repairItems; return repairCosts;
} }
public void setRepairItems(HashSet<RepairCost> repairItems) { public void setRepairCosts(HashSet<RepairCost> repairItems) {
this.repairItems = repairItems; this.repairCosts = repairItems;
}
public boolean canPayRepairCosts(PlayerInventory playerInventory) {
return true;
} }
} }

View File

@ -1,37 +1,32 @@
package com.gmail.nossr50.skills.repair.repairables; package com.gmail.nossr50.skills.repair.repairables;
import com.gmail.nossr50.datatypes.items.CustomItemTarget;
import com.gmail.nossr50.datatypes.permissions.PermissionWrapper; import com.gmail.nossr50.datatypes.permissions.PermissionWrapper;
import com.gmail.nossr50.skills.repair.RepairTransaction; import com.gmail.nossr50.skills.repair.RepairTransaction;
import com.gmail.nossr50.util.nbt.RawNBT; import com.gmail.nossr50.util.nbt.RawNBT;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
public class Repairable { public class Repairable {
private final ItemStack item; private int minimumLevel;
private int minimumLevel = 0;
private short maximumDurability; private short maximumDurability;
private RepairTransaction repairTransaction; private RepairTransaction repairTransaction;
private boolean strictMatchingItem = false; private int baseXP;
// private boolean strictMatchingRepairTransaction = false; private CustomItemTarget customItemTarget;
private int baseXP = 0; private int repairCount;
private RawNBT rawNBT;
private int repairCount = 1;
private PermissionWrapper permissionWrapper; private PermissionWrapper permissionWrapper;
private boolean hasPermission = false; private boolean hasPermission = false;
private boolean hasNBT = false;
public Repairable(ItemStack item, int minimumLevel, short maximumDurability, RepairTransaction repairTransaction, boolean strictMatchingItem, int baseXP, int repairCount) { public Repairable(CustomItemTarget customItemTarget, int minimumLevel, short maximumDurability, RepairTransaction repairTransaction, int baseXP, int repairCount, PermissionWrapper permissionWrapper) {
this.item = item;
this.minimumLevel = minimumLevel; this.minimumLevel = minimumLevel;
this.maximumDurability = maximumDurability; this.maximumDurability = maximumDurability;
this.repairTransaction = repairTransaction; this.repairTransaction = repairTransaction;
this.strictMatchingItem = strictMatchingItem;
// this.strictMatchingRepairTransaction = strictMatchingRepairTransaction;
this.baseXP = baseXP; this.baseXP = baseXP;
this.customItemTarget = customItemTarget;
this.repairCount = repairCount; this.repairCount = repairCount;
} this.permissionWrapper = permissionWrapper;
public ItemStack getItem() { if(permissionWrapper != null)
return item; hasPermission = true;
} }
public int getMinimumLevel() { public int getMinimumLevel() {
@ -58,22 +53,6 @@ public class Repairable {
this.repairTransaction = repairTransaction; this.repairTransaction = repairTransaction;
} }
public boolean isStrictMatchingItem() {
return strictMatchingItem;
}
public void setStrictMatchingItem(boolean strictMatchingItem) {
this.strictMatchingItem = strictMatchingItem;
}
// public boolean isStrictMatchingRepairTransaction() {
// return strictMatchingRepairTransaction;
// }
//
// public void setStrictMatchingRepairTransaction(boolean strictMatchingRepairTransaction) {
// this.strictMatchingRepairTransaction = strictMatchingRepairTransaction;
// }
public int getBaseXP() { public int getBaseXP() {
return baseXP; return baseXP;
} }
@ -82,13 +61,12 @@ public class Repairable {
this.baseXP = baseXP; this.baseXP = baseXP;
} }
public RawNBT getRawNBT() { public CustomItemTarget getCustomItemTarget() {
return rawNBT; return customItemTarget;
} }
public void setRawNBT(RawNBT rawNBT) { public void setCustomItemTarget(CustomItemTarget customItemTarget) {
this.rawNBT = rawNBT; this.customItemTarget = customItemTarget;
hasNBT = true;
} }
public int getRepairCount() { public int getRepairCount() {
@ -105,10 +83,9 @@ public class Repairable {
public void setPermissionWrapper(PermissionWrapper permissionWrapper) { public void setPermissionWrapper(PermissionWrapper permissionWrapper) {
this.permissionWrapper = permissionWrapper; this.permissionWrapper = permissionWrapper;
hasPermission = true;
} }
public boolean hasPermission() { public boolean hasPermissionNode() {
return hasPermission; return hasPermission;
} }
@ -116,11 +93,4 @@ public class Repairable {
this.hasPermission = hasPermission; this.hasPermission = hasPermission;
} }
public boolean hasNBT() {
return hasNBT;
}
public void setHasNBT(boolean hasNBT) {
this.hasNBT = hasNBT;
}
} }

View File

@ -1,5 +1,6 @@
package com.gmail.nossr50.skills.repair.repairables; package com.gmail.nossr50.skills.repair.repairables;
import com.gmail.nossr50.datatypes.items.CustomItemTarget;
import com.gmail.nossr50.datatypes.permissions.PermissionWrapper; import com.gmail.nossr50.datatypes.permissions.PermissionWrapper;
import com.gmail.nossr50.skills.repair.RepairTransaction; import com.gmail.nossr50.skills.repair.RepairTransaction;
import com.gmail.nossr50.util.nbt.RawNBT; import com.gmail.nossr50.util.nbt.RawNBT;
@ -7,63 +8,46 @@ import org.bukkit.inventory.ItemStack;
public class RepairableBuilder { public class RepairableBuilder {
private final ItemStack item; private int minimumLevel;
private int minimumLevel = 0;
private short maximumDurability; private short maximumDurability;
private RepairTransaction repairTransaction; private RepairTransaction repairTransaction;
private boolean strictMatchingItem = false; private int baseXP;
// private boolean strictMatchingRepairTransaction = false; private CustomItemTarget customItemTarget;
private int baseXP = 0; private int repairCount;
private RawNBT rawNBT;
private int repairCount = 1;
private PermissionWrapper permissionWrapper; private PermissionWrapper permissionWrapper;
public RepairableBuilder(ItemStack item) { public RepairableBuilder(CustomItemTarget customItemTarget, Short maximumDurability, RepairTransaction repairTransaction) {
this.item = item; this.customItemTarget = customItemTarget;
this.maximumDurability = item.getType().getMaxDurability(); this.maximumDurability = maximumDurability;
this.repairTransaction = repairTransaction;
} }
public RepairableBuilder minLevel(Integer minimumLevel) { public RepairableBuilder addMinLevel(Integer minimumLevel) {
this.minimumLevel = minimumLevel; this.minimumLevel = minimumLevel;
return this; return this;
} }
public RepairableBuilder maximumDurability(Short maximumDurability) { public RepairableBuilder setMaximumDurability(Short maximumDurability) {
this.maximumDurability = maximumDurability; this.maximumDurability = maximumDurability;
return this; return this;
} }
public RepairableBuilder repairTransaction(RepairTransaction repairTransaction) { public RepairableBuilder setRepairTransaction(RepairTransaction repairTransaction) {
this.repairTransaction = repairTransaction; this.repairTransaction = repairTransaction;
return this; return this;
} }
public RepairableBuilder strictMatchingItem(Boolean strictMatchingItem) { public RepairableBuilder setBaseXP(Integer baseXP) {
this.strictMatchingItem = strictMatchingItem;
return this;
}
// public RepairableBuilder strictMatchingRepairTransaction(Boolean strictMatchingRepairTransaction) {
// this.strictMatchingRepairTransaction = strictMatchingRepairTransaction;
// return this;
// }
public RepairableBuilder baseXP(Integer baseXP) {
this.baseXP = baseXP; this.baseXP = baseXP;
return this; return this;
} }
public RepairableBuilder rawNBT(RawNBT rawNBT) { public RepairableBuilder setRepairCount(Integer repairCount) {
this.rawNBT = rawNBT;
return this;
}
public RepairableBuilder repairCount(Integer repairCount) {
this.repairCount = repairCount; this.repairCount = repairCount;
return this; return this;
} }
public RepairableBuilder permissionWrapper(PermissionWrapper permissionWrapper) { public RepairableBuilder addPermissionWrapper(PermissionWrapper permissionWrapper) {
this.permissionWrapper = permissionWrapper; this.permissionWrapper = permissionWrapper;
return this; return this;
} }
@ -73,16 +57,8 @@ public class RepairableBuilder {
} }
private Repairable makeRepairable() { private Repairable makeRepairable() {
Repairable repairable = new Repairable(item, minimumLevel, maximumDurability, repairTransaction, Repairable repairable = new Repairable(customItemTarget, minimumLevel, maximumDurability, repairTransaction,
strictMatchingItem, baseXP, repairCount); baseXP, repairCount, permissionWrapper);
if(permissionWrapper != null) {
repairable.setPermissionWrapper(permissionWrapper);
}
if(rawNBT != null) {
repairable.setRawNBT(rawNBT);
}
return repairable; return repairable;
} }

View File

@ -9,8 +9,6 @@ import org.bukkit.craftbukkit.v1_13_R2.inventory.CraftItemStack;
import org.bukkit.craftbukkit.v1_13_R2.util.CraftNBTTagConfigSerializer; import org.bukkit.craftbukkit.v1_13_R2.util.CraftNBTTagConfigSerializer;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
public class NBTManager { public class NBTManager {
private static final String CRAFT_META_ITEM_CLASS_PATH = "org.bukkit.craftbukkit.inventory.CraftMetaItem"; private static final String CRAFT_META_ITEM_CLASS_PATH = "org.bukkit.craftbukkit.inventory.CraftMetaItem";
@ -47,4 +45,9 @@ public class NBTManager {
} }
} }
public boolean hasNBT(NBTTagCompound root, NBTTagCompound nbtData) {
//TODO: Implement this
return false;
}
} }

View File

@ -1,5 +1,7 @@
package com.gmail.nossr50.util.nbt; package com.gmail.nossr50.util.nbt;
import net.minecraft.server.v1_13_R2.NBTTagCompound;
/** /**
* A simple class that acts as a container for raw NBT data * A simple class that acts as a container for raw NBT data
* NBT data will be constructed from the raw NBT string using server internals * NBT data will be constructed from the raw NBT string using server internals
@ -10,13 +12,14 @@ package com.gmail.nossr50.util.nbt;
* 1) Read partial or complete NBT from the config file for an item * 1) Read partial or complete NBT from the config file for an item
* 2) Check an items NBT tree for this NBT data during runtime once transformed * 2) Check an items NBT tree for this NBT data during runtime once transformed
*/ */
public class RawNBT<T> { public class RawNBT {
private String nbtContents; private String nbtContents;
private T nbtTree; //Will be constructed using server internals to make matching NBT easier private NBTTagCompound nbtData; //Will be constructed using server internals to make matching NBT easier
public RawNBT(String nbtContents, T nbtTree) {
public RawNBT(String nbtContents, NBTTagCompound nbtData) {
this.nbtContents = nbtContents; this.nbtContents = nbtContents;
NBTManager this.nbtData = nbtData;
} }
public String getNbtContents() { public String getNbtContents() {
@ -27,4 +30,7 @@ public class RawNBT<T> {
this.nbtContents = nbtContents; this.nbtContents = nbtContents;
} }
public NBTTagCompound getNbtData() {
return nbtData;
}
} }