Merge branch 'patch-2' of https://github.com/anti344/BuildCraft into anti344-patch-2
This commit is contained in:
commit
3cf50c69f6
1 changed files with 76 additions and 2 deletions
|
@ -8,12 +8,18 @@
|
|||
*/
|
||||
package buildcraft.core;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
|
||||
import buildcraft.core.recipes.AssemblyRecipeManager;
|
||||
import buildcraft.core.recipes.RefineryRecipeManager;
|
||||
import com.google.common.base.Strings;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.nbt.NBTTagCompound;
|
||||
import net.minecraft.nbt.NBTTagList;
|
||||
import net.minecraft.world.biome.BiomeGenBase;
|
||||
import buildcraft.energy.worldgen.OilPopulate;
|
||||
import buildcraft.transport.ItemFacade;
|
||||
|
@ -24,6 +30,7 @@ import com.google.common.primitives.Ints;
|
|||
|
||||
import cpw.mods.fml.common.event.FMLInterModComms.IMCEvent;
|
||||
import cpw.mods.fml.common.event.FMLInterModComms.IMCMessage;
|
||||
import net.minecraftforge.fluids.FluidStack;
|
||||
|
||||
public class InterModComms {
|
||||
|
||||
|
@ -37,10 +44,77 @@ public class InterModComms {
|
|||
processOilLakeBiomeIMC(event, m);
|
||||
} else if (m.key.equals("oil-gen-exclude")) {
|
||||
processOilGenExcludeIMC(event, m);
|
||||
} else if (m.key.equals("add-assembly-recipe")){
|
||||
processAssemblyRecipeIMC(event, m);
|
||||
} else if (m.key.equals("add-refinery-recipe")){
|
||||
processRefineryRecipeIMC(event, m);
|
||||
} else if (m.key.equals("remove-assembly-recipe")){
|
||||
//TODO
|
||||
} else if (m.key.equals("remove-refinery-recipe")){
|
||||
//TODO
|
||||
} else {
|
||||
Logger.getLogger("Buildcraft").log(Level.WARNING, "Received IMC message with unknown key('%s') from %s!", new Object[]{m.key, m.getSender()});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static void processAssemblyRecipeIMC(IMCEvent event, IMCMessage msg){
|
||||
boolean failed = false;
|
||||
if (!msg.isNBTMessage()) {
|
||||
failed = true;
|
||||
} else {
|
||||
NBTTagCompound recipe = msg.getNBTValue();
|
||||
if (!recipe.hasKey("input", 9) || !recipe.hasKey("output", 10) || !recipe.hasKey("energy", 6)) { //Ints - NBTBase#NBTTypes
|
||||
failed = true;
|
||||
} else {
|
||||
NBTTagList list = (NBTTagList) recipe.getTag("input");
|
||||
List<ItemStack> input = new ArrayList<ItemStack>();
|
||||
for (int i = 0; i < list.tagCount(); i++) {
|
||||
ItemStack is = ItemStack.loadItemStackFromNBT(list.getCompoundTagAt(i));
|
||||
if (is != null) {
|
||||
input.add(is);
|
||||
}
|
||||
}
|
||||
ItemStack is = ItemStack.loadItemStackFromNBT(recipe.getCompoundTag("output"));
|
||||
if (is != null && !input.isEmpty()) {
|
||||
AssemblyRecipeManager.INSTANCE.addRecipe(recipe.getDouble("energy"), is, input.toArray(new ItemStack[input.size()]));
|
||||
} else {
|
||||
failed = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (failed) {
|
||||
Logger.getLogger("Buildcraft").log(Level.WARNING, "Received invalid assembly recipe IMC message from %s!", msg.getSender());
|
||||
}
|
||||
}
|
||||
|
||||
public static void processRefineryRecipeIMC(IMCEvent event, IMCMessage msg){
|
||||
boolean failed = false;
|
||||
if (!msg.isNBTMessage()) {
|
||||
failed = true;
|
||||
} else {
|
||||
NBTTagCompound recipe = msg.getNBTValue();
|
||||
if (!recipe.hasKey("input", 10) || !recipe.hasKey("output", 10) || !recipe.hasKey("energy", 3) || !recipe.hasKey("delay", 3)) {
|
||||
failed = true;
|
||||
} else {
|
||||
FluidStack output = FluidStack.loadFluidStackFromNBT(recipe.getCompoundTag("output"));
|
||||
FluidStack input = FluidStack.loadFluidStackFromNBT(recipe.getCompoundTag("input"));
|
||||
FluidStack input2 = null;
|
||||
if (recipe.hasKey("input_2", 10)) {
|
||||
input2 = FluidStack.loadFluidStackFromNBT(recipe.getCompoundTag("input_2"));
|
||||
}
|
||||
if (input != null && output != null) {
|
||||
RefineryRecipeManager.INSTANCE.addRecipe(input, input2, output, recipe.getInteger("energy"), recipe.getInteger("delay"));
|
||||
} else {
|
||||
failed = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (failed) {
|
||||
Logger.getLogger("Buildcraft").log(Level.WARNING, "Received invalid refinery recipe IMC message from %s!", msg.getSender());
|
||||
}
|
||||
}
|
||||
|
||||
public static void processAddFacadeIMC(IMCEvent event, IMCMessage m) {
|
||||
try {
|
||||
if (m.isStringMessage()) {
|
||||
|
|
Loading…
Add table
Reference in a new issue