Skip to content
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

[issue] bad handling of fluid in tree recipe crafting mode #649

Closed
jonatjano opened this issue Aug 3, 2024 · 8 comments
Closed

[issue] bad handling of fluid in tree recipe crafting mode #649

jonatjano opened this issue Aug 3, 2024 · 8 comments

Comments

@jonatjano
Copy link

issue

When using EMI tree recipe crafting mode with fluid and looking into a machine with the requested fluid, it is not detected and EMI says that I can't craft any batch of the item

In the below screenshot using Modern Industrialisation to illustrate the issue, the recipe asks for 1mb of lubricant and the machine currently holds 3909mb of lubricant

image

expected behavior

I expect that the liquid in the machine is detected and that EMI tells me I can use it to craft the recipe

version

Neoforge : 21.0.148
EMI : 1.1.10+1.21+neoforge
Modern Industrialization : 2.2.16-beta

additional information

I also opened an issue on Modern Industrialization's github, thinking their side had to allow EMI to read that slot and they told me the issue is EMI lacking an handling of fluid

@emilyploszaj
Copy link
Owner

MI is not exposing their input slots as part of their inventory, as is necessary for EMI to assume you have lubricant and assume this is craftable.

@Technici4n
Copy link

@emilyploszaj how am I supposed to expose fluid slots?

@jonatjano
Copy link
Author

@emilyploszaj sorry to bother, but I'll allow myself to send you a ping so you know Technici4n is waiting for an answer

@emilyploszaj
Copy link
Owner

You need to override getInventory to expose your inputs inside the inventory. You can use a similar approach of collecting your slots and getting their contents and additionally add all fluid contents. @Technici4n

@Technici4n
Copy link

That does not actually work for #craft. EmiRecipeFiller#getStacks will try to find fluid ingredients in the input sources, and of course that will fail. Interestingly, #canCraft does however succeed. 😓

This is what I tried: AztechMC/Modern-Industrialization@10a356a.

@emilyploszaj
Copy link
Owner

Well, yeah, any complex (non-standard) recipe filling will require manual work, MI is going to need to handle moving items for crafts. I assumed you already had this since you handle + filling yourself.

@Technici4n
Copy link

Could EMI maybe move items only and ignore fluids? I'd prefer not to reimplement the whole thing myself 😅

@emilyploszaj
Copy link
Owner

It's very hard for EMI to know how to handle non-standard ingredients and what is desirable to a developer. I'll think about it but I really feel like non-standard use cases should be handled explicitly

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants