2014-06-22 15:49:11 -05:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2015-04-13 15:48:16 -05:00
From: Zach Brown <1254957+zachbr@users.noreply.github.com>
2016-02-29 17:09:49 -06:00
Date: Wed, 2 Mar 2016 00:21:24 -0600
2014-06-22 15:49:11 -05:00
Subject: [PATCH] Fix redstone lag issues
2016-02-29 17:09:49 -06:00
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
@@ -0,0 +0,0 @@ public class PaperWorldConfig {
netherVoidTopDamage = getBoolean( "nether-ceiling-void-damage", false );
log("Top of the nether void damage: " + netherVoidTopDamage);
}
+
+ public int tickNextTickCap;
+ public boolean tickNextTickListCapIgnoresRedstone;
+ private void tickNextTickCap() {
+ tickNextTickCap = getInt("tick-next-tick-list-cap", 1000); // Higher values will be friendlier to vanilla style mechanics (to a point) but may hurt performance
+ tickNextTickListCapIgnoresRedstone = getBoolean("tick-next-tick-list-cap-ignores-redstone", false); // Redstone TickNextTicks will always bypass the preceding cap
+ log("WorldServer TickNextTick cap set at " + tickNextTickCap);
+ log("WorldServer TickNextTickList cap always processes redstone: " + tickNextTickListCapIgnoresRedstone);
+
+ }
+
}
2014-06-22 15:49:11 -05:00
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-27 17:17:45 -08:00
@@ -0,0 +0,0 @@ public class WorldServer extends World implements IAsyncTaskHandler {
2015-04-13 15:48:16 -05:00
if (false) { // CraftBukkit
2014-11-27 17:17:45 -08:00
throw new IllegalStateException("TickNextTick list out of synch");
} else {
2016-02-29 17:09:49 -06:00
+ // Paper start - No, stop doing this, it affects things like redstone
2014-11-27 17:17:45 -08: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 {
}
2015-03-07 19:16:09 -06:00
// CraftBukkit end
2014-11-30 20:09:09 -06:00
}
2016-02-29 17:09:49 -06:00
+ */
+ if (i > paperConfig.tickNextTickCap) {
+ i = paperConfig.tickNextTickCap;
+ }
+ // Paper end
2014-06-22 15:49:11 -05:00
2014-11-27 17:17:45 -08:00
this.methodProfiler.a("cleaning");
2014-06-22 15:49:11 -05:00
2015-04-17 03:54:46 -07:00
@@ -0,0 +0,0 @@ public class WorldServer extends World implements IAsyncTaskHandler {
2016-02-29 17:09:49 -06:00
this.U.add(nextticklistentry);
2015-04-17 03:54:46 -07:00
}
2016-02-29 17:09:49 -06:00
+ // Paper start - Allow redstone ticks to bypass the tickNextTickListCap
+ if (paperConfig.tickNextTickListCapIgnoresRedstone) {
+ Iterator<NextTickListEntry> iterator = this.nextTickList.iterator();
2015-04-17 03:54:46 -07:00
+ while (iterator.hasNext()) {
+ NextTickListEntry next = iterator.next();
+ if (!flag && next.b > this.worldData.getTime()) {
+ break;
+ }
+
2016-02-29 17:09:49 -06:00
+ IBlockData data = next.a().getBlockData();
+ if (next.a().isPowerSource(data) || next.a() instanceof IInventory) {
2015-04-17 03:54:46 -07:00
+ iterator.remove();
2016-02-29 17:09:49 -06:00
+ this.U.add(next);
2015-04-17 03:54:46 -07:00
+ }
+ }
+ }
2016-02-29 17:09:49 -06:00
+ // Paper end
2015-04-17 03:54:46 -07:00
+
this.methodProfiler.b();
this.methodProfiler.a("ticking");
2016-02-29 17:09:49 -06:00
Iterator iterator = this.U.iterator();
2015-09-12 19:57:39 -05:00
--