2024-12-11 22:26:55 +01:00
--- a/net/minecraft/server/PlayerAdvancements.java
+++ b/net/minecraft/server/PlayerAdvancements.java
2024-12-14 04:12:33 +01:00
@@ -47,7 +_,7 @@
2024-09-20 14:17:37 +02:00
2024-12-14 04:12:33 +01:00
public class PlayerAdvancements {
2024-09-20 14:17:37 +02:00
private static final Logger LOGGER = LogUtils.getLogger();
2024-12-14 04:12:33 +01:00
- private static final Gson GSON = new GsonBuilder().setPrettyPrinting().create();
+ private static final Gson GSON = new GsonBuilder().create(); // Paper - Remove pretty printing from advancements
2024-09-20 14:17:37 +02:00
private final PlayerList playerList;
private final Path playerSavePath;
private AdvancementTree tree;
2024-12-14 04:12:33 +01:00
@@ -60,6 +_,7 @@
2020-07-13 15:22:54 +02:00
private AdvancementHolder lastSelectedTab;
private boolean isFirstPacket = true;
private final Codec<PlayerAdvancements.Data> codec;
+ public final Map<net.minecraft.advancements.critereon.SimpleCriterionTrigger<?>, Set<CriterionTrigger.Listener<?>>> criterionData = new java.util.IdentityHashMap<>(); // Paper - fix advancement data player leakage
2024-12-14 04:12:33 +01:00
public PlayerAdvancements(DataFixer dataFixer, PlayerList playerList, ServerAdvancementManager manager, Path playerSavePath, ServerPlayer player) {
this.playerList = playerList;
@@ -128,6 +_,7 @@
2017-06-09 08:29:31 +02:00
}
public void save() {
+ if (org.spigotmc.SpigotConfig.disableAdvancementSaving) return; // Spigot
2024-12-14 04:12:33 +01:00
JsonElement jsonElement = this.codec.encodeStart(JsonOps.INSTANCE, this.asData()).getOrThrow();
2017-06-09 08:29:31 +02:00
try {
2024-12-14 04:12:33 +01:00
@@ -145,6 +_,7 @@
data.forEach((path, progress) -> {
AdvancementHolder advancementHolder = advancementManager.get(path);
if (advancementHolder == null) {
+ if (!path.getNamespace().equals(ResourceLocation.DEFAULT_NAMESPACE)) return; // CraftBukkit
LOGGER.warn("Ignored advancement '{}' in progress file {} - it doesn't exist anymore?", path, this.playerSavePath);
2024-12-11 22:26:55 +01:00
} else {
2024-12-14 04:12:33 +01:00
this.startProgress(advancementHolder, progress);
@@ -169,14 +_,31 @@
AdvancementProgress orStartProgress = this.getOrStartProgress(advancement);
boolean isDone = orStartProgress.isDone();
if (orStartProgress.grantProgress(criterionKey)) {
2018-01-19 15:15:29 +01:00
+ // Paper start - Add PlayerAdvancementCriterionGrantEvent
2024-12-14 04:12:33 +01:00
+ if (!new com.destroystokyo.paper.event.player.PlayerAdvancementCriterionGrantEvent(this.player.getBukkitEntity(), advancement.toBukkit(), criterionKey).callEvent()) {
+ orStartProgress.revokeProgress(criterionKey);
2018-01-19 15:15:29 +01:00
+ return false;
+ }
+ // Paper end - Add PlayerAdvancementCriterionGrantEvent
this.unregisterListeners(advancement);
2024-12-11 22:26:55 +01:00
this.progressChanged.add(advancement);
flag = true;
2024-12-14 04:12:33 +01:00
if (!isDone && orStartProgress.isDone()) {
2021-01-08 20:31:13 +01:00
+ // Paper start - Add Adventure message to PlayerAdvancementDoneEvent
+ final net.kyori.adventure.text.Component message = advancement.value().display().flatMap(info -> {
+ return java.util.Optional.ofNullable(
+ info.shouldAnnounceChat() ? io.papermc.paper.adventure.PaperAdventure.asAdventure(info.getType().createAnnouncement(advancement, this.player)) : null
+ );
+ }).orElse(null);
+ final org.bukkit.event.player.PlayerAdvancementDoneEvent event = new org.bukkit.event.player.PlayerAdvancementDoneEvent(this.player.getBukkitEntity(), advancement.toBukkit(), message);
+ this.player.level().getCraftServer().getPluginManager().callEvent(event); // CraftBukkit
+ // Paper end
2024-12-11 22:26:55 +01:00
advancement.value().rewards().grant(this.player);
2024-12-14 04:12:33 +01:00
advancement.value().display().ifPresent(displayInfo -> {
- if (displayInfo.shouldAnnounceChat() && this.player.serverLevel().getGameRules().getBoolean(GameRules.RULE_ANNOUNCE_ADVANCEMENTS)) {
- this.playerList.broadcastSystemMessage(displayInfo.getType().createAnnouncement(advancement, this.player), false);
2021-01-08 20:31:13 +01:00
+ // Paper start - Add Adventure message to PlayerAdvancementDoneEvent
+ if (event.message() != null && this.player.serverLevel().getGameRules().getBoolean(GameRules.RULE_ANNOUNCE_ADVANCEMENTS)) {
+ this.playerList.broadcastSystemMessage(io.papermc.paper.adventure.PaperAdventure.asVanilla(event.message()), false);
+ // Paper end
}
});
2024-12-14 04:12:33 +01:00
}