package emasher.modules; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; import emasher.api.MixerRecipeRegistry; import emasher.api.MixerRecipeRegistry.MixerRecipe; import emasher.api.SideConfig; import emasher.api.SocketModule; import emasher.api.SocketTileAccess; import net.minecraft.block.Block; import net.minecraft.init.Blocks; import net.minecraft.init.Items; import net.minecraft.item.ItemStack; import net.minecraft.item.crafting.CraftingManager; import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.fluids.FluidStack; import net.minecraftforge.fluids.IFluidBlock; import net.minecraftforge.oredict.ShapedOreRecipe; import java.util.List; public class ModMixer extends SocketModule { public ModMixer( int id ) { super( id, "eng_toolbox:mixer", "eng_toolbox:mixerActive" ); } @Override public String getLocalizedName() { return "Mixer"; } @Override public void getToolTip( List l ) { l.add( "Used to mix items and fluids" ); } @Override public void getIndicatorKey( List l ) { l.add( emasher.util.Config.PREF_BLUE() + "Input Tank" ); 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/tick" ); l.add( "Cannot be installed on a socket with other machines" ); } @Override public void addRecipe() { CraftingManager.getInstance().getRecipeList().add( new ShapedOreRecipe( new ItemStack( emasher.items.Items.module(), 1, moduleID ), " h ", "udu", " b ", Character.valueOf( 'h' ), Blocks.hopper, Character.valueOf( 'u' ), Items.bucket, Character.valueOf( 'd' ), Blocks.dispenser, Character.valueOf( 'b' ), emasher.items.Items.blankSide() ) ); } @Override public boolean hasTankIndicator() { return true; } @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.tank >= 0 && config.tank <= 2 && config.inventory >= 0 && config.inventory <= 2 ) { if( ts.sideInventory.getStackInSlot( side.ordinal() ) == null ) { if( ts.getFluidInTank( config.tank ) != null && ts.getStackInInventorySlot( config.inventory ) != null ) { FluidStack toIntakeFluid = ts.getFluidInTank( config.tank ); ItemStack toIntake = ts.getStackInInventorySlot( config.inventory ); FluidStack product = null; MixerRecipe r = MixerRecipeRegistry.getRecipe( toIntake, toIntakeFluid ); if( r != null ) product = r.getOutput(); if( product != null && r.getFluidInput().amount <= toIntakeFluid.amount ) { ts.extractItemInternal( true, config.inventory, 1 ); ts.drainInternal( config.tank, r.getFluidInput().amount, true ); ts.sideInventory.setInventorySlotContents( side.ordinal(), fluidToItem( product ) ); config.meta = 40; 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 ) { FluidStack f = itemToFluid( ts.sideInventory.getStackInSlot( side.ordinal() ) ); int num = ts.forceOutputFluid( f ); if( num < f.amount ) { //TODO Check Fluid things //ts.sideInventory.setInventorySlotContents(side.ordinal(), new ItemStack(f.fluidID, 1, f.amount - num)); ts.sideInventory.setInventorySlotContents( side.ordinal(), new ItemStack( f.getFluid().getBlock(), 1, f.amount - num ) ); } else { ts.sideInventory.setInventorySlotContents( side.ordinal(), null ); } } if( updateClient ) ts.sendClientSideState( side.ordinal() ); } } private ItemStack fluidToItem( FluidStack f ) { //TODO Check what this is used for to see if it works this way or not //return new ItemStack(f.fluidID, 1, f.amount); return new ItemStack( f.getFluid().getBlock(), 1, f.amount ); } private FluidStack itemToFluid( ItemStack i ) { //TODO Check what this is used for to see if it works this way or not //return new FluidStack(i.itemID, i.getItemDamage()); Block b = Block.getBlockFromItem( i.getItem() ); if( !( b instanceof IFluidBlock ) ) return null; return new FluidStack( ( ( IFluidBlock ) b ).getFluid(), i.getItemDamage() ); } @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_mixer"; } @Override @SideOnly( Side.CLIENT ) public String[] getAllInternalTextures() { System.out.println( "inner mixer texture loaded" ); return new String[] {"eng_toolbox:inner_mixer"}; } }