Massive recipe system overhaul.
They should be much more efficient now (this reduced the tick time of the CI Chamber by 3-4x in my testing), due to being able to just use the HashMap's get() instead of being limited to iterating through entries. NEI integration code now a lot more readable and type-safe as well.
This commit is contained in:
parent
4dd3d4ba01
commit
ce6946c669
77 changed files with 1294 additions and 486 deletions
|
@ -116,4 +116,10 @@ public class GasStack
|
|||
{
|
||||
return "[" + type + ", " + amount + "]";
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode()
|
||||
{
|
||||
return type == null ? 0 : type.getID();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,29 +0,0 @@
|
|||
package mekanism.api.recipe;
|
||||
|
||||
import mekanism.api.gas.Gas;
|
||||
import mekanism.api.util.StackUtils;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class AdvancedInput
|
||||
{
|
||||
public ItemStack itemStack;
|
||||
|
||||
public Gas gasType;
|
||||
|
||||
public AdvancedInput(ItemStack item, Gas gas)
|
||||
{
|
||||
itemStack = item;
|
||||
gasType = gas;
|
||||
}
|
||||
|
||||
public boolean isValid()
|
||||
{
|
||||
return itemStack != null && gasType != null;
|
||||
}
|
||||
|
||||
public boolean matches(AdvancedInput input)
|
||||
{
|
||||
return StackUtils.equalsWildcard(itemStack, input.itemStack) && input.itemStack.stackSize >= itemStack.stackSize;
|
||||
}
|
||||
}
|
|
@ -1,25 +0,0 @@
|
|||
package mekanism.api.recipe;
|
||||
|
||||
public class PressurizedRecipe
|
||||
{
|
||||
public PressurizedReactants reactants;
|
||||
|
||||
public double extraEnergy;
|
||||
|
||||
public PressurizedProducts products;
|
||||
|
||||
public int ticks;
|
||||
|
||||
public PressurizedRecipe(PressurizedReactants pressurizedReactants, double energy, PressurizedProducts pressurizedProducts, int duration)
|
||||
{
|
||||
reactants = pressurizedReactants;
|
||||
extraEnergy = energy;
|
||||
products = pressurizedProducts;
|
||||
ticks = duration;
|
||||
}
|
||||
|
||||
public PressurizedRecipe copy()
|
||||
{
|
||||
return new PressurizedRecipe(reactants.copy(), extraEnergy, products.copy(), ticks);
|
||||
}
|
||||
}
|
|
@ -3,7 +3,7 @@ package mekanism.api.recipe;
|
|||
import java.lang.reflect.Method;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.api.infuse.InfuseType;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraftforge.fluids.FluidStack;
|
||||
|
@ -113,15 +113,16 @@ public final class RecipeHelper
|
|||
|
||||
/**
|
||||
* Add a Chemical Infuser recipe.
|
||||
* @param input - input ChemicalInput
|
||||
* @param leftInput - left input GasStack
|
||||
* @param rightInput - right input GasStack
|
||||
* @param output - output GasStack
|
||||
*/
|
||||
public static void addChemicalInfuserRecipe(ChemicalPair input, GasStack output)
|
||||
public static void addChemicalInfuserRecipe(GasStack leftInput, GasStack rightInput, GasStack output)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addChemicalInfuserRecipe", ChemicalPair.class, GasStack.class);
|
||||
m.invoke(null, input, output);
|
||||
Method m = recipeClass.getMethod("addChemicalInfuserRecipe", GasStack.class, GasStack.class, GasStack.class);
|
||||
m.invoke(null, leftInput, rightInput, output);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
|
@ -130,14 +131,32 @@ public final class RecipeHelper
|
|||
/**
|
||||
* Add a Precision Sawmill recipe.
|
||||
* @param input - input ItemStack
|
||||
* @param output - output ChanceOutput
|
||||
* @param primaryOutput - guaranteed output
|
||||
* @param secondaryOutput - possible extra output
|
||||
* @param chance - probability of obtaining extra output
|
||||
*/
|
||||
public static void addPrecisionSawmillRecipe(ItemStack input, ChanceOutput output)
|
||||
public static void addPrecisionSawmillRecipe(ItemStack input, ItemStack primaryOutput, ItemStack secondaryOutput, double chance)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addPrecisionSawmillRecipe", ItemStack.class, ChanceOutput.class);
|
||||
m.invoke(null, input, output);
|
||||
Method m = recipeClass.getMethod("addPrecisionSawmillRecipe", ItemStack.class, ItemStack.class, ItemStack.class, Double.TYPE);
|
||||
m.invoke(null, input, primaryOutput, secondaryOutput, chance);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a Precision Sawmill recipe with no chance output
|
||||
* @param input - input ItemStack
|
||||
* @param primaryOutput - guaranteed output
|
||||
*/
|
||||
public static void addPrecisionSawmillRecipe(ItemStack input, ItemStack primaryOutput)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addPrecisionSawmillRecipe", ItemStack.class, ItemStack.class);
|
||||
m.invoke(null, input, primaryOutput);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
|
@ -148,12 +167,12 @@ public final class RecipeHelper
|
|||
* @param input - input AdvancedInput
|
||||
* @param output - output ItemStack
|
||||
*/
|
||||
public static void addChemicalInjectionChamberRecipe(AdvancedInput input, ItemStack output)
|
||||
public static void addChemicalInjectionChamberRecipe(ItemStack input, String gasName, ItemStack output)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addChemicalInjectionChamberRecipe", AdvancedInput.class, ItemStack.class);
|
||||
m.invoke(null, input, output);
|
||||
Method m = recipeClass.getMethod("addChemicalInjectionChamberRecipe", ItemStack.class, String.class, ItemStack.class);
|
||||
m.invoke(null, input, gasName, output);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
|
@ -162,14 +181,15 @@ public final class RecipeHelper
|
|||
/**
|
||||
* Add an Electrolytic Separator recipe.
|
||||
* @param input - input FluidStack
|
||||
* @param output - output ChemicalPair
|
||||
* @param leftOutput - left output GasStack
|
||||
* @param rightOutput - right output GasStack
|
||||
*/
|
||||
public static void addElectrolyticSeparatorRecipe(FluidStack input, ChemicalPair output)
|
||||
public static void addElectrolyticSeparatorRecipe(FluidStack input, GasStack leftOutput, GasStack rightOutput)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addElectrolyticSeparatorRecipe", FluidStack.class, ChemicalPair.class);
|
||||
m.invoke(null, input, output);
|
||||
Method m = recipeClass.getMethod("addElectrolyticSeparatorRecipe", FluidStack.class, GasStack.class, GasStack.class);
|
||||
m.invoke(null, input, leftOutput, rightOutput);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
|
@ -225,15 +245,17 @@ public final class RecipeHelper
|
|||
|
||||
/**
|
||||
* Add a Metallurgic Infuser recipe.
|
||||
* @param input - input Infusion
|
||||
* @param infuse - which Infuse to use
|
||||
* @param amount - how much Infuse to use
|
||||
* @param input - input ItemStack
|
||||
* @param output - output ItemStack
|
||||
*/
|
||||
public static void addMetallurgicInfuserRecipe(InfusionInput input, ItemStack output)
|
||||
public static void addMetallurgicInfuserRecipe(InfuseType infuse, int amount, ItemStack input, ItemStack output)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addMetallurgicInfuserRecipe", InfusionInput.class, ItemStack.class);
|
||||
m.invoke(null, input, output);
|
||||
Method m = recipeClass.getMethod("addMetallurgicInfuserRecipe", InfuseType.class, Integer.TYPE, ItemStack.class, ItemStack.class);
|
||||
m.invoke(null, infuse, amount, input, output);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
|
@ -241,17 +263,20 @@ public final class RecipeHelper
|
|||
|
||||
/**
|
||||
* Add a Pressurized Reaction Chamber recipe.
|
||||
* @param input - input PressurizedReactants
|
||||
* @param output - output PressurizedProducts
|
||||
* @param inputSolid - input ItemStack
|
||||
* @param inputFluid - input FluidStack
|
||||
* @param inputGas - input GasStack
|
||||
* @param outputSolid - output ItemStack
|
||||
* @param outputGas - output GasStack
|
||||
* @param extraEnergy - extra energy needed by the recipe
|
||||
* @param ticks - amount of ticks it takes for this recipe to complete
|
||||
*/
|
||||
public static void addPRCRecipe(PressurizedReactants input, PressurizedProducts output, double extraEnergy, int ticks)
|
||||
public static void addPRCRecipe(ItemStack inputSolid, FluidStack inputFluid, GasStack inputGas, ItemStack outputSolid, GasStack outputGas, double extraEnergy, int ticks)
|
||||
{
|
||||
try {
|
||||
Class recipeClass = Class.forName("mekanism.common.recipe.RecipeHandler");
|
||||
Method m = recipeClass.getMethod("addPRCRecipe", PressurizedReactants.class, PressurizedProducts.class, Double.TYPE, Integer.TYPE);
|
||||
m.invoke(null, input, output);
|
||||
Method m = recipeClass.getMethod("addPRCRecipe", ItemStack.class, FluidStack.class, GasStack.class, ItemStack.class, GasStack.class, Double.TYPE, Integer.TYPE);
|
||||
m.invoke(null, inputSolid, inputFluid, inputGas, outputSolid, outputGas, extraEnergy, ticks);
|
||||
} catch(Exception e) {
|
||||
System.err.println("Error while adding recipe: " + e.getMessage());
|
||||
}
|
||||
|
|
|
@ -58,6 +58,11 @@ public final class StackUtils
|
|||
return wild.getItem() == check.getItem() && (wild.getItemDamage() == OreDictionary.WILDCARD_VALUE || wild.getItemDamage() == check.getItemDamage());
|
||||
}
|
||||
|
||||
public static boolean equalsWildcardWithNBT(ItemStack wild, ItemStack check)
|
||||
{
|
||||
return equalsWildcard(wild, check) && (wild.stackTagCompound == null ? check.stackTagCompound == null : (wild.stackTagCompound == check.stackTagCompound || wild.stackTagCompound.equals(check.stackTagCompound)));
|
||||
}
|
||||
|
||||
public static List<ItemStack> even(ItemStack stack1, ItemStack stack2)
|
||||
{
|
||||
ArrayList<ItemStack> ret = new ArrayList<ItemStack>();
|
||||
|
@ -225,4 +230,9 @@ public final class StackUtils
|
|||
return StackUtils.size(orig, newSize);
|
||||
}
|
||||
}
|
||||
|
||||
public static int hashItemStack(ItemStack stack)
|
||||
{
|
||||
return Item.getIdFromItem(stack.getItem()) << 8 | stack.getItemDamage();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
@ -8,7 +9,7 @@ import java.util.Set;
|
|||
|
||||
import mekanism.api.gas.Gas;
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.common.recipe.inputs.AdvancedMachineInput;
|
||||
import mekanism.client.gui.GuiElement;
|
||||
import mekanism.client.gui.GuiPowerBar;
|
||||
import mekanism.client.gui.GuiPowerBar.IPowerInfoHandler;
|
||||
|
@ -19,6 +20,7 @@ import mekanism.client.gui.GuiSlot;
|
|||
import mekanism.client.gui.GuiSlot.SlotOverlay;
|
||||
import mekanism.client.gui.GuiSlot.SlotType;
|
||||
import mekanism.common.ObfuscatedNames;
|
||||
import mekanism.common.recipe.machines.AdvancedMachineRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
import mekanism.common.util.MekanismUtils.ResourceType;
|
||||
|
||||
|
@ -43,7 +45,7 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
public abstract String getRecipeId();
|
||||
|
||||
public abstract Set<Entry<AdvancedInput, ItemStack>> getRecipes();
|
||||
public abstract Collection<? extends AdvancedMachineRecipe> getRecipes();
|
||||
|
||||
public abstract List<ItemStack> getFuelStacks(Gas gasType);
|
||||
|
||||
|
@ -117,9 +119,9 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry<AdvancedInput, ItemStack> irecipe : getRecipes())
|
||||
for(AdvancedMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getKey().gasType)));
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getInput().gasType)));
|
||||
}
|
||||
}
|
||||
else {
|
||||
|
@ -130,11 +132,11 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadCraftingRecipes(ItemStack result)
|
||||
{
|
||||
for(Map.Entry<AdvancedInput, ItemStack> irecipe : getRecipes())
|
||||
for(AdvancedMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getValue(), result))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getOutput().output, result))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getKey().gasType)));
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getInput().gasType)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -150,11 +152,11 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(inputId.equals("gas") && ingredients.length == 1 && ingredients[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<AdvancedInput, ItemStack> irecipe : getRecipes())
|
||||
for(AdvancedMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getKey().gasType == ((GasStack)ingredients[0]).getGas())
|
||||
if(irecipe.getInput().gasType == ((GasStack)ingredients[0]).getGas())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getKey().gasType)));
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getInput().gasType)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -166,11 +168,11 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadUsageRecipes(ItemStack ingredient)
|
||||
{
|
||||
for(Map.Entry<AdvancedInput, ItemStack> irecipe : getRecipes())
|
||||
for(AdvancedMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getKey().itemStack, ingredient))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getInput().itemStack, ingredient))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getKey().gasType)));
|
||||
arecipes.add(new CachedIORecipe(irecipe, getFuelStacks(irecipe.getInput().gasType)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -270,7 +272,7 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
public List<ItemStack> fuelStacks;
|
||||
|
||||
public AdvancedInput input;
|
||||
public AdvancedMachineInput input;
|
||||
|
||||
public PositionedStack outputStack;
|
||||
|
||||
|
@ -292,16 +294,16 @@ public abstract class AdvancedMachineRecipeHandler extends BaseRecipeHandler
|
|||
return new PositionedStack(fuelStacks.get(cycleticks/40 % fuelStacks.size()), 40, 48);
|
||||
}
|
||||
|
||||
public CachedIORecipe(AdvancedInput adv, ItemStack output, List<ItemStack> fuels)
|
||||
public CachedIORecipe(AdvancedMachineInput adv, ItemStack output, List<ItemStack> fuels)
|
||||
{
|
||||
input = adv;
|
||||
outputStack = new PositionedStack(output, 100, 30);
|
||||
fuelStacks = fuels;
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe, List<ItemStack> fuels)
|
||||
public CachedIORecipe(AdvancedMachineRecipe recipe, List<ItemStack> fuels)
|
||||
{
|
||||
this((AdvancedInput)recipe.getKey(), (ItemStack)recipe.getValue(), fuels);
|
||||
this(recipe.getInput(), recipe.getOutput().output, fuels);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,11 +1,14 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
import java.util.Set;
|
||||
|
||||
import mekanism.api.recipe.ChanceOutput;
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.machines.ChanceMachineRecipe;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
import mekanism.client.gui.GuiElement;
|
||||
import mekanism.client.gui.GuiPowerBar;
|
||||
import mekanism.client.gui.GuiPowerBar.IPowerInfoHandler;
|
||||
|
@ -36,7 +39,7 @@ public abstract class ChanceMachineRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
public abstract String getRecipeId();
|
||||
|
||||
public abstract Set<Entry<ItemStack, ChanceOutput>> getRecipes();
|
||||
public abstract Collection<? extends ChanceMachineRecipe> getRecipes();
|
||||
|
||||
public abstract ProgressBar getProgressType();
|
||||
|
||||
|
@ -106,7 +109,7 @@ public abstract class ChanceMachineRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(ChanceMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -119,13 +122,13 @@ public abstract class ChanceMachineRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadCraftingRecipes(ItemStack result)
|
||||
{
|
||||
for(Map.Entry<ItemStack, ChanceOutput> irecipe : getRecipes())
|
||||
for(ChanceMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getValue().hasPrimary() && NEIServerUtils.areStacksSameTypeCrafting(irecipe.getValue().primaryOutput, result))
|
||||
if(irecipe.getOutput().hasPrimary() && NEIServerUtils.areStacksSameTypeCrafting(irecipe.getOutput().primaryOutput, result))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
else if(irecipe.getValue().hasSecondary() && NEIServerUtils.areStacksSameTypeCrafting(irecipe.getValue().secondaryOutput, result))
|
||||
else if(irecipe.getOutput().hasSecondary() && NEIServerUtils.areStacksSameTypeCrafting(irecipe.getOutput().secondaryOutput, result))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -141,9 +144,9 @@ public abstract class ChanceMachineRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadUsageRecipes(ItemStack ingredient)
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(ChanceMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getKey(), ingredient))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getInput().ingredient, ingredient))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -189,9 +192,9 @@ public abstract class ChanceMachineRecipeHandler extends BaseRecipeHandler
|
|||
output = chance;
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(ChanceMachineRecipe recipe)
|
||||
{
|
||||
this((ItemStack)recipe.getKey(), (ChanceOutput)recipe.getValue());
|
||||
this(recipe.getInput().ingredient, recipe.getOutput());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
@ -10,6 +11,7 @@ import mekanism.api.gas.GasStack;
|
|||
import mekanism.client.gui.GuiChemicalCrystallizer;
|
||||
import mekanism.common.ObfuscatedNames;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.CrystallizerRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.client.gui.inventory.GuiContainer;
|
||||
|
@ -63,9 +65,9 @@ public class ChemicalCrystallizerRecipeHandler extends BaseRecipeHandler
|
|||
return "mekanism.chemicalcrystallizer";
|
||||
}
|
||||
|
||||
public Set<Entry<GasStack, ItemStack>> getRecipes()
|
||||
public Collection<CrystallizerRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CHEMICAL_CRYSTALLIZER.get().entrySet();
|
||||
return Recipe.CHEMICAL_CRYSTALLIZER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -109,7 +111,7 @@ public class ChemicalCrystallizerRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(CrystallizerRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -122,9 +124,9 @@ public class ChemicalCrystallizerRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadCraftingRecipes(ItemStack result)
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(CrystallizerRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getValue(), result))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getOutput().output, result))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -230,9 +232,9 @@ public class ChemicalCrystallizerRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(inputId.equals("gas") && ingredients.length == 1 && ingredients[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<GasStack, ItemStack> irecipe : getRecipes())
|
||||
for(CrystallizerRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getKey().isGasEqual((GasStack)ingredients[0]))
|
||||
if(irecipe.getInput().ingredient.isGasEqual((GasStack)ingredients[0]))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -266,9 +268,9 @@ public class ChemicalCrystallizerRecipeHandler extends BaseRecipeHandler
|
|||
outputStack = new PositionedStack(output, 131-xOffset, 57-yOffset);
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(CrystallizerRecipe recipe)
|
||||
{
|
||||
this((GasStack)recipe.getKey(), (ItemStack)recipe.getValue());
|
||||
this(recipe.getInput().ingredient, recipe.getOutput().output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
@ -11,6 +12,7 @@ import mekanism.api.gas.GasStack;
|
|||
import mekanism.client.gui.GuiChemicalDissolutionChamber;
|
||||
import mekanism.common.ObfuscatedNames;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.DissolutionRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.client.gui.inventory.GuiContainer;
|
||||
|
@ -64,9 +66,9 @@ public class ChemicalDissolutionChamberRecipeHandler extends BaseRecipeHandler
|
|||
return "mekanism.chemicaldissolutionchamber";
|
||||
}
|
||||
|
||||
public Set<Entry<ItemStack, GasStack>> getRecipes()
|
||||
public Collection<DissolutionRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get().entrySet();
|
||||
return Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -112,16 +114,16 @@ public class ChemicalDissolutionChamberRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(DissolutionRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
}
|
||||
else if(outputId.equals("gas") && results.length == 1 && results[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<ItemStack, GasStack> irecipe : getRecipes())
|
||||
for(DissolutionRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getValue()))
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getOutput().output))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -241,9 +243,9 @@ public class ChemicalDissolutionChamberRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadUsageRecipes(ItemStack ingredient)
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(DissolutionRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getKey(), ingredient))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getInput().ingredient, ingredient))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -279,9 +281,9 @@ public class ChemicalDissolutionChamberRecipeHandler extends BaseRecipeHandler
|
|||
outputStack = output;
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(DissolutionRecipe recipe)
|
||||
{
|
||||
this((ItemStack)recipe.getKey(), (GasStack)recipe.getValue());
|
||||
this(recipe.getInput().ingredient, recipe.getOutput().output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,16 +1,18 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
import java.util.Set;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.recipe.ChemicalPair;
|
||||
import mekanism.common.recipe.inputs.ChemicalPairInput;
|
||||
import mekanism.client.gui.GuiChemicalInfuser;
|
||||
import mekanism.common.ObfuscatedNames;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.ChemicalInfuserRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.client.gui.inventory.GuiContainer;
|
||||
|
@ -62,9 +64,9 @@ public class ChemicalInfuserRecipeHandler extends BaseRecipeHandler
|
|||
return "mekanism.chemicalinfuser";
|
||||
}
|
||||
|
||||
public Set<Entry<ChemicalPair, GasStack>> getRecipes()
|
||||
public Collection<ChemicalInfuserRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CHEMICAL_INFUSER.get().entrySet();
|
||||
return Recipe.CHEMICAL_INFUSER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -119,16 +121,16 @@ public class ChemicalInfuserRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(ChemicalInfuserRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
}
|
||||
else if(outputId.equals("gas") && results.length == 1 && results[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<ChemicalPair, GasStack> irecipe : getRecipes())
|
||||
for(ChemicalInfuserRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getValue()))
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getOutput().output))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -144,9 +146,9 @@ public class ChemicalInfuserRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(inputId.equals("gas") && ingredients.length == 1 && ingredients[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<ChemicalPair, GasStack> irecipe : getRecipes())
|
||||
for(ChemicalInfuserRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getKey().containsType((GasStack)ingredients[0]))
|
||||
if(irecipe.getInput().containsType((GasStack)ingredients[0]))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -283,7 +285,7 @@ public class ChemicalInfuserRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
public class CachedIORecipe extends TemplateRecipeHandler.CachedRecipe
|
||||
{
|
||||
public ChemicalPair chemicalInput;
|
||||
public ChemicalPairInput chemicalInput;
|
||||
public GasStack outputStack;
|
||||
|
||||
@Override
|
||||
|
@ -292,15 +294,15 @@ public class ChemicalInfuserRecipeHandler extends BaseRecipeHandler
|
|||
return null;
|
||||
}
|
||||
|
||||
public CachedIORecipe(ChemicalPair input, GasStack output)
|
||||
public CachedIORecipe(ChemicalPairInput input, GasStack output)
|
||||
{
|
||||
chemicalInput = input;
|
||||
outputStack = output;
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(ChemicalInfuserRecipe recipe)
|
||||
{
|
||||
this((ChemicalPair)recipe.getKey(), (GasStack)recipe.getValue());
|
||||
this(recipe.getInput(), recipe.getOutput().output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
|
@ -10,6 +11,7 @@ import mekanism.api.util.ListUtils;
|
|||
import mekanism.client.gui.GuiChemicalInjectionChamber;
|
||||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.InjectionRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
@ -36,9 +38,9 @@ public class ChemicalInjectionChamberRecipeHandler extends AdvancedMachineRecipe
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<InjectionRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CHEMICAL_INJECTION_CHAMBER.get().entrySet();
|
||||
return Recipe.CHEMICAL_INJECTION_CHAMBER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
@ -19,6 +20,7 @@ import mekanism.client.gui.GuiSlot.SlotOverlay;
|
|||
import mekanism.client.gui.GuiSlot.SlotType;
|
||||
import mekanism.common.ObfuscatedNames;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.OxidationRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
import mekanism.common.util.MekanismUtils.ResourceType;
|
||||
|
||||
|
@ -94,9 +96,9 @@ public class ChemicalOxidizerRecipeHandler extends BaseRecipeHandler
|
|||
return "mekanism.chemicaloxidizer";
|
||||
}
|
||||
|
||||
public Set<Entry<ItemStack, GasStack>> getRecipes()
|
||||
public Collection<OxidationRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CHEMICAL_OXIDIZER.get().entrySet();
|
||||
return Recipe.CHEMICAL_OXIDIZER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -143,16 +145,16 @@ public class ChemicalOxidizerRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(OxidationRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
}
|
||||
else if(outputId.equals("gas") && results.length == 1 && results[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<ItemStack, GasStack> irecipe : getRecipes())
|
||||
for(OxidationRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getValue()))
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getOutput().output))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -253,9 +255,9 @@ public class ChemicalOxidizerRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadUsageRecipes(ItemStack ingredient)
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(OxidationRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getKey(), ingredient))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getInput().ingredient, ingredient))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -285,9 +287,9 @@ public class ChemicalOxidizerRecipeHandler extends BaseRecipeHandler
|
|||
outputStack = output;
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(OxidationRecipe recipe)
|
||||
{
|
||||
this((ItemStack)recipe.getKey(), (GasStack)recipe.getValue());
|
||||
this(recipe.getInput().ingredient, recipe.getOutput().output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
@ -10,6 +11,7 @@ import mekanism.api.gas.GasStack;
|
|||
import mekanism.client.gui.GuiChemicalWasher;
|
||||
import mekanism.common.ObfuscatedNames;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.WasherRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.client.gui.inventory.GuiContainer;
|
||||
|
@ -63,9 +65,9 @@ public class ChemicalWasherRecipeHandler extends BaseRecipeHandler
|
|||
return "mekanism.chemicalwasher";
|
||||
}
|
||||
|
||||
public Set<Entry<GasStack, GasStack>> getRecipes()
|
||||
public Collection<WasherRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CHEMICAL_WASHER.get().entrySet();
|
||||
return Recipe.CHEMICAL_WASHER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -115,16 +117,16 @@ public class ChemicalWasherRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(WasherRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
}
|
||||
else if(outputId.equals("gas") && results.length == 1 && results[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<GasStack, GasStack> irecipe : getRecipes())
|
||||
for(WasherRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getValue()))
|
||||
if(((GasStack)results[0]).isGasEqual(irecipe.getOutput().output))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -142,7 +144,7 @@ public class ChemicalWasherRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(((FluidStack)ingredients[0]).getFluid() == FluidRegistry.WATER)
|
||||
{
|
||||
for(Map.Entry<GasStack, GasStack> irecipe : getRecipes())
|
||||
for(WasherRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -150,9 +152,9 @@ public class ChemicalWasherRecipeHandler extends BaseRecipeHandler
|
|||
}
|
||||
else if(inputId.equals("gas") && ingredients.length == 1 && ingredients[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<GasStack, GasStack> irecipe : getRecipes())
|
||||
for(WasherRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getKey().isGasEqual((GasStack)ingredients[0]))
|
||||
if(irecipe.getOutput().output.isGasEqual((GasStack)ingredients[0]))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -340,9 +342,9 @@ public class ChemicalWasherRecipeHandler extends BaseRecipeHandler
|
|||
outputStack = output;
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(WasherRecipe recipe)
|
||||
{
|
||||
this((GasStack)recipe.getKey(), (GasStack)recipe.getValue());
|
||||
this(recipe.getInput().ingredient, recipe.getOutput().output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
|
@ -8,6 +9,7 @@ import mekanism.api.util.ListUtils;
|
|||
import mekanism.client.gui.GuiCombiner;
|
||||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.CombinerRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.init.Blocks;
|
||||
|
@ -34,9 +36,9 @@ public class CombinerRecipeHandler extends AdvancedMachineRecipeHandler
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<CombinerRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.COMBINER.get().entrySet();
|
||||
return Recipe.COMBINER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -1,10 +1,12 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Set;
|
||||
|
||||
import mekanism.client.gui.GuiCrusher;
|
||||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.CrusherRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
public class CrusherRecipeHandler extends MachineRecipeHandler
|
||||
|
@ -34,9 +36,9 @@ public class CrusherRecipeHandler extends MachineRecipeHandler
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<CrusherRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.CRUSHER.get().entrySet();
|
||||
return Recipe.CRUSHER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -7,7 +7,7 @@ import java.util.Map.Entry;
|
|||
import java.util.Set;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.recipe.ChemicalPair;
|
||||
import mekanism.common.recipe.inputs.ChemicalPairInput;
|
||||
import mekanism.client.gui.GuiElectrolyticSeparator;
|
||||
import mekanism.client.gui.GuiElement;
|
||||
import mekanism.client.gui.GuiFluidGauge;
|
||||
|
@ -110,7 +110,7 @@ public class ElectrolyticSeparatorRecipeHandler extends BaseRecipeHandler
|
|||
return "mekanism.electrolyticseparator";
|
||||
}
|
||||
|
||||
public Set<Entry<FluidStack, ChemicalPair>> getRecipes()
|
||||
public Set<Entry<FluidStack, ChemicalPairInput>> getRecipes()
|
||||
{
|
||||
return Recipe.ELECTROLYTIC_SEPARATOR.get().entrySet();
|
||||
}
|
||||
|
@ -180,7 +180,7 @@ public class ElectrolyticSeparatorRecipeHandler extends BaseRecipeHandler
|
|||
}
|
||||
else if(outputId.equals("gas") && results.length == 1 && results[0] instanceof GasStack)
|
||||
{
|
||||
for(Map.Entry<FluidStack, ChemicalPair> irecipe : getRecipes())
|
||||
for(Map.Entry<FluidStack, ChemicalPairInput> irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getValue().containsType((GasStack)results[0]))
|
||||
{
|
||||
|
@ -198,7 +198,7 @@ public class ElectrolyticSeparatorRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(inputId.equals("fluid") && ingredients.length == 1 && ingredients[0] instanceof FluidStack)
|
||||
{
|
||||
for(Map.Entry<FluidStack, ChemicalPair> irecipe : getRecipes())
|
||||
for(Map.Entry<FluidStack, ChemicalPairInput> irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getKey().isFluidEqual((FluidStack)ingredients[0]))
|
||||
{
|
||||
|
@ -368,7 +368,7 @@ public class ElectrolyticSeparatorRecipeHandler extends BaseRecipeHandler
|
|||
public class CachedIORecipe extends TemplateRecipeHandler.CachedRecipe
|
||||
{
|
||||
public FluidStack fluidInput;
|
||||
public ChemicalPair outputPair;
|
||||
public ChemicalPairInput outputPair;
|
||||
|
||||
@Override
|
||||
public PositionedStack getResult()
|
||||
|
@ -376,7 +376,7 @@ public class ElectrolyticSeparatorRecipeHandler extends BaseRecipeHandler
|
|||
return null;
|
||||
}
|
||||
|
||||
public CachedIORecipe(FluidStack input, ChemicalPair pair)
|
||||
public CachedIORecipe(FluidStack input, ChemicalPairInput pair)
|
||||
{
|
||||
fluidInput = input;
|
||||
outputPair = pair;
|
||||
|
@ -384,7 +384,7 @@ public class ElectrolyticSeparatorRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
{
|
||||
this((FluidStack)recipe.getKey(), (ChemicalPair)recipe.getValue());
|
||||
this((FluidStack)recipe.getKey(), (ChemicalPairInput)recipe.getValue());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,10 +1,12 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Set;
|
||||
|
||||
import mekanism.client.gui.GuiEnrichmentChamber;
|
||||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.EnrichmentRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
public class EnrichmentChamberRecipeHandler extends MachineRecipeHandler
|
||||
|
@ -34,9 +36,9 @@ public class EnrichmentChamberRecipeHandler extends MachineRecipeHandler
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<EnrichmentRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.ENRICHMENT_CHAMBER.get().entrySet();
|
||||
return Recipe.ENRICHMENT_CHAMBER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Collection;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
import java.util.Set;
|
||||
|
@ -14,6 +15,7 @@ import mekanism.client.gui.GuiProgress.ProgressBar;
|
|||
import mekanism.client.gui.GuiSlot;
|
||||
import mekanism.client.gui.GuiSlot.SlotOverlay;
|
||||
import mekanism.client.gui.GuiSlot.SlotType;
|
||||
import mekanism.common.recipe.machines.BasicMachineRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
import mekanism.common.util.MekanismUtils.ResourceType;
|
||||
|
||||
|
@ -34,7 +36,7 @@ public abstract class MachineRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
public abstract String getRecipeId();
|
||||
|
||||
public abstract Set<Entry<ItemStack, ItemStack>> getRecipes();
|
||||
public abstract Collection<? extends BasicMachineRecipe> getRecipes();
|
||||
|
||||
public abstract ProgressBar getProgressType();
|
||||
|
||||
|
@ -93,7 +95,7 @@ public abstract class MachineRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
if(outputId.equals(getRecipeId()))
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(BasicMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -106,9 +108,9 @@ public abstract class MachineRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadCraftingRecipes(ItemStack result)
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(BasicMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getValue(), result))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getOutput().output, result))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -124,9 +126,9 @@ public abstract class MachineRecipeHandler extends BaseRecipeHandler
|
|||
@Override
|
||||
public void loadUsageRecipes(ItemStack ingredient)
|
||||
{
|
||||
for(Map.Entry irecipe : getRecipes())
|
||||
for(BasicMachineRecipe irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting((ItemStack)irecipe.getKey(), ingredient))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getInput().ingredient, ingredient))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -158,9 +160,9 @@ public abstract class MachineRecipeHandler extends BaseRecipeHandler
|
|||
output = new PositionedStack(itemstack1, 100, 30);
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
public CachedIORecipe(BasicMachineRecipe recipe)
|
||||
{
|
||||
this((ItemStack)recipe.getKey(), (ItemStack)recipe.getValue());
|
||||
this(recipe.getInput().ingredient, recipe.getOutput().output);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -10,8 +10,8 @@ import java.util.Set;
|
|||
import mekanism.api.infuse.InfuseObject;
|
||||
import mekanism.api.infuse.InfuseRegistry;
|
||||
import mekanism.api.infuse.InfuseType;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.api.infuse.InfusionOutput;
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.recipe.outputs.InfusionOutput;
|
||||
import mekanism.client.gui.GuiElement;
|
||||
import mekanism.client.gui.GuiMetallurgicInfuser;
|
||||
import mekanism.client.gui.GuiPowerBar;
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
|
@ -9,6 +10,7 @@ import mekanism.client.gui.GuiOsmiumCompressor;
|
|||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.common.MekanismItems;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.OsmiumCompressorRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
@ -34,9 +36,9 @@ public class OsmiumCompressorRecipeHandler extends AdvancedMachineRecipeHandler
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<OsmiumCompressorRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.OSMIUM_COMPRESSOR.get().entrySet();
|
||||
return Recipe.OSMIUM_COMPRESSOR.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -7,8 +7,8 @@ import java.util.Map.Entry;
|
|||
import java.util.Set;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.recipe.PressurizedReactants;
|
||||
import mekanism.api.recipe.PressurizedRecipe;
|
||||
import mekanism.common.recipe.inputs.PressurizedReactants;
|
||||
import mekanism.common.recipe.machines.PressurizedRecipe;
|
||||
import mekanism.client.gui.GuiElement;
|
||||
import mekanism.client.gui.GuiFluidGauge;
|
||||
import mekanism.client.gui.GuiGasGauge;
|
||||
|
@ -159,21 +159,21 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
CachedIORecipe recipe = (CachedIORecipe)arecipes.get(i);
|
||||
|
||||
if(recipe.pressurizedRecipe.reactants.getFluid() != null)
|
||||
if(recipe.pressurizedRecipe.getInput().getFluid() != null)
|
||||
{
|
||||
fluidInput.setDummyType(recipe.pressurizedRecipe.reactants.getFluid().getFluid());
|
||||
fluidInput.setDummyType(recipe.pressurizedRecipe.getInput().getFluid().getFluid());
|
||||
fluidInput.renderScale(0, 0, -xOffset, -yOffset);
|
||||
}
|
||||
|
||||
if(recipe.pressurizedRecipe.reactants.getGas() != null)
|
||||
if(recipe.pressurizedRecipe.getInput().getGas() != null)
|
||||
{
|
||||
gasInput.setDummyType(recipe.pressurizedRecipe.reactants.getGas().getGas());
|
||||
gasInput.setDummyType(recipe.pressurizedRecipe.getInput().getGas().getGas());
|
||||
gasInput.renderScale(0, 0, -xOffset, -yOffset);
|
||||
}
|
||||
|
||||
if(recipe.pressurizedRecipe.products.getGasOutput() != null)
|
||||
if(recipe.pressurizedRecipe.getOutput().getGasOutput() != null)
|
||||
{
|
||||
gasOutput.setDummyType(recipe.pressurizedRecipe.products.getGasOutput().getGas());
|
||||
gasOutput.setDummyType(recipe.pressurizedRecipe.getOutput().getGasOutput().getGas());
|
||||
gasOutput.renderScale(0, 0, -xOffset, -yOffset);
|
||||
}
|
||||
}
|
||||
|
@ -192,7 +192,7 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
for(Map.Entry<PressurizedReactants, PressurizedRecipe> irecipe : getRecipes())
|
||||
{
|
||||
if(irecipe.getValue().reactants.containsType((GasStack)results[0]))
|
||||
if(irecipe.getValue().getInput().containsType((GasStack)results[0]))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -208,7 +208,7 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
{
|
||||
for(Map.Entry<PressurizedReactants, PressurizedRecipe> irecipe : getRecipes())
|
||||
{
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getValue().products.getItemOutput(), result))
|
||||
if(NEIServerUtils.areStacksSameTypeCrafting(irecipe.getValue().getOutput().getItemOutput(), result))
|
||||
{
|
||||
arecipes.add(new CachedIORecipe(irecipe));
|
||||
}
|
||||
|
@ -266,15 +266,15 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
if(xAxis >= 6-5 && xAxis <= 22-5 && yAxis >= 11-10 && yAxis <= 69-10)
|
||||
{
|
||||
currenttip.add(LangUtils.localizeFluidStack(((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.reactants.getFluid()));
|
||||
currenttip.add(LangUtils.localizeFluidStack(((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getInput().getFluid()));
|
||||
}
|
||||
else if(xAxis >= 29-5 && xAxis <= 45-5 && yAxis >= 11-10 && yAxis <= 69-10)
|
||||
{
|
||||
currenttip.add(((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.reactants.getGas().getGas().getLocalizedName());
|
||||
currenttip.add(((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getInput().getGas().getGas().getLocalizedName());
|
||||
}
|
||||
else if(xAxis >= 141-5 && xAxis <= 157-5 && yAxis >= 41-10 && yAxis <= 69-10)
|
||||
{
|
||||
currenttip.add(((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.products.getGasOutput().getGas().getLocalizedName());
|
||||
currenttip.add(((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getOutput().getGasOutput().getGas().getLocalizedName());
|
||||
}
|
||||
|
||||
return super.handleTooltip(gui, currenttip, recipe);
|
||||
|
@ -294,15 +294,15 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
if(xAxis >= 6-5 && xAxis <= 22-5 && yAxis >= 11-10 && yAxis <= 69-10)
|
||||
{
|
||||
fluid = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.reactants.getFluid();
|
||||
fluid = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getInput().getFluid();
|
||||
}
|
||||
else if(xAxis >= 29-5 && xAxis <= 45-5 && yAxis >= 11-10 && yAxis <= 69-10)
|
||||
{
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.reactants.getGas();
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getInput().getGas();
|
||||
}
|
||||
else if(xAxis >= 141-5 && xAxis <= 157-5 && yAxis >= 41-10 && yAxis <= 69-10)
|
||||
{
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.products.getGasOutput();
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getOutput().getGasOutput();
|
||||
}
|
||||
|
||||
if(gas != null)
|
||||
|
@ -357,15 +357,15 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
if(xAxis >= 6-5 && xAxis <= 22-5 && yAxis >= 11-10 && yAxis <= 69-10)
|
||||
{
|
||||
fluid = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.reactants.getFluid();
|
||||
fluid = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getInput().getFluid();
|
||||
}
|
||||
else if(xAxis >= 29-5 && xAxis <= 45-5 && yAxis >= 11-10 && yAxis <= 69-10)
|
||||
{
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.reactants.getGas();
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getInput().getGas();
|
||||
}
|
||||
else if(xAxis >= 141-5 && xAxis <= 157-5 && yAxis >= 41-10 && yAxis <= 69-10)
|
||||
{
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.products.getGasOutput();
|
||||
gas = ((CachedIORecipe)arecipes.get(recipe)).pressurizedRecipe.getOutput().getGasOutput();
|
||||
}
|
||||
|
||||
if(gas != null)
|
||||
|
@ -431,8 +431,8 @@ public class PRCRecipeHandler extends BaseRecipeHandler
|
|||
|
||||
pressurizedRecipe = recipe;
|
||||
|
||||
input = new PositionedStack(recipe.reactants.getSolid(), 54-xOffset, 35-yOffset);
|
||||
output = new PositionedStack(recipe.products.getItemOutput(), 116-xOffset, 35-yOffset);
|
||||
input = new PositionedStack(recipe.getInput().getSolid(), 54-xOffset, 35-yOffset);
|
||||
output = new PositionedStack(recipe.getOutput().getItemOutput(), 116-xOffset, 35-yOffset);
|
||||
}
|
||||
|
||||
public CachedIORecipe(Map.Entry recipe)
|
||||
|
|
|
@ -1,10 +1,13 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Set;
|
||||
|
||||
import mekanism.client.gui.GuiPrecisionSawmill;
|
||||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.ChanceMachineRecipe;
|
||||
import mekanism.common.recipe.machines.SawmillRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
public class PrecisionSawmillRecipeHandler extends ChanceMachineRecipeHandler
|
||||
|
@ -28,9 +31,9 @@ public class PrecisionSawmillRecipeHandler extends ChanceMachineRecipeHandler
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<SawmillRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.PRECISION_SAWMILL.get().entrySet();
|
||||
return Recipe.PRECISION_SAWMILL.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package mekanism.client.nei;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
|
@ -10,6 +11,7 @@ import mekanism.api.util.ListUtils;
|
|||
import mekanism.client.gui.GuiProgress.ProgressBar;
|
||||
import mekanism.client.gui.GuiPurificationChamber;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
import mekanism.common.recipe.machines.PurificationRecipe;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
||||
import net.minecraft.init.Items;
|
||||
|
@ -36,9 +38,9 @@ public class PurificationChamberRecipeHandler extends AdvancedMachineRecipeHandl
|
|||
}
|
||||
|
||||
@Override
|
||||
public Set getRecipes()
|
||||
public Collection<PurificationRecipe> getRecipes()
|
||||
{
|
||||
return Recipe.PURIFICATION_CHAMBER.get().entrySet();
|
||||
return Recipe.PURIFICATION_CHAMBER.get().values();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -22,12 +22,12 @@ import mekanism.api.gas.OreGas;
|
|||
import mekanism.api.infuse.InfuseObject;
|
||||
import mekanism.api.infuse.InfuseRegistry;
|
||||
import mekanism.api.infuse.InfuseType;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.api.recipe.ChanceOutput;
|
||||
import mekanism.api.recipe.ChemicalPair;
|
||||
import mekanism.api.recipe.PressurizedProducts;
|
||||
import mekanism.api.recipe.PressurizedReactants;
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.recipe.inputs.ChemicalPairInput;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
import mekanism.common.recipe.outputs.ChemicalPairOutput;
|
||||
import mekanism.common.recipe.outputs.PressurizedProducts;
|
||||
import mekanism.common.recipe.inputs.PressurizedReactants;
|
||||
import mekanism.api.transmitters.DynamicNetwork.ClientTickUpdate;
|
||||
import mekanism.api.transmitters.DynamicNetwork.NetworkClientRequest;
|
||||
import mekanism.api.transmitters.TransmitterNetworkRegistry;
|
||||
|
@ -680,44 +680,44 @@ public class Mekanism
|
|||
RecipeHandler.addPurificationChamberRecipe(new ItemStack(Blocks.gravel), new ItemStack(Items.flint));
|
||||
|
||||
//Chemical Injection Chamber Recipes
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(new ItemStack(Blocks.obsidian), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 6));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(new ItemStack(Blocks.dirt), GasRegistry.getGas("water")), new ItemStack(Blocks.clay));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(new ItemStack(Items.gunpowder), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Dust, 1, 10));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new ItemStack(Blocks.obsidian), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 6));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new ItemStack(Blocks.dirt), "water", new ItemStack(Blocks.clay));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new ItemStack(Items.gunpowder), "hydrogenChloride", new ItemStack(MekanismItems.Dust, 1, 10));
|
||||
|
||||
//Precision Sawmill Recipes
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.ladder, 3), new ChanceOutput(new ItemStack(Items.stick, 7)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.chest), new ChanceOutput(new ItemStack(Blocks.planks, 8)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.trapdoor), new ChanceOutput(new ItemStack(Blocks.planks, 3)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Items.boat), new ChanceOutput(new ItemStack(Blocks.planks, 5)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Items.bed), new ChanceOutput(new ItemStack(Blocks.planks, 3), new ItemStack(Blocks.wool, 3), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.jukebox), new ChanceOutput(new ItemStack(Blocks.planks, 8), new ItemStack(Items.diamond), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.bookshelf), new ChanceOutput(new ItemStack(Blocks.planks, 6), new ItemStack(Items.book, 3), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.wooden_pressure_plate), new ChanceOutput(new ItemStack(Blocks.planks, 2)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.fence), new ChanceOutput(new ItemStack(Items.stick, 3)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.fence_gate), new ChanceOutput(new ItemStack(Blocks.planks, 2), new ItemStack(Items.stick, 4), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.noteblock), new ChanceOutput(new ItemStack(Blocks.planks, 8), new ItemStack(Items.redstone, 1), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.redstone_torch), new ChanceOutput(new ItemStack(Items.stick, 1), new ItemStack(Items.redstone), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.crafting_table), new ChanceOutput(new ItemStack(Blocks.planks, 4)));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.ladder, 3), new ItemStack(Items.stick, 7));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.chest), new ItemStack(Blocks.planks, 8));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.trapdoor), new ItemStack(Blocks.planks, 3));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Items.boat), new ItemStack(Blocks.planks, 5));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Items.bed), new ItemStack(Blocks.planks, 3), new ItemStack(Blocks.wool, 3), 1);
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.jukebox), new ItemStack(Blocks.planks, 8), new ItemStack(Items.diamond), 1);
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.bookshelf), new ItemStack(Blocks.planks, 6), new ItemStack(Items.book, 3), 1);
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.wooden_pressure_plate), new ItemStack(Blocks.planks, 2));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.fence), new ItemStack(Items.stick, 3));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.fence_gate), new ItemStack(Blocks.planks, 2), new ItemStack(Items.stick, 4), 1);
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.noteblock), new ItemStack(Blocks.planks, 8), new ItemStack(Items.redstone), 1);
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.redstone_torch), new ItemStack(Items.stick), new ItemStack(Items.redstone), 1);
|
||||
RecipeHandler.addPrecisionSawmillRecipe(new ItemStack(Blocks.crafting_table), new ItemStack(Blocks.planks, 4));
|
||||
|
||||
//Metallurgic Infuser Recipes
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("CARBON"), 10, new ItemStack(Items.iron_ingot)), new ItemStack(MekanismItems.EnrichedIron));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("CARBON"), 10, new ItemStack(MekanismItems.EnrichedIron)), new ItemStack(MekanismItems.Dust, 1, 5));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("REDSTONE"), 10, new ItemStack(Items.iron_ingot)), new ItemStack(MekanismItems.EnrichedAlloy));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("FUNGI"), 10, new ItemStack(Blocks.dirt)), new ItemStack(Blocks.mycelium));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("BIO"), 10, new ItemStack(Blocks.cobblestone)), new ItemStack(Blocks.mossy_cobblestone));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("BIO"), 10, new ItemStack(Blocks.stonebrick, 1, 0)), new ItemStack(Blocks.stonebrick, 1, 1));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("BIO"), 10, new ItemStack(Blocks.sand)), new ItemStack(Blocks.dirt));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("DIAMOND"), 10, new ItemStack(MekanismItems.EnrichedAlloy)), new ItemStack(MekanismItems.ReinforcedAlloy));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("OBSIDIAN"), 10, new ItemStack(MekanismItems.ReinforcedAlloy)), new ItemStack(MekanismItems.AtomicAlloy));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("CARBON"), 10, new ItemStack(Items.iron_ingot), new ItemStack(MekanismItems.EnrichedIron));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("CARBON"), 10, new ItemStack(MekanismItems.EnrichedIron), new ItemStack(MekanismItems.Dust, 1, 5));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("REDSTONE"), 10, new ItemStack(Items.iron_ingot), new ItemStack(MekanismItems.EnrichedAlloy));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("FUNGI"), 10, new ItemStack(Blocks.dirt), new ItemStack(Blocks.mycelium));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("BIO"), 10, new ItemStack(Blocks.cobblestone), new ItemStack(Blocks.mossy_cobblestone));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("BIO"), 10, new ItemStack(Blocks.stonebrick, 1, 0), new ItemStack(Blocks.stonebrick, 1, 1));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("BIO"), 10, new ItemStack(Blocks.sand), new ItemStack(Blocks.dirt));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("DIAMOND"), 10, new ItemStack(MekanismItems.EnrichedAlloy), new ItemStack(MekanismItems.ReinforcedAlloy));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("OBSIDIAN"), 10, new ItemStack(MekanismItems.ReinforcedAlloy), new ItemStack(MekanismItems.AtomicAlloy));
|
||||
|
||||
//Chemical Infuser Recipes
|
||||
RecipeHandler.addChemicalInfuserRecipe(new ChemicalPair(new GasStack(GasRegistry.getGas("oxygen"), 1), new GasStack(GasRegistry.getGas("sulfurDioxideGas"), 2)), new GasStack(GasRegistry.getGas("sulfurTrioxideGas"), 2));
|
||||
RecipeHandler.addChemicalInfuserRecipe(new ChemicalPair(new GasStack(GasRegistry.getGas("sulfurTrioxideGas"), 1), new GasStack(GasRegistry.getGas("water"), 1)), new GasStack(GasRegistry.getGas("sulfuricAcid"), 1));
|
||||
RecipeHandler.addChemicalInfuserRecipe(new ChemicalPair(new GasStack(GasRegistry.getGas("hydrogen"), 1), new GasStack(GasRegistry.getGas("chlorine"), 1)), new GasStack(GasRegistry.getGas("hydrogenChloride"), 1));
|
||||
RecipeHandler.addChemicalInfuserRecipe(new GasStack(GasRegistry.getGas("oxygen"), 1), new GasStack(GasRegistry.getGas("sulfurDioxideGas"), 2), new GasStack(GasRegistry.getGas("sulfurTrioxideGas"), 2));
|
||||
RecipeHandler.addChemicalInfuserRecipe(new GasStack(GasRegistry.getGas("sulfurTrioxideGas"), 1), new GasStack(GasRegistry.getGas("water"), 1), new GasStack(GasRegistry.getGas("sulfuricAcid"), 1));
|
||||
RecipeHandler.addChemicalInfuserRecipe(new GasStack(GasRegistry.getGas("hydrogen"), 1), new GasStack(GasRegistry.getGas("chlorine"), 1), new GasStack(GasRegistry.getGas("hydrogenChloride"), 1));
|
||||
|
||||
//Electrolytic Separator Recipes
|
||||
RecipeHandler.addElectrolyticSeparatorRecipe(FluidRegistry.getFluidStack("water", 2), new ChemicalPair(new GasStack(GasRegistry.getGas("hydrogen"), 2), new GasStack(GasRegistry.getGas("oxygen"), 1)));
|
||||
RecipeHandler.addElectrolyticSeparatorRecipe(FluidRegistry.getFluidStack("brine", 10), new ChemicalPair(new GasStack(GasRegistry.getGas("sodium"), 1), new GasStack(GasRegistry.getGas("chlorine"), 1)));
|
||||
RecipeHandler.addElectrolyticSeparatorRecipe(FluidRegistry.getFluidStack("water", 2), new GasStack(GasRegistry.getGas("hydrogen"), 2), new GasStack(GasRegistry.getGas("oxygen"), 1));
|
||||
RecipeHandler.addElectrolyticSeparatorRecipe(FluidRegistry.getFluidStack("brine", 10), new GasStack(GasRegistry.getGas("sodium"), 1), new GasStack(GasRegistry.getGas("chlorine"), 1));
|
||||
|
||||
//T4 Processing Recipes
|
||||
for(Gas gas : GasRegistry.getRegisteredGasses())
|
||||
|
@ -736,15 +736,15 @@ public class Mekanism
|
|||
|
||||
//Pressurized Reaction Chamber Recipes
|
||||
RecipeHandler.addPRCRecipe(
|
||||
new PressurizedReactants(new ItemStack(MekanismItems.BioFuel, 2), new FluidStack(FluidRegistry.WATER, 10), new GasStack(GasRegistry.getGas("hydrogen"), 100)),
|
||||
new PressurizedProducts(new ItemStack(MekanismItems.Substrate), new GasStack(GasRegistry.getGas("ethene"), 100)),
|
||||
new ItemStack(MekanismItems.BioFuel, 2), new FluidStack(FluidRegistry.WATER, 10), new GasStack(GasRegistry.getGas("hydrogen"), 100),
|
||||
new ItemStack(MekanismItems.Substrate), new GasStack(GasRegistry.getGas("ethene"), 100),
|
||||
0,
|
||||
100
|
||||
);
|
||||
|
||||
RecipeHandler.addPRCRecipe(
|
||||
new PressurizedReactants(new ItemStack(MekanismItems.Substrate), new FluidStack(FluidRegistry.getFluid("ethene"), 50), new GasStack(GasRegistry.getGas("oxygen"), 10)),
|
||||
new PressurizedProducts(new ItemStack(MekanismItems.Polyethene), new GasStack(GasRegistry.getGas("oxygen"), 5)),
|
||||
new ItemStack(MekanismItems.Substrate), new FluidStack(FluidRegistry.getFluid("ethene"), 50), new GasStack(GasRegistry.getGas("oxygen"), 10),
|
||||
new ItemStack(MekanismItems.Polyethene), new GasStack(GasRegistry.getGas("oxygen"), 5),
|
||||
1000,
|
||||
60
|
||||
);
|
||||
|
|
|
@ -4,7 +4,7 @@ import java.util.Map;
|
|||
|
||||
import mekanism.api.gas.Gas;
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.common.recipe.inputs.AdvancedMachineInput;
|
||||
import mekanism.api.util.StackUtils;
|
||||
import mekanism.common.block.BlockMachine.MachineType;
|
||||
import mekanism.common.recipe.RecipeHandler;
|
||||
|
@ -82,7 +82,7 @@ public interface IFactory
|
|||
|
||||
if(usesFuel())
|
||||
{
|
||||
return RecipeHandler.getOutput(new AdvancedInput(input, gas), stackDecrease, recipe.get());
|
||||
return RecipeHandler.getOutput(new AdvancedMachineInput(input, gas), stackDecrease, recipe.get());
|
||||
}
|
||||
else {
|
||||
return RecipeHandler.getOutput(input, stackDecrease, recipe.get());
|
||||
|
@ -148,11 +148,11 @@ public interface IFactory
|
|||
|
||||
for(Object obj : recipe.get().entrySet())
|
||||
{
|
||||
if(((Map.Entry)obj).getKey() instanceof AdvancedInput)
|
||||
if(((Map.Entry)obj).getKey() instanceof AdvancedMachineInput)
|
||||
{
|
||||
Map.Entry entry = (Map.Entry)obj;
|
||||
|
||||
ItemStack stack = ((AdvancedInput)entry.getKey()).itemStack;
|
||||
ItemStack stack = ((AdvancedMachineInput)entry.getKey()).itemStack;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, itemStack))
|
||||
{
|
||||
|
|
|
@ -261,26 +261,14 @@ public class BlockBasic extends Block implements IBlockCTM
|
|||
case BASIC_BLOCK_1:
|
||||
for(int i = 0; i < 16; i++)
|
||||
{
|
||||
list.add(new ItemStack(item, 1, 0));
|
||||
list.add(new ItemStack(item, 1, 1));
|
||||
list.add(new ItemStack(item, 1, 2));
|
||||
list.add(new ItemStack(item, 1, 3));
|
||||
list.add(new ItemStack(item, 1, 4));
|
||||
list.add(new ItemStack(item, 1, 5));
|
||||
list.add(new ItemStack(item, 1, 6));
|
||||
list.add(new ItemStack(item, 1, 7));
|
||||
list.add(new ItemStack(item, 1, 8));
|
||||
list.add(new ItemStack(item, 1, 9));
|
||||
list.add(new ItemStack(item, 1, 10));
|
||||
list.add(new ItemStack(item, 1, 11));
|
||||
list.add(new ItemStack(item, 1, 12));
|
||||
list.add(new ItemStack(item, 1, 13));
|
||||
list.add(new ItemStack(item, 1, 14));
|
||||
list.add(new ItemStack(item, 1, 15));
|
||||
list.add(new ItemStack(item, 1, i));
|
||||
}
|
||||
break;
|
||||
case BASIC_BLOCK_2:
|
||||
list.add(new ItemStack(item, 1, 0));
|
||||
for(int i = 0; i < 1; i++)
|
||||
{
|
||||
list.add(new ItemStack(item, 1, i));
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,9 +6,8 @@ import mekanism.api.gas.GasRegistry;
|
|||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.infuse.InfuseObject;
|
||||
import mekanism.api.infuse.InfuseRegistry;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.api.recipe.ChanceOutput;
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
import mekanism.api.util.StackUtils;
|
||||
import mekanism.common.Mekanism;
|
||||
import mekanism.common.MekanismBlocks;
|
||||
|
@ -45,11 +44,11 @@ public final class OreDictManager
|
|||
|
||||
if(!Recipe.PRECISION_SAWMILL.containsRecipe(wildStack))
|
||||
{
|
||||
RecipeHandler.addPrecisionSawmillRecipe(wildStack, new ChanceOutput(new ItemStack(Items.stick, 6), new ItemStack(MekanismItems.Sawdust), 0.25));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(wildStack, new ItemStack(Items.stick, 6), new ItemStack(MekanismItems.Sawdust), 0.25);
|
||||
}
|
||||
}
|
||||
else {
|
||||
RecipeHandler.addPrecisionSawmillRecipe(StackUtils.size(ore, 1), new ChanceOutput(new ItemStack(Items.stick, 6), new ItemStack(MekanismItems.Sawdust), 0.25));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(StackUtils.size(ore, 1), new ItemStack(Items.stick, 6), new ItemStack(MekanismItems.Sawdust), 0.25);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -62,7 +61,7 @@ public final class OreDictManager
|
|||
{
|
||||
for(ItemStack ore : OreDictionary.getOres("woodRubber"))
|
||||
{
|
||||
RecipeHandler.addPrecisionSawmillRecipe(MekanismUtils.size(ore, 1), new ChanceOutput(new ItemStack(Blocks.planks, 4), MekanismUtils.size(OreDictionary.getOres("itemRubber").get(0), 1), 1F));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(MekanismUtils.size(ore, 1), new ItemStack(Blocks.planks, 4), MekanismUtils.size(OreDictionary.getOres("itemRubber").get(0), 1), 1F);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -167,42 +166,42 @@ public final class OreDictManager
|
|||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalIron"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 0));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 0));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalGold"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 1));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 1));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalOsmium"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 2));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 2));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalCopper"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 3));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 3));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalTin"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 4));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 4));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalSilver"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 5));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 5));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalObsidian"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 6));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 6));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("crystalLead"))
|
||||
{
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 1, 7));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 1, 7));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("dustDirtyIron"))
|
||||
|
@ -244,7 +243,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 6));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 3));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 3));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 3));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("copper"), 1000));
|
||||
}
|
||||
|
||||
|
@ -252,7 +251,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 7));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 4));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 4));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 4));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("tin"), 1000));
|
||||
}
|
||||
|
||||
|
@ -260,7 +259,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 2));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 2));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 2));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 2));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("osmium"), 1000));
|
||||
}
|
||||
|
||||
|
@ -268,7 +267,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 0));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 0));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 0));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 0));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("iron"), 1000));
|
||||
}
|
||||
|
||||
|
@ -276,7 +275,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 1));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 1));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 1));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 1));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("gold"), 1000));
|
||||
}
|
||||
|
||||
|
@ -284,7 +283,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 8));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 5));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 5));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 5));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("silver"), 1000));
|
||||
}
|
||||
|
||||
|
@ -292,7 +291,7 @@ public final class OreDictManager
|
|||
{
|
||||
RecipeHandler.addEnrichmentChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 2, 9));
|
||||
RecipeHandler.addPurificationChamberRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Clump, 3, 7));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(new AdvancedInput(MekanismUtils.size(ore, 1), GasRegistry.getGas("hydrogenChloride")), new ItemStack(MekanismItems.Shard, 4, 7));
|
||||
RecipeHandler.addChemicalInjectionChamberRecipe(MekanismUtils.size(ore, 1), "hydrogenChloride", new ItemStack(MekanismItems.Shard, 4, 7));
|
||||
RecipeHandler.addChemicalDissolutionChamberRecipe(MekanismUtils.size(ore, 1), new GasStack(GasRegistry.getGas("lead"), 1000));
|
||||
}
|
||||
|
||||
|
@ -392,7 +391,7 @@ public final class OreDictManager
|
|||
for(ItemStack ore : OreDictionary.getOres("ingotOsmium"))
|
||||
{
|
||||
RecipeHandler.addCrusherRecipe(MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 1, 2));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("REDSTONE"), 10, MekanismUtils.size(ore, 1)), new ItemStack(MekanismItems.ControlCircuit, 1, 0));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("REDSTONE"), 10, MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.ControlCircuit, 1, 0));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("ingotRedstone"))
|
||||
|
@ -467,7 +466,7 @@ public final class OreDictManager
|
|||
for(ItemStack ore : OreDictionary.getOres("dustObsidian"))
|
||||
{
|
||||
RecipeHandler.addCombinerRecipe(MekanismUtils.size(ore, 4), new ItemStack(Blocks.obsidian));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("DIAMOND"), 10, MekanismUtils.size(ore, 1)), new ItemStack(MekanismItems.Dust, 1, 3));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("DIAMOND"), 10, MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Dust, 1, 3));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("dustOsmium"))
|
||||
|
@ -488,7 +487,7 @@ public final class OreDictManager
|
|||
|
||||
for(ItemStack ore : OreDictionary.getOres("ingotCopper"))
|
||||
{
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfusionInput.getInfusion(InfuseRegistry.get("TIN"), 10, MekanismUtils.size(ore, 1)), new ItemStack(MekanismItems.Ingot, 1, 2));
|
||||
RecipeHandler.addMetallurgicInfuserRecipe(InfuseRegistry.get("TIN"), 10, MekanismUtils.size(ore, 1), new ItemStack(MekanismItems.Ingot, 1, 2));
|
||||
}
|
||||
|
||||
for(ItemStack ore : OreDictionary.getOres("dustTin"))
|
||||
|
@ -568,7 +567,7 @@ public final class OreDictManager
|
|||
|
||||
if(resultEntry != null)
|
||||
{
|
||||
RecipeHandler.addPrecisionSawmillRecipe(log, new ChanceOutput(StackUtils.size(resultEntry, 6), new ItemStack(MekanismItems.Sawdust), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(log, StackUtils.size(resultEntry, 6), new ItemStack(MekanismItems.Sawdust), 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -579,7 +578,7 @@ public final class OreDictManager
|
|||
|
||||
if(resultEntry != null)
|
||||
{
|
||||
RecipeHandler.addPrecisionSawmillRecipe(log, new ChanceOutput(StackUtils.size(resultEntry, 6), new ItemStack(MekanismItems.Sawdust), 1));
|
||||
RecipeHandler.addPrecisionSawmillRecipe(log, StackUtils.size(resultEntry, 6), new ItemStack(MekanismItems.Sawdust), 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@ package mekanism.common.inventory.container;
|
|||
|
||||
import java.util.Map;
|
||||
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.common.recipe.inputs.AdvancedMachineInput;
|
||||
import mekanism.common.inventory.slot.SlotEnergy.SlotDischarge;
|
||||
import mekanism.common.inventory.slot.SlotOutput;
|
||||
import mekanism.common.tile.TileEntityAdvancedElectricMachine;
|
||||
|
@ -170,7 +170,7 @@ public class ContainerAdvancedElectricMachine extends Container
|
|||
|
||||
private boolean isInputItem(ItemStack itemstack)
|
||||
{
|
||||
for(Map.Entry<AdvancedInput, ItemStack> entry : ((Map<AdvancedInput, ItemStack>)tileEntity.getRecipes()).entrySet())
|
||||
for(Map.Entry<AdvancedMachineInput, ItemStack> entry : ((Map<AdvancedMachineInput, ItemStack>)tileEntity.getRecipes()).entrySet())
|
||||
{
|
||||
if(entry.getKey().itemStack.isItemEqual(itemstack))
|
||||
{
|
||||
|
|
|
@ -71,7 +71,7 @@ public class ContainerChemicalDissolutionChamber extends Container
|
|||
ItemStack slotStack = currentSlot.getStack();
|
||||
stack = slotStack.copy();
|
||||
|
||||
if(RecipeHandler.getItemToGasOutput(slotStack, false, Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get()) != null)
|
||||
if(RecipeHandler.getDissolutionOutput(slotStack, false) != null)
|
||||
{
|
||||
if(slotID != 1)
|
||||
{
|
||||
|
|
|
@ -70,7 +70,7 @@ public class ContainerChemicalOxidizer extends Container
|
|||
ItemStack slotStack = currentSlot.getStack();
|
||||
stack = slotStack.copy();
|
||||
|
||||
if(RecipeHandler.getItemToGasOutput(slotStack, false, Recipe.CHEMICAL_OXIDIZER.get()) != null)
|
||||
if(RecipeHandler.getOxidizerOutput(slotStack, false) != null)
|
||||
{
|
||||
if(slotID != 0)
|
||||
{
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
package mekanism.common.inventory.container;
|
||||
|
||||
import mekanism.api.infuse.InfuseRegistry;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.inventory.slot.SlotEnergy.SlotDischarge;
|
||||
import mekanism.common.inventory.slot.SlotOutput;
|
||||
import mekanism.common.recipe.RecipeHandler;
|
||||
|
|
|
@ -4,18 +4,43 @@ import java.util.HashMap;
|
|||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import mekanism.api.gas.GasRegistry;
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.gas.GasTank;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.api.infuse.InfusionOutput;
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.api.recipe.ChanceOutput;
|
||||
import mekanism.api.recipe.ChemicalPair;
|
||||
import mekanism.api.recipe.PressurizedProducts;
|
||||
import mekanism.api.recipe.PressurizedReactants;
|
||||
import mekanism.api.recipe.PressurizedRecipe;
|
||||
import mekanism.api.infuse.InfuseType;
|
||||
import mekanism.common.recipe.inputs.AdvancedMachineInput;
|
||||
import mekanism.common.recipe.inputs.ChemicalPairInput;
|
||||
import mekanism.common.recipe.inputs.FluidInput;
|
||||
import mekanism.common.recipe.inputs.GasInput;
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.recipe.inputs.IntegerInput;
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.inputs.MachineInput;
|
||||
import mekanism.common.recipe.inputs.PressurizedReactants;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
import mekanism.common.recipe.outputs.ChemicalPairOutput;
|
||||
import mekanism.common.recipe.outputs.InfusionOutput;
|
||||
import mekanism.common.recipe.outputs.MachineOutput;
|
||||
import mekanism.api.util.StackUtils;
|
||||
import mekanism.common.recipe.machines.AdvancedMachineRecipe;
|
||||
import mekanism.common.recipe.machines.AmbientGasRecipe;
|
||||
import mekanism.common.recipe.machines.BasicMachineRecipe;
|
||||
import mekanism.common.recipe.machines.ChanceMachineRecipe;
|
||||
import mekanism.common.recipe.machines.ChemicalInfuserRecipe;
|
||||
import mekanism.common.recipe.machines.CombinerRecipe;
|
||||
import mekanism.common.recipe.machines.CrusherRecipe;
|
||||
import mekanism.common.recipe.machines.CrystallizerRecipe;
|
||||
import mekanism.common.recipe.machines.DissolutionRecipe;
|
||||
import mekanism.common.recipe.machines.EnrichmentRecipe;
|
||||
import mekanism.common.recipe.machines.InjectionRecipe;
|
||||
import mekanism.common.recipe.machines.MachineRecipe;
|
||||
import mekanism.common.recipe.machines.MetallurgicInfuserRecipe;
|
||||
import mekanism.common.recipe.machines.OsmiumCompressorRecipe;
|
||||
import mekanism.common.recipe.machines.OxidationRecipe;
|
||||
import mekanism.common.recipe.machines.PressurizedRecipe;
|
||||
import mekanism.common.recipe.machines.PurificationRecipe;
|
||||
import mekanism.common.recipe.machines.SawmillRecipe;
|
||||
import mekanism.common.recipe.machines.SeparatorRecipe;
|
||||
import mekanism.common.recipe.machines.WasherRecipe;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraftforge.fluids.Fluid;
|
||||
|
@ -29,9 +54,9 @@ import net.minecraftforge.fluids.FluidTank;
|
|||
*/
|
||||
public final class RecipeHandler
|
||||
{
|
||||
public static void addRecipe(Recipe recipe, Object input, Object output)
|
||||
public static void addRecipe(Recipe recipeMap, MachineRecipe recipe)
|
||||
{
|
||||
recipe.put(input, output);
|
||||
recipeMap.put(recipe);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -41,7 +66,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addEnrichmentChamberRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
Recipe.ENRICHMENT_CHAMBER.put(input, output);
|
||||
addRecipe(Recipe.ENRICHMENT_CHAMBER, new EnrichmentRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -51,7 +76,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addOsmiumCompressorRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
Recipe.OSMIUM_COMPRESSOR.put(new AdvancedInput(input, GasRegistry.getGas("liquidOsmium")), output);
|
||||
addRecipe(Recipe.OSMIUM_COMPRESSOR, new OsmiumCompressorRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -61,7 +86,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addCombinerRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
Recipe.COMBINER.put(new AdvancedInput(input, GasRegistry.getGas("liquidStone")), output);
|
||||
addRecipe(Recipe.COMBINER, new CombinerRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -71,7 +96,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addCrusherRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
Recipe.CRUSHER.put(input, output);
|
||||
addRecipe(Recipe.CRUSHER, new CrusherRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -81,27 +106,30 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addPurificationChamberRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
Recipe.PURIFICATION_CHAMBER.put(new AdvancedInput(input, GasRegistry.getGas("oxygen")), output);
|
||||
addRecipe(Recipe.PURIFICATION_CHAMBER, new PurificationRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a Metallurgic Infuser recipe.
|
||||
* @param input - input Infusion
|
||||
* @param infuse - which Infuse to use
|
||||
* @param amount - how much of the Infuse to use
|
||||
* @param input - input ItemStack
|
||||
* @param output - output ItemStack
|
||||
*/
|
||||
public static void addMetallurgicInfuserRecipe(InfusionInput input, ItemStack output)
|
||||
public static void addMetallurgicInfuserRecipe(InfuseType infuse, int amount, ItemStack input, ItemStack output)
|
||||
{
|
||||
Recipe.METALLURGIC_INFUSER.put(input, InfusionOutput.getInfusion(input, output));
|
||||
addRecipe(Recipe.METALLURGIC_INFUSER, new MetallurgicInfuserRecipe(new InfusionInput(infuse, amount, input), output));
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a Chemical Infuser recipe.
|
||||
* @param input - input ChemicalPair
|
||||
* @param leftInput - left GasStack to input
|
||||
* @param rightInput - right GasStack to input
|
||||
* @param output - output GasStack
|
||||
*/
|
||||
public static void addChemicalInfuserRecipe(ChemicalPair input, GasStack output)
|
||||
public static void addChemicalInfuserRecipe(GasStack leftInput, GasStack rightInput, GasStack output)
|
||||
{
|
||||
Recipe.CHEMICAL_INFUSER.put(input, output);
|
||||
addRecipe(Recipe.CHEMICAL_INFUSER, new ChemicalInfuserRecipe(leftInput, rightInput, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -111,7 +139,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addChemicalOxidizerRecipe(ItemStack input, GasStack output)
|
||||
{
|
||||
Recipe.CHEMICAL_OXIDIZER.put(input, output);
|
||||
addRecipe(Recipe.CHEMICAL_OXIDIZER, new OxidationRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -119,29 +147,42 @@ public final class RecipeHandler
|
|||
* @param input - input ItemStack
|
||||
* @param output - output ItemStack
|
||||
*/
|
||||
public static void addChemicalInjectionChamberRecipe(AdvancedInput input, ItemStack output)
|
||||
public static void addChemicalInjectionChamberRecipe(ItemStack input, String gasName, ItemStack output)
|
||||
{
|
||||
Recipe.CHEMICAL_INJECTION_CHAMBER.put(input, output);
|
||||
addRecipe(Recipe.CHEMICAL_INJECTION_CHAMBER, new InjectionRecipe(input, gasName, output));
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an Electrolytic Separator recipe.
|
||||
* @param fluid - FluidStack to electrolyze
|
||||
* @param products - Pair of gases to produce when the fluid is electrolyzed
|
||||
* @param leftOutput - left gas to produce when the fluid is electrolyzed
|
||||
* @param rightOutput - right gas to produce when the fluid is electrolyzed
|
||||
*/
|
||||
public static void addElectrolyticSeparatorRecipe(FluidStack fluid, ChemicalPair products)
|
||||
public static void addElectrolyticSeparatorRecipe(FluidStack fluid, GasStack leftOutput, GasStack rightOutput)
|
||||
{
|
||||
Recipe.ELECTROLYTIC_SEPARATOR.put(fluid, products);
|
||||
addRecipe(Recipe.ELECTROLYTIC_SEPARATOR, new SeparatorRecipe(fluid, leftOutput, rightOutput));
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an Precision Sawmill recipe.
|
||||
* Add a Precision Sawmill recipe.
|
||||
* @param input - input ItemStack
|
||||
* @param output - output ChanceOutput
|
||||
* @param primaryOutput - guaranteed output
|
||||
* @param secondaryOutput - possible extra output
|
||||
* @param chance - probability of obtaining extra output
|
||||
*/
|
||||
public static void addPrecisionSawmillRecipe(ItemStack input, ChanceOutput output)
|
||||
public static void addPrecisionSawmillRecipe(ItemStack input, ItemStack primaryOutput, ItemStack secondaryOutput, double chance)
|
||||
{
|
||||
Recipe.PRECISION_SAWMILL.put(input, output);
|
||||
addRecipe(Recipe.PRECISION_SAWMILL, new SawmillRecipe(input, primaryOutput, secondaryOutput, chance));
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a Precision Sawmill recipe with no chance output
|
||||
* @param input - input ItemStack
|
||||
* @param primaryOutput - guaranteed output
|
||||
*/
|
||||
public static void addPrecisionSawmillRecipe(ItemStack input, ItemStack primaryOutput)
|
||||
{
|
||||
addRecipe(Recipe.PRECISION_SAWMILL, new SawmillRecipe(input, primaryOutput));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -151,7 +192,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addChemicalDissolutionChamberRecipe(ItemStack input, GasStack output)
|
||||
{
|
||||
Recipe.CHEMICAL_DISSOLUTION_CHAMBER.put(input, output);
|
||||
addRecipe(Recipe.CHEMICAL_DISSOLUTION_CHAMBER, new DissolutionRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -161,7 +202,7 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addChemicalWasherRecipe(GasStack input, GasStack output)
|
||||
{
|
||||
Recipe.CHEMICAL_WASHER.put(input, output);
|
||||
addRecipe(Recipe.CHEMICAL_WASHER, new WasherRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -171,20 +212,27 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static void addChemicalCrystallizerRecipe(GasStack input, ItemStack output)
|
||||
{
|
||||
Recipe.CHEMICAL_CRYSTALLIZER.put(input, output);
|
||||
addRecipe(Recipe.CHEMICAL_CRYSTALLIZER, new CrystallizerRecipe(input, output));
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a Pressurized Reaction Chamber recipe.
|
||||
* @param input - input PressurizedReactants
|
||||
* @param output - output PressurizedProducts
|
||||
* @param inputSolid - input ItemStack
|
||||
* @param inputFluid - input FluidStack
|
||||
* @param inputGas - input GasStack
|
||||
* @param outputSolid - output ItemStack
|
||||
* @param outputGas - output GasStack
|
||||
* @param extraEnergy - extra energy needed by the recipe
|
||||
* @param ticks - amount of ticks it takes for this recipe to complete
|
||||
*/
|
||||
public static void addPRCRecipe(PressurizedReactants input, PressurizedProducts output, double extraEnergy, int ticks)
|
||||
public static void addPRCRecipe(ItemStack inputSolid, FluidStack inputFluid, GasStack inputGas, ItemStack outputSolid, GasStack outputGas, double extraEnergy, int ticks)
|
||||
{
|
||||
PressurizedRecipe recipe = new PressurizedRecipe(input, extraEnergy, output, ticks);
|
||||
Recipe.PRESSURIZED_REACTION_CHAMBER.put(input, recipe);
|
||||
addRecipe(Recipe.PRESSURIZED_REACTION_CHAMBER, new PressurizedRecipe(inputSolid, inputFluid, inputGas, outputSolid, outputGas, extraEnergy, ticks));
|
||||
}
|
||||
|
||||
public static void addAmbientGas(int dimensionID, String ambientGasName)
|
||||
{
|
||||
addRecipe(Recipe.AMBIENT_ACCUMULATOR, new AmbientGasRecipe(dimensionID, ambientGasName));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -197,22 +245,22 @@ public final class RecipeHandler
|
|||
{
|
||||
if(infusion != null && infusion.inputStack != null)
|
||||
{
|
||||
HashMap<InfusionInput, InfusionOutput> recipes = Recipe.METALLURGIC_INFUSER.get();
|
||||
HashMap<InfusionInput, MetallurgicInfuserRecipe> recipes = Recipe.METALLURGIC_INFUSER.get();
|
||||
|
||||
for(Map.Entry<InfusionInput, InfusionOutput> entry : recipes.entrySet())
|
||||
{
|
||||
InfusionInput input = (InfusionInput)entry.getKey();
|
||||
MetallurgicInfuserRecipe recipe = recipes.get(infusion);
|
||||
|
||||
if(StackUtils.equalsWildcard(input.inputStack, infusion.inputStack) && infusion.inputStack.stackSize >= input.inputStack.stackSize)
|
||||
if(recipe != null)
|
||||
{
|
||||
if(infusion.infusionType == input.infusionType)
|
||||
if(StackUtils.equalsWildcard(recipe.getInput().inputStack, infusion.inputStack) && infusion.inputStack.stackSize >= recipe.getInput().inputStack.stackSize)
|
||||
{
|
||||
if(infusion.infusionType == recipe.getInput().infusionType)
|
||||
{
|
||||
if(stackDecrease)
|
||||
{
|
||||
infusion.inputStack.stackSize -= ((InfusionInput)entry.getKey()).inputStack.stackSize;
|
||||
infusion.inputStack.stackSize -= recipe.getInput().inputStack.stackSize;
|
||||
}
|
||||
|
||||
return ((InfusionOutput)entry.getValue()).copy();
|
||||
return recipe.getOutput().copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -230,24 +278,26 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static GasStack getChemicalInfuserOutput(GasTank leftTank, GasTank rightTank, boolean doRemove)
|
||||
{
|
||||
ChemicalPair input = new ChemicalPair(leftTank.getGas(), rightTank.getGas());
|
||||
ChemicalPairInput input = new ChemicalPairInput(leftTank.getGas(), rightTank.getGas());
|
||||
|
||||
if(input.isValid())
|
||||
{
|
||||
HashMap<ChemicalPair, GasStack> recipes = Recipe.CHEMICAL_INFUSER.get();
|
||||
HashMap<ChemicalPairInput, ChemicalInfuserRecipe> recipes = Recipe.CHEMICAL_INFUSER.get();
|
||||
|
||||
for(Map.Entry<ChemicalPair, GasStack> entry : recipes.entrySet())
|
||||
ChemicalInfuserRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
ChemicalPair key = (ChemicalPair)entry.getKey();
|
||||
ChemicalPairInput required = recipe.getInput();
|
||||
|
||||
if(key.meetsInput(input))
|
||||
if(required.meetsInput(input))
|
||||
{
|
||||
if(doRemove)
|
||||
{
|
||||
key.draw(leftTank, rightTank);
|
||||
required.draw(leftTank, rightTank);
|
||||
}
|
||||
|
||||
return entry.getValue().copy();
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -263,21 +313,23 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static ItemStack getChemicalCrystallizerOutput(GasTank gasTank, boolean removeGas)
|
||||
{
|
||||
GasStack gas = gasTank.getGas();
|
||||
GasInput input = new GasInput(gasTank.getGas());
|
||||
|
||||
if(gas != null)
|
||||
if(input.ingredient != null)
|
||||
{
|
||||
HashMap<GasStack, ItemStack> recipes = Recipe.CHEMICAL_CRYSTALLIZER.get();
|
||||
HashMap<GasInput, CrystallizerRecipe> recipes = Recipe.CHEMICAL_CRYSTALLIZER.get();
|
||||
|
||||
for(Map.Entry<GasStack, ItemStack> entry : recipes.entrySet())
|
||||
CrystallizerRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
GasStack key = (GasStack)entry.getKey();
|
||||
GasStack key = recipe.getInput().ingredient;
|
||||
|
||||
if(key != null && key.getGas() == gas.getGas() && gas.amount >= key.amount)
|
||||
if(key != null && key.getGas() == input.ingredient.getGas() && input.ingredient.amount >= key.amount)
|
||||
{
|
||||
gasTank.draw(key.amount, removeGas);
|
||||
|
||||
return entry.getValue().copy();
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -293,21 +345,23 @@ public final class RecipeHandler
|
|||
*/
|
||||
public static GasStack getChemicalWasherOutput(GasTank gasTank, boolean removeGas)
|
||||
{
|
||||
GasStack gas = gasTank.getGas();
|
||||
GasInput input = new GasInput(gasTank.getGas());
|
||||
|
||||
if(gas != null)
|
||||
if(input.ingredient != null)
|
||||
{
|
||||
HashMap<GasStack, GasStack> recipes = Recipe.CHEMICAL_WASHER.get();
|
||||
HashMap<GasInput, WasherRecipe> recipes = Recipe.CHEMICAL_WASHER.get();
|
||||
|
||||
for(Map.Entry<GasStack, GasStack> entry : recipes.entrySet())
|
||||
WasherRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
GasStack key = (GasStack)entry.getKey();
|
||||
GasStack key = recipe.getInput().ingredient;
|
||||
|
||||
if(key != null && key.getGas() == gas.getGas() && gas.amount >= key.amount)
|
||||
if(key != null && key.getGas() == input.ingredient.getGas() && input.ingredient.amount >= key.amount)
|
||||
{
|
||||
gasTank.draw(key.amount, removeGas);
|
||||
|
||||
return entry.getValue().copy();
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -321,13 +375,19 @@ public final class RecipeHandler
|
|||
* @param stackDecrease - whether or not to decrease the input slot's stack size
|
||||
* @return output GasStack
|
||||
*/
|
||||
public static GasStack getItemToGasOutput(ItemStack itemstack, boolean stackDecrease, HashMap<ItemStack, GasStack> recipes)
|
||||
public static GasStack getDissolutionOutput(ItemStack itemstack, boolean stackDecrease)
|
||||
{
|
||||
if(itemstack != null)
|
||||
{
|
||||
for(Map.Entry<ItemStack, GasStack> entry : recipes.entrySet())
|
||||
ItemStackInput input = new ItemStackInput(itemstack);
|
||||
|
||||
HashMap<ItemStackInput, DissolutionRecipe> recipes = Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get();
|
||||
|
||||
DissolutionRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
ItemStack stack = (ItemStack)entry.getKey();
|
||||
ItemStack stack = recipe.getInput().ingredient;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, itemstack) && itemstack.stackSize >= stack.stackSize)
|
||||
{
|
||||
|
@ -336,7 +396,42 @@ public final class RecipeHandler
|
|||
itemstack.stackSize -= stack.stackSize;
|
||||
}
|
||||
|
||||
return entry.getValue().copy();
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the GasStack of the ItemStack in the parameters using a defined map.
|
||||
* @param itemstack - input ItemStack
|
||||
* @param stackDecrease - whether or not to decrease the input slot's stack size
|
||||
* @return output GasStack
|
||||
*/
|
||||
public static GasStack getOxidizerOutput(ItemStack itemstack, boolean stackDecrease)
|
||||
{
|
||||
if(itemstack != null)
|
||||
{
|
||||
ItemStackInput input = new ItemStackInput(itemstack);
|
||||
|
||||
HashMap<ItemStackInput, OxidationRecipe> recipes = Recipe.CHEMICAL_OXIDIZER.get();
|
||||
|
||||
OxidationRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
ItemStack stack = recipe.getInput().ingredient;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, itemstack) && itemstack.stackSize >= stack.stackSize)
|
||||
{
|
||||
if(stackDecrease)
|
||||
{
|
||||
itemstack.stackSize -= stack.stackSize;
|
||||
}
|
||||
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -351,13 +446,17 @@ public final class RecipeHandler
|
|||
* @param recipes - Map of recipes
|
||||
* @return output ChanceOutput
|
||||
*/
|
||||
public static ChanceOutput getChanceOutput(ItemStack itemstack, boolean stackDecrease, Map<ItemStack, ChanceOutput> recipes)
|
||||
public static ChanceOutput getChanceOutput(ItemStack itemstack, boolean stackDecrease, Map<ItemStackInput, ? extends ChanceMachineRecipe> recipes)
|
||||
{
|
||||
if(itemstack != null)
|
||||
{
|
||||
for(Map.Entry entry : recipes.entrySet())
|
||||
ItemStackInput input = new ItemStackInput(itemstack);
|
||||
|
||||
ChanceMachineRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
ItemStack stack = (ItemStack)entry.getKey();
|
||||
ItemStack stack = recipe.getInput().ingredient;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, itemstack) && itemstack.stackSize >= stack.stackSize)
|
||||
{
|
||||
|
@ -366,7 +465,7 @@ public final class RecipeHandler
|
|||
itemstack.stackSize -= stack.stackSize;
|
||||
}
|
||||
|
||||
return ((ChanceOutput)entry.getValue()).copy();
|
||||
return recipe.getOutput().copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -381,13 +480,17 @@ public final class RecipeHandler
|
|||
* @param recipes - Map of recipes
|
||||
* @return output ItemStack
|
||||
*/
|
||||
public static ItemStack getOutput(ItemStack itemstack, boolean stackDecrease, Map<ItemStack, ItemStack> recipes)
|
||||
public static ItemStack getOutput(ItemStack itemstack, boolean stackDecrease, Map<ItemStackInput, ? extends BasicMachineRecipe> recipes)
|
||||
{
|
||||
if(itemstack != null)
|
||||
{
|
||||
for(Map.Entry entry : recipes.entrySet())
|
||||
ItemStackInput input = new ItemStackInput(itemstack);
|
||||
|
||||
BasicMachineRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
ItemStack stack = (ItemStack)entry.getKey();
|
||||
ItemStack stack = recipe.getInput().ingredient;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, itemstack) && itemstack.stackSize >= stack.stackSize)
|
||||
{
|
||||
|
@ -396,7 +499,7 @@ public final class RecipeHandler
|
|||
itemstack.stackSize -= stack.stackSize;
|
||||
}
|
||||
|
||||
return ((ItemStack)entry.getValue()).copy();
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -410,21 +513,20 @@ public final class RecipeHandler
|
|||
* @param recipes - Map of recipes
|
||||
* @return output ItemStack
|
||||
*/
|
||||
public static ItemStack getOutput(AdvancedInput input, boolean stackDecrease, Map<AdvancedInput, ItemStack> recipes)
|
||||
public static ItemStack getOutput(AdvancedMachineInput input, boolean stackDecrease, Map<AdvancedMachineInput, ? extends AdvancedMachineRecipe> recipes)
|
||||
{
|
||||
if(input != null && input.isValid())
|
||||
{
|
||||
for(Map.Entry<AdvancedInput, ItemStack> entry : recipes.entrySet())
|
||||
{
|
||||
if(entry.getKey().matches(input))
|
||||
AdvancedMachineRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null && recipe.getInput().matches(input))
|
||||
{
|
||||
if(stackDecrease)
|
||||
{
|
||||
input.itemStack.stackSize -= entry.getKey().itemStack.stackSize;
|
||||
input.itemStack.stackSize -= recipe.getInput().itemStack.stackSize;
|
||||
}
|
||||
|
||||
return entry.getValue().copy();
|
||||
}
|
||||
return recipe.getOutput().output.copy();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -435,23 +537,27 @@ public final class RecipeHandler
|
|||
* Get the result of electrolysing a given fluid
|
||||
* @param fluidTank - the FluidTank to electrolyse fluid from
|
||||
*/
|
||||
public static ChemicalPair getElectrolyticSeparatorOutput(FluidTank fluidTank, boolean doRemove)
|
||||
public static ChemicalPairOutput getElectrolyticSeparatorOutput(FluidTank fluidTank, boolean doRemove)
|
||||
{
|
||||
FluidStack fluid = fluidTank.getFluid();
|
||||
|
||||
if(fluid != null)
|
||||
{
|
||||
HashMap<FluidStack, ChemicalPair> recipes = Recipe.ELECTROLYTIC_SEPARATOR.get();
|
||||
FluidInput input = new FluidInput(fluid);
|
||||
|
||||
for(Map.Entry<FluidStack, ChemicalPair> entry : recipes.entrySet())
|
||||
HashMap<FluidInput, SeparatorRecipe> recipes = Recipe.ELECTROLYTIC_SEPARATOR.get();
|
||||
|
||||
SeparatorRecipe recipe = recipes.get(input);
|
||||
|
||||
if(recipe != null)
|
||||
{
|
||||
FluidStack key = (FluidStack)entry.getKey();
|
||||
FluidStack key = recipe.getInput().ingredient;
|
||||
|
||||
if(fluid.containsFluid(key))
|
||||
{
|
||||
fluidTank.drain(key.amount, doRemove);
|
||||
|
||||
return entry.getValue().copy();
|
||||
return recipe.getOutput().copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -464,24 +570,29 @@ public final class RecipeHandler
|
|||
FluidStack inputFluid = inputFluidTank.getFluid();
|
||||
GasStack inputGas = inputGasTank.getGas();
|
||||
|
||||
if(inputFluid != null && inputGas != null)
|
||||
if(inputItem != null && inputFluid != null && inputGas != null)
|
||||
{
|
||||
PressurizedReactants input = new PressurizedReactants(inputItem, inputFluid, inputGas);
|
||||
|
||||
HashMap<PressurizedReactants, PressurizedRecipe> recipes = Recipe.PRESSURIZED_REACTION_CHAMBER.get();
|
||||
|
||||
for(PressurizedRecipe recipe : recipes.values())
|
||||
{
|
||||
PressurizedReactants reactants = recipe.reactants;
|
||||
PressurizedRecipe recipe = recipes.get(input);
|
||||
|
||||
if(reactants.meetsInput(inputItem, inputFluid, inputGas))
|
||||
if(recipe.getInput().meets(input))
|
||||
{
|
||||
return recipe.copy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public static GasStack getDimensionGas(Integer dimensionID)
|
||||
{
|
||||
HashMap<IntegerInput, AmbientGasRecipe> recipes = Recipe.AMBIENT_ACCUMULATOR.get();
|
||||
return recipes.get(new IntegerInput(dimensionID)).getOutput().output;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the output ItemStack of the ItemStack in the parameters.
|
||||
* @param itemstack - input ItemStack
|
||||
|
@ -524,32 +635,33 @@ public final class RecipeHandler
|
|||
|
||||
public static enum Recipe
|
||||
{
|
||||
ENRICHMENT_CHAMBER(new HashMap<ItemStack, ItemStack>()),
|
||||
OSMIUM_COMPRESSOR(new HashMap<AdvancedInput, ItemStack>()),
|
||||
COMBINER(new HashMap<AdvancedInput, ItemStack>()),
|
||||
CRUSHER(new HashMap<ItemStack, ItemStack>()),
|
||||
PURIFICATION_CHAMBER(new HashMap<AdvancedInput, ItemStack>()),
|
||||
METALLURGIC_INFUSER(new HashMap<InfusionInput, InfusionOutput>()),
|
||||
CHEMICAL_INFUSER(new HashMap<ChemicalPair, GasStack>()),
|
||||
CHEMICAL_OXIDIZER(new HashMap<ItemStack, GasStack>()),
|
||||
CHEMICAL_INJECTION_CHAMBER(new HashMap<AdvancedInput, ItemStack>()),
|
||||
ELECTROLYTIC_SEPARATOR(new HashMap<FluidStack, ChemicalPair>()),
|
||||
PRECISION_SAWMILL(new HashMap<ItemStack, ChanceOutput>()),
|
||||
CHEMICAL_DISSOLUTION_CHAMBER(new HashMap<ItemStack, FluidStack>()),
|
||||
CHEMICAL_WASHER(new HashMap<GasStack, GasStack>()),
|
||||
CHEMICAL_CRYSTALLIZER(new HashMap<GasStack, ItemStack>()),
|
||||
PRESSURIZED_REACTION_CHAMBER(new HashMap<PressurizedReactants, PressurizedRecipe>());
|
||||
ENRICHMENT_CHAMBER(new HashMap<ItemStackInput, EnrichmentRecipe>()),
|
||||
OSMIUM_COMPRESSOR(new HashMap<AdvancedMachineInput, OsmiumCompressorRecipe>()),
|
||||
COMBINER(new HashMap<AdvancedMachineInput, CombinerRecipe>()),
|
||||
CRUSHER(new HashMap<ItemStackInput, CrusherRecipe>()),
|
||||
PURIFICATION_CHAMBER(new HashMap<AdvancedMachineInput, PurificationRecipe>()),
|
||||
METALLURGIC_INFUSER(new HashMap<InfusionInput, MetallurgicInfuserRecipe>()),
|
||||
CHEMICAL_INFUSER(new HashMap<ChemicalPairInput, ChemicalInfuserRecipe>()),
|
||||
CHEMICAL_OXIDIZER(new HashMap<ItemStackInput, OxidationRecipe>()),
|
||||
CHEMICAL_INJECTION_CHAMBER(new HashMap<AdvancedMachineInput, InjectionRecipe>()),
|
||||
ELECTROLYTIC_SEPARATOR(new HashMap<FluidInput, SeparatorRecipe>()),
|
||||
PRECISION_SAWMILL(new HashMap<ItemStackInput, SawmillRecipe>()),
|
||||
CHEMICAL_DISSOLUTION_CHAMBER(new HashMap<ItemStackInput, DissolutionRecipe>()),
|
||||
CHEMICAL_WASHER(new HashMap<GasInput, WasherRecipe>()),
|
||||
CHEMICAL_CRYSTALLIZER(new HashMap<GasInput, CrystallizerRecipe>()),
|
||||
PRESSURIZED_REACTION_CHAMBER(new HashMap<PressurizedReactants, PressurizedRecipe>()),
|
||||
AMBIENT_ACCUMULATOR(new HashMap<IntegerInput, AmbientGasRecipe>());
|
||||
|
||||
private HashMap recipes;
|
||||
|
||||
private Recipe(HashMap map)
|
||||
private Recipe(HashMap<? extends MachineInput, ? extends MachineRecipe> map)
|
||||
{
|
||||
recipes = map;
|
||||
}
|
||||
|
||||
public void put(Object input, Object output)
|
||||
public void put(MachineRecipe<? extends MachineInput, ? extends MachineOutput> recipe)
|
||||
{
|
||||
recipes.put(input, output);
|
||||
recipes.put(recipe.getInput(), recipe);
|
||||
}
|
||||
|
||||
public boolean containsRecipe(ItemStack input)
|
||||
|
@ -560,25 +672,25 @@ public final class RecipeHandler
|
|||
{
|
||||
Map.Entry entry = (Map.Entry)obj;
|
||||
|
||||
if(entry.getKey() instanceof ItemStack)
|
||||
if(entry.getKey() instanceof ItemStackInput)
|
||||
{
|
||||
ItemStack stack = (ItemStack)entry.getKey();
|
||||
ItemStack stack = ((ItemStackInput)entry.getKey()).ingredient;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, input))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
else if(entry.getKey() instanceof FluidStack)
|
||||
else if(entry.getKey() instanceof FluidInput)
|
||||
{
|
||||
if(((FluidStack)entry.getKey()).isFluidEqual(input))
|
||||
if(((FluidInput)entry.getKey()).ingredient.isFluidEqual(input))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
else if(entry.getKey() instanceof AdvancedInput)
|
||||
else if(entry.getKey() instanceof AdvancedMachineInput)
|
||||
{
|
||||
ItemStack stack = ((AdvancedInput)entry.getKey()).itemStack;
|
||||
ItemStack stack = ((AdvancedMachineInput)entry.getKey()).itemStack;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, input))
|
||||
{
|
||||
|
|
|
@ -0,0 +1,41 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import mekanism.api.gas.Gas;
|
||||
import mekanism.api.util.StackUtils;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class AdvancedMachineInput extends MachineInput
|
||||
{
|
||||
public ItemStack itemStack;
|
||||
|
||||
public Gas gasType;
|
||||
|
||||
public AdvancedMachineInput(ItemStack item, Gas gas)
|
||||
{
|
||||
itemStack = item;
|
||||
gasType = gas;
|
||||
}
|
||||
|
||||
public boolean isValid()
|
||||
{
|
||||
return itemStack != null && gasType != null;
|
||||
}
|
||||
|
||||
public boolean matches(AdvancedMachineInput input)
|
||||
{
|
||||
return StackUtils.equalsWildcard(itemStack, input.itemStack) && input.itemStack.stackSize >= itemStack.stackSize;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return StackUtils.hashItemStack(itemStack) << 8 | gasType.getID();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
return other instanceof AdvancedMachineInput && StackUtils.equalsWildcardWithNBT(itemStack, ((AdvancedMachineInput)other).itemStack) && gasType.getID() == ((AdvancedMachineInput)other).gasType.getID();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,134 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.gas.GasTank;
|
||||
|
||||
/**
|
||||
* An input of gasses for recipe use.
|
||||
* @author aidancbrady
|
||||
*
|
||||
*/
|
||||
public class ChemicalPairInput extends MachineInput
|
||||
{
|
||||
/** The left gas of this chemical input */
|
||||
public GasStack leftGas;
|
||||
|
||||
/** The right gas of this chemical input */
|
||||
public GasStack rightGas;
|
||||
|
||||
/**
|
||||
* Creates a chemical input with two defined gasses.
|
||||
* @param left - left gas
|
||||
* @param right - right gas
|
||||
*/
|
||||
public ChemicalPairInput(GasStack left, GasStack right)
|
||||
{
|
||||
leftGas = left;
|
||||
rightGas = right;
|
||||
}
|
||||
|
||||
/**
|
||||
* If this is a valid ChemicalPair
|
||||
* @return
|
||||
*/
|
||||
public boolean isValid()
|
||||
{
|
||||
return leftGas != null && rightGas != null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Whether or not the defined input contains the same gasses and at least the required amount of the defined gasses as this input.
|
||||
* @param input - input to check
|
||||
* @return if the input meets this input's requirements
|
||||
*/
|
||||
public boolean meetsInput(ChemicalPairInput input)
|
||||
{
|
||||
return meets(input) || meets(input.swap());
|
||||
}
|
||||
|
||||
/**
|
||||
* Swaps the right gas and left gas of this input.
|
||||
* @return a swapped ChemicalInput
|
||||
*/
|
||||
public ChemicalPairInput swap()
|
||||
{
|
||||
return new ChemicalPairInput(rightGas, leftGas);
|
||||
}
|
||||
|
||||
/**
|
||||
* Draws the needed amount of gas from each tank.
|
||||
* @param leftTank - left tank to draw from
|
||||
* @param rightTank - right tank to draw from
|
||||
*/
|
||||
public void draw(GasTank leftTank, GasTank rightTank)
|
||||
{
|
||||
if(meets(new ChemicalPairInput(leftTank.getGas(), rightTank.getGas())))
|
||||
{
|
||||
leftTank.draw(leftGas.amount, true);
|
||||
rightTank.draw(rightGas.amount, true);
|
||||
}
|
||||
else if(meets(new ChemicalPairInput(rightTank.getGas(), leftTank.getGas())))
|
||||
{
|
||||
leftTank.draw(rightGas.amount, true);
|
||||
rightTank.draw(leftGas.amount, true);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Whether or not one of this ChemicalInput's GasStack entry's gas type is equal to the gas type of the given gas.
|
||||
* @param stack - stack to check
|
||||
* @return if the stack's gas type is contained in this ChemicalInput
|
||||
*/
|
||||
public boolean containsType(GasStack stack)
|
||||
{
|
||||
if(stack == null || stack.amount == 0)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return stack.isGasEqual(leftGas) || stack.isGasEqual(rightGas);
|
||||
}
|
||||
|
||||
/**
|
||||
* Actual implementation of meetsInput(), performs the checks.
|
||||
* @param input - input to check
|
||||
* @return if the input meets this input's requirements
|
||||
*/
|
||||
private boolean meets(ChemicalPairInput input)
|
||||
{
|
||||
if(input == null || !input.isValid())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
if(input.leftGas.getGas() != leftGas.getGas() || input.rightGas.getGas() != rightGas.getGas())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return input.leftGas.amount >= leftGas.amount && input.rightGas.amount >= rightGas.amount;
|
||||
}
|
||||
|
||||
public ChemicalPairInput copy()
|
||||
{
|
||||
return new ChemicalPairInput(leftGas.copy(), rightGas.copy());
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return (leftGas.hashCode() << 8 | rightGas.hashCode()) + (rightGas.hashCode() << 8 | leftGas.hashCode());
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
if(other instanceof ChemicalPairInput)
|
||||
{
|
||||
int leftID = ((ChemicalPairInput)other).leftGas.hashCode();
|
||||
int rightID = ((ChemicalPairInput)other).rightGas.hashCode();
|
||||
return (leftID == leftGas.hashCode() && rightID == rightGas.hashCode()) || (leftID == rightGas.hashCode() && rightID == leftGas.hashCode());
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
25
src/main/java/mekanism/common/recipe/inputs/FluidInput.java
Normal file
25
src/main/java/mekanism/common/recipe/inputs/FluidInput.java
Normal file
|
@ -0,0 +1,25 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import net.minecraftforge.fluids.FluidStack;
|
||||
|
||||
public class FluidInput extends MachineInput
|
||||
{
|
||||
public FluidStack ingredient;
|
||||
|
||||
public FluidInput(FluidStack stack)
|
||||
{
|
||||
ingredient = stack;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return ingredient.hashCode();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
return other instanceof FluidInput && ingredient.equals(((FluidInput)other).ingredient);
|
||||
}
|
||||
}
|
25
src/main/java/mekanism/common/recipe/inputs/GasInput.java
Normal file
25
src/main/java/mekanism/common/recipe/inputs/GasInput.java
Normal file
|
@ -0,0 +1,25 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
|
||||
public class GasInput extends MachineInput
|
||||
{
|
||||
public GasStack ingredient;
|
||||
|
||||
public GasInput(GasStack stack)
|
||||
{
|
||||
ingredient = stack;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return ingredient.hashCode();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
return other instanceof GasInput && ((GasInput)other).ingredient.hashCode() == ingredient.hashCode();
|
||||
}
|
||||
}
|
|
@ -1,4 +1,7 @@
|
|||
package mekanism.api.infuse;
|
||||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import mekanism.api.infuse.InfuseType;
|
||||
import mekanism.api.util.StackUtils;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
|
@ -7,7 +10,7 @@ import net.minecraft.item.ItemStack;
|
|||
* @author AidanBrady
|
||||
*
|
||||
*/
|
||||
public class InfusionInput
|
||||
public class InfusionInput extends MachineInput
|
||||
{
|
||||
/** The type of this infusion */
|
||||
public InfuseType infusionType;
|
||||
|
@ -29,4 +32,21 @@ public class InfusionInput
|
|||
{
|
||||
return new InfusionInput(type, stored, itemstack);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return infusionType.unlocalizedName.hashCode() << 8 | StackUtils.hashItemStack(inputStack);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
if(other instanceof InfusionInput)
|
||||
{
|
||||
InfusionInput ii = (InfusionInput)other;
|
||||
return infusionType == ii.infusionType && StackUtils.equalsWildcardWithNBT(inputStack, ii.inputStack);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,24 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
public class IntegerInput extends MachineInput
|
||||
{
|
||||
public int ingredient;
|
||||
|
||||
public IntegerInput(int integer)
|
||||
{
|
||||
ingredient = integer;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return ingredient;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
return other instanceof IntegerInput && ingredient == ((IntegerInput)other).ingredient;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,27 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import mekanism.api.util.StackUtils;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class ItemStackInput extends MachineInput
|
||||
{
|
||||
public ItemStack ingredient;
|
||||
|
||||
public ItemStackInput(ItemStack stack)
|
||||
{
|
||||
ingredient = stack;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return StackUtils.hashItemStack(ingredient);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
return other instanceof ItemStackInput && StackUtils.equalsWildcardWithNBT(ingredient, ((ItemStackInput)other).ingredient);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,34 @@
|
|||
package mekanism.common.recipe.inputs;
|
||||
|
||||
public abstract class MachineInput
|
||||
{
|
||||
public abstract int hashIngredients();
|
||||
|
||||
/**
|
||||
* Test equality to another input.
|
||||
* This should return true if the input matches this one,
|
||||
* IGNORING AMOUNTS.
|
||||
* Allows usage of HashMap optimisation to get recipes.
|
||||
* @param other
|
||||
* @return
|
||||
*/
|
||||
public abstract boolean testEquality(MachineInput other);
|
||||
|
||||
@Override
|
||||
public int hashCode()
|
||||
{
|
||||
return hashIngredients();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object other)
|
||||
{
|
||||
if(other instanceof MachineInput)
|
||||
{
|
||||
return testEquality((MachineInput)other);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
package mekanism.api.recipe;
|
||||
package mekanism.common.recipe.inputs;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.gas.GasTank;
|
||||
|
@ -11,7 +11,7 @@ import net.minecraftforge.fluids.FluidTank;
|
|||
/**
|
||||
* An input of a gas, a fluid and an item for the pressurized reaction chamber
|
||||
*/
|
||||
public class PressurizedReactants
|
||||
public class PressurizedReactants extends MachineInput
|
||||
{
|
||||
private ItemStack theSolid;
|
||||
private FluidStack theFluid;
|
||||
|
@ -103,7 +103,7 @@ public class PressurizedReactants
|
|||
* @param input - input to check
|
||||
* @return if the input meets this input's requirements
|
||||
*/
|
||||
private boolean meets(PressurizedReactants input)
|
||||
public boolean meets(PressurizedReactants input)
|
||||
{
|
||||
if(input == null || !input.isValid())
|
||||
{
|
||||
|
@ -137,4 +137,21 @@ public class PressurizedReactants
|
|||
{
|
||||
return theGas;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashIngredients()
|
||||
{
|
||||
return StackUtils.hashItemStack(theSolid) << 16 | theFluid.hashCode() << 8 | theGas.hashCode();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean testEquality(MachineInput other)
|
||||
{
|
||||
if(other instanceof PressurizedReactants)
|
||||
{
|
||||
PressurizedReactants pr = (PressurizedReactants)other;
|
||||
return pr.containsType(theSolid) && pr.containsType(theFluid) && pr.containsType(theGas);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,21 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.Gas;
|
||||
import mekanism.api.gas.GasRegistry;
|
||||
import mekanism.common.recipe.inputs.AdvancedMachineInput;
|
||||
import mekanism.common.recipe.outputs.ItemStackOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class AdvancedMachineRecipe extends MachineRecipe<AdvancedMachineInput, ItemStackOutput>
|
||||
{
|
||||
public AdvancedMachineRecipe(ItemStack input, String gasName, ItemStack output)
|
||||
{
|
||||
super(new AdvancedMachineInput(input, GasRegistry.getGas(gasName)), new ItemStackOutput(output));
|
||||
}
|
||||
|
||||
public AdvancedMachineRecipe(ItemStack input, Gas gas, ItemStack output)
|
||||
{
|
||||
super(new AdvancedMachineInput(input, gas), new ItemStackOutput(output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,14 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasRegistry;
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.IntegerInput;
|
||||
import mekanism.common.recipe.outputs.GasOutput;
|
||||
|
||||
public class AmbientGasRecipe extends MachineRecipe<IntegerInput, GasOutput>
|
||||
{
|
||||
public AmbientGasRecipe(int input, String output)
|
||||
{
|
||||
super(new IntegerInput(input), new GasOutput(new GasStack(GasRegistry.getGas(output), 1)));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,14 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.outputs.ItemStackOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class BasicMachineRecipe extends MachineRecipe<ItemStackInput, ItemStackOutput>
|
||||
{
|
||||
public BasicMachineRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
super(new ItemStackInput(input), new ItemStackOutput(output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,12 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
|
||||
public class ChanceMachineRecipe extends MachineRecipe<ItemStackInput, ChanceOutput>
|
||||
{
|
||||
public ChanceMachineRecipe(ItemStackInput input, ChanceOutput output)
|
||||
{
|
||||
super(input, output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,13 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.ChemicalPairInput;
|
||||
import mekanism.common.recipe.outputs.GasOutput;
|
||||
|
||||
public class ChemicalInfuserRecipe extends MachineRecipe<ChemicalPairInput, GasOutput>
|
||||
{
|
||||
public ChemicalInfuserRecipe(GasStack leftInput, GasStack rightInput, GasStack output)
|
||||
{
|
||||
super(new ChemicalPairInput(leftInput, rightInput), new GasOutput(output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class CombinerRecipe extends AdvancedMachineRecipe
|
||||
{
|
||||
public CombinerRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
super(input, "liquidStone", output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class CrusherRecipe extends BasicMachineRecipe
|
||||
{
|
||||
public CrusherRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
super(input, output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.GasInput;
|
||||
import mekanism.common.recipe.outputs.ItemStackOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class CrystallizerRecipe extends MachineRecipe<GasInput, ItemStackOutput>
|
||||
{
|
||||
public CrystallizerRecipe(GasStack input, ItemStack output)
|
||||
{
|
||||
super(new GasInput(input), new ItemStackOutput(output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.outputs.GasOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class DissolutionRecipe extends MachineRecipe<ItemStackInput, GasOutput>
|
||||
{
|
||||
public DissolutionRecipe(ItemStack input, GasStack output)
|
||||
{
|
||||
super(new ItemStackInput(input), new GasOutput(output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class EnrichmentRecipe extends BasicMachineRecipe
|
||||
{
|
||||
public EnrichmentRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
super(input, output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class InjectionRecipe extends AdvancedMachineRecipe
|
||||
{
|
||||
public InjectionRecipe(ItemStack input, String gasName, ItemStack output)
|
||||
{
|
||||
super(input, gasName, output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,26 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.common.recipe.inputs.MachineInput;
|
||||
import mekanism.common.recipe.outputs.MachineOutput;
|
||||
|
||||
public abstract class MachineRecipe<INPUT extends MachineInput, OUTPUT extends MachineOutput>
|
||||
{
|
||||
public INPUT recipeInput;
|
||||
public OUTPUT recipeOutput;
|
||||
|
||||
public MachineRecipe(INPUT input, OUTPUT output)
|
||||
{
|
||||
recipeInput = input;
|
||||
recipeOutput = output;
|
||||
}
|
||||
|
||||
public INPUT getInput()
|
||||
{
|
||||
return recipeInput;
|
||||
}
|
||||
|
||||
public OUTPUT getOutput()
|
||||
{
|
||||
return recipeOutput;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,14 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.recipe.outputs.InfusionOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class MetallurgicInfuserRecipe extends MachineRecipe<InfusionInput, InfusionOutput>
|
||||
{
|
||||
public MetallurgicInfuserRecipe(InfusionInput input, ItemStack output)
|
||||
{
|
||||
super(input, InfusionOutput.getInfusion(input, output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class OsmiumCompressorRecipe extends AdvancedMachineRecipe
|
||||
{
|
||||
public OsmiumCompressorRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
super(input, "liquidOsmium", output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.outputs.GasOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class OxidationRecipe extends MachineRecipe<ItemStackInput, GasOutput>
|
||||
{
|
||||
public OxidationRecipe(ItemStack input, GasStack output)
|
||||
{
|
||||
super(new ItemStackInput(input), new GasOutput(output));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,33 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.outputs.PressurizedProducts;
|
||||
import mekanism.common.recipe.inputs.PressurizedReactants;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraftforge.fluids.FluidStack;
|
||||
|
||||
public class PressurizedRecipe extends MachineRecipe<PressurizedReactants, PressurizedProducts>
|
||||
{
|
||||
public double extraEnergy;
|
||||
|
||||
public int ticks;
|
||||
|
||||
public PressurizedRecipe(ItemStack inputSolid, FluidStack inputFluid, GasStack inputGas, ItemStack outputSolid, GasStack outputGas, double energy, int duration)
|
||||
{
|
||||
this(new PressurizedReactants(inputSolid, inputFluid, inputGas), new PressurizedProducts(outputSolid, outputGas), energy, duration);
|
||||
}
|
||||
|
||||
public PressurizedRecipe(PressurizedReactants pressurizedReactants, PressurizedProducts pressurizedProducts, double energy, int duration)
|
||||
{
|
||||
super(pressurizedReactants, pressurizedProducts);
|
||||
|
||||
extraEnergy = energy;
|
||||
ticks = duration;
|
||||
}
|
||||
|
||||
public PressurizedRecipe copy()
|
||||
{
|
||||
return new PressurizedRecipe(getInput().copy(), getOutput().copy(), extraEnergy, ticks);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class PurificationRecipe extends AdvancedMachineRecipe
|
||||
{
|
||||
public PurificationRecipe(ItemStack input, ItemStack output)
|
||||
{
|
||||
super(input, "oxygen", output);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,19 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.common.recipe.inputs.ItemStackInput;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class SawmillRecipe extends ChanceMachineRecipe
|
||||
{
|
||||
public SawmillRecipe(ItemStack input, ItemStack primaryOutput, ItemStack secondaryOutput, double chance)
|
||||
{
|
||||
super(new ItemStackInput(input), new ChanceOutput(primaryOutput, secondaryOutput, chance));
|
||||
}
|
||||
|
||||
public SawmillRecipe(ItemStack input, ItemStack primaryOutput)
|
||||
{
|
||||
super(new ItemStackInput(input), new ChanceOutput(primaryOutput));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.FluidInput;
|
||||
import mekanism.common.recipe.outputs.ChemicalPairOutput;
|
||||
|
||||
import net.minecraftforge.fluids.FluidStack;
|
||||
|
||||
public class SeparatorRecipe extends MachineRecipe<FluidInput, ChemicalPairOutput>
|
||||
{
|
||||
public SeparatorRecipe(FluidStack input, GasStack left, GasStack right)
|
||||
{
|
||||
super(new FluidInput(input), new ChemicalPairOutput(left, right));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,13 @@
|
|||
package mekanism.common.recipe.machines;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.common.recipe.inputs.GasInput;
|
||||
import mekanism.common.recipe.outputs.GasOutput;
|
||||
|
||||
public class WasherRecipe extends MachineRecipe<GasInput, GasOutput>
|
||||
{
|
||||
public WasherRecipe(GasStack input, GasStack output)
|
||||
{
|
||||
super(new GasInput(input), new GasOutput(output));
|
||||
}
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
package mekanism.api.recipe;
|
||||
package mekanism.common.recipe.outputs;
|
||||
|
||||
import java.util.Random;
|
||||
|
||||
|
@ -6,7 +6,7 @@ import mekanism.api.util.StackUtils;
|
|||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class ChanceOutput
|
||||
public class ChanceOutput extends MachineOutput
|
||||
{
|
||||
private static Random rand = new Random();
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package mekanism.api.recipe;
|
||||
package mekanism.common.recipe.outputs;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.gas.GasTank;
|
||||
|
@ -8,7 +8,7 @@ import mekanism.api.gas.GasTank;
|
|||
* @author aidancbrady
|
||||
*
|
||||
*/
|
||||
public class ChemicalPair
|
||||
public class ChemicalPairOutput extends MachineOutput
|
||||
{
|
||||
/** The left gas of this chemical input */
|
||||
public GasStack leftGas;
|
||||
|
@ -21,7 +21,7 @@ public class ChemicalPair
|
|||
* @param left - left gas
|
||||
* @param right - right gas
|
||||
*/
|
||||
public ChemicalPair(GasStack left, GasStack right)
|
||||
public ChemicalPairOutput(GasStack left, GasStack right)
|
||||
{
|
||||
leftGas = left;
|
||||
rightGas = right;
|
||||
|
@ -41,7 +41,7 @@ public class ChemicalPair
|
|||
* @param input - input to check
|
||||
* @return if the input meets this input's requirements
|
||||
*/
|
||||
public boolean meetsInput(ChemicalPair input)
|
||||
public boolean meetsInput(ChemicalPairOutput input)
|
||||
{
|
||||
return meets(input) || meets(input.swap());
|
||||
}
|
||||
|
@ -50,9 +50,9 @@ public class ChemicalPair
|
|||
* Swaps the right gas and left gas of this input.
|
||||
* @return a swapped ChemicalInput
|
||||
*/
|
||||
public ChemicalPair swap()
|
||||
public ChemicalPairOutput swap()
|
||||
{
|
||||
return new ChemicalPair(rightGas, leftGas);
|
||||
return new ChemicalPairOutput(rightGas, leftGas);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -62,12 +62,12 @@ public class ChemicalPair
|
|||
*/
|
||||
public void draw(GasTank leftTank, GasTank rightTank)
|
||||
{
|
||||
if(meets(new ChemicalPair(leftTank.getGas(), rightTank.getGas())))
|
||||
if(meets(new ChemicalPairOutput(leftTank.getGas(), rightTank.getGas())))
|
||||
{
|
||||
leftTank.draw(leftGas.amount, true);
|
||||
rightTank.draw(rightGas.amount, true);
|
||||
}
|
||||
else if(meets(new ChemicalPair(rightTank.getGas(), leftTank.getGas())))
|
||||
else if(meets(new ChemicalPairOutput(rightTank.getGas(), leftTank.getGas())))
|
||||
{
|
||||
leftTank.draw(rightGas.amount, true);
|
||||
rightTank.draw(leftGas.amount, true);
|
||||
|
@ -94,7 +94,7 @@ public class ChemicalPair
|
|||
* @param input - input to check
|
||||
* @return if the input meets this input's requirements
|
||||
*/
|
||||
private boolean meets(ChemicalPair input)
|
||||
private boolean meets(ChemicalPairOutput input)
|
||||
{
|
||||
if(input == null || !input.isValid())
|
||||
{
|
||||
|
@ -109,8 +109,8 @@ public class ChemicalPair
|
|||
return input.leftGas.amount >= leftGas.amount && input.rightGas.amount >= rightGas.amount;
|
||||
}
|
||||
|
||||
public ChemicalPair copy()
|
||||
public ChemicalPairOutput copy()
|
||||
{
|
||||
return new ChemicalPair(leftGas.copy(), rightGas.copy());
|
||||
return new ChemicalPairOutput(leftGas.copy(), rightGas.copy());
|
||||
}
|
||||
}
|
13
src/main/java/mekanism/common/recipe/outputs/GasOutput.java
Normal file
13
src/main/java/mekanism/common/recipe/outputs/GasOutput.java
Normal file
|
@ -0,0 +1,13 @@
|
|||
package mekanism.common.recipe.outputs;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
|
||||
public class GasOutput extends MachineOutput
|
||||
{
|
||||
public GasStack output;
|
||||
|
||||
public GasOutput(GasStack stack)
|
||||
{
|
||||
output = stack;
|
||||
}
|
||||
}
|
|
@ -1,4 +1,6 @@
|
|||
package mekanism.api.infuse;
|
||||
package mekanism.common.recipe.outputs;
|
||||
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
|
@ -7,7 +9,7 @@ import net.minecraft.item.ItemStack;
|
|||
* @author AidanBrady
|
||||
*
|
||||
*/
|
||||
public class InfusionOutput
|
||||
public class InfusionOutput extends MachineOutput
|
||||
{
|
||||
/** The input infusion */
|
||||
public InfusionInput infusionInput;
|
|
@ -0,0 +1,13 @@
|
|||
package mekanism.common.recipe.outputs;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class ItemStackOutput extends MachineOutput
|
||||
{
|
||||
public ItemStack output;
|
||||
|
||||
public ItemStackOutput(ItemStack stack)
|
||||
{
|
||||
output = stack;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package mekanism.common.recipe.outputs;
|
||||
|
||||
public class MachineOutput
|
||||
{
|
||||
}
|
|
@ -1,11 +1,11 @@
|
|||
package mekanism.api.recipe;
|
||||
package mekanism.common.recipe.outputs;
|
||||
|
||||
import mekanism.api.gas.GasStack;
|
||||
import mekanism.api.gas.GasTank;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
public class PressurizedProducts
|
||||
public class PressurizedProducts extends MachineOutput
|
||||
{
|
||||
private ItemStack itemOutput;
|
||||
private GasStack gasOutput;
|
|
@ -0,0 +1,5 @@
|
|||
package mekanism.common.recipe.outputs;
|
||||
|
||||
public class StringOutput extends MachineOutput
|
||||
{
|
||||
}
|
|
@ -9,7 +9,7 @@ import mekanism.api.gas.GasStack;
|
|||
import mekanism.api.gas.GasTank;
|
||||
import mekanism.api.gas.IGasHandler;
|
||||
import mekanism.api.gas.ITubeConnection;
|
||||
import mekanism.api.recipe.AdvancedInput;
|
||||
import mekanism.common.recipe.inputs.AdvancedMachineInput;
|
||||
import mekanism.api.util.StackUtils;
|
||||
import mekanism.common.Mekanism;
|
||||
import mekanism.common.MekanismItems;
|
||||
|
@ -140,11 +140,11 @@ public abstract class TileEntityAdvancedElectricMachine extends TileEntityBasicM
|
|||
|
||||
for(Object obj : getRecipes().entrySet())
|
||||
{
|
||||
if(((Map.Entry)obj).getKey() instanceof AdvancedInput)
|
||||
if(((Map.Entry)obj).getKey() instanceof AdvancedMachineInput)
|
||||
{
|
||||
Map.Entry entry = (Map.Entry)obj;
|
||||
|
||||
ItemStack stack = ((AdvancedInput)entry.getKey()).itemStack;
|
||||
ItemStack stack = ((AdvancedMachineInput)entry.getKey()).itemStack;
|
||||
|
||||
if(StackUtils.equalsWildcard(stack, itemStack))
|
||||
{
|
||||
|
@ -207,7 +207,7 @@ public abstract class TileEntityAdvancedElectricMachine extends TileEntityBasicM
|
|||
@Override
|
||||
public void operate()
|
||||
{
|
||||
ItemStack itemstack = RecipeHandler.getOutput(new AdvancedInput(inventory[0], gasTank.getGas().getGas()), true, getRecipes());
|
||||
ItemStack itemstack = RecipeHandler.getOutput(new AdvancedMachineInput(inventory[0], gasTank.getGas().getGas()), true, getRecipes());
|
||||
|
||||
if(inventory[0].stackSize <= 0)
|
||||
{
|
||||
|
@ -234,7 +234,7 @@ public abstract class TileEntityAdvancedElectricMachine extends TileEntityBasicM
|
|||
return false;
|
||||
}
|
||||
|
||||
ItemStack itemstack = RecipeHandler.getOutput(new AdvancedInput(inventory[0], gasTank.getGas().getGas()), false, getRecipes());
|
||||
ItemStack itemstack = RecipeHandler.getOutput(new AdvancedMachineInput(inventory[0], gasTank.getGas().getGas()), false, getRecipes());
|
||||
|
||||
if(itemstack == null)
|
||||
{
|
||||
|
|
|
@ -11,6 +11,8 @@ import mekanism.api.gas.GasStack;
|
|||
import mekanism.api.gas.GasTank;
|
||||
import mekanism.api.gas.IGasHandler;
|
||||
import mekanism.api.gas.ITubeConnection;
|
||||
import mekanism.common.recipe.RecipeHandler;
|
||||
import mekanism.common.recipe.RecipeHandler.Recipe;
|
||||
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraftforge.common.util.ForgeDirection;
|
||||
|
@ -21,17 +23,11 @@ public class TileEntityAmbientAccumulator extends TileEntityContainerBlock imple
|
|||
{
|
||||
public GasTank collectedGas = new GasTank(1000);
|
||||
|
||||
public static Map<Integer, String> dimensionGases = new HashMap<Integer, String>();
|
||||
public int cachedDimensionId = 0;
|
||||
public GasStack cachedGas;
|
||||
|
||||
public static Random gasRand = new Random();
|
||||
|
||||
static
|
||||
{
|
||||
dimensionGases.put(-1, "sulfurDioxideGas");
|
||||
dimensionGases.put(+0, "oxygen");
|
||||
dimensionGases.put(+1, "tritium");
|
||||
}
|
||||
|
||||
public TileEntityAmbientAccumulator()
|
||||
{
|
||||
super("AmbientAccumulator");
|
||||
|
@ -43,11 +39,15 @@ public class TileEntityAmbientAccumulator extends TileEntityContainerBlock imple
|
|||
{
|
||||
if(!worldObj.isRemote)
|
||||
{
|
||||
Gas gasToCollect = GasRegistry.getGas(dimensionGases.get(worldObj.provider.dimensionId));
|
||||
|
||||
if(gasToCollect != null && gasRand.nextDouble() < 0.05)
|
||||
if(cachedGas == null || worldObj.provider.dimensionId != cachedDimensionId)
|
||||
{
|
||||
collectedGas.receive(new GasStack(gasToCollect, 1), true);
|
||||
cachedDimensionId = worldObj.provider.dimensionId;
|
||||
cachedGas = RecipeHandler.getDimensionGas(cachedDimensionId);
|
||||
}
|
||||
|
||||
if(cachedGas != null && gasRand.nextDouble() < 0.05)
|
||||
{
|
||||
collectedGas.receive(cachedGas, true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@ package mekanism.common.tile;
|
|||
import java.util.Map;
|
||||
|
||||
import mekanism.api.EnumColor;
|
||||
import mekanism.api.recipe.ChanceOutput;
|
||||
import mekanism.common.recipe.outputs.ChanceOutput;
|
||||
import mekanism.common.MekanismItems;
|
||||
import mekanism.common.SideData;
|
||||
import mekanism.common.recipe.RecipeHandler;
|
||||
|
|
|
@ -119,7 +119,7 @@ public class TileEntityChemicalDissolutionChamber extends TileEntityNoisyElectri
|
|||
injectTank.draw(INJECT_USAGE, true);
|
||||
}
|
||||
else {
|
||||
GasStack stack = RecipeHandler.getItemToGasOutput(inventory[1], true, Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get());
|
||||
GasStack stack = RecipeHandler.getDissolutionOutput(inventory[1], true);
|
||||
|
||||
outputTank.receive(stack, true);
|
||||
injectTank.draw(INJECT_USAGE, true);
|
||||
|
@ -171,7 +171,7 @@ public class TileEntityChemicalDissolutionChamber extends TileEntityNoisyElectri
|
|||
{
|
||||
if(slotID == 1)
|
||||
{
|
||||
return RecipeHandler.getItemToGasOutput(itemstack, false, Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get()) != null;
|
||||
return RecipeHandler.getDissolutionOutput(itemstack, false) != null;
|
||||
}
|
||||
else if(slotID == 3)
|
||||
{
|
||||
|
@ -223,7 +223,7 @@ public class TileEntityChemicalDissolutionChamber extends TileEntityNoisyElectri
|
|||
return false;
|
||||
}
|
||||
|
||||
GasStack stack = RecipeHandler.getItemToGasOutput(inventory[1], false, Recipe.CHEMICAL_DISSOLUTION_CHAMBER.get());
|
||||
GasStack stack = RecipeHandler.getDissolutionOutput(inventory[1], false);
|
||||
|
||||
if(stack == null || (outputTank.getGas() != null && (outputTank.getGas().getGas() != stack.getGas() || outputTank.getNeeded() < stack.amount)))
|
||||
{
|
||||
|
|
|
@ -107,7 +107,7 @@ public class TileEntityChemicalOxidizer extends TileEntityNoisyElectricBlock imp
|
|||
operatingTicks++;
|
||||
}
|
||||
else {
|
||||
GasStack stack = RecipeHandler.getItemToGasOutput(inventory[0], true, Recipe.CHEMICAL_OXIDIZER.get());
|
||||
GasStack stack = RecipeHandler.getOxidizerOutput(inventory[0], true);
|
||||
|
||||
gasTank.receive(stack, true);
|
||||
operatingTicks = 0;
|
||||
|
@ -151,7 +151,7 @@ public class TileEntityChemicalOxidizer extends TileEntityNoisyElectricBlock imp
|
|||
{
|
||||
if(slotID == 0)
|
||||
{
|
||||
return RecipeHandler.getItemToGasOutput(itemstack, false, Recipe.CHEMICAL_OXIDIZER.get()) != null;
|
||||
return RecipeHandler.getOxidizerOutput(itemstack, false) != null;
|
||||
}
|
||||
else if(slotID == 1)
|
||||
{
|
||||
|
@ -203,7 +203,7 @@ public class TileEntityChemicalOxidizer extends TileEntityNoisyElectricBlock imp
|
|||
return false;
|
||||
}
|
||||
|
||||
GasStack stack = RecipeHandler.getItemToGasOutput(inventory[0], false, Recipe.CHEMICAL_OXIDIZER.get());
|
||||
GasStack stack = RecipeHandler.getOxidizerOutput(inventory[0], false);
|
||||
|
||||
if(stack == null || (gasTank.getGas() != null && (gasTank.getGas().getGas() != stack.getGas() || gasTank.getNeeded() < stack.amount)))
|
||||
{
|
||||
|
|
|
@ -13,7 +13,7 @@ import mekanism.api.gas.GasTransmission;
|
|||
import mekanism.api.gas.IGasHandler;
|
||||
import mekanism.api.gas.IGasItem;
|
||||
import mekanism.api.gas.ITubeConnection;
|
||||
import mekanism.api.recipe.ChemicalPair;
|
||||
import mekanism.common.recipe.outputs.ChemicalPairOutput;
|
||||
import mekanism.common.Mekanism;
|
||||
import mekanism.common.base.ISustainedData;
|
||||
import mekanism.common.block.BlockMachine.MachineType;
|
||||
|
@ -204,7 +204,7 @@ public class TileEntityElectrolyticSeparator extends TileEntityElectricBlock imp
|
|||
return canFillWithSwap(RecipeHandler.getElectrolyticSeparatorOutput(fluidTank, false)) && getEnergy() >= general.FROM_H2*2;
|
||||
}
|
||||
|
||||
public boolean canFillWithSwap(ChemicalPair gases)
|
||||
public boolean canFillWithSwap(ChemicalPairOutput gases)
|
||||
{
|
||||
if(gases == null)
|
||||
{
|
||||
|
@ -214,13 +214,13 @@ public class TileEntityElectrolyticSeparator extends TileEntityElectricBlock imp
|
|||
return canFill(gases) || canFill(gases.swap());
|
||||
}
|
||||
|
||||
public boolean canFill(ChemicalPair gases)
|
||||
public boolean canFill(ChemicalPairOutput gases)
|
||||
{
|
||||
return (leftTank.canReceive(gases.leftGas.getGas()) && leftTank.getNeeded() >= gases.leftGas.amount
|
||||
&& rightTank.canReceive(gases.rightGas.getGas()) && rightTank.getNeeded() >= gases.rightGas.amount);
|
||||
}
|
||||
|
||||
public void fillTanks(ChemicalPair gases)
|
||||
public void fillTanks(ChemicalPairOutput gases)
|
||||
{
|
||||
if(gases == null) return;
|
||||
|
||||
|
|
|
@ -10,8 +10,8 @@ import mekanism.api.Range4D;
|
|||
import mekanism.api.infuse.InfuseObject;
|
||||
import mekanism.api.infuse.InfuseRegistry;
|
||||
import mekanism.api.infuse.InfuseType;
|
||||
import mekanism.api.infuse.InfusionInput;
|
||||
import mekanism.api.infuse.InfusionOutput;
|
||||
import mekanism.common.recipe.inputs.InfusionInput;
|
||||
import mekanism.common.recipe.outputs.InfusionOutput;
|
||||
import mekanism.common.Mekanism;
|
||||
import mekanism.common.MekanismItems;
|
||||
import mekanism.common.PacketHandler;
|
||||
|
|
|
@ -12,8 +12,8 @@ import mekanism.api.gas.GasStack;
|
|||
import mekanism.api.gas.GasTank;
|
||||
import mekanism.api.gas.IGasHandler;
|
||||
import mekanism.api.gas.ITubeConnection;
|
||||
import mekanism.api.recipe.PressurizedProducts;
|
||||
import mekanism.api.recipe.PressurizedRecipe;
|
||||
import mekanism.common.recipe.outputs.PressurizedProducts;
|
||||
import mekanism.common.recipe.machines.PressurizedRecipe;
|
||||
import mekanism.common.SideData;
|
||||
import mekanism.common.base.ISustainedData;
|
||||
import mekanism.common.block.BlockMachine.MachineType;
|
||||
|
@ -154,16 +154,16 @@ public class TileEntityPRC extends TileEntityBasicMachine implements IFluidHandl
|
|||
{
|
||||
PressurizedRecipe recipe = getRecipe();
|
||||
|
||||
recipe.reactants.use(inventory[0], inputFluidTank, inputGasTank);
|
||||
recipe.getInput().use(inventory[0], inputFluidTank, inputGasTank);
|
||||
|
||||
if(inventory[0].stackSize <= 0)
|
||||
{
|
||||
inventory[0] = null;
|
||||
}
|
||||
|
||||
recipe.products.fillTank(outputGasTank);
|
||||
recipe.getOutput().fillTank(outputGasTank);
|
||||
|
||||
recipe.products.addProducts(inventory, 2);
|
||||
recipe.getOutput().addProducts(inventory, 2);
|
||||
|
||||
markDirty();
|
||||
ejectorComponent.onOutput();
|
||||
|
@ -179,7 +179,7 @@ public class TileEntityPRC extends TileEntityBasicMachine implements IFluidHandl
|
|||
return false;
|
||||
}
|
||||
|
||||
PressurizedProducts products = recipe.products;
|
||||
PressurizedProducts products = recipe.getOutput();
|
||||
|
||||
if(products.getItemOutput() != null)
|
||||
{
|
||||
|
|
Loading…
Add table
Reference in a new issue