BloodMagic/src/main/java/WayofTime/bloodmagic/compress/BaseCompressionHandler.java

111 lines
2.8 KiB
Java
Raw Normal View History

2015-12-29 00:09:51 +00:00
package WayofTime.bloodmagic.compress;
import WayofTime.bloodmagic.api.compress.CompressionHandler;
import net.minecraft.item.ItemStack;
import net.minecraft.world.World;
public class BaseCompressionHandler extends CompressionHandler
{
2015-12-29 00:09:51 +00:00
private final ItemStack required;
private final ItemStack result;
private final int leftover;
public BaseCompressionHandler(ItemStack requested, ItemStack result, int leftover)
{
2015-12-29 00:09:51 +00:00
super();
this.required = requested;
this.result = result;
this.leftover = leftover;
}
public ItemStack getResultStack()
{
2015-12-29 00:09:51 +00:00
return this.result.copy();
}
public ItemStack getRequiredStack()
{
2015-12-29 00:09:51 +00:00
return this.required.copy();
}
@Override
public ItemStack compressInventory(ItemStack[] inv, World world)
{
2015-12-29 00:09:51 +00:00
int remaining = this.getRemainingNeeded(inv);
if (remaining <= 0)
{
2015-12-29 00:09:51 +00:00
this.drainInventory(inv);
return this.getResultStack();
}
return null;
}
public int getRemainingNeeded(ItemStack[] inv)
{
2015-12-29 00:09:51 +00:00
return iterateThroughInventory(inv, false);
}
public int drainInventory(ItemStack[] inv)
{
2015-12-29 00:09:51 +00:00
return iterateThroughInventory(inv, true);
}
public int iterateThroughInventory(ItemStack[] inv, boolean doDrain)
{
2015-12-29 00:09:51 +00:00
int needed = this.required.stackSize;
int kept = this.getLeftover();
int i = -1;
for (ItemStack invStack : inv)
{
2015-12-29 00:09:51 +00:00
i++;
if (invStack == null)
{
2015-12-29 00:09:51 +00:00
continue;
}
if (invStack.isItemEqual(this.required) && (invStack.getTagCompound() == null ? this.required.getTagCompound() == null : invStack.getTagCompound().equals(this.required.getTagCompound())))
{
2015-12-29 00:09:51 +00:00
int stackSize = invStack.stackSize;
int used = 0;
if (kept > 0)
{
2015-12-29 00:09:51 +00:00
int remainingFromStack = Math.max(stackSize - kept, 0);
used += stackSize - remainingFromStack;
}
kept -= used;
if (kept <= 0 && needed > 0)
{
2015-12-29 00:09:51 +00:00
int remainingFromStack = Math.max(stackSize - used - needed, 0);
if (doDrain)
{
2015-12-29 00:09:51 +00:00
invStack.stackSize = remainingFromStack + used;
if (invStack.stackSize <= 0)
{
2015-12-29 00:09:51 +00:00
inv[i] = null;
}
}
needed -= (stackSize - used - remainingFromStack);
}
if (needed <= 0)
{
2015-12-29 00:09:51 +00:00
return 0;
}
}
}
return needed;
}
public int getLeftover()
{
2015-12-29 00:09:51 +00:00
return this.leftover;
}
}