testserver/Spigot-Server-Patches/0005-Teleport-passenger-veh...

97 lines
4.2 KiB
Diff
Raw Normal View History

2014-11-28 01:17:45 +00:00
From d5d998345385422fa5f96941068f849fbaa69558 Mon Sep 17 00:00:00 2001
From: Zach Brown <Zbob750@live.com>
Date: Fri, 28 Nov 2014 00:24:18 -0600
2014-06-22 20:28:51 +00:00
Subject: [PATCH] Teleport passenger/vehicle with player
diff --git a/src/main/java/net/minecraft/server/Entity.java b/src/main/java/net/minecraft/server/Entity.java
2014-11-28 01:17:45 +00:00
index b0a90d7..1e5f057 100644
2014-06-22 20:28:51 +00:00
--- a/src/main/java/net/minecraft/server/Entity.java
+++ b/src/main/java/net/minecraft/server/Entity.java
2014-11-28 01:17:45 +00:00
@@ -40,6 +40,13 @@ public abstract class Entity implements ICommandListener {
2014-06-22 20:28:51 +00:00
return tag.hasKey("Bukkit.updateLevel") && tag.getInt("Bukkit.updateLevel") >= level;
}
2014-11-28 01:17:45 +00:00
// CraftBukikt end
+ // PaperSpigot start - Teleport passenger vehicle with player
2014-06-22 20:28:51 +00:00
+ public void retrack() {
+ final EntityTracker entityTracker = ((WorldServer) world).getTracker();
+ entityTracker.untrackEntity(this);
+ entityTracker.track(this);
+ }
+ // PaperSpigot end
2014-11-28 01:17:45 +00:00
private static final AxisAlignedBB a = new AxisAlignedBB(0.0D, 0.0D, 0.0D, 0.0D, 0.0D, 0.0D);
2014-06-22 20:28:51 +00:00
private static int entityCount;
2014-11-28 01:17:45 +00:00
@@ -1949,7 +1956,7 @@ public abstract class Entity implements ICommandListener {
// minecraftserver.getPlayerList().changeWorld(this, j, worldserver, worldserver1);
2014-06-22 20:28:51 +00:00
boolean before = worldserver1.chunkProviderServer.forceChunkLoad;
worldserver1.chunkProviderServer.forceChunkLoad = true;
- worldserver1.getMinecraftServer().getPlayerList().repositionEntity(this, exit, portal);
+ //worldserver1.getMinecraftServer().getPlayerList().repositionEntity(this, exit, portal); // PaperSpigot - no... this entity is dead
worldserver1.chunkProviderServer.forceChunkLoad = before;
// CraftBukkit end
this.world.methodProfiler.c("reloading");
2014-11-28 01:17:45 +00:00
@@ -1957,6 +1964,10 @@ public abstract class Entity implements ICommandListener {
2014-06-22 20:28:51 +00:00
if (entity != null) {
2014-11-28 01:17:45 +00:00
entity.n(this);
2014-06-22 20:28:51 +00:00
+ // PaperSpigot start - move entity to new location
+ exit.getBlock(); // force load
+ entity.setLocation(exit.getX(), exit.getY(), exit.getZ(), exit.getYaw(), exit.getPitch());
+ // PaperSpigot end
/* CraftBukkit start - We need to do this...
if (j == 1 && i == 1) {
2014-11-28 01:17:45 +00:00
BlockPosition blockposition = this.world.r(worldserver1.getSpawn());
2014-06-22 20:28:51 +00:00
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
2014-11-28 01:17:45 +00:00
index 5864a51..2d4398e 100644
2014-06-22 20:28:51 +00:00
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
2014-11-28 01:17:45 +00:00
@@ -453,6 +453,26 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
// If this player is riding another entity, we must dismount before teleporting.
entity.mount(null);
2014-06-22 20:28:51 +00:00
+ // PaperSpigot start
+ Entity vehicle = entity.vehicle;
+ Entity passenger = entity.passenger;
+ if (vehicle != null) {
+ vehicle.passenger = null;
+ vehicle.teleportTo(location, false);
+ vehicle = vehicle.getBukkitEntity().getHandle();
+ entity.vehicle = vehicle;
2014-11-28 01:17:45 +00:00
+ entity.passenger = entity;
2014-06-22 20:28:51 +00:00
+ }
+
+ if (passenger != null) {
+ passenger.vehicle = null;
+ passenger.teleportTo(location, false);
+ passenger = passenger.getBukkitEntity().getHandle();
+ entity.passenger = passenger;
+ entity.vehicle = entity;
+ }
+ // PaperSpigot end
+
// Update the From Location
from = event.getFrom();
// Grab the new To Location dependent on whether the event was cancelled.
2014-11-28 01:17:45 +00:00
@@ -472,6 +492,17 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
2014-06-22 20:28:51 +00:00
} else {
server.getHandle().moveToWorld(entity, toWorld.dimension, true, to, true);
}
+
+ // PaperSpigot start
+ if (vehicle != null) {
+ vehicle.retrack();
+ }
2014-11-28 01:17:45 +00:00
+
2014-06-22 20:28:51 +00:00
+ if (passenger != null) {
+ passenger.retrack();
+ }
+ // PaperSpigot end
2014-11-28 01:17:45 +00:00
+
2014-06-22 20:28:51 +00:00
return true;
}
--
1.9.1