From 0e668caa276bc4f0f99efbe5e91902d3dba3f529 Mon Sep 17 00:00:00 2001 From: Nassim Jahnke Date: Tue, 3 Dec 2024 21:03:25 +0100 Subject: [PATCH] Even more work --- ...s-send-Banner-patterns-to-the-client.patch | 0 .../server/Rewrite-dataconverter-system.patch | 0 .../Separate-dimensiondata-executor.patch | 25 +++++++++++++------ 3 files changed, 17 insertions(+), 8 deletions(-) rename patches/{unapplied => }/server/Always-send-Banner-patterns-to-the-client.patch (100%) rename patches/{unapplied => }/server/Rewrite-dataconverter-system.patch (100%) rename patches/{unapplied => }/server/Separate-dimensiondata-executor.patch (69%) diff --git a/patches/unapplied/server/Always-send-Banner-patterns-to-the-client.patch b/patches/server/Always-send-Banner-patterns-to-the-client.patch similarity index 100% rename from patches/unapplied/server/Always-send-Banner-patterns-to-the-client.patch rename to patches/server/Always-send-Banner-patterns-to-the-client.patch diff --git a/patches/unapplied/server/Rewrite-dataconverter-system.patch b/patches/server/Rewrite-dataconverter-system.patch similarity index 100% rename from patches/unapplied/server/Rewrite-dataconverter-system.patch rename to patches/server/Rewrite-dataconverter-system.patch diff --git a/patches/unapplied/server/Separate-dimensiondata-executor.patch b/patches/server/Separate-dimensiondata-executor.patch similarity index 69% rename from patches/unapplied/server/Separate-dimensiondata-executor.patch rename to patches/server/Separate-dimensiondata-executor.patch index 845818cfda..437d8ffffc 100644 --- a/patches/unapplied/server/Separate-dimensiondata-executor.patch +++ b/patches/server/Separate-dimensiondata-executor.patch @@ -43,11 +43,20 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 --- a/src/main/java/net/minecraft/world/level/storage/DimensionDataStorage.java +++ b/src/main/java/net/minecraft/world/level/storage/DimensionDataStorage.java @@ -0,0 +0,0 @@ public class DimensionDataStorage implements AutoCloseable { - } catch (IOException var3) { - LOGGER.error("Could not save data to {}", path.getFileName(), var3); - } -- }, Util.ioPool()); -+ }, Util.DIMENSION_DATA_IO_POOL); // Paper - Separate dimension data IO pool - } - - public void saveAndJoin() { + } else { + int i = Util.maxAllowedExecutorThreads(); + int j = map.size(); +- if (j > i) { ++ if (false && j > i) { // Paper - Separate dimension data IO pool; just throw them into the fixed pool queue + this.pendingWriteFuture = this.pendingWriteFuture.thenCompose(object -> { + List> list = new ArrayList<>(i); + int k = Mth.positiveCeilDiv(j, i); +@@ -0,0 +0,0 @@ public class DimensionDataStorage implements AutoCloseable { + v -> CompletableFuture.allOf( + map.entrySet() + .stream() +- .map(entry -> CompletableFuture.runAsync(() -> tryWrite(entry.getKey(), entry.getValue()), Util.ioPool())) ++ .map(entry -> CompletableFuture.runAsync(() -> tryWrite(entry.getKey(), entry.getValue()), Util.DIMENSION_DATA_IO_POOL)) // Paper - Separate dimension data IO pool + .toArray(CompletableFuture[]::new) + ) + );