Jump to content

Recommended Posts

Posted (edited)

I've had a bug report raised to me where my crafting recipes using enchanted books were not matching anymore.

The issue came down to me testing with cheated in or enchantment table books and the user creating them with the anvil.

 

The anvil added an extra nbt tag "RepairCost" that caused the book to no longer match in the recipe.

 

So I'm guessing that the ingredient type "minecraft:item_nbt" has to match exactly and have no other nbt tags present.

 

Does anyone have any pointers as to how to handle this situation of extra, unwanted nbt tags being present on the item that item_nbt matches against?

I've looked at IIngredientFactory but I'm not sure that is going to help me.

 

Thanks

Ipsis

 

This is what I'm using to match against.

    {
      "type": "minecraft:item_nbt",
      "item": "minecraft:enchanted_book",
      "nbt": "{ StoredEnchantments: [ { id: 21s, lvl: 1s } ] }"
    }

 

The user showed a screenshot with the nbt as

{RepairCost:1,StoredEnchantments:[{lvl:2s,id:48s}]}

 

Edited by Ipsissimus418
Posted (edited)

I'm not entirely sure but you might be able to qualify the NBT by treating the ingredient at a conditional ingredient. If you want conditional ingredients, you'll need to create an IIngredientFactory and specify it in _factories.json. In the IIngredientFactory, you can use CraftingHelper.processConditions to check if the conditions are met. If they are, return an Ingredient instance for the specified item; if they aren't, return Ingredient.EMPTY (an Ingredient that never matches any ItemStack). You can see an example implementation by Choonster here.

 

Alternatively, maybe you need to make a custom IRecipe.

Edited by jabelar

Check out my tutorials here: http://jabelarminecraft.blogspot.com/

Posted

Please don't color your posts. I can't read that shit.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Posted
21 minutes ago, jabelar said:

I didn't do that on purpose. I cut and pasted from a different forum. 

Then click the convenient "remove formatting" button that shows up when you paste stuff.

Or the one in the tool bar.

Cyan on white is impossible to read.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Posted (edited)
1 minute ago, Draco18s said:

Then click the convenient "remove formatting" button that shows up when you paste stuff.

Or the one in the tool bar.

Cyan on white is impossible to read.

I didn't know it was cyan because I use black and white on my monitor for eye health reasons. But yeah, I can try to remember to remove formatting/color.

Edited by jabelar

Check out my tutorials here: http://jabelarminecraft.blogspot.com/

Posted (edited)

You'll need to create a copy of IngredientNBT and override Ingredient#apply to perform a partial NBT match instead of a full NBT match.

 

You'll then need to create an implementation of IIngredientFactory that creates an instance of the Ingredient class from the provided JSON object; you can use CraftingHelper.getItemStack to parse an ItemStack from JSON.

 

Register this factory by adding the fully-qualified name to your _factories.json file; you can see an example here.

 

The name you specify for the factory in _factories.json is the name you'll use in the type property of the ingredients in your recipe files.

 

Edit: You might want to use an NBTPredicate for the NBT matching rather than storing a full ItemStack.

 

 

2 hours ago, jabelar said:

I'm not entirely sure but you might be able to qualify the NBT by treating the ingredient at a conditional ingredient. If you want conditional ingredients, you'll need to create an IIngredientFactory and specify it in _factories.json. In the IIngredientFactory, you can use CraftingHelper.processConditions to check if the conditions are met. If they are, return an Ingredient instance for the specified item; if they aren't, return Ingredient.EMPTY (an Ingredient that never matches any ItemStack). You can see an example implementation by Choonster here.

 

Alternatively, maybe you need to make a custom IRecipe.

 

This isn't really what the OP is looking for, since the conditions are only evaluated once when the recipe is loaded.

Edited by Choonster
  • Like 1

Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.

Posted (edited)

So I gave Choonster's pointers a go and I think I have something working.

 

