More progress on Logistical Sorter

This commit is contained in:
Aidan C. Brady 2013-10-25 09:51:13 -04:00
parent 5a748c5ff6
commit e9c038cd24
6 changed files with 123 additions and 18 deletions

View file

@ -31,6 +31,14 @@ public class TileEntityLogisticalSorter extends TileEntityElectricBlock implemen
public void onUpdate()
{
super.onUpdate();
if(!worldObj.isRemote)
{
if(MekanismUtils.canFunction(this))
{
//TODO
}
}
}
@Override
@ -80,6 +88,13 @@ public class TileEntityLogisticalSorter extends TileEntityElectricBlock implemen
controlType = RedstoneControl.values()[dataStream.readInt()];
filters.clear();
for(int i = 0; i < dataStream.readInt(); i++)
{
filters.add(TransporterFilter.readFromPacket(dataStream));
}
MekanismUtils.updateBlock(worldObj, xCoord, yCoord, zCoord);
}
@ -89,6 +104,12 @@ public class TileEntityLogisticalSorter extends TileEntityElectricBlock implemen
super.getNetworkedData(data);
data.add(controlType.ordinal());
data.add(filters.size());
for(TransporterFilter filter : filters)
{
filter.write(data);
}
return data;
}
@ -104,6 +125,12 @@ public class TileEntityLogisticalSorter extends TileEntityElectricBlock implemen
{
return false;
}
@Override
public int getInventoryStackLimit()
{
return 1;
}
@Override
public RedstoneControl getControlType()

View file

@ -335,14 +335,9 @@ public class TileEntityLogisticalTransporter extends TileEntityTransmitter<Inven
transit.clear();
int amount = dataStream.readInt();
for(int i = 0; i < amount; i++)
for(int i = 0; i < dataStream.readInt(); i++)
{
TransporterStack stack = new TransporterStack();
stack.read(dataStream);
transit.add(stack);
transit.add(TransporterStack.readFromPacket(dataStream));
}
}
@ -383,7 +378,7 @@ public class TileEntityLogisticalTransporter extends TileEntityTransmitter<Inven
for(int i = 0; i < tagList.tagCount(); i++)
{
transit.add(TransporterStack.read((NBTTagCompound)tagList.tagAt(i)));
transit.add(TransporterStack.readFromNBT((NBTTagCompound)tagList.tagAt(i)));
}
}
}

View file

@ -10,14 +10,20 @@ import net.minecraft.nbt.NBTTagCompound;
public class ItemStackFilter extends TransporterFilter
{
public ItemStack itemStack;
public ItemStack itemType;
@Override
public boolean canFilter(ItemStack itemStack)
{
return itemType.isItemEqual(itemStack);
}
@Override
public void write(NBTTagCompound nbtTags)
{
super.write(nbtTags);
itemStack.writeToNBT(nbtTags);
itemType.writeToNBT(nbtTags);
}
@Override
@ -25,7 +31,7 @@ public class ItemStackFilter extends TransporterFilter
{
super.read(nbtTags);
itemStack = ItemStack.loadItemStackFromNBT(nbtTags);
itemType = ItemStack.loadItemStackFromNBT(nbtTags);
}
@Override
@ -33,9 +39,9 @@ public class ItemStackFilter extends TransporterFilter
{
super.write(data);
data.add(itemStack.itemID);
data.add(itemStack.stackSize);
data.add(itemStack.getItemDamage());
data.add(itemType.itemID);
data.add(itemType.stackSize);
data.add(itemType.getItemDamage());
}
@Override
@ -43,6 +49,23 @@ public class ItemStackFilter extends TransporterFilter
{
super.read(dataStream);
itemStack = new ItemStack(dataStream.readInt(), dataStream.readInt(), dataStream.readInt());
itemType = new ItemStack(dataStream.readInt(), dataStream.readInt(), dataStream.readInt());
}
@Override
public int hashCode()
{
int code = 1;
code = 31 * code + super.hashCode();
code = 31 * code + itemType.itemID;
code = 31 * code + itemType.stackSize;
code = 31 * code + itemType.getItemDamage();
return code;
}
@Override
public boolean equals(Object filter)
{
return super.equals(filter) && filter instanceof ItemStackFilter && ((ItemStackFilter)filter).itemType.isItemEqual(itemType);
}
}

View file

@ -4,13 +4,21 @@ import java.util.ArrayList;
import com.google.common.io.ByteArrayDataInput;
import mekanism.common.util.MekanismUtils;
import mekanism.common.util.TransporterUtils;
import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
public class OreDictFilter extends TransporterFilter
{
public String oreDictName;
@Override
public boolean canFilter(ItemStack itemStack)
{
return MekanismUtils.oreDictCheck(itemStack, oreDictName);
}
@Override
public void write(NBTTagCompound nbtTags)
{
@ -42,4 +50,19 @@ public class OreDictFilter extends TransporterFilter
oreDictName = dataStream.readUTF();
}
@Override
public int hashCode()
{
int code = 1;
code = 31 * code + super.hashCode();
code = 31 * code + oreDictName.hashCode();
return code;
}
@Override
public boolean equals(Object filter)
{
return super.equals(filter) && filter instanceof OreDictFilter && ((OreDictFilter)filter).oreDictName.equals(oreDictName);
}
}

View file

@ -3,7 +3,9 @@ package mekanism.common.transporter;
import java.util.ArrayList;
import mekanism.api.EnumColor;
import mekanism.common.Teleporter.Code;
import mekanism.common.util.TransporterUtils;
import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
import com.google.common.io.ByteArrayDataInput;
@ -12,6 +14,11 @@ public class TransporterFilter
{
public EnumColor color;
public boolean canFilter(ItemStack itemStack)
{
return false;
}
public void write(NBTTagCompound nbtTags)
{
nbtTags.setInteger("color", TransporterUtils.colors.indexOf(color));
@ -39,4 +46,26 @@ public class TransporterFilter
return filter;
}
public static TransporterFilter readFromPacket(ByteArrayDataInput dataStream)
{
TransporterFilter filter = new TransporterFilter();
filter.read(dataStream);
return filter;
}
@Override
public int hashCode()
{
int code = 1;
code = 31 * code + color.ordinal();
return code;
}
@Override
public boolean equals(Object filter)
{
return filter instanceof TransporterFilter && ((TransporterFilter)filter).color == color;
}
}

View file

@ -101,7 +101,7 @@ public class TransporterStack
itemStack.writeToNBT(nbtTags);
}
public void readFromNBT(NBTTagCompound nbtTags)
public void read(NBTTagCompound nbtTags)
{
if(nbtTags.hasKey("color"))
{
@ -114,10 +114,18 @@ public class TransporterStack
itemStack = ItemStack.loadItemStackFromNBT(nbtTags);
}
public static TransporterStack read(NBTTagCompound nbtTags)
public static TransporterStack readFromNBT(NBTTagCompound nbtTags)
{
TransporterStack stack = new TransporterStack();
stack.readFromNBT(nbtTags);
stack.read(nbtTags);
return stack;
}
public static TransporterStack readFromPacket(ByteArrayDataInput dataStream)
{
TransporterStack stack = new TransporterStack();
stack.read(dataStream);
return stack;
}