Buggy stuff
This commit is contained in:
		| @@ -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()) { | ||||||
|   | |||||||
							
								
								
									
										24
									
								
								src/main/java/refinedstorage/tile/autocrafting/CraftingIngredient.java
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										24
									
								
								src/main/java/refinedstorage/tile/autocrafting/CraftingIngredient.java
									
									
									
									
									
										Executable 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; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -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,25 +25,72 @@ 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)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Raoul Van den Berge
					Raoul Van den Berge