2013-12-29 23:55:02 -06:00
|
|
|
package appeng.parts.automation;
|
|
|
|
|
|
|
|
import net.minecraft.inventory.IInventory;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.tileentity.TileEntity;
|
2014-01-20 10:41:37 -06:00
|
|
|
import net.minecraft.world.World;
|
2014-01-01 23:51:41 -06:00
|
|
|
import appeng.api.config.RedstoneMode;
|
2014-01-01 03:05:27 -06:00
|
|
|
import appeng.api.config.Upgrades;
|
2013-12-29 23:55:02 -06:00
|
|
|
import appeng.api.networking.ticking.IGridTickable;
|
2014-01-01 23:51:41 -06:00
|
|
|
import appeng.api.networking.ticking.TickRateModulation;
|
2013-12-29 23:55:02 -06:00
|
|
|
import appeng.me.GridAccessException;
|
|
|
|
import appeng.tile.inventory.AppEngInternalAEInventory;
|
|
|
|
import appeng.util.InventoryAdaptor;
|
|
|
|
import appeng.util.Platform;
|
|
|
|
|
|
|
|
public abstract class PartSharedItemBus extends PartUpgradeable implements IGridTickable
|
|
|
|
{
|
|
|
|
|
2014-02-08 19:34:52 -06:00
|
|
|
private TileEntity getTileEntity(TileEntity self, int x, int y, int z)
|
2014-01-20 10:41:37 -06:00
|
|
|
{
|
2014-02-08 19:34:52 -06:00
|
|
|
World w = self.getWorldObj();
|
2014-01-20 10:41:37 -06:00
|
|
|
|
|
|
|
if ( w.getChunkProvider().chunkExists( x >> 4, z >> 4 ) )
|
|
|
|
{
|
2014-02-08 19:34:52 -06:00
|
|
|
TileEntity te = w.getTileEntity( x, y, z );
|
2014-01-20 10:41:37 -06:00
|
|
|
return te;
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2013-12-29 23:55:02 -06:00
|
|
|
public PartSharedItemBus(Class c, ItemStack is) {
|
|
|
|
super( c, is );
|
|
|
|
}
|
|
|
|
|
2014-01-01 23:51:41 -06:00
|
|
|
@Override
|
|
|
|
public void upgradesChanged()
|
|
|
|
{
|
|
|
|
updateState();
|
|
|
|
}
|
|
|
|
|
2014-01-01 03:05:27 -06:00
|
|
|
protected int availableSlots()
|
|
|
|
{
|
|
|
|
return Math.min( 1 + getInstalledUpgrades( Upgrades.CAPACITY ) * 4, config.getSizeInventory() );
|
|
|
|
}
|
|
|
|
|
2013-12-29 23:55:02 -06:00
|
|
|
public void writeToNBT(net.minecraft.nbt.NBTTagCompound extra)
|
|
|
|
{
|
|
|
|
super.writeToNBT( extra );
|
|
|
|
config.writeToNBT( extra, "config" );
|
|
|
|
}
|
|
|
|
|
|
|
|
public void readFromNBT(net.minecraft.nbt.NBTTagCompound extra)
|
|
|
|
{
|
|
|
|
super.readFromNBT( extra );
|
|
|
|
config.readFromNBT( extra, "config" );
|
|
|
|
}
|
|
|
|
|
|
|
|
AppEngInternalAEInventory config = new AppEngInternalAEInventory( this, 9 );
|
|
|
|
|
|
|
|
int adaptorHash = 0;
|
|
|
|
InventoryAdaptor adaptor;
|
|
|
|
|
|
|
|
InventoryAdaptor getHandler()
|
|
|
|
{
|
|
|
|
TileEntity self = getHost().getTile();
|
2014-02-08 19:34:52 -06:00
|
|
|
TileEntity target = getTileEntity( self, self.xCoord + side.offsetX, self.yCoord + side.offsetY, self.zCoord + side.offsetZ );
|
2013-12-29 23:55:02 -06:00
|
|
|
|
|
|
|
int newAdaptorHash = Platform.generateTileHash( target );
|
|
|
|
|
2014-01-03 12:28:52 -06:00
|
|
|
if ( adaptorHash == newAdaptorHash && newAdaptorHash != 0 )
|
2013-12-29 23:55:02 -06:00
|
|
|
return adaptor;
|
|
|
|
|
|
|
|
adaptorHash = newAdaptorHash;
|
|
|
|
adaptor = InventoryAdaptor.getAdaptor( target, side.getOpposite() );
|
|
|
|
|
|
|
|
return adaptor;
|
|
|
|
}
|
|
|
|
|
2014-01-01 23:51:41 -06:00
|
|
|
boolean lastRedstone = false;
|
|
|
|
|
|
|
|
abstract TickRateModulation doBusWork();
|
|
|
|
|
2013-12-29 23:55:02 -06:00
|
|
|
@Override
|
|
|
|
public void onNeighborChanged()
|
2014-01-01 23:51:41 -06:00
|
|
|
{
|
|
|
|
updateState();
|
|
|
|
if ( lastRedstone != host.hasRedstone( side ) )
|
|
|
|
{
|
|
|
|
lastRedstone = !lastRedstone;
|
|
|
|
if ( lastRedstone && getRSMode() == RedstoneMode.SIGNAL_PULSE )
|
|
|
|
doBusWork();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void updateState()
|
2013-12-29 23:55:02 -06:00
|
|
|
{
|
2014-01-01 23:51:41 -06:00
|
|
|
try
|
2013-12-29 23:55:02 -06:00
|
|
|
{
|
2014-01-01 23:51:41 -06:00
|
|
|
if ( !isSleeping() )
|
2013-12-29 23:55:02 -06:00
|
|
|
proxy.getTick().wakeDevice( proxy.getNode() );
|
2014-01-01 23:51:41 -06:00
|
|
|
else
|
|
|
|
proxy.getTick().sleepDevice( proxy.getNode() );
|
|
|
|
}
|
|
|
|
catch (GridAccessException e)
|
|
|
|
{
|
|
|
|
// :P
|
2013-12-29 23:55:02 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public IInventory getInventoryByName(String name)
|
|
|
|
{
|
|
|
|
if ( name.equals( "config" ) )
|
|
|
|
return config;
|
|
|
|
|
|
|
|
return super.getInventoryByName( name );
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|