Paper/Spigot-Server-Patches/Fix-redstone-lag-issues.patch

48 lines
2.3 KiB
Diff
Raw Normal View History

2014-06-22 22:49:11 +02:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2015-04-13 22:48:16 +02:00
From: Zach Brown <1254957+zachbr@users.noreply.github.com>
Date: Mon, 13 Apr 2015 15:47:15 -0500
2014-06-22 22:49:11 +02:00
Subject: [PATCH] Fix redstone lag issues
diff --git a/src/main/java/net/minecraft/server/WorldServer.java b/src/main/java/net/minecraft/server/WorldServer.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/net/minecraft/server/WorldServer.java
+++ b/src/main/java/net/minecraft/server/WorldServer.java
2014-11-28 02:17:45 +01:00
@@ -0,0 +0,0 @@ public class WorldServer extends World implements IAsyncTaskHandler {
2015-04-13 22:48:16 +02:00
if (false) { // CraftBukkit
2014-11-28 02:17:45 +01:00
throw new IllegalStateException("TickNextTick list out of synch");
} else {
2015-03-08 02:16:09 +01:00
+ // PaperSpigot start - No, stop doing this, it affects things like redstone
2014-11-28 02:17:45 +01:00
+ /*
if (i > 1000) {
// CraftBukkit start - If the server has too much to process over time, try to alleviate that
if (i > 20 * 1000) {
@@ -0,0 +0,0 @@ public class WorldServer extends World implements IAsyncTaskHandler {
i = 1000;
}
2015-03-08 02:16:09 +01:00
// CraftBukkit end
+ */
+ if (i > paperSpigotConfig.tickNextTickCap) {
+ i = paperSpigotConfig.tickNextTickCap;
2014-12-01 03:09:09 +01:00
}
2014-11-28 02:17:45 +01:00
+ // PaperSpigot end
2014-06-22 22:49:11 +02:00
2014-11-28 02:17:45 +01:00
this.methodProfiler.a("cleaning");
2014-06-22 22:49:11 +02:00
diff --git a/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java b/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java
+++ b/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java
@@ -0,0 +0,0 @@ public class PaperSpigotWorldConfig
System.err.println( "==========================================" );
}
}
+
+ public int tickNextTickCap;
+ private void tickNextTickCap()
+ {
+ tickNextTickCap = getInt( "tick-next-tick-list-cap", 10000 ); // Higher values will be friendlier to vanilla style mechanics (to a point) but may hurt performance
+ log( "WorldServer TickNextTick cap set at " + tickNextTickCap );
+ }
}
2015-03-08 02:16:09 +01:00
--