2020-07-17 18:05:50 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2020-06-27 20:02:39 +02:00
|
|
|
From: tr7zw <tr7zw@live.de>
|
|
|
|
Date: Thu, 25 Jun 2020 23:40:12 +0200
|
|
|
|
Subject: [PATCH] Heavily optimize furnance fuel and recipe lookups
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/CraftingManager.java b/src/main/java/net/minecraft/server/CraftingManager.java
|
2020-08-03 18:48:42 +02:00
|
|
|
index c2af174e639396ac70eb7b520fdd641b1d2c67e6..7de6e116a7e301754c637b68be39c30f610a04d7 100644
|
2020-06-27 20:02:39 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/CraftingManager.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/CraftingManager.java
|
2020-08-03 18:48:42 +02:00
|
|
|
@@ -83,7 +83,24 @@ public class CraftingManager extends ResourceDataJson {
|
2020-06-27 20:02:39 +02:00
|
|
|
}).findFirst();
|
|
|
|
c0.setCurrentRecipe(recipe.orElse(null)); // CraftBukkit - Clear recipe when no recipe is found
|
|
|
|
// CraftBukkit end
|
|
|
|
- return recipe;
|
2020-08-03 18:48:42 +02:00
|
|
|
+ // Yatopia start
|
|
|
|
+ if(c0.getCurrentRecipe() != null) {
|
|
|
|
+ Optional<T> optional = recipes.a(c0.getCurrentRecipe(), world, c0);
|
|
|
|
+ if(optional.isPresent()) {
|
2020-06-27 20:02:39 +02:00
|
|
|
+ c0.setCurrentRecipe(optional.get());
|
2020-08-03 18:48:42 +02:00
|
|
|
+ return optional;
|
|
|
|
+ }
|
|
|
|
+ }
|
2020-06-27 20:02:39 +02:00
|
|
|
+ for(IRecipe<C> rep : this.a(recipes)) {
|
2020-08-03 18:48:42 +02:00
|
|
|
+ Optional<T> optional = recipes.a(rep, world, c0);
|
|
|
|
+ if(optional.isPresent()) {
|
2020-06-27 20:02:39 +02:00
|
|
|
+ c0.setCurrentRecipe(optional.get());
|
2020-08-03 18:48:42 +02:00
|
|
|
+ return optional;
|
|
|
|
+ }
|
2020-06-27 20:02:39 +02:00
|
|
|
+ }
|
|
|
|
+ c0.setCurrentRecipe(null); // CraftBukkit - Clear recipe when no recipe is found
|
|
|
|
+ return Optional.empty();
|
2020-08-03 18:48:42 +02:00
|
|
|
+ // Yatopia end
|
2020-06-27 20:02:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public <C extends IInventory, T extends IRecipe<C>> List<T> a(Recipes<T> recipes) {
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityFurnace.java b/src/main/java/net/minecraft/server/TileEntityFurnace.java
|
2020-08-03 18:48:42 +02:00
|
|
|
index acc533ca8ad612cc439208f4adf6e3d3289c92c7..eded99b59beb7d6fe759b21fa7d3082057c741d4 100644
|
2020-06-27 20:02:39 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/TileEntityFurnace.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityFurnace.java
|
|
|
|
@@ -99,7 +99,13 @@ public abstract class TileEntityFurnace extends TileEntityContainer implements I
|
|
|
|
this.c = recipes;
|
|
|
|
}
|
|
|
|
|
2020-08-03 18:48:42 +02:00
|
|
|
+ //Yatopia
|
2020-06-27 20:02:39 +02:00
|
|
|
+ private static Map<Item, Integer> cachedFuelMap = null;
|
2020-08-03 18:48:42 +02:00
|
|
|
+
|
2020-06-27 20:02:39 +02:00
|
|
|
public static Map<Item, Integer> f() {
|
2020-08-03 18:48:42 +02:00
|
|
|
+ if(cachedFuelMap != null) {
|
|
|
|
+ return cachedFuelMap; // Yatopia
|
|
|
|
+ }
|
2020-06-27 20:02:39 +02:00
|
|
|
Map<Item, Integer> map = Maps.newLinkedHashMap();
|
|
|
|
|
|
|
|
a(map, (IMaterial) Items.LAVA_BUCKET, 20000);
|
|
|
|
@@ -162,6 +168,7 @@ public abstract class TileEntityFurnace extends TileEntityContainer implements I
|
|
|
|
a(map, (IMaterial) Blocks.FLETCHING_TABLE, 300);
|
|
|
|
a(map, (IMaterial) Blocks.SMITHING_TABLE, 300);
|
|
|
|
a(map, (IMaterial) Blocks.COMPOSTER, 300);
|
2020-08-03 18:48:42 +02:00
|
|
|
+ cachedFuelMap = map; // Yatopia
|
2020-06-27 20:02:39 +02:00
|
|
|
return map;
|
|
|
|
}
|
|
|
|
|
2020-08-03 18:48:42 +02:00
|
|
|
@@ -615,4 +622,19 @@ public abstract class TileEntityFurnace extends TileEntityContainer implements I
|
2020-06-27 20:02:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-08-03 18:48:42 +02:00
|
|
|
+
|
|
|
|
+ // Yatopia start
|
2020-06-27 20:02:39 +02:00
|
|
|
+ private IRecipe cachedRecipe = null;
|
|
|
|
+ @Override
|
|
|
|
+ public IRecipe getCurrentRecipe() {
|
|
|
|
+ return cachedRecipe;
|
|
|
|
+ }
|
|
|
|
+ @Override
|
|
|
|
+ public void setCurrentRecipe(IRecipe recipe) {
|
2020-08-03 18:48:42 +02:00
|
|
|
+ cachedRecipe = recipe;
|
2020-06-27 20:02:39 +02:00
|
|
|
+ }
|
|
|
|
+
|
2020-08-03 18:48:42 +02:00
|
|
|
+
|
|
|
|
+ // Yatopia end
|
|
|
|
+
|
2020-06-27 20:02:39 +02:00
|
|
|
}
|