package emasher.modules; import cpw.mods.fml.common.registry.GameRegistry; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; import emasher.api.SideConfig; import emasher.api.SocketModule; import emasher.api.SocketTileAccess; import net.minecraft.init.Blocks; import net.minecraft.init.Items; import net.minecraft.item.ItemStack; import net.minecraftforge.common.util.ForgeDirection; import java.util.List; public class ModItemOutput extends SocketModule { public ModItemOutput( int id ) { super( id, "eng_toolbox:itemOutput" ); } @Override public String getLocalizedName() { return "Item Output"; } @Override public void getToolTip( List l ) { l.add( "Outputs items from its configured inventory" ); l.add( "to adjacent pipes/inventories/etc." ); } @Override public void getIndicatorKey( List l ) { l.add( emasher.util.Config.PREF_GREEN() + "Inventory to output from" ); l.add( emasher.util.Config.PREF_RED() + "RS control circuit" ); l.add( emasher.util.Config.PREF_DARK_PURPLE() + "RS control latch" ); } @Override public void addRecipe() { GameRegistry.addShapedRecipe( new ItemStack( emasher.items.Items.module(), 1, moduleID ), "h", "d", "b", Character.valueOf( 'i' ), Items.iron_ingot, Character.valueOf( 'h' ), Blocks.trapdoor, Character.valueOf( 'd' ), Blocks.dropper, Character.valueOf( 'b' ), emasher.items.Items.blankSide() ); } @Override public void updateSide( SideConfig config, SocketTileAccess ts, ForgeDirection side ) { if( config.inventory < 0 || config.inventory > 2 ) return; boolean allOff = true; for( int i = 0; i < 3; i++ ) { if( config.rsControl[i] ) { if( ts.getRSControl( i ) ) { if( ts.tryInsertItem( ts.getStackInInventorySlot( config.inventory ), side ) ) ts.extractItemInternal( true, config.inventory, 1 ); return; } allOff = false; } if( config.rsLatch[i] ) { if( ts.getRSLatch( i ) ) { if( ts.tryInsertItem( ts.getStackInInventorySlot( config.inventory ), side ) ) ts.extractItemInternal( true, config.inventory, 1 ); return; } allOff = false; } } if( allOff ) if( ts.tryInsertItem( ts.getStackInInventorySlot( config.inventory ), side ) ) ts.extractItemInternal( true, config.inventory, 1 ); } @Override public boolean hasInventoryIndicator() { return true; } @Override public boolean hasRSIndicator() { return true; } @Override public boolean hasLatchIndicator() { return true; } @Override public boolean isItemInterface() { return true; } @Override public boolean canExtractItems() { return true; } @Override public boolean canDirectlyExtractItems( SideConfig config, SocketTileAccess ts ) { if( config.inventory < 0 || config.inventory > 2 ) return false; boolean allOff = true; for( int i = 0; i < 3; i++ ) { if( config.rsControl[i] ) { if( ts.getRSControl( i ) ) { return true; } allOff = false; } if( config.rsLatch[i] ) { if( ts.getRSLatch( i ) ) { return true; } allOff = false; } } return allOff; } @Override public ItemStack itemExtract( int amount, boolean doExtract, SideConfig config, SocketTileAccess ts ) { if( config.inventory != -1 ) return ts.extractItemInternal( doExtract, config.inventory, amount ); return null; } @SideOnly( Side.CLIENT ) public ItemStack getItemToRender( SocketTileAccess ts, SideConfig config, ForgeDirection side ) { if( config.inventory != -1 ) return ts.getStackInInventorySlot( config.inventory ); return null; } @Override public void onInventoryChange( SideConfig config, int index, SocketTileAccess ts, ForgeDirection side, boolean add ) { if( index == config.inventory ) { ts.sendClientInventorySlot( index ); } } }