package emasher.modules; 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.CraftingManager; import net.minecraft.tileentity.TileEntityFurnace; import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.oredict.ShapedOreRecipe; import java.util.List; public class ModStirlingGenerator extends SocketModule { private static final int ACTIVE = 1; private static final int HIGH_POWER = 2; public ModStirlingGenerator( int id ) { super( id, "eng_toolbox:stirlingGenIdle0", "eng_toolbox:stirlingGenIdle1" ); } @Override public String getLocalizedName() { return "Stirling Generator"; } @Override public void getToolTip( List l ) { l.add( "Generates power using" ); l.add( "furnace fuel" ); l.add( "High power mode uses" ); l.add( "more than double the fuel" ); l.add( "to produce double the power" ); l.add( "per tick" ); } @Override public void getIndicatorKey( List l ) { l.add( emasher.util.Config.PREF_GREEN() + "Input inventory" ); l.add( emasher.util.Config.PREF_WHITE() + "Toggles high power mode" ); l.add( emasher.util.Config.PREF_AQUA() + "Produces 10 or 20 RF/t" ); } @Override public void addRecipe() { CraftingManager.getInstance().getRecipeList().add( new ShapedOreRecipe( new ItemStack( emasher.items.Items.module(), 1, moduleID ), "ggg", " F ", " b ", Character.valueOf( 'g' ), Blocks.stone, Character.valueOf( 'F' ), Blocks.furnace, Character.valueOf( 'b' ), emasher.items.Items.blankSide() ) ); } @Override public boolean hasInventoryIndicator() { return true; } @Override public void onGenericRemoteSignal( SocketTileAccess ts, SideConfig config, ForgeDirection side ) { config.tank ^= HIGH_POWER; ts.sendClientSideState( side.ordinal() ); } @Override public void updateSide( SideConfig config, SocketTileAccess ts, ForgeDirection side ) { boolean updateClient = false; if( config.inventory >= 0 && config.inventory <= 2 ) { boolean roomForMoreFuel = ts.sideInventory.getStackInSlot( side.ordinal() ) == null; boolean moreFuelAvail = ts.getStackInInventorySlot( config.inventory ) != null; boolean canStoreEnergy = ts.getEnergyStored() < ts.getMaxEnergyStored(); if( moreFuelAvail && roomForMoreFuel && canStoreEnergy && config.meta <= 0 ) { ItemStack toIntake = ts.getStackInInventorySlot( config.inventory ); int time = TileEntityFurnace.getItemBurnTime( toIntake ); if( time > 0 ) { // ensure it's even if( time % 2 != 0 ) time++; ts.extractItemInternal( true, config.inventory, 1 ); config.meta = time; } } if( canStoreEnergy && config.meta > 0 ) { if( ( config.tank & HIGH_POWER ) != HIGH_POWER ) { config.meta--; ts.addEnergy( 10, false ); } else { config.meta -= 2; if( ts.getWorldObj().rand.nextBoolean() ) config.meta--; ts.addEnergy( 20, false ); } if( config.meta == 0 ) { config.tank &= ~ACTIVE; updateClient = true; } else { if( ( config.tank & ACTIVE ) != ACTIVE ) updateClient = true; config.tank |= ACTIVE; } } else if( !canStoreEnergy && config.meta > 0 ) { config.tank &= ~ACTIVE; updateClient = true; } } if( updateClient ) ts.sendClientSideState( side.ordinal() ); } @Override public void init( SocketTileAccess ts, SideConfig config, ForgeDirection side ) { // not ACTIVE and not HIGH_POWER config.tank = 0; ts.sendClientSideState( side.ordinal() ); } @Override public int getCurrentTexture( SideConfig config ) { if( ( config.tank & HIGH_POWER ) == HIGH_POWER ) return 1; return 0; } @Override @SideOnly( Side.CLIENT ) public String getInternalTexture( SocketTileAccess ts, SideConfig config, ForgeDirection side ) { if( ( config.tank & ACTIVE ) == ACTIVE ) { if( ( config.tank & HIGH_POWER ) == HIGH_POWER ) return "eng_toolbox:inner_fire_blue"; return "eng_toolbox:inner_fire_orange"; } else { return "eng_toolbox:inner_black"; } } @Override @SideOnly( Side.CLIENT ) public String[] getAllInternalTextures() { return new String[] {"eng_toolbox:inner_fire_blue", "eng_toolbox:inner_fire_orange"}; } }