mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-03 23:07:40 +01:00
Optimize some methods for inlining
Adds final to some methods to improve inlining ability
This commit is contained in:
parent
7968c4f5c9
commit
0aa0eba111
@ -10,15 +10,21 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
--- a/src/main/java/net/minecraft/server/World.java
|
--- a/src/main/java/net/minecraft/server/World.java
|
||||||
+++ b/src/main/java/net/minecraft/server/World.java
|
+++ b/src/main/java/net/minecraft/server/World.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- public Fluid getFluidIfLoaded(BlockPosition blockposition) {
|
||||||
|
+ public final Fluid getFluidIfLoaded(BlockPosition blockposition) {
|
||||||
|
IChunkAccess chunk = this.getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4);
|
||||||
|
|
||||||
return chunk == null ? null : chunk.getFluid(blockposition);
|
return chunk == null ? null : chunk.getFluid(blockposition);
|
||||||
}
|
}
|
||||||
+
|
+
|
||||||
+ public boolean isLoadedAndInBounds(BlockPosition blockposition) {
|
+ public final boolean isLoadedAndInBounds(BlockPosition blockposition) { // Paper - final for inline
|
||||||
+ return getWorldBorder().isInBounds(blockposition) && getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null;
|
+ return getWorldBorder().isInBounds(blockposition) && getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public Chunk getChunkIfLoaded(int x, int z) {
|
+ public Chunk getChunkIfLoaded(int x, int z) { // Overridden in WorldServer for ABI compat which has final
|
||||||
+ return ((WorldServer) this).getChunkProvider().getChunkAtIfLoadedImmediately(x, z);
|
+ return ((WorldServer) this).getChunkProvider().getChunkAtIfLoadedImmediately(x, z);
|
||||||
+ }
|
+ }
|
||||||
+ public final Chunk getChunkIfLoaded(BlockPosition blockposition) {
|
+ public final Chunk getChunkIfLoaded(BlockPosition blockposition) {
|
||||||
@ -26,7 +32,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ // reduces need to do isLoaded before getType
|
+ // reduces need to do isLoaded before getType
|
||||||
+ public IBlockData getTypeIfLoadedAndInBounds(BlockPosition blockposition) {
|
+ public final IBlockData getTypeIfLoadedAndInBounds(BlockPosition blockposition) {
|
||||||
+ return getWorldBorder().isInBounds(blockposition) ? getTypeIfLoaded(blockposition) : null;
|
+ return getWorldBorder().isInBounds(blockposition) ? getTypeIfLoaded(blockposition) : null;
|
||||||
+ }
|
+ }
|
||||||
// Paper end
|
// Paper end
|
||||||
|
@ -4000,14 +4000,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ // Paper end
|
+ // Paper end
|
||||||
+
|
+
|
||||||
// CraftBukkit start
|
// CraftBukkit start
|
||||||
public Chunk getFullChunk() {
|
- public Chunk getFullChunk() {
|
||||||
|
+ public final Chunk getFullChunk() { // Paper - final for inline
|
||||||
if (!getChunkState(this.oldTicketLevel).isAtLeast(PlayerChunk.State.BORDER)) return null; // note: using oldTicketLevel for isLoaded checks
|
if (!getChunkState(this.oldTicketLevel).isAtLeast(PlayerChunk.State.BORDER)) return null; // note: using oldTicketLevel for isLoaded checks
|
||||||
@@ -0,0 +0,0 @@ public class PlayerChunk {
|
CompletableFuture<Either<IChunkAccess, PlayerChunk.Failure>> statusFuture = this.getStatusFutureUnchecked(ChunkStatus.FULL);
|
||||||
|
Either<IChunkAccess, PlayerChunk.Failure> either = (Either<IChunkAccess, PlayerChunk.Failure>) statusFuture.getNow(null);
|
||||||
return either == null ? null : (Chunk) either.left().orElse(null);
|
return either == null ? null : (Chunk) either.left().orElse(null);
|
||||||
}
|
}
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
+ // Paper start - "real" get full chunk immediately
|
+ // Paper start - "real" get full chunk immediately
|
||||||
+ public Chunk getFullChunkIfCached() {
|
+ public final Chunk getFullChunkIfCached() {
|
||||||
+ // Note: Copied from above without ticket level check
|
+ // Note: Copied from above without ticket level check
|
||||||
+ CompletableFuture<Either<IChunkAccess, PlayerChunk.Failure>> statusFuture = this.getStatusFutureUnchecked(ChunkStatus.FULL);
|
+ CompletableFuture<Either<IChunkAccess, PlayerChunk.Failure>> statusFuture = this.getStatusFutureUnchecked(ChunkStatus.FULL);
|
||||||
+ Either<IChunkAccess, PlayerChunk.Failure> either = (Either<IChunkAccess, PlayerChunk.Failure>) statusFuture.getNow(null);
|
+ Either<IChunkAccess, PlayerChunk.Failure> either = (Either<IChunkAccess, PlayerChunk.Failure>) statusFuture.getNow(null);
|
||||||
@ -4021,20 +4023,53 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
return getChunkStatus(this.ticketLevel).b(chunkstatus) ? this.getStatusFutureUnchecked(chunkstatus) : PlayerChunk.UNLOADED_CHUNK_ACCESS_FUTURE;
|
return getChunkStatus(this.ticketLevel).b(chunkstatus) ? this.getStatusFutureUnchecked(chunkstatus) : PlayerChunk.UNLOADED_CHUNK_ACCESS_FUTURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- public CompletableFuture<Either<Chunk, PlayerChunk.Failure>> a() {
|
||||||
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> getTickingFuture() { return this.a(); } // Paper - OBFHELPER
|
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> getTickingFuture() { return this.a(); } // Paper - OBFHELPER
|
||||||
public CompletableFuture<Either<Chunk, PlayerChunk.Failure>> a() {
|
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> a() { // Paper - final for inline
|
||||||
return this.tickingFuture;
|
return this.tickingFuture;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- public CompletableFuture<Either<Chunk, PlayerChunk.Failure>> b() {
|
||||||
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> getEntityTickingFuture() { return this.b(); } // Paper - OBFHELPER
|
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> getEntityTickingFuture() { return this.b(); } // Paper - OBFHELPER
|
||||||
public CompletableFuture<Either<Chunk, PlayerChunk.Failure>> b() {
|
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> b() { // Paper - final for inline
|
||||||
return this.entityTickingFuture;
|
return this.entityTickingFuture;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- public CompletableFuture<Either<Chunk, PlayerChunk.Failure>> c() {
|
||||||
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> getFullChunkFuture() { return this.c(); } // Paper - OBFHELPER
|
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> getFullChunkFuture() { return this.c(); } // Paper - OBFHELPER
|
||||||
public CompletableFuture<Either<Chunk, PlayerChunk.Failure>> c() {
|
+ public final CompletableFuture<Either<Chunk, PlayerChunk.Failure>> c() { // Paper - final for inline
|
||||||
return this.fullChunkFuture;
|
return this.fullChunkFuture;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
- public Chunk getChunk() {
|
||||||
|
+ public final Chunk getChunk() { // Paper - final for inline
|
||||||
|
CompletableFuture<Either<Chunk, PlayerChunk.Failure>> completablefuture = this.a();
|
||||||
|
Either<Chunk, PlayerChunk.Failure> either = (Either) completablefuture.getNow(null); // CraftBukkit - decompile error
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class PlayerChunk {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
- public CompletableFuture<IChunkAccess> getChunkSave() {
|
||||||
|
+ public final CompletableFuture<IChunkAccess> getChunkSave() { // Paper - final for inline
|
||||||
|
return this.chunkSave;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class PlayerChunk {
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
- public ChunkCoordIntPair i() {
|
||||||
|
+ public final ChunkCoordIntPair i() { // Paper - final for inline
|
||||||
|
return this.location;
|
||||||
|
}
|
||||||
|
|
||||||
|
- public int getTicketLevel() {
|
||||||
|
+ public final int getTicketLevel() { // Paper - final for inline
|
||||||
|
return this.ticketLevel;
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class PlayerChunk {
|
@@ -0,0 +0,0 @@ public class PlayerChunk {
|
||||||
|
|
||||||
this.hasBeenLoaded |= flag3;
|
this.hasBeenLoaded |= flag3;
|
||||||
@ -4373,18 +4408,31 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
this.world = new CraftWorld((WorldServer) this, gen, env);
|
this.world = new CraftWorld((WorldServer) this, gen, env);
|
||||||
this.ticksPerAnimalSpawns = this.getServer().getTicksPerAnimalSpawns(); // CraftBukkit
|
this.ticksPerAnimalSpawns = this.getServer().getTicksPerAnimalSpawns(); // CraftBukkit
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
||||||
return (Chunk) this.getChunkAt(i, j, ChunkStatus.FULL);
|
return i < 0 || i >= 256;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- public Chunk getChunkAtWorldCoords(BlockPosition blockposition) {
|
||||||
|
+ public final Chunk getChunkAtWorldCoords(BlockPosition blockposition) { // Paper - help inline
|
||||||
|
return this.getChunkAt(blockposition.getX() >> 4, blockposition.getZ() >> 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- public Chunk getChunkAt(int i, int j) {
|
||||||
|
- return (Chunk) this.getChunkAt(i, j, ChunkStatus.FULL);
|
||||||
|
+ public final Chunk getChunkAt(int i, int j) { // Paper - final to help inline
|
||||||
|
+ return (Chunk) this.getChunkAt(i, j, ChunkStatus.FULL, true); // Paper - avoid a method jump
|
||||||
|
+ }
|
||||||
|
+
|
||||||
+ // Paper start - if loaded
|
+ // Paper start - if loaded
|
||||||
+ @Nullable
|
+ @Nullable
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public IChunkAccess getChunkIfLoadedImmediately(int x, int z) {
|
+ public final IChunkAccess getChunkIfLoadedImmediately(int x, int z) {
|
||||||
+ return ((WorldServer)this).chunkProvider.getChunkAtIfLoadedImmediately(x, z);
|
+ return ((WorldServer)this).chunkProvider.getChunkAtIfLoadedImmediately(x, z);
|
||||||
+ }
|
}
|
||||||
+
|
|
||||||
+ @Override
|
@Override
|
||||||
+ public IBlockData getTypeIfLoaded(BlockPosition blockposition) {
|
- public IChunkAccess getChunkAt(int i, int j, ChunkStatus chunkstatus, boolean flag) {
|
||||||
|
+ public final IBlockData getTypeIfLoaded(BlockPosition blockposition) {
|
||||||
+ // CraftBukkit start - tree generation
|
+ // CraftBukkit start - tree generation
|
||||||
+ if (captureTreeGeneration) {
|
+ if (captureTreeGeneration) {
|
||||||
+ CraftBlockState previous = capturedBlockStates.get(blockposition);
|
+ CraftBlockState previous = capturedBlockStates.get(blockposition);
|
||||||
@ -4409,9 +4457,20 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
+
|
+
|
||||||
@Override
|
+ @Override
|
||||||
public IChunkAccess getChunkAt(int i, int j, ChunkStatus chunkstatus, boolean flag) {
|
+ public final IChunkAccess getChunkAt(int i, int j, ChunkStatus chunkstatus, boolean flag) { // Paper - final for inline
|
||||||
IChunkAccess ichunkaccess = this.getChunkProvider().getChunkAt(i, j, chunkstatus, flag);
|
IChunkAccess ichunkaccess = this.getChunkProvider().getChunkAt(i, j, chunkstatus, flag);
|
||||||
|
|
||||||
|
if (ichunkaccess == null && flag) {
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- public boolean setTypeAndData(BlockPosition blockposition, IBlockData iblockdata, int i) {
|
||||||
|
+ public final boolean setTypeAndData(BlockPosition blockposition, IBlockData iblockdata, int i) { // Paper - final for inline
|
||||||
|
return this.a(blockposition, iblockdata, i, 512);
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
||||||
|
|
||||||
public void a(BlockPosition blockposition, IBlockData iblockdata, IBlockData iblockdata1) {}
|
public void a(BlockPosition blockposition, IBlockData iblockdata, IBlockData iblockdata1) {}
|
||||||
|
@ -64,22 +64,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/World.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/World.java
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, AutoCloseable {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Chunk getChunkAt(int i, int j) {
|
|
||||||
+ // Paper start - optimise this for loaded chunks
|
|
||||||
+ if (Thread.currentThread() == this.serverThread) {
|
|
||||||
+ Chunk ifLoaded = ((WorldServer) this).getChunkProvider().getChunkAtIfLoadedMainThread(i, j);
|
|
||||||
+ if (ifLoaded != null) {
|
|
||||||
+ return ifLoaded;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
return (Chunk) this.getChunkAt(i, j, ChunkStatus.FULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@ -13,11 +13,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
return chunk == null ? null : chunk.getFluid(blockposition);
|
return chunk == null ? null : chunk.getFluid(blockposition);
|
||||||
}
|
}
|
||||||
|
|
||||||
+ public boolean isLoaded(BlockPosition blockposition) {
|
+ public final boolean isLoaded(BlockPosition blockposition) {
|
||||||
+ return getChunkIfLoaded(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null; // Paper
|
+ return getChunkIfLoaded(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null; // Paper
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+
|
public final boolean isLoadedAndInBounds(BlockPosition blockposition) { // Paper - final for inline
|
||||||
public boolean isLoadedAndInBounds(BlockPosition blockposition) {
|
|
||||||
return getWorldBorder().isInBounds(blockposition) && getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null;
|
return getWorldBorder().isInBounds(blockposition) && getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user