aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorOwen <[email protected]>2022-10-22 20:37:37 -0400
committerGitHub <[email protected]>2022-10-22 19:37:37 -0500
commit66650763422698310e1d0b73f75267d88092cea0 (patch)
treef0b2a15592b0775576bb4b33e76d05ff932a44a1
parentd713b47b1469fb811a8d7bde92d451a608fb8d0d (diff)
downloadPaper-66650763422698310e1d0b73f75267d88092cea0.tar.gz
Paper-66650763422698310e1d0b73f75267d88092cea0.zip
Add Moving Piston API (#7019)
-rw-r--r--patches/api/0406-Add-Moving-Piston-API.patch55
-rw-r--r--patches/server/0934-Add-Moving-Piston-API.patch42
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
+ }