mirror of
https://github.com/HbmMods/Hbm-s-Nuclear-Tech-GIT.git
synced 2026-01-25 10:32:49 +00:00
322 lines
6.9 KiB
Java
322 lines
6.9 KiB
Java
package com.hbm.inventory;
|
|
|
|
import java.util.List;
|
|
|
|
import net.minecraft.block.Block;
|
|
import net.minecraft.item.Item;
|
|
import net.minecraft.item.ItemStack;
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
import net.minecraftforge.oredict.OreDictionary;
|
|
|
|
public class RecipesCommon {
|
|
|
|
public static ItemStack[] copyStackArray(ItemStack[] array) {
|
|
|
|
if(array == null)
|
|
return null;
|
|
|
|
ItemStack[] clone = new ItemStack[array.length];
|
|
|
|
for(int i = 0; i < array.length; i++) {
|
|
|
|
if(array[i] != null)
|
|
clone[i] = array[i].copy();
|
|
}
|
|
|
|
return clone;
|
|
}
|
|
|
|
public static ItemStack[] objectToStackArray(Object[] array) {
|
|
|
|
if(array == null)
|
|
return null;
|
|
|
|
ItemStack[] clone = new ItemStack[array.length];
|
|
|
|
for(int i = 0; i < array.length; i++) {
|
|
|
|
if(array[i] instanceof ItemStack)
|
|
clone[i] = (ItemStack)array[i];
|
|
}
|
|
|
|
return clone;
|
|
}
|
|
|
|
public static abstract class AStack implements Comparable<AStack> {
|
|
|
|
public int stacksize;
|
|
|
|
public boolean isApplicable(ItemStack stack) {
|
|
return isApplicable(new ComparableStack(stack));
|
|
}
|
|
|
|
/*
|
|
* Is it unprofessional to pool around in child classes from an abstract superclass? Do I look like I give a shit?
|
|
*/
|
|
public boolean isApplicable(ComparableStack comp) {
|
|
|
|
if(this instanceof ComparableStack) {
|
|
return ((ComparableStack)this).equals(comp);
|
|
}
|
|
|
|
if(this instanceof OreDictStack) {
|
|
|
|
List<ItemStack> ores = OreDictionary.getOres(((OreDictStack)this).name);
|
|
|
|
for(ItemStack stack : ores) {
|
|
if(stack.getItem() == comp.item && stack.getItemDamage() == comp.meta)
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
public abstract AStack copy();
|
|
}
|
|
|
|
public static class ComparableStack extends AStack {
|
|
|
|
public Item item;
|
|
public int meta;
|
|
|
|
public ComparableStack(ItemStack stack) {
|
|
this.item = stack.getItem();
|
|
this.stacksize = stack.stackSize;
|
|
this.meta = stack.getItemDamage();
|
|
}
|
|
|
|
public ComparableStack makeSingular() {
|
|
stacksize = 1;
|
|
return this;
|
|
}
|
|
|
|
public ComparableStack(Item item) {
|
|
this.item = item;
|
|
this.stacksize = 1;
|
|
this.meta = 0;
|
|
}
|
|
|
|
public ComparableStack(Block item) {
|
|
this.item = Item.getItemFromBlock(item);
|
|
this.stacksize = 1;
|
|
this.meta = 0;
|
|
}
|
|
|
|
public ComparableStack(Block item, int stacksize) {
|
|
this.item = Item.getItemFromBlock(item);
|
|
this.stacksize = stacksize;
|
|
this.meta = 0;
|
|
}
|
|
|
|
public ComparableStack(Block item, int stacksize, int meta) {
|
|
this.item = Item.getItemFromBlock(item);
|
|
this.stacksize = stacksize;
|
|
this.meta = meta;
|
|
}
|
|
|
|
public ComparableStack(Item item, int stacksize) {
|
|
this(item);
|
|
this.stacksize = stacksize;
|
|
}
|
|
|
|
public ComparableStack(Item item, int stacksize, int meta) {
|
|
this(item, stacksize);
|
|
this.meta = meta;
|
|
}
|
|
|
|
public ItemStack toStack() {
|
|
|
|
return new ItemStack(item, stacksize, meta);
|
|
}
|
|
|
|
public String[] getDictKeys() {
|
|
|
|
int[] ids = OreDictionary.getOreIDs(toStack());
|
|
|
|
if(ids == null || ids.length == 0)
|
|
return new String[0];
|
|
|
|
String[] entries = new String[ids.length];
|
|
|
|
for(int i = 0; i < ids.length; i++) {
|
|
|
|
entries[i] = OreDictionary.getOreName(ids[i]);
|
|
}
|
|
|
|
return entries;
|
|
}
|
|
|
|
@Override
|
|
public int hashCode() {
|
|
final int prime = 31;
|
|
int result = 1;
|
|
result = prime * result + Item.itemRegistry.getNameForObject(item).hashCode(); //using the int ID will cause fucky-wuckys if IDs are scrambled
|
|
result = prime * result + meta;
|
|
result = prime * result + stacksize;
|
|
return result;
|
|
}
|
|
|
|
@Override
|
|
public boolean equals(Object obj) {
|
|
if (this == obj)
|
|
return true;
|
|
if (obj == null)
|
|
return false;
|
|
if (getClass() != obj.getClass())
|
|
return false;
|
|
ComparableStack other = (ComparableStack) obj;
|
|
if (item == null) {
|
|
if (other.item != null)
|
|
return false;
|
|
} else if (!item.equals(other.item))
|
|
return false;
|
|
if (meta != OreDictionary.WILDCARD_VALUE && other.meta != OreDictionary.WILDCARD_VALUE && meta != other.meta)
|
|
return false;
|
|
if (stacksize != other.stacksize)
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
@Override
|
|
public int compareTo(AStack stack) {
|
|
|
|
if(stack instanceof ComparableStack) {
|
|
|
|
ComparableStack comp = (ComparableStack) stack;
|
|
|
|
int thisID = Item.getIdFromItem(item);
|
|
int thatID = Item.getIdFromItem(comp.item);
|
|
|
|
if(thisID > thatID)
|
|
return 1;
|
|
if(thatID > thisID)
|
|
return -1;
|
|
|
|
if(meta > comp.meta)
|
|
return 1;
|
|
if(comp.meta > meta)
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
//if compared with an ODStack, the CStack will take priority
|
|
if(stack instanceof OreDictStack)
|
|
return 1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
@Override
|
|
public AStack copy() {
|
|
return new ComparableStack(item, stacksize, meta);
|
|
}
|
|
}
|
|
|
|
/*
|
|
* This implementation does not override the compare function, which effectively makes it ignore stack data.
|
|
* This is still in line with the use-case of the ComparableNBTStack holding machine output stack information,
|
|
* since the compare function is not needed. In case the compare function is required, make a new child class.
|
|
*/
|
|
public static class ComparableNBTStack extends ComparableStack {
|
|
|
|
NBTTagCompound nbt;
|
|
|
|
public ComparableNBTStack(ItemStack stack) {
|
|
super(stack);
|
|
}
|
|
|
|
public ComparableNBTStack(Item item) {
|
|
super(item);
|
|
}
|
|
|
|
public ComparableNBTStack(Block item) {
|
|
super(item);
|
|
}
|
|
|
|
public ComparableNBTStack(Block item, int stacksize) {
|
|
super(item, stacksize);
|
|
}
|
|
|
|
public ComparableNBTStack(Block item, int stacksize, int meta) {
|
|
super(item, stacksize, meta);
|
|
}
|
|
|
|
public ComparableNBTStack(Item item, int stacksize) {
|
|
super(item, stacksize);
|
|
}
|
|
|
|
public ComparableNBTStack(Item item, int stacksize, int meta) {
|
|
super(item, stacksize, meta);
|
|
}
|
|
|
|
public ComparableNBTStack addNBT(NBTTagCompound nbt) {
|
|
this.nbt = nbt;
|
|
return this;
|
|
}
|
|
|
|
public ItemStack toStack() {
|
|
ItemStack stack = super.toStack();
|
|
stack.stackTagCompound = this.nbt;
|
|
return stack;
|
|
}
|
|
}
|
|
|
|
public static class OreDictStack extends AStack {
|
|
|
|
public String name;
|
|
|
|
public OreDictStack(String name) {
|
|
this.name = name;
|
|
this.stacksize = 1;
|
|
}
|
|
|
|
public OreDictStack(String name, int stacksize) {
|
|
this(name);
|
|
this.stacksize = stacksize;
|
|
}
|
|
|
|
public List<ItemStack> toStacks() {
|
|
return OreDictionary.getOres(name);
|
|
}
|
|
|
|
@Override
|
|
public int compareTo(AStack stack) {
|
|
|
|
if(stack instanceof OreDictStack) {
|
|
|
|
OreDictStack comp = (OreDictStack) stack;
|
|
return name.compareTo(comp.name);
|
|
}
|
|
|
|
//if compared with a CStack, the ODStack will yield
|
|
if(stack instanceof ComparableStack)
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
@Override
|
|
public AStack copy() {
|
|
return new OreDictStack(name, stacksize);
|
|
}
|
|
}
|
|
|
|
public static class MetaBlock {
|
|
|
|
public Block block;
|
|
public int meta;
|
|
|
|
public MetaBlock(Block block, int meta) {
|
|
this.block = block;
|
|
this.meta = meta;
|
|
}
|
|
|
|
public MetaBlock(Block block) {
|
|
this(block, 0);
|
|
}
|
|
}
|
|
|
|
}
|