geforkt von Mirrors/Paper
SPIGOT-729: Revert the entity slice move
By: Thinkofdeath <thinkofdeath@spigotmc.org>
Dieser Commit ist enthalten in:
Ursprung
e1387f5ef4
Commit
c52ea50ad9
@ -1,5 +1,5 @@
|
|||||||
--- /home/matt/mc-dev-private//net/minecraft/server/Chunk.java 2015-03-16 09:47:02.911222177 +0000
|
--- /home/matt/mc-dev-private//net/minecraft/server/Chunk.java 2015-03-22 19:01:20.013879491 +0000
|
||||||
+++ src/main/java/net/minecraft/server/Chunk.java 2015-03-16 09:47:02.911222177 +0000
|
+++ src/main/java/net/minecraft/server/Chunk.java 2015-03-22 19:01:20.013879491 +0000
|
||||||
@@ -14,6 +14,9 @@
|
@@ -14,6 +14,9 @@
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
@ -63,15 +63,7 @@
|
|||||||
public Chunk(World world, int i, int j) {
|
public Chunk(World world, int i, int j) {
|
||||||
this.sections = new ChunkSection[16];
|
this.sections = new ChunkSection[16];
|
||||||
this.e = new byte[256];
|
this.e = new byte[256];
|
||||||
@@ -54,14 +85,25 @@
|
@@ -60,8 +91,17 @@
|
||||||
this.locZ = j;
|
|
||||||
this.heightMap = new int[256];
|
|
||||||
|
|
||||||
+ /* CraftBukkit start
|
|
||||||
for (int k = 0; k < this.entitySlices.length; ++k) {
|
|
||||||
this.entitySlices[k] = new EntitySlice(Entity.class);
|
|
||||||
}
|
|
||||||
+ // CraftBukkit end */
|
|
||||||
|
|
||||||
Arrays.fill(this.f, -999);
|
Arrays.fill(this.f, -999);
|
||||||
Arrays.fill(this.e, (byte) -1);
|
Arrays.fill(this.e, (byte) -1);
|
||||||
@ -89,7 +81,7 @@
|
|||||||
public Chunk(World world, ChunkSnapshot chunksnapshot, int i, int j) {
|
public Chunk(World world, ChunkSnapshot chunksnapshot, int i, int j) {
|
||||||
this(world, i, j);
|
this(world, i, j);
|
||||||
short short0 = 256;
|
short short0 = 256;
|
||||||
@@ -529,7 +571,8 @@
|
@@ -529,7 +569,8 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,7 +91,7 @@
|
|||||||
block.onPlace(this.world, blockposition, iblockdata);
|
block.onPlace(this.world, blockposition, iblockdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -610,7 +653,11 @@
|
@@ -610,7 +651,11 @@
|
||||||
int j = MathHelper.floor(entity.locZ / 16.0D);
|
int j = MathHelper.floor(entity.locZ / 16.0D);
|
||||||
|
|
||||||
if (i != this.locX || j != this.locZ) {
|
if (i != this.locX || j != this.locZ) {
|
||||||
@ -112,7 +104,7 @@
|
|||||||
entity.die();
|
entity.die();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -662,7 +709,15 @@
|
@@ -662,7 +707,15 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public TileEntity a(BlockPosition blockposition, Chunk.EnumTileEntityState chunk_enumtileentitystate) {
|
public TileEntity a(BlockPosition blockposition, Chunk.EnumTileEntityState chunk_enumtileentitystate) {
|
||||||
@ -129,7 +121,7 @@
|
|||||||
|
|
||||||
if (tileentity == null) {
|
if (tileentity == null) {
|
||||||
if (chunk_enumtileentitystate == Chunk.EnumTileEntityState.IMMEDIATE) {
|
if (chunk_enumtileentitystate == Chunk.EnumTileEntityState.IMMEDIATE) {
|
||||||
@@ -697,6 +752,13 @@
|
@@ -697,6 +750,13 @@
|
||||||
|
|
||||||
tileentity.D();
|
tileentity.D();
|
||||||
this.tileEntities.put(blockposition, tileentity);
|
this.tileEntities.put(blockposition, tileentity);
|
||||||
@ -143,7 +135,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -740,7 +802,21 @@
|
@@ -740,7 +800,21 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < this.entitySlices.length; ++i) {
|
for (int i = 0; i < this.entitySlices.length; ++i) {
|
||||||
@ -166,7 +158,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -798,8 +874,8 @@
|
@@ -798,8 +872,8 @@
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Entity entity = (Entity) iterator.next();
|
Entity entity = (Entity) iterator.next();
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
--- /home/matt/mc-dev-private//net/minecraft/server/ChunkProviderServer.java 2015-03-15 21:37:46.552362734 +0000
|
--- /home/matt/mc-dev-private//net/minecraft/server/ChunkProviderServer.java 2015-03-22 19:01:20.021879491 +0000
|
||||||
+++ src/main/java/net/minecraft/server/ChunkProviderServer.java 2015-03-15 21:37:46.552362734 +0000
|
+++ src/main/java/net/minecraft/server/ChunkProviderServer.java 2015-03-22 19:01:20.021879491 +0000
|
||||||
@@ -11,17 +11,28 @@
|
@@ -11,17 +11,28 @@
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
@ -138,7 +138,7 @@
|
|||||||
|
|
||||||
if (chunk == null) {
|
if (chunk == null) {
|
||||||
chunk = this.loadChunk(i, j);
|
chunk = this.loadChunk(i, j);
|
||||||
@@ -79,16 +144,49 @@
|
@@ -79,16 +144,44 @@
|
||||||
CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Chunk to be generated");
|
CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Chunk to be generated");
|
||||||
|
|
||||||
crashreportsystemdetails.a("Location", (Object) String.format("%d,%d", new Object[] { Integer.valueOf(i), Integer.valueOf(j)}));
|
crashreportsystemdetails.a("Location", (Object) String.format("%d,%d", new Object[] { Integer.valueOf(i), Integer.valueOf(j)}));
|
||||||
@ -155,11 +155,6 @@
|
|||||||
- this.chunkList.add(chunk);
|
- this.chunkList.add(chunk);
|
||||||
+ this.chunks.put(LongHash.toLong(i, j), chunk);
|
+ this.chunks.put(LongHash.toLong(i, j), chunk);
|
||||||
+
|
+
|
||||||
+ // CraftBukkit start - moved from Chunk.<init>
|
|
||||||
+ for (int k = 0; k < chunk.entitySlices.length; ++k) {
|
|
||||||
+ chunk.entitySlices[k] = new EntitySlice(Entity.class);
|
|
||||||
+ }
|
|
||||||
+ // CraftBukkit end
|
|
||||||
chunk.addEntities();
|
chunk.addEntities();
|
||||||
+
|
+
|
||||||
+ // CraftBukkit start
|
+ // CraftBukkit start
|
||||||
@ -191,7 +186,7 @@
|
|||||||
chunk.loadNearby(this, this, i, j);
|
chunk.loadNearby(this, this, i, j);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -96,12 +194,25 @@
|
@@ -96,12 +189,25 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public Chunk getOrCreateChunk(int i, int j) {
|
public Chunk getOrCreateChunk(int i, int j) {
|
||||||
@ -220,7 +215,7 @@
|
|||||||
if (this.chunkLoader == null) {
|
if (this.chunkLoader == null) {
|
||||||
return null;
|
return null;
|
||||||
} else {
|
} else {
|
||||||
@@ -123,7 +234,7 @@
|
@@ -123,7 +229,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,7 +224,7 @@
|
|||||||
if (this.chunkLoader != null) {
|
if (this.chunkLoader != null) {
|
||||||
try {
|
try {
|
||||||
this.chunkLoader.b(this.world, chunk);
|
this.chunkLoader.b(this.world, chunk);
|
||||||
@@ -134,7 +245,7 @@
|
@@ -134,7 +240,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -238,7 +233,7 @@
|
|||||||
if (this.chunkLoader != null) {
|
if (this.chunkLoader != null) {
|
||||||
try {
|
try {
|
||||||
chunk.setLastSaved(this.world.getTime());
|
chunk.setLastSaved(this.world.getTime());
|
||||||
@@ -155,6 +266,30 @@
|
@@ -155,6 +261,30 @@
|
||||||
chunk.n();
|
chunk.n();
|
||||||
if (this.chunkProvider != null) {
|
if (this.chunkProvider != null) {
|
||||||
this.chunkProvider.getChunkAt(ichunkprovider, i, j);
|
this.chunkProvider.getChunkAt(ichunkprovider, i, j);
|
||||||
@ -269,7 +264,7 @@
|
|||||||
chunk.e();
|
chunk.e();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -174,10 +309,12 @@
|
@@ -174,10 +304,12 @@
|
||||||
|
|
||||||
public boolean saveChunks(boolean flag, IProgressUpdate iprogressupdate) {
|
public boolean saveChunks(boolean flag, IProgressUpdate iprogressupdate) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
@ -285,7 +280,7 @@
|
|||||||
|
|
||||||
if (flag) {
|
if (flag) {
|
||||||
this.saveChunkNOP(chunk);
|
this.saveChunkNOP(chunk);
|
||||||
@@ -205,22 +342,43 @@
|
@@ -205,22 +337,43 @@
|
||||||
|
|
||||||
public boolean unloadChunks() {
|
public boolean unloadChunks() {
|
||||||
if (!this.world.savingDisabled) {
|
if (!this.world.savingDisabled) {
|
||||||
@ -336,7 +331,7 @@
|
|||||||
|
|
||||||
if (this.chunkLoader != null) {
|
if (this.chunkLoader != null) {
|
||||||
this.chunkLoader.a();
|
this.chunkLoader.a();
|
||||||
@@ -235,7 +393,8 @@
|
@@ -235,7 +388,8 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
@ -346,7 +341,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
public List<BiomeBase.BiomeMeta> getMobsFor(EnumCreatureType enumcreaturetype, BlockPosition blockposition) {
|
public List<BiomeBase.BiomeMeta> getMobsFor(EnumCreatureType enumcreaturetype, BlockPosition blockposition) {
|
||||||
@@ -247,7 +406,8 @@
|
@@ -247,7 +401,8 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getLoadedChunks() {
|
public int getLoadedChunks() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
--- /home/matt/mc-dev-private//net/minecraft/server/ChunkRegionLoader.java 2015-03-16 19:44:31.166833062 +0000
|
--- /home/matt/mc-dev-private//net/minecraft/server/ChunkRegionLoader.java 2015-03-22 19:01:20.065879491 +0000
|
||||||
+++ src/main/java/net/minecraft/server/ChunkRegionLoader.java 2015-03-16 19:44:31.166833062 +0000
|
+++ src/main/java/net/minecraft/server/ChunkRegionLoader.java 2015-03-22 19:01:20.065879491 +0000
|
||||||
@@ -25,7 +25,39 @@
|
@@ -25,7 +25,39 @@
|
||||||
this.e = file;
|
this.e = file;
|
||||||
}
|
}
|
||||||
@ -107,7 +107,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
chunksection.a(achar);
|
chunksection.a(achar);
|
||||||
@@ -326,6 +395,17 @@
|
@@ -326,6 +395,13 @@
|
||||||
chunk.a(nbttagcompound.getByteArray("Biomes"));
|
chunk.a(nbttagcompound.getByteArray("Biomes"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -116,16 +116,12 @@
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public void loadEntities(Chunk chunk, NBTTagCompound nbttagcompound, World world) {
|
+ public void loadEntities(Chunk chunk, NBTTagCompound nbttagcompound, World world) {
|
||||||
+ // moved from Chunk.<init>
|
|
||||||
+ for (int k = 0; k < chunk.entitySlices.length; ++k) {
|
|
||||||
+ chunk.entitySlices[k] = new EntitySlice(Entity.class);
|
|
||||||
+ }
|
|
||||||
+ // CraftBukkit end
|
+ // CraftBukkit end
|
||||||
+
|
+
|
||||||
NBTTagList nbttaglist1 = nbttagcompound.getList("Entities", 10);
|
NBTTagList nbttaglist1 = nbttagcompound.getList("Entities", 10);
|
||||||
|
|
||||||
if (nbttaglist1 != null) {
|
if (nbttaglist1 != null) {
|
||||||
@@ -384,7 +464,7 @@
|
@@ -384,7 +460,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -261,10 +261,6 @@ public class CraftWorld implements World {
|
|||||||
|
|
||||||
private void chunkLoadPostProcess(net.minecraft.server.Chunk chunk, int cx, int cz) {
|
private void chunkLoadPostProcess(net.minecraft.server.Chunk chunk, int cx, int cz) {
|
||||||
if (chunk != null) {
|
if (chunk != null) {
|
||||||
// moved from Chunk.<init>
|
|
||||||
for (int k = 0; k < chunk.entitySlices.length; ++k) {
|
|
||||||
chunk.entitySlices[k] = new EntitySlice(net.minecraft.server.Entity.class);
|
|
||||||
}
|
|
||||||
world.chunkProviderServer.chunks.put(LongHash.toLong(cx, cz), chunk);
|
world.chunkProviderServer.chunks.put(LongHash.toLong(cx, cz), chunk);
|
||||||
|
|
||||||
chunk.addEntities();
|
chunk.addEntities();
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren