mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
Fix client lag on advancement loading
When new advancements are added via the UnsafeValues#loadAdvancement API, it triggers a full datapack reload when this is not necessary. The advancement is already loaded directly into the advancement registry, and the point of saving the advancement to the Bukkit datapack seems to be for persistence. By removing the call to reload datapacks when an advancement is loaded, the client no longer completely freezes up when adding a new advancement. To ensure the client still receives the updated advancement data, we manually reload the advancement data for all players, which normally takes place as a part of the datapack reloading.
This commit is contained in:
parent
c8ba4fb789
commit
9ac98063a0
1 changed files with 7 additions and 1 deletions
|
@ -318,7 +318,13 @@ public final class CraftMagicNumbers implements UnsafeValues {
|
|||
Bukkit.getLogger().log(Level.SEVERE, "Error saving advancement " + key, ex);
|
||||
}
|
||||
|
||||
MinecraftServer.getServer().getPlayerList().reloadResources();
|
||||
// Paper start - Fix client lag on advancement loading
|
||||
//MinecraftServer.getServer().getPlayerList().reload();
|
||||
MinecraftServer.getServer().getPlayerList().getPlayers().forEach(player -> {
|
||||
player.getAdvancements().reload(MinecraftServer.getServer().getAdvancements());
|
||||
player.getAdvancements().flushDirty(player);
|
||||
});
|
||||
// Paper end - Fix client lag on advancement loading
|
||||
|
||||
return bukkit;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue