2016-03-01 08:32:46 +11:00
|
|
|
--- a/net/minecraft/server/PlayerChunk.java
|
|
|
|
+++ b/net/minecraft/server/PlayerChunk.java
|
2018-07-15 10:00:00 +10:00
|
|
|
@@ -7,21 +7,36 @@
|
2016-05-10 21:47:39 +10:00
|
|
|
import javax.annotation.Nullable;
|
2016-03-01 08:32:46 +11:00
|
|
|
import org.apache.logging.log4j.LogManager;
|
|
|
|
import org.apache.logging.log4j.Logger;
|
2016-05-10 21:47:39 +10:00
|
|
|
+// CraftBukkit Start
|
2016-03-01 08:32:46 +11:00
|
|
|
+import org.bukkit.craftbukkit.chunkio.ChunkIOExecutor;
|
2016-05-10 21:47:39 +10:00
|
|
|
+// CraftBukkit end
|
2016-03-01 08:32:46 +11:00
|
|
|
|
|
|
|
public class PlayerChunk {
|
|
|
|
|
|
|
|
private static final Logger a = LogManager.getLogger();
|
|
|
|
private final PlayerChunkMap playerChunkMap;
|
|
|
|
- private final List<EntityPlayer> c = Lists.newArrayList();
|
|
|
|
+ public final List<EntityPlayer> c = Lists.newArrayList(); // CraftBukkit - public
|
|
|
|
private final ChunkCoordIntPair location;
|
|
|
|
private final short[] dirtyBlocks = new short[64];
|
2016-05-10 21:47:39 +10:00
|
|
|
@Nullable
|
2016-03-06 23:49:28 +00:00
|
|
|
- private Chunk chunk;
|
|
|
|
+ public Chunk chunk; // CraftBukkit - public
|
|
|
|
private int dirtyCount;
|
|
|
|
private int h;
|
2016-03-01 08:32:46 +11:00
|
|
|
private long i;
|
|
|
|
private boolean done;
|
|
|
|
|
|
|
|
+ // CraftBukkit start - add fields
|
2018-07-15 10:00:00 +10:00
|
|
|
+ // You know the drill, https://hub.spigotmc.org/stash/projects/SPIGOT/repos/craftbukkit/browse
|
|
|
|
+ // All may seem good at first, but there's deeper issues if you play for a bit
|
2016-04-20 11:00:35 +01:00
|
|
|
+ private boolean loadInProgress = false;
|
2016-03-01 08:32:46 +11:00
|
|
|
+ private Runnable loadedRunnable = new Runnable() {
|
|
|
|
+ public void run() {
|
2016-04-20 11:00:35 +01:00
|
|
|
+ loadInProgress = false;
|
2016-03-01 08:32:46 +11:00
|
|
|
+ PlayerChunk.this.chunk = PlayerChunk.this.playerChunkMap.getWorld().getChunkProviderServer().getOrLoadChunkAt(location.x, location.z);
|
|
|
|
+ }
|
|
|
|
+ };
|
|
|
|
+ // CraftBukkit end
|
|
|
|
+
|
|
|
|
public PlayerChunk(PlayerChunkMap playerchunkmap, int i, int j) {
|
|
|
|
this.playerChunkMap = playerchunkmap;
|
|
|
|
this.location = new ChunkCoordIntPair(i, j);
|