2024-12-11 22:26:55 +01:00
|
|
|
--- a/net/minecraft/server/ServerAdvancementManager.java
|
|
|
|
+++ b/net/minecraft/server/ServerAdvancementManager.java
|
2024-10-23 02:15:00 +11:00
|
|
|
@@ -21,10 +21,14 @@
|
2024-12-11 22:26:55 +01:00
|
|
|
import net.minecraft.util.profiling.ProfilerFiller;
|
2024-06-09 11:12:13 +10:00
|
|
|
import org.slf4j.Logger;
|
2021-04-07 15:03:29 +10:00
|
|
|
|
2024-06-09 11:12:13 +10:00
|
|
|
+// CraftBukkit start
|
|
|
|
+import java.util.HashMap;
|
|
|
|
+// CraftBukkit end
|
|
|
|
+
|
2024-12-11 22:26:55 +01:00
|
|
|
public class ServerAdvancementManager extends SimpleJsonResourceReloadListener<Advancement> {
|
2024-06-09 11:12:13 +10:00
|
|
|
|
|
|
|
private static final Logger LOGGER = LogUtils.getLogger();
|
2024-12-11 22:26:55 +01:00
|
|
|
- public Map<ResourceLocation, AdvancementHolder> advancements = Map.of();
|
|
|
|
+ public Map<ResourceLocation, AdvancementHolder> advancements = new HashMap<>(); // CraftBukkit - SPIGOT-7734: mutable
|
2024-06-09 11:12:13 +10:00
|
|
|
private AdvancementTree tree = new AdvancementTree();
|
2024-12-11 22:26:55 +01:00
|
|
|
private final HolderLookup.Provider registries;
|
2024-06-09 11:12:13 +10:00
|
|
|
|
2022-12-14 15:52:11 -08:00
|
|
|
@@ -37,13 +41,19 @@
|
2017-06-09 16:29:31 +10:00
|
|
|
Builder<ResourceLocation, AdvancementHolder> builder = ImmutableMap.builder();
|
|
|
|
|
|
|
|
prepared.forEach((minecraftkey, advancement) -> {
|
|
|
|
+ // Spigot start
|
|
|
|
+ if (org.spigotmc.SpigotConfig.disabledAdvancements != null && (org.spigotmc.SpigotConfig.disabledAdvancements.contains("*") || org.spigotmc.SpigotConfig.disabledAdvancements.contains(minecraftkey.toString()) || org.spigotmc.SpigotConfig.disabledAdvancements.contains(minecraftkey.getNamespace()))) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Spigot end
|
2024-10-23 02:15:00 +11:00
|
|
|
this.validate(minecraftkey, advancement);
|
|
|
|
builder.put(minecraftkey, new AdvancementHolder(minecraftkey, advancement));
|
2024-06-09 11:12:13 +10:00
|
|
|
});
|
|
|
|
- this.advancements = builder.buildOrThrow();
|
|
|
|
+ this.advancements = new HashMap<>(builder.buildOrThrow()); // CraftBukkit - SPIGOT-7734: mutable
|
|
|
|
AdvancementTree advancementtree = new AdvancementTree();
|
|
|
|
|
|
|
|
advancementtree.addAll(this.advancements.values());
|
2022-12-14 15:52:11 -08:00
|
|
|
+ LOGGER.info("Loaded {} advancements", advancementtree.nodes().size()); // Paper - Improve logging and errors; moved from AdvancementTree#addAll
|
|
|
|
Iterator iterator = advancementtree.roots().iterator();
|
|
|
|
|
|
|
|
while (iterator.hasNext()) {
|