Add Moving Piston API (#7019)
This commit is contained in:
parent
d713b47b14
commit
6665076342
|
@ -0,0 +1,55 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
|
||||||
|
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();
|
||||||
|
+
|
||||||
|
+}
|
|
@ -0,0 +1,42 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
|
||||||
|
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
|
||||||
|
}
|
Loading…
Reference in New Issue