Charm Reforged

Charm Reforged

8M Downloads

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

commented

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]