diff options
author | Owen <[email protected]> | 2022-10-22 20:37:37 -0400 |
---|---|---|
committer | GitHub <[email protected]> | 2022-10-22 19:37:37 -0500 |
commit | 66650763422698310e1d0b73f75267d88092cea0 (patch) | |
tree | f0b2a15592b0775576bb4b33e76d05ff932a44a1 | |
parent | d713b47b1469fb811a8d7bde92d451a608fb8d0d (diff) | |
download | Paper-66650763422698310e1d0b73f75267d88092cea0.tar.gz Paper-66650763422698310e1d0b73f75267d88092cea0.zip |
Add Moving Piston API (#7019)
-rw-r--r-- | patches/api/0406-Add-Moving-Piston-API.patch | 55 | ||||
-rw-r--r-- | patches/server/0934-Add-Moving-Piston-API.patch | 42 |
2 files changed, 97 insertions, 0 deletions
diff --git a/patches/api/0406-Add-Moving-Piston-API.patch b/patches/api/0406-Add-Moving-Piston-API.patch new file mode 100644 index 0000000000..8f889f1e3d --- /dev/null +++ b/patches/api/0406-Add-Moving-Piston-API.patch @@ -0,0 +1,55 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Owen1212055 <[email protected]> +Date: Sat, 4 Dec 2021 13:29:45 -0500 +Subject: [PATCH] Add Moving Piston API + + +diff --git a/src/main/java/io/papermc/paper/block/MovingPiston.java b/src/main/java/io/papermc/paper/block/MovingPiston.java +new file mode 100644 +index 0000000000000000000000000000000000000000..ee7c85abf66dc11920bb29f9ce3b407121a665ee +--- /dev/null ++++ b/src/main/java/io/papermc/paper/block/MovingPiston.java +@@ -0,0 +1,43 @@ ++package io.papermc.paper.block; ++ ++import org.bukkit.block.BlockFace; ++import org.bukkit.block.TileState; ++import org.bukkit.block.data.BlockData; ++import org.jetbrains.annotations.NotNull; ++ ++public interface MovingPiston extends TileState { ++ ++ /** ++ * Gets the block that is being pushed ++ * ++ * @return the pushed block ++ */ ++ @NotNull ++ BlockData getMovingBlock(); ++ ++ /** ++ * The direction that the current moving piston ++ * is pushing/pulling a block in. ++ * ++ * @return the direction ++ */ ++ @NotNull ++ BlockFace getDirection(); ++ ++ /** ++ * Gets if the piston is extending or not. ++ * Returns false if the piston is retracting. ++ * ++ * @return is extending or not ++ */ ++ boolean isExtending(); ++ ++ /** ++ * Returns if this moving piston represents the main piston head ++ * from the original piston. ++ * ++ * @return is the piston head or not ++ */ ++ boolean isPistonHead(); ++ ++} diff --git a/patches/server/0934-Add-Moving-Piston-API.patch b/patches/server/0934-Add-Moving-Piston-API.patch new file mode 100644 index 0000000000..53df041ba1 --- /dev/null +++ b/patches/server/0934-Add-Moving-Piston-API.patch @@ -0,0 +1,42 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Owen1212055 <[email protected]> +Date: Sat, 4 Dec 2021 13:29:36 -0500 +Subject: [PATCH] Add Moving Piston API + + +diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftMovingPiston.java b/src/main/java/org/bukkit/craftbukkit/block/CraftMovingPiston.java +index 04857cc934daee87e8bff1a8bbd8ade349c3952b..b779b4abbf3c257c2aa90697b2ed43172290bf73 100644 +--- a/src/main/java/org/bukkit/craftbukkit/block/CraftMovingPiston.java ++++ b/src/main/java/org/bukkit/craftbukkit/block/CraftMovingPiston.java +@@ -3,9 +3,30 @@ package org.bukkit.craftbukkit.block; + import net.minecraft.world.level.block.piston.PistonMovingBlockEntity; + import org.bukkit.World; + +-public class CraftMovingPiston extends CraftBlockEntityState<PistonMovingBlockEntity> { ++public class CraftMovingPiston extends CraftBlockEntityState<PistonMovingBlockEntity> implements io.papermc.paper.block.MovingPiston { // Paper - Add Moving Piston API + + public CraftMovingPiston(World world, PistonMovingBlockEntity tileEntity) { + super(world, tileEntity); + } ++ // Paper start - Add Moving Piston API ++ @Override ++ public org.bukkit.block.data.BlockData getMovingBlock() { ++ return org.bukkit.craftbukkit.block.data.CraftBlockData.fromData(this.getTileEntity().getMovedState()); ++ } ++ ++ @Override ++ public org.bukkit.block.BlockFace getDirection() { ++ return org.bukkit.craftbukkit.block.CraftBlock.notchToBlockFace(this.getTileEntity().getDirection()); ++ } ++ ++ @Override ++ public boolean isExtending() { ++ return this.getTileEntity().isExtending(); ++ } ++ ++ @Override ++ public boolean isPistonHead() { ++ return this.getTileEntity().isSourcePiston(); ++ } ++ // Paper end - Add Moving Piston API + } |