-
Notifications
You must be signed in to change notification settings - Fork 86
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
I/O Pipe inserting into the same inventory it pulled from causes unexpected behavior for inventories with multiple item types #685
Comments
This is actually "working as intended" - in some cases it is useful to move items within the same block, e.g. a machine output that gets moved back into an input slot for a different recipe. It is annoying in some cases and useful in other cases. |
What's funny is that before I thought of this as unintended behavior, I had already used it as you described - to pull output from a Macerator and insert it right back into the same Macerator with just a single pipe in I/O mode. The main thing to me is that intuitively it seems like inconsistent behavior, especially based on the tooltip for Extraction Priority. If the tooltip was accurate (only into higher priorities) then an I/O pipe could never insert into itself. I haven't looked at the code, but is it the case that it's actually "same or higher priorities"? In which case, a change in wording of the tooltip would probably be sufficient in clearing that up. |
What I tried to say with |
Minecraft 1.20.1
Fabric 0.14.25
MI: 1.8.3
Long story short, I realized the exact issue as I was writing this. The problem is that an I/O pipe will pull up to 16 items out of the inventory it's attached to and then reinsert those 16 items back into the source inventory if they don't have another destination. In the case where you have two different types of item stack in your source inventory and 16 or more of the first item stack then it will never pull the second type of item in the source inventory. It gets into a loop of pulling 16 of the first, only having the source inventory as a destination, putting them back into the source inventory, and repeating.
This is a problem when:
In this very specific situation, the I/O pipe constantly pulls 16 of the first item type and reinserts it into the source inventory and never reaches the second item type. This is unexpected because according to the tooltip for Extraction Priority (Lower priorities first, only into higher priorities), an I/O pipe shouldn't even be able to insert back into itself. The problem would be fixed either by preventing I/O pipes from inserting into themselves or by adding special behavior to the I/O pipe that will skip all operations that would extract X items from an inventory and reinsert X items back into the same inventory.
Feel free to read the rest of this, it's the original issue I was going to post that led me to the realization above.
Possibly related to #268
Ran into a quirk in behavior in pipes configured I/O vs OUT. I created a simplified setup to explain the situation. Pictures below text for clarifcation.
Left barrel is my source
Right barrel is the destination
I/O pipe connected to left chest
IN pipe connected to right chest
Expected behavior: Pipe network fills up both the single stack for bronze plates and the single stack for bricks in the right chest.
Actual Behavior: Pipe network only fills up the corresponding slot in the right chest with whatever item happens to be first in the left barrel. As pictured, it filled up the bronze plates because those were first in the left barrel. If I instead swapped those so that the bricks were first in the left barrel, it would have filled up the bricks on the right barrel and not the plates.
Two more interesting quirks I observed while writing this issue:
An inventory with a single I/O pipe connected to it will pull a set of items from the inventory and then reinsert them, but it will only do it if the first occupied slot of the inventory has a full stack of items.
The 2 images below are stable - nothing is transferring from the first (left) barrel to the second (right) barrel. (You can also observe the behavior described in the previous two pictures - I inserted a stack of 64 bronze plates and the I/O pipe pulled out 16 and reinserted them into the barrel in the second slot). But specifically the other quirk is that reducing the quantity of bronze plates to below 16 lets the I/O pipe take some of the bricks. If I reduce the quantity of bronze plates to 15, for example, then the I/O pipe will take 15 plates out and 1 brick out in a single operation - inserting the 15 plates back into the barrel from which they came, and inserting the 1 brick into the second barrel.
The text was updated successfully, but these errors were encountered: