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.item.ItemStack; import net.minecraft.item.crafting.FurnaceRecipes; import net.minecraftforge.common.util.ForgeDirection; import java.util.List; //import emasher.sockets.PacketHandler; public class ModFurnace extends SocketModule { public ModFurnace( int id ) { super( id, "eng_toolbox:furnaceIdle", "eng_toolbox:furnaceActive" ); } @Override public String getLocalizedName() { return "Furnace"; } @Override public void getToolTip( List l ) { l.add( "Uses energy to smelt items" ); } @Override public void getIndicatorKey( List l ) { l.add( emasher.util.Config.PREF_GREEN() + "Input inventory" ); l.add( emasher.util.Config.PREF_YELLOW() + "Outputs to Machine Output" ); l.add( emasher.util.Config.PREF_AQUA() + "Requires 10 RF/t" ); l.add( "Cannot be installed on a socket with other machines" ); } @Override public void addRecipe() { GameRegistry.addShapedRecipe( new ItemStack( emasher.items.Items.module(), 1, moduleID ), " h ", "iui", " b ", Character.valueOf( 'i' ), Blocks.brick_block, Character.valueOf( 'h' ), emasher.items.Items.psu(), Character.valueOf( 'u' ), Blocks.furnace, Character.valueOf( 'b' ), emasher.items.Items.blankSide() ); } @Override public boolean hasInventoryIndicator() { return true; } @Override public boolean isMachine() { return true; } @Override public boolean canBeInstalled( SocketTileAccess ts, ForgeDirection side ) { for( int i = 0; i < 6; i++ ) { SocketModule m = ts.getSide( ForgeDirection.getOrientation( i ) ); if( m != null && m.isMachine() ) return false; } return true; } @Override public void onRemoved( SocketTileAccess ts, SideConfig config, ForgeDirection side ) { ts.sideInventory.setInventorySlotContents( side.ordinal(), null ); } @Override public void updateSide( SideConfig config, SocketTileAccess ts, ForgeDirection side ) { boolean updateClient = false; if( config.inventory >= 0 && config.inventory <= 2 ) { if( ts.sideInventory.getStackInSlot( side.ordinal() ) == null ) { if( ts.getStackInInventorySlot( config.inventory ) != null ) { ItemStack toIntake = ts.getStackInInventorySlot( config.inventory ); ItemStack product = FurnaceRecipes.smelting().getSmeltingResult( toIntake ); if( product != null ) { ts.extractItemInternal( true, config.inventory, 1 ); ts.sideInventory.setInventorySlotContents( side.ordinal(), product.copy() ); config.meta = 180; config.rsControl[0] = false; updateClient = true; } } } else if( ts.useEnergy( 10, true ) >= 10 && config.meta > 0 ) { ts.useEnergy( 10, false ); config.meta--; if( config.meta == 0 ) updateClient = true; if( !config.rsControl[0] && config.meta > 0 ) { config.rsControl[0] = true; updateClient = true; } } else { if( config.rsControl[0] ) { config.rsControl[0] = false; updateClient = true; } } if( config.meta == 0 && ts.sideInventory.getStackInSlot( side.ordinal() ) != null ) { int num = ts.forceOutputItem( ts.sideInventory.getStackInSlot( side.ordinal() ) ); ts.sideInventory.getStackInSlot( side.ordinal() ).stackSize -= num; if( ts.sideInventory.getStackInSlot( side.ordinal() ).stackSize <= 0 ) ts.sideInventory.setInventorySlotContents( side.ordinal(), null ); } if( updateClient ) ts.sendClientSideState( side.ordinal() ); } } @Override public int getCurrentTexture( SideConfig config ) { if( config.meta == 0 || !config.rsControl[0] ) return 0; return 1; } @Override @SideOnly( Side.CLIENT ) public String getInternalTexture( SocketTileAccess ts, SideConfig config, ForgeDirection side ) { if( config.meta == 0 || !config.rsControl[0] ) return "eng_toolbox:inner_black"; return "eng_toolbox:inner_fire_blue"; } @Override @SideOnly( Side.CLIENT ) public String[] getAllInternalTextures() { return new String[] {"eng_toolbox:inner_fire_blue"}; } }