I added a new factory with my new type that allowed me to specify an enchant id and enchant level.

The factory then parsed those json entries and applies them as the enchantment to the itemstack so it shows up in the recipe tooltips.

The factory then created a new IngredientEnchantedBook object with the itemstack, enchantment id and enchantment level.

The IngredientEnchantedBook apply method then uses EnchantmentHelper to pull the enchantments off the input stack and looks for the stored enchantment id and level in that map.

The recipes were then updated to do the following:

 

{
"type": "woot:enchanted_book",
"item": "minecraft:enchanted_book",
"enchant_id", 16,
"enchant_lvl": 1
}

 

This moves away from matching the NBT tags for now, but does mean that as long as a valid enchantment is present it will match.

I am a little concerned with this method processing all the enchantments on the itemstack to do this match, as it seems a lot of processing compared to a quicker(?) partial-nbt match.

 

Below is a link to the commit with the factory and EnchantmentHelper version for future reference.

Github commit

 

I'll investigate the NBTPredicate method next.

 

Edited by Ipsissimus418
Posted

Enchantments are managed by a Forge registry, so the numeric IDs are automatically assigned per-save and shouldn't be used. Use the registry name in the JSON instead and store the Enchantment instance in the Ingredient for matching.

  • Like 1

Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.

Posted

I'm going to stick with the enchantment name solution, rather than trying a NBTPredicate solution.

I'll mark this as solved and update the title to something more appropriate. Mainly so nobody thinks that the solution shows partial NBT matching.

  • 1 year later...
Posted
17 hours ago, Juice_lmao said:

So can I get a straight answer because I have no idea whts going on. Can someone maybe explain this a bit better or something?

Don't necro posts. Make your own.

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • When I first heard about Bitcoin back in 2018, I was skeptical. The idea of a decentralized, digital currency seemed too good to be true. But I was intrigued as I learned more about the technology behind it and its potential. I started small, investing just a few hundred dollars, dipping my toes into the cryptocurrency waters. At first, it was exhilarating to watch the value of my investment grow exponentially. I felt like I was part of the future, an early adopter of this revolutionary new asset. But that euphoria was short-lived. One day, I logged into my digital wallet only to find it empty - my Bitcoin had vanished without a trace. It turned out that the online exchange I had trusted had been hacked, and my funds were stolen. I was devastated, both financially and emotionally. All the potential I had seen in Bitcoin was tainted by the harsh reality that with decentralization came a lack of regulation and oversight. My hard-earned money was gone, lost to the ether of the digital world. This experience taught me a painful lesson about the price of trust in the uncharted territory of cryptocurrency. While the technology holds incredible promise, the risks can be catastrophic if you don't approach it with extreme caution. My Bitcoin investment gamble had failed, and I was left to pick up the pieces, wiser but poorer for having placed my faith in the wrong hands. My sincere appreciation goes to MUYERN TRUST HACKER. You are my hero in recovering my lost funds. Send a direct m a i l ( muyerntrusted ( @ ) mail-me ( . )c o m ) or message on whats app : + 1 ( 4-4-0 ) ( 3 -3 -5 ) ( 0-2-0-5 )
    • You could try posting a log (if there is no log at all, it may be the launcher you are using, the FAQ may have info on how to enable the log) as described in the FAQ, however this will probably need to be reported to/remedied by the mod author.
    • So me and a couple of friends are playing with a shitpost mod pack and one of the mods in the pack is corail tombstone and for some reason there is a problem with it, where on death to fire the player will get kicked out of the server and the tombstone will not spawn basically deleting an entire inventory, it doesn't matter what type of fire it is, whether it's from vanilla fire/lava, or from modded fire like ice&fire/lycanites and it's common enough to where everyone on the server has experienced at least once or twice and it doesn't give any crash log. a solution to this would be much appreciated thank you!
    • It is 1.12.2 - I have no idea if there is a 1.12 pack
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.