2021-06-15 01:44:37 -04:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Wed, 12 Sep 2018 21:47:01 -0400
|
|
|
|
Subject: [PATCH] Optimize Biome Mob Lookups for Mob Spawning
|
|
|
|
|
|
|
|
Uses an EnumMap as well as a Set paired List for O(1) contains calls.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/biome/MobSpawnSettings.java b/src/main/java/net/minecraft/world/level/biome/MobSpawnSettings.java
|
|
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
|
|
--- a/src/main/java/net/minecraft/world/level/biome/MobSpawnSettings.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/level/biome/MobSpawnSettings.java
|
|
|
|
@@ -0,0 +0,0 @@ public class MobSpawnSettings {
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class Builder {
|
2024-01-19 13:22:30 +01:00
|
|
|
+ // Paper start - Perf: keep track of data in a pair set to give O(1) contains calls - we have to hook removals incase plugins mess with it
|
2021-06-15 01:44:37 -04:00
|
|
|
+ public static class MobList extends java.util.ArrayList<MobSpawnSettings.SpawnerData> {
|
|
|
|
+ java.util.Set<MobSpawnSettings.SpawnerData> biomes = new java.util.HashSet<>();
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean contains(Object o) {
|
|
|
|
+ return biomes.contains(o);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean add(MobSpawnSettings.SpawnerData BiomeSettingsMobs) {
|
|
|
|
+ biomes.add(BiomeSettingsMobs);
|
|
|
|
+ return super.add(BiomeSettingsMobs);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public MobSpawnSettings.SpawnerData remove(int index) {
|
|
|
|
+ MobSpawnSettings.SpawnerData removed = super.remove(index);
|
|
|
|
+ if (removed != null) {
|
|
|
|
+ biomes.remove(removed);
|
|
|
|
+ }
|
|
|
|
+ return removed;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void clear() {
|
|
|
|
+ biomes.clear();
|
|
|
|
+ super.clear();
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // use toImmutableEnumMap collector
|
2024-04-12 12:14:06 -07:00
|
|
|
private final Map<MobCategory, List<MobSpawnSettings.SpawnerData>> spawners = Stream.of(MobCategory.values())
|
|
|
|
- .collect(ImmutableMap.toImmutableMap(mobCategory -> (MobCategory)mobCategory, mobCategory -> Lists.newArrayList()));
|
|
|
|
+ .collect(Maps.toImmutableEnumMap(mobCategory -> (MobCategory)mobCategory, mobCategory -> new MobList())); // Use MobList instead of ArrayList
|
2024-01-19 13:22:30 +01:00
|
|
|
+ // Paper end - Perf: keep track of data in a pair set to give O(1) contains calls
|
2021-06-15 01:44:37 -04:00
|
|
|
private final Map<EntityType<?>, MobSpawnSettings.MobSpawnCost> mobSpawnCosts = Maps.newLinkedHashMap();
|
|
|
|
private float creatureGenerationProbability = 0.1F;
|
2021-11-24 15:26:29 -08:00
|
|
|
|