2019-09-30 04:02:04 +08:00
|
|
|
From f740ce691e50b45b0fb0b729ce92c5e1ead81226 Mon Sep 17 00:00:00 2001
|
2019-05-29 11:25:08 +08:00
|
|
|
From: Shane Freeder <theboyetronic@gmail.com>
|
|
|
|
Date: Wed, 29 May 2019 04:01:22 +0100
|
|
|
|
Subject: [PATCH] ChunkMapDistance CME
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkMapDistance.java b/src/main/java/net/minecraft/server/ChunkMapDistance.java
|
2019-09-30 04:02:04 +08:00
|
|
|
index 101eb58ac..63a688725 100644
|
2019-05-29 11:25:08 +08:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkMapDistance.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkMapDistance.java
|
2019-07-05 10:23:33 +08:00
|
|
|
@@ -36,7 +36,7 @@ public abstract class ChunkMapDistance {
|
2019-06-25 09:47:58 +08:00
|
|
|
private final ChunkMapDistance.a e = new ChunkMapDistance.a();
|
|
|
|
private final ChunkMapDistance.b f = new ChunkMapDistance.b(8);
|
|
|
|
private final ChunkMapDistance.c g = new ChunkMapDistance.c(33);
|
2019-07-20 12:01:24 +08:00
|
|
|
- private final Set<PlayerChunk> pendingChunkUpdates = Sets.newHashSet();
|
|
|
|
+ private final java.util.Queue<PlayerChunk> pendingChunkUpdates = new java.util.LinkedList<>(); // PAIL pendingChunkUpdates // Paper - use a queue
|
|
|
|
private final ChunkTaskQueueSorter i;
|
2019-06-25 09:47:58 +08:00
|
|
|
private final Mailbox<ChunkTaskQueueSorter.a<Runnable>> j;
|
|
|
|
private final Mailbox<ChunkTaskQueueSorter.b> k;
|
2019-07-20 12:01:24 +08:00
|
|
|
@@ -99,26 +99,12 @@ public abstract class ChunkMapDistance {
|
2019-05-29 11:25:08 +08:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
2019-07-20 12:01:24 +08:00
|
|
|
if (!this.pendingChunkUpdates.isEmpty()) {
|
2019-07-17 06:09:32 +08:00
|
|
|
- // CraftBukkit start
|
|
|
|
- // Iterate pending chunk updates with protection against concurrent modification exceptions
|
2019-07-20 12:01:24 +08:00
|
|
|
- java.util.Iterator<PlayerChunk> iter = this.pendingChunkUpdates.iterator();
|
|
|
|
- int expectedSize = this.pendingChunkUpdates.size();
|
2019-07-17 06:09:32 +08:00
|
|
|
- do {
|
|
|
|
- PlayerChunk playerchunk = iter.next();
|
|
|
|
- iter.remove();
|
|
|
|
- expectedSize--;
|
|
|
|
-
|
2019-07-03 02:50:03 +08:00
|
|
|
- playerchunk.a(playerchunkmap);
|
2019-07-17 06:09:32 +08:00
|
|
|
-
|
|
|
|
- // Reset iterator if set was modified using add()
|
2019-07-20 12:01:24 +08:00
|
|
|
- if (this.pendingChunkUpdates.size() != expectedSize) {
|
|
|
|
- expectedSize = this.pendingChunkUpdates.size();
|
|
|
|
- iter = this.pendingChunkUpdates.iterator();
|
2019-07-17 06:09:32 +08:00
|
|
|
- }
|
|
|
|
- } while (iter.hasNext());
|
|
|
|
- // CraftBukkit end
|
|
|
|
-
|
2019-07-20 12:01:24 +08:00
|
|
|
+ while(!this.pendingChunkUpdates.isEmpty()) {
|
|
|
|
+ this.pendingChunkUpdates.remove().a(playerchunkmap);
|
2019-07-03 02:50:03 +08:00
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
if (!this.l.isEmpty()) {
|
2019-05-29 11:25:08 +08:00
|
|
|
--
|
2019-09-30 04:02:04 +08:00
|
|
|
2.23.0
|
2019-05-29 11:25:08 +08:00
|
|
|
|