mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-04 10:11:29 +01:00
58 lines
3.3 KiB
Diff
58 lines
3.3 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: commandblockguy <commandblockguy1@gmail.com>
|
||
|
Date: Fri, 14 Aug 2020 14:44:14 -0500
|
||
|
Subject: [PATCH] Prevent headless pistons from being created
|
||
|
|
||
|
Prevent headless pistons from being created by explosions or tree/mushroom growth.
|
||
|
|
||
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperConfig.java b/src/main/java/com/destroystokyo/paper/PaperConfig.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/com/destroystokyo/paper/PaperConfig.java
|
||
|
+++ b/src/main/java/com/destroystokyo/paper/PaperConfig.java
|
||
|
@@ -0,0 +0,0 @@ public class PaperConfig {
|
||
|
set("settings.unsupported-settings.allow-tnt-duplication", null);
|
||
|
}
|
||
|
|
||
|
+ public static boolean allowHeadlessPistons;
|
||
|
+ private static void allowHeadlessPistons() {
|
||
|
+ config.set("settings.unsupported-settings.allow-headless-pistons-readme", "This setting controls if players should be able to create headless pistons.");
|
||
|
+ allowHeadlessPistons = getBoolean("settings.unsupported-settings.allow-headless-pistons", false);
|
||
|
+ }
|
||
|
+
|
||
|
public static int playerAutoSaveRate = -1;
|
||
|
public static int maxPlayerAutoSavePerTick = 10;
|
||
|
private static void playerAutoSaveRate() {
|
||
|
diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/server/Explosion.java
|
||
|
+++ b/src/main/java/net/minecraft/server/Explosion.java
|
||
|
@@ -0,0 +0,0 @@ public class Explosion {
|
||
|
|
||
|
if (f > 0.0F && this.l.a(this, this.world, blockposition, iblockdata, f) && blockposition.getY() < 256 && blockposition.getY() >= 0) { // CraftBukkit - don't wrap explosions
|
||
|
set.add(blockposition);
|
||
|
+ // Paper start - prevent headless pistons from forming
|
||
|
+ if (!com.destroystokyo.paper.PaperConfig.allowHeadlessPistons && iblockdata.getBlock() == Blocks.MOVING_PISTON) {
|
||
|
+ TileEntityPiston extension = (TileEntityPiston)this.world.getTileEntity(blockposition);
|
||
|
+ if (extension.isHead()) {
|
||
|
+ EnumDirection direction = iblockdata.get(BlockPistonExtension.FACING);
|
||
|
+ set.add(blockposition.shift(direction.opposite()));
|
||
|
+ }
|
||
|
+ }
|
||
|
+ // Paper end
|
||
|
}
|
||
|
|
||
|
d4 += d0 * 0.30000001192092896D;
|
||
|
diff --git a/src/main/java/net/minecraft/server/TileEntityPiston.java b/src/main/java/net/minecraft/server/TileEntityPiston.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/server/TileEntityPiston.java
|
||
|
+++ b/src/main/java/net/minecraft/server/TileEntityPiston.java
|
||
|
@@ -0,0 +0,0 @@ public class TileEntityPiston extends TileEntity implements ITickable {
|
||
|
return this.b;
|
||
|
}
|
||
|
|
||
|
+ public final boolean isHead() { return this.h(); } // Paper - OBFHELPER
|
||
|
+
|
||
|
public boolean h() {
|
||
|
return this.g;
|
||
|
}
|