-
Notifications
You must be signed in to change notification settings - Fork 192
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cooking Pot's interface does not check stack counts for ingredients #26
Comments
I might work on this but I'd need to change recipe format. Is that a possible option? "ingredients": [
{
"item": "minecraft:beetroot"
},
{
"item": "minecraft:beetroot"
},
{
"item": "minecraft:beetroot"
}
], changed to: "ingredients": [
{
"item": "minecraft:beetroot",
"count": 3
}
], |
Hmm, sure! It could even allow cooking recipes to be more expensive than six ingredients. |
Hello, I noticed the "help wanted" sign and thought I'd step in... Matching stacks of input against ingredients seems to have a serious scaling problem, which you mentioned. Minecraft's With that in mind, could the problem itself be reconsidered?
Could this be seen as a need for a new item rather than as a problem with the Cooking Pot? Maybe the Cooking Pot's limits are reasonable, and it's the job of a new block or item to simplify things. For example, the Item Router in the mod Modular Routers is able to handle round-robin moving of items. Would Farmer's Delight benefit from a new block that could do just that? Or, what if Farmer's Delight has a Cookbook item that references one recipe: When a Cookbook is in the Cooking Pot's input, the Pot only accepts additional input that matches that recipe. When the output is produced, the Cookbook stays in the input, allowing the Pot to automate one recipe. This only avoids part of the scaling problem (ingredients still need to match the input), but maybe there is a similar, simpler solution out there. Or, if the Pot is the problem, maybe the input slots could accept stacks only 1 item deep. The Smelter in Tinker's Construct uses this restriction to prevent dealing with (or even displaying) stacks. It would also fit the theme of the Pot: It can only hold so much at once, so you'd better spread the ingredients around. No need to unstack input, so there's no more concern about scaling. As before, this only addresses one angle, but... Anyway, I think it's an interesting problem and I hope I wasn't out of line for commenting. 👋 |
Quick comment about changing the Cooking Pot's slot depth to 1 item: It does solve the automation problem. Here is a before-and-after, auto-cooking Beetroot Soup using Applied Energistics 2 blocks... Automating the Cooking Pot with 64-deep slots (current functionality): cookingpot-deep-slots.mp4Automating the Cooking Pot with 1-deep slots: cookingpot-shallow-slots.mp4 |
Add "Lock Recipe" button. Just a small button with tooltip "Lock Recipe" or something like that. If recipe is locked:
Similar button has the Dissolution Chamber from Industrial Foregoing, but it only accepts one item at a time per slot. It will really help if you just export items into the Cooking Pot. For example with vanila hopper of any other method. It will also help to do autocrafts. If you request 2 stacks of some cooked food, with locked recipe Cooking Pot won't accept more than one stack of one ingridient. However it doesn't solve the issue if some recipe has two identical ingredients, like Tomato Sauce.
I can't believe that this issue is 2 years old and there is no good solution for this problem.
It's really panful to automate food production with this great mod right now. |
is there a reason why you don't just make a list of all the items inside of the cooking pot and match it with the json like
|
it's obviously not going to be that simple. but im just curious on why you can't do it like that |
hi, can you please tell that how you managed to edit the stack of the pot? thanks |
Description
As of now, the Cooking Pot only verifies each slot for the presence of a given ingredient, not its count. The six slots must match the given recipe by spreading ingredients across each other - that means that Beetroot Soup can only be made with one Beetroot in each slot, but not with 3 Beetroots stacked in a single slot.
This is both a design and automation problem, as nothing prevents datapack creators from allowing multiples of the same ingredient in a Cooking recipe. Say we want the pot to receive items from Hoppers - a hopper cannot round-robin the slots, and even if it could, it could end up clogging the inputs with six carrots before other types of ingredients, invalidating the recipe.
To do a deep check for ingredients, we run into a bigger logic puzzle that may result in ambiguity checks and performance issues. Simibubi raised some possibilities about the problem, though I'm unsure how practical the solution would be to implement.
Steps to reproduce
Attempt to prepare Beetroot Soup in the Cooking pot in the following ways:
The text was updated successfully, but these errors were encountered: