2015-04-09 05:41:04 +02:00
|
|
|
From 51854cf382ae9ba6fe8a2da3151479ec09b5bb9c Mon Sep 17 00:00:00 2001
|
2014-07-21 22:46:54 +02:00
|
|
|
From: Andrew Krieger <Slizyboy@hotmail.com>
|
|
|
|
Date: Tue, 24 Dec 2013 07:55:23 -0800
|
|
|
|
Subject: [PATCH] Cross World Entity Teleportation
|
|
|
|
|
|
|
|
Use Entity.teleportTo for cross-world teleportation in CraftEntity.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
|
2015-02-26 11:40:16 +01:00
|
|
|
index 9df27e3..9030f2c 100644
|
2014-07-21 22:46:54 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java
|
2015-01-05 03:01:24 +01:00
|
|
|
@@ -231,7 +231,14 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity {
|
2014-08-18 17:43:17 +02:00
|
|
|
// If this entity is riding another entity, we must dismount before teleporting.
|
|
|
|
entity.mount(null);
|
2014-07-21 22:46:54 +02:00
|
|
|
|
|
|
|
- entity.world = ((CraftWorld) location.getWorld()).getHandle();
|
|
|
|
+ // Spigot start
|
|
|
|
+ if (!location.getWorld().equals(getWorld())) {
|
|
|
|
+ entity.teleportTo(location, cause.equals(TeleportCause.NETHER_PORTAL));
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // entity.world = ((CraftWorld) location.getWorld()).getHandle();
|
|
|
|
+ // Spigot end
|
|
|
|
entity.setLocation(location.getX(), location.getY(), location.getZ(), location.getYaw(), location.getPitch());
|
|
|
|
// entity.setLocation() throws no event, and so cannot be cancelled
|
|
|
|
return true;
|
|
|
|
--
|
2014-11-28 02:17:45 +01:00
|
|
|
2.1.0
|
2014-07-21 22:46:54 +02:00
|
|
|
|