summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMatthew <stteg@hotmail.com>2016-03-16 21:30:40 -0400
committermd_5 <git@md-5.net>2016-03-18 14:30:03 +1100
commit205982588ff34bdd4885472d3eba4a26860fca7c (patch)
treedac6c4df1e94940ac722c56730caa9ac2230d6ba /src
parentda444904c207e8030a50c084f864b37e3d5a763a (diff)
downloadcraftbukkit-205982588ff34bdd4885472d3eba4a26860fca7c.tar
craftbukkit-205982588ff34bdd4885472d3eba4a26860fca7c.tar.gz
craftbukkit-205982588ff34bdd4885472d3eba4a26860fca7c.tar.lz
craftbukkit-205982588ff34bdd4885472d3eba4a26860fca7c.tar.xz
craftbukkit-205982588ff34bdd4885472d3eba4a26860fca7c.zip
Implement EndGateway#getExitLocation and EndGateway#setExitLocation(Location)
Diffstat (limited to 'src')
-rw-r--r--src/main/java/org/bukkit/craftbukkit/block/CraftEndGateway.java25
1 files changed, 23 insertions, 2 deletions
diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftEndGateway.java b/src/main/java/org/bukkit/craftbukkit/block/CraftEndGateway.java
index ed0e609d..0828b36e 100644
--- a/src/main/java/org/bukkit/craftbukkit/block/CraftEndGateway.java
+++ b/src/main/java/org/bukkit/craftbukkit/block/CraftEndGateway.java
@@ -1,6 +1,8 @@
package org.bukkit.craftbukkit.block;
+import net.minecraft.server.BlockPosition;
import net.minecraft.server.TileEntityEndGateway;
+import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.block.Block;
import org.bukkit.block.EndGateway;
@@ -8,19 +10,38 @@ import org.bukkit.craftbukkit.CraftWorld;
public class CraftEndGateway extends CraftBlockState implements EndGateway {
- private TileEntityEndGateway gateway;
+ private final CraftWorld world;
+ private final TileEntityEndGateway gateway;
public CraftEndGateway(Block block) {
super(block);
- CraftWorld world = (CraftWorld) block.getWorld();
+ world = (CraftWorld) block.getWorld();
gateway = (TileEntityEndGateway) world.getTileEntityAt(getX(), getY(), getZ());
}
public CraftEndGateway(final Material material, TileEntityEndGateway te) {
super(material);
+ world = null;
this.gateway = te;
}
+
+ @Override
+ public Location getExitLocation() {
+ BlockPosition pos = gateway.h; // PAIL: Rename exitLocation
+ return pos == null ? null : new Location(world, pos.getX(), pos.getY(), pos.getZ());
+ }
+
+ @Override
+ public void setExitLocation(Location location) {
+ if (location == null) {
+ gateway.h = null;
+ } else if (location.getWorld() != world) {
+ throw new IllegalArgumentException("Cannot set exit location to different world");
+ } else {
+ gateway.h = new BlockPosition(location.getBlockX(), location.getBlockY(), location.getBlockZ());
+ }
+ }
@Override
public boolean update(boolean force, boolean applyPhysics) {