2022-06-02 01:35:57 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
|
|
|
|
Date: Sun, 6 Mar 2022 11:09:09 -0500
|
|
|
|
Subject: [PATCH] Prevent entity loading causing async lookups
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/Entity.java b/src/main/java/net/minecraft/world/entity/Entity.java
|
2024-06-13 15:45:43 +00:00
|
|
|
index 85fd7ad12e059f88bacf2d7c27715dcbd8fa3d4e..608bc43bd84f10d5610133b041aff8e3a32f178a 100644
|
2022-06-02 01:35:57 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
2024-05-26 19:51:15 +00:00
|
|
|
@@ -739,6 +739,7 @@ public abstract class Entity implements SyncedDataHolder, Nameable, EntityAccess
|
2022-06-02 01:35:57 +00:00
|
|
|
|
|
|
|
public void baseTick() {
|
2023-06-08 08:47:19 +00:00
|
|
|
this.level().getProfiler().push("entityBaseTick");
|
2024-01-18 17:52:00 +00:00
|
|
|
+ if (firstTick && this instanceof net.minecraft.world.entity.NeutralMob neutralMob) neutralMob.tickInitialPersistentAnger(level); // Paper - Prevent entity loading causing async lookups
|
2024-04-24 20:32:38 +00:00
|
|
|
this.inBlockState = null;
|
2022-06-02 01:35:57 +00:00
|
|
|
if (this.isPassenger() && this.getVehicle().isRemoved()) {
|
|
|
|
this.stopRiding();
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/NeutralMob.java b/src/main/java/net/minecraft/world/entity/NeutralMob.java
|
2024-05-11 21:48:37 +00:00
|
|
|
index 3b08905ddc3c2506779ce0eac1a53a4d89442ddc..b55633bf4e26dc00e27ab28c7739c274e48b74c3 100644
|
2022-06-02 01:35:57 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/NeutralMob.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/NeutralMob.java
|
2024-05-11 21:48:37 +00:00
|
|
|
@@ -45,24 +45,11 @@ public interface NeutralMob {
|
2022-06-02 01:35:57 +00:00
|
|
|
UUID uuid = nbt.getUUID("AngryAt");
|
|
|
|
|
|
|
|
this.setPersistentAngerTarget(uuid);
|
|
|
|
- Entity entity = ((ServerLevel) world).getEntity(uuid);
|
|
|
|
-
|
|
|
|
- if (entity != null) {
|
|
|
|
- if (entity instanceof Mob) {
|
2024-04-24 20:32:38 +00:00
|
|
|
- Mob entityinsentient = (Mob) entity;
|
|
|
|
-
|
2024-05-11 21:48:37 +00:00
|
|
|
- this.setTarget(entityinsentient, EntityTargetEvent.TargetReason.UNKNOWN, false); // CraftBukkit
|
2024-04-24 20:32:38 +00:00
|
|
|
- this.setLastHurtByMob(entityinsentient);
|
2022-06-02 01:35:57 +00:00
|
|
|
- }
|
|
|
|
-
|
2024-04-24 20:32:38 +00:00
|
|
|
- if (entity instanceof Player) {
|
|
|
|
- Player entityhuman = (Player) entity;
|
|
|
|
-
|
2024-05-11 21:48:37 +00:00
|
|
|
- this.setTarget(entityhuman, EntityTargetEvent.TargetReason.UNKNOWN, false); // CraftBukkit
|
2024-04-24 20:32:38 +00:00
|
|
|
- this.setLastHurtByPlayer(entityhuman);
|
2022-06-02 01:35:57 +00:00
|
|
|
- }
|
|
|
|
-
|
|
|
|
- }
|
2024-01-18 17:52:00 +00:00
|
|
|
+ // Paper - Prevent entity loading causing async lookups; Moved diff to separate method
|
2022-12-02 17:09:41 +00:00
|
|
|
+ // If this entity already survived its first tick, e.g. is loaded and ticked in sync, actively
|
|
|
|
+ // tick the initial persistent anger.
|
|
|
|
+ // If not, let the first tick on the baseTick call the method later down the line.
|
|
|
|
+ if (this instanceof Entity entity && !entity.firstTick) this.tickInitialPersistentAnger(world);
|
2022-06-02 01:35:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-05-11 21:48:37 +00:00
|
|
|
@@ -136,4 +123,28 @@ public interface NeutralMob {
|
2022-06-02 01:35:57 +00:00
|
|
|
|
|
|
|
@Nullable
|
|
|
|
LivingEntity getTarget();
|
|
|
|
+
|
2024-01-18 17:52:00 +00:00
|
|
|
+ // Paper start - Prevent entity loading causing async lookups
|
|
|
|
+ // Update last hurt when ticking
|
2022-06-02 01:35:57 +00:00
|
|
|
+ default void tickInitialPersistentAnger(Level level) {
|
|
|
|
+ UUID target = getPersistentAngerTarget();
|
|
|
|
+ if (target == null) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ Entity entity = ((ServerLevel) level).getEntity(target);
|
|
|
|
+
|
|
|
|
+ if (entity != null) {
|
2024-04-24 20:32:38 +00:00
|
|
|
+ if (entity instanceof Mob mob) {
|
2024-05-11 21:48:37 +00:00
|
|
|
+ this.setTarget(mob, EntityTargetEvent.TargetReason.UNKNOWN, false); // CraftBukkit
|
2024-04-24 20:32:38 +00:00
|
|
|
+ this.setLastHurtByMob(mob);
|
2022-06-02 01:35:57 +00:00
|
|
|
+ }
|
|
|
|
+
|
2024-04-24 20:32:38 +00:00
|
|
|
+ if (entity instanceof Player player) {
|
2024-05-11 21:48:37 +00:00
|
|
|
+ this.setTarget(player, EntityTargetEvent.TargetReason.UNKNOWN, false); // CraftBukkit
|
2024-04-24 20:32:38 +00:00
|
|
|
+ this.setLastHurtByPlayer(player);
|
2022-06-02 01:35:57 +00:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
2024-01-18 17:52:00 +00:00
|
|
|
+ // Paper end - Prevent entity loading causing async lookups
|
2022-06-02 01:35:57 +00:00
|
|
|
}
|