From 326091c130657294157d137895663ad2924c0b95 Mon Sep 17 00:00:00 2001 From: Celtic Minstrel Date: Sat, 23 Jul 2011 23:16:14 -0400 Subject: [Bleeding] Recipe API improvements and fixes. Addresses BUKKIT-738 and BUKKIT-624 Add a recipe iterator to make it possible to retrieve and remove recipes (BUKKIT-738), and updated the recipe classes to not clip the data to 127 (BUKKIT-624) --- .../java/net/minecraft/server/ShapedRecipes.java | 62 ++++++++++++++++++++++ 1 file changed, 62 insertions(+) (limited to 'src/main/java/net/minecraft/server/ShapedRecipes.java') diff --git a/src/main/java/net/minecraft/server/ShapedRecipes.java b/src/main/java/net/minecraft/server/ShapedRecipes.java index 6fde0c73..eccfd47e 100644 --- a/src/main/java/net/minecraft/server/ShapedRecipes.java +++ b/src/main/java/net/minecraft/server/ShapedRecipes.java @@ -1,5 +1,11 @@ package net.minecraft.server; +// CraftBukkit start +import org.bukkit.craftbukkit.inventory.CraftItemStack; +import org.bukkit.craftbukkit.inventory.CraftShapedRecipe; +import org.bukkit.inventory.ShapedRecipe; +// CraftBukkit end + public class ShapedRecipes implements CraftingRecipe { private int b; @@ -16,6 +22,62 @@ public class ShapedRecipes implements CraftingRecipe { this.e = itemstack; } + // CraftBukkit start + public ShapedRecipe toBukkitRecipe() { + CraftItemStack result = new CraftItemStack(this.e); + CraftShapedRecipe recipe = new CraftShapedRecipe(result, this); + switch (this.b) { + case 1: + switch (this.c) { + case 1: + recipe.shape("a"); + break; + case 2: + recipe.shape("ab"); + break; + case 3: + recipe.shape("abc"); + break; + } + break; + case 2: + switch (this.c) { + case 1: + recipe.shape("a","b"); + break; + case 2: + recipe.shape("ab","cd"); + break; + case 3: + recipe.shape("abc","def"); + break; + } + break; + case 3: + switch (this.c) { + case 1: + recipe.shape("a","b","c"); + break; + case 2: + recipe.shape("ab","cd","ef"); + break; + case 3: + recipe.shape("abc","def","ghi"); + break; + } + break; + } + char c = 'a'; + for (ItemStack stack : this.d) { + if (stack != null) { + recipe.setIngredient(c, org.bukkit.Material.getMaterial(stack.id), stack.getData()); + } + c++; + } + return recipe; + } + // CraftBukkit end + public ItemStack b() { return this.e; } -- cgit v1.2.3