Prevent duplciates in registered Ores in the OreDictionary and clean up some of the code, add new function to return all ores the specified ItemStack satisfies. Closes #1102

This commit is contained in:
Lex Manos 2014-05-25 14:20:02 -07:00
parent 507f184144
commit 25ef7e3469
3 changed files with 54 additions and 21 deletions

View file

@ -294,7 +294,7 @@ public class OreDictionary
{ {
for(ItemStack target : ore.getValue()) for(ItemStack target : ore.getValue())
{ {
if(itemStack.getItem() == target.getItem() && (target.getItemDamage() == WILDCARD_VALUE || itemStack.getItemDamage() == target.getItemDamage())) if (itemMatches(itemStack, target, false))
{ {
return ore.getKey(); return ore.getKey();
} }
@ -303,6 +303,34 @@ public class OreDictionary
return -1; // didn't find it. return -1; // didn't find it.
} }
/**
* Gets all the integer ID for the ores that the specified item stakc is registered to.
* If the item stack is not linked to any ore, this will return an empty array and no new entry will be created.
*
* @param itemStack The item stack of the ore.
* @return An array of ids that this ore is registerd as.
*/
public static int[] getOreIDs(ItemStack itemStack)
{
if (itemStack == null) return new int[0];
List<Integer> ids = new ArrayList<Integer>();
for(Entry<Integer, ArrayList<ItemStack>> ore : oreStacks.entrySet())
{
for(ItemStack target : ore.getValue())
{
if (itemMatches(itemStack, target, false))
{
ids.add(ore.getKey());
}
}
}
int[] ret = new int[ids.size()];
for (int x = 0; x < ids.size(); x++)
ret[x] = ids.get(x);
return ret;
}
/** /**
* Retrieves the ArrayList of items that are registered to this ore type. * Retrieves the ArrayList of items that are registered to this ore type.
* Creates the list as empty if it did not exist. * Creates the list as empty if it did not exist.
@ -358,6 +386,21 @@ public class OreDictionary
return false; return false;
} }
private static boolean containsMatch(boolean strict, List<ItemStack> inputs, ItemStack... targets)
{
for (ItemStack input : inputs)
{
for (ItemStack target : targets)
{
if (itemMatches(target, input, strict))
{
return true;
}
}
}
return false;
}
public static boolean itemMatches(ItemStack target, ItemStack input, boolean strict) public static boolean itemMatches(ItemStack target, ItemStack input, boolean strict)
{ {
if (input == null && target != null || input != null && target == null) if (input == null && target != null || input != null && target == null)
@ -386,6 +429,7 @@ public class OreDictionary
private static void registerOre(String name, int id, ItemStack ore) private static void registerOre(String name, int id, ItemStack ore)
{ {
ArrayList<ItemStack> ores = getOres(id); ArrayList<ItemStack> ores = getOres(id);
if (containsMatch(false, ores, ore)) return; // Prevent duplicates.
ore = ore.copy(); ore = ore.copy();
ores.add(ore); ores.add(ore);
MinecraftForge.EVENT_BUS.post(new OreRegisterEvent(name, ore)); MinecraftForge.EVENT_BUS.post(new OreRegisterEvent(name, ore));

View file

@ -2,6 +2,7 @@ package net.minecraftforge.oredict;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.Iterator;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
@ -209,7 +210,7 @@ public class ShapedOreRecipe implements IRecipe
if (target instanceof ItemStack) if (target instanceof ItemStack)
{ {
if (!checkItemEquals((ItemStack)target, slot)) if (!OreDictionary.itemMatches((ItemStack)target, slot, false))
{ {
return false; return false;
} }
@ -218,9 +219,10 @@ public class ShapedOreRecipe implements IRecipe
{ {
boolean matched = false; boolean matched = false;
for (ItemStack item : (ArrayList<ItemStack>)target) Iterator<ItemStack> itr = ((ArrayList<ItemStack>)target).iterator();
while (itr.hasNext() && !matched)
{ {
matched = matched || checkItemEquals(item, slot); matched = OreDictionary.itemMatches(itr.next(), slot, false);
} }
if (!matched) if (!matched)
@ -238,15 +240,6 @@ public class ShapedOreRecipe implements IRecipe
return true; return true;
} }
private boolean checkItemEquals(ItemStack target, ItemStack input)
{
if (input == null && target != null || input != null && target == null)
{
return false;
}
return (target.getItem() == input.getItem() && (target.getItemDamage() == OreDictionary.WILDCARD_VALUE|| target.getItemDamage() == input.getItemDamage()));
}
public ShapedOreRecipe setMirrored(boolean mirror) public ShapedOreRecipe setMirrored(boolean mirror)
{ {
mirrored = mirror; mirrored = mirror;

View file

@ -108,13 +108,14 @@ public class ShapelessOreRecipe implements IRecipe
if (next instanceof ItemStack) if (next instanceof ItemStack)
{ {
match = checkItemEquals((ItemStack)next, slot); match = OreDictionary.itemMatches((ItemStack)next, slot, false);
} }
else if (next instanceof ArrayList) else if (next instanceof ArrayList)
{ {
for (ItemStack item : (ArrayList<ItemStack>)next) Iterator<ItemStack> itr = ((ArrayList<ItemStack>)next).iterator();
while (itr.hasNext() && !match)
{ {
match = match || checkItemEquals(item, slot); match = OreDictionary.itemMatches(itr.next(), slot, false);
} }
} }
@ -136,11 +137,6 @@ public class ShapelessOreRecipe implements IRecipe
return required.isEmpty(); return required.isEmpty();
} }
private boolean checkItemEquals(ItemStack target, ItemStack input)
{
return (target.getItem() == input.getItem() && (target.getItemDamage() == OreDictionary.WILDCARD_VALUE || target.getItemDamage() == input.getItemDamage()));
}
/** /**
* Returns the input for this recipe, any mod accessing this value should never * Returns the input for this recipe, any mod accessing this value should never
* manipulate the values in this array as it will effect the recipe itself. * manipulate the values in this array as it will effect the recipe itself.