
No coded protection against minecraft:air being accidentally tried in recipe registry, caught and spammed in log during JEI scan
Kaleidio opened this issue ยท 0 comments
Versions
JEI AND MOD WITH AIR IN THEIR CREATIVE TAB REQUIRED
- Charm version - any
- Minecraft version - 1.16.5
Description
Some other mods (incorrectly) will provide a minecraft:air block under their creative tabs to "fill empty slots". This causes misbehaviours with any mods that dynamically make recipes.
Charm reforged is building recipes and JEI is finding this air block when attempting scans, causing log spam. The code that does dynamic registry should have an if statement that rejects any air blocks from being registered
What I am asking for is a simple hotfix that will reject air blocks from being stuck into the registry, preventing log spam
For similarity sake that should make the fix easy to understand, check out the code here from another mod that had a similar issue:
Geforce132/SecurityCraft@f083f57
Optional: Stacktrace/Screenshots
[10:48:23] [main/ERROR]: Found a broken recipe: Charm charm:woodcutters/quark/oak_ladder_from_oak_planks class svenhjol.charm.recipe.WoodcuttingRecipe
Outputs:
net.minecraft.item.ItemStack: [[4 air minecraft:air]]
Inputs:
net.minecraft.item.ItemStack: [[1 oak_planks minecraft:oak_planks]]
java.lang.IllegalArgumentException: ItemStack value must not be empty. 4 air minecraft:air
at mezz.jei.util.ErrorUtil.checkNotEmpty(ErrorUtil.java:206) ~[?:7.7.1.138]
at mezz.jei.plugins.vanilla.ingredients.item.ItemStackHelper.getUniqueId(ItemStackHelper.java:88) ~[?:7.7.1.138]
at mezz.jei.plugins.vanilla.ingredients.item.ItemStackHelper.getUniqueId(ItemStackHelper.java:28) ~[?:7.7.1.138]
at mezz.jei.recipes.RecipeMap.addRecipe(RecipeMap.java:94) ~[?:7.7.1.138]
at mezz.jei.recipes.RecipeMap.addRecipe(RecipeMap.java:75) ~[?:7.7.1.138]
at mezz.jei.recipes.RecipeManagerInternal.addRecipe(RecipeManagerInternal.java:125) [?:7.7.1.138]
at mezz.jei.recipes.RecipeManagerInternal.addRecipeTyped(RecipeManagerInternal.java:101) [?:7.7.1.138]
at mezz.jei.recipes.RecipeManagerInternal.addRecipes(RecipeManagerInternal.java:94) [?:7.7.1.138]
at mezz.jei.recipes.RecipeManagerInternal.(RecipeManagerInternal.java:86) [?:7.7.1.138]
at mezz.jei.load.PluginLoader.getRecipeManager(PluginLoader.java:144) [?:7.7.1.138]
at mezz.jei.startup.JeiStarter.start(JeiStarter.java:74) [?:7.7.1.138]
at mezz.jei.startup.ClientLifecycleHandler.startJEI(ClientLifecycleHandler.java:147) [?:7.7.1.138]
at mezz.jei.startup.ClientLifecycleHandler.setupJEI(ClientLifecycleHandler.java:140) [?:7.7.1.138]
at mezz.jei.startup.ClientLifecycleHandler.lambda$new$3(ClientLifecycleHandler.java:106) [?:7.7.1.138]
at mezz.jei.startup.ClientLifecycleHandler$$Lambda$23701/1161312438.accept(Unknown Source) [?:7.7.1.138]