InputItem serializes to only the item, ignores count despite supporting count
Opened this issue · 4 comments
Minecraft Version
1.20.1
KubeJS Version
2001.6.5-build.7
Rhino Version
2001.2.2-build.18
Architectury Version
9.2.14
Forge/Fabric Version
Forge 47.2.30
Describe your issue
I'm trying to set up recipeSchemaRegistry for a mod that supports stacked items in its machine's recipes. Particularly, Biomancy's Bio Forge.
According to what we know, the following KubeJS Startup code should work:
const $RecipeSchema = Java.loadClass(
"dev.latvian.mods.kubejs.recipe.schema.RecipeSchema"
);
const $RecipeComponentBuilder = Java.loadClass(
"dev.latvian.mods.kubejs.recipe.component.RecipeComponentBuilder"
);
StartupEvents.recipeSchemaRegistry((event) => {
const Components = event.components;
const result = Components.get("outputItem")().key("result");
const input = Components.get("inputItemArray")()
.key("ingredients");
event.register(
"biomancy:bio_forging",
new $RecipeSchema(
result,
input,
Components.get("intNumber")().key("nutrientsCost"),
Components.get("anyString")().key("bio_forge_tab")
)
);
});
// This didn't work, because for some reason it ignores the item count now.
The following recipe in Server Events was used to test:
let r = event.recipes.biomancy
.bio_forging(
"bleed4me:steroidal_explosion",
[
Item.of("minecraft:potion", { Potion: "minecraft:regeneration" }),
Ingredient.of("biomancy:exotic_dust", 6),
InputItem.of("biomancy:flesh", 10),
"10x biomancy:fibrous_flesh",
{ item: "minecraft:iron_block", count: 3 },
],
10,
"biomancy:misc"
)
.id("bleed4me:steroidal_explosion");
r.serialize();
console.log(r.json);
However, when InputItem is serialized, despite InputItem.of() accepting a count, it does not return the count, as evidenced by this part of KubeJS's code
Crash report/logs
No response
This happens because the InputItem RecipeComponent delegates to RecipeJS#writeInputItem and RecipeJS#readInputItem:
For writing, RecipeJS delegates to the Ingredient, which won't write the count because that is held in the InputItem. For reading it delegates to InputItem#of, which will actually read the count if it is there (I misread that in the Discord thread).
KubeJS/common/src/main/java/dev/latvian/mods/kubejs/recipe/RecipeJS.java
Lines 611 to 618 in fc38ad0
This is intentional, as (up to 1.20.4), there is no unified standard for serialising ingredient stacks and some recipes actively broke if there was an invalid field present in the ingredient. You would need to override writeInputItem to respect the count (probably serialising it as "amount" or "count"?) in your schema using a custom recipe class
Rip writing schemas from scripts.
You would need to override writeInputItem to respect the count (probably serialising it as "amount" or "count"?) in your schema using a custom recipe class
Can confirm that the recipes I'm looking for use "count", so how would one go about doing this?