Mirror von
https://github.com/PaperMC/Paper.git
synchronisiert 2025-01-10 07:10:06 +01:00
da9d110d5b
This patch does not appear to be doing anything useful, and may hide errors. Currently, the save logic does not run through this path either so it did not do anything. Additionally, properly implement support for handling RegionFileSizeException in Moonrise.
95 Zeilen
3.8 KiB
Diff
95 Zeilen
3.8 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Nassim Jahnke <nassim@njahnke.dev>
|
|
Date: Sat, 9 Nov 2024 21:10:45 +0100
|
|
Subject: [PATCH] Improve CraftEntity and CraftPlayer equals and hashCode
|
|
|
|
Make sure the hash code does not change and also remove outdated
|
|
equals logic from CraftPlayer. Long-term, the override there should
|
|
be entirely removed, but this is good enough for now.
|
|
|
|
Replacing some getHandle method calls with direct field access will
|
|
also reduce overhead from casts that the overridden methods come with,
|
|
at least until those are changed later on as well.
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
|
|
index 0480fbeffd19011d3cd63021225f376c464b480c..d6241e2db362de034ae610694c49c1883ffabd07 100644
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
|
|
@@ -437,7 +437,7 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity {
|
|
|
|
@Override
|
|
public UUID getUniqueId() {
|
|
- return this.getHandle().getUUID();
|
|
+ return this.entity.getUUID();
|
|
}
|
|
|
|
@Override
|
|
@@ -496,21 +496,17 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity {
|
|
|
|
@Override
|
|
public boolean equals(Object obj) {
|
|
- if (obj == null) {
|
|
- return false;
|
|
- }
|
|
- if (this.getClass() != obj.getClass()) {
|
|
- return false;
|
|
- }
|
|
+ if (this == obj) return true;
|
|
+ if (obj == null || getClass() != obj.getClass()) return false;
|
|
+
|
|
final CraftEntity other = (CraftEntity) obj;
|
|
- return (this.getEntityId() == other.getEntityId());
|
|
+ return this.entity == other.entity; // There should never be duplicate entities with differing references
|
|
}
|
|
|
|
@Override
|
|
public int hashCode() {
|
|
- int hash = 7;
|
|
- hash = 29 * hash + this.getEntityId();
|
|
- return hash;
|
|
+ // The UUID and thus hash code should never change (unlike the entity id)
|
|
+ return this.getUniqueId().hashCode();
|
|
}
|
|
|
|
@Override
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
index a4333eae8aa2ae3fefdc8a765a4434c36e123b12..48fce5964c49f30f705d11bbbabae49ad9a606c7 100644
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
@@ -626,22 +626,10 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
|
|
|
@Override
|
|
public boolean equals(Object obj) {
|
|
- if (!(obj instanceof OfflinePlayer)) {
|
|
- return false;
|
|
- }
|
|
- OfflinePlayer other = (OfflinePlayer) obj;
|
|
- if ((this.getUniqueId() == null) || (other.getUniqueId() == null)) {
|
|
- return false;
|
|
- }
|
|
-
|
|
- boolean uuidEquals = this.getUniqueId().equals(other.getUniqueId());
|
|
- boolean idEquals = true;
|
|
-
|
|
- if (other instanceof CraftPlayer) {
|
|
- idEquals = this.getEntityId() == ((CraftPlayer) other).getEntityId();
|
|
- }
|
|
-
|
|
- return uuidEquals && idEquals;
|
|
+ // Long-term, this should just use the super equals... for now, check the UUID
|
|
+ if (obj == this) return true;
|
|
+ if (!(obj instanceof OfflinePlayer other)) return false;
|
|
+ return this.getUniqueId().equals(other.getUniqueId());
|
|
}
|
|
|
|
@Override
|
|
@@ -2052,7 +2040,7 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
|
@Override
|
|
public int hashCode() {
|
|
if (this.hash == 0 || this.hash == 485) {
|
|
- this.hash = 97 * 5 + (this.getUniqueId() != null ? this.getUniqueId().hashCode() : 0);
|
|
+ this.hash = 97 * 5 + this.getUniqueId().hashCode();
|
|
}
|
|
return this.hash;
|
|
}
|