diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/RecipeIterator.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/RecipeIterator.java index 33fd782642..1223bfc7f5 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/RecipeIterator.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/RecipeIterator.java @@ -1,29 +1,42 @@ package org.bukkit.craftbukkit.inventory; +import it.unimi.dsi.fastutil.objects.Object2ObjectLinkedOpenHashMap; import java.util.Iterator; +import java.util.Map; import net.minecraft.server.IRecipe; +import net.minecraft.server.MinecraftKey; import net.minecraft.server.MinecraftServer; +import net.minecraft.server.Recipes; import org.bukkit.inventory.Recipe; public class RecipeIterator implements Iterator { - private final Iterator> recipes; + private final Iterator, Object2ObjectLinkedOpenHashMap>>> recipes; + private Iterator> current; public RecipeIterator() { - this.recipes = MinecraftServer.getServer().getCraftingManager().b().iterator(); + this.recipes = MinecraftServer.getServer().getCraftingManager().recipes.entrySet().iterator(); } @Override public boolean hasNext() { - return recipes.hasNext(); + return (current != null && current.hasNext()) || recipes.hasNext(); } @Override public Recipe next() { - return recipes.next().toBukkitRecipe(); + if (current == null || !current.hasNext()) { + current = recipes.next().getValue().values().iterator(); + } + + return current.next().toBukkitRecipe(); } @Override public void remove() { - recipes.remove(); + if (current == null) { + throw new IllegalStateException("next() not yet called"); + } + + current.remove(); } }