2020-05-06 17:48:49 +08:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2019-05-06 01:19:34 +08:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Fri, 18 Jan 2019 00:08:15 -0500
|
|
|
|
Subject: [PATCH] Fix Custom Shapeless Custom Crafting Recipes
|
|
|
|
|
|
|
|
Mojang implemented Shapeless different than Shaped
|
|
|
|
|
|
|
|
This made the Bukkit RecipeChoice API not work for Shapeless.
|
|
|
|
|
|
|
|
This reimplements vanilla logic using the same test logic as Shaped
|
|
|
|
|
2021-03-16 15:19:45 +08:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/item/crafting/ShapelessRecipes.java b/src/main/java/net/minecraft/world/item/crafting/ShapelessRecipes.java
|
|
|
|
index 9226602691ccbf39835f2dd071f171c2375b0a16..e112d149fc3a7af7f0c9a5280c94c9b03b2aba2d 100644
|
|
|
|
--- a/src/main/java/net/minecraft/world/item/crafting/ShapelessRecipes.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/item/crafting/ShapelessRecipes.java
|
|
|
|
@@ -72,16 +72,49 @@ public class ShapelessRecipes implements RecipeCrafting {
|
2019-05-06 01:19:34 +08:00
|
|
|
AutoRecipeStackManager autorecipestackmanager = new AutoRecipeStackManager();
|
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ java.util.List<ItemStack> providedItems = new java.util.ArrayList<>();
|
|
|
|
+ co.aikar.util.Counter<ItemStack> matchedProvided = new co.aikar.util.Counter<>();
|
|
|
|
+ co.aikar.util.Counter<RecipeItemStack> matchedIngredients = new co.aikar.util.Counter<>();
|
|
|
|
+ // Paper end
|
|
|
|
for (int j = 0; j < inventorycrafting.getSize(); ++j) {
|
|
|
|
ItemStack itemstack = inventorycrafting.getItem(j);
|
|
|
|
|
|
|
|
if (!itemstack.isEmpty()) {
|
|
|
|
- ++i;
|
|
|
|
- autorecipestackmanager.a(itemstack, 1);
|
|
|
|
+ // Paper start
|
|
|
|
+ itemstack = itemstack.cloneItemStack();
|
|
|
|
+ providedItems.add(itemstack);
|
|
|
|
+ for (RecipeItemStack ingredient : ingredients) {
|
|
|
|
+ if (ingredient.test(itemstack)) {
|
|
|
|
+ matchedProvided.increment(itemstack);
|
|
|
|
+ matchedIngredients.increment(ingredient);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
- return i == this.ingredients.size() && autorecipestackmanager.a(this, (IntList) null);
|
|
|
|
+ // Paper start
|
2020-10-27 23:04:32 +08:00
|
|
|
+ if (matchedProvided.isEmpty() || matchedIngredients.isEmpty()) {
|
|
|
|
+ return false;
|
|
|
|
+ }
|
2019-05-06 01:19:34 +08:00
|
|
|
+ java.util.List<RecipeItemStack> ingredients = new java.util.ArrayList<>(this.ingredients);
|
|
|
|
+ providedItems.sort(java.util.Comparator.comparingInt((ItemStack c) -> (int) matchedProvided.getCount(c)).reversed());
|
|
|
|
+ ingredients.sort(java.util.Comparator.comparingInt((RecipeItemStack c) -> (int) matchedIngredients.getCount(c)));
|
|
|
|
+
|
|
|
|
+ PROVIDED:
|
|
|
|
+ for (ItemStack provided : providedItems) {
|
|
|
|
+ for (Iterator<RecipeItemStack> itIngredient = ingredients.iterator(); itIngredient.hasNext(); ) {
|
|
|
|
+ RecipeItemStack ingredient = itIngredient.next();
|
|
|
|
+ if (ingredient.test(provided)) {
|
|
|
|
+ itIngredient.remove();
|
|
|
|
+ continue PROVIDED;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ return ingredients.isEmpty();
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
|
|
|
|
public ItemStack a(InventoryCrafting inventorycrafting) {
|