2018-09-29 07:31:59 +08:00
|
|
|
From 454a4b007f6acbd522312c5dec9cc03b81ed396c Mon Sep 17 00:00:00 2001
|
2016-08-19 08:53:36 +08:00
|
|
|
From: Alfie Cleveland <alfeh@me.com>
|
|
|
|
Date: Fri, 19 Aug 2016 01:52:56 +0100
|
2016-09-01 06:18:54 +08:00
|
|
|
Subject: [PATCH] Optimise BlockStateEnum hashCode and equals
|
2016-08-19 08:53:36 +08:00
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/BlockStateEnum.java b/src/main/java/net/minecraft/server/BlockStateEnum.java
|
2018-09-01 06:56:57 +08:00
|
|
|
index 73623a21c5..9d8a03be8d 100644
|
2016-08-19 08:53:36 +08:00
|
|
|
--- a/src/main/java/net/minecraft/server/BlockStateEnum.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/BlockStateEnum.java
|
2018-09-01 06:56:57 +08:00
|
|
|
@@ -8,6 +8,7 @@ import java.util.Arrays;
|
|
|
|
import java.util.Collection;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.Optional;
|
|
|
|
+import java.util.concurrent.atomic.AtomicInteger;
|
|
|
|
import java.util.function.Predicate;
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
@@ -15,11 +16,17 @@ public class BlockStateEnum<T extends Enum<T> & INamable> extends BlockState<T>
|
2016-08-19 08:53:36 +08:00
|
|
|
private final ImmutableSet<T> a;
|
|
|
|
private final Map<String, T> b = Maps.newHashMap();
|
|
|
|
|
|
|
|
+ // Paper start - BlockStateEnum is a singleton, so we can use our own hashCode
|
2018-09-01 06:56:57 +08:00
|
|
|
+ private static AtomicInteger hashId = new AtomicInteger(1);
|
2016-08-19 08:53:36 +08:00
|
|
|
+ private int hashCode;
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
protected BlockStateEnum(String s, Class<T> oclass, Collection<T> collection) {
|
|
|
|
super(s, oclass);
|
|
|
|
this.a = ImmutableSet.copyOf(collection);
|
|
|
|
|
2018-09-01 06:56:57 +08:00
|
|
|
- for(Enum oenum : collection) {
|
|
|
|
+ this.hashCode = hashId.getAndIncrement() * 61; // Paper
|
|
|
|
+ for(T oenum : collection) { // Paper - decompile fix
|
|
|
|
String s1 = ((INamable)oenum).getName();
|
|
|
|
if (this.b.containsKey(s1)) {
|
|
|
|
throw new IllegalArgumentException("Multiple values have the same name '" + s1 + "'");
|
|
|
|
@@ -42,22 +49,14 @@ public class BlockStateEnum<T extends Enum<T> & INamable> extends BlockState<T>
|
|
|
|
return ((INamable)oenum).getName();
|
2016-08-19 08:53:36 +08:00
|
|
|
}
|
|
|
|
|
2018-07-17 04:08:09 +08:00
|
|
|
+ @Override // Paper start - override equals as BlockStateEnum is a singleton
|
2016-08-19 08:53:36 +08:00
|
|
|
public boolean equals(Object object) {
|
|
|
|
- if (this == object) {
|
|
|
|
- return true;
|
|
|
|
- } else if (object instanceof BlockStateEnum && super.equals(object)) {
|
2018-09-01 06:56:57 +08:00
|
|
|
- BlockStateEnum blockstateenum1 = (BlockStateEnum)object;
|
|
|
|
- return this.a.equals(blockstateenum1.a) && this.b.equals(blockstateenum1.b);
|
2016-08-19 08:53:36 +08:00
|
|
|
- } else {
|
|
|
|
- return false;
|
|
|
|
- }
|
|
|
|
+ return this == object;
|
2018-07-17 04:08:09 +08:00
|
|
|
+ // Paper end - override equals as BlockStateEnum is a singleton
|
2016-08-19 08:53:36 +08:00
|
|
|
}
|
|
|
|
|
2018-07-17 04:08:09 +08:00
|
|
|
public int c() {
|
|
|
|
- int i = super.c();
|
|
|
|
- i = 31 * i + this.a.hashCode();
|
|
|
|
- i = 31 * i + this.b.hashCode();
|
|
|
|
- return i;
|
|
|
|
+ return hashCode; // Paper - hashCode method is final, but we can do this here
|
2016-08-19 08:53:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public static <T extends Enum<T> & INamable> BlockStateEnum<T> of(String s, Class<T> oclass) {
|
|
|
|
--
|
2018-09-29 07:31:59 +08:00
|
|
|
2.19.0
|
2016-08-19 08:53:36 +08:00
|
|
|
|