2020-07-17 18:05:50 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2020-06-27 19:00:18 +02:00
|
|
|
From: tr7zw <tr7zw@live.de>
|
|
|
|
Date: Mon, 11 May 2020 21:00:44 +0200
|
|
|
|
Subject: [PATCH] lithium MixinDirection
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/EnumDirection.java b/src/main/java/net/minecraft/server/EnumDirection.java
|
2020-07-17 18:05:50 +02:00
|
|
|
index 5a04654657fa47cfce0709ee75c5ff0dbe07ec8c..e60310a5358e23fdf3969f5a422d66280eb465a9 100644
|
2020-06-27 19:00:18 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/EnumDirection.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EnumDirection.java
|
|
|
|
@@ -20,13 +20,13 @@ public enum EnumDirection implements INamable {
|
|
|
|
DOWN(0, 1, -1, "down", EnumDirection.EnumAxisDirection.NEGATIVE, EnumDirection.EnumAxis.Y, new BaseBlockPosition(0, -1, 0)), UP(1, 0, -1, "up", EnumDirection.EnumAxisDirection.POSITIVE, EnumDirection.EnumAxis.Y, new BaseBlockPosition(0, 1, 0)), NORTH(2, 3, 2, "north", EnumDirection.EnumAxisDirection.NEGATIVE, EnumDirection.EnumAxis.Z, new BaseBlockPosition(0, 0, -1)), SOUTH(3, 2, 0, "south", EnumDirection.EnumAxisDirection.POSITIVE, EnumDirection.EnumAxis.Z, new BaseBlockPosition(0, 0, 1)), WEST(4, 5, 1, "west", EnumDirection.EnumAxisDirection.NEGATIVE, EnumDirection.EnumAxis.X, new BaseBlockPosition(-1, 0, 0)), EAST(5, 4, 3, "east", EnumDirection.EnumAxisDirection.POSITIVE, EnumDirection.EnumAxis.X, new BaseBlockPosition(1, 0, 0));
|
|
|
|
|
|
|
|
private final int g;
|
|
|
|
- private final int h;
|
|
|
|
+ private final int h; // YAPFA this is idOpposit(yarn)
|
|
|
|
private final int i;
|
|
|
|
private final String j;
|
|
|
|
private final EnumDirection.EnumAxis k;
|
|
|
|
private final EnumDirection.EnumAxisDirection l;
|
|
|
|
private final BaseBlockPosition m;
|
|
|
|
- private static final EnumDirection[] n = values();
|
|
|
|
+ private static final EnumDirection[] n = values(); private static final EnumDirection[] ALL = n;// YAPFA OBF HELPER
|
|
|
|
private static final Map<String, EnumDirection> o = (Map) Arrays.stream(EnumDirection.n).collect(Collectors.toMap(EnumDirection::m, (enumdirection) -> {
|
|
|
|
return enumdirection;
|
|
|
|
}));
|
|
|
|
@@ -98,8 +98,12 @@ public enum EnumDirection implements INamable {
|
|
|
|
return this.l;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * @reason Avoid the modulo/abs operations
|
|
|
|
+ * @author JellySquid
|
|
|
|
+ */
|
|
|
|
public EnumDirection opposite() {
|
|
|
|
- return fromType1(this.h);
|
|
|
|
+ return ALL[this.h];
|
|
|
|
}
|
|
|
|
|
|
|
|
public EnumDirection g() {
|
|
|
|
@@ -185,8 +189,12 @@ public enum EnumDirection implements INamable {
|
|
|
|
return (float) ((this.i & 3) * 90);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * @reason Do not allocate an excessive number of Direction arrays
|
|
|
|
+ * @author JellySquid
|
|
|
|
+ */
|
|
|
|
public static EnumDirection a(Random random) {
|
|
|
|
- return (EnumDirection) SystemUtils.a((Object[]) EnumDirection.n, random);
|
|
|
|
+ return ALL[random.nextInt(ALL.length)];
|
|
|
|
}
|
|
|
|
|
|
|
|
public static EnumDirection a(double d0, double d1, double d2) {
|