Buggy stuff

This commit is contained in:
Raoul Van den Berge
2016-04-10 21:46:16 +02:00
parent 0bf1591f0b
commit 080d61faf4
3 changed files with 90 additions and 5 deletions

View File

@@ -141,6 +141,18 @@ public class TileController extends TileBase implements IEnergyReceiver, INetwor
energyUsage += machine.getEnergyUsage(); energyUsage += machine.getEnergyUsage();
} }
} }
Iterator<CraftingTask> it = craftingTasks.iterator();
while (it.hasNext()) {
CraftingTask task = it.next();
if (task.attemptCraft(this)) {
it.remove();
push(task.getResult());
}
}
} }
if (isActive()) { if (isActive()) {

View File

@@ -0,0 +1,24 @@
package refinedstorage.tile.autocrafting;
import net.minecraft.item.ItemStack;
public class CraftingIngredient {
private ItemStack stack;
private boolean satisfied;
public CraftingIngredient(ItemStack stack) {
this.stack = stack;
}
public ItemStack getStack() {
return stack;
}
public boolean isSatisfied() {
return satisfied;
}
public void setSatisfied() {
this.satisfied = true;
}
}

View File

@@ -5,6 +5,7 @@ import net.minecraft.item.ItemStack;
import net.minecraft.item.crafting.CraftingManager; import net.minecraft.item.crafting.CraftingManager;
import net.minecraft.item.crafting.IRecipe; import net.minecraft.item.crafting.IRecipe;
import refinedstorage.container.ContainerDummy; import refinedstorage.container.ContainerDummy;
import refinedstorage.tile.TileController;
import refinedstorage.util.InventoryUtils; import refinedstorage.util.InventoryUtils;
import java.util.ArrayList; import java.util.ArrayList;
@@ -12,9 +13,10 @@ import java.util.List;
public class CraftingTask { public class CraftingTask {
private ItemStack result; private ItemStack result;
private List<ItemStack> ingredients; private List<CraftingIngredient> ingredients;
private CraftingTask parentTask;
public CraftingTask(ItemStack result, List<ItemStack> ingredients) { public CraftingTask(ItemStack result, List<CraftingIngredient> ingredients) {
this.result = result; this.result = result;
this.ingredients = ingredients; this.ingredients = ingredients;
} }
@@ -23,26 +25,73 @@ public class CraftingTask {
return result; return result;
} }
public CraftingTask getParentTask() {
return parentTask;
}
public void setParentTask(CraftingTask parentTask) {
this.parentTask = parentTask;
}
public boolean attemptCraft(TileController controller) {
for (CraftingIngredient ingredient : ingredients) {
if (!ingredient.isSatisfied()) {
ItemStack took = controller.take(ingredient.getStack().copy());
if (took != null) {
ingredient.setSatisfied();
} else {
// schedule a crafting task, if it doesn't exist yet
for (CraftingTask task : controller.getCraftingTasks()) {
if (InventoryUtils.compareStack(task.getResult(), result) & task.getParentTask() == this) {
return false;
}
}
CraftingTask subTask = CraftingTask.create(ingredient.getStack());
subTask.setParentTask(this);
controller.getCraftingTasks().add(subTask);
}
}
}
for (CraftingIngredient ingredient : ingredients) {
if (!ingredient.isSatisfied()) {
return false;
}
}
return true;
}
public static CraftingTask create(ItemStack result) { public static CraftingTask create(ItemStack result) {
List<ItemStack> ingredients = new ArrayList<ItemStack>(); List<CraftingIngredient> ingredients = new ArrayList<CraftingIngredient>();
addCraftingIngredients(ingredients, result); addCraftingIngredients(ingredients, result);
return new CraftingTask(result, ingredients); return new CraftingTask(result, ingredients);
} }
private static void addCraftingIngredients(List<ItemStack> ingredients, ItemStack stack) { private static void addCraftingIngredients(List<CraftingIngredient> ingredients, ItemStack stack) {
for (IRecipe recipe : CraftingManager.getInstance().getRecipeList()) { for (IRecipe recipe : CraftingManager.getInstance().getRecipeList()) {
ItemStack output = recipe.getRecipeOutput(); ItemStack output = recipe.getRecipeOutput();
// this may seem unnecessary but keep it, some horrible mods return a null itemstack // this may seem unnecessary but keep it, some horrible mods return a null itemstack
if (output != null && output.getItem() != null) { if (output != null && output.getItem() != null) {
boolean hasIngredients = false;
// first check if the output is the stack we're adding the ingredients for // first check if the output is the stack we're adding the ingredients for
if (InventoryUtils.compareStack(output, stack)) { if (InventoryUtils.compareStack(output, stack)) {
// now get all the ingredients from that recipe // now get all the ingredients from that recipe
for (ItemStack ingredient : recipe.getRemainingItems(new InventoryCrafting(new ContainerDummy(), 3, 3))) { for (ItemStack ingredient : recipe.getRemainingItems(new InventoryCrafting(new ContainerDummy(), 3, 3))) {
ingredients.add(ingredient); ingredients.add(new CraftingIngredient(ingredient));
hasIngredients = true;
break;
} }
} }
if (!hasIngredients) {
ingredients.add(new CraftingIngredient(stack));
}
} }
} }
} }