2016-06-23 04:43:02 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Thu, 3 Mar 2016 02:07:55 -0600
|
|
|
|
Subject: [PATCH] Optimize isValidLocation, getType and getBlockData for inling
|
|
|
|
|
|
|
|
Hot methods, so reduce # of instructions for the method.
|
|
|
|
|
|
|
|
Move is valid location test to the BlockPosition class so that it can access local variables.
|
|
|
|
|
|
|
|
Replace all calls to the new place to the unnecessary forward.
|
|
|
|
|
|
|
|
Optimize getType and getBlockData to manually inline and optimize the calls
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/BaseBlockPosition.java b/src/main/java/net/minecraft/server/BaseBlockPosition.java
|
2019-05-07 02:05:41 +02:00
|
|
|
index 2852a17f23..7cb46d7a9c 100644
|
2016-06-23 04:43:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/BaseBlockPosition.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/BaseBlockPosition.java
|
|
|
|
@@ -0,0 +0,0 @@ public class BaseBlockPosition implements Comparable<BaseBlockPosition> {
|
|
|
|
private final int a;
|
|
|
|
private final int b;
|
|
|
|
private final int c;
|
|
|
|
+ // Paper start
|
|
|
|
+ public boolean isValidLocation() {
|
|
|
|
+ return a >= -30000000 && c >= -30000000 && a < 30000000 && c < 30000000 && b >= 0 && b < 256;
|
|
|
|
+ }
|
|
|
|
+ public boolean isInvalidYLocation() {
|
|
|
|
+ return b < 0 || b >= 256;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
public BaseBlockPosition(int i, int j, int k) {
|
|
|
|
this.a = i;
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/BlockPosition.java b/src/main/java/net/minecraft/server/BlockPosition.java
|
2019-05-07 02:05:41 +02:00
|
|
|
index c927d524a8..64700b97c0 100644
|
2016-06-23 04:43:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/BlockPosition.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/BlockPosition.java
|
2019-04-27 05:05:36 +02:00
|
|
|
@@ -0,0 +0,0 @@ public class BlockPosition extends BaseBlockPosition implements MinecraftSeriali
|
2016-06-23 04:43:02 +02:00
|
|
|
protected int b;
|
|
|
|
protected int c;
|
|
|
|
protected int d;
|
|
|
|
+ // Paper start
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isValidLocation() {
|
|
|
|
+ return b >= -30000000 && d >= -30000000 && b < 30000000 && d < 30000000 && c >= 0 && c < 256;
|
|
|
|
+ }
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isInvalidYLocation() {
|
|
|
|
+ return c < 0 || c >= 256;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
public MutableBlockPosition() {
|
|
|
|
this(0, 0, 0);
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
2019-05-07 02:05:41 +02:00
|
|
|
index 2928f7d218..7a0ab24a91 100644
|
2016-06-23 04:43:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/Chunk.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
2018-07-15 03:53:17 +02:00
|
|
|
@@ -0,0 +0,0 @@ public class Chunk implements IChunkAccess {
|
2019-04-27 05:05:36 +02:00
|
|
|
return this.sections;
|
2016-06-23 04:43:02 +02:00
|
|
|
}
|
|
|
|
|
2019-04-27 05:05:36 +02:00
|
|
|
- @Override
|
2018-08-26 20:11:49 +02:00
|
|
|
- public IBlockData getType(BlockPosition blockposition) {
|
2019-04-27 05:05:36 +02:00
|
|
|
- int i = blockposition.getX();
|
|
|
|
- int j = blockposition.getY();
|
|
|
|
- int k = blockposition.getZ();
|
2016-06-23 04:43:02 +02:00
|
|
|
+ // Paper start - Optimize getBlockData to reduce instructions
|
2018-08-26 20:11:49 +02:00
|
|
|
+ public final IBlockData getBlockData(BlockPosition pos) { return getBlockData(pos.getX(), pos.getY(), pos.getZ()); } // Paper
|
|
|
|
+ public final IBlockData getType(BlockPosition blockposition) {
|
2019-04-27 05:05:36 +02:00
|
|
|
+ return this.getBlockData(blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
|
|
|
+ }
|
2018-07-15 03:53:17 +02:00
|
|
|
|
2016-06-23 04:43:02 +02:00
|
|
|
+ public final IBlockData getBlockData(final int x, final int y, final int z) {
|
|
|
|
+ // Method body / logic copied from below
|
|
|
|
+ final int i = y >> 4;
|
|
|
|
+ if (y >= 0 && i < this.sections.length && this.sections[i] != null) {
|
|
|
|
+ // Inlined ChunkSection.getType() and DataPaletteBlock.a(int,int,int)
|
|
|
|
+ return this.sections[i].blockIds.a((y & 15) << 8 | (z & 15) << 4 | x & 15);
|
|
|
|
+ }
|
|
|
|
+ return Blocks.AIR.getBlockData();
|
|
|
|
+ }
|
2017-05-14 20:05:01 +02:00
|
|
|
+
|
2018-07-15 03:53:17 +02:00
|
|
|
+ public IBlockData getBlockData_unused(int i, int j, int k) {
|
|
|
|
+ // Paper end
|
2019-04-27 05:05:36 +02:00
|
|
|
if (this.world.P() == WorldType.DEBUG_ALL_BLOCK_STATES) {
|
2016-06-23 04:43:02 +02:00
|
|
|
IBlockData iblockdata = null;
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkSection.java b/src/main/java/net/minecraft/server/ChunkSection.java
|
2019-05-07 02:05:41 +02:00
|
|
|
index 30701fd7f3..43f75fc837 100644
|
2016-06-23 04:43:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkSection.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkSection.java
|
|
|
|
@@ -0,0 +0,0 @@ public class ChunkSection {
|
2019-04-27 05:05:36 +02:00
|
|
|
private short nonEmptyBlockCount;
|
|
|
|
private short tickingBlockCount;
|
|
|
|
private short e;
|
2018-07-15 03:53:17 +02:00
|
|
|
- private final DataPaletteBlock<IBlockData> blockIds;
|
|
|
|
+ final DataPaletteBlock<IBlockData> blockIds; // Paper - package
|
2016-06-23 04:43:02 +02:00
|
|
|
|
2019-04-27 05:05:36 +02:00
|
|
|
public ChunkSection(int i) {
|
|
|
|
this(i, (short) 0, (short) 0, (short) 0);
|
2016-06-23 04:43:02 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
2019-05-07 02:05:41 +02:00
|
|
|
index e1cebacb83..31c38e1051 100644
|
2016-06-23 04:43:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/World.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/World.java
|
2019-04-27 05:05:36 +02:00
|
|
|
@@ -0,0 +0,0 @@ public abstract class World implements IIBlockAccess, GeneratorAccess, AutoClose
|
2016-06-23 04:43:02 +02:00
|
|
|
}
|
|
|
|
|
2018-07-15 03:53:17 +02:00
|
|
|
public static boolean isValidLocation(BlockPosition blockposition) {
|
2019-04-27 05:05:36 +02:00
|
|
|
- return !isInsideWorld(blockposition) && blockposition.getX() >= -30000000 && blockposition.getZ() >= -30000000 && blockposition.getX() < 30000000 && blockposition.getZ() < 30000000;
|
2016-06-23 04:43:02 +02:00
|
|
|
+ return blockposition.isValidLocation(); // Paper
|
|
|
|
}
|
|
|
|
|
2019-04-27 05:05:36 +02:00
|
|
|
public static boolean isInsideWorld(BlockPosition blockposition) {
|
|
|
|
- return b(blockposition.getY());
|
2016-06-23 04:43:02 +02:00
|
|
|
+ return blockposition.isInvalidYLocation(); // Paper
|
|
|
|
}
|
|
|
|
|
2019-04-27 05:05:36 +02:00
|
|
|
public static boolean b(int i) {
|
2016-06-23 04:43:02 +02:00
|
|
|
--
|