|
| 1 | +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 |
| 2 | +From: Jake Potrebic <jake.m.potrebic@gmail.com> |
| 3 | +Date: Sun, 20 Mar 2022 22:06:47 -0700 |
| 4 | +Subject: [PATCH] cache resource keys |
| 5 | + |
| 6 | + |
| 7 | +diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java |
| 8 | +index a52e76c8870b1dd578c4332930c6f2fd3b31d471..ca9904ded51580425f06587b7eed72da7b95d2f1 100644 |
| 9 | +--- a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java |
| 10 | ++++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java |
| 11 | +@@ -366,12 +366,13 @@ public class CraftBlock implements Block { |
| 12 | + return (biome == null) ? Biome.CUSTOM : biome; |
| 13 | + } |
| 14 | + |
| 15 | ++ private static final java.util.Map<org.bukkit.block.Biome, net.minecraft.resources.ResourceKey<net.minecraft.world.level.biome.Biome>> BIOME_KEY_CACHE = Collections.synchronizedMap(new java.util.EnumMap<>(Biome.class)); // Paper |
| 16 | + public static Holder<net.minecraft.world.level.biome.Biome> biomeToBiomeBase(net.minecraft.core.Registry<net.minecraft.world.level.biome.Biome> registry, Biome bio) { |
| 17 | + if (bio == null || bio == Biome.CUSTOM) { |
| 18 | + return null; |
| 19 | + } |
| 20 | + |
| 21 | +- return registry.getHolderOrThrow(ResourceKey.create(net.minecraft.core.Registry.BIOME_REGISTRY, CraftNamespacedKey.toMinecraft(bio.getKey()))); |
| 22 | ++ return registry.getHolderOrThrow(BIOME_KEY_CACHE.computeIfAbsent(bio, b -> ResourceKey.create(net.minecraft.core.Registry.BIOME_REGISTRY, CraftNamespacedKey.toMinecraft(b.getKey())))); // Paper - cache key |
| 23 | + } |
| 24 | + |
| 25 | + @Override |
| 26 | +diff --git a/src/main/java/org/bukkit/craftbukkit/tag/CraftEntityTag.java b/src/main/java/org/bukkit/craftbukkit/tag/CraftEntityTag.java |
| 27 | +index 393bb27648501c6f25cf846e929f4c95b1a0b11f..979f82d589e378b9e52417d20b48d66f077f5dfd 100644 |
| 28 | +--- a/src/main/java/org/bukkit/craftbukkit/tag/CraftEntityTag.java |
| 29 | ++++ b/src/main/java/org/bukkit/craftbukkit/tag/CraftEntityTag.java |
| 30 | +@@ -16,9 +16,10 @@ public class CraftEntityTag extends CraftTag<net.minecraft.world.entity.EntityTy |
| 31 | + super(registry, tag); |
| 32 | + } |
| 33 | + |
| 34 | ++ private static final java.util.Map<org.bukkit.entity.EntityType, net.minecraft.resources.ResourceKey<net.minecraft.world.entity.EntityType<?>>> KEY_CACHE = Collections.synchronizedMap(new java.util.EnumMap<>(EntityType.class)); // Paper |
| 35 | + @Override |
| 36 | + public boolean isTagged(EntityType entity) { |
| 37 | +- return registry.getHolderOrThrow(ResourceKey.create(net.minecraft.core.Registry.ENTITY_TYPE_REGISTRY, CraftNamespacedKey.toMinecraft(entity.getKey()))).is(tag); |
| 38 | ++ return registry.getHolderOrThrow(KEY_CACHE.computeIfAbsent(entity, type -> ResourceKey.create(net.minecraft.core.Registry.ENTITY_TYPE_REGISTRY, CraftNamespacedKey.toMinecraft(type.getKey())))).is(tag); // Paper - cache key |
| 39 | + } |
| 40 | + |
| 41 | + @Override |
| 42 | +diff --git a/src/main/java/org/bukkit/craftbukkit/tag/CraftFluidTag.java b/src/main/java/org/bukkit/craftbukkit/tag/CraftFluidTag.java |
| 43 | +index cdd474e9b0363641839a66d3e61fec46c735879a..3611e3e9d33a0f1d82a78a27ea5c2c649225f564 100644 |
| 44 | +--- a/src/main/java/org/bukkit/craftbukkit/tag/CraftFluidTag.java |
| 45 | ++++ b/src/main/java/org/bukkit/craftbukkit/tag/CraftFluidTag.java |
| 46 | +@@ -14,9 +14,10 @@ public class CraftFluidTag extends CraftTag<net.minecraft.world.level.material.F |
| 47 | + super(registry, tag); |
| 48 | + } |
| 49 | + |
| 50 | ++ private static final java.util.Map<Fluid, net.minecraft.resources.ResourceKey<net.minecraft.world.level.material.Fluid>> KEY_CACHE = Collections.synchronizedMap(new java.util.EnumMap<>(Fluid.class)); // Paper |
| 51 | + @Override |
| 52 | + public boolean isTagged(Fluid fluid) { |
| 53 | +- return registry.getHolderOrThrow(net.minecraft.resources.ResourceKey.create(net.minecraft.core.Registry.FLUID_REGISTRY, org.bukkit.craftbukkit.util.CraftNamespacedKey.toMinecraft(fluid.getKey()))).is(tag); // Paper |
| 54 | ++ return registry.getHolderOrThrow(KEY_CACHE.computeIfAbsent(fluid, f -> net.minecraft.resources.ResourceKey.create(net.minecraft.core.Registry.FLUID_REGISTRY, org.bukkit.craftbukkit.util.CraftNamespacedKey.toMinecraft(f.getKey())))).is(tag); // Paper - cache key |
| 55 | + } |
| 56 | + |
| 57 | + @Override |
0 commit comments