2015-05-25 18:37:24 +08:00
|
|
|
--- a/net/minecraft/server/PlayerChunkMap.java
|
|
|
|
+++ b/net/minecraft/server/PlayerChunkMap.java
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -12,6 +12,10 @@
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Set;
|
2014-11-26 05:32:16 +08:00
|
|
|
|
|
|
|
+// CraftBukkit start
|
|
|
|
+import java.util.LinkedList;
|
|
|
|
+// CraftBukkit end
|
|
|
|
+
|
|
|
|
public class PlayerChunkMap {
|
|
|
|
|
2016-03-01 05:32:46 +08:00
|
|
|
private static final Predicate<EntityPlayer> a = new Predicate() {
|
|
|
|
@@ -43,6 +47,7 @@
|
|
|
|
private long k;
|
|
|
|
private boolean l = true;
|
|
|
|
private boolean m = true;
|
2014-11-26 05:32:16 +08:00
|
|
|
+ private boolean wasNotEmpty; // CraftBukkit - add field
|
|
|
|
|
|
|
|
public PlayerChunkMap(WorldServer worldserver) {
|
|
|
|
this.world = worldserver;
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -227,6 +232,16 @@
|
|
|
|
return playerchunk;
|
2014-11-26 05:32:16 +08:00
|
|
|
}
|
2015-02-27 06:41:06 +08:00
|
|
|
|
2014-11-26 05:32:16 +08:00
|
|
|
+ // CraftBukkit start - add method
|
|
|
|
+ public final boolean isChunkInUse(int x, int z) {
|
2016-03-01 05:32:46 +08:00
|
|
|
+ PlayerChunk pi = b(x, z);
|
2014-11-26 05:32:16 +08:00
|
|
|
+ if (pi != null) {
|
2016-03-01 05:32:46 +08:00
|
|
|
+ return (pi.c.size() > 0);
|
2014-11-26 05:32:16 +08:00
|
|
|
+ }
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
2015-02-27 06:41:06 +08:00
|
|
|
+
|
2014-11-26 05:32:16 +08:00
|
|
|
public void flagDirty(BlockPosition blockposition) {
|
|
|
|
int i = blockposition.getX() >> 4;
|
2015-02-27 06:41:06 +08:00
|
|
|
int j = blockposition.getZ() >> 4;
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -245,12 +260,22 @@
|
2014-11-26 05:32:16 +08:00
|
|
|
entityplayer.d = entityplayer.locX;
|
|
|
|
entityplayer.e = entityplayer.locZ;
|
2015-02-27 06:41:06 +08:00
|
|
|
|
2016-03-01 05:32:46 +08:00
|
|
|
+
|
2014-11-26 05:32:16 +08:00
|
|
|
+ // CraftBukkit start - Load nearby chunks first
|
|
|
|
+ List<ChunkCoordIntPair> chunkList = new LinkedList<ChunkCoordIntPair>();
|
2015-02-27 06:41:06 +08:00
|
|
|
+
|
2016-03-01 05:32:46 +08:00
|
|
|
for (int k = i - this.j; k <= i + this.j; ++k) {
|
|
|
|
for (int l = j - this.j; l <= j + this.j; ++l) {
|
|
|
|
- this.c(k, l).a(entityplayer);
|
2014-11-26 05:32:16 +08:00
|
|
|
+ chunkList.add(new ChunkCoordIntPair(k, l));
|
|
|
|
}
|
|
|
|
}
|
2016-03-01 05:32:46 +08:00
|
|
|
|
2014-11-26 05:32:16 +08:00
|
|
|
+ Collections.sort(chunkList, new ChunkCoordComparator(entityplayer));
|
2015-02-27 06:41:06 +08:00
|
|
|
+ for (ChunkCoordIntPair pair : chunkList) {
|
2016-03-01 05:32:46 +08:00
|
|
|
+ this.c(pair.x, pair.z).a(entityplayer);
|
2014-11-26 05:32:16 +08:00
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
2016-03-01 05:32:46 +08:00
|
|
|
+
|
2014-11-26 05:32:16 +08:00
|
|
|
this.managedPlayers.add(entityplayer);
|
2016-03-01 05:32:46 +08:00
|
|
|
this.e();
|
|
|
|
}
|
|
|
|
@@ -294,11 +319,14 @@
|
2014-11-26 05:32:16 +08:00
|
|
|
int j1 = i - k;
|
|
|
|
int k1 = j - l;
|
|
|
|
|
2016-03-01 05:32:46 +08:00
|
|
|
+ List<ChunkCoordIntPair> chunksToLoad = new LinkedList<ChunkCoordIntPair>(); // CraftBukkit
|
|
|
|
+
|
2014-11-26 05:32:16 +08:00
|
|
|
if (j1 != 0 || k1 != 0) {
|
|
|
|
for (int l1 = i - i1; l1 <= i + i1; ++l1) {
|
|
|
|
for (int i2 = j - i1; i2 <= j + i1; ++i2) {
|
|
|
|
if (!this.a(l1, i2, k, l, i1)) {
|
2016-03-01 05:32:46 +08:00
|
|
|
- this.c(l1, i2).a(entityplayer);
|
|
|
|
+ // this.c(l1, i2).a(entityplayer);
|
2014-11-26 05:32:16 +08:00
|
|
|
+ chunksToLoad.add(new ChunkCoordIntPair(l1, i2)); // CraftBukkit
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!this.a(l1 - j1, i2 - k1, i, j, i1)) {
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -314,6 +342,13 @@
|
2014-11-26 05:32:16 +08:00
|
|
|
entityplayer.d = entityplayer.locX;
|
|
|
|
entityplayer.e = entityplayer.locZ;
|
2016-03-01 05:32:46 +08:00
|
|
|
this.e();
|
2015-02-27 06:41:06 +08:00
|
|
|
+
|
|
|
|
+ // CraftBukkit start - send nearest chunks first
|
2014-11-26 05:32:16 +08:00
|
|
|
+ Collections.sort(chunksToLoad, new ChunkCoordComparator(entityplayer));
|
2015-02-27 06:41:06 +08:00
|
|
|
+ for (ChunkCoordIntPair pair : chunksToLoad) {
|
2016-03-01 05:32:46 +08:00
|
|
|
+ this.c(pair.x, pair.z).a(entityplayer);
|
2014-11-26 05:32:16 +08:00
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -393,4 +428,47 @@
|
|
|
|
this.h.remove(playerchunk);
|
|
|
|
this.getWorld().getChunkProviderServer().queueUnload(chunkcoordintpair.x, chunkcoordintpair.z);
|
2014-11-26 05:32:16 +08:00
|
|
|
}
|
2015-02-27 06:41:06 +08:00
|
|
|
+
|
2014-11-26 05:32:16 +08:00
|
|
|
+ // CraftBukkit start - Sorter to load nearby chunks first
|
|
|
|
+ private static class ChunkCoordComparator implements java.util.Comparator<ChunkCoordIntPair> {
|
|
|
|
+ private int x;
|
|
|
|
+ private int z;
|
|
|
|
+
|
|
|
|
+ public ChunkCoordComparator (EntityPlayer entityplayer) {
|
|
|
|
+ x = (int) entityplayer.locX >> 4;
|
|
|
|
+ z = (int) entityplayer.locZ >> 4;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public int compare(ChunkCoordIntPair a, ChunkCoordIntPair b) {
|
|
|
|
+ if (a.equals(b)) {
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // Subtract current position to set center point
|
|
|
|
+ int ax = a.x - this.x;
|
|
|
|
+ int az = a.z - this.z;
|
|
|
|
+ int bx = b.x - this.x;
|
|
|
|
+ int bz = b.z - this.z;
|
|
|
|
+
|
|
|
|
+ int result = ((ax - bx) * (ax + bx)) + ((az - bz) * (az + bz));
|
|
|
|
+ if (result != 0) {
|
|
|
|
+ return result;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (ax < 0) {
|
|
|
|
+ if (bx < 0) {
|
|
|
|
+ return bz - az;
|
|
|
|
+ } else {
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ if (bx < 0) {
|
|
|
|
+ return 1;
|
|
|
|
+ } else {
|
|
|
|
+ return az - bz;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|