mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-29 12:27:59 +01:00
Prevent entity loading causing async lookups (#7553)
This commit is contained in:
parent
d6784f22c1
commit
68ef4d7878
@ -0,0 +1,69 @@
|
|||||||
|
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
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
||||||
|
|
||||||
|
public void baseTick() {
|
||||||
|
this.level.getProfiler().push("entityBaseTick");
|
||||||
|
+ if (firstTick && this instanceof net.minecraft.world.entity.NeutralMob neutralMob) neutralMob.tickInitialPersistentAnger(level); // Paper - Update last hurt when ticking
|
||||||
|
this.feetBlockState = null;
|
||||||
|
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
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/NeutralMob.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/NeutralMob.java
|
||||||
|
@@ -0,0 +0,0 @@ public interface NeutralMob {
|
||||||
|
UUID uuid = nbt.getUUID("AngryAt");
|
||||||
|
|
||||||
|
this.setPersistentAngerTarget(uuid);
|
||||||
|
- Entity entity = ((ServerLevel) world).getEntity(uuid);
|
||||||
|
-
|
||||||
|
- if (entity != null) {
|
||||||
|
- if (entity instanceof Mob) {
|
||||||
|
- this.setLastHurtByMob((Mob) entity);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if (entity.getType() == EntityType.PLAYER) {
|
||||||
|
- this.setLastHurtByPlayer((Player) entity);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- }
|
||||||
|
+ // Paper - Moved diff to separate method
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ public interface NeutralMob {
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
LivingEntity getTarget();
|
||||||
|
+
|
||||||
|
+ // Paper start - Update last hurt when ticking
|
||||||
|
+ default void tickInitialPersistentAnger(Level level) {
|
||||||
|
+ UUID target = getPersistentAngerTarget();
|
||||||
|
+ if (target == null) {
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ Entity entity = ((ServerLevel) level).getEntity(target);
|
||||||
|
+
|
||||||
|
+ if (entity != null) {
|
||||||
|
+ if (entity instanceof Mob) {
|
||||||
|
+ this.setLastHurtByMob((Mob) entity);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (entity.getType() == EntityType.PLAYER) {
|
||||||
|
+ this.setLastHurtByPlayer((Player) entity);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user