aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0912-Fix-missing-event-call-for-entity-teleport-API.patch
diff options
context:
space:
mode:
authorJakub Zacek <[email protected]>2024-07-15 23:35:51 +0200
committerGitHub <[email protected]>2024-07-15 17:35:51 -0400
commit2cd8c461af74f0a524878dcdffba86cd105c48c6 (patch)
treeac107a76fe3d6cdd2e6ef5804ef3cba152957e4c /patches/server/0912-Fix-missing-event-call-for-entity-teleport-API.patch
parentb57b24d549c65ddc5eb3edcc1ecc6aad2826dbd8 (diff)
downloadPaper-2cd8c461af74f0a524878dcdffba86cd105c48c6.tar.gz
Paper-2cd8c461af74f0a524878dcdffba86cd105c48c6.zip
Add OMINOUS_ITEM_SPAWNER SpawnReason (#10897)
Diffstat (limited to 'patches/server/0912-Fix-missing-event-call-for-entity-teleport-API.patch')
-rw-r--r--patches/server/0912-Fix-missing-event-call-for-entity-teleport-API.patch28
1 files changed, 28 insertions, 0 deletions
diff --git a/patches/server/0912-Fix-missing-event-call-for-entity-teleport-API.patch b/patches/server/0912-Fix-missing-event-call-for-entity-teleport-API.patch
new file mode 100644
index 0000000000..79cebb8989
--- /dev/null
+++ b/patches/server/0912-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
+