2015-05-25 20:37:24 +10:00
--- a/net/minecraft/server/CraftingManager.java
+++ b/net/minecraft/server/CraftingManager.java
2015-07-30 16:56:52 +10:00
@@ -9,10 +9,16 @@
2014-11-26 08:32:16 +11:00
import java.util.Iterator;
import java.util.List;
+import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit
+
public class CraftingManager {
private static final CraftingManager a = new CraftingManager();
2015-06-06 19:33:48 +10:00
public List<IRecipe> recipes = Lists.newArrayList();
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start
+ public IRecipe lastRecipe;
+ public org.bukkit.inventory.InventoryView lastCraftView;
+ // CraftBukkit end
public static CraftingManager getInstance() {
return CraftingManager.a;
2016-03-01 08:32:46 +11:00
@@ -176,7 +182,12 @@
2014-11-26 08:32:16 +11:00
this.registerShapedRecipe(new ItemStack(Blocks.HOPPER), new Object[] { "I I", "ICI", " I ", Character.valueOf('I'), Items.IRON_INGOT, Character.valueOf('C'), Blocks.CHEST});
2015-02-26 22:41:06 +00:00
this.registerShapedRecipe(new ItemStack(Items.ARMOR_STAND, 1), new Object[] { "///", " / ", "/_/", Character.valueOf('/'), Items.STICK, Character.valueOf('_'), new ItemStack(Blocks.STONE_SLAB, 1, BlockDoubleStepAbstract.EnumStoneSlabVariant.STONE.a())});
2016-03-01 08:32:46 +11:00
this.registerShapedRecipe(new ItemStack(Blocks.END_ROD, 4), new Object[] { "/", "#", Character.valueOf('/'), Items.BLAZE_ROD, Character.valueOf('#'), Items.CHORUS_FRUIT_POPPED});
2015-02-26 22:41:06 +00:00
- Collections.sort(this.recipes, new Comparator() {
2014-11-26 08:32:16 +11:00
+ sort();
+ }
2015-02-26 22:41:06 +00:00
+
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start
+ public void sort() {
2015-02-26 22:41:06 +00:00
+ Collections.sort(this.recipes, new Comparator() {
public int a(IRecipe irecipe, IRecipe irecipe1) {
return irecipe instanceof ShapelessRecipes && irecipe1 instanceof ShapedRecipes ? 1 : (irecipe1 instanceof ShapelessRecipes && irecipe instanceof ShapedRecipes ? -1 : (irecipe1.a() < irecipe.a() ? -1 : (irecipe1.a() > irecipe.a() ? 1 : 0)));
}
2016-03-01 08:32:46 +11:00
@@ -283,13 +294,18 @@
2014-11-26 08:32:16 +11:00
do {
if (!iterator.hasNext()) {
+ inventorycrafting.currentRecipe = null; // CraftBukkit - Clear recipe when no recipe is found
return null;
}
irecipe = (IRecipe) iterator.next();
2015-02-26 22:41:06 +00:00
} while (!irecipe.a(inventorycrafting, world));
2015-07-30 16:56:52 +10:00
- return irecipe.craftItem(inventorycrafting);
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - INVENTORY_PRE_CRAFT event
+ inventorycrafting.currentRecipe = irecipe;
2015-07-30 16:56:52 +10:00
+ ItemStack result = irecipe.craftItem(inventorycrafting);
2014-11-26 08:32:16 +11:00
+ return CraftEventFactory.callPreCraftEvent(inventorycrafting, result, lastCraftView, false);
+ // CraftBukkit end
}
public ItemStack[] b(InventoryCrafting inventorycrafting, World world) {