aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0913-Fix-missing-event-call-for-entity-teleport-API.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0913-Fix-missing-event-call-for-entity-teleport-API.patch')
-rw-r--r--patches/server/0913-Fix-missing-event-call-for-entity-teleport-API.patch28
1 files changed, 28 insertions, 0 deletions
diff --git a/patches/server/0913-Fix-missing-event-call-for-entity-teleport-API.patch b/patches/server/0913-Fix-missing-event-call-for-entity-teleport-API.patch
new file mode 100644
index 0000000000..79cebb8989
--- /dev/null
+++ b/patches/server/0913-Fix-missing-event-call-for-entity-teleport-API.patch
@@ -0,0 +1,28 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: booky10 <[email protected]>
+Date: Sun, 12 Nov 2023 05:09:47 +0100
+Subject: [PATCH] Fix missing event call for entity teleport API
+
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
+index a8b9b50991361160880b9fc0a94cad30c319e62e..b8eb9166e44da8745a056bf68f2f9316ce25d7a7 100644
+--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
+@@ -258,6 +258,17 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity {
+ return false;
+ }
+
++ // Paper start - fix teleport event not being called
++ org.bukkit.event.entity.EntityTeleportEvent event = new org.bukkit.event.entity.EntityTeleportEvent(
++ this, this.getLocation(), location);
++ // cancelling the event is handled differently for players and entities,
++ // entities just stop teleporting, players will still teleport to the "from" location of the event
++ if (!event.callEvent() || event.getTo() == null) {
++ return false;
++ }
++ location = event.getTo();
++ // Paper end
++
+ // If this entity is riding another entity, we must dismount before teleporting.
+ if (dismount) this.entity.stopRiding(); // Paper - Teleport passenger API
+