From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: tr7zw Date: Thu, 25 Jun 2020 23:40:12 +0200 Subject: [PATCH] Heavily optimize furnance fuel and recipe lookups Co-authored-by: Mykyta Komarn diff --git a/src/main/java/net/minecraft/world/level/block/entity/TileEntityFurnace.java b/src/main/java/net/minecraft/world/level/block/entity/TileEntityFurnace.java index 9ce19b89c16eb6edd3d5d5cc87a966a37f66895c..20193ba36c62fdd40ae905d1cea4bfd6d6aebcd7 100644 --- a/src/main/java/net/minecraft/world/level/block/entity/TileEntityFurnace.java +++ b/src/main/java/net/minecraft/world/level/block/entity/TileEntityFurnace.java @@ -313,7 +313,10 @@ public abstract class TileEntityFurnace extends TileEntityContainer implements I this.cookTime = MathHelper.clamp(this.cookTime - 2, 0, this.cookTimeTotal); } } else { - IRecipe irecipe = this.world.getCraftingManager().craft((Recipes) this.c, this, this.world).orElse(null); // Eclipse fail + // Yatopia start - used cached recipe if possible, otherwise look up + IRecipe irecipe = getCurrentRecipe(); + if (irecipe == null) irecipe = this.world.getCraftingManager().craft((Recipes) this.c, this, this.world).orElse(null); // Eclipse fail + // Yatopia end if (!this.isBurning() && this.canBurn(irecipe)) { // CraftBukkit start @@ -643,4 +646,18 @@ public abstract class TileEntityFurnace extends TileEntityContainer implements I } } + + // Yatopia start - cache recipe + private IRecipe cachedRecipe = null; + + @Override + public IRecipe getCurrentRecipe() { + return cachedRecipe; + } + + @Override + public void setCurrentRecipe(IRecipe recipe) { + cachedRecipe = recipe; + } + // Yatopia end }