aboutsummaryrefslogtreecommitdiffhomepage
path: root/feature-patches/1066-Incremental-chunk-and-player-saving.patch
diff options
context:
space:
mode:
authorNassim Jahnke <[email protected]>2024-12-20 23:18:34 +0100
committerNassim Jahnke <[email protected]>2024-12-20 23:24:23 +0100
commit13b890950daa67c2c6d3d7c2e2fa78b6542ef698 (patch)
tree1932b1251a489ddbf57ac69cd5f41e3735805536 /feature-patches/1066-Incremental-chunk-and-player-saving.patch
parentc45286cb08881ab4d28a16b8ef9c6a4fd0984ce8 (diff)
downloadPaper-13b890950daa67c2c6d3d7c2e2fa78b6542ef698.tar.gz
Paper-13b890950daa67c2c6d3d7c2e2fa78b6542ef698.zip
Apply remaining feature patches
Diffstat (limited to 'feature-patches/1066-Incremental-chunk-and-player-saving.patch')
-rw-r--r--feature-patches/1066-Incremental-chunk-and-player-saving.patch133
1 files changed, 0 insertions, 133 deletions
diff --git a/feature-patches/1066-Incremental-chunk-and-player-saving.patch b/feature-patches/1066-Incremental-chunk-and-player-saving.patch
deleted file mode 100644
index 17ee1796ca..0000000000
--- a/feature-patches/1066-Incremental-chunk-and-player-saving.patch
+++ /dev/null
@@ -1,133 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Shane Freeder <[email protected]>
-Date: Sun, 9 Jun 2019 03:53:22 +0100
-Subject: [PATCH] Incremental chunk and player saving
-
-
-diff --git a/net/minecraft/server/MinecraftServer.java b/net/minecraft/server/MinecraftServer.java
-index f4fba4e2d12c7ab4b4eb9858cd738a9678a2d203..a0a75c84379432ccc525ab22d476c358c77f663b 100644
---- a/net/minecraft/server/MinecraftServer.java
-+++ b/net/minecraft/server/MinecraftServer.java
-@@ -862,7 +862,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
- boolean var4;
- try {
- this.isSaving = true;
-- this.getPlayerList().saveAll();
-+ this.getPlayerList().saveAll(); // Paper - Incremental chunk and player saving; diff on change
- var4 = this.saveAllChunks(suppressLog, flush, forced);
- } finally {
- this.isSaving = false;
-@@ -1409,9 +1409,29 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
- }
-
- this.ticksUntilAutosave--;
-- if (this.autosavePeriod > 0 && this.ticksUntilAutosave <= 0) { // CraftBukkit
-- this.autoSave();
-+ // Paper start - Incremental chunk and player saving
-+ final ProfilerFiller profiler = Profiler.get();
-+ int playerSaveInterval = io.papermc.paper.configuration.GlobalConfiguration.get().playerAutoSave.rate;
-+ if (playerSaveInterval < 0) {
-+ playerSaveInterval = autosavePeriod;
-+ }
-+ profiler.push("save");
-+ final boolean fullSave = autosavePeriod > 0 && this.tickCount % autosavePeriod == 0;
-+ try {
-+ this.isSaving = true;
-+ if (playerSaveInterval > 0) {
-+ this.playerList.saveAll(playerSaveInterval);
-+ }
-+ for (final ServerLevel level : this.getAllLevels()) {
-+ if (level.paperConfig().chunks.autoSaveInterval.value() > 0) {
-+ level.saveIncrementally(fullSave);
-+ }
-+ }
-+ } finally {
-+ this.isSaving = false;
- }
-+ profiler.pop();
-+ // Paper end - Incremental chunk and player saving
-
- ProfilerFiller profilerFiller = Profiler.get();
- this.runAllTasks(); // Paper - move runAllTasks() into full server tick (previously for timings)
-diff --git a/net/minecraft/server/level/ServerLevel.java b/net/minecraft/server/level/ServerLevel.java
-index c38eda42b33cfa4792625f40ebde6f30e591119b..c8129f0d8218daff9123f1ad2d8ca321a02e1c7e 100644
---- a/net/minecraft/server/level/ServerLevel.java
-+++ b/net/minecraft/server/level/ServerLevel.java
-@@ -1007,6 +1007,28 @@ public class ServerLevel extends Level implements ServerEntityGetter, WorldGenLe
- return !this.server.isUnderSpawnProtection(this, pos, player) && this.getWorldBorder().isWithinBounds(pos);
- }
-
-+ // Paper start - Incremental chunk and player saving
-+ public void saveIncrementally(boolean doFull) {
-+ if (doFull) {
-+ org.bukkit.Bukkit.getPluginManager().callEvent(new org.bukkit.event.world.WorldSaveEvent(this.getWorld()));
-+ }
-+
-+ if (doFull) {
-+ this.saveLevelData(true);
-+ }
-+ // chunk autosave is already called by the ChunkSystem during unload processing (ChunkMap#processUnloads)
-+ // Copied from save()
-+ // CraftBukkit start - moved from MinecraftServer.saveChunks
-+ if (doFull) { // Paper
-+ ServerLevel serverLevel1 = this;
-+ this.serverLevelData.setWorldBorder(serverLevel1.getWorldBorder().createSettings());
-+ this.serverLevelData.setCustomBossEvents(this.server.getCustomBossEvents().save(this.registryAccess()));
-+ this.convertable.saveDataTag(this.server.registryAccess(), this.serverLevelData, this.server.getPlayerList().getSingleplayerData());
-+ }
-+ // CraftBukkit end
-+ }
-+ // Paper end - Incremental chunk and player saving
-+
- public void save(@Nullable ProgressListener progress, boolean flush, boolean skipSave) {
- ServerChunkCache chunkSource = this.getChunkSource();
- if (!skipSave) {
-diff --git a/net/minecraft/server/level/ServerPlayer.java b/net/minecraft/server/level/ServerPlayer.java
-index 92bd46cca1956f327fb0b407e988d68782f441a4..0f00db82e85c9e510c2e4fe4065291971c408dad 100644
---- a/net/minecraft/server/level/ServerPlayer.java
-+++ b/net/minecraft/server/level/ServerPlayer.java
-@@ -180,6 +180,7 @@ import org.slf4j.Logger;
-
- public class ServerPlayer extends Player {
- private static final Logger LOGGER = LogUtils.getLogger();
-+ public long lastSave = MinecraftServer.currentTick; // Paper - Incremental chunk and player saving
- private static final int NEUTRAL_MOB_DEATH_NOTIFICATION_RADII_XZ = 32;
- private static final int NEUTRAL_MOB_DEATH_NOTIFICATION_RADII_Y = 10;
- private static final int FLY_STAT_RECORDING_SPEED = 25;
-diff --git a/net/minecraft/server/players/PlayerList.java b/net/minecraft/server/players/PlayerList.java
-index bafeeab3edbc73f6f86474e18ab4a3d96ce17157..aaa6b8eee7b34fe6efa76f1fe997dcece827d5dd 100644
---- a/net/minecraft/server/players/PlayerList.java
-+++ b/net/minecraft/server/players/PlayerList.java
-@@ -483,6 +483,7 @@ public abstract class PlayerList {
-
- protected void save(ServerPlayer player) {
- if (!player.getBukkitEntity().isPersistent()) return; // CraftBukkit
-+ player.lastSave = MinecraftServer.currentTick; // Paper - Incremental chunk and player saving
- this.playerIo.save(player);
- ServerStatsCounter serverStatsCounter = player.getStats(); // CraftBukkit
- if (serverStatsCounter != null) {
-@@ -1070,9 +1071,23 @@ public abstract class PlayerList {
- }
-
- public void saveAll() {
-+ // Paper start - Incremental chunk and player saving
-+ this.saveAll(-1);
-+ }
-+
-+ public void saveAll(final int interval) {
- io.papermc.paper.util.MCUtil.ensureMain("Save Players" , () -> { // Paper - Ensure main
-+ int numSaved = 0;
-+ final long now = MinecraftServer.currentTick;
- for (int i = 0; i < this.players.size(); i++) {
-- this.save(this.players.get(i));
-+ final ServerPlayer player = this.players.get(i);
-+ if (interval == -1 || now - player.lastSave >= interval) {
-+ this.save(player);
-+ if (interval != -1 && ++numSaved >= io.papermc.paper.configuration.GlobalConfiguration.get().playerAutoSave.maxPerTick()) {
-+ break;
-+ }
-+ }
-+ // Paper end - Incremental chunk and player saving
- }
- return null; }); // Paper - ensure main
- }