Move autocrafting stuff in better package
This commit is contained in:
		| @@ -1,4 +1,4 @@ | |||||||
| package refinedstorage.tile.autocrafting; | package refinedstorage.autocrafting; | ||||||
| 
 | 
 | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| import net.minecraft.nbt.NBTTagCompound; | import net.minecraft.nbt.NBTTagCompound; | ||||||
| @@ -7,6 +7,7 @@ import net.minecraft.util.math.BlockPos; | |||||||
| import net.minecraft.world.World; | import net.minecraft.world.World; | ||||||
| import net.minecraftforge.common.util.Constants; | import net.minecraftforge.common.util.Constants; | ||||||
| import refinedstorage.item.ItemPattern; | import refinedstorage.item.ItemPattern; | ||||||
|  | import refinedstorage.tile.TileCrafter; | ||||||
| 
 | 
 | ||||||
| public class CraftingPattern { | public class CraftingPattern { | ||||||
|     public static final String NBT = "Pattern"; |     public static final String NBT = "Pattern"; | ||||||
| @@ -1,9 +1,8 @@ | |||||||
| package refinedstorage.tile.autocrafting.task; | package refinedstorage.autocrafting; | ||||||
| 
 | 
 | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| import net.minecraft.nbt.NBTTagCompound; | import net.minecraft.nbt.NBTTagCompound; | ||||||
| import refinedstorage.RefinedStorageUtils; | import refinedstorage.RefinedStorageUtils; | ||||||
| import refinedstorage.tile.autocrafting.CraftingPattern; |  | ||||||
| import refinedstorage.tile.controller.TileController; | import refinedstorage.tile.controller.TileController; | ||||||
| 
 | 
 | ||||||
| public class CraftingTaskScheduler { | public class CraftingTaskScheduler { | ||||||
							
								
								
									
										179
									
								
								src/main/java/refinedstorage/autocrafting/task/BasicCraftingTask.java
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										179
									
								
								src/main/java/refinedstorage/autocrafting/task/BasicCraftingTask.java
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,179 @@ | |||||||
|  | package refinedstorage.autocrafting.task; | ||||||
|  |  | ||||||
|  | import net.minecraft.item.ItemStack; | ||||||
|  | import net.minecraft.nbt.NBTTagCompound; | ||||||
|  | import net.minecraft.nbt.NBTTagList; | ||||||
|  | import net.minecraft.util.text.TextFormatting; | ||||||
|  | import net.minecraftforge.common.util.Constants; | ||||||
|  | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.CraftingPattern; | ||||||
|  | import refinedstorage.tile.controller.TileController; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | public class BasicCraftingTask implements ICraftingTask { | ||||||
|  |     public static final int ID = 0; | ||||||
|  |  | ||||||
|  |     public static final String NBT_SATISFIED = "Satisfied"; | ||||||
|  |     public static final String NBT_CHECKED = "Checked"; | ||||||
|  |     public static final String NBT_CHILD_TASKS = "ChildTasks"; | ||||||
|  |     public static final String NBT_TOOK = "Took"; | ||||||
|  |  | ||||||
|  |     private CraftingPattern pattern; | ||||||
|  |     private boolean satisfied[]; | ||||||
|  |     private boolean checked[]; | ||||||
|  |     private boolean childTasks[]; | ||||||
|  |     private List<ItemStack> itemsTook = new ArrayList<ItemStack>(); | ||||||
|  |     private boolean updatedOnce; | ||||||
|  |  | ||||||
|  |     public BasicCraftingTask(CraftingPattern pattern) { | ||||||
|  |         this.pattern = pattern; | ||||||
|  |         this.satisfied = new boolean[pattern.getInputs().length]; | ||||||
|  |         this.checked = new boolean[pattern.getInputs().length]; | ||||||
|  |         this.childTasks = new boolean[pattern.getInputs().length]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public BasicCraftingTask(NBTTagCompound tag, CraftingPattern pattern) { | ||||||
|  |         this.pattern = pattern; | ||||||
|  |         this.satisfied = RefinedStorageUtils.readBooleanArray(tag, NBT_SATISFIED); | ||||||
|  |         this.checked = RefinedStorageUtils.readBooleanArray(tag, NBT_CHECKED); | ||||||
|  |         this.childTasks = RefinedStorageUtils.readBooleanArray(tag, NBT_CHILD_TASKS); | ||||||
|  |  | ||||||
|  |         NBTTagList tookList = tag.getTagList(NBT_TOOK, Constants.NBT.TAG_COMPOUND); | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < tookList.tagCount(); ++i) { | ||||||
|  |             itemsTook.add(ItemStack.loadItemStackFromNBT(tookList.getCompoundTagAt(i))); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public CraftingPattern getPattern() { | ||||||
|  |         return pattern; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean update(TileController controller) { | ||||||
|  |         this.updatedOnce = true; | ||||||
|  |  | ||||||
|  |         boolean done = true; | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < pattern.getInputs().length; ++i) { | ||||||
|  |             checked[i] = true; | ||||||
|  |  | ||||||
|  |             ItemStack input = pattern.getInputs()[i]; | ||||||
|  |  | ||||||
|  |             if (!satisfied[i]) { | ||||||
|  |                 done = false; | ||||||
|  |  | ||||||
|  |                 ItemStack took = controller.take(input, 1); | ||||||
|  |  | ||||||
|  |                 if (took != null) { | ||||||
|  |                     itemsTook.add(took); | ||||||
|  |  | ||||||
|  |                     satisfied[i] = true; | ||||||
|  |                 } else if (!childTasks[i]) { | ||||||
|  |                     CraftingPattern pattern = controller.getPattern(input); | ||||||
|  |  | ||||||
|  |                     if (pattern != null) { | ||||||
|  |                         controller.addCraftingTask(controller.createCraftingTask(pattern)); | ||||||
|  |  | ||||||
|  |                         childTasks[i] = true; | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     break; | ||||||
|  |                 } else { | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return done; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void onDone(TileController controller) { | ||||||
|  |         for (ItemStack output : pattern.getOutputs()) { | ||||||
|  |             controller.push(output); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (pattern.getByproducts() != null) { | ||||||
|  |             for (ItemStack byproduct : pattern.getByproducts()) { | ||||||
|  |                 controller.push(byproduct); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void onCancelled(TileController controller) { | ||||||
|  |         for (ItemStack took : itemsTook) { | ||||||
|  |             controller.push(took); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void writeToNBT(NBTTagCompound tag) { | ||||||
|  |         NBTTagCompound patternTag = new NBTTagCompound(); | ||||||
|  |         pattern.writeToNBT(patternTag); | ||||||
|  |         tag.setTag(CraftingPattern.NBT, patternTag); | ||||||
|  |  | ||||||
|  |         RefinedStorageUtils.writeBooleanArray(tag, NBT_SATISFIED, satisfied); | ||||||
|  |         RefinedStorageUtils.writeBooleanArray(tag, NBT_CHECKED, checked); | ||||||
|  |         RefinedStorageUtils.writeBooleanArray(tag, NBT_CHILD_TASKS, childTasks); | ||||||
|  |  | ||||||
|  |         NBTTagList tookList = new NBTTagList(); | ||||||
|  |  | ||||||
|  |         for (ItemStack took : itemsTook) { | ||||||
|  |             tookList.appendTag(took.serializeNBT()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         tag.setTag(NBT_TOOK, tookList); | ||||||
|  |  | ||||||
|  |         tag.setInteger("Type", ID); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public String getInfo() { | ||||||
|  |         if (!updatedOnce) { | ||||||
|  |             return "{not_started_yet}"; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         StringBuilder builder = new StringBuilder(); | ||||||
|  |  | ||||||
|  |         builder.append(TextFormatting.YELLOW).append("{missing_items}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |  | ||||||
|  |         int missingItems = 0; | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < pattern.getInputs().length; ++i) { | ||||||
|  |             ItemStack input = pattern.getInputs()[i]; | ||||||
|  |  | ||||||
|  |             if (checked[i] && !satisfied[i] && !childTasks[i]) { | ||||||
|  |                 builder.append("- ").append(input.getDisplayName()).append("\n"); | ||||||
|  |  | ||||||
|  |                 missingItems++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (missingItems == 0) { | ||||||
|  |             builder.append(TextFormatting.GRAY).append(TextFormatting.ITALIC).append("{none}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         builder.append(TextFormatting.YELLOW).append("{items_crafting}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |  | ||||||
|  |         int itemsCrafting = 0; | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < pattern.getInputs().length; ++i) { | ||||||
|  |             ItemStack input = pattern.getInputs()[i]; | ||||||
|  |  | ||||||
|  |             if (!satisfied[i] && childTasks[i]) { | ||||||
|  |                 builder.append("- ").append(input.getUnlocalizedName()).append(".name").append("\n"); | ||||||
|  |  | ||||||
|  |                 itemsCrafting++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (itemsCrafting == 0) { | ||||||
|  |             builder.append(TextFormatting.GRAY).append(TextFormatting.ITALIC).append("{none}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return builder.toString(); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										19
									
								
								src/main/java/refinedstorage/autocrafting/task/ICraftingTask.java
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										19
									
								
								src/main/java/refinedstorage/autocrafting/task/ICraftingTask.java
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | package refinedstorage.autocrafting.task; | ||||||
|  |  | ||||||
|  | import net.minecraft.nbt.NBTTagCompound; | ||||||
|  | import refinedstorage.autocrafting.CraftingPattern; | ||||||
|  | import refinedstorage.tile.controller.TileController; | ||||||
|  |  | ||||||
|  | public interface ICraftingTask { | ||||||
|  |     CraftingPattern getPattern(); | ||||||
|  |  | ||||||
|  |     boolean update(TileController controller); | ||||||
|  |  | ||||||
|  |     void onDone(TileController controller); | ||||||
|  |  | ||||||
|  |     void onCancelled(TileController controller); | ||||||
|  |  | ||||||
|  |     void writeToNBT(NBTTagCompound tag); | ||||||
|  |  | ||||||
|  |     String getInfo(); | ||||||
|  | } | ||||||
							
								
								
									
										191
									
								
								src/main/java/refinedstorage/autocrafting/task/ProcessingCraftingTask.java
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										191
									
								
								src/main/java/refinedstorage/autocrafting/task/ProcessingCraftingTask.java
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,191 @@ | |||||||
|  | package refinedstorage.autocrafting.task; | ||||||
|  |  | ||||||
|  | import net.minecraft.item.ItemStack; | ||||||
|  | import net.minecraft.nbt.NBTTagCompound; | ||||||
|  | import net.minecraft.util.text.TextFormatting; | ||||||
|  | import net.minecraftforge.items.IItemHandler; | ||||||
|  | import net.minecraftforge.items.ItemHandlerHelper; | ||||||
|  | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.CraftingPattern; | ||||||
|  | import refinedstorage.tile.TileCrafter; | ||||||
|  | import refinedstorage.tile.controller.TileController; | ||||||
|  |  | ||||||
|  | public class ProcessingCraftingTask implements ICraftingTask { | ||||||
|  |     public static final int ID = 1; | ||||||
|  |  | ||||||
|  |     public static final String NBT_INSERTED = "Inserted"; | ||||||
|  |     public static final String NBT_CHILD_TASKS = "ChildTasks"; | ||||||
|  |     public static final String NBT_SATISFIED = "Satisfied"; | ||||||
|  |  | ||||||
|  |     private CraftingPattern pattern; | ||||||
|  |     private boolean inserted[]; | ||||||
|  |     private boolean childTasks[]; | ||||||
|  |     private boolean satisfied[]; | ||||||
|  |     private boolean updatedOnce; | ||||||
|  |  | ||||||
|  |     public ProcessingCraftingTask(CraftingPattern pattern) { | ||||||
|  |         this.pattern = pattern; | ||||||
|  |         this.inserted = new boolean[pattern.getInputs().length]; | ||||||
|  |         this.childTasks = new boolean[pattern.getInputs().length]; | ||||||
|  |         this.satisfied = new boolean[pattern.getOutputs().length]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ProcessingCraftingTask(NBTTagCompound tag, CraftingPattern pattern) { | ||||||
|  |         this.pattern = pattern; | ||||||
|  |         this.inserted = RefinedStorageUtils.readBooleanArray(tag, NBT_INSERTED); | ||||||
|  |         this.childTasks = RefinedStorageUtils.readBooleanArray(tag, NBT_CHILD_TASKS); | ||||||
|  |         this.satisfied = RefinedStorageUtils.readBooleanArray(tag, NBT_SATISFIED); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public CraftingPattern getPattern() { | ||||||
|  |         return pattern; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean update(TileController controller) { | ||||||
|  |         this.updatedOnce = true; | ||||||
|  |  | ||||||
|  |         TileCrafter crafter = pattern.getCrafter(controller.getWorld()); | ||||||
|  |         IItemHandler handler = RefinedStorageUtils.getItemHandler(crafter.getFacingTile(), crafter.getDirection().getOpposite()); | ||||||
|  |  | ||||||
|  |         if (handler != null) { | ||||||
|  |             for (int i = 0; i < inserted.length; ++i) { | ||||||
|  |                 if (!inserted[i]) { | ||||||
|  |                     ItemStack input = pattern.getInputs()[i]; | ||||||
|  |                     ItemStack took = controller.take(input, 1); | ||||||
|  |  | ||||||
|  |                     if (took != null) { | ||||||
|  |                         if (ItemHandlerHelper.insertItem(handler, took, true) == null) { | ||||||
|  |                             ItemHandlerHelper.insertItem(handler, took, false); | ||||||
|  |  | ||||||
|  |                             inserted[i] = true; | ||||||
|  |                         } else { | ||||||
|  |                             controller.push(took); | ||||||
|  |                         } | ||||||
|  |                     } else if (!childTasks[i]) { | ||||||
|  |                         CraftingPattern pattern = controller.getPattern(input); | ||||||
|  |  | ||||||
|  |                         if (pattern != null) { | ||||||
|  |                             childTasks[i] = true; | ||||||
|  |  | ||||||
|  |                             controller.addCraftingTask(controller.createCraftingTask(pattern)); | ||||||
|  |  | ||||||
|  |                             break; | ||||||
|  |                         } | ||||||
|  |                     } else { | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < satisfied.length; ++i) { | ||||||
|  |             if (!satisfied[i]) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void onPushed(ItemStack inserted) { | ||||||
|  |         for (int i = 0; i < pattern.getOutputs().length; ++i) { | ||||||
|  |             if (!satisfied[i] && RefinedStorageUtils.compareStackNoQuantity(inserted, pattern.getOutputs()[i])) { | ||||||
|  |                 satisfied[i] = true; | ||||||
|  |  | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void onDone(TileController controller) { | ||||||
|  |         // NO OP | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void onCancelled(TileController controller) { | ||||||
|  |         // NO OP | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void writeToNBT(NBTTagCompound tag) { | ||||||
|  |         NBTTagCompound patternTag = new NBTTagCompound(); | ||||||
|  |         pattern.writeToNBT(patternTag); | ||||||
|  |         tag.setTag(CraftingPattern.NBT, patternTag); | ||||||
|  |  | ||||||
|  |         RefinedStorageUtils.writeBooleanArray(tag, NBT_INSERTED, inserted); | ||||||
|  |         RefinedStorageUtils.writeBooleanArray(tag, NBT_CHILD_TASKS, childTasks); | ||||||
|  |         RefinedStorageUtils.writeBooleanArray(tag, NBT_SATISFIED, satisfied); | ||||||
|  |  | ||||||
|  |         tag.setInteger("Type", ID); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public String getInfo() { | ||||||
|  |         if (!updatedOnce) { | ||||||
|  |             return "{not_started_yet}"; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         StringBuilder builder = new StringBuilder(); | ||||||
|  |  | ||||||
|  |         builder.append(TextFormatting.YELLOW).append("{missing_items}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |  | ||||||
|  |         int missingItems = 0; | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < pattern.getInputs().length; ++i) { | ||||||
|  |             ItemStack input = pattern.getInputs()[i]; | ||||||
|  |  | ||||||
|  |             if (!inserted[i] && !childTasks[i]) { | ||||||
|  |                 builder.append("- ").append(input.getDisplayName()).append("\n"); | ||||||
|  |  | ||||||
|  |                 missingItems++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (missingItems == 0) { | ||||||
|  |             builder.append(TextFormatting.GRAY).append(TextFormatting.ITALIC).append("{none}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         builder.append(TextFormatting.YELLOW).append("{items_crafting}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |  | ||||||
|  |         int itemsCrafting = 0; | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < pattern.getInputs().length; ++i) { | ||||||
|  |             ItemStack input = pattern.getInputs()[i]; | ||||||
|  |  | ||||||
|  |             if (!inserted[i] && childTasks[i]) { | ||||||
|  |                 builder.append("- ").append(input.getUnlocalizedName()).append(".name").append("\n"); | ||||||
|  |  | ||||||
|  |                 itemsCrafting++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (itemsCrafting == 0) { | ||||||
|  |             builder.append(TextFormatting.GRAY).append(TextFormatting.ITALIC).append("{none}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         builder.append(TextFormatting.YELLOW).append("{items_processing}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |  | ||||||
|  |         int itemsProcessing = 0; | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < pattern.getInputs().length; ++i) { | ||||||
|  |             ItemStack input = pattern.getInputs()[i]; | ||||||
|  |  | ||||||
|  |             if (inserted[i]) { | ||||||
|  |                 builder.append("- ").append(input.getDisplayName()).append("\n"); | ||||||
|  |  | ||||||
|  |                 itemsProcessing++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (itemsProcessing == 0) { | ||||||
|  |             builder.append(TextFormatting.GRAY).append(TextFormatting.ITALIC).append("{none}").append(TextFormatting.RESET).append("\n"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return builder.toString(); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -10,7 +10,7 @@ import net.minecraft.util.math.BlockPos; | |||||||
| import net.minecraft.world.World; | import net.minecraft.world.World; | ||||||
| import refinedstorage.RefinedStorage; | import refinedstorage.RefinedStorage; | ||||||
| import refinedstorage.RefinedStorageGui; | import refinedstorage.RefinedStorageGui; | ||||||
| import refinedstorage.tile.autocrafting.TileCrafter; | import refinedstorage.tile.TileCrafter; | ||||||
|  |  | ||||||
| public class BlockCrafter extends BlockMachine { | public class BlockCrafter extends BlockMachine { | ||||||
|     public BlockCrafter() { |     public BlockCrafter() { | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ import net.minecraft.util.math.BlockPos; | |||||||
| import net.minecraft.world.World; | import net.minecraft.world.World; | ||||||
| import refinedstorage.RefinedStorage; | import refinedstorage.RefinedStorage; | ||||||
| import refinedstorage.RefinedStorageGui; | import refinedstorage.RefinedStorageGui; | ||||||
| import refinedstorage.tile.autocrafting.TileCraftingMonitor; | import refinedstorage.tile.TileCraftingMonitor; | ||||||
|  |  | ||||||
| public class BlockCraftingMonitor extends BlockMachine { | public class BlockCraftingMonitor extends BlockMachine { | ||||||
|     public BlockCraftingMonitor() { |     public BlockCraftingMonitor() { | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ import net.minecraft.util.math.BlockPos; | |||||||
| import net.minecraft.world.World; | import net.minecraft.world.World; | ||||||
| import refinedstorage.RefinedStorage; | import refinedstorage.RefinedStorage; | ||||||
| import refinedstorage.RefinedStorageGui; | import refinedstorage.RefinedStorageGui; | ||||||
| import refinedstorage.tile.autocrafting.TileProcessingPatternEncoder; | import refinedstorage.tile.TileProcessingPatternEncoder; | ||||||
|  |  | ||||||
| public class BlockProcessingPatternEncoder extends BlockBase { | public class BlockProcessingPatternEncoder extends BlockBase { | ||||||
|     public BlockProcessingPatternEncoder() { |     public BlockProcessingPatternEncoder() { | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import net.minecraft.entity.player.EntityPlayer; | |||||||
| import net.minecraft.inventory.Slot; | import net.minecraft.inventory.Slot; | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| import net.minecraftforge.items.SlotItemHandler; | import net.minecraftforge.items.SlotItemHandler; | ||||||
| import refinedstorage.tile.autocrafting.TileCrafter; | import refinedstorage.tile.TileCrafter; | ||||||
|  |  | ||||||
| public class ContainerCrafter extends ContainerStorage { | public class ContainerCrafter extends ContainerStorage { | ||||||
|     public ContainerCrafter(EntityPlayer player, TileCrafter crafter) { |     public ContainerCrafter(EntityPlayer player, TileCrafter crafter) { | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import net.minecraft.entity.player.EntityPlayer; | |||||||
| import net.minecraftforge.items.SlotItemHandler; | import net.minecraftforge.items.SlotItemHandler; | ||||||
| import refinedstorage.container.slot.SlotOutput; | import refinedstorage.container.slot.SlotOutput; | ||||||
| import refinedstorage.container.slot.SlotSpecimen; | import refinedstorage.container.slot.SlotSpecimen; | ||||||
| import refinedstorage.tile.autocrafting.TileProcessingPatternEncoder; | import refinedstorage.tile.TileProcessingPatternEncoder; | ||||||
|  |  | ||||||
| public class ContainerProcessingPatternEncoder extends ContainerBase { | public class ContainerProcessingPatternEncoder extends ContainerBase { | ||||||
|     public ContainerProcessingPatternEncoder(EntityPlayer player, TileProcessingPatternEncoder processingPatternEncoder) { |     public ContainerProcessingPatternEncoder(EntityPlayer player, TileProcessingPatternEncoder processingPatternEncoder) { | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ import refinedstorage.RefinedStorageUtils; | |||||||
| import refinedstorage.container.ContainerCrafter; | import refinedstorage.container.ContainerCrafter; | ||||||
| import refinedstorage.gui.sidebutton.SideButtonRedstoneMode; | import refinedstorage.gui.sidebutton.SideButtonRedstoneMode; | ||||||
| import refinedstorage.item.ItemPattern; | import refinedstorage.item.ItemPattern; | ||||||
| import refinedstorage.tile.autocrafting.TileCrafter; | import refinedstorage.tile.TileCrafter; | ||||||
|  |  | ||||||
| public class GuiCrafter extends GuiBase { | public class GuiCrafter extends GuiBase { | ||||||
|     private TileCrafter crafter; |     private TileCrafter crafter; | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ import refinedstorage.RefinedStorageUtils; | |||||||
| import refinedstorage.container.ContainerCraftingMonitor; | import refinedstorage.container.ContainerCraftingMonitor; | ||||||
| import refinedstorage.gui.sidebutton.SideButtonRedstoneMode; | import refinedstorage.gui.sidebutton.SideButtonRedstoneMode; | ||||||
| import refinedstorage.network.MessageCraftingMonitorCancel; | import refinedstorage.network.MessageCraftingMonitorCancel; | ||||||
| import refinedstorage.tile.autocrafting.TileCraftingMonitor; | import refinedstorage.tile.TileCraftingMonitor; | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|   | |||||||
| @@ -11,9 +11,6 @@ import refinedstorage.RefinedStorageUtils; | |||||||
| import refinedstorage.container.*; | import refinedstorage.container.*; | ||||||
| import refinedstorage.storage.IStorageGui; | import refinedstorage.storage.IStorageGui; | ||||||
| import refinedstorage.tile.*; | import refinedstorage.tile.*; | ||||||
| import refinedstorage.tile.autocrafting.TileCrafter; |  | ||||||
| import refinedstorage.tile.autocrafting.TileCraftingMonitor; |  | ||||||
| import refinedstorage.tile.autocrafting.TileProcessingPatternEncoder; |  | ||||||
| import refinedstorage.tile.controller.TileController; | import refinedstorage.tile.controller.TileController; | ||||||
| import refinedstorage.tile.grid.TileGrid; | import refinedstorage.tile.grid.TileGrid; | ||||||
| import refinedstorage.tile.grid.WirelessGrid; | import refinedstorage.tile.grid.WirelessGrid; | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import net.minecraft.init.SoundEvents; | |||||||
| import refinedstorage.RefinedStorage; | import refinedstorage.RefinedStorage; | ||||||
| import refinedstorage.container.ContainerProcessingPatternEncoder; | import refinedstorage.container.ContainerProcessingPatternEncoder; | ||||||
| import refinedstorage.network.MessageGridPatternCreate; | import refinedstorage.network.MessageGridPatternCreate; | ||||||
| import refinedstorage.tile.autocrafting.TileProcessingPatternEncoder; | import refinedstorage.tile.TileProcessingPatternEncoder; | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import net.minecraft.entity.player.EntityPlayerMP; | |||||||
| import net.minecraft.tileentity.TileEntity; | import net.minecraft.tileentity.TileEntity; | ||||||
| import net.minecraft.util.math.BlockPos; | import net.minecraft.util.math.BlockPos; | ||||||
| import net.minecraftforge.fml.common.network.simpleimpl.IMessage; | import net.minecraftforge.fml.common.network.simpleimpl.IMessage; | ||||||
| import refinedstorage.tile.autocrafting.TileCraftingMonitor; | import refinedstorage.tile.TileCraftingMonitor; | ||||||
|  |  | ||||||
| public class MessageCraftingMonitorCancel extends MessageHandlerPlayerToServer<MessageCraftingMonitorCancel> implements IMessage { | public class MessageCraftingMonitorCancel extends MessageHandlerPlayerToServer<MessageCraftingMonitorCancel> implements IMessage { | ||||||
|     private int x; |     private int x; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import net.minecraft.tileentity.TileEntity; | |||||||
| import net.minecraft.util.math.BlockPos; | import net.minecraft.util.math.BlockPos; | ||||||
| import net.minecraftforge.fml.common.network.simpleimpl.IMessage; | import net.minecraftforge.fml.common.network.simpleimpl.IMessage; | ||||||
| import refinedstorage.block.EnumGridType; | import refinedstorage.block.EnumGridType; | ||||||
| import refinedstorage.tile.autocrafting.TileProcessingPatternEncoder; | import refinedstorage.tile.TileProcessingPatternEncoder; | ||||||
| import refinedstorage.tile.grid.TileGrid; | import refinedstorage.tile.grid.TileGrid; | ||||||
|  |  | ||||||
| public class MessageGridPatternCreate extends MessageHandlerPlayerToServer<MessageGridPatternCreate> implements IMessage { | public class MessageGridPatternCreate extends MessageHandlerPlayerToServer<MessageGridPatternCreate> implements IMessage { | ||||||
|   | |||||||
| @@ -31,9 +31,6 @@ import refinedstorage.solderer.SoldererRecipeStorage; | |||||||
| import refinedstorage.solderer.SoldererRecipeUpgrade; | import refinedstorage.solderer.SoldererRecipeUpgrade; | ||||||
| import refinedstorage.storage.NBTStorage; | import refinedstorage.storage.NBTStorage; | ||||||
| import refinedstorage.tile.*; | import refinedstorage.tile.*; | ||||||
| import refinedstorage.tile.autocrafting.TileCrafter; |  | ||||||
| import refinedstorage.tile.autocrafting.TileCraftingMonitor; |  | ||||||
| import refinedstorage.tile.autocrafting.TileProcessingPatternEncoder; |  | ||||||
| import refinedstorage.tile.controller.TileController; | import refinedstorage.tile.controller.TileController; | ||||||
| import refinedstorage.tile.grid.TileGrid; | import refinedstorage.tile.grid.TileGrid; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -18,11 +18,11 @@ import net.minecraftforge.items.CapabilityItemHandler; | |||||||
| import net.minecraftforge.items.IItemHandler; | import net.minecraftforge.items.IItemHandler; | ||||||
| import refinedstorage.RefinedStorageItems; | import refinedstorage.RefinedStorageItems; | ||||||
| import refinedstorage.RefinedStorageUtils; | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.CraftingTaskScheduler; | ||||||
| import refinedstorage.container.ContainerConstructor; | import refinedstorage.container.ContainerConstructor; | ||||||
| import refinedstorage.inventory.BasicItemHandler; | import refinedstorage.inventory.BasicItemHandler; | ||||||
| import refinedstorage.inventory.BasicItemValidator; | import refinedstorage.inventory.BasicItemValidator; | ||||||
| import refinedstorage.item.ItemUpgrade; | import refinedstorage.item.ItemUpgrade; | ||||||
| import refinedstorage.tile.autocrafting.task.CraftingTaskScheduler; |  | ||||||
| import refinedstorage.tile.config.ICompareConfig; | import refinedstorage.tile.config.ICompareConfig; | ||||||
|  |  | ||||||
| import java.lang.reflect.Field; | import java.lang.reflect.Field; | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| package refinedstorage.tile.autocrafting; | package refinedstorage.tile; | ||||||
| 
 | 
 | ||||||
| import net.minecraft.inventory.Container; | import net.minecraft.inventory.Container; | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| @@ -11,14 +11,13 @@ import net.minecraftforge.items.IItemHandler; | |||||||
| import net.minecraftforge.items.wrapper.CombinedInvWrapper; | import net.minecraftforge.items.wrapper.CombinedInvWrapper; | ||||||
| import refinedstorage.RefinedStorageItems; | import refinedstorage.RefinedStorageItems; | ||||||
| import refinedstorage.RefinedStorageUtils; | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.task.ICraftingTask; | ||||||
| import refinedstorage.container.ContainerCrafter; | import refinedstorage.container.ContainerCrafter; | ||||||
| import refinedstorage.inventory.BasicItemHandler; | import refinedstorage.inventory.BasicItemHandler; | ||||||
| import refinedstorage.inventory.BasicItemValidator; | import refinedstorage.inventory.BasicItemValidator; | ||||||
| import refinedstorage.inventory.IItemValidator; | import refinedstorage.inventory.IItemValidator; | ||||||
| import refinedstorage.item.ItemPattern; | import refinedstorage.item.ItemPattern; | ||||||
| import refinedstorage.item.ItemUpgrade; | import refinedstorage.item.ItemUpgrade; | ||||||
| import refinedstorage.tile.TileMachine; |  | ||||||
| import refinedstorage.tile.autocrafting.task.ICraftingTask; |  | ||||||
| 
 | 
 | ||||||
| public class TileCrafter extends TileMachine { | public class TileCrafter extends TileMachine { | ||||||
|     private BasicItemHandler patterns = new BasicItemHandler(PATTERN_SLOTS, this, new IItemValidator() { |     private BasicItemHandler patterns = new BasicItemHandler(PATTERN_SLOTS, this, new IItemValidator() { | ||||||
| @@ -1,12 +1,11 @@ | |||||||
| package refinedstorage.tile.autocrafting; | package refinedstorage.tile; | ||||||
| 
 | 
 | ||||||
| import io.netty.buffer.ByteBuf; | import io.netty.buffer.ByteBuf; | ||||||
| import net.minecraft.inventory.Container; | import net.minecraft.inventory.Container; | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| import net.minecraftforge.fml.common.network.ByteBufUtils; | import net.minecraftforge.fml.common.network.ByteBufUtils; | ||||||
|  | import refinedstorage.autocrafting.task.ICraftingTask; | ||||||
| import refinedstorage.container.ContainerCraftingMonitor; | import refinedstorage.container.ContainerCraftingMonitor; | ||||||
| import refinedstorage.tile.TileMachine; |  | ||||||
| import refinedstorage.tile.autocrafting.task.ICraftingTask; |  | ||||||
| 
 | 
 | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| @@ -11,11 +11,11 @@ import net.minecraftforge.items.IItemHandler; | |||||||
| import net.minecraftforge.items.ItemHandlerHelper; | import net.minecraftforge.items.ItemHandlerHelper; | ||||||
| import refinedstorage.RefinedStorageItems; | import refinedstorage.RefinedStorageItems; | ||||||
| import refinedstorage.RefinedStorageUtils; | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.CraftingTaskScheduler; | ||||||
| import refinedstorage.container.ContainerExporter; | import refinedstorage.container.ContainerExporter; | ||||||
| import refinedstorage.inventory.BasicItemHandler; | import refinedstorage.inventory.BasicItemHandler; | ||||||
| import refinedstorage.inventory.BasicItemValidator; | import refinedstorage.inventory.BasicItemValidator; | ||||||
| import refinedstorage.item.ItemUpgrade; | import refinedstorage.item.ItemUpgrade; | ||||||
| import refinedstorage.tile.autocrafting.task.CraftingTaskScheduler; |  | ||||||
| import refinedstorage.tile.config.ICompareConfig; | import refinedstorage.tile.config.ICompareConfig; | ||||||
|  |  | ||||||
| public class TileExporter extends TileMachine implements ICompareConfig { | public class TileExporter extends TileMachine implements ICompareConfig { | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| package refinedstorage.tile.autocrafting; | package refinedstorage.tile; | ||||||
| 
 | 
 | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| import net.minecraft.nbt.NBTTagCompound; | import net.minecraft.nbt.NBTTagCompound; | ||||||
| @@ -11,7 +11,6 @@ import refinedstorage.RefinedStorageUtils; | |||||||
| import refinedstorage.inventory.BasicItemHandler; | import refinedstorage.inventory.BasicItemHandler; | ||||||
| import refinedstorage.inventory.BasicItemValidator; | import refinedstorage.inventory.BasicItemValidator; | ||||||
| import refinedstorage.item.ItemPattern; | import refinedstorage.item.ItemPattern; | ||||||
| import refinedstorage.tile.TileBase; |  | ||||||
| 
 | 
 | ||||||
| public class TileProcessingPatternEncoder extends TileBase { | public class TileProcessingPatternEncoder extends TileBase { | ||||||
|     private BasicItemHandler patterns = new BasicItemHandler(2, this, new BasicItemValidator(RefinedStorageItems.PATTERN)); |     private BasicItemHandler patterns = new BasicItemHandler(2, this, new BasicItemValidator(RefinedStorageItems.PATTERN)); | ||||||
| @@ -3,10 +3,10 @@ package refinedstorage.tile.controller; | |||||||
| import net.minecraft.entity.player.EntityPlayerMP; | import net.minecraft.entity.player.EntityPlayerMP; | ||||||
| import net.minecraft.item.ItemStack; | import net.minecraft.item.ItemStack; | ||||||
| import refinedstorage.RefinedStorageUtils; | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.CraftingPattern; | ||||||
|  | import refinedstorage.autocrafting.task.ICraftingTask; | ||||||
| import refinedstorage.item.ItemWirelessGrid; | import refinedstorage.item.ItemWirelessGrid; | ||||||
| import refinedstorage.network.GridPullFlags; | import refinedstorage.network.GridPullFlags; | ||||||
| import refinedstorage.tile.autocrafting.CraftingPattern; |  | ||||||
| import refinedstorage.tile.autocrafting.task.ICraftingTask; |  | ||||||
|  |  | ||||||
| public class StorageHandler { | public class StorageHandler { | ||||||
|     public static final int MAX_CRAFTING_PER_REQUEST = 500; |     public static final int MAX_CRAFTING_PER_REQUEST = 500; | ||||||
|   | |||||||
| @@ -17,6 +17,10 @@ import net.minecraftforge.items.ItemHandlerHelper; | |||||||
| import refinedstorage.RefinedStorage; | import refinedstorage.RefinedStorage; | ||||||
| import refinedstorage.RefinedStorageBlocks; | import refinedstorage.RefinedStorageBlocks; | ||||||
| import refinedstorage.RefinedStorageUtils; | import refinedstorage.RefinedStorageUtils; | ||||||
|  | import refinedstorage.autocrafting.CraftingPattern; | ||||||
|  | import refinedstorage.autocrafting.task.BasicCraftingTask; | ||||||
|  | import refinedstorage.autocrafting.task.ICraftingTask; | ||||||
|  | import refinedstorage.autocrafting.task.ProcessingCraftingTask; | ||||||
| import refinedstorage.block.BlockController; | import refinedstorage.block.BlockController; | ||||||
| import refinedstorage.block.EnumControllerType; | import refinedstorage.block.EnumControllerType; | ||||||
| import refinedstorage.container.ContainerController; | import refinedstorage.container.ContainerController; | ||||||
| @@ -25,15 +29,7 @@ import refinedstorage.item.ItemPattern; | |||||||
| import refinedstorage.network.MessageGridItems; | import refinedstorage.network.MessageGridItems; | ||||||
| import refinedstorage.storage.IStorage; | import refinedstorage.storage.IStorage; | ||||||
| import refinedstorage.storage.IStorageProvider; | import refinedstorage.storage.IStorageProvider; | ||||||
| import refinedstorage.tile.ISynchronizedContainer; | import refinedstorage.tile.*; | ||||||
| import refinedstorage.tile.TileBase; |  | ||||||
| import refinedstorage.tile.TileMachine; |  | ||||||
| import refinedstorage.tile.TileWirelessTransmitter; |  | ||||||
| import refinedstorage.tile.autocrafting.CraftingPattern; |  | ||||||
| import refinedstorage.tile.autocrafting.TileCrafter; |  | ||||||
| import refinedstorage.tile.autocrafting.task.BasicCraftingTask; |  | ||||||
| import refinedstorage.tile.autocrafting.task.ICraftingTask; |  | ||||||
| import refinedstorage.tile.autocrafting.task.ProcessingCraftingTask; |  | ||||||
| import refinedstorage.tile.config.IRedstoneModeConfig; | import refinedstorage.tile.config.IRedstoneModeConfig; | ||||||
| import refinedstorage.tile.config.RedstoneMode; | import refinedstorage.tile.config.RedstoneMode; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Raoul Van den Berge
					Raoul Van den Berge