papermc/patches/unapplied/server/0590-Inline-shift-direction-fields.patch

56 lines
2 KiB
Diff
Raw Normal View History

2021-06-11 12:02:28 +00:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Andrew Steinborn <git@steinborn.me>
Date: Mon, 18 Jan 2021 20:45:25 -0500
Subject: [PATCH] Inline shift direction fields
Removes a layer of indirection for EnumDirection.getAdjacent(X|Y|Z)(), which is in the
critical section for much of the server, including the lighting engine.
diff --git a/src/main/java/net/minecraft/core/Direction.java b/src/main/java/net/minecraft/core/Direction.java
2022-06-03 04:26:56 +00:00
index 4eddfa6a07f9d42b5ecf9eb92cd609559b9b6b56..6b71d9433846eb4464177f09d7bfdea82200b189 100644
2021-06-11 12:02:28 +00:00
--- a/src/main/java/net/minecraft/core/Direction.java
+++ b/src/main/java/net/minecraft/core/Direction.java
2021-11-24 19:33:17 +00:00
@@ -64,6 +64,11 @@ public enum Direction implements StringRepresentable {
2021-06-15 02:59:31 +00:00
}, (direction1, direction2) -> {
2021-06-11 12:02:28 +00:00
throw new IllegalArgumentException("Duplicate keys");
}, Long2ObjectOpenHashMap::new));
+ // Paper start
+ private final int adjX;
+ private final int adjY;
+ private final int adjZ;
+ // Paper end
2021-06-15 02:59:31 +00:00
private Direction(int id, int idOpposite, int idHorizontal, String name, Direction.AxisDirection direction, Direction.Axis axis, Vec3i vector) {
this.data3d = id;
2021-11-24 19:33:17 +00:00
@@ -73,6 +78,11 @@ public enum Direction implements StringRepresentable {
2021-06-15 02:59:31 +00:00
this.axis = axis;
this.axisDirection = direction;
this.normal = vector;
2021-06-11 12:02:28 +00:00
+ // Paper start
2021-06-15 02:59:31 +00:00
+ this.adjX = vector.getX();
+ this.adjY = vector.getY();
+ this.adjZ = vector.getZ();
2021-06-11 12:02:28 +00:00
+ // Paper end
}
public static Direction[] orderedByNearest(Entity entity) {
2021-11-24 19:33:17 +00:00
@@ -357,15 +367,15 @@ public enum Direction implements StringRepresentable {
2021-06-11 12:02:28 +00:00
}
public int getStepX() {
- return this.normal.getX();
+ return this.adjX; // Paper
}
public int getStepY() {
- return this.normal.getY();
+ return this.adjY; // Paper
}
public int getStepZ() {
- return this.normal.getZ();
+ return this.adjZ; // Paper
}
2021-06-15 02:59:31 +00:00
public Vector3f step() {