mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2024-11-22 21:26:46 +01:00
Also try to count recipe ingredients regardless of repairMaterial
when the normal counting and the config value result in 0 Fixes #1484
This commit is contained in:
parent
57dfa00541
commit
1ca53da0e2
@ -116,21 +116,25 @@ public class Repair {
|
|||||||
return getRepairAndSalvageQuantities(inHand, getSalvagedItem(inHand), (byte) -1);
|
return getRepairAndSalvageQuantities(inHand, getSalvagedItem(inHand), (byte) -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static int getRepairAndSalvageQuantities(ItemStack item) {
|
||||||
|
return getRepairAndSalvageQuantities(item, null, (byte) -1);
|
||||||
|
}
|
||||||
|
|
||||||
public static int getRepairAndSalvageQuantities(ItemStack item, Material repairMaterial, byte repairMetadata) {
|
public static int getRepairAndSalvageQuantities(ItemStack item, Material repairMaterial, byte repairMetadata) {
|
||||||
int quantity = 0;
|
int quantity = 0;
|
||||||
MaterialData repairData = new MaterialData(repairMaterial, repairMetadata);
|
MaterialData repairData = repairMaterial != null ? new MaterialData(repairMaterial, repairMetadata) : null;
|
||||||
Recipe recipe = mcMMO.p.getServer().getRecipesFor(item).get(0);
|
Recipe recipe = mcMMO.p.getServer().getRecipesFor(item).get(0);
|
||||||
|
|
||||||
if (recipe instanceof ShapelessRecipe) {
|
if (recipe instanceof ShapelessRecipe) {
|
||||||
for (ItemStack ingredient : ((ShapelessRecipe) recipe).getIngredientList()) {
|
for (ItemStack ingredient : ((ShapelessRecipe) recipe).getIngredientList()) {
|
||||||
if (ingredient != null && ingredient.getType() == repairMaterial && (repairMetadata == -1 || ingredient.getData() == repairData)) {
|
if (ingredient != null && (repairMaterial == null || ingredient.getType() == repairMaterial) && (repairMetadata == -1 || ingredient.getData() == repairData)) {
|
||||||
quantity += ingredient.getAmount();
|
quantity += ingredient.getAmount();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (recipe instanceof ShapedRecipe) {
|
else if (recipe instanceof ShapedRecipe) {
|
||||||
for (ItemStack ingredient : ((ShapedRecipe) recipe).getIngredientMap().values()) {
|
for (ItemStack ingredient : ((ShapedRecipe) recipe).getIngredientMap().values()) {
|
||||||
if (ingredient != null && ingredient.getType() == repairMaterial && (repairMetadata == -1 || ingredient.getData() == repairData)) {
|
if (ingredient != null && (repairMaterial == null || ingredient.getType() == repairMaterial) && (repairMetadata == -1 || ingredient.getData() == repairData)) {
|
||||||
quantity += ingredient.getAmount();
|
quantity += ingredient.getAmount();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -136,6 +136,10 @@ public class RepairConfig extends ConfigLoader {
|
|||||||
// Minimum Quantity
|
// Minimum Quantity
|
||||||
int minimumQuantity = (itemMaterial != null && repairMaterial != null ? Repair.getRepairAndSalvageQuantities(new ItemStack(itemMaterial), repairMaterial, repairMetadata) : config.getInt("Repairables." + key + ".MinimumQuantity"));
|
int minimumQuantity = (itemMaterial != null && repairMaterial != null ? Repair.getRepairAndSalvageQuantities(new ItemStack(itemMaterial), repairMaterial, repairMetadata) : config.getInt("Repairables." + key + ".MinimumQuantity"));
|
||||||
|
|
||||||
|
if (minimumQuantity <= 0 && itemMaterial != null) {
|
||||||
|
minimumQuantity = Repair.getRepairAndSalvageQuantities(new ItemStack(itemMaterial));
|
||||||
|
}
|
||||||
|
|
||||||
if (minimumQuantity <= 0) {
|
if (minimumQuantity <= 0) {
|
||||||
reason.add("Minimum quantity of " + key + " must be greater than 0!");
|
reason.add("Minimum quantity of " + key + " must be greater than 0!");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